@prosopo/provider 2.9.8 → 3.0.5
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/CHANGELOG.md +179 -0
- package/dist/api/admin/apiRegisterSiteKeyEndpoint.d.ts.map +1 -1
- package/dist/api/admin/apiRegisterSiteKeyEndpoint.js +4 -4
- package/dist/api/admin/apiRegisterSiteKeyEndpoint.js.map +1 -1
- package/dist/api/admin/apiRemoveDetectorKeyEndpoint.d.ts.map +1 -1
- package/dist/api/admin/apiRemoveDetectorKeyEndpoint.js +5 -5
- package/dist/api/admin/apiRemoveDetectorKeyEndpoint.js.map +1 -1
- package/dist/api/admin/apiUpdateDetectorKeyEndpoint.d.ts.map +1 -1
- package/dist/api/admin/apiUpdateDetectorKeyEndpoint.js +5 -5
- package/dist/api/admin/apiUpdateDetectorKeyEndpoint.js.map +1 -1
- package/dist/api/blacklistRequestInspector.d.ts +6 -8
- package/dist/api/blacklistRequestInspector.d.ts.map +1 -1
- package/dist/api/blacklistRequestInspector.js +38 -20
- package/dist/api/blacklistRequestInspector.js.map +1 -1
- package/dist/api/block.d.ts.map +1 -1
- package/dist/api/block.js +5 -5
- package/dist/api/block.js.map +1 -1
- package/dist/api/captcha.d.ts.map +1 -1
- package/dist/api/captcha.js +114 -24
- package/dist/api/captcha.js.map +1 -1
- package/dist/api/domainMiddleware.d.ts.map +1 -1
- package/dist/api/domainMiddleware.js +3 -3
- package/dist/api/domainMiddleware.js.map +1 -1
- package/dist/api/headerCheckMiddleware.js +2 -2
- package/dist/api/headerCheckMiddleware.js.map +1 -1
- package/dist/api/ja4Middleware.d.ts.map +1 -1
- package/dist/api/ja4Middleware.js +18 -6
- package/dist/api/ja4Middleware.js.map +1 -1
- package/dist/api/public.d.ts +1 -2
- package/dist/api/public.d.ts.map +1 -1
- package/dist/api/public.js +9 -4
- package/dist/api/public.js.map +1 -1
- package/dist/api/validateAddress.d.ts +2 -2
- package/dist/api/validateAddress.d.ts.map +1 -1
- package/dist/api/validateAddress.js +10 -4
- package/dist/api/validateAddress.js.map +1 -1
- package/dist/api/verify.d.ts.map +1 -1
- package/dist/api/verify.js +8 -7
- package/dist/api/verify.js.map +1 -1
- package/dist/cjs/api/admin/apiRegisterSiteKeyEndpoint.cjs +3 -3
- package/dist/cjs/api/admin/apiRemoveDetectorKeyEndpoint.cjs +4 -4
- package/dist/cjs/api/admin/apiUpdateDetectorKeyEndpoint.cjs +4 -4
- package/dist/cjs/api/blacklistRequestInspector.cjs +36 -21
- package/dist/cjs/api/block.cjs +4 -5
- package/dist/cjs/api/captcha.cjs +116 -39
- package/dist/cjs/api/domainMiddleware.cjs +3 -3
- package/dist/cjs/api/headerCheckMiddleware.cjs +1 -1
- package/dist/cjs/api/ja4Middleware.cjs +17 -8
- package/dist/cjs/api/public.cjs +9 -4
- package/dist/cjs/api/validateAddress.cjs +12 -6
- package/dist/cjs/api/verify.cjs +13 -12
- package/dist/cjs/index.cjs +1 -5
- package/dist/cjs/schedulers/captchaScheduler.cjs +11 -7
- package/dist/cjs/schedulers/getClientList.cjs +12 -5
- package/dist/cjs/tasks/captchaManager.cjs +76 -23
- package/dist/cjs/tasks/client/clientTasks.cjs +25 -19
- package/dist/cjs/tasks/detection/decodePayload.cjs +284 -362
- package/dist/cjs/tasks/frictionless/frictionlessTasks.cjs +32 -25
- package/dist/cjs/tasks/imgCaptcha/imgCaptchaTasks.cjs +37 -26
- package/dist/cjs/tasks/powCaptcha/powTasks.cjs +19 -18
- package/dist/cjs/tasks/powCaptcha/powTasksUtils.cjs +5 -3
- package/dist/cjs/tasks/tasks.cjs +11 -2
- package/dist/cjs/util.cjs +58 -8
- package/dist/index.d.ts +0 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +0 -2
- package/dist/index.js.map +1 -1
- package/dist/schedulers/captchaScheduler.d.ts +1 -1
- package/dist/schedulers/captchaScheduler.d.ts.map +1 -1
- package/dist/schedulers/captchaScheduler.js +11 -3
- package/dist/schedulers/captchaScheduler.js.map +1 -1
- package/dist/schedulers/getClientList.d.ts +1 -1
- package/dist/schedulers/getClientList.d.ts.map +1 -1
- package/dist/schedulers/getClientList.js +12 -3
- package/dist/schedulers/getClientList.js.map +1 -1
- package/dist/tasks/captchaManager.d.ts +14 -1
- package/dist/tasks/captchaManager.d.ts.map +1 -1
- package/dist/tasks/captchaManager.js +67 -24
- package/dist/tasks/captchaManager.js.map +1 -1
- package/dist/tasks/client/clientTasks.d.ts.map +1 -1
- package/dist/tasks/client/clientTasks.js +26 -18
- package/dist/tasks/client/clientTasks.js.map +1 -1
- package/dist/tasks/detection/decodePayload.d.ts +2 -2
- package/dist/tasks/detection/decodePayload.d.ts.map +1 -1
- package/dist/tasks/detection/decodePayload.js +184 -230
- package/dist/tasks/detection/decodePayload.js.map +1 -1
- package/dist/tasks/frictionless/frictionlessTasks.d.ts +4 -5
- package/dist/tasks/frictionless/frictionlessTasks.d.ts.map +1 -1
- package/dist/tasks/frictionless/frictionlessTasks.js +32 -24
- package/dist/tasks/frictionless/frictionlessTasks.js.map +1 -1
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts +1 -1
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.d.ts.map +1 -1
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.js +38 -25
- package/dist/tasks/imgCaptcha/imgCaptchaTasks.js.map +1 -1
- package/dist/tasks/powCaptcha/powTasks.d.ts +1 -1
- package/dist/tasks/powCaptcha/powTasks.d.ts.map +1 -1
- package/dist/tasks/powCaptcha/powTasks.js +17 -18
- package/dist/tasks/powCaptcha/powTasks.js.map +1 -1
- package/dist/tasks/powCaptcha/powTasksUtils.d.ts +1 -1
- package/dist/tasks/powCaptcha/powTasksUtils.d.ts.map +1 -1
- package/dist/tasks/powCaptcha/powTasksUtils.js +5 -3
- package/dist/tasks/powCaptcha/powTasksUtils.js.map +1 -1
- package/dist/tasks/tasks.d.ts +3 -2
- package/dist/tasks/tasks.d.ts.map +1 -1
- package/dist/tasks/tasks.js +13 -3
- package/dist/tasks/tasks.js.map +1 -1
- package/dist/tests/integration/imgCaptcha.integration.test.js +3 -2
- package/dist/tests/integration/imgCaptcha.integration.test.js.map +1 -1
- package/dist/tests/integration/powCaptcha.integration.test.js +9 -9
- package/dist/tests/integration/powCaptcha.integration.test.js.map +1 -1
- package/dist/tests/integration/registerSitekey.d.ts.map +1 -1
- package/dist/tests/integration/registerSitekey.js +13 -2
- package/dist/tests/integration/registerSitekey.js.map +1 -1
- package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts +2 -0
- package/dist/tests/unit/api/ignoreMiddleware.unit.test.d.ts.map +1 -0
- package/dist/tests/unit/api/ignoreMiddleware.unit.test.js +43 -0
- package/dist/tests/unit/api/ignoreMiddleware.unit.test.js.map +1 -0
- package/dist/tests/unit/api/ja4Middleware.unit.test.js +18 -4
- package/dist/tests/unit/api/ja4Middleware.unit.test.js.map +1 -1
- package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js +30 -18
- package/dist/tests/unit/schedulers/captchaScheduler.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/captchaManager.unit.test.js +11 -5
- package/dist/tests/unit/tasks/captchaManager.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/client/clientTasks.unit.test.js +43 -19
- package/dist/tests/unit/tasks/client/clientTasks.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js +11 -4
- package/dist/tests/unit/tasks/dataset/datasetTasks.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js +9 -8
- package/dist/tests/unit/tasks/frictionless/frictionlessTasks.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js +29 -10
- package/dist/tests/unit/tasks/imgCaptcha/imgCaptchaTasks.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js +2 -3
- package/dist/tests/unit/tasks/powCaptcha/powTasks.unit.test.js.map +1 -1
- package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js +4 -2
- package/dist/tests/unit/tasks/powCaptcha/powTasksUtils.unit.test.js.map +1 -1
- package/dist/tests/unit/util.unit.test.js +110 -2
- package/dist/tests/unit/util.unit.test.js.map +1 -1
- package/dist/util.d.ts +5 -0
- package/dist/util.d.ts.map +1 -1
- package/dist/util.js +57 -5
- package/dist/util.js.map +1 -1
- package/package.json +23 -19
- package/vite.test.config.ts +1 -1
- package/dist/api/authMiddleware.d.ts +0 -6
- package/dist/api/authMiddleware.d.ts.map +0 -1
- package/dist/api/authMiddleware.js +0 -82
- package/dist/api/authMiddleware.js.map +0 -1
- package/dist/api/requestLoggerMiddleware.d.ts +0 -4
- package/dist/api/requestLoggerMiddleware.d.ts.map +0 -1
- package/dist/api/requestLoggerMiddleware.js +0 -12
- package/dist/api/requestLoggerMiddleware.js.map +0 -1
- package/dist/cjs/api/authMiddleware.cjs +0 -81
- package/dist/cjs/api/requestLoggerMiddleware.cjs +0 -14
- package/dist/tests/unit/api/authMiddleware.unit.test.d.ts +0 -2
- package/dist/tests/unit/api/authMiddleware.unit.test.d.ts.map +0 -1
- package/dist/tests/unit/api/authMiddleware.unit.test.js +0 -125
- package/dist/tests/unit/api/authMiddleware.unit.test.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,184 @@
|
|
|
1
1
|
# @prosopo/provider
|
|
2
2
|
|
|
3
|
+
## 3.0.5
|
|
4
|
+
### Patch Changes
|
|
5
|
+
|
|
6
|
+
- Updated dependencies [745cc89]
|
|
7
|
+
- @prosopo/config@3.1.0
|
|
8
|
+
- @prosopo/database@3.0.5
|
|
9
|
+
- @prosopo/datasets@3.0.5
|
|
10
|
+
- @prosopo/env@3.0.5
|
|
11
|
+
- @prosopo/types-database@3.0.5
|
|
12
|
+
- @prosopo/types-env@2.7.9
|
|
13
|
+
- @prosopo/util@3.0.2
|
|
14
|
+
- @prosopo/user-access-policy@3.1.4
|
|
15
|
+
|
|
16
|
+
## 3.0.4
|
|
17
|
+
### Patch Changes
|
|
18
|
+
|
|
19
|
+
- Updated dependencies [5619b4b]
|
|
20
|
+
- @prosopo/config@3.0.1
|
|
21
|
+
- @prosopo/database@3.0.4
|
|
22
|
+
- @prosopo/datasets@3.0.4
|
|
23
|
+
- @prosopo/env@3.0.4
|
|
24
|
+
- @prosopo/types-database@3.0.4
|
|
25
|
+
- @prosopo/types-env@2.7.8
|
|
26
|
+
- @prosopo/util@3.0.1
|
|
27
|
+
- @prosopo/user-access-policy@3.1.3
|
|
28
|
+
|
|
29
|
+
## 3.0.3
|
|
30
|
+
### Patch Changes
|
|
31
|
+
|
|
32
|
+
- Updated dependencies [f682f0c]
|
|
33
|
+
- @prosopo/types-database@3.0.3
|
|
34
|
+
- @prosopo/database@3.0.3
|
|
35
|
+
- @prosopo/types@3.0.2
|
|
36
|
+
- @prosopo/datasets@3.0.3
|
|
37
|
+
- @prosopo/env@3.0.3
|
|
38
|
+
- @prosopo/types-env@2.7.7
|
|
39
|
+
- @prosopo/common@3.0.2
|
|
40
|
+
- @prosopo/keyring@2.8.5
|
|
41
|
+
- @prosopo/user-access-policy@3.1.2
|
|
42
|
+
- @prosopo/api-express-router@3.0.2
|
|
43
|
+
- @prosopo/api-route@2.6.7
|
|
44
|
+
|
|
45
|
+
## 3.0.2
|
|
46
|
+
### Patch Changes
|
|
47
|
+
|
|
48
|
+
- @prosopo/common@3.0.1
|
|
49
|
+
- @prosopo/types@3.0.1
|
|
50
|
+
- @prosopo/api-express-router@3.0.1
|
|
51
|
+
- @prosopo/api-route@2.6.6
|
|
52
|
+
- @prosopo/database@3.0.2
|
|
53
|
+
- @prosopo/datasets@3.0.2
|
|
54
|
+
- @prosopo/env@3.0.2
|
|
55
|
+
- @prosopo/keyring@2.8.4
|
|
56
|
+
- @prosopo/types-database@3.0.2
|
|
57
|
+
- @prosopo/types-env@2.7.6
|
|
58
|
+
- @prosopo/user-access-policy@3.1.1
|
|
59
|
+
|
|
60
|
+
## 3.0.1
|
|
61
|
+
### Patch Changes
|
|
62
|
+
|
|
63
|
+
- Updated dependencies [913f2a6]
|
|
64
|
+
- @prosopo/user-access-policy@3.1.0
|
|
65
|
+
- @prosopo/types-database@3.0.1
|
|
66
|
+
- @prosopo/database@3.0.1
|
|
67
|
+
- @prosopo/datasets@3.0.1
|
|
68
|
+
- @prosopo/env@3.0.1
|
|
69
|
+
- @prosopo/types-env@2.7.5
|
|
70
|
+
|
|
71
|
+
## 3.0.0
|
|
72
|
+
### Major Changes
|
|
73
|
+
|
|
74
|
+
- 64b5bcd: Access Controls
|
|
75
|
+
|
|
76
|
+
### Patch Changes
|
|
77
|
+
|
|
78
|
+
- Updated dependencies [64b5bcd]
|
|
79
|
+
- @prosopo/api-express-router@3.0.0
|
|
80
|
+
- @prosopo/user-access-policy@3.0.0
|
|
81
|
+
- @prosopo/types-database@3.0.0
|
|
82
|
+
- @prosopo/database@3.0.0
|
|
83
|
+
- @prosopo/datasets@3.0.0
|
|
84
|
+
- @prosopo/common@3.0.0
|
|
85
|
+
- @prosopo/types@3.0.0
|
|
86
|
+
- @prosopo/util@3.0.0
|
|
87
|
+
- @prosopo/env@3.0.0
|
|
88
|
+
- @prosopo/config@3.0.0
|
|
89
|
+
- @prosopo/types-env@2.7.4
|
|
90
|
+
- @prosopo/api-route@2.6.5
|
|
91
|
+
- @prosopo/keyring@2.8.3
|
|
92
|
+
|
|
93
|
+
## 2.14.0
|
|
94
|
+
### Minor Changes
|
|
95
|
+
|
|
96
|
+
- aee3efe: Add healthz endpoint
|
|
97
|
+
|
|
98
|
+
### Patch Changes
|
|
99
|
+
|
|
100
|
+
- Updated dependencies [aee3efe]
|
|
101
|
+
- @prosopo/types@2.10.0
|
|
102
|
+
- @prosopo/database@2.6.9
|
|
103
|
+
- @prosopo/datasets@2.7.3
|
|
104
|
+
- @prosopo/env@2.7.3
|
|
105
|
+
- @prosopo/keyring@2.8.2
|
|
106
|
+
- @prosopo/types-database@2.7.6
|
|
107
|
+
- @prosopo/types-env@2.7.3
|
|
108
|
+
- @prosopo/user-access-policy@2.6.8
|
|
109
|
+
|
|
110
|
+
## 2.13.0
|
|
111
|
+
### Minor Changes
|
|
112
|
+
|
|
113
|
+
- d5f2e95: Fix ip checking logic
|
|
114
|
+
|
|
115
|
+
## 2.12.1
|
|
116
|
+
### Patch Changes
|
|
117
|
+
|
|
118
|
+
- 86c22b8: structured logging
|
|
119
|
+
- Updated dependencies [86c22b8]
|
|
120
|
+
- @prosopo/api-express-router@2.6.4
|
|
121
|
+
- @prosopo/user-access-policy@2.6.7
|
|
122
|
+
- @prosopo/types-database@2.7.5
|
|
123
|
+
- @prosopo/util-crypto@13.5.1
|
|
124
|
+
- @prosopo/api-route@2.6.4
|
|
125
|
+
- @prosopo/types-env@2.7.2
|
|
126
|
+
- @prosopo/database@2.6.8
|
|
127
|
+
- @prosopo/datasets@2.7.2
|
|
128
|
+
- @prosopo/keyring@2.8.1
|
|
129
|
+
- @prosopo/common@2.7.2
|
|
130
|
+
- @prosopo/types@2.9.1
|
|
131
|
+
- @prosopo/env@2.7.2
|
|
132
|
+
- @prosopo/config@2.6.1
|
|
133
|
+
- @prosopo/util@2.6.1
|
|
134
|
+
|
|
135
|
+
## 2.12.0
|
|
136
|
+
### Minor Changes
|
|
137
|
+
|
|
138
|
+
- d6de900: ip pass through
|
|
139
|
+
|
|
140
|
+
## 2.11.0
|
|
141
|
+
### Minor Changes
|
|
142
|
+
|
|
143
|
+
- 30bb383: Making sure verify works and derived accounts
|
|
144
|
+
|
|
145
|
+
### Patch Changes
|
|
146
|
+
|
|
147
|
+
- Updated dependencies [30bb383]
|
|
148
|
+
- @prosopo/util-crypto@13.5.0
|
|
149
|
+
- @prosopo/keyring@2.8.0
|
|
150
|
+
- @prosopo/types@2.9.0
|
|
151
|
+
- @prosopo/common@2.7.1
|
|
152
|
+
- @prosopo/datasets@2.7.1
|
|
153
|
+
- @prosopo/database@2.6.7
|
|
154
|
+
- @prosopo/env@2.7.1
|
|
155
|
+
- @prosopo/types-database@2.7.4
|
|
156
|
+
- @prosopo/types-env@2.7.1
|
|
157
|
+
- @prosopo/user-access-policy@2.6.6
|
|
158
|
+
- @prosopo/api-express-router@2.6.3
|
|
159
|
+
- @prosopo/api-route@2.6.3
|
|
160
|
+
|
|
161
|
+
## 2.10.0
|
|
162
|
+
### Minor Changes
|
|
163
|
+
|
|
164
|
+
- 8f0644a: Taking required functions from polkadot/keyring and polkadot/util-crypto in-house and removing WASM dependencies. Adding @scure JS-based sr25519 function instead.
|
|
165
|
+
|
|
166
|
+
### Patch Changes
|
|
167
|
+
|
|
168
|
+
- Updated dependencies [8f0644a]
|
|
169
|
+
- @prosopo/util-crypto@13.4.0
|
|
170
|
+
- @prosopo/types-env@2.7.0
|
|
171
|
+
- @prosopo/datasets@2.7.0
|
|
172
|
+
- @prosopo/keyring@2.7.0
|
|
173
|
+
- @prosopo/common@2.7.0
|
|
174
|
+
- @prosopo/types@2.8.0
|
|
175
|
+
- @prosopo/env@2.7.0
|
|
176
|
+
- @prosopo/api-express-router@2.6.2
|
|
177
|
+
- @prosopo/api-route@2.6.2
|
|
178
|
+
- @prosopo/database@2.6.6
|
|
179
|
+
- @prosopo/types-database@2.7.3
|
|
180
|
+
- @prosopo/user-access-policy@2.6.5
|
|
181
|
+
|
|
3
182
|
## 2.9.8
|
|
4
183
|
|
|
5
184
|
### Patch Changes
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"apiRegisterSiteKeyEndpoint.d.ts","sourceRoot":"","sources":["../../../src/api/admin/apiRegisterSiteKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,KAAK,MAAM,
|
|
1
|
+
{"version":3,"file":"apiRegisterSiteKeyEndpoint.d.ts","sourceRoot":"","sources":["../../../src/api/admin/apiRegisterSiteKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,KAAK,MAAM,EAAa,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAwB,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC3E,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAC7B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AAE3E,KAAK,uBAAuB,GAAG,OAAO,mBAAmB,CAAC;AAE1D,cAAM,0BACL,YAAW,WAAW,CAAC,uBAAuB,CAAC;IAE5B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;gBAAjB,iBAAiB,EAAE,iBAAiB;IAElE,cAAc,CACnB,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,uBAAuB,CAAC,EACtC,MAAM,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,mBAAmB,CAAC;IAkBxB,oBAAoB,IAAI,uBAAuB;CAGtD;AAED,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ApiEndpointResponseStatus, } from "@prosopo/api-route";
|
|
2
|
-
import {
|
|
2
|
+
import { getLogger } from "@prosopo/common";
|
|
3
3
|
import { ClientSettingsSchema, RegisterSitekeyBody } from "@prosopo/types";
|
|
4
4
|
class ApiRegisterSiteKeyEndpoint {
|
|
5
5
|
constructor(clientTaskManager) {
|
|
@@ -7,11 +7,11 @@ class ApiRegisterSiteKeyEndpoint {
|
|
|
7
7
|
}
|
|
8
8
|
async processRequest(args, logger) {
|
|
9
9
|
const { siteKey, tier, settings } = args;
|
|
10
|
-
logger = logger ||
|
|
10
|
+
logger = logger || getLogger("info", import.meta.url);
|
|
11
11
|
const temp = settings || ClientSettingsSchema.parse({});
|
|
12
|
-
logger.info(`Registering site key
|
|
12
|
+
logger.info(() => ({ data: { siteKey }, msg: "`Registering site key" }));
|
|
13
13
|
await this.clientTaskManager.registerSiteKey(siteKey, tier, temp);
|
|
14
|
-
logger.info("Site key registered");
|
|
14
|
+
logger.info(() => ({ msg: "Site key registered" }));
|
|
15
15
|
return {
|
|
16
16
|
status: ApiEndpointResponseStatus.SUCCESS,
|
|
17
17
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"apiRegisterSiteKeyEndpoint.js","sourceRoot":"","sources":["../../../src/api/admin/apiRegisterSiteKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAe,
|
|
1
|
+
{"version":3,"file":"apiRegisterSiteKeyEndpoint.js","sourceRoot":"","sources":["../../../src/api/admin/apiRegisterSiteKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAe,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAM3E,MAAM,0BAA0B;IAG/B,YAAoC,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;IAAG,CAAC;IAE5E,KAAK,CAAC,cAAc,CACnB,IAAsC,EACtC,MAAe;QAEf,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC;QAEzC,MAAM,GAAG,MAAM,IAAI,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEtD,MAAM,IAAI,GAAG,QAAQ,IAAI,oBAAoB,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAExD,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,OAAO,EAAE,EAAE,GAAG,EAAE,uBAAuB,EAAE,CAAC,CAAC,CAAC;QAEzE,MAAM,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAElE,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,qBAAqB,EAAE,CAAC,CAAC,CAAC;QAEpD,OAAO;YACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;SACzC,CAAC;IACH,CAAC;IAEM,oBAAoB;QAC1B,OAAO,mBAAmB,CAAC;IAC5B,CAAC;CACD;AAED,OAAO,EAAE,0BAA0B,EAAE,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"apiRemoveDetectorKeyEndpoint.d.ts","sourceRoot":"","sources":["../../../src/api/admin/apiRemoveDetectorKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,
|
|
1
|
+
{"version":3,"file":"apiRemoveDetectorKeyEndpoint.d.ts","sourceRoot":"","sources":["../../../src/api/admin/apiRemoveDetectorKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,KAAK,MAAM,EAAmC,MAAM,iBAAiB,CAAC;AAC/E,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAC7B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AAE3E,KAAK,yBAAyB,GAAG,OAAO,qBAAqB,CAAC;AAE9D,cAAM,4BACL,YAAW,WAAW,CAAC,yBAAyB,CAAC;IAE9B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;gBAAjB,iBAAiB,EAAE,iBAAiB;IAElE,cAAc,CACnB,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,yBAAyB,CAAC,EACxC,MAAM,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,mBAAmB,CAAC;IAuBxB,oBAAoB,IAAI,yBAAyB;CAGxD;AAED,OAAO,EAAE,4BAA4B,EAAE,CAAC"}
|
|
@@ -1,23 +1,23 @@
|
|
|
1
1
|
import { ApiEndpointResponseStatus, } from "@prosopo/api-route";
|
|
2
|
-
import {
|
|
2
|
+
import { getLogger } from "@prosopo/common";
|
|
3
3
|
import { UpdateDetectorKeyBody } from "@prosopo/types";
|
|
4
4
|
class ApiRemoveDetectorKeyEndpoint {
|
|
5
5
|
constructor(clientTaskManager) {
|
|
6
6
|
this.clientTaskManager = clientTaskManager;
|
|
7
7
|
}
|
|
8
8
|
async processRequest(args, logger) {
|
|
9
|
-
logger = logger ||
|
|
9
|
+
logger = logger || getLogger("info", import.meta.url);
|
|
10
10
|
try {
|
|
11
11
|
const { detectorKey } = args;
|
|
12
|
-
logger = logger ||
|
|
13
|
-
logger.info({
|
|
12
|
+
logger = logger || getLogger("info", import.meta.url);
|
|
13
|
+
logger.info(() => ({ msg: "Removing detector key" }));
|
|
14
14
|
await this.clientTaskManager.removeDetectorKey(detectorKey);
|
|
15
15
|
return {
|
|
16
16
|
status: ApiEndpointResponseStatus.SUCCESS,
|
|
17
17
|
};
|
|
18
18
|
}
|
|
19
19
|
catch (error) {
|
|
20
|
-
logger.error({
|
|
20
|
+
logger.error(() => ({ err: error, msg: "Error updating detector key" }));
|
|
21
21
|
return {
|
|
22
22
|
status: ApiEndpointResponseStatus.FAIL,
|
|
23
23
|
error: error.message,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"apiRemoveDetectorKeyEndpoint.js","sourceRoot":"","sources":["../../../src/api/admin/apiRemoveDetectorKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,
|
|
1
|
+
{"version":3,"file":"apiRemoveDetectorKeyEndpoint.js","sourceRoot":"","sources":["../../../src/api/admin/apiRemoveDetectorKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAqC,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC/E,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AAMvD,MAAM,4BAA4B;IAGjC,YAAoC,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;IAAG,CAAC;IAE5E,KAAK,CAAC,cAAc,CACnB,IAAwC,EACxC,MAAe;QAEf,MAAM,GAAG,MAAM,IAAI,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACtD,IAAI,CAAC;YACJ,MAAM,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC;YAE7B,MAAM,GAAG,MAAM,IAAI,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAEtD,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,uBAAuB,EAAE,CAAC,CAAC,CAAC;YAEtD,MAAM,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;YAE5D,OAAO;gBACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;aACzC,CAAC;QACH,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACzB,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,6BAA6B,EAAE,CAAC,CAAC,CAAC;YACzE,OAAO;gBACN,MAAM,EAAE,yBAAyB,CAAC,IAAI;gBACtC,KAAK,EAAG,KAAyB,CAAC,OAAO;aACzC,CAAC;QACH,CAAC;IACF,CAAC;IAEM,oBAAoB;QAC1B,OAAO,qBAAqB,CAAC;IAC9B,CAAC;CACD;AAED,OAAO,EAAE,4BAA4B,EAAE,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"apiUpdateDetectorKeyEndpoint.d.ts","sourceRoot":"","sources":["../../../src/api/admin/apiUpdateDetectorKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,
|
|
1
|
+
{"version":3,"file":"apiUpdateDetectorKeyEndpoint.d.ts","sourceRoot":"","sources":["../../../src/api/admin/apiUpdateDetectorKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EACN,KAAK,WAAW,EAChB,KAAK,mBAAmB,EAExB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,KAAK,MAAM,EAAmC,MAAM,iBAAiB,CAAC;AAC/E,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAC7B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAC;AAE3E,KAAK,yBAAyB,GAAG,OAAO,qBAAqB,CAAC;AAE9D,cAAM,4BACL,YAAW,WAAW,CAAC,yBAAyB,CAAC;IAE9B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;gBAAjB,iBAAiB,EAAE,iBAAiB;IAElE,cAAc,CACnB,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,yBAAyB,CAAC,EACxC,MAAM,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,mBAAmB,CAAC;IAuBxB,oBAAoB,IAAI,yBAAyB;CAGxD;AAED,OAAO,EAAE,4BAA4B,EAAE,CAAC"}
|
|
@@ -1,23 +1,23 @@
|
|
|
1
1
|
import { ApiEndpointResponseStatus, } from "@prosopo/api-route";
|
|
2
|
-
import {
|
|
2
|
+
import { getLogger } from "@prosopo/common";
|
|
3
3
|
import { UpdateDetectorKeyBody } from "@prosopo/types";
|
|
4
4
|
class ApiUpdateDetectorKeyEndpoint {
|
|
5
5
|
constructor(clientTaskManager) {
|
|
6
6
|
this.clientTaskManager = clientTaskManager;
|
|
7
7
|
}
|
|
8
8
|
async processRequest(args, logger) {
|
|
9
|
-
logger = logger ||
|
|
9
|
+
logger = logger || getLogger("info", "");
|
|
10
10
|
try {
|
|
11
11
|
const { detectorKey } = args;
|
|
12
|
-
logger = logger ||
|
|
13
|
-
logger.info("Updating detector key");
|
|
12
|
+
logger = logger || getLogger("info", "");
|
|
13
|
+
logger.info(() => ({ msg: "Updating detector key" }));
|
|
14
14
|
await this.clientTaskManager.updateDetectorKey(detectorKey);
|
|
15
15
|
return {
|
|
16
16
|
status: ApiEndpointResponseStatus.SUCCESS,
|
|
17
17
|
};
|
|
18
18
|
}
|
|
19
19
|
catch (error) {
|
|
20
|
-
logger.error("Error updating detector key", error);
|
|
20
|
+
logger.error(() => ({ msg: "Error updating detector key", err: error }));
|
|
21
21
|
return {
|
|
22
22
|
status: ApiEndpointResponseStatus.FAIL,
|
|
23
23
|
error: error.message,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"apiUpdateDetectorKeyEndpoint.js","sourceRoot":"","sources":["../../../src/api/admin/apiUpdateDetectorKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,
|
|
1
|
+
{"version":3,"file":"apiUpdateDetectorKeyEndpoint.js","sourceRoot":"","sources":["../../../src/api/admin/apiUpdateDetectorKeyEndpoint.ts"],"names":[],"mappings":"AAcA,OAAO,EAGN,yBAAyB,GACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAqC,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC/E,OAAO,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AAMvD,MAAM,4BAA4B;IAGjC,YAAoC,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;IAAG,CAAC;IAE5E,KAAK,CAAC,cAAc,CACnB,IAAwC,EACxC,MAAe;QAEf,MAAM,GAAG,MAAM,IAAI,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QACzC,IAAI,CAAC;YACJ,MAAM,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC;YAE7B,MAAM,GAAG,MAAM,IAAI,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YAEzC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,uBAAuB,EAAE,CAAC,CAAC,CAAC;YAEtD,MAAM,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;YAE5D,OAAO;gBACN,MAAM,EAAE,yBAAyB,CAAC,OAAO;aACzC,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,6BAA6B,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;YACzE,OAAO;gBACN,MAAM,EAAE,yBAAyB,CAAC,IAAI;gBACtC,KAAK,EAAG,KAAyB,CAAC,OAAO;aACzC,CAAC;QACH,CAAC;IACF,CAAC;IAEM,oBAAoB;QAC1B,OAAO,qBAAqB,CAAC;IAC9B,CAAC;CACD;AAED,OAAO,EAAE,4BAA4B,EAAE,CAAC"}
|
|
@@ -1,19 +1,17 @@
|
|
|
1
1
|
import type { Logger } from "@prosopo/common";
|
|
2
|
-
import type
|
|
2
|
+
import { type ResolveAccessPolicy } from "@prosopo/user-access-policy";
|
|
3
3
|
import type { NextFunction, Request, Response } from "express";
|
|
4
|
-
declare class BlacklistRequestInspector {
|
|
5
|
-
private readonly
|
|
4
|
+
export declare class BlacklistRequestInspector {
|
|
5
|
+
private readonly resolveAccessPolicy;
|
|
6
6
|
private readonly environmentReadinessWaiter;
|
|
7
|
-
|
|
8
|
-
constructor(blacklistInspector: BlacklistInspector, environmentReadinessWaiter: () => Promise<void>, logger: Logger);
|
|
7
|
+
constructor(resolveAccessPolicy: ResolveAccessPolicy, environmentReadinessWaiter: () => Promise<void>);
|
|
9
8
|
abortRequestForBlockedUsers(request: Request, res: Response, next: NextFunction): Promise<void>;
|
|
10
9
|
shouldAbortRequest(requestedRoute: string, rawIp: string, ja4: string, requestHeaders: Record<string, unknown>, requestBody: Record<string, unknown>, logger: Logger): Promise<boolean>;
|
|
11
10
|
protected isApiUnrelatedRoute(url: string): boolean;
|
|
12
11
|
protected extractIdsFromRequest(requestHeaders: Record<string, unknown>, requestBody: Record<string, unknown>): {
|
|
13
|
-
userId: string;
|
|
14
|
-
clientId: string;
|
|
12
|
+
userId: string | undefined;
|
|
13
|
+
clientId: string | undefined;
|
|
15
14
|
};
|
|
16
15
|
protected getObjectValue(object: Record<string, unknown>, key: string): unknown;
|
|
17
16
|
}
|
|
18
|
-
export { BlacklistRequestInspector };
|
|
19
17
|
//# sourceMappingURL=blacklistRequestInspector.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blacklistRequestInspector.d.ts","sourceRoot":"","sources":["../../src/api/blacklistRequestInspector.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"blacklistRequestInspector.d.ts","sourceRoot":"","sources":["../../src/api/blacklistRequestInspector.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,EACN,KAAK,mBAAmB,EAExB,MAAM,6BAA6B,CAAC;AAGrC,OAAO,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAE/D,qBAAa,yBAAyB;IAEpC,OAAO,CAAC,QAAQ,CAAC,mBAAmB;IACpC,OAAO,CAAC,QAAQ,CAAC,0BAA0B;gBAD1B,mBAAmB,EAAE,mBAAmB,EACxC,0BAA0B,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC;IAGpD,2BAA2B,CACvC,OAAO,EAAE,OAAO,EAChB,GAAG,EAAE,QAAQ,EACb,IAAI,EAAE,YAAY,GAChB,OAAO,CAAC,IAAI,CAAC;IAwBH,kBAAkB,CAC9B,cAAc,EAAE,MAAM,EACtB,KAAK,EAAE,MAAM,EACb,GAAG,EAAE,MAAM,EACX,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACvC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACpC,MAAM,EAAE,MAAM,GACZ,OAAO,CAAC,OAAO,CAAC;IAsDnB,SAAS,CAAC,mBAAmB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAInD,SAAS,CAAC,qBAAqB,CAC9B,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACvC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAClC;QACF,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;QAC3B,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;KAC7B;IAcD,SAAS,CAAC,cAAc,CACvB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC/B,GAAG,EAAE,MAAM,GACT,OAAO;CAGV"}
|
|
@@ -1,14 +1,17 @@
|
|
|
1
1
|
import { ApiPrefix } from "@prosopo/types";
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
import { ScopeMatch, } from "@prosopo/user-access-policy";
|
|
3
|
+
import { AccessPolicyType } from "@prosopo/user-access-policy";
|
|
4
|
+
import { getIPAddress } from "@prosopo/util";
|
|
5
|
+
export class BlacklistRequestInspector {
|
|
6
|
+
constructor(resolveAccessPolicy, environmentReadinessWaiter) {
|
|
7
|
+
this.resolveAccessPolicy = resolveAccessPolicy;
|
|
6
8
|
this.environmentReadinessWaiter = environmentReadinessWaiter;
|
|
7
|
-
this.logger = logger;
|
|
8
9
|
}
|
|
9
10
|
async abortRequestForBlockedUsers(request, res, next) {
|
|
10
11
|
const rawIp = request.ip || "";
|
|
11
|
-
request.logger.debug(
|
|
12
|
+
request.logger.debug(() => ({
|
|
13
|
+
data: { ja4: request.ja4 },
|
|
14
|
+
}));
|
|
12
15
|
const shouldAbortRequest = await this.shouldAbortRequest(request.url, rawIp, request.ja4, request.headers, request.body, request.logger);
|
|
13
16
|
if (shouldAbortRequest) {
|
|
14
17
|
res.status(401).json({ error: "Unauthorized" });
|
|
@@ -21,21 +24,39 @@ class BlacklistRequestInspector {
|
|
|
21
24
|
return false;
|
|
22
25
|
}
|
|
23
26
|
if (!rawIp) {
|
|
24
|
-
logger.info(
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
27
|
+
logger.info(() => ({
|
|
28
|
+
data: {
|
|
29
|
+
requestedRoute: requestedRoute,
|
|
30
|
+
requestHeaders: requestHeaders,
|
|
31
|
+
requestBody: requestBody,
|
|
32
|
+
},
|
|
33
|
+
msg: "Request without IP",
|
|
34
|
+
}));
|
|
29
35
|
return true;
|
|
30
36
|
}
|
|
31
37
|
await this.environmentReadinessWaiter();
|
|
32
38
|
try {
|
|
33
39
|
const userIpAddress = getIPAddress(rawIp);
|
|
34
40
|
const { userId, clientId } = this.extractIdsFromRequest(requestHeaders, requestBody);
|
|
35
|
-
|
|
41
|
+
const accessPolicy = await this.resolveAccessPolicy({
|
|
42
|
+
policyScope: {
|
|
43
|
+
clientId: clientId,
|
|
44
|
+
},
|
|
45
|
+
policyScopeMatch: ScopeMatch.Greedy,
|
|
46
|
+
userScope: {
|
|
47
|
+
userId: userId,
|
|
48
|
+
numericIp: userIpAddress.bigInt(),
|
|
49
|
+
ja4Hash: ja4,
|
|
50
|
+
},
|
|
51
|
+
userScopeMatch: ScopeMatch.Greedy,
|
|
52
|
+
});
|
|
53
|
+
return AccessPolicyType.Block === accessPolicy?.type;
|
|
36
54
|
}
|
|
37
55
|
catch (err) {
|
|
38
|
-
logger.error(
|
|
56
|
+
logger.error(() => ({
|
|
57
|
+
err,
|
|
58
|
+
msg: "Block Middleware Error",
|
|
59
|
+
}));
|
|
39
60
|
return true;
|
|
40
61
|
}
|
|
41
62
|
}
|
|
@@ -44,19 +65,16 @@ class BlacklistRequestInspector {
|
|
|
44
65
|
}
|
|
45
66
|
extractIdsFromRequest(requestHeaders, requestBody) {
|
|
46
67
|
const userId = this.getObjectValue(requestHeaders, "Prosopo-User") ||
|
|
47
|
-
this.getObjectValue(requestBody, "user")
|
|
48
|
-
"";
|
|
68
|
+
this.getObjectValue(requestBody, "user");
|
|
49
69
|
const clientId = this.getObjectValue(requestHeaders, "Prosopo-Site-Key") ||
|
|
50
|
-
this.getObjectValue(requestBody, "dapp")
|
|
51
|
-
"";
|
|
70
|
+
this.getObjectValue(requestBody, "dapp");
|
|
52
71
|
return {
|
|
53
|
-
userId: "string" === typeof userId ? userId :
|
|
54
|
-
clientId: "string" === typeof clientId ? clientId :
|
|
72
|
+
userId: "string" === typeof userId ? userId : undefined,
|
|
73
|
+
clientId: "string" === typeof clientId ? clientId : undefined,
|
|
55
74
|
};
|
|
56
75
|
}
|
|
57
76
|
getObjectValue(object, key) {
|
|
58
77
|
return object[key];
|
|
59
78
|
}
|
|
60
79
|
}
|
|
61
|
-
export { BlacklistRequestInspector };
|
|
62
80
|
//# sourceMappingURL=blacklistRequestInspector.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blacklistRequestInspector.js","sourceRoot":"","sources":["../../src/api/blacklistRequestInspector.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"blacklistRequestInspector.js","sourceRoot":"","sources":["../../src/api/blacklistRequestInspector.ts"],"names":[],"mappings":"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"}
|
package/dist/api/block.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"block.d.ts","sourceRoot":"","sources":["../../src/api/block.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"block.d.ts","sourceRoot":"","sources":["../../src/api/block.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAI9D,eAAO,MAAM,eAAe,wBAAyB,mBAAmB,iIAwBvE,CAAC"}
|
package/dist/api/block.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { getLogger } from "@prosopo/common";
|
|
2
|
-
import {
|
|
1
|
+
import { getLogger, parseLogLevel } from "@prosopo/common";
|
|
2
|
+
import { createAccessPolicyResolver } from "@prosopo/user-access-policy";
|
|
3
3
|
import { BlacklistRequestInspector } from "./blacklistRequestInspector.js";
|
|
4
4
|
export const blockMiddleware = (providerEnvironment) => {
|
|
5
|
-
const logLevel = providerEnvironment.config.logLevel;
|
|
5
|
+
const logLevel = parseLogLevel(providerEnvironment.config.logLevel);
|
|
6
6
|
const logger = getLogger(logLevel, "blockMiddleware");
|
|
7
7
|
const userAccessRulesStorage = providerEnvironment
|
|
8
8
|
.getDb()
|
|
9
9
|
.getUserAccessRulesStorage();
|
|
10
10
|
const environmentReadinessWaiter = providerEnvironment.isReady.bind(providerEnvironment);
|
|
11
|
-
const
|
|
12
|
-
const blacklistRequestInspector = new BlacklistRequestInspector(
|
|
11
|
+
const resolveAccessPolicy = createAccessPolicyResolver(userAccessRulesStorage, logger);
|
|
12
|
+
const blacklistRequestInspector = new BlacklistRequestInspector(resolveAccessPolicy, environmentReadinessWaiter);
|
|
13
13
|
return blacklistRequestInspector.abortRequestForBlockedUsers.bind(blacklistRequestInspector);
|
|
14
14
|
};
|
|
15
15
|
//# sourceMappingURL=block.js.map
|
package/dist/api/block.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"block.js","sourceRoot":"","sources":["../../src/api/block.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"block.js","sourceRoot":"","sources":["../../src/api/block.ts"],"names":[],"mappings":"AAcA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAE3D,OAAO,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AACzE,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAE3E,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,mBAAwC,EAAE,EAAE;IAC3E,MAAM,QAAQ,GAAG,aAAa,CAAC,mBAAmB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACpE,MAAM,MAAM,GAAG,SAAS,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;IAEtD,MAAM,sBAAsB,GAAG,mBAAmB;SAChD,KAAK,EAAE;SACP,yBAAyB,EAAE,CAAC;IAE9B,MAAM,0BAA0B,GAC/B,mBAAmB,CAAC,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IAEvD,MAAM,mBAAmB,GAAG,0BAA0B,CACrD,sBAAsB,EACtB,MAAM,CACN,CAAC;IAEF,MAAM,yBAAyB,GAAG,IAAI,yBAAyB,CAC9D,mBAAmB,EACnB,0BAA0B,CAC1B,CAAC;IAEF,OAAO,yBAAyB,CAAC,2BAA2B,CAAC,IAAI,CAChE,yBAAyB,CACzB,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"captcha.d.ts","sourceRoot":"","sources":["../../src/api/captcha.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"captcha.d.ts","sourceRoot":"","sources":["../../src/api/captcha.ts"],"names":[],"mappings":"AAsCA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAO9D,OAAgB,EAAE,KAAK,MAAM,EAAE,MAAM,SAAS,CAAC;AAc/C,wBAAgB,aAAa,CAAC,GAAG,EAAE,mBAAmB,GAAG,MAAM,CA6pB9D"}
|