Files
shields/services/puppetforge/puppetforge-base.js
chris48s 8621fe42d7 Upgrade Joi (#3505)
* upgrade joi
* find & replace ALL THE THINGS
* update related deps
2019-06-02 21:59:55 +01:00

58 lines
1.4 KiB
JavaScript

'use strict'
const Joi = require('@hapi/joi')
const { BaseJsonService } = require('..')
const { nonNegativeInteger, semver } = require('../validators')
const usersSchema = Joi.object({
module_count: nonNegativeInteger,
release_count: nonNegativeInteger,
}).required()
const modulesSchema = Joi.object({
endorsement: Joi.string().allow(null),
feedback_score: Joi.number()
.integer()
.min(0)
.allow(null),
downloads: nonNegativeInteger,
current_release: Joi.alternatives(
Joi.object({
pdk: Joi.boolean()
.valid(true)
.required(),
version: semver,
metadata: Joi.object({ 'pdk-version': semver }).required(),
}).required(),
Joi.object({
pdk: Joi.boolean()
.valid(false)
.required(),
version: semver,
}).required()
),
}).required()
class BasePuppetForgeUsersService extends BaseJsonService {
async fetch({ user }) {
return this._requestJson({
schema: usersSchema,
url: `https://forgeapi.puppetlabs.com/v3/users/${user}`,
})
}
}
class BasePuppetForgeModulesService extends BaseJsonService {
async fetch({ user, moduleName }) {
return this._requestJson({
schema: modulesSchema,
url: `https://forgeapi.puppetlabs.com/v3/modules/${user}-${moduleName}`,
})
}
}
module.exports = {
BasePuppetForgeModulesService,
BasePuppetForgeUsersService,
}