Files
shields/services/luarocks/luarocks.service.js
chris48s 4f67ab7a09 migrate examples to openApi part5; affects [itunes jetbrains jitpack keybase lemmy luarocks maintenance openvsx] (#9431)
* migrate some services from examples to openApi

* improve and de-dupe service titles

* revert changes to jsdelivr

* Update services/jetbrains/jetbrains-downloads.service.js

Co-authored-by: Pierre-Yves Bigourdan <10694593+PyvesB@users.noreply.github.com>

---------

Co-authored-by: Pierre-Yves Bigourdan <10694593+PyvesB@users.noreply.github.com>
2023-08-21 11:16:01 +01:00

97 lines
2.3 KiB
JavaScript

import Joi from 'joi'
import { addv } from '../text-formatters.js'
import { BaseJsonService, NotFound, pathParams } from '../index.js'
import { latestVersion } from './luarocks-version-helpers.js'
const schema = Joi.object({
repository: Joi.object()
.pattern(
Joi.string(),
Joi.object().pattern(Joi.string(), Joi.array().strip()),
)
.required(),
}).required()
export default class Luarocks extends BaseJsonService {
static category = 'version'
static route = {
base: 'luarocks/v',
pattern: ':user/:moduleName/:version?',
}
static openApi = {
'/luarocks/v/{user}/{moduleName}': {
get: {
summary: 'LuaRocks',
parameters: pathParams(
{
name: 'user',
example: 'mpeterv',
},
{
name: 'moduleName',
example: 'luacheck',
},
),
},
},
}
static defaultBadgeData = {
label: 'luarocks',
}
static render({ version }) {
// The badge colors are following the heuristic rule where `scm < dev <
// stable` (e.g., `scm-1` < `dev-1` < `0.1.0-1`).
let color
switch (version.slice(0, 3).toLowerCase()) {
case 'dev':
color = 'yellow'
break
case 'scm':
case 'cvs':
color = 'orange'
break
default:
color = 'brightgreen'
}
return { message: addv(version), color }
}
async fetch({ user, moduleName }) {
const { repository } = await this._requestJson({
url: `https://luarocks.org/manifests/${encodeURIComponent(
user,
)}/manifest.json`,
schema,
httpErrors: {
404: 'user not found',
},
})
const moduleData = repository[moduleName]
if (!moduleData) {
throw new NotFound({ prettyMessage: 'module not found' })
}
return moduleData
}
async handle({ user, moduleName, version: requestedVersion }) {
const moduleInfo = await this.fetch({ user, moduleName })
let version
if (requestedVersion) {
if (!(requestedVersion in moduleInfo)) {
throw new NotFound({ prettyMessage: 'version not found' })
}
version = requestedVersion
} else {
const versions = Object.keys(moduleInfo)
version = latestVersion(versions)
}
return this.constructor.render({ version })
}
}