mirror of
https://github.com/logto-io/logto.git
synced 2025-01-06 20:40:08 -05:00
feat: init application api
This commit is contained in:
parent
25d4f15b8e
commit
bb7c8184f7
7 changed files with 67 additions and 2 deletions
|
@ -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);
|
||||
|
||||
|
|
28
packages/core/src/middleware/koa-auth.ts
Normal file
28
packages/core/src/middleware/koa-auth.ts
Normal 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();
|
||||
};
|
||||
}
|
24
packages/core/src/routes/application.ts
Normal file
24
packages/core/src/routes/application.ts
Normal 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();
|
||||
}
|
||||
);
|
||||
}
|
|
@ -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;
|
||||
|
|
|
@ -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,
|
||||
|
|
|
@ -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.',
|
||||
},
|
||||
|
|
|
@ -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: '请求内容有误。',
|
||||
},
|
||||
|
|
Loading…
Reference in a new issue