blixify-server 0.3.28 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/apis/authWrapper.d.ts.map +1 -1
- package/dist/apis/authWrapper.js +1 -228
- package/dist/apis/crypto.d.ts.map +1 -1
- package/dist/apis/crypto.js +1 -63
- package/dist/apis/dayjs.d.ts +3 -0
- package/dist/apis/dayjs.d.ts.map +1 -0
- package/dist/apis/dayjs.js +1 -0
- package/dist/apis/fbWrapper.d.ts +6 -6
- package/dist/apis/fbWrapper.d.ts.map +1 -1
- package/dist/apis/fbWrapper.js +1 -839
- package/dist/apis/googleAnalyticsWrapper.d.ts.map +1 -1
- package/dist/apis/googleAnalyticsWrapper.js +1 -223
- package/dist/apis/index.js +1 -21
- package/dist/apis/mondayWrapper.d.ts +2 -2
- package/dist/apis/mondayWrapper.d.ts.map +1 -1
- package/dist/apis/mondayWrapper.js +32 -527
- package/dist/apis/mongoWrapper.d.ts +6 -6
- package/dist/apis/mongoWrapper.d.ts.map +1 -1
- package/dist/apis/mongoWrapper.js +1 -1524
- package/dist/apis/postgresqlWrapper.d.ts +3 -3
- package/dist/apis/postgresqlWrapper.d.ts.map +1 -1
- package/dist/apis/postgresqlWrapper.js +1 -514
- package/dist/apis/security.d.ts.map +1 -1
- package/dist/apis/security.js +1 -80
- package/dist/apis/trackVisionWrapper.d.ts.map +1 -1
- package/dist/apis/trackVisionWrapper.js +1 -150
- package/dist/apis/uploadWrapper.d.ts.map +1 -1
- package/dist/apis/uploadWrapper.js +1 -481
- package/dist/apis/utils.d.ts +1 -1
- package/dist/apis/utils.d.ts.map +1 -1
- package/dist/apis/utils.js +1 -25
- package/dist/buildtsconfig.tsbuildinfo +1 -0
- package/dist/model/Log.js +1 -2
- package/dist/model/QueryModel.d.ts.map +1 -1
- package/dist/model/QueryModel.js +1 -118
- package/dist/model/SecurityConfig.js +1 -2
- package/package.json +21 -12
package/dist/apis/utils.d.ts
CHANGED
package/dist/apis/utils.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/apis/utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,oBAAoB,
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/apis/utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,oBAAoB,GAAI,UAAU,GAAG,EAAE,aAAa,GAAG;;;;;;;CAoBnE,CAAC;AAEF,eAAO,MAAM,6BAA6B,GAAI,QAAQ,MAAM,WAE3D,CAAC"}
|
package/dist/apis/utils.js
CHANGED
|
@@ -1,25 +1 @@
|
|
|
1
|
-
"
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.handleSpecialWordsEscapeRegex = exports.compareUpdatedFields = void 0;
|
|
4
|
-
const uuid_1 = require("uuid");
|
|
5
|
-
const compareUpdatedFields = (prevData, currentData) => {
|
|
6
|
-
const updatedFields = {};
|
|
7
|
-
Object.keys(prevData).forEach((key) => {
|
|
8
|
-
if (prevData[key] && (0, uuid_1.validate)(prevData[key]))
|
|
9
|
-
updatedFields[key] = prevData[key];
|
|
10
|
-
});
|
|
11
|
-
Object.keys(currentData).forEach((key) => {
|
|
12
|
-
if (JSON.stringify(currentData[key]) !== JSON.stringify(prevData[key])) {
|
|
13
|
-
updatedFields[key] = currentData[key];
|
|
14
|
-
}
|
|
15
|
-
});
|
|
16
|
-
return {
|
|
17
|
-
workflowUpdateFields: Object.assign({}, updatedFields),
|
|
18
|
-
updatedFields,
|
|
19
|
-
};
|
|
20
|
-
};
|
|
21
|
-
exports.compareUpdatedFields = compareUpdatedFields;
|
|
22
|
-
const handleSpecialWordsEscapeRegex = (string) => {
|
|
23
|
-
return string.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
24
|
-
};
|
|
25
|
-
exports.handleSpecialWordsEscapeRegex = handleSpecialWordsEscapeRegex;
|
|
1
|
+
Object.defineProperty(exports,"__esModule",{value:!0}),exports.handleSpecialWordsEscapeRegex=exports.compareUpdatedFields=void 0;let uuid_1=require("uuid"),compareUpdatedFields=(d,a)=>{let s={};return Object.keys(d).forEach(e=>{d[e]&&(0,uuid_1.validate)(d[e])&&(s[e]=d[e])}),Object.keys(a).forEach(e=>{JSON.stringify(a[e])!==JSON.stringify(d[e])&&(s[e]=a[e])}),{workflowUpdateFields:Object.assign({},s),updatedFields:s}},handleSpecialWordsEscapeRegex=(exports.compareUpdatedFields=compareUpdatedFields,e=>e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"));exports.handleSpecialWordsEscapeRegex=handleSpecialWordsEscapeRegex;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"root":["../src/apis/authWrapper.ts","../src/apis/crypto.ts","../src/apis/dayjs.ts","../src/apis/fbWrapper.ts","../src/apis/googleAnalyticsWrapper.ts","../src/apis/index.ts","../src/apis/mondayWrapper.ts","../src/apis/mongoWrapper.ts","../src/apis/postgresqlWrapper.ts","../src/apis/security.ts","../src/apis/trackVisionWrapper.ts","../src/apis/uploadWrapper.ts","../src/apis/utils.ts"],"version":"5.9.3"}
|
package/dist/model/Log.js
CHANGED
|
@@ -1,2 +1 @@
|
|
|
1
|
-
"
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
Object.defineProperty(exports,"__esModule",{value:!0});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QueryModel.d.ts","sourceRoot":"","sources":["../../src/model/QueryModel.ts"],"names":[],"mappings":"AAAA,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAE9C;;;;;;;;;;GAUG;AACH,MAAM,WAAW,KAAK;IACpB,IAAI,EACA,QAAQ,GACR,GAAG,GACH,IAAI,GACJ,GAAG,GACH,GAAG,GACH,IAAI,GACJ,IAAI,GACJ,KAAK,GACL,QAAQ,GACR,OAAO,GACP,OAAO,GACP,SAAS,GACT,WAAW,CAAC;IAChB,KAAK,EAAE,GAAG,CAAC;IACX,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,OAAO,CAAC,EAAE;QACR,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,YAAY,EAAE,MAAM,EAAE,CAAC;QACvB,KAAK,EAAE,MAAM,CAAC;KACf,EAAE,CAAC;CACL;AAED,UAAU,iBAAiB;IACzB,IAAI,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,KAAK,CAAC;IACnD,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED;;;;;;;;;;;GAWG;AACH,MAAM,WAAW,QAAQ;IACvB,SAAS,EAAE,iBAAiB,EAAE,CAAC;IAC/B,mBAAmB,EAAE,MAAM,EAAE,CAAC;IAC9B,aAAa,CAAC,EAAE,IAAI,CAAC;IACrB,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED;;;;;;;;;;;;;;;GAeG;AACH,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,OAAO,GAAG,KAAK,GAAG,KAAK,GAAG,OAAO,CAAC;IACxC,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE;QACP,UAAU,EAAE,MAAM,CAAC;QACnB,YAAY,EAAE,MAAM,CAAC;QACrB,KAAK,EAAE,KAAK,EAAE,CAAC;QACf,MAAM,CAAC,EAAE;YACP,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC;YACxB,IAAI,CAAC,EAAE,OAAO,CAAC;SAChB,CAAC;KACH,EAAE,CAAC;CACL;AAED,MAAM,WAAW,IAAI;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,KAAK,GAAG,MAAM,CAAC;IACrB,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED;;;;;;GAMG;AACH,eAAO,MAAM,eAAe,
|
|
1
|
+
{"version":3,"file":"QueryModel.d.ts","sourceRoot":"","sources":["../../src/model/QueryModel.ts"],"names":[],"mappings":"AAAA,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAE9C;;;;;;;;;;GAUG;AACH,MAAM,WAAW,KAAK;IACpB,IAAI,EACA,QAAQ,GACR,GAAG,GACH,IAAI,GACJ,GAAG,GACH,GAAG,GACH,IAAI,GACJ,IAAI,GACJ,KAAK,GACL,QAAQ,GACR,OAAO,GACP,OAAO,GACP,SAAS,GACT,WAAW,CAAC;IAChB,KAAK,EAAE,GAAG,CAAC;IACX,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,OAAO,CAAC,EAAE;QACR,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,YAAY,EAAE,MAAM,EAAE,CAAC;QACvB,KAAK,EAAE,MAAM,CAAC;KACf,EAAE,CAAC;CACL;AAED,UAAU,iBAAiB;IACzB,IAAI,EAAE,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,KAAK,CAAC;IACnD,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED;;;;;;;;;;;GAWG;AACH,MAAM,WAAW,QAAQ;IACvB,SAAS,EAAE,iBAAiB,EAAE,CAAC;IAC/B,mBAAmB,EAAE,MAAM,EAAE,CAAC;IAC9B,aAAa,CAAC,EAAE,IAAI,CAAC;IACrB,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED;;;;;;;;;;;;;;;GAeG;AACH,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,OAAO,GAAG,KAAK,GAAG,KAAK,GAAG,OAAO,CAAC;IACxC,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE;QACP,UAAU,EAAE,MAAM,CAAC;QACnB,YAAY,EAAE,MAAM,CAAC;QACrB,KAAK,EAAE,KAAK,EAAE,CAAC;QACf,MAAM,CAAC,EAAE;YACP,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC;YACxB,IAAI,CAAC,EAAE,OAAO,CAAC;SAChB,CAAC;KACH,EAAE,CAAC;CACL;AAED,MAAM,WAAW,IAAI;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,KAAK,GAAG,MAAM,CAAC;IACrB,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED;;;;;;GAMG;AACH,eAAO,MAAM,eAAe,GAAI,QAAQ,cAAc,EAAE,KAAK,GAAG,YAmC/D,CAAC;AAEF;;;;;;;GAOG;AACH,eAAO,MAAM,cAAc,GACzB,QAAQ,cAAc,EACtB,MAAM,MAAM,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,EAC7C,KAAK,GAAG,EACR,KAAK,GAAG,YAyDT,CAAC"}
|
package/dist/model/QueryModel.js
CHANGED
|
@@ -1,118 +1 @@
|
|
|
1
|
-
"
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.checkOpsConfig = exports.checkBaseConfig = void 0;
|
|
4
|
-
/**
|
|
5
|
-
*
|
|
6
|
-
* Doc is not supported for Base Config
|
|
7
|
-
* @param config
|
|
8
|
-
* @param req
|
|
9
|
-
* @returns
|
|
10
|
-
*/
|
|
11
|
-
const checkBaseConfig = (config, req) => {
|
|
12
|
-
let validBaseConfig = true;
|
|
13
|
-
if (config.baseConfig.length > 0) {
|
|
14
|
-
config.baseConfig.map((eachConfig) => {
|
|
15
|
-
switch (eachConfig.type) {
|
|
16
|
-
case "domain":
|
|
17
|
-
if (!req.headers["referer"])
|
|
18
|
-
validBaseConfig = false;
|
|
19
|
-
break;
|
|
20
|
-
case "android":
|
|
21
|
-
if (!req.headers["x-android-package"])
|
|
22
|
-
validBaseConfig = false;
|
|
23
|
-
break;
|
|
24
|
-
case "androidSHA":
|
|
25
|
-
if (!req.headers["x-android-cert"])
|
|
26
|
-
validBaseConfig = false;
|
|
27
|
-
break;
|
|
28
|
-
case "ios":
|
|
29
|
-
if (!req.headers["x-ios-bundle-identifier"])
|
|
30
|
-
validBaseConfig = false;
|
|
31
|
-
break;
|
|
32
|
-
case "api":
|
|
33
|
-
if (!req.body["bm_apiToken"])
|
|
34
|
-
validBaseConfig = false;
|
|
35
|
-
break;
|
|
36
|
-
case "auth":
|
|
37
|
-
if (!req.body["bm_userId"])
|
|
38
|
-
validBaseConfig = false;
|
|
39
|
-
break;
|
|
40
|
-
case "role":
|
|
41
|
-
if (req.body["bm_userRole"] !== eachConfig.value)
|
|
42
|
-
validBaseConfig = false;
|
|
43
|
-
break;
|
|
44
|
-
case "org":
|
|
45
|
-
case "doc":
|
|
46
|
-
break;
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
return validBaseConfig;
|
|
51
|
-
};
|
|
52
|
-
exports.checkBaseConfig = checkBaseConfig;
|
|
53
|
-
/**
|
|
54
|
-
*
|
|
55
|
-
* @param config
|
|
56
|
-
* @param type
|
|
57
|
-
* @param req
|
|
58
|
-
* @param doc
|
|
59
|
-
* @returns
|
|
60
|
-
*/
|
|
61
|
-
const checkOpsConfig = (config, type, req, doc) => {
|
|
62
|
-
let validOpsConfig = false;
|
|
63
|
-
let selectedOpsConfig;
|
|
64
|
-
if (type === "read") {
|
|
65
|
-
selectedOpsConfig = config.opsConfig.read;
|
|
66
|
-
}
|
|
67
|
-
else if (type === "create") {
|
|
68
|
-
selectedOpsConfig = config.opsConfig.create;
|
|
69
|
-
}
|
|
70
|
-
else if (type === "update") {
|
|
71
|
-
selectedOpsConfig = config.opsConfig.update;
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
selectedOpsConfig = config.opsConfig.delete;
|
|
75
|
-
}
|
|
76
|
-
if (selectedOpsConfig.length > 0) {
|
|
77
|
-
selectedOpsConfig.map((eachConfig) => {
|
|
78
|
-
switch (eachConfig.type) {
|
|
79
|
-
case "auth":
|
|
80
|
-
if (req.body["bm_userId"])
|
|
81
|
-
validOpsConfig = true;
|
|
82
|
-
break;
|
|
83
|
-
case "doc":
|
|
84
|
-
if (req.body["bm_userId"]) {
|
|
85
|
-
const compareValue = JSON.stringify(req.body["bm_userId"]);
|
|
86
|
-
if (Array.isArray(eachConfig.value)) {
|
|
87
|
-
eachConfig.value.map((eachValue) => {
|
|
88
|
-
if (compareValue === JSON.stringify(doc[eachValue]))
|
|
89
|
-
validOpsConfig = true;
|
|
90
|
-
});
|
|
91
|
-
}
|
|
92
|
-
else {
|
|
93
|
-
if (compareValue === JSON.stringify(doc[eachConfig.value]))
|
|
94
|
-
validOpsConfig = true;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
break;
|
|
98
|
-
case "org":
|
|
99
|
-
if (req.body["bm_userOrg"] && !Array.isArray(eachConfig.value)) {
|
|
100
|
-
if (JSON.stringify(req.body["bm_userOrg"]) ===
|
|
101
|
-
JSON.stringify(doc[eachConfig.value]))
|
|
102
|
-
validOpsConfig = true;
|
|
103
|
-
}
|
|
104
|
-
break;
|
|
105
|
-
case "role":
|
|
106
|
-
if (req.body["bm_userRole"] &&
|
|
107
|
-
req.body["bm_userRole"] === eachConfig.value)
|
|
108
|
-
validOpsConfig = true;
|
|
109
|
-
break;
|
|
110
|
-
}
|
|
111
|
-
});
|
|
112
|
-
}
|
|
113
|
-
else {
|
|
114
|
-
validOpsConfig = true;
|
|
115
|
-
}
|
|
116
|
-
return validOpsConfig;
|
|
117
|
-
};
|
|
118
|
-
exports.checkOpsConfig = checkOpsConfig;
|
|
1
|
+
Object.defineProperty(exports,"__esModule",{value:!0}),exports.checkOpsConfig=exports.checkBaseConfig=void 0;let checkBaseConfig=(e,r)=>{let a=!0;return 0<e.baseConfig.length&&e.baseConfig.map(e=>{switch(e.type){case"domain":r.headers.referer||(a=!1);break;case"android":r.headers["x-android-package"]||(a=!1);break;case"androidSHA":r.headers["x-android-cert"]||(a=!1);break;case"ios":r.headers["x-ios-bundle-identifier"]||(a=!1);break;case"api":r.body.bm_apiToken||(a=!1);break;case"auth":r.body.bm_userId||(a=!1);break;case"role":r.body.bm_userRole!==e.value&&(a=!1)}}),a},checkOpsConfig=(exports.checkBaseConfig=checkBaseConfig,(e,r,a,s)=>{let o=!1,i;return 0<(i="read"===r?e.opsConfig.read:"create"===r?e.opsConfig.create:"update"===r?e.opsConfig.update:e.opsConfig.delete).length?i.map(e=>{switch(e.type){case"auth":a.body.bm_userId&&(o=!0);break;case"doc":if(a.body.bm_userId){let r=JSON.stringify(a.body.bm_userId);Array.isArray(e.value)?e.value.map(e=>{r===JSON.stringify(s[e])&&(o=!0)}):r===JSON.stringify(s[e.value])&&(o=!0)}break;case"org":a.body.bm_userOrg&&!Array.isArray(e.value)&&JSON.stringify(a.body.bm_userOrg)===JSON.stringify(s[e.value])&&(o=!0);break;case"role":a.body.bm_userRole&&a.body.bm_userRole===e.value&&(o=!0)}}):o=!0,o});exports.checkOpsConfig=checkOpsConfig;
|
|
@@ -1,2 +1 @@
|
|
|
1
|
-
"
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
Object.defineProperty(exports,"__esModule",{value:!0});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "blixify-server",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "1.0.0",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"main": "dist/apis/index.js",
|
|
6
6
|
"private": false,
|
|
@@ -30,7 +30,11 @@
|
|
|
30
30
|
"start:monday": "cd dist && node mondayServer.js",
|
|
31
31
|
"start:trackVision": "cd dist && node trackVisionServer.js",
|
|
32
32
|
"start:analytics": "cd dist && node analyticsServer.js",
|
|
33
|
-
"install:husky": "yarn husky install"
|
|
33
|
+
"install:husky": "yarn husky install",
|
|
34
|
+
"test": "jest --maxWorkers=50%",
|
|
35
|
+
"test:unit": "jest tests/unit --maxWorkers=50%",
|
|
36
|
+
"test:integration": "jest tests/integration --maxWorkers=50%",
|
|
37
|
+
"test:all": "concurrently \"jest tests/unit\" \"jest tests/integration\""
|
|
34
38
|
},
|
|
35
39
|
"config": {
|
|
36
40
|
"commit-message-validator": {
|
|
@@ -42,34 +46,39 @@
|
|
|
42
46
|
"dependencies": {
|
|
43
47
|
"@google-analytics/data": "^5.1.0",
|
|
44
48
|
"@google-cloud/bigquery": "^8.1.0",
|
|
45
|
-
"@types/uuid": "^9.0.7",
|
|
46
49
|
"axios": "^1.4.0",
|
|
47
50
|
"crypto-js": "^4.2.0",
|
|
48
51
|
"mime": "^3.0.0",
|
|
49
|
-
"moment": "^2.29.4",
|
|
50
|
-
"moment-timezone": "^0.5.43",
|
|
51
52
|
"pg": "^8.12.0",
|
|
52
|
-
"uuid": "^9.0.1"
|
|
53
|
+
"uuid": "^9.0.1",
|
|
54
|
+
"dayjs": "^1.11.13"
|
|
53
55
|
},
|
|
54
56
|
"devDependencies": {
|
|
55
57
|
"@types/express": "^4.17.14",
|
|
56
|
-
"@types/
|
|
57
|
-
"@
|
|
58
|
-
"@typescript-eslint/
|
|
58
|
+
"@types/jest": "^30.0.0",
|
|
59
|
+
"@types/node": "^20.0.0",
|
|
60
|
+
"@typescript-eslint/eslint-plugin": "^7.0.0",
|
|
61
|
+
"@typescript-eslint/parser": "^7.0.0",
|
|
59
62
|
"aws-sdk": "^2.1432.0",
|
|
60
63
|
"body-parser": "^1.20.0",
|
|
61
64
|
"branch-naming-check": "^1.0.2",
|
|
62
65
|
"commit-message-validator": "^1.0.2",
|
|
66
|
+
"concurrently": "^9.2.1",
|
|
63
67
|
"cors": "^2.8.5",
|
|
64
68
|
"dotenv": "^16.0.1",
|
|
65
69
|
"eslint": "^8.16.0",
|
|
66
70
|
"express": "^4.18.1",
|
|
67
71
|
"express-rate-limit": "^6.6.0",
|
|
68
72
|
"firebase-admin": "^12.2.0",
|
|
69
|
-
"helmet": "^
|
|
73
|
+
"helmet": "^8.0.0",
|
|
70
74
|
"husky": "^8.0.2",
|
|
71
|
-
"
|
|
75
|
+
"jest": "^30.3.0",
|
|
76
|
+
"mongodb": "^6.5.0",
|
|
77
|
+
"mongodb-memory-server": "^11.1.0",
|
|
72
78
|
"multer": "^1.4.5-lts.1",
|
|
73
|
-
"
|
|
79
|
+
"ts-jest": "^29.4.9",
|
|
80
|
+
"ts-node": "^10.9.2",
|
|
81
|
+
"typescript": "^5.5.4",
|
|
82
|
+
"@types/uuid": "^9.0.7"
|
|
74
83
|
}
|
|
75
84
|
}
|