mirror of
https://github.com/DIYgod/RSSHub.git
synced 2025-12-03 02:28:23 +08:00
feat: support package
This commit is contained in:
80
lib/app.js
Normal file
80
lib/app.js
Normal file
@@ -0,0 +1,80 @@
|
|||||||
|
require('dotenv').config();
|
||||||
|
require('module-alias/register');
|
||||||
|
require('./utils/request-wrapper');
|
||||||
|
|
||||||
|
const Koa = require('koa');
|
||||||
|
const logger = require('./utils/logger');
|
||||||
|
|
||||||
|
const onerror = require('./middleware/onerror');
|
||||||
|
const header = require('./middleware/header');
|
||||||
|
const utf8 = require('./middleware/utf8');
|
||||||
|
const cache = require('./middleware/cache');
|
||||||
|
const parameter = require('./middleware/parameter');
|
||||||
|
const template = require('./middleware/template');
|
||||||
|
const favicon = require('koa-favicon');
|
||||||
|
const debug = require('./middleware/debug');
|
||||||
|
const accessControl = require('./middleware/access-control');
|
||||||
|
|
||||||
|
const router = require('./router');
|
||||||
|
const protected_router = require('./protected_router');
|
||||||
|
const mount = require('koa-mount');
|
||||||
|
|
||||||
|
// API related
|
||||||
|
const apiTemplate = require('./middleware/api-template');
|
||||||
|
const api_router = require('./api_router');
|
||||||
|
const apiResponseHandler = require('./middleware/api-response-handler');
|
||||||
|
|
||||||
|
process.on('uncaughtException', (e) => {
|
||||||
|
logger.error('uncaughtException: ' + e);
|
||||||
|
});
|
||||||
|
|
||||||
|
const app = new Koa();
|
||||||
|
app.proxy = true;
|
||||||
|
|
||||||
|
// favicon
|
||||||
|
app.use(favicon(__dirname + '/favicon.png'));
|
||||||
|
|
||||||
|
// global error handing
|
||||||
|
app.use(onerror);
|
||||||
|
|
||||||
|
// 1 set header
|
||||||
|
app.use(header);
|
||||||
|
|
||||||
|
app.use(accessControl);
|
||||||
|
|
||||||
|
// 6 debug
|
||||||
|
app.context.debug = {
|
||||||
|
hitCache: 0,
|
||||||
|
request: 0,
|
||||||
|
paths: [],
|
||||||
|
routes: [],
|
||||||
|
ips: [],
|
||||||
|
errorPaths: [],
|
||||||
|
errorRoutes: [],
|
||||||
|
};
|
||||||
|
app.use(debug);
|
||||||
|
|
||||||
|
// 5 fix incorrect `utf-8` characters
|
||||||
|
app.use(utf8);
|
||||||
|
|
||||||
|
app.use(apiTemplate);
|
||||||
|
app.use(apiResponseHandler());
|
||||||
|
|
||||||
|
// 4 generate body
|
||||||
|
app.use(template);
|
||||||
|
// 3 filter content
|
||||||
|
app.use(parameter);
|
||||||
|
|
||||||
|
// 2 cache
|
||||||
|
app.use(cache(app));
|
||||||
|
|
||||||
|
// router
|
||||||
|
app.use(mount('/', router.routes())).use(router.allowedMethods());
|
||||||
|
|
||||||
|
// routes the require authentication
|
||||||
|
app.use(mount('/protected', protected_router.routes())).use(protected_router.allowedMethods());
|
||||||
|
|
||||||
|
// API router
|
||||||
|
app.use(mount('/api', api_router.routes())).use(api_router.allowedMethods());
|
||||||
|
|
||||||
|
module.exports = app;
|
||||||
91
lib/index.js
91
lib/index.js
@@ -1,95 +1,16 @@
|
|||||||
require('dotenv').config();
|
const app = require('./app');
|
||||||
require('module-alias/register');
|
|
||||||
const config = require('./config');
|
const config = require('./config');
|
||||||
const Koa = require('koa');
|
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const logger = require('./utils/logger');
|
const logger = require('./utils/logger');
|
||||||
require('./utils/request-wrapper');
|
|
||||||
|
|
||||||
const onerror = require('./middleware/onerror');
|
|
||||||
const header = require('./middleware/header');
|
|
||||||
const utf8 = require('./middleware/utf8');
|
|
||||||
const cache = require('./middleware/cache');
|
|
||||||
const parameter = require('./middleware/parameter');
|
|
||||||
const template = require('./middleware/template');
|
|
||||||
const favicon = require('koa-favicon');
|
|
||||||
const debug = require('./middleware/debug');
|
|
||||||
const accessControl = require('./middleware/access-control');
|
|
||||||
|
|
||||||
const router = require('./router');
|
|
||||||
const protected_router = require('./protected_router');
|
|
||||||
const mount = require('koa-mount');
|
|
||||||
|
|
||||||
// API related
|
|
||||||
|
|
||||||
const apiTemplate = require('./middleware/api-template');
|
|
||||||
const api_router = require('./api_router');
|
|
||||||
const apiResponseHandler = require('./middleware/api-response-handler');
|
|
||||||
|
|
||||||
const cluster = require('cluster');
|
const cluster = require('cluster');
|
||||||
const numCPUs = require('os').cpus().length;
|
const numCPUs = require('os').cpus().length;
|
||||||
|
|
||||||
if (cluster.isMaster && config.enableCluster && process.env.NODE_ENV !== 'test' && process.env.NODE_ENV !== 'dev') {
|
if (config.enableCluster && cluster.isMaster && process.env.NODE_ENV !== 'test' && process.env.NODE_ENV !== 'dev') {
|
||||||
for (let i = 0; i < numCPUs; i++) {
|
for (let i = 0; i < numCPUs; i++) {
|
||||||
cluster.fork();
|
cluster.fork();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
process.on('uncaughtException', (e) => {
|
|
||||||
logger.error('uncaughtException: ' + e);
|
|
||||||
});
|
|
||||||
|
|
||||||
logger.info('🎉 RSSHub start! Cheers!');
|
|
||||||
|
|
||||||
const app = new Koa();
|
|
||||||
app.proxy = true;
|
|
||||||
|
|
||||||
// favicon
|
|
||||||
app.use(favicon(__dirname + '/favicon.png'));
|
|
||||||
|
|
||||||
// global error handing
|
|
||||||
app.use(onerror);
|
|
||||||
|
|
||||||
// 1 set header
|
|
||||||
app.use(header);
|
|
||||||
|
|
||||||
app.use(accessControl);
|
|
||||||
|
|
||||||
// 6 debug
|
|
||||||
app.context.debug = {
|
|
||||||
hitCache: 0,
|
|
||||||
request: 0,
|
|
||||||
paths: [],
|
|
||||||
routes: [],
|
|
||||||
ips: [],
|
|
||||||
errorPaths: [],
|
|
||||||
errorRoutes: [],
|
|
||||||
};
|
|
||||||
app.use(debug);
|
|
||||||
|
|
||||||
// 5 fix incorrect `utf-8` characters
|
|
||||||
app.use(utf8);
|
|
||||||
|
|
||||||
app.use(apiTemplate);
|
|
||||||
app.use(apiResponseHandler());
|
|
||||||
|
|
||||||
// 4 generate body
|
|
||||||
app.use(template);
|
|
||||||
// 3 filter content
|
|
||||||
app.use(parameter);
|
|
||||||
|
|
||||||
// 2 cache
|
|
||||||
app.use(cache(app));
|
|
||||||
|
|
||||||
// router
|
|
||||||
app.use(mount('/', router.routes())).use(router.allowedMethods());
|
|
||||||
|
|
||||||
// routes the require authentication
|
|
||||||
app.use(mount('/protected', protected_router.routes())).use(protected_router.allowedMethods());
|
|
||||||
|
|
||||||
// API router
|
|
||||||
app.use(mount('/api', api_router.routes())).use(api_router.allowedMethods());
|
|
||||||
|
|
||||||
// connect
|
|
||||||
let server;
|
let server;
|
||||||
if (config.connect.socket) {
|
if (config.connect.socket) {
|
||||||
if (fs.existsSync(config.connect.socket)) {
|
if (fs.existsSync(config.connect.socket)) {
|
||||||
@@ -107,9 +28,7 @@ if (cluster.isMaster && config.enableCluster && process.env.NODE_ENV !== 'test'
|
|||||||
logger.info('Listening Port ' + config.connect.port);
|
logger.info('Listening Port ' + config.connect.port);
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = {
|
logger.info('🎉 RSSHub start! Cheers!');
|
||||||
server: server,
|
|
||||||
app: app,
|
module.exports = server;
|
||||||
cache: app.context.cache.client,
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|||||||
21
lib/pkg.js
Normal file
21
lib/pkg.js
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
const app = require('./app');
|
||||||
|
|
||||||
|
const pkg = (path) =>
|
||||||
|
new Promise((resolve) => {
|
||||||
|
app.callback()(
|
||||||
|
{
|
||||||
|
url: path,
|
||||||
|
method: 'GET',
|
||||||
|
headers: {},
|
||||||
|
socket: {},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
setHeader: () => {},
|
||||||
|
end: (data) => {
|
||||||
|
resolve(data);
|
||||||
|
},
|
||||||
|
}
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = pkg;
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
{
|
{
|
||||||
"name": "rsshub",
|
"name": "rsshub",
|
||||||
"version": "0.0.1",
|
"version": "1.0.0",
|
||||||
"description": "Make RSS Great Again!",
|
"description": "Make RSS Great Again!",
|
||||||
"main": "lib/index.js",
|
"main": "lib/pkg.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"start": "node lib/index.js",
|
"start": "node lib/index.js",
|
||||||
"dev": "cross-env NODE_ENV=dev nodemon --inspect lib/index.js",
|
"dev": "cross-env NODE_ENV=dev nodemon --inspect lib/index.js",
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ afterEach(() => {
|
|||||||
describe('access-control', () => {
|
describe('access-control', () => {
|
||||||
it(`blacklist`, async () => {
|
it(`blacklist`, async () => {
|
||||||
process.env.BLACKLIST = '/test/1,233.233.233.233';
|
process.env.BLACKLIST = '/test/1,233.233.233.233';
|
||||||
server = require('../../lib/index').server;
|
server = require('../../lib/index');
|
||||||
const request = supertest(server);
|
const request = supertest(server);
|
||||||
|
|
||||||
const response11 = await request.get('/test/1');
|
const response11 = await request.get('/test/1');
|
||||||
@@ -39,7 +39,7 @@ describe('access-control', () => {
|
|||||||
|
|
||||||
it(`whitelist`, async () => {
|
it(`whitelist`, async () => {
|
||||||
process.env.WHITELIST = '/test/1,233.233.233.233';
|
process.env.WHITELIST = '/test/1,233.233.233.233';
|
||||||
server = require('../../lib/index').server;
|
server = require('../../lib/index');
|
||||||
const request = supertest(server);
|
const request = supertest(server);
|
||||||
|
|
||||||
const response11 = await request.get('/test/1');
|
const response11 = await request.get('/test/1');
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ afterAll(() => {
|
|||||||
describe('cache', () => {
|
describe('cache', () => {
|
||||||
it('memory', async () => {
|
it('memory', async () => {
|
||||||
process.env.CACHE_TYPE = 'memory';
|
process.env.CACHE_TYPE = 'memory';
|
||||||
server = require('../../lib/index').server;
|
server = require('../../lib/index');
|
||||||
const request = supertest(server);
|
const request = supertest(server);
|
||||||
|
|
||||||
const response1 = await request.get('/test/cache');
|
const response1 = await request.get('/test/cache');
|
||||||
@@ -54,7 +54,7 @@ describe('cache', () => {
|
|||||||
expect(parsed3.items[0].content).toBe('Cache1');
|
expect(parsed3.items[0].content).toBe('Cache1');
|
||||||
expect(parsed4.items[0].content).toBe('Cache2');
|
expect(parsed4.items[0].content).toBe('Cache2');
|
||||||
|
|
||||||
const app = require('../../lib/index').app;
|
const app = require('../../lib/app');
|
||||||
await app.context.cache.set('mock', undefined);
|
await app.context.cache.set('mock', undefined);
|
||||||
expect(await app.context.cache.get('mock')).toBe('');
|
expect(await app.context.cache.get('mock')).toBe('');
|
||||||
|
|
||||||
@@ -68,7 +68,7 @@ describe('cache', () => {
|
|||||||
|
|
||||||
it('redis', async () => {
|
it('redis', async () => {
|
||||||
process.env.CACHE_TYPE = 'redis';
|
process.env.CACHE_TYPE = 'redis';
|
||||||
server = require('../../lib/index').server;
|
server = require('../../lib/index');
|
||||||
const request = supertest(server);
|
const request = supertest(server);
|
||||||
|
|
||||||
const response1 = await request.get('/test/cache');
|
const response1 = await request.get('/test/cache');
|
||||||
@@ -100,7 +100,7 @@ describe('cache', () => {
|
|||||||
expect(parsed3.items[0].content).toBe('Cache1');
|
expect(parsed3.items[0].content).toBe('Cache1');
|
||||||
expect(parsed4.items[0].content).toBe('Cache2');
|
expect(parsed4.items[0].content).toBe('Cache2');
|
||||||
|
|
||||||
const app = require('../../lib/index').app;
|
const app = require('../../lib/app');
|
||||||
await app.context.cache.set('mock1', undefined);
|
await app.context.cache.set('mock1', undefined);
|
||||||
expect(await app.context.cache.get('mock1')).toBe('');
|
expect(await app.context.cache.get('mock1')).toBe('');
|
||||||
await app.context.cache.set('mock2', '2');
|
await app.context.cache.set('mock2', '2');
|
||||||
@@ -110,8 +110,8 @@ describe('cache', () => {
|
|||||||
|
|
||||||
it('redis with quit', async () => {
|
it('redis with quit', async () => {
|
||||||
process.env.CACHE_TYPE = 'redis';
|
process.env.CACHE_TYPE = 'redis';
|
||||||
server = require('../../lib/index').server;
|
server = require('../../lib/index');
|
||||||
const client = require('../../lib/index').cache;
|
const client = require('../../lib/app').context.cache.client;
|
||||||
await client.quit();
|
await client.quit();
|
||||||
const request = supertest(server);
|
const request = supertest(server);
|
||||||
|
|
||||||
@@ -132,7 +132,7 @@ describe('cache', () => {
|
|||||||
it('redis with error', async () => {
|
it('redis with error', async () => {
|
||||||
process.env.CACHE_TYPE = 'redis';
|
process.env.CACHE_TYPE = 'redis';
|
||||||
process.env.REDIS_URL = 'redis://wrongpath:6379';
|
process.env.REDIS_URL = 'redis://wrongpath:6379';
|
||||||
server = require('../../lib/index').server;
|
server = require('../../lib/index');
|
||||||
const request = supertest(server);
|
const request = supertest(server);
|
||||||
|
|
||||||
const response1 = await request.get('/test/cache');
|
const response1 = await request.get('/test/cache');
|
||||||
@@ -151,7 +151,7 @@ describe('cache', () => {
|
|||||||
|
|
||||||
it('no cache', async () => {
|
it('no cache', async () => {
|
||||||
process.env.CACHE_TYPE = '';
|
process.env.CACHE_TYPE = '';
|
||||||
server = require('../../lib/index').server;
|
server = require('../../lib/index');
|
||||||
const request = supertest(server);
|
const request = supertest(server);
|
||||||
|
|
||||||
const response1 = await request.get('/test/cache');
|
const response1 = await request.get('/test/cache');
|
||||||
|
|||||||
Reference in New Issue
Block a user