UNPKG

30.7 kBJavaScriptView Raw
1"use strict";
2var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3 return new (P || (P = Promise))(function (resolve, reject) {
4 function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5 function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6 function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
7 step((generator = generator.apply(thisArg, _arguments || [])).next());
8 });
9};
10var __generator = (this && this.__generator) || function (thisArg, body) {
11 var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
12 return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
13 function verb(n) { return function (v) { return step([n, v]); }; }
14 function step(op) {
15 if (f) throw new TypeError("Generator is already executing.");
16 while (_) try {
17 if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
18 if (y = 0, t) op = [op[0] & 2, t.value];
19 switch (op[0]) {
20 case 0: case 1: t = op; break;
21 case 4: _.label++; return { value: op[1], done: false };
22 case 5: _.label++; y = op[1]; op = [0]; continue;
23 case 7: op = _.ops.pop(); _.trys.pop(); continue;
24 default:
25 if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
26 if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
27 if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
28 if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
29 if (t[2]) _.ops.pop();
30 _.trys.pop(); continue;
31 }
32 op = body.call(thisArg, _);
33 } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
34 if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
35 }
36};
37Object.defineProperty(exports, "__esModule", { value: true });
38// 根据架构设计约定自动识别各种运行环境
39if (process.env['NODE_ENV']) {
40 global['__env__'] = process.env['NODE_ENV'];
41}
42else {
43 if (process.argv.length >= 3 && process.argv[2] == 'https') {
44 // 预发环境配置
45 global['__env__'] = 'pre';
46 }
47 else if (process.argv.length >= 3 && process.argv[2] == 'http') {
48 // 日常环境配置
49 global['__env__'] = 'daily';
50 }
51 else {
52 // 本地环境配置
53 global['__env__'] = 'local';
54 }
55}
56if (global['__env__'] != 'local') {
57 require('source-map-support').install();
58}
59require('tsconfig-paths').register();
60var express = require('express');
61var app = express();
62var _ = require('lodash');
63var path = require('path');
64var http = require('http');
65var https = require('https');
66var fs = require('fs');
67var init_1 = require("./init");
68// 端口号启动参数配置
69var PORT = parseInt(process.argv[2]);
70if (!PORT) {
71 PORT = 8888;
72}
73// 设置静态资源路径(必须要使用绝对路径)
74app.use(express.static(path.join(init_1.get_root_path_prefix(), './static')));
75// 引入json解析中间件
76var bodyParser = require('body-parser');
77app.use(function (req, res, next) {
78 var rawBody = [];
79 var size = 0;
80 req.on('data', function (data) {
81 rawBody.push(data);
82 size += data.length;
83 });
84 req.on('end', function () {
85 // 获取原始的content-type对应的body内容自行解析处理,解决本地环境和线上环境不兼容问题。
86 req.rawBody = Buffer.concat(rawBody, size).toString();
87 });
88 next();
89});
90// 添加json解析
91app.use(bodyParser.json());
92app.use(bodyParser.urlencoded({ extended: false }));
93// 允许所有的请求形式
94app.use(function (req, res, next) {
95 if (req.headers.origin) {
96 // 获取源站动态允许请求跨域 (FIXME 需要进行安全限制对来源服务器网址合法性进行安全限制,本地开发调试全部放开请求)
97 res.header("Access-Control-Allow-Origin", req.headers.origin);
98 }
99 // res.header("Access-Control-Allow-Origin", "*")
100 res.header("Access-Control-Allow-Credentials", "true");
101 res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
102 res.header('Access-Control-Allow-Methods', 'POST, OPTIONS');
103 next();
104});
105// 本地调试使用路由重定向映射功能模拟
106var routes = require(path.join(init_1.get_root_path_prefix(), './app/entries/route.map')).default;
107var _loop_1 = function (k) {
108 app.all(k, function (req, res) {
109 return __awaiter(this, void 0, void 0, function () {
110 return __generator(this, function (_a) {
111 req.headers.__api__ = routes[k].path;
112 callback(req, res);
113 return [2 /*return*/];
114 });
115 });
116 });
117};
118for (var k in routes) {
119 _loop_1(k);
120}
121// TODO SLS日志机制云端对接、监控机制的业务对接、性能测试的对接、ACM配置机制的对接、报错机制信息的正确解析处理、
122// TODO COOKIE解析、BUC登录验证、 会议室信息的JAVA接口联调、梅丽莎多语言对接、ACM的配置发布
123// TODO 错误页处理、SESSION模拟基于TableStore的实现、REST的实现、更多PAAS中间件根据业务需要对接集成进来、实际业务问题更多的优化扩展。。。
124// 匹配不包含.的所有路由进行处理,否则表示文件静态资源需要单独处理。(API网关不返回任何静态资源,静态资源需要全部上传到CDN上,API网关只处理一个网站图标请求)
125app.all(/^((?!\.).)*$/, callback);
126// TODO 通过请求的域名和入口文件的位置,自动区分:本地、日常、预发、线上,四种环境。(灰度通过线上版本位置自动区分)
127// 加载配置文件信息。。。比较特殊需要在每次请求的时候单独处理。
128// 日常与预发在一台机器上需要分别启动两个独立nodejs进程进行处理,确保二者内部运行太壮数据的隔离性。
129// nodejs服务支持证书配置问题,使用正式的域名证书进行绑定配置,测试的时候本地配置域名链接确保正常。
130if (process.argv[2] == 'https') {
131 // 预发绑定HTTPS服务(对应AONE的日常机器)
132 var privateKey = fs.readFileSync(path.join(init_1.get_root_path_prefix(), './secrete/private.pem'), 'utf8');
133 var certificate = fs.readFileSync(path.join(init_1.get_root_path_prefix(), './secrete/public.crt'), 'utf8');
134 var credentials = { key: privateKey, cert: certificate };
135 var httpsServer = https.createServer(credentials, app);
136 httpsServer.listen(443, function () {
137 console.log('fc pre-release-test app listening on port 443!');
138 });
139}
140else if (process.argv[2] == 'http') {
141 // 日常绑定HTTP服务(对应AONE的日常机器,一台机器同时配置HTTP日常和HTTPS预发)
142 var httpServer = http.createServer(app);
143 httpServer.listen(80, function () {
144 console.log('fc test app listening on port 80!');
145 });
146}
147else {
148 // 本地开发环境HTTP协议绑定指定的端口号
149 var httpServer = http.createServer(app);
150 httpServer.listen(PORT, function () {
151 console.log("fc test app listening on port " + PORT + ", visit http://127.0.0.1:" + PORT);
152 });
153}
154function callback(req, res) {
155 return __awaiter(this, void 0, void 0, function () {
156 var param, __api__, __url__, __header__, out, err_1;
157 return __generator(this, function (_a) {
158 switch (_a.label) {
159 case 0:
160 param = req.query || {};
161 __api__ = req.headers.__api__ ? req.headers.__api__ : req.path;
162 __url__ = req.protocol + '://' + req.get('host') + req.originalUrl;
163 _a.label = 1;
164 case 1:
165 _a.trys.push([1, 3, , 5]);
166 // 请求参数的自动格式化处理兼容get和post协议方便开发调试
167 switch (req.method) {
168 case 'GET':
169 break;
170 case 'POST':
171 param = xassign(param, init_1.parse_post_param(req.headers, req.rawBody));
172 break;
173 case 'OPTIONS':
174 // 仅仅支持本地开发跨域调试,线上需要禁止此方法的调用应该同域请求处理。
175 res.sendStatus(200);
176 return [2 /*return*/];
177 default:
178 // 400 Bad Request 客户端请求的语法错误,服务器无法理解
179 res.sendStatus(400);
180 return [2 /*return*/];
181 }
182 __header__ = req.headers;
183 param = xassign(param, { __api__: __api__, __url__: __url__, __header__: __header__ });
184 // 解析请求中的cookies数据并转换为JSON对象存储到全局变量中便于后续应用xcookie接口使用
185 global['__request_cookies__'] = require('cookie').parse(_.get(req.headers, 'cookie', ''));
186 // 获取use-agent请求头部信息
187 global['__user_agent__'] = req['headers'] ? (req['headers']['user-agent'] ? req['headers']['user-agent'] : '') : '';
188 // 取到客户端的IP地址信息
189 global['__client_ip__'] = req.headers['x-forwarded-for'] || req.connection.remoteAddress;
190 return [4 /*yield*/, init_1.request_process(__api__, param)
191 // 处理response的cookies设置
192 ];
193 case 2:
194 out = _a.sent();
195 // 处理response的cookies设置
196 if (!_.isEmpty(global['__respond_cookies__'])) {
197 res.setHeader('Set-Cookie', _.values(global['__respond_cookies__']));
198 }
199 if (global['__redirect_url__']) {
200 res.redirect(302, global['__redirect_url__']);
201 global['__redirect_url__'] = undefined;
202 return [2 /*return*/];
203 }
204 res.send(out);
205 return [3 /*break*/, 5];
206 case 3:
207 err_1 = _a.sent();
208 // 通知框架自身实现逻辑的意外报错(框架自身不论何种情况都应该正常工作,一旦出现此问题大多数情况是框架自身问题或者流量引发的运维问题)
209 return [4 /*yield*/, xwarn({
210 __api__: __api__, __url__: __url__, param: param, message: err_1.message, stack: xstack(err_1)
211 })
212 // 500 Internal Server Error 服务器内部错误,无法完成请求
213 ];
214 case 4:
215 // 通知框架自身实现逻辑的意外报错(框架自身不论何种情况都应该正常工作,一旦出现此问题大多数情况是框架自身问题或者流量引发的运维问题)
216 _a.sent();
217 // 500 Internal Server Error 服务器内部错误,无法完成请求
218 res.sendStatus(500);
219 return [3 /*break*/, 5];
220 case 5: return [2 /*return*/];
221 }
222 });
223 });
224}
225//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.js","sourceRoot":"","sources":["test.ts"],"names":[],"mappings":"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","sourcesContent":["// 根据架构设计约定自动识别各种运行环境\nif (process.env['NODE_ENV']) {\n    global['__env__'] = process.env['NODE_ENV']\n} else {\n    if (process.argv.length >= 3 && process.argv[2] == 'https') {\n        // 预发环境配置\n        global['__env__'] = 'pre'\n    } else if (process.argv.length >= 3 && process.argv[2] == 'http') {\n        // 日常环境配置\n        global['__env__'] = 'daily'\n    }\n    else {\n        // 本地环境配置\n        global['__env__'] = 'local'\n    }\n}\nif (global['__env__'] != 'local') {\n    require('source-map-support').install()\n}\nrequire('tsconfig-paths').register()\nconst express = require('express')\nconst app = express()\nconst _ = require('lodash')\nconst path = require('path')\nconst http = require('http')\nconst https = require('https')\nconst fs = require('fs')\nimport {get_root_path_prefix, request_process, parse_post_param} from './init'\n\n// 端口号启动参数配置\nlet PORT: any = parseInt(process.argv[2])\nif (!PORT) {\n    PORT = 8888\n}\n\n// 设置静态资源路径（必须要使用绝对路径）\napp.use(express.static(path.join(get_root_path_prefix(), './static')))\n\n// 引入json解析中间件\nconst bodyParser = require('body-parser')\napp.use(function (req, res, next) {\n    var rawBody = []\n    var size = 0\n    req.on('data', function (data) {\n        rawBody.push(data)\n        size += data.length\n    })\n    req.on('end', function () {\n        // 获取原始的content-type对应的body内容自行解析处理，解决本地环境和线上环境不兼容问题。\n        req.rawBody = Buffer.concat(rawBody, size).toString()\n    })\n    next()\n})\n// 添加json解析\napp.use(bodyParser.json())\napp.use(bodyParser.urlencoded({extended: false}))\n// 允许所有的请求形式\napp.use(function (req, res, next) {\n    if (req.headers.origin) {\n        // 获取源站动态允许请求跨域 (FIXME 需要进行安全限制对来源服务器网址合法性进行安全限制，本地开发调试全部放开请求)\n        res.header(\"Access-Control-Allow-Origin\", req.headers.origin);\n    }\n    // res.header(\"Access-Control-Allow-Origin\", \"*\")\n    res.header(\"Access-Control-Allow-Credentials\", \"true\")\n    res.header(\"Access-Control-Allow-Headers\", \"Origin, X-Requested-With, Content-Type, Accept\")\n    res.header('Access-Control-Allow-Methods', 'POST, OPTIONS')\n    next()\n})\n\n// 本地调试使用路由重定向映射功能模拟\nconst routes = require(path.join(get_root_path_prefix(), './app/entries/route.map')).default\nfor (let k in routes) {\n    app.all(k, async function (req, res) {\n        req.headers.__api__ = routes[k].path\n        callback(req, res)\n    })\n}\n\n// TODO SLS日志机制云端对接、监控机制的业务对接、性能测试的对接、ACM配置机制的对接、报错机制信息的正确解析处理、\n// TODO COOKIE解析、BUC登录验证、   会议室信息的JAVA接口联调、梅丽莎多语言对接、ACM的配置发布\n// TODO 错误页处理、SESSION模拟基于TableStore的实现、REST的实现、更多PAAS中间件根据业务需要对接集成进来、实际业务问题更多的优化扩展。。。\n// 匹配不包含.的所有路由进行处理，否则表示文件静态资源需要单独处理。（API网关不返回任何静态资源，静态资源需要全部上传到CDN上，API网关只处理一个网站图标请求）\napp.all(/^((?!\\.).)*$/, callback)\n\n// TODO 通过请求的域名和入口文件的位置，自动区分：本地、日常、预发、线上，四种环境。（灰度通过线上版本位置自动区分）\n// 加载配置文件信息。。。比较特殊需要在每次请求的时候单独处理。\n// 日常与预发在一台机器上需要分别启动两个独立nodejs进程进行处理，确保二者内部运行太壮数据的隔离性。\n\n// nodejs服务支持证书配置问题，使用正式的域名证书进行绑定配置，测试的时候本地配置域名链接确保正常。\nif (process.argv[2] == 'https') {\n    // 预发绑定HTTPS服务（对应AONE的日常机器）\n    const privateKey = fs.readFileSync(\n        path.join(get_root_path_prefix(), './secrete/private.pem'), 'utf8')\n    const certificate = fs.readFileSync(\n        path.join(get_root_path_prefix(), './secrete/public.crt'), 'utf8')\n    const credentials = {key: privateKey, cert: certificate}\n    const httpsServer = https.createServer(credentials, app)\n    httpsServer.listen(443, function () {\n        console.log('fc pre-release-test app listening on port 443!')\n    })\n} else if (process.argv[2] == 'http') {\n    // 日常绑定HTTP服务（对应AONE的日常机器，一台机器同时配置HTTP日常和HTTPS预发）\n    const httpServer = http.createServer(app)\n    httpServer.listen(80, function () {\n        console.log('fc test app listening on port 80!')\n    })\n} else {\n    // 本地开发环境HTTP协议绑定指定的端口号\n    const httpServer = http.createServer(app)\n    httpServer.listen(PORT, function () {\n        console.log(`fc test app listening on port ${PORT}, visit http://127.0.0.1:${PORT}`)\n    })\n}\n\nasync function callback(req, res) {\n    let param = req.query || {}\n    // 补上框架预定义的缺省参数__url__(其他更多框架参数__api__ __debug__ __mock__ TODO __param__ 在get中json字符串的base64格式)\n    let __api__ = req.headers.__api__ ? req.headers.__api__ : req.path\n    let __url__ = req.protocol + '://' + req.get('host') + req.originalUrl\n\n    try {\n        // 请求参数的自动格式化处理兼容get和post协议方便开发调试\n        switch (req.method) {\n            case 'GET':\n                break\n            case 'POST':\n                param = xassign(param, parse_post_param(req.headers, req.rawBody))\n                break\n            case 'OPTIONS':\n                // 仅仅支持本地开发跨域调试，线上需要禁止此方法的调用应该同域请求处理。\n                res.sendStatus(200)\n                return\n            default:\n                // 400  Bad Request\t客户端请求的语法错误，服务器无法理解\n                res.sendStatus(400)\n                return\n        }\n        // 补上请求的HEADER参数到应用中进行自行处理业务逻辑定制的请求头部信息\n        let __header__ = req.headers\n        param = xassign(param, {__api__, __url__, __header__})\n\n        // 解析请求中的cookies数据并转换为JSON对象存储到全局变量中便于后续应用xcookie接口使用\n        global['__request_cookies__'] = require('cookie').parse(_.get(req.headers, 'cookie', ''))\n\n        // 获取use-agent请求头部信息\n        global['__user_agent__'] = req['headers'] ? (req['headers']['user-agent'] ? req['headers']['user-agent'] : '') : ''\n\n        // 取到客户端的IP地址信息\n        global['__client_ip__'] = req.headers['x-forwarded-for'] || req.connection.remoteAddress\n\n        // 请求处理\n        let out = await request_process(__api__, param)\n\n        // 处理response的cookies设置\n        if (!_.isEmpty(global['__respond_cookies__'])) {\n            res.setHeader('Set-Cookie', _.values(global['__respond_cookies__']))\n        }\n\n        if (global['__redirect_url__']) {\n            res.redirect(302, global['__redirect_url__'])\n            global['__redirect_url__'] = undefined\n            return\n        }\n        res.send(out)\n    } catch (err) {\n        // 通知框架自身实现逻辑的意外报错（框架自身不论何种情况都应该正常工作，一旦出现此问题大多数情况是框架自身问题或者流量引发的运维问题）\n        await xwarn({\n            __api__, __url__, param, message: err.message, stack: xstack(err)\n        })\n        // 500\tInternal Server Error\t服务器内部错误，无法完成请求\n        res.sendStatus(500)\n    }\n}"]}
\No newline at end of file