UNPKG

25.1 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3const inversify_binding_decorators_1 = require("inversify-binding-decorators");
4const inversify_koa_utils_1 = require("inversify-koa-utils");
5const bodyParser = require("koa-bodyparser");
6const jwt = require("koa-jwt");
7const log4js = require("koa-log4");
8const Router = require("koa-router");
9const cors = require("koa2-cors");
10const _ = require("lodash");
11const defConfig = require("./config/defconfig");
12const ioc_1 = require("./ioc/ioc");
13const iocTracer_1 = require("./ioc/iocTracer");
14const log4js_1 = require("./middlewares/logger/log4js");
15const models_1 = require("./models");
16const BaseResponse_1 = require("./models/BaseResponse");
17const log = log4js.getLogger('GServer');
18class GServer {
19 constructor(initSetting) {
20 let middlewares;
21 let domainName;
22 // let mqSetting;
23 let jwtPrivateKey;
24 let jwtActive;
25 let httpPort;
26 let corsWhitelist;
27 let log4;
28 if (!_.isUndefined(initSetting)) {
29 middlewares = _.isUndefined(initSetting.middlewares) ? undefined : initSetting.middlewares;
30 if (_.size(middlewares) === 0) {
31 middlewares = undefined;
32 }
33 this.serverInitOnceEvents = _.isUndefined(initSetting.iniData) ? undefined : initSetting.iniData;
34 corsWhitelist = _.isUndefined(initSetting.corsWhitelist) ? undefined : initSetting.corsWhitelist;
35 domainName = _.isUndefined(initSetting.domainName) ? undefined : initSetting.domainName;
36 // mqSetting = _.isUndefined(initSetting.mqSetting) ? undefined : initSetting.mqSetting;
37 jwtPrivateKey = _.isUndefined(initSetting.jwtPrivateKey) ?
38 defConfig.jwt.privateKey : initSetting.jwtPrivateKey;
39 jwtActive = _.isUndefined(initSetting.jwtActive) ? defConfig.jwt.active : initSetting.jwtActive;
40 httpPort = _.isUndefined(initSetting.httpPort) ? defConfig.httpPort : initSetting.httpPort;
41 log4 = _.isFunction(initSetting.log4) ? log4js_1.default : initSetting.log4;
42 ioc_1.container.load(inversify_binding_decorators_1.buildProviderModule());
43 if (initSetting.filtersOpen) {
44 const iocTracer = new iocTracer_1.default(initSetting.filters);
45 iocTracer.apply(ioc_1.container);
46 }
47 }
48 this.main = models_1.ORMContext.init(initSetting.pathdb, initSetting.pathBeansPath);
49 // caeate DB connection
50 // 還不會用到mq應該還不需要去讓他一直嘗試連線
51 // if (!_.isUndefined(mqSetting)) {
52 // this.main.then((result) => {
53 // tslint:disable-next-line:no-null-keyword
54 // return mq(null, mqSetting); // connect MQ Server
55 // });
56 // }
57 this.main.then(() => {
58 const rootRouter = new Router({
59 prefix: _.isUndefined(domainName) ? '' : domainName
60 });
61 // create server
62 const server = new inversify_koa_utils_1.InversifyKoaServer(ioc_1.container, rootRouter);
63 server
64 .setConfig((app) => {
65 app.use(async (ctx, next) => {
66 // TODO check user auth to operate function
67 try {
68 await next();
69 }
70 catch (err) {
71 const response = new BaseResponse_1.default(err.message);
72 const statusArray = _.map(_.toString(err.status));
73 if (_.size(statusArray) === 4 &&
74 statusArray[0] in ['8', '9', '7', '6', '5', '4', '3', '2', '1', '0']) {
75 // 這邊map是因為要抓取第一個數字開頭等於9就會跑error
76 if (statusArray[0] === '9') {
77 log.error(err.status, err.message, JSON.stringify(ctx.state.user) || '');
78 }
79 else {
80 log.warn(err.status, err.message, JSON.stringify(ctx.state.user) || '');
81 }
82 response.$status = err.status;
83 }
84 else {
85 ctx.status = err.status || 500;
86 log.error(err.stack, JSON.stringify(ctx.state.user) || '');
87 response.$status = ctx.status;
88 ctx.app.emit('error', err, ctx);
89 }
90 ctx.body = response;
91 }
92 })
93 .use(cors({
94 origin: (ctx) => {
95 if (_.isUndefined(corsWhitelist) ||
96 _.size(corsWhitelist) === 0) {
97 return '*';
98 }
99 else if (_.includes(corsWhitelist, ctx.header.origin)) {
100 return '*';
101 }
102 else {
103 ctx.status = 404;
104 ctx.throw(422, new Error('Not Allow Cors'));
105 return false;
106 }
107 }
108 }))
109 .use(log4())
110 // .use(multer({
111 // storage: multer.memoryStorage()
112 // }).any())
113 .use(bodyParser({
114 strict: false,
115 onerror: (err, ctx) => {
116 log.error(err);
117 ctx.throw(422, new Error('body parse error'));
118 }
119 }));
120 if (!_.isUndefined(middlewares) && _.size(middlewares) !== 0) {
121 _.forEach(middlewares, (middleware) => {
122 app.use(middleware);
123 });
124 }
125 app.use(jwt({ secret: jwtPrivateKey, passthrough: !jwtActive })
126 .unless({
127 path: _.isUndefined(initSetting.unlessPath) ? [] : initSetting.unlessPath
128 }));
129 })
130 .setErrorConfig((app) => {
131 app.use((ctx, next) => {
132 log.error(ctx.status, ctx.message, JSON.stringify(ctx.state.user) || '');
133 next();
134 });
135 });
136 this.koaServer = server.build().listen(httpPort);
137 log.info('Http started listening on http://localhost:%s ...', httpPort);
138 })
139 .catch((e) => {
140 log.error(e);
141 });
142 }
143 async start() {
144 await Promise.all([this.main]);
145 if (!_.isUndefined(this.serverInitOnceEvents) && _.size(this.serverInitOnceEvents) !== 0) {
146 _.forEach(this.serverInitOnceEvents, (element) => {
147 element.doOnce();
148 element.end();
149 });
150 }
151 return this.koaServer;
152 }
153}
154exports.default = GServer;
155//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GServer.js","sourceRoot":"./src/","sources":["GServer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Server } from 'http';\nimport { buildProviderModule } from 'inversify-binding-decorators';\nimport { InversifyKoaServer } from 'inversify-koa-utils';\nimport { Middleware } from 'koa';\nimport * as bodyParser from 'koa-bodyparser';\nimport * as jwt from 'koa-jwt';\nimport * as log4js from 'koa-log4';\nimport * as Router from 'koa-router';\nimport * as cors from 'koa2-cors';\nimport * as _ from 'lodash';\nimport * as defConfig from './config/defconfig';\nimport { container } from './ioc/ioc';\nimport IocTracer from './ioc/iocTracer';\nimport koaLog4js from './middlewares/logger/log4js';\nimport { ORMContext } from './models';\nimport BaseResponse from './models/BaseResponse';\nimport HttpInitSetting from './models/HttpInitSetting';\nimport IServerInitOnceEvent from './ServerEvent/ServerInitOnceEvent';\n\nconst log = log4js.getLogger('GServer');\nexport default class GServer {\n    private main: Promise<any>;\n    private serverInitOnceEvents: IServerInitOnceEvent[] | undefined;\n    private koaServer: Server;\n    constructor(initSetting: HttpInitSetting) {\n        let middlewares;\n        let domainName;\n        // let mqSetting;\n        let jwtPrivateKey;\n        let jwtActive;\n        let httpPort;\n        let corsWhitelist;\n        let log4: () => Middleware;\n        if (!_.isUndefined(initSetting)) {\n            middlewares = _.isUndefined(initSetting.middlewares) ? undefined : initSetting.middlewares;\n            if (_.size(middlewares) === 0) {\n                middlewares = undefined;\n            }\n            this.serverInitOnceEvents = _.isUndefined(initSetting.iniData) ? undefined : initSetting.iniData;\n            corsWhitelist = _.isUndefined(initSetting.corsWhitelist) ? undefined : initSetting.corsWhitelist;\n            domainName = _.isUndefined(initSetting.domainName) ? undefined : initSetting.domainName;\n            // mqSetting = _.isUndefined(initSetting.mqSetting) ? undefined : initSetting.mqSetting;\n            jwtPrivateKey = _.isUndefined(initSetting.jwtPrivateKey) ?\n                defConfig.jwt.privateKey : initSetting.jwtPrivateKey;\n            jwtActive = _.isUndefined(initSetting.jwtActive) ? defConfig.jwt.active : initSetting.jwtActive;\n            httpPort = _.isUndefined(initSetting.httpPort) ? defConfig.httpPort : initSetting.httpPort;\n            log4 = _.isFunction(initSetting.log4) ? koaLog4js : initSetting.log4!;\n            container.load(buildProviderModule());\n            if (initSetting.filtersOpen) {\n                const iocTracer = new IocTracer(initSetting.filters);\n                iocTracer.apply(container);\n            }\n        }\n        this.main = ORMContext.init(initSetting.pathdb, initSetting.pathBeansPath);\n        // caeate DB connection\n        // 還不會用到mq應該還不需要去讓他一直嘗試連線\n        // if (!_.isUndefined(mqSetting)) {\n        // this.main.then((result) => {\n        // tslint:disable-next-line:no-null-keyword\n        // return mq(null, mqSetting); // connect MQ Server\n        // });\n        // }\n        this.main.then(() => {\n            const rootRouter = new Router({\n                prefix: _.isUndefined(domainName) ? '' : domainName\n            });\n            // create server\n            const server = new InversifyKoaServer(container, rootRouter);\n            server\n                .setConfig((app) => {\n                    app.use(async (ctx, next) => {\n                        // TODO check user auth to operate function\n                        try {\n                            await next();\n                        } catch (err) {\n                            const response = new BaseResponse(err.message);\n                            const statusArray = _.map(_.toString(err.status));\n                            if (_.size(statusArray) === 4 &&\n                                statusArray[0] in ['8', '9', '7', '6', '5', '4', '3', '2', '1', '0']) {\n                                // 這邊map是因為要抓取第一個數字開頭等於9就會跑error\n                                if (statusArray[0] === '9') {\n                                    log.error(err.status, err.message, JSON.stringify(ctx.state.user) || '');\n                                } else {\n                                    log.warn(err.status, err.message, JSON.stringify(ctx.state.user) || '');\n                                }\n                                response.$status = err.status;\n                            } else {\n                                ctx.status = err.status || 500;\n                                log.error(err.stack, JSON.stringify(ctx.state.user) || '');\n                                response.$status = ctx.status;\n                                ctx.app.emit('error', err, ctx);\n                            }\n\n                            ctx.body = response;\n                        }\n                    })\n                        .use(cors({\n                            origin: (ctx) => {\n                                if (_.isUndefined(corsWhitelist) ||\n                                    _.size(corsWhitelist) === 0) {\n                                    return '*';\n                                } else if (_.includes(corsWhitelist, ctx.header.origin)) {\n                                    return '*';\n                                } else {\n                                    ctx.status = 404;\n                                    ctx.throw(422, new Error('Not Allow Cors'));\n                                    return false;\n                                }\n                            }\n                        }))\n                        .use(log4())\n                        // .use(multer({\n                        //     storage: multer.memoryStorage()\n                        // }).any())\n                        .use(bodyParser({\n                            strict: false,\n                            onerror: (err, ctx) => {\n                                log.error(err);\n                                ctx.throw(422, new Error('body parse error'));\n                            }\n                        }));\n                    if (!_.isUndefined(middlewares) && _.size(middlewares) !== 0) {\n                        _.forEach(middlewares, (middleware) => {\n                            app.use(middleware);\n                        });\n                    }\n                    app.use(jwt({ secret: jwtPrivateKey, passthrough: !jwtActive })\n                        .unless({\n                            path: _.isUndefined(initSetting.unlessPath) ? [] : initSetting.unlessPath\n                        }));\n                })\n                .setErrorConfig((app) => {\n                    app.use((ctx, next) => {\n                        log.error(ctx.status, ctx.message, JSON.stringify(ctx.state.user) || '');\n                        next();\n                    });\n                });\n            this.koaServer = server.build().listen(httpPort);\n            log.info('Http started listening on http://localhost:%s ...', httpPort);\n        })\n            .catch((e) => {\n                log.error(e);\n            });\n    }\n    public async start() {\n        await Promise.all([this.main]);\n        if (!_.isUndefined(this.serverInitOnceEvents) && _.size(this.serverInitOnceEvents) !== 0) {\n            _.forEach(this.serverInitOnceEvents, (element) => {\n                element.doOnce();\n                element.end();\n            });\n        }\n        return this.koaServer;\n    }\n}\n"]}
\No newline at end of file