diff options
Diffstat (limited to 'src/server/api/openapi/description.ts')
| -rw-r--r-- | src/server/api/openapi/description.ts | 37 |
1 files changed, 36 insertions, 1 deletions
diff --git a/src/server/api/openapi/description.ts b/src/server/api/openapi/description.ts index b801c86387..0a4c8699d1 100644 --- a/src/server/api/openapi/description.ts +++ b/src/server/api/openapi/description.ts @@ -1,5 +1,40 @@ import config from '../../../config'; -import { IKindInfo, kinds } from '../kinds'; +import endpoints from '../endpoints'; +import * as locale from '../../../../locales/'; +import { fromEntries } from '../../../prelude/array'; +import { kinds as kindsList } from '../kinds'; + +export interface IKindInfo { + endpoints: string[]; + descs: { [x: string]: string; }; +} + +export function kinds() { + const kinds = fromEntries( + kindsList + .map(k => [k, { + endpoints: [], + descs: fromEntries( + Object.keys(locale) + .map(l => [l, locale[l].common.permissions[k] as string] as [string, string]) + ) as { [x: string]: string; } + }] as [ string, IKindInfo ]) + ) as { [x: string]: IKindInfo; }; + + const errors = [] as string[][]; + + for (const endpoint of endpoints.filter(ep => !ep.meta.secure)) { + if (endpoint.meta.kind) { + const kind = endpoint.meta.kind; + if (kind in kinds) kinds[kind].endpoints.push(endpoint.name); + else errors.push([kind, endpoint.name]); + } + } + + if (errors.length > 0) throw Error('\n ' + errors.map((e) => `Unknown kind (permission) "${e[0]}" found at ${e[1]}.`).join('\n ')); + + return kinds; +} export function getDescription(lang = 'ja-JP'): string { const permissionTable = (Object.entries(kinds()) as [string, IKindInfo][]) |