Compare commits
1 Commits
60c5a986ed
...
162d4c72b4
Author | SHA1 | Date | |
---|---|---|---|
162d4c72b4 |
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@kevisual/code-center-module",
|
"name": "@kevisual/code-center-module",
|
||||||
"version": "0.0.16",
|
"version": "0.0.17",
|
||||||
"description": "",
|
"description": "",
|
||||||
"main": "dist/system.mjs",
|
"main": "dist/system.mjs",
|
||||||
"module": "dist/system.mjs",
|
"module": "dist/system.mjs",
|
||||||
|
@@ -4,7 +4,9 @@
|
|||||||
import { UserServices, User, UserInit, UserModel } from './models/user.ts';
|
import { UserServices, User, UserInit, UserModel } from './models/user.ts';
|
||||||
import { Org, OrgInit, OrgModel } from './models/org.ts';
|
import { Org, OrgInit, OrgModel } from './models/org.ts';
|
||||||
import { addAuth } from './middleware/auth.ts';
|
import { addAuth } from './middleware/auth.ts';
|
||||||
|
import { checkAuth, getLoginUser } from './middleware/auth-manual.ts';
|
||||||
export { User, Org, UserServices, UserInit, OrgInit, UserModel, OrgModel };
|
export { User, Org, UserServices, UserInit, OrgInit, UserModel, OrgModel };
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 可以不需要user成功, 有则赋值,交给下一个中间件
|
* 可以不需要user成功, 有则赋值,交给下一个中间件
|
||||||
*/
|
*/
|
||||||
@@ -13,4 +15,5 @@ export const authCan = 'auth-can';
|
|||||||
* 必须需要user成功
|
* 必须需要user成功
|
||||||
*/
|
*/
|
||||||
export const auth = 'auth';
|
export const auth = 'auth';
|
||||||
export { addAuth };
|
|
||||||
|
export { addAuth, checkAuth, getLoginUser };
|
||||||
|
72
src/middleware/auth-manual.ts
Normal file
72
src/middleware/auth-manual.ts
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
import { User } from '../models/user.ts';
|
||||||
|
import http from 'http';
|
||||||
|
import cookie from 'cookie';
|
||||||
|
export const error = (msg: string, code = 500) => {
|
||||||
|
return JSON.stringify({ code, message: msg });
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* 手动验证token,如果token不存在,则返回401
|
||||||
|
* @param req
|
||||||
|
* @param res
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
export const checkAuth = async (req: http.IncomingMessage, res: http.ServerResponse) => {
|
||||||
|
let token = (req.headers?.['authorization'] as string) || (req.headers?.['Authorization'] as string) || '';
|
||||||
|
const url = new URL(req.url || '', 'http://localhost');
|
||||||
|
const resNoPermission = () => {
|
||||||
|
res.statusCode = 401;
|
||||||
|
res.end(error('Invalid authorization'));
|
||||||
|
return { tokenUser: null, token: null };
|
||||||
|
};
|
||||||
|
if (!token) {
|
||||||
|
token = url.searchParams.get('token') || '';
|
||||||
|
}
|
||||||
|
if (!token) {
|
||||||
|
const parsedCookies = cookie.parse(req.headers.cookie || '');
|
||||||
|
token = parsedCookies.token || '';
|
||||||
|
}
|
||||||
|
if (!token) {
|
||||||
|
return resNoPermission();
|
||||||
|
}
|
||||||
|
if (token) {
|
||||||
|
token = token.replace('Bearer ', '');
|
||||||
|
}
|
||||||
|
let tokenUser;
|
||||||
|
try {
|
||||||
|
tokenUser = await User.verifyToken(token);
|
||||||
|
} catch (e) {
|
||||||
|
console.log('checkAuth error', e);
|
||||||
|
res.statusCode = 401;
|
||||||
|
res.end(error('Invalid token'));
|
||||||
|
return { tokenUser: null, token: null };
|
||||||
|
}
|
||||||
|
return { tokenUser, token };
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取登录用户,有则获取,无则返回null
|
||||||
|
* @param req
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
export const getLoginUser = async (req: http.IncomingMessage) => {
|
||||||
|
let token = (req.headers?.['authorization'] as string) || (req.headers?.['Authorization'] as string) || '';
|
||||||
|
const url = new URL(req.url || '', 'http://localhost');
|
||||||
|
if (!token) {
|
||||||
|
token = url.searchParams.get('token') || '';
|
||||||
|
}
|
||||||
|
if (!token) {
|
||||||
|
const parsedCookies = cookie.parse(req.headers.cookie || '');
|
||||||
|
token = parsedCookies.token || '';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (token) {
|
||||||
|
token = token.replace('Bearer ', '');
|
||||||
|
}
|
||||||
|
let tokenUser;
|
||||||
|
try {
|
||||||
|
tokenUser = await User.verifyToken(token);
|
||||||
|
return { tokenUser, token };
|
||||||
|
} catch (e) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
@@ -1,9 +1,15 @@
|
|||||||
import { Redis } from 'ioredis';
|
import { Redis } from 'ioredis';
|
||||||
import { useConfig } from '@kevisual/use-config';
|
import { useConfig } from '@kevisual/use-config/env';
|
||||||
import { useContextKey } from '@kevisual/use-config/context';
|
import { useContextKey } from '@kevisual/use-config/context';
|
||||||
const config = useConfig<{
|
const configEnv = useConfig();
|
||||||
redis: ConstructorParameters<typeof Redis>;
|
|
||||||
}>();
|
const redisConfig = {
|
||||||
|
host: configEnv.REDIS_HOST || 'localhost',
|
||||||
|
port: configEnv.REDIS_PORT ? parseInt(configEnv.REDIS_PORT) : 6379,
|
||||||
|
password: configEnv.REDIS_PASSWORD || undefined,
|
||||||
|
db: configEnv.REDIS_DB ? parseInt(configEnv.REDIS_DB) : 0,
|
||||||
|
};
|
||||||
|
|
||||||
// 配置 Redis 连接
|
// 配置 Redis 连接
|
||||||
export const redis = new Redis({
|
export const redis = new Redis({
|
||||||
host: 'localhost', // Redis 服务器的主机名或 IP 地址
|
host: 'localhost', // Redis 服务器的主机名或 IP 地址
|
||||||
@@ -16,7 +22,6 @@ export const redis = new Redis({
|
|||||||
return Math.min(times * 50, 2000); // 每次重试时延迟增加
|
return Math.min(times * 50, 2000); // 每次重试时延迟增加
|
||||||
},
|
},
|
||||||
maxRetriesPerRequest: null, // 允许请求重试的次数 (如果需要无限次重试)
|
maxRetriesPerRequest: null, // 允许请求重试的次数 (如果需要无限次重试)
|
||||||
...config.redis,
|
|
||||||
});
|
});
|
||||||
useContextKey('redis', () => redis);
|
useContextKey('redis', () => redis);
|
||||||
// 监听连接事件
|
// 监听连接事件
|
||||||
|
@@ -1,19 +1,16 @@
|
|||||||
import { useConfig } from '@kevisual/use-config';
|
import { useConfig } from '@kevisual/use-config/env';
|
||||||
import { Sequelize } from 'sequelize';
|
import { Sequelize } from 'sequelize';
|
||||||
import { useContextKey, useContext } from '@kevisual/use-config/context';
|
import { useContextKey } from '@kevisual/use-config/context';
|
||||||
|
|
||||||
type PostgresConfig = {
|
const configEnv = useConfig();
|
||||||
postgres: {
|
|
||||||
username: string;
|
const postgresConfig = {
|
||||||
password: string;
|
username: configEnv.POSTGRES_USERNAME,
|
||||||
host: string;
|
password: configEnv.POSTGRES_PASSWORD,
|
||||||
port: number;
|
host: configEnv.POSTGRES_HOST,
|
||||||
database: string;
|
port: configEnv.POSTGRES_PORT ? parseInt(configEnv.POSTGRES_PORT) : 5432,
|
||||||
};
|
database: configEnv.POSTGRES_DATABASE,
|
||||||
};
|
};
|
||||||
const config = useConfig<PostgresConfig>();
|
|
||||||
|
|
||||||
const postgresConfig = config.postgres;
|
|
||||||
|
|
||||||
if (!postgresConfig) {
|
if (!postgresConfig) {
|
||||||
console.error('postgres config is required');
|
console.error('postgres config is required');
|
||||||
|
@@ -1,7 +1,6 @@
|
|||||||
/**
|
/**
|
||||||
* 直接开发业务代码,把redis和sequelize的初始化放到库当中。
|
* 直接开发业务代码,把redis和sequelize的初始化放到库当中。
|
||||||
*/
|
*/
|
||||||
import { useConfig } from '@kevisual/use-config';
|
|
||||||
import { app } from './app.ts';
|
import { app } from './app.ts';
|
||||||
import * as sequelizeLib from './modules/sequelize.ts';
|
import * as sequelizeLib from './modules/sequelize.ts';
|
||||||
export const sequelize = useContextKey('sequelize', () => sequelizeLib.sequelize);
|
export const sequelize = useContextKey('sequelize', () => sequelizeLib.sequelize);
|
||||||
@@ -11,7 +10,6 @@ import { Org, OrgInit, OrgModel } from './models/org.ts';
|
|||||||
|
|
||||||
import * as redisLib from './modules/redis.ts';
|
import * as redisLib from './modules/redis.ts';
|
||||||
import { useContextKey } from '@kevisual/use-config/context';
|
import { useContextKey } from '@kevisual/use-config/context';
|
||||||
useConfig();
|
|
||||||
|
|
||||||
export const redis = useContextKey('redis', () => redisLib.redis);
|
export const redis = useContextKey('redis', () => redisLib.redis);
|
||||||
export const redisPublisher = useContextKey('redisPublisher', () => redisLib.redisPublisher);
|
export const redisPublisher = useContextKey('redisPublisher', () => redisLib.redisPublisher);
|
||||||
|
Reference in New Issue
Block a user