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.
Files changed (37) hide show
  1. package/dist/apis/authWrapper.d.ts.map +1 -1
  2. package/dist/apis/authWrapper.js +1 -228
  3. package/dist/apis/crypto.d.ts.map +1 -1
  4. package/dist/apis/crypto.js +1 -63
  5. package/dist/apis/dayjs.d.ts +3 -0
  6. package/dist/apis/dayjs.d.ts.map +1 -0
  7. package/dist/apis/dayjs.js +1 -0
  8. package/dist/apis/fbWrapper.d.ts +6 -6
  9. package/dist/apis/fbWrapper.d.ts.map +1 -1
  10. package/dist/apis/fbWrapper.js +1 -839
  11. package/dist/apis/googleAnalyticsWrapper.d.ts.map +1 -1
  12. package/dist/apis/googleAnalyticsWrapper.js +1 -223
  13. package/dist/apis/index.js +1 -21
  14. package/dist/apis/mondayWrapper.d.ts +2 -2
  15. package/dist/apis/mondayWrapper.d.ts.map +1 -1
  16. package/dist/apis/mondayWrapper.js +32 -527
  17. package/dist/apis/mongoWrapper.d.ts +6 -6
  18. package/dist/apis/mongoWrapper.d.ts.map +1 -1
  19. package/dist/apis/mongoWrapper.js +1 -1524
  20. package/dist/apis/postgresqlWrapper.d.ts +3 -3
  21. package/dist/apis/postgresqlWrapper.d.ts.map +1 -1
  22. package/dist/apis/postgresqlWrapper.js +1 -514
  23. package/dist/apis/security.d.ts.map +1 -1
  24. package/dist/apis/security.js +1 -80
  25. package/dist/apis/trackVisionWrapper.d.ts.map +1 -1
  26. package/dist/apis/trackVisionWrapper.js +1 -150
  27. package/dist/apis/uploadWrapper.d.ts.map +1 -1
  28. package/dist/apis/uploadWrapper.js +1 -481
  29. package/dist/apis/utils.d.ts +1 -1
  30. package/dist/apis/utils.d.ts.map +1 -1
  31. package/dist/apis/utils.js +1 -25
  32. package/dist/buildtsconfig.tsbuildinfo +1 -0
  33. package/dist/model/Log.js +1 -2
  34. package/dist/model/QueryModel.d.ts.map +1 -1
  35. package/dist/model/QueryModel.js +1 -118
  36. package/dist/model/SecurityConfig.js +1 -2
  37. package/package.json +21 -12
@@ -1,6 +1,6 @@
1
1
  export declare const compareUpdatedFields: (prevData: any, currentData: any) => {
2
2
  workflowUpdateFields: {
3
- [x: string]: any;
3
+ [key: string]: any;
4
4
  };
5
5
  updatedFields: {
6
6
  [key: string]: any;
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/apis/utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,oBAAoB,aAAc,GAAG,eAAe,GAAG;;;;;;;CAoBnE,CAAC;AAEF,eAAO,MAAM,6BAA6B,WAAY,MAAM,WAE3D,CAAC"}
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"}
@@ -1,25 +1 @@
1
- "use strict";
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
- "use strict";
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,WAAY,cAAc,OAAO,GAAG,YAmC/D,CAAC;AAEF;;;;;;;GAOG;AACH,eAAO,MAAM,cAAc,WACjB,cAAc,QAChB,MAAM,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,OACxC,GAAG,OACH,GAAG,YAyDT,CAAC"}
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"}
@@ -1,118 +1 @@
1
- "use strict";
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
- "use strict";
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.28",
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/node": "^17.0.35",
57
- "@typescript-eslint/eslint-plugin": "^5.25.0",
58
- "@typescript-eslint/parser": "^5.25.0",
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": "^6.0.0",
73
+ "helmet": "^8.0.0",
70
74
  "husky": "^8.0.2",
71
- "mongodb": "^4.11.0",
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
- "typescript": "^4.6.4"
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
  }