0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-06 20:40:08 -05:00

Merge pull request #80 from logto-io/gao-log-2

feat: init application api
This commit is contained in:
Gao Sun 2021-08-14 21:45:35 +08:00 committed by GitHub
commit 0704d21601
7 changed files with 67 additions and 2 deletions

View file

@ -1,6 +1,6 @@
import pick from 'lodash.pick';
import i18next from 'i18next';
import { LogtoErrorCode } from '@logto/phrases';
import { LogtoErrorCode, LogtoErrorI18nKey } from '@logto/phrases';
import { RequestErrorBody, RequestErrorMetadata } from '@logto/schemas';
export default class RequestError extends Error {
@ -11,7 +11,7 @@ export default class RequestError extends Error {
constructor(input: RequestErrorMetadata | LogtoErrorCode, data?: unknown) {
const { code, status = 400 } = typeof input === 'string' ? { code: input } : input;
const message = i18next.t<string, LogtoErrorCode>(code);
const message = i18next.t<string, LogtoErrorI18nKey>(`errors:${code}`);
super(message);

View file

@ -0,0 +1,28 @@
import assert from 'assert';
import RequestError from '@/errors/RequestError';
import { RequestErrorBody } from '@logto/schemas';
import { Middleware } from 'koa';
const bearerToken = 'Bearer';
export default function koaAuth<StateT, ContextT>(): Middleware<
StateT,
ContextT,
RequestErrorBody
> {
return async (ctx, next) => {
const { authorization } = ctx.request.headers;
assert(
authorization,
new RequestError({ code: 'auth.authorization_header_missing', status: 401 })
);
assert(
authorization.startsWith(bearerToken),
new RequestError(
{ code: 'auth.authorization_type_not_supported', status: 401 },
{ supportedTypes: [bearerToken] }
)
);
return next();
};
}

View file

@ -0,0 +1,24 @@
import Router from 'koa-router';
import { nativeEnum, object, string } from 'zod';
import { ApplicationType } from '@logto/schemas';
import koaGuard from '@/middleware/koa-guard';
import koaAuth from '@/middleware/koa-auth';
export default function applicationRoutes(router: Router) {
router.use('/application', koaAuth());
router.post(
'/application',
koaGuard({
body: object({
name: string().min(1),
type: nativeEnum(ApplicationType),
}),
}),
async (ctx, next) => {
const { name, type } = ctx.guard.body;
ctx.body = { name, type };
return next();
}
);
}

View file

@ -5,12 +5,14 @@ import sessionRoutes from '@/routes/session';
import userRoutes from '@/routes/user';
import swaggerRoutes from '@/routes/swagger';
import mount from 'koa-mount';
import applicationRoutes from './application';
const createRouter = (provider: Provider): Router => {
const router = new Router();
sessionRoutes(router, provider);
userRoutes(router);
applicationRoutes(router);
swaggerRoutes(router);
return router;

View file

@ -3,6 +3,7 @@ import zhCN from './locales/zh-cn';
import { Normalize, Resource } from './types';
export type LogtoErrorCode = Normalize<typeof en.errors>;
export type LogtoErrorI18nKey = `errors:${LogtoErrorCode}`;
const resource: Resource = {
en,

View file

@ -15,6 +15,11 @@ const translation = {
};
const errors = {
auth: {
authorization_header_missing: 'Authorization header is missing.',
authorization_type_not_supported: 'Authorization type is not supported.',
unauthorized: 'Unauthorized. Please check credentils and its scope.',
},
guard: {
invalid_input: 'The request input is invalid.',
},

View file

@ -17,6 +17,11 @@ const translation = {
};
const errors = {
auth: {
authorization_header_missing: 'Authorization 请求 header 遗漏。',
authorization_type_not_supported: '不支持的 authorization 类型。',
unauthorized: '未授权。请检查相关 credentials 和 scope。',
},
guard: {
invalid_input: '请求内容有误。',
},