@cheqd/studio 3.0.0-develop.1

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 (654) hide show
  1. package/LICENSE +190 -0
  2. package/README.md +246 -0
  3. package/dist/app.d.ts +4 -0
  4. package/dist/app.d.ts.map +1 -0
  5. package/dist/app.js +180 -0
  6. package/dist/app.js.map +1 -0
  7. package/dist/controllers/admin/api-key.d.ts +153 -0
  8. package/dist/controllers/admin/api-key.d.ts.map +1 -0
  9. package/dist/controllers/admin/api-key.js +389 -0
  10. package/dist/controllers/admin/api-key.js.map +1 -0
  11. package/dist/controllers/admin/organisation.d.ts +72 -0
  12. package/dist/controllers/admin/organisation.d.ts.map +1 -0
  13. package/dist/controllers/admin/organisation.js +139 -0
  14. package/dist/controllers/admin/organisation.js.map +1 -0
  15. package/dist/controllers/admin/prices.d.ts +37 -0
  16. package/dist/controllers/admin/prices.d.ts.map +1 -0
  17. package/dist/controllers/admin/prices.js +75 -0
  18. package/dist/controllers/admin/prices.js.map +1 -0
  19. package/dist/controllers/admin/product.d.ts +90 -0
  20. package/dist/controllers/admin/product.d.ts.map +1 -0
  21. package/dist/controllers/admin/product.js +187 -0
  22. package/dist/controllers/admin/product.js.map +1 -0
  23. package/dist/controllers/admin/subscriptions.d.ts +183 -0
  24. package/dist/controllers/admin/subscriptions.d.ts.map +1 -0
  25. package/dist/controllers/admin/subscriptions.js +512 -0
  26. package/dist/controllers/admin/subscriptions.js.map +1 -0
  27. package/dist/controllers/admin/webhook.d.ts +5 -0
  28. package/dist/controllers/admin/webhook.d.ts.map +1 -0
  29. package/dist/controllers/admin/webhook.js +90 -0
  30. package/dist/controllers/admin/webhook.js.map +1 -0
  31. package/dist/controllers/api/account.d.ts +84 -0
  32. package/dist/controllers/api/account.d.ts.map +1 -0
  33. package/dist/controllers/api/account.js +442 -0
  34. package/dist/controllers/api/account.js.map +1 -0
  35. package/dist/controllers/api/credential-status.d.ts +257 -0
  36. package/dist/controllers/api/credential-status.d.ts.map +1 -0
  37. package/dist/controllers/api/credential-status.js +1080 -0
  38. package/dist/controllers/api/credential-status.js.map +1 -0
  39. package/dist/controllers/api/credential.d.ts +207 -0
  40. package/dist/controllers/api/credential.d.ts.map +1 -0
  41. package/dist/controllers/api/credential.js +527 -0
  42. package/dist/controllers/api/credential.js.map +1 -0
  43. package/dist/controllers/api/did.d.ts +259 -0
  44. package/dist/controllers/api/did.d.ts.map +1 -0
  45. package/dist/controllers/api/did.js +673 -0
  46. package/dist/controllers/api/did.js.map +1 -0
  47. package/dist/controllers/api/key.d.ts +136 -0
  48. package/dist/controllers/api/key.d.ts.map +1 -0
  49. package/dist/controllers/api/key.js +268 -0
  50. package/dist/controllers/api/key.js.map +1 -0
  51. package/dist/controllers/api/presentation.d.ts +87 -0
  52. package/dist/controllers/api/presentation.d.ts.map +1 -0
  53. package/dist/controllers/api/presentation.js +264 -0
  54. package/dist/controllers/api/presentation.js.map +1 -0
  55. package/dist/controllers/api/resource.d.ts +118 -0
  56. package/dist/controllers/api/resource.d.ts.map +1 -0
  57. package/dist/controllers/api/resource.js +312 -0
  58. package/dist/controllers/api/resource.js.map +1 -0
  59. package/dist/controllers/validator/controller.d.ts +7 -0
  60. package/dist/controllers/validator/controller.d.ts.map +1 -0
  61. package/dist/controllers/validator/controller.js +31 -0
  62. package/dist/controllers/validator/controller.js.map +1 -0
  63. package/dist/controllers/validator/credential-status.d.ts +6 -0
  64. package/dist/controllers/validator/credential-status.d.ts.map +1 -0
  65. package/dist/controllers/validator/credential-status.js +36 -0
  66. package/dist/controllers/validator/credential-status.js.map +1 -0
  67. package/dist/controllers/validator/credential.d.ts +9 -0
  68. package/dist/controllers/validator/credential.d.ts.map +1 -0
  69. package/dist/controllers/validator/credential.js +103 -0
  70. package/dist/controllers/validator/credential.js.map +1 -0
  71. package/dist/controllers/validator/decorator.d.ts +2 -0
  72. package/dist/controllers/validator/decorator.d.ts.map +1 -0
  73. package/dist/controllers/validator/decorator.js +25 -0
  74. package/dist/controllers/validator/decorator.js.map +1 -0
  75. package/dist/controllers/validator/did-also-known-as.d.ts +8 -0
  76. package/dist/controllers/validator/did-also-known-as.d.ts.map +1 -0
  77. package/dist/controllers/validator/did-also-known-as.js +31 -0
  78. package/dist/controllers/validator/did-also-known-as.js.map +1 -0
  79. package/dist/controllers/validator/did-array.d.ts +7 -0
  80. package/dist/controllers/validator/did-array.d.ts.map +1 -0
  81. package/dist/controllers/validator/did-array.js +27 -0
  82. package/dist/controllers/validator/did-array.js.map +1 -0
  83. package/dist/controllers/validator/did-document-section-id.d.ts +7 -0
  84. package/dist/controllers/validator/did-document-section-id.d.ts.map +1 -0
  85. package/dist/controllers/validator/did-document-section-id.js +43 -0
  86. package/dist/controllers/validator/did-document-section-id.js.map +1 -0
  87. package/dist/controllers/validator/did-document.d.ts +11 -0
  88. package/dist/controllers/validator/did-document.d.ts.map +1 -0
  89. package/dist/controllers/validator/did-document.js +96 -0
  90. package/dist/controllers/validator/did-document.js.map +1 -0
  91. package/dist/controllers/validator/did-uri.d.ts +5 -0
  92. package/dist/controllers/validator/did-uri.d.ts.map +1 -0
  93. package/dist/controllers/validator/did-uri.js +14 -0
  94. package/dist/controllers/validator/did-uri.js.map +1 -0
  95. package/dist/controllers/validator/did.d.ts +35 -0
  96. package/dist/controllers/validator/did.d.ts.map +1 -0
  97. package/dist/controllers/validator/did.js +233 -0
  98. package/dist/controllers/validator/did.js.map +1 -0
  99. package/dist/controllers/validator/helpers.d.ts +7 -0
  100. package/dist/controllers/validator/helpers.d.ts.map +1 -0
  101. package/dist/controllers/validator/helpers.js +6 -0
  102. package/dist/controllers/validator/helpers.js.map +1 -0
  103. package/dist/controllers/validator/identifier.d.ts +20 -0
  104. package/dist/controllers/validator/identifier.d.ts.map +1 -0
  105. package/dist/controllers/validator/identifier.js +100 -0
  106. package/dist/controllers/validator/identifier.js.map +1 -0
  107. package/dist/controllers/validator/index.d.ts +42 -0
  108. package/dist/controllers/validator/index.d.ts.map +1 -0
  109. package/dist/controllers/validator/index.js +90 -0
  110. package/dist/controllers/validator/index.js.map +1 -0
  111. package/dist/controllers/validator/jsonld-proof.d.ts +5 -0
  112. package/dist/controllers/validator/jsonld-proof.d.ts.map +1 -0
  113. package/dist/controllers/validator/jsonld-proof.js +50 -0
  114. package/dist/controllers/validator/jsonld-proof.js.map +1 -0
  115. package/dist/controllers/validator/jwt-proof.d.ts +5 -0
  116. package/dist/controllers/validator/jwt-proof.d.ts.map +1 -0
  117. package/dist/controllers/validator/jwt-proof.js +45 -0
  118. package/dist/controllers/validator/jwt-proof.js.map +1 -0
  119. package/dist/controllers/validator/presentation.d.ts +9 -0
  120. package/dist/controllers/validator/presentation.d.ts.map +1 -0
  121. package/dist/controllers/validator/presentation.js +96 -0
  122. package/dist/controllers/validator/presentation.js.map +1 -0
  123. package/dist/controllers/validator/resource-also-known-as.d.ts +7 -0
  124. package/dist/controllers/validator/resource-also-known-as.d.ts.map +1 -0
  125. package/dist/controllers/validator/resource-also-known-as.js +47 -0
  126. package/dist/controllers/validator/resource-also-known-as.js.map +1 -0
  127. package/dist/controllers/validator/service-create-request.d.ts +10 -0
  128. package/dist/controllers/validator/service-create-request.d.ts.map +1 -0
  129. package/dist/controllers/validator/service-create-request.js +63 -0
  130. package/dist/controllers/validator/service-create-request.js.map +1 -0
  131. package/dist/controllers/validator/service.d.ts +11 -0
  132. package/dist/controllers/validator/service.d.ts.map +1 -0
  133. package/dist/controllers/validator/service.js +76 -0
  134. package/dist/controllers/validator/service.js.map +1 -0
  135. package/dist/controllers/validator/utils.d.ts +3 -0
  136. package/dist/controllers/validator/utils.d.ts.map +1 -0
  137. package/dist/controllers/validator/utils.js +21 -0
  138. package/dist/controllers/validator/utils.js.map +1 -0
  139. package/dist/controllers/validator/validator.d.ts +20 -0
  140. package/dist/controllers/validator/validator.d.ts.map +1 -0
  141. package/dist/controllers/validator/validator.js +2 -0
  142. package/dist/controllers/validator/validator.js.map +1 -0
  143. package/dist/controllers/validator/verification-method.d.ts +30 -0
  144. package/dist/controllers/validator/verification-method.d.ts.map +1 -0
  145. package/dist/controllers/validator/verification-method.js +211 -0
  146. package/dist/controllers/validator/verification-method.js.map +1 -0
  147. package/dist/database/connection/connection.d.ts +9 -0
  148. package/dist/database/connection/connection.d.ts.map +1 -0
  149. package/dist/database/connection/connection.js +27 -0
  150. package/dist/database/connection/connection.js.map +1 -0
  151. package/dist/database/entities/api.key.entity.d.ts +18 -0
  152. package/dist/database/entities/api.key.entity.d.ts.map +1 -0
  153. package/dist/database/entities/api.key.entity.js +102 -0
  154. package/dist/database/entities/api.key.entity.js.map +1 -0
  155. package/dist/database/entities/coin.entity.d.ts +11 -0
  156. package/dist/database/entities/coin.entity.d.ts.map +1 -0
  157. package/dist/database/entities/coin.entity.js +66 -0
  158. package/dist/database/entities/coin.entity.js.map +1 -0
  159. package/dist/database/entities/customer.entity.d.ts +14 -0
  160. package/dist/database/entities/customer.entity.d.ts.map +1 -0
  161. package/dist/database/entities/customer.entity.js +87 -0
  162. package/dist/database/entities/customer.entity.js.map +1 -0
  163. package/dist/database/entities/identifier.entity.d.ts +7 -0
  164. package/dist/database/entities/identifier.entity.d.ts.map +1 -0
  165. package/dist/database/entities/identifier.entity.js +26 -0
  166. package/dist/database/entities/identifier.entity.js.map +1 -0
  167. package/dist/database/entities/key.entity.d.ts +13 -0
  168. package/dist/database/entities/key.entity.d.ts.map +1 -0
  169. package/dist/database/entities/key.entity.js +63 -0
  170. package/dist/database/entities/key.entity.js.map +1 -0
  171. package/dist/database/entities/operation.entity.d.ts +17 -0
  172. package/dist/database/entities/operation.entity.d.ts.map +1 -0
  173. package/dist/database/entities/operation.entity.js +98 -0
  174. package/dist/database/entities/operation.entity.js.map +1 -0
  175. package/dist/database/entities/payment.account.entity.d.ts +16 -0
  176. package/dist/database/entities/payment.account.entity.d.ts.map +1 -0
  177. package/dist/database/entities/payment.account.entity.js +86 -0
  178. package/dist/database/entities/payment.account.entity.js.map +1 -0
  179. package/dist/database/entities/payment.entity.d.ts +20 -0
  180. package/dist/database/entities/payment.entity.d.ts.map +1 -0
  181. package/dist/database/entities/payment.entity.js +103 -0
  182. package/dist/database/entities/payment.entity.js.map +1 -0
  183. package/dist/database/entities/resource.entity.d.ts +21 -0
  184. package/dist/database/entities/resource.entity.d.ts.map +1 -0
  185. package/dist/database/entities/resource.entity.js +117 -0
  186. package/dist/database/entities/resource.entity.js.map +1 -0
  187. package/dist/database/entities/role.entity.d.ts +7 -0
  188. package/dist/database/entities/role.entity.d.ts.map +1 -0
  189. package/dist/database/entities/role.entity.js +60 -0
  190. package/dist/database/entities/role.entity.js.map +1 -0
  191. package/dist/database/entities/subscription.entity.d.ts +16 -0
  192. package/dist/database/entities/subscription.entity.d.ts.map +1 -0
  193. package/dist/database/entities/subscription.entity.js +102 -0
  194. package/dist/database/entities/subscription.entity.js.map +1 -0
  195. package/dist/database/entities/user.entity.d.ts +13 -0
  196. package/dist/database/entities/user.entity.d.ts.map +1 -0
  197. package/dist/database/entities/user.entity.js +67 -0
  198. package/dist/database/entities/user.entity.js.map +1 -0
  199. package/dist/database/migrations/AlterAPIKeyTable.d.ts +6 -0
  200. package/dist/database/migrations/AlterAPIKeyTable.d.ts.map +1 -0
  201. package/dist/database/migrations/AlterAPIKeyTable.js +51 -0
  202. package/dist/database/migrations/AlterAPIKeyTable.js.map +1 -0
  203. package/dist/database/migrations/AlterCustomerTable.d.ts +6 -0
  204. package/dist/database/migrations/AlterCustomerTable.d.ts.map +1 -0
  205. package/dist/database/migrations/AlterCustomerTable.js +15 -0
  206. package/dist/database/migrations/AlterCustomerTable.js.map +1 -0
  207. package/dist/database/migrations/AlterCustomerTableAddEmail.d.ts +6 -0
  208. package/dist/database/migrations/AlterCustomerTableAddEmail.d.ts.map +1 -0
  209. package/dist/database/migrations/AlterCustomerTableAddEmail.js +20 -0
  210. package/dist/database/migrations/AlterCustomerTableAddEmail.js.map +1 -0
  211. package/dist/database/migrations/AlterOperationTable.d.ts +6 -0
  212. package/dist/database/migrations/AlterOperationTable.d.ts.map +1 -0
  213. package/dist/database/migrations/AlterOperationTable.js +38 -0
  214. package/dist/database/migrations/AlterOperationTable.js.map +1 -0
  215. package/dist/database/migrations/AlterOperationTableAddCustomer.d.ts +6 -0
  216. package/dist/database/migrations/AlterOperationTableAddCustomer.d.ts.map +1 -0
  217. package/dist/database/migrations/AlterOperationTableAddCustomer.js +22 -0
  218. package/dist/database/migrations/AlterOperationTableAddCustomer.js.map +1 -0
  219. package/dist/database/migrations/AlterOperationTableNewCategory.d.ts +6 -0
  220. package/dist/database/migrations/AlterOperationTableNewCategory.d.ts.map +1 -0
  221. package/dist/database/migrations/AlterOperationTableNewCategory.js +17 -0
  222. package/dist/database/migrations/AlterOperationTableNewCategory.js.map +1 -0
  223. package/dist/database/migrations/AlterPaymentTable.d.ts +6 -0
  224. package/dist/database/migrations/AlterPaymentTable.d.ts.map +1 -0
  225. package/dist/database/migrations/AlterPaymentTable.js +61 -0
  226. package/dist/database/migrations/AlterPaymentTable.js.map +1 -0
  227. package/dist/database/migrations/AlterTableClaim.d.ts +6 -0
  228. package/dist/database/migrations/AlterTableClaim.d.ts.map +1 -0
  229. package/dist/database/migrations/AlterTableClaim.js +21 -0
  230. package/dist/database/migrations/AlterTableClaim.js.map +1 -0
  231. package/dist/database/migrations/AlterTableIdentifier.d.ts +6 -0
  232. package/dist/database/migrations/AlterTableIdentifier.d.ts.map +1 -0
  233. package/dist/database/migrations/AlterTableIdentifier.js +21 -0
  234. package/dist/database/migrations/AlterTableIdentifier.js.map +1 -0
  235. package/dist/database/migrations/AlterTableKey.d.ts +6 -0
  236. package/dist/database/migrations/AlterTableKey.d.ts.map +1 -0
  237. package/dist/database/migrations/AlterTableKey.js +36 -0
  238. package/dist/database/migrations/AlterTableKey.js.map +1 -0
  239. package/dist/database/migrations/CreateApiKeyMigration.d.ts +6 -0
  240. package/dist/database/migrations/CreateApiKeyMigration.d.ts.map +1 -0
  241. package/dist/database/migrations/CreateApiKeyMigration.js +40 -0
  242. package/dist/database/migrations/CreateApiKeyMigration.js.map +1 -0
  243. package/dist/database/migrations/CreateCoinTable.d.ts +6 -0
  244. package/dist/database/migrations/CreateCoinTable.d.ts.map +1 -0
  245. package/dist/database/migrations/CreateCoinTable.js +20 -0
  246. package/dist/database/migrations/CreateCoinTable.js.map +1 -0
  247. package/dist/database/migrations/CreateCustomerTable.d.ts +6 -0
  248. package/dist/database/migrations/CreateCustomerTable.d.ts.map +1 -0
  249. package/dist/database/migrations/CreateCustomerTable.js +24 -0
  250. package/dist/database/migrations/CreateCustomerTable.js.map +1 -0
  251. package/dist/database/migrations/CreateCustomersTable.d.ts +6 -0
  252. package/dist/database/migrations/CreateCustomersTable.d.ts.map +1 -0
  253. package/dist/database/migrations/CreateCustomersTable.js +21 -0
  254. package/dist/database/migrations/CreateCustomersTable.js.map +1 -0
  255. package/dist/database/migrations/CreateOperationTable.d.ts +6 -0
  256. package/dist/database/migrations/CreateOperationTable.d.ts.map +1 -0
  257. package/dist/database/migrations/CreateOperationTable.js +28 -0
  258. package/dist/database/migrations/CreateOperationTable.js.map +1 -0
  259. package/dist/database/migrations/CreatePaymentAccountTable.d.ts +6 -0
  260. package/dist/database/migrations/CreatePaymentAccountTable.d.ts.map +1 -0
  261. package/dist/database/migrations/CreatePaymentAccountTable.js +35 -0
  262. package/dist/database/migrations/CreatePaymentAccountTable.js.map +1 -0
  263. package/dist/database/migrations/CreatePaymentTable.d.ts +6 -0
  264. package/dist/database/migrations/CreatePaymentTable.d.ts.map +1 -0
  265. package/dist/database/migrations/CreatePaymentTable.js +55 -0
  266. package/dist/database/migrations/CreatePaymentTable.js.map +1 -0
  267. package/dist/database/migrations/CreateResourceTable.d.ts +6 -0
  268. package/dist/database/migrations/CreateResourceTable.d.ts.map +1 -0
  269. package/dist/database/migrations/CreateResourceTable.js +46 -0
  270. package/dist/database/migrations/CreateResourceTable.js.map +1 -0
  271. package/dist/database/migrations/CreateRoleTable.d.ts +6 -0
  272. package/dist/database/migrations/CreateRoleTable.d.ts.map +1 -0
  273. package/dist/database/migrations/CreateRoleTable.js +25 -0
  274. package/dist/database/migrations/CreateRoleTable.js.map +1 -0
  275. package/dist/database/migrations/CreateSubscriptionTable.d.ts +6 -0
  276. package/dist/database/migrations/CreateSubscriptionTable.d.ts.map +1 -0
  277. package/dist/database/migrations/CreateSubscriptionTable.js +30 -0
  278. package/dist/database/migrations/CreateSubscriptionTable.js.map +1 -0
  279. package/dist/database/migrations/CreateUserTable.d.ts +6 -0
  280. package/dist/database/migrations/CreateUserTable.d.ts.map +1 -0
  281. package/dist/database/migrations/CreateUserTable.js +32 -0
  282. package/dist/database/migrations/CreateUserTable.js.map +1 -0
  283. package/dist/database/migrations/MigrateData.d.ts +7 -0
  284. package/dist/database/migrations/MigrateData.d.ts.map +1 -0
  285. package/dist/database/migrations/MigrateData.js +138 -0
  286. package/dist/database/migrations/MigrateData.js.map +1 -0
  287. package/dist/database/ormconfig.d.ts +2 -0
  288. package/dist/database/ormconfig.d.ts.map +1 -0
  289. package/dist/database/ormconfig.js +3 -0
  290. package/dist/database/ormconfig.js.map +1 -0
  291. package/dist/database/types/enum.d.ts +21 -0
  292. package/dist/database/types/enum.d.ts.map +1 -0
  293. package/dist/database/types/enum.js +35 -0
  294. package/dist/database/types/enum.js.map +1 -0
  295. package/dist/database/types/types.d.ts +11 -0
  296. package/dist/database/types/types.d.ts.map +1 -0
  297. package/dist/database/types/types.js +127 -0
  298. package/dist/database/types/types.js.map +1 -0
  299. package/dist/helpers/faucet.d.ts +5 -0
  300. package/dist/helpers/faucet.d.ts.map +1 -0
  301. package/dist/helpers/faucet.js +24 -0
  302. package/dist/helpers/faucet.js.map +1 -0
  303. package/dist/helpers/fee-analyzer.d.ts +8 -0
  304. package/dist/helpers/fee-analyzer.d.ts.map +1 -0
  305. package/dist/helpers/fee-analyzer.js +73 -0
  306. package/dist/helpers/fee-analyzer.js.map +1 -0
  307. package/dist/helpers/helpers.d.ts +28 -0
  308. package/dist/helpers/helpers.d.ts.map +1 -0
  309. package/dist/helpers/helpers.js +167 -0
  310. package/dist/helpers/helpers.js.map +1 -0
  311. package/dist/index.d.ts +2 -0
  312. package/dist/index.d.ts.map +1 -0
  313. package/dist/index.js +28 -0
  314. package/dist/index.js.map +1 -0
  315. package/dist/middleware/auth/auth-gaurd.d.ts +51 -0
  316. package/dist/middleware/auth/auth-gaurd.d.ts.map +1 -0
  317. package/dist/middleware/auth/auth-gaurd.js +117 -0
  318. package/dist/middleware/auth/auth-gaurd.js.map +1 -0
  319. package/dist/middleware/auth/logto-helper.d.ts +44 -0
  320. package/dist/middleware/auth/logto-helper.d.ts.map +1 -0
  321. package/dist/middleware/auth/logto-helper.js +438 -0
  322. package/dist/middleware/auth/logto-helper.js.map +1 -0
  323. package/dist/middleware/auth/oauth/abstract.d.ts +22 -0
  324. package/dist/middleware/auth/oauth/abstract.d.ts.map +1 -0
  325. package/dist/middleware/auth/oauth/abstract.js +24 -0
  326. package/dist/middleware/auth/oauth/abstract.js.map +1 -0
  327. package/dist/middleware/auth/oauth/logto-provider.d.ts +15 -0
  328. package/dist/middleware/auth/oauth/logto-provider.d.ts.map +1 -0
  329. package/dist/middleware/auth/oauth/logto-provider.js +42 -0
  330. package/dist/middleware/auth/oauth/logto-provider.js.map +1 -0
  331. package/dist/middleware/auth/routes/admin/admin-auth.d.ts +8 -0
  332. package/dist/middleware/auth/routes/admin/admin-auth.d.ts.map +1 -0
  333. package/dist/middleware/auth/routes/admin/admin-auth.js +44 -0
  334. package/dist/middleware/auth/routes/admin/admin-auth.js.map +1 -0
  335. package/dist/middleware/auth/routes/api/account-auth.d.ts +5 -0
  336. package/dist/middleware/auth/routes/api/account-auth.d.ts.map +1 -0
  337. package/dist/middleware/auth/routes/api/account-auth.js +9 -0
  338. package/dist/middleware/auth/routes/api/account-auth.js.map +1 -0
  339. package/dist/middleware/auth/routes/api/auth-user-info.d.ts +5 -0
  340. package/dist/middleware/auth/routes/api/auth-user-info.d.ts.map +1 -0
  341. package/dist/middleware/auth/routes/api/auth-user-info.js +8 -0
  342. package/dist/middleware/auth/routes/api/auth-user-info.js.map +1 -0
  343. package/dist/middleware/auth/routes/api/credential-auth.d.ts +5 -0
  344. package/dist/middleware/auth/routes/api/credential-auth.d.ts.map +1 -0
  345. package/dist/middleware/auth/routes/api/credential-auth.js +17 -0
  346. package/dist/middleware/auth/routes/api/credential-auth.js.map +1 -0
  347. package/dist/middleware/auth/routes/api/credential-status-auth.d.ts +5 -0
  348. package/dist/middleware/auth/routes/api/credential-status-auth.d.ts.map +1 -0
  349. package/dist/middleware/auth/routes/api/credential-status-auth.js +20 -0
  350. package/dist/middleware/auth/routes/api/credential-status-auth.js.map +1 -0
  351. package/dist/middleware/auth/routes/api/did-auth.d.ts +5 -0
  352. package/dist/middleware/auth/routes/api/did-auth.d.ts.map +1 -0
  353. package/dist/middleware/auth/routes/api/did-auth.js +19 -0
  354. package/dist/middleware/auth/routes/api/did-auth.js.map +1 -0
  355. package/dist/middleware/auth/routes/api/key-auth.d.ts +5 -0
  356. package/dist/middleware/auth/routes/api/key-auth.d.ts.map +1 -0
  357. package/dist/middleware/auth/routes/api/key-auth.js +11 -0
  358. package/dist/middleware/auth/routes/api/key-auth.js.map +1 -0
  359. package/dist/middleware/auth/routes/api/presentation-auth.d.ts +5 -0
  360. package/dist/middleware/auth/routes/api/presentation-auth.d.ts.map +1 -0
  361. package/dist/middleware/auth/routes/api/presentation-auth.js +10 -0
  362. package/dist/middleware/auth/routes/api/presentation-auth.js.map +1 -0
  363. package/dist/middleware/auth/routes/api/resource-auth.d.ts +5 -0
  364. package/dist/middleware/auth/routes/api/resource-auth.d.ts.map +1 -0
  365. package/dist/middleware/auth/routes/api/resource-auth.js +11 -0
  366. package/dist/middleware/auth/routes/api/resource-auth.js.map +1 -0
  367. package/dist/middleware/auth/routes/auth-rule-provider.d.ts +33 -0
  368. package/dist/middleware/auth/routes/auth-rule-provider.d.ts.map +1 -0
  369. package/dist/middleware/auth/routes/auth-rule-provider.js +39 -0
  370. package/dist/middleware/auth/routes/auth-rule-provider.js.map +1 -0
  371. package/dist/middleware/auth/routes/auth-rule-repository.d.ts +21 -0
  372. package/dist/middleware/auth/routes/auth-rule-repository.d.ts.map +1 -0
  373. package/dist/middleware/auth/routes/auth-rule-repository.js +28 -0
  374. package/dist/middleware/auth/routes/auth-rule-repository.js.map +1 -0
  375. package/dist/middleware/auth/user-info-fetcher/api-token.d.ts +17 -0
  376. package/dist/middleware/auth/user-info-fetcher/api-token.d.ts.map +1 -0
  377. package/dist/middleware/auth/user-info-fetcher/api-token.js +60 -0
  378. package/dist/middleware/auth/user-info-fetcher/api-token.js.map +1 -0
  379. package/dist/middleware/auth/user-info-fetcher/base.d.ts +14 -0
  380. package/dist/middleware/auth/user-info-fetcher/base.d.ts.map +1 -0
  381. package/dist/middleware/auth/user-info-fetcher/base.js +38 -0
  382. package/dist/middleware/auth/user-info-fetcher/base.js.map +1 -0
  383. package/dist/middleware/auth/user-info-fetcher/idtoken.d.ts +18 -0
  384. package/dist/middleware/auth/user-info-fetcher/idtoken.d.ts.map +1 -0
  385. package/dist/middleware/auth/user-info-fetcher/idtoken.js +56 -0
  386. package/dist/middleware/auth/user-info-fetcher/idtoken.js.map +1 -0
  387. package/dist/middleware/auth/user-info-fetcher/m2m-creds-token.d.ts +18 -0
  388. package/dist/middleware/auth/user-info-fetcher/m2m-creds-token.d.ts.map +1 -0
  389. package/dist/middleware/auth/user-info-fetcher/m2m-creds-token.js +52 -0
  390. package/dist/middleware/auth/user-info-fetcher/m2m-creds-token.js.map +1 -0
  391. package/dist/middleware/auth/user-info-fetcher/portal-token.d.ts +20 -0
  392. package/dist/middleware/auth/user-info-fetcher/portal-token.d.ts.map +1 -0
  393. package/dist/middleware/auth/user-info-fetcher/portal-token.js +79 -0
  394. package/dist/middleware/auth/user-info-fetcher/portal-token.js.map +1 -0
  395. package/dist/middleware/auth/user-info-fetcher/swagger-ui.d.ts +16 -0
  396. package/dist/middleware/auth/user-info-fetcher/swagger-ui.d.ts.map +1 -0
  397. package/dist/middleware/auth/user-info-fetcher/swagger-ui.js +48 -0
  398. package/dist/middleware/auth/user-info-fetcher/swagger-ui.js.map +1 -0
  399. package/dist/middleware/authentication.d.ts +15 -0
  400. package/dist/middleware/authentication.d.ts.map +1 -0
  401. package/dist/middleware/authentication.js +110 -0
  402. package/dist/middleware/authentication.js.map +1 -0
  403. package/dist/middleware/event-tracker.d.ts +5 -0
  404. package/dist/middleware/event-tracker.d.ts.map +1 -0
  405. package/dist/middleware/event-tracker.js +34 -0
  406. package/dist/middleware/event-tracker.js.map +1 -0
  407. package/dist/middleware/hook.d.ts +9 -0
  408. package/dist/middleware/hook.d.ts.map +1 -0
  409. package/dist/middleware/hook.js +24 -0
  410. package/dist/middleware/hook.js.map +1 -0
  411. package/dist/middleware/middleware.d.ts +6 -0
  412. package/dist/middleware/middleware.d.ts.map +1 -0
  413. package/dist/middleware/middleware.js +36 -0
  414. package/dist/middleware/middleware.js.map +1 -0
  415. package/dist/services/admin/api-key.d.ts +30 -0
  416. package/dist/services/admin/api-key.d.ts.map +1 -0
  417. package/dist/services/admin/api-key.js +135 -0
  418. package/dist/services/admin/api-key.js.map +1 -0
  419. package/dist/services/admin/stripe.d.ts +18 -0
  420. package/dist/services/admin/stripe.d.ts.map +1 -0
  421. package/dist/services/admin/stripe.js +125 -0
  422. package/dist/services/admin/stripe.js.map +1 -0
  423. package/dist/services/admin/subscription.d.ts +16 -0
  424. package/dist/services/admin/subscription.d.ts.map +1 -0
  425. package/dist/services/admin/subscription.js +75 -0
  426. package/dist/services/admin/subscription.js.map +1 -0
  427. package/dist/services/api/coin.d.ts +13 -0
  428. package/dist/services/api/coin.d.ts.map +1 -0
  429. package/dist/services/api/coin.js +49 -0
  430. package/dist/services/api/coin.js.map +1 -0
  431. package/dist/services/api/credentials.d.ts +8 -0
  432. package/dist/services/api/credentials.d.ts.map +1 -0
  433. package/dist/services/api/credentials.js +38 -0
  434. package/dist/services/api/credentials.js.map +1 -0
  435. package/dist/services/api/customer.d.ts +19 -0
  436. package/dist/services/api/customer.d.ts.map +1 -0
  437. package/dist/services/api/customer.js +88 -0
  438. package/dist/services/api/customer.js.map +1 -0
  439. package/dist/services/api/identifier.d.ts +12 -0
  440. package/dist/services/api/identifier.d.ts.map +1 -0
  441. package/dist/services/api/identifier.js +38 -0
  442. package/dist/services/api/identifier.js.map +1 -0
  443. package/dist/services/api/key.d.ts +14 -0
  444. package/dist/services/api/key.d.ts.map +1 -0
  445. package/dist/services/api/key.js +49 -0
  446. package/dist/services/api/key.js.map +1 -0
  447. package/dist/services/api/operation.d.ts +14 -0
  448. package/dist/services/api/operation.d.ts.map +1 -0
  449. package/dist/services/api/operation.js +61 -0
  450. package/dist/services/api/operation.js.map +1 -0
  451. package/dist/services/api/payment-account.d.ts +14 -0
  452. package/dist/services/api/payment-account.d.ts.map +1 -0
  453. package/dist/services/api/payment-account.js +68 -0
  454. package/dist/services/api/payment-account.js.map +1 -0
  455. package/dist/services/api/payment.d.ts +17 -0
  456. package/dist/services/api/payment.d.ts.map +1 -0
  457. package/dist/services/api/payment.js +68 -0
  458. package/dist/services/api/payment.js.map +1 -0
  459. package/dist/services/api/resource.d.ts +17 -0
  460. package/dist/services/api/resource.d.ts.map +1 -0
  461. package/dist/services/api/resource.js +65 -0
  462. package/dist/services/api/resource.js.map +1 -0
  463. package/dist/services/api/role.d.ts +14 -0
  464. package/dist/services/api/role.d.ts.map +1 -0
  465. package/dist/services/api/role.js +53 -0
  466. package/dist/services/api/role.js.map +1 -0
  467. package/dist/services/api/store.d.ts +8 -0
  468. package/dist/services/api/store.d.ts.map +1 -0
  469. package/dist/services/api/store.js +18 -0
  470. package/dist/services/api/store.js.map +1 -0
  471. package/dist/services/api/user.d.ts +15 -0
  472. package/dist/services/api/user.d.ts.map +1 -0
  473. package/dist/services/api/user.js +54 -0
  474. package/dist/services/api/user.js.map +1 -0
  475. package/dist/services/connectors/verida.d.ts +40 -0
  476. package/dist/services/connectors/verida.d.ts.map +1 -0
  477. package/dist/services/connectors/verida.js +110 -0
  478. package/dist/services/connectors/verida.js.map +1 -0
  479. package/dist/services/helpers.d.ts +10 -0
  480. package/dist/services/helpers.d.ts.map +1 -0
  481. package/dist/services/helpers.js +44 -0
  482. package/dist/services/helpers.js.map +1 -0
  483. package/dist/services/identity/abstract.d.ts +51 -0
  484. package/dist/services/identity/abstract.d.ts.map +1 -0
  485. package/dist/services/identity/abstract.js +101 -0
  486. package/dist/services/identity/abstract.js.map +1 -0
  487. package/dist/services/identity/agent.d.ts +43 -0
  488. package/dist/services/identity/agent.d.ts.map +1 -0
  489. package/dist/services/identity/agent.js +625 -0
  490. package/dist/services/identity/agent.js.map +1 -0
  491. package/dist/services/identity/default.d.ts +19 -0
  492. package/dist/services/identity/default.d.ts.map +1 -0
  493. package/dist/services/identity/default.js +26 -0
  494. package/dist/services/identity/default.js.map +1 -0
  495. package/dist/services/identity/index.d.ts +59 -0
  496. package/dist/services/identity/index.d.ts.map +1 -0
  497. package/dist/services/identity/index.js +31 -0
  498. package/dist/services/identity/index.js.map +1 -0
  499. package/dist/services/identity/local.d.ts +33 -0
  500. package/dist/services/identity/local.d.ts.map +1 -0
  501. package/dist/services/identity/local.js +156 -0
  502. package/dist/services/identity/local.js.map +1 -0
  503. package/dist/services/identity/postgres.d.ts +59 -0
  504. package/dist/services/identity/postgres.d.ts.map +1 -0
  505. package/dist/services/identity/postgres.js +388 -0
  506. package/dist/services/identity/postgres.js.map +1 -0
  507. package/dist/services/identity/unauthorized.d.ts +6 -0
  508. package/dist/services/identity/unauthorized.d.ts.map +1 -0
  509. package/dist/services/identity/unauthorized.js +49 -0
  510. package/dist/services/identity/unauthorized.js.map +1 -0
  511. package/dist/services/track/admin/account-submitter.d.ts +11 -0
  512. package/dist/services/track/admin/account-submitter.d.ts.map +1 -0
  513. package/dist/services/track/admin/account-submitter.js +54 -0
  514. package/dist/services/track/admin/account-submitter.js.map +1 -0
  515. package/dist/services/track/admin/subscription-submitter.d.ts +13 -0
  516. package/dist/services/track/admin/subscription-submitter.d.ts.map +1 -0
  517. package/dist/services/track/admin/subscription-submitter.js +106 -0
  518. package/dist/services/track/admin/subscription-submitter.js.map +1 -0
  519. package/dist/services/track/api/credential-status-subscriber.d.ts +10 -0
  520. package/dist/services/track/api/credential-status-subscriber.d.ts.map +1 -0
  521. package/dist/services/track/api/credential-status-subscriber.js +35 -0
  522. package/dist/services/track/api/credential-status-subscriber.js.map +1 -0
  523. package/dist/services/track/api/credential-subscriber.d.ts +10 -0
  524. package/dist/services/track/api/credential-subscriber.d.ts.map +1 -0
  525. package/dist/services/track/api/credential-subscriber.js +35 -0
  526. package/dist/services/track/api/credential-subscriber.js.map +1 -0
  527. package/dist/services/track/api/did-subscriber.d.ts +10 -0
  528. package/dist/services/track/api/did-subscriber.d.ts.map +1 -0
  529. package/dist/services/track/api/did-subscriber.js +33 -0
  530. package/dist/services/track/api/did-subscriber.js.map +1 -0
  531. package/dist/services/track/api/key-subscriber.d.ts +10 -0
  532. package/dist/services/track/api/key-subscriber.d.ts.map +1 -0
  533. package/dist/services/track/api/key-subscriber.js +35 -0
  534. package/dist/services/track/api/key-subscriber.js.map +1 -0
  535. package/dist/services/track/api/presentation-subscriber.d.ts +10 -0
  536. package/dist/services/track/api/presentation-subscriber.d.ts.map +1 -0
  537. package/dist/services/track/api/presentation-subscriber.js +35 -0
  538. package/dist/services/track/api/presentation-subscriber.js.map +1 -0
  539. package/dist/services/track/api/resource-subscriber.d.ts +11 -0
  540. package/dist/services/track/api/resource-subscriber.d.ts.map +1 -0
  541. package/dist/services/track/api/resource-subscriber.js +107 -0
  542. package/dist/services/track/api/resource-subscriber.js.map +1 -0
  543. package/dist/services/track/base.d.ts +10 -0
  544. package/dist/services/track/base.d.ts.map +1 -0
  545. package/dist/services/track/base.js +26 -0
  546. package/dist/services/track/base.js.map +1 -0
  547. package/dist/services/track/helpers.d.ts +23 -0
  548. package/dist/services/track/helpers.d.ts.map +1 -0
  549. package/dist/services/track/helpers.js +35 -0
  550. package/dist/services/track/helpers.js.map +1 -0
  551. package/dist/services/track/notifiers.d.ts +12 -0
  552. package/dist/services/track/notifiers.d.ts.map +1 -0
  553. package/dist/services/track/notifiers.js +39 -0
  554. package/dist/services/track/notifiers.js.map +1 -0
  555. package/dist/services/track/observer.d.ts +14 -0
  556. package/dist/services/track/observer.d.ts.map +1 -0
  557. package/dist/services/track/observer.js +43 -0
  558. package/dist/services/track/observer.js.map +1 -0
  559. package/dist/services/track/operation-subscriber.d.ts +14 -0
  560. package/dist/services/track/operation-subscriber.d.ts.map +1 -0
  561. package/dist/services/track/operation-subscriber.js +112 -0
  562. package/dist/services/track/operation-subscriber.js.map +1 -0
  563. package/dist/services/track/submitter.d.ts +22 -0
  564. package/dist/services/track/submitter.d.ts.map +1 -0
  565. package/dist/services/track/submitter.js +2 -0
  566. package/dist/services/track/submitter.js.map +1 -0
  567. package/dist/services/track/tracker.d.ts +24 -0
  568. package/dist/services/track/tracker.d.ts.map +1 -0
  569. package/dist/services/track/tracker.js +79 -0
  570. package/dist/services/track/tracker.js.map +1 -0
  571. package/dist/services/track/types.d.ts +16 -0
  572. package/dist/services/track/types.d.ts.map +1 -0
  573. package/dist/services/track/types.js +2 -0
  574. package/dist/services/track/types.js.map +1 -0
  575. package/dist/services/w3c-credential.d.ts +32 -0
  576. package/dist/services/w3c-credential.d.ts.map +1 -0
  577. package/dist/services/w3c-credential.js +120 -0
  578. package/dist/services/w3c-credential.js.map +1 -0
  579. package/dist/services/w3c-presentation.d.ts +30 -0
  580. package/dist/services/w3c-presentation.d.ts.map +1 -0
  581. package/dist/services/w3c-presentation.js +95 -0
  582. package/dist/services/w3c-presentation.js.map +1 -0
  583. package/dist/static/custom-button.d.ts +2 -0
  584. package/dist/static/custom-button.d.ts.map +1 -0
  585. package/dist/static/custom-button.js +35 -0
  586. package/dist/static/custom-button.js.map +1 -0
  587. package/dist/static/swagger-admin.json +1191 -0
  588. package/dist/static/swagger-api.json +3564 -0
  589. package/dist/types/admin.d.ts +122 -0
  590. package/dist/types/admin.d.ts.map +1 -0
  591. package/dist/types/admin.js +2 -0
  592. package/dist/types/admin.js.map +1 -0
  593. package/dist/types/authentication.d.ts +30 -0
  594. package/dist/types/authentication.d.ts.map +1 -0
  595. package/dist/types/authentication.js +131 -0
  596. package/dist/types/authentication.js.map +1 -0
  597. package/dist/types/constants.d.ts +98 -0
  598. package/dist/types/constants.d.ts.map +1 -0
  599. package/dist/types/constants.js +138 -0
  600. package/dist/types/constants.js.map +1 -0
  601. package/dist/types/credential-status.d.ts +168 -0
  602. package/dist/types/credential-status.d.ts.map +1 -0
  603. package/dist/types/credential-status.js +12 -0
  604. package/dist/types/credential-status.js.map +1 -0
  605. package/dist/types/credential.d.ts +55 -0
  606. package/dist/types/credential.d.ts.map +1 -0
  607. package/dist/types/credential.js +2 -0
  608. package/dist/types/credential.js.map +1 -0
  609. package/dist/types/customer.d.ts +18 -0
  610. package/dist/types/customer.d.ts.map +1 -0
  611. package/dist/types/customer.js +2 -0
  612. package/dist/types/customer.js.map +1 -0
  613. package/dist/types/did.d.ts +56 -0
  614. package/dist/types/did.d.ts.map +1 -0
  615. package/dist/types/did.js +2 -0
  616. package/dist/types/did.js.map +1 -0
  617. package/dist/types/key.d.ts +23 -0
  618. package/dist/types/key.d.ts.map +1 -0
  619. package/dist/types/key.js +2 -0
  620. package/dist/types/key.js.map +1 -0
  621. package/dist/types/presentation.d.ts +19 -0
  622. package/dist/types/presentation.d.ts.map +1 -0
  623. package/dist/types/presentation.js +2 -0
  624. package/dist/types/presentation.js.map +1 -0
  625. package/dist/types/resource.d.ts +26 -0
  626. package/dist/types/resource.d.ts.map +1 -0
  627. package/dist/types/resource.js +2 -0
  628. package/dist/types/resource.js.map +1 -0
  629. package/dist/types/shared.d.ts +51 -0
  630. package/dist/types/shared.d.ts.map +1 -0
  631. package/dist/types/shared.js +24 -0
  632. package/dist/types/shared.js.map +1 -0
  633. package/dist/types/swagger-admin-types.d.ts +352 -0
  634. package/dist/types/swagger-admin-types.d.ts.map +1 -0
  635. package/dist/types/swagger-admin-types.js +353 -0
  636. package/dist/types/swagger-admin-types.js.map +1 -0
  637. package/dist/types/swagger-api-types.d.ts +1312 -0
  638. package/dist/types/swagger-api-types.d.ts.map +1 -0
  639. package/dist/types/swagger-api-types.js +1313 -0
  640. package/dist/types/swagger-api-types.js.map +1 -0
  641. package/dist/types/track.d.ts +72 -0
  642. package/dist/types/track.d.ts.map +1 -0
  643. package/dist/types/track.js +37 -0
  644. package/dist/types/track.js.map +1 -0
  645. package/dist/types/validation.d.ts +23 -0
  646. package/dist/types/validation.d.ts.map +1 -0
  647. package/dist/types/validation.js +2 -0
  648. package/dist/types/validation.js.map +1 -0
  649. package/dist/types/verida.d.ts +23 -0
  650. package/dist/types/verida.d.ts.map +1 -0
  651. package/dist/types/verida.js +2 -0
  652. package/dist/types/verida.js.map +1 -0
  653. package/example.env +43 -0
  654. package/package.json +156 -0
@@ -0,0 +1,60 @@
1
+ import { StatusCodes } from 'http-status-codes';
2
+ import { UserInfoHelper } from './base.js';
3
+ import * as dotenv from 'dotenv';
4
+ import { APIKeyService } from '../../../services/admin/api-key.js';
5
+ import { UserService } from '../../../services/api/user.js';
6
+ dotenv.config();
7
+ export class APITokenUserInfoFetcher extends UserInfoHelper {
8
+ token;
9
+ oauthProvider;
10
+ constructor(token, oauthProvider) {
11
+ super();
12
+ this.token = token;
13
+ this.oauthProvider = oauthProvider;
14
+ }
15
+ async fetch(request, response) {
16
+ return this.verifyToken(response);
17
+ }
18
+ /**
19
+ * Verifies the token and sets the user's scopes and customer entity in the global context.
20
+ *
21
+ * @param {Response} response - The response object to send the response.
22
+ * @return {Promise<Response | undefined>} The response object with the appropriate status code and error message, or undefined if successful.
23
+ */
24
+ async verifyToken(response) {
25
+ try {
26
+ const apiEntity = await APIKeyService.instance.get(this.token);
27
+ if (!apiEntity) {
28
+ return response.status(StatusCodes.UNAUTHORIZED).json({
29
+ error: `Unauthorized error: API Key not found.`,
30
+ });
31
+ }
32
+ if (apiEntity.revoked) {
33
+ return response.status(StatusCodes.UNAUTHORIZED).json({
34
+ error: `Unauthorized error: API Key is revoked.`,
35
+ });
36
+ }
37
+ const userEntity = await UserService.instance.findOne({ customer: apiEntity.customer });
38
+ if (!userEntity) {
39
+ return response.status(StatusCodes.UNAUTHORIZED).json({
40
+ error: `Unauthorized error: User not found.`,
41
+ });
42
+ }
43
+ const _resp = await this.oauthProvider.getUserScopes(userEntity.logToId);
44
+ if (_resp.status !== 200) {
45
+ return response.status(StatusCodes.UNAUTHORIZED).json({
46
+ error: `Unauthorized error: No scopes found for the user: ${userEntity.logToId}`,
47
+ });
48
+ }
49
+ // Set global context
50
+ this.setScopes(_resp.data, response);
51
+ return await this.setCustomerEntity(apiEntity.customer.customerId, response);
52
+ }
53
+ catch (error) {
54
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
55
+ error: `Unexpected error: While verifying API key: ${error}`,
56
+ });
57
+ }
58
+ }
59
+ }
60
+ //# sourceMappingURL=api-token.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api-token.js","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/api-token.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAyB,MAAM,WAAW,CAAC;AAGlE,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,oCAAoC,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAE5D,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,OAAO,uBAAwB,SAAQ,cAAc;IAC1D,KAAK,CAAS;IACN,aAAa,CAAiB;IAEtC,YAAY,KAAa,EAAE,aAA6B;QACvD,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,OAAgB,EAAE,QAAkB;QAC/C,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC;IAED;;;;;OAKG;IACI,KAAK,CAAC,WAAW,CAAC,QAAkB;QAC1C,IAAI,CAAC;YACJ,MAAM,SAAS,GAAG,MAAM,aAAa,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/D,IAAI,CAAC,SAAS,EAAE,CAAC;gBAChB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;oBACrD,KAAK,EAAE,wCAAwC;iBACZ,CAAC,CAAC;YACvC,CAAC;YACD,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;gBACvB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;oBACrD,KAAK,EAAE,yCAAyC;iBACb,CAAC,CAAC;YACvC,CAAC;YACD,MAAM,UAAU,GAAG,MAAM,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC;YACxF,IAAI,CAAC,UAAU,EAAE,CAAC;gBACjB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;oBACrD,KAAK,EAAE,qCAAqC;iBACT,CAAC,CAAC;YACvC,CAAC;YACD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,OAAiB,CAAC,CAAC;YACnF,IAAI,KAAK,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;gBAC1B,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;oBACrD,KAAK,EAAE,qDAAqD,UAAU,CAAC,OAAO,EAAE;iBAC7C,CAAC,CAAC;YACvC,CAAC;YACD,qBAAqB;YACrB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;YACrC,OAAO,MAAM,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QAC9E,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC;gBAC9D,KAAK,EAAE,8CAA8C,KAAK,EAAE;aACzB,CAAC,CAAC;QACvC,CAAC;IACF,CAAC;CACD"}
@@ -0,0 +1,14 @@
1
+ import type { Request, Response } from 'express';
2
+ import type { IOAuthProvider } from '../oauth/abstract.js';
3
+ export interface IUserInfoOptions {
4
+ [key: string]: any;
5
+ }
6
+ export interface IUserInfoFetcher {
7
+ fetch(request: Request, response: Response, oauthProvider: IOAuthProvider, options?: IUserInfoOptions): Promise<Response | undefined>;
8
+ }
9
+ export declare class UserInfoHelper {
10
+ setScopes(scopes: string[], response: Response): void;
11
+ setCustomerEntity(customerId: string, response: Response): Promise<Response | undefined>;
12
+ setUserEntity(logToId: string, response: Response): Promise<Response | undefined>;
13
+ }
14
+ //# sourceMappingURL=base.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/base.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAK3D,MAAM,WAAW,gBAAgB;IAChC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACnB;AAED,MAAM,WAAW,gBAAgB;IAChC,KAAK,CACJ,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,cAAc,EAC7B,OAAO,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC;CACjC;AAED,qBAAa,cAAc;IAC1B,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,QAAQ,EAAE,QAAQ;IAIxC,iBAAiB,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,QAAQ,GAAG,SAAS,CAAC;IAkBxF,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,QAAQ,GAAG,SAAS,CAAC;CAWvF"}
@@ -0,0 +1,38 @@
1
+ import { CustomerService } from '../../../services/api/customer.js';
2
+ import { StatusCodes } from 'http-status-codes';
3
+ import { UserService } from '../../../services/api/user.js';
4
+ export class UserInfoHelper {
5
+ setScopes(scopes, response) {
6
+ response.locals.scopes = scopes;
7
+ return;
8
+ }
9
+ async setCustomerEntity(customerId, response) {
10
+ const customerEntity = await CustomerService.instance.get(customerId);
11
+ if (!customerEntity) {
12
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
13
+ error: `Unexpected error: Customer entity for handling such request is not found in internal storage. CustomerId: ${customerId}`,
14
+ });
15
+ }
16
+ const userEntity = await UserService.instance.findOne({ customer: customerEntity });
17
+ if (!userEntity) {
18
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
19
+ error: `Unexpected error: User entity for handling such request is not found in internal storage. CustomerId: ${customerId}`,
20
+ });
21
+ }
22
+ response.locals.customer = customerEntity;
23
+ response.locals.user = userEntity;
24
+ return;
25
+ }
26
+ async setUserEntity(logToId, response) {
27
+ const entity = await UserService.instance.get(logToId);
28
+ if (!entity) {
29
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
30
+ error: `Unexpected error: User entity for handling such request is not found in internal storage`,
31
+ });
32
+ }
33
+ response.locals.user = entity;
34
+ response.locals.customer = entity.customer;
35
+ return;
36
+ }
37
+ }
38
+ //# sourceMappingURL=base.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/base.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAe5D,MAAM,OAAO,cAAc;IAC1B,SAAS,CAAC,MAAgB,EAAE,QAAkB;QAC7C,QAAQ,CAAC,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC;QAChC,OAAO;IACR,CAAC;IACD,KAAK,CAAC,iBAAiB,CAAC,UAAkB,EAAE,QAAkB;QAC7D,MAAM,cAAc,GAAG,MAAM,eAAe,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACtE,IAAI,CAAC,cAAc,EAAE,CAAC;YACrB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC;gBAC9D,KAAK,EAAE,6GAA6G,UAAU,EAAE;aAChI,CAAC,CAAC;QACJ,CAAC;QACD,MAAM,UAAU,GAAG,MAAM,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,cAAc,EAAE,CAAC,CAAC;QACpF,IAAI,CAAC,UAAU,EAAE,CAAC;YACjB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC;gBAC9D,KAAK,EAAE,yGAAyG,UAAU,EAAE;aAC5H,CAAC,CAAC;QACJ,CAAC;QACD,QAAQ,CAAC,MAAM,CAAC,QAAQ,GAAG,cAAc,CAAC;QAC1C,QAAQ,CAAC,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC;QAClC,OAAO;IACR,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,OAAe,EAAE,QAAkB;QACtD,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QACvD,IAAI,CAAC,MAAM,EAAE,CAAC;YACb,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC;gBAC9D,KAAK,EAAE,0FAA0F;aACjG,CAAC,CAAC;QACJ,CAAC;QACD,QAAQ,CAAC,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC;QAC9B,QAAQ,CAAC,MAAM,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAC3C,OAAO;IACR,CAAC;CACD"}
@@ -0,0 +1,18 @@
1
+ import type { Request, Response } from 'express';
2
+ import { UserInfoHelper, type IUserInfoFetcher } from './base.js';
3
+ import type { IOAuthProvider } from '../oauth/abstract.js';
4
+ export declare class IdTokenUserInfoFetcher extends UserInfoHelper implements IUserInfoFetcher {
5
+ token: string;
6
+ private oauthProvider;
7
+ constructor(token: string, oauthProvider: IOAuthProvider);
8
+ fetch(request: Request, response: Response): Promise<Response<any, Record<string, any>> | undefined>;
9
+ /**
10
+ * Verifies the JWT token and sets the user's scopes and customer entity in the global context.
11
+ *
12
+ * @param {Request} request - The request object.
13
+ * @param {Response} response - The response object.
14
+ * @return {Promise<Response | undefined>} The response object with the appropriate status code and error message, or undefined if successful.
15
+ */
16
+ verifyJWTToken(request: Request, response: Response): Promise<Response<any, Record<string, any>> | undefined>;
17
+ }
18
+ //# sourceMappingURL=idtoken.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"idtoken.d.ts","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/idtoken.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEjD,OAAO,EAAE,cAAc,EAAE,KAAK,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAO3D,qBAAa,sBAAuB,SAAQ,cAAe,YAAW,gBAAgB;IACrF,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,aAAa,CAAiB;gBAE1B,KAAK,EAAE,MAAM,EAAE,aAAa,EAAE,cAAc;IAMlD,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ;IAIhD;;;;;;OAMG;IACU,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ;CAiChE"}
@@ -0,0 +1,56 @@
1
+ import { StatusCodes } from 'http-status-codes';
2
+ import { UserInfoHelper } from './base.js';
3
+ import { createRemoteJWKSet, jwtVerify } from 'jose';
4
+ import * as dotenv from 'dotenv';
5
+ dotenv.config();
6
+ export class IdTokenUserInfoFetcher extends UserInfoHelper {
7
+ token;
8
+ oauthProvider;
9
+ constructor(token, oauthProvider) {
10
+ super();
11
+ this.token = token;
12
+ this.oauthProvider = oauthProvider;
13
+ }
14
+ async fetch(request, response) {
15
+ return this.verifyJWTToken(request, response);
16
+ }
17
+ /**
18
+ * Verifies the JWT token and sets the user's scopes and customer entity in the global context.
19
+ *
20
+ * @param {Request} request - The request object.
21
+ * @param {Response} response - The response object.
22
+ * @return {Promise<Response | undefined>} The response object with the appropriate status code and error message, or undefined if successful.
23
+ */
24
+ async verifyJWTToken(request, response) {
25
+ try {
26
+ const { payload } = await jwtVerify(this.token, // The raw Bearer Token extracted from the request header
27
+ createRemoteJWKSet(new URL(this.oauthProvider.endpoint_jwks)), {
28
+ // expected issuer of the token, should be issued by the Logto server
29
+ issuer: this.oauthProvider.endpoint_issuer,
30
+ // expected audience token, should be the resource indicator of the current API
31
+ audience: process.env.LOGTO_APP_ID,
32
+ });
33
+ // Setup the scopes from the token
34
+ if (!payload.roles) {
35
+ return response.status(StatusCodes.UNAUTHORIZED).json({
36
+ error: `Unauthorized error: No roles found in the token.`,
37
+ });
38
+ }
39
+ const scopes = await this.oauthProvider.getScopesForRoles(payload.roles);
40
+ if (!scopes) {
41
+ return response.status(StatusCodes.UNAUTHORIZED).json({
42
+ error: `Unauthorized error: No scopes found for the roles: ${payload.roles}`,
43
+ });
44
+ }
45
+ // Set global context
46
+ this.setScopes(scopes, response);
47
+ return await this.setUserEntity(payload.sub, response);
48
+ }
49
+ catch (error) {
50
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
51
+ error: `Unexpected error: While verifying ID token: ${error}`,
52
+ });
53
+ }
54
+ }
55
+ }
56
+ //# sourceMappingURL=idtoken.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"idtoken.js","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/idtoken.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAyB,MAAM,WAAW,CAAC;AAElE,OAAO,EAAE,kBAAkB,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAErD,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AAEjC,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,OAAO,sBAAuB,SAAQ,cAAc;IACzD,KAAK,CAAS;IACN,aAAa,CAAiB;IAEtC,YAAY,KAAa,EAAE,aAA6B;QACvD,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,OAAgB,EAAE,QAAkB;QAC/C,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;IAC/C,CAAC;IAED;;;;;;OAMG;IACI,KAAK,CAAC,cAAc,CAAC,OAAgB,EAAE,QAAkB;QAC/D,IAAI,CAAC;YACJ,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,SAAS,CAClC,IAAI,CAAC,KAAK,EAAE,yDAAyD;YACrE,kBAAkB,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,EAC7D;gBACC,qEAAqE;gBACrE,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,eAAe;gBAC1C,+EAA+E;gBAC/E,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY;aAClC,CACD,CAAC;YACF,kCAAkC;YAClC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;gBACpB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;oBACrD,KAAK,EAAE,kDAAkD;iBACtB,CAAC,CAAC;YACvC,CAAC;YACD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,OAAO,CAAC,KAAiB,CAAC,CAAC;YACrF,IAAI,CAAC,MAAM,EAAE,CAAC;gBACb,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;oBACrD,KAAK,EAAE,sDAAsD,OAAO,CAAC,KAAK,EAAE;iBACzC,CAAC,CAAC;YACvC,CAAC;YACD,qBAAqB;YACrB,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YACjC,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,GAAa,EAAE,QAAQ,CAAC,CAAC;QAClE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC;gBAC9D,KAAK,EAAE,+CAA+C,KAAK,EAAE;aAC1B,CAAC,CAAC;QACvC,CAAC;IACF,CAAC;CACD"}
@@ -0,0 +1,18 @@
1
+ import type { Request, Response } from 'express';
2
+ import { UserInfoHelper, type IUserInfoFetcher } from './base.js';
3
+ import type { IOAuthProvider } from '../oauth/abstract.js';
4
+ export declare class M2MCredsTokenUserInfoFetcher extends UserInfoHelper implements IUserInfoFetcher {
5
+ token: string;
6
+ private oauthProvider;
7
+ constructor(token: string, oauthProvider: IOAuthProvider);
8
+ /**
9
+ * Verify M2M token
10
+ *
11
+ * @param {Request} request - The request object.
12
+ * @param {Response} response - The response object.
13
+ * @return {Promise<void>} The result of verifying the M2M token.
14
+ */
15
+ fetch(request: Request, response: Response): Promise<Response<any, Record<string, any>> | undefined>;
16
+ verifyJWTToken(request: Request, response: Response): Promise<Response<any, Record<string, any>> | undefined>;
17
+ }
18
+ //# sourceMappingURL=m2m-creds-token.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"m2m-creds-token.d.ts","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/m2m-creds-token.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEjD,OAAO,EAAE,cAAc,EAAE,KAAK,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAM3D,qBAAa,4BAA6B,SAAQ,cAAe,YAAW,gBAAgB;IAC3F,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,aAAa,CAAiB;gBAE1B,KAAK,EAAE,MAAM,EAAE,aAAa,EAAE,cAAc;IAMxD;;;;;;OAMG;IACG,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ;IAKnC,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ;CA4BhE"}
@@ -0,0 +1,52 @@
1
+ import { StatusCodes } from 'http-status-codes';
2
+ import { UserInfoHelper } from './base.js';
3
+ import { createRemoteJWKSet, jwtVerify } from 'jose';
4
+ import * as dotenv from 'dotenv';
5
+ dotenv.config();
6
+ export class M2MCredsTokenUserInfoFetcher extends UserInfoHelper {
7
+ token;
8
+ oauthProvider;
9
+ constructor(token, oauthProvider) {
10
+ super();
11
+ this.token = token;
12
+ this.oauthProvider = oauthProvider;
13
+ }
14
+ /**
15
+ * Verify M2M token
16
+ *
17
+ * @param {Request} request - The request object.
18
+ * @param {Response} response - The response object.
19
+ * @return {Promise<void>} The result of verifying the M2M token.
20
+ */
21
+ async fetch(request, response) {
22
+ // Verify M2M token
23
+ return this.verifyJWTToken(request, response);
24
+ }
25
+ async verifyJWTToken(request, response) {
26
+ // Get customerId from header
27
+ const customerId = request.headers['customer-id'];
28
+ try {
29
+ const { payload } = await jwtVerify(this.token, // The raw Bearer Token extracted from the request header
30
+ createRemoteJWKSet(new URL(this.oauthProvider.endpoint_jwks)), {
31
+ // expected issuer of the token, should be issued by the Logto server
32
+ issuer: this.oauthProvider.endpoint_issuer,
33
+ });
34
+ // Setup the scopes from the token
35
+ if (!payload.sub) {
36
+ return response.status(StatusCodes.UNAUTHORIZED).json({
37
+ error: `Unauthorized error: No sub found in the token.`,
38
+ });
39
+ }
40
+ // Set global context
41
+ const scopes = payload.scope ? payload.scope.split(' ') : [];
42
+ this.setScopes(scopes, response);
43
+ return await this.setCustomerEntity(customerId, response);
44
+ }
45
+ catch (error) {
46
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
47
+ error: `Unexpected error: While verifying M2M token: ${error}`,
48
+ });
49
+ }
50
+ }
51
+ }
52
+ //# sourceMappingURL=m2m-creds-token.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"m2m-creds-token.js","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/m2m-creds-token.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAyB,MAAM,WAAW,CAAC;AAElE,OAAO,EAAE,kBAAkB,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACrD,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AAEjC,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,OAAO,4BAA6B,SAAQ,cAAc;IAC/D,KAAK,CAAS;IACN,aAAa,CAAiB;IAEtC,YAAY,KAAa,EAAE,aAA6B;QACvD,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;IACpC,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,KAAK,CAAC,OAAgB,EAAE,QAAkB;QAC/C,mBAAmB;QACnB,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;IAC/C,CAAC;IAEM,KAAK,CAAC,cAAc,CAAC,OAAgB,EAAE,QAAkB;QAC/D,6BAA6B;QAC7B,MAAM,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAClD,IAAI,CAAC;YACJ,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,SAAS,CAClC,IAAI,CAAC,KAAK,EAAE,yDAAyD;YACrE,kBAAkB,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,EAC7D;gBACC,qEAAqE;gBACrE,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,eAAe;aAC1C,CACD,CAAC;YACF,kCAAkC;YAClC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC;gBAClB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;oBACrD,KAAK,EAAE,gDAAgD;iBACpB,CAAC,CAAC;YACvC,CAAC;YACD,qBAAqB;YACrB,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAE,OAAO,CAAC,KAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACzE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YACjC,OAAO,MAAM,IAAI,CAAC,iBAAiB,CAAC,UAAoB,EAAE,QAAQ,CAAC,CAAC;QACrE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC;gBAC9D,KAAK,EAAE,gDAAgD,KAAK,EAAE;aAC3B,CAAC,CAAC;QACvC,CAAC;IACF,CAAC;CACD"}
@@ -0,0 +1,20 @@
1
+ import type { Request, Response } from 'express';
2
+ import { UserInfoHelper, type IUserInfoFetcher } from './base.js';
3
+ import type { IOAuthProvider } from '../oauth/abstract.js';
4
+ export declare class PortalUserInfoFetcher extends UserInfoHelper implements IUserInfoFetcher {
5
+ private m2mToken;
6
+ private idToken;
7
+ private oauthProvider;
8
+ constructor(m2mToken: string, idToken: string, oauthProvider: IOAuthProvider);
9
+ fetch(request: Request, response: Response): Promise<Response<any, Record<string, any>> | undefined>;
10
+ /**
11
+ * Verifies the ID token for the portal.
12
+ *
13
+ * @param {Request} request - The request object.
14
+ * @param {Response} response - The response object.
15
+ * @return {Promise<void>} The result of verifying the ID token.
16
+ */
17
+ verifyIdToken(request: Request, response: Response): Promise<Response<any, Record<string, any>> | undefined>;
18
+ verifyM2MToken(request: Request, response: Response): Promise<Response<any, Record<string, any>> | undefined>;
19
+ }
20
+ //# sourceMappingURL=portal-token.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"portal-token.d.ts","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/portal-token.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEjD,OAAO,EAAE,cAAc,EAAE,KAAK,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAO3D,qBAAa,qBAAsB,SAAQ,cAAe,YAAW,gBAAgB;IACpF,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,OAAO,CAAC;IAChB,OAAO,CAAC,aAAa,CAAiB;gBAE1B,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,cAAc;IAOtE,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ;IAUhD;;;;;;OAMG;IACU,aAAa,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ;IAyBlD,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ;CAyBhE"}
@@ -0,0 +1,79 @@
1
+ import { StatusCodes } from 'http-status-codes';
2
+ import { UserInfoHelper } from './base.js';
3
+ import { createRemoteJWKSet, jwtVerify } from 'jose';
4
+ import * as dotenv from 'dotenv';
5
+ dotenv.config();
6
+ export class PortalUserInfoFetcher extends UserInfoHelper {
7
+ m2mToken;
8
+ idToken;
9
+ oauthProvider;
10
+ constructor(m2mToken, idToken, oauthProvider) {
11
+ super();
12
+ this.m2mToken = m2mToken;
13
+ this.idToken = idToken;
14
+ this.oauthProvider = oauthProvider;
15
+ }
16
+ async fetch(request, response) {
17
+ // Check the idToken, provided in header
18
+ const errorResponse = await this.verifyIdToken(request, response);
19
+ if (errorResponse) {
20
+ return errorResponse;
21
+ }
22
+ return this.verifyM2MToken(request, response);
23
+ }
24
+ /**
25
+ * Verifies the ID token for the portal.
26
+ *
27
+ * @param {Request} request - The request object.
28
+ * @param {Response} response - The response object.
29
+ * @return {Promise<void>} The result of verifying the ID token.
30
+ */
31
+ async verifyIdToken(request, response) {
32
+ try {
33
+ const { payload } = await jwtVerify(this.idToken, // The raw Bearer Token extracted from the request header
34
+ createRemoteJWKSet(new URL(this.oauthProvider.endpoint_jwks)), // generate a jwks using jwks_uri inquired from Logto server
35
+ {
36
+ // expected issuer of the token, should be issued by the Logto server
37
+ issuer: this.oauthProvider.endpoint_issuer,
38
+ });
39
+ // Setup the scopes from the token
40
+ if (!payload.sub) {
41
+ return response.status(StatusCodes.UNAUTHORIZED).json({
42
+ error: `Unauthorized error: No sub found in the token. Cannot set customerId.`,
43
+ });
44
+ }
45
+ return await this.setUserEntity(payload.sub, response);
46
+ }
47
+ catch (error) {
48
+ console.error(error);
49
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
50
+ error: `Unexpected error: While verifying ID token for Portal: ${error}`,
51
+ });
52
+ }
53
+ }
54
+ async verifyM2MToken(request, response) {
55
+ try {
56
+ const { payload } = await jwtVerify(this.m2mToken, // The raw Bearer Token extracted from the request header
57
+ createRemoteJWKSet(new URL(this.oauthProvider.endpoint_jwks)), // generate a jwks using jwks_uri inquired from Logto server
58
+ {
59
+ // expected issuer of the token, should be issued by the Logto server
60
+ issuer: this.oauthProvider.endpoint_issuer,
61
+ });
62
+ // Setup the scopes from the token
63
+ if (!payload.sub) {
64
+ return response.status(StatusCodes.UNAUTHORIZED).json({
65
+ error: `Unauthorized error: No sub found in the token.`,
66
+ });
67
+ }
68
+ const scopes = payload.scope ? payload.scope.split(' ') : [];
69
+ this.setScopes(scopes, response);
70
+ return;
71
+ }
72
+ catch (error) {
73
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
74
+ error: `Unexpected error: While verifying M2M token for Portal: ${error}`,
75
+ });
76
+ }
77
+ }
78
+ }
79
+ //# sourceMappingURL=portal-token.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"portal-token.js","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/portal-token.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import type { Response, Request } from 'express';
2
+ import type { IOAuthProvider } from '../oauth/abstract.js';
3
+ import { UserInfoHelper, type IUserInfoFetcher } from './base.js';
4
+ export declare class SwaggerUserInfoFetcher extends UserInfoHelper implements IUserInfoFetcher {
5
+ private oauthProvider;
6
+ constructor(oauthProvider: IOAuthProvider);
7
+ /**
8
+ * Tries to fetch user information based on the request and sets the appropriate response.
9
+ *
10
+ * @param {Request} request - The request object containing user information.
11
+ * @param {Response} response - The response object to be set based on user authentication status.
12
+ * @return {Promise<Response>} The response object with user information or an error message.
13
+ */
14
+ fetch(request: Request, response: Response): Promise<Response<any, Record<string, any>> | undefined>;
15
+ }
16
+ //# sourceMappingURL=swagger-ui.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"swagger-ui.d.ts","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/swagger-ui.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE3D,OAAO,EAAE,cAAc,EAAE,KAAK,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAGlE,qBAAa,sBAAuB,SAAQ,cAAe,YAAW,gBAAgB;IACrF,OAAO,CAAC,aAAa,CAAiB;gBAE1B,aAAa,EAAE,cAAc;IAIzC;;;;;;OAMG;IACG,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ;CA8BhD"}
@@ -0,0 +1,48 @@
1
+ import { StatusCodes } from 'http-status-codes';
2
+ import { UserInfoHelper } from './base.js';
3
+ export class SwaggerUserInfoFetcher extends UserInfoHelper {
4
+ oauthProvider;
5
+ constructor(oauthProvider) {
6
+ super();
7
+ this.oauthProvider = oauthProvider;
8
+ }
9
+ /**
10
+ * Tries to fetch user information based on the request and sets the appropriate response.
11
+ *
12
+ * @param {Request} request - The request object containing user information.
13
+ * @param {Response} response - The response object to be set based on user authentication status.
14
+ * @return {Promise<Response>} The response object with user information or an error message.
15
+ */
16
+ async fetch(request, response) {
17
+ try {
18
+ // If the user is not authenticated - return error
19
+ if (!request.user.isAuthenticated) {
20
+ return response.status(StatusCodes.UNAUTHORIZED).json({
21
+ error: "Unauthorized error: Seems like you are not authenticated. Please follow the authentication process using 'LogIn' button",
22
+ });
23
+ }
24
+ // Tries to get customerId from the logTo user structure
25
+ if (!request.user || !request.user.claims || !request.user.claims.sub) {
26
+ return response.status(StatusCodes.BAD_GATEWAY).json({
27
+ error: 'Internal error: Seems like authentication process was corrupted and there are problems with getting customerId',
28
+ });
29
+ }
30
+ const userId = request.user.claims.sub;
31
+ // Tries to get scopes for current user and check that required scopes are present
32
+ const _resp = await this.oauthProvider.getUserScopes(userId);
33
+ if (_resp.status !== 200) {
34
+ return response.status(StatusCodes.UNAUTHORIZED).json({
35
+ error: `Unauthorized error: No scopes found for the user: ${userId}.`,
36
+ });
37
+ }
38
+ this.setScopes(_resp.data, response);
39
+ return await this.setUserEntity(userId, response);
40
+ }
41
+ catch (error) {
42
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).json({
43
+ error: `Unexpected error: While verifying API key: ${error}`,
44
+ });
45
+ }
46
+ }
47
+ }
48
+ //# sourceMappingURL=swagger-ui.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"swagger-ui.js","sourceRoot":"","sources":["../../../../src/middleware/auth/user-info-fetcher/swagger-ui.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAyB,MAAM,WAAW,CAAC;AAGlE,MAAM,OAAO,sBAAuB,SAAQ,cAAc;IACjD,aAAa,CAAiB;IAEtC,YAAY,aAA6B;QACxC,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;IACpC,CAAC;IACD;;;;;;OAMG;IACH,KAAK,CAAC,KAAK,CAAC,OAAgB,EAAE,QAAkB;QAC/C,IAAI,CAAC;YACJ,kDAAkD;YAClD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;gBACnC,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;oBACrD,KAAK,EAAE,yHAAyH;iBAC7F,CAAC,CAAC;YACvC,CAAC;YACD,wDAAwD;YACxD,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;gBACvE,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC;oBACpD,KAAK,EAAE,gHAAgH;iBACpF,CAAC,CAAC;YACvC,CAAC;YACD,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;YACvC,kFAAkF;YAClF,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC7D,IAAI,KAAK,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;gBAC1B,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;oBACrD,KAAK,EAAE,qDAAqD,MAAM,GAAG;iBAClC,CAAC,CAAC;YACvC,CAAC;YACD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;YACrC,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QACnD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC;gBAC9D,KAAK,EAAE,8CAA8C,KAAK,EAAE;aACzB,CAAC,CAAC;QACvC,CAAC;IACF,CAAC;CACD"}
@@ -0,0 +1,15 @@
1
+ import { Request, Response, NextFunction } from 'express';
2
+ export declare class Authentication {
3
+ private apiGuardian;
4
+ private isSetup;
5
+ private logToHelper;
6
+ private oauthProvider;
7
+ constructor();
8
+ setup(next: NextFunction): Promise<void | Response<any, Record<string, any>>>;
9
+ handleError(error: Error, request: Request, response: Response, next: NextFunction): Promise<void | Response<any, Record<string, any>>>;
10
+ accessControl(request: Request, response: Response, next: NextFunction): Promise<void | Response<any, Record<string, any>>>;
11
+ wrapperHandleAuthRoutes(request: Request, response: Response, next: NextFunction): Promise<void>;
12
+ withLogtoWrapper(request: Request, response: Response, next: NextFunction): Promise<void | Response<any, Record<string, any>>>;
13
+ guard(request: Request, response: Response, next: NextFunction): Promise<void | Response<any, Record<string, any>>>;
14
+ }
15
+ //# sourceMappingURL=authentication.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"authentication.d.ts","sourceRoot":"","sources":["../../src/middleware/authentication.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAY,MAAM,SAAS,CAAC;AA0BpE,qBAAa,cAAc;IAC1B,OAAO,CAAC,WAAW,CAAW;IAC9B,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,aAAa,CAAiB;;IAwBzB,KAAK,CAAC,IAAI,EAAE,YAAY;IAcxB,WAAW,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;IASlF,aAAa,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;IActE,uBAAuB,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;IAShF,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;IAkBzE,KAAK,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;CAW3E"}
@@ -0,0 +1,110 @@
1
+ import { response } from 'express';
2
+ import { StatusCodes } from 'http-status-codes';
3
+ import * as dotenv from 'dotenv';
4
+ import { AccountAuthProvider } from './auth/routes/api/account-auth.js';
5
+ import { KeyAuthProvider } from './auth/routes/api/key-auth.js';
6
+ import { LogToHelper } from './auth/logto-helper.js';
7
+ import { configLogToExpress } from '../types/constants.js';
8
+ import { handleAuthRoutes, withLogto } from '@logto/express';
9
+ import { LogToProvider } from './auth/oauth/logto-provider.js';
10
+ import { AdminAuthRuleProvider } from './auth/routes/admin/admin-auth.js';
11
+ import { APIGuard } from './auth/auth-gaurd.js';
12
+ import { AuthRuleRepository } from './auth/routes/auth-rule-repository.js';
13
+ import { DidAuthRuleProvider } from './auth/routes/api/did-auth.js';
14
+ import { PresentationAuthRuleProvider } from './auth/routes/api/presentation-auth.js';
15
+ import { ResourceAuthRuleProvider } from './auth/routes/api/resource-auth.js';
16
+ import { CredentialAuthRuleProvider } from './auth/routes/api/credential-auth.js';
17
+ import { CredentialStatusAuthRuleProvider } from './auth/routes/api/credential-status-auth.js';
18
+ import { AuthInfoProvider } from './auth/routes/api/auth-user-info.js';
19
+ dotenv.config();
20
+ const { ENABLE_EXTERNAL_DB } = process.env;
21
+ export class Authentication {
22
+ apiGuardian;
23
+ isSetup = false;
24
+ logToHelper;
25
+ oauthProvider;
26
+ constructor() {
27
+ this.oauthProvider = new LogToProvider();
28
+ const authRuleRepository = new AuthRuleRepository();
29
+ authRuleRepository.push(new AuthInfoProvider());
30
+ authRuleRepository.push(new AccountAuthProvider());
31
+ authRuleRepository.push(new KeyAuthProvider());
32
+ authRuleRepository.push(new DidAuthRuleProvider());
33
+ authRuleRepository.push(new ResourceAuthRuleProvider());
34
+ authRuleRepository.push(new CredentialAuthRuleProvider());
35
+ authRuleRepository.push(new CredentialStatusAuthRuleProvider());
36
+ authRuleRepository.push(new PresentationAuthRuleProvider());
37
+ authRuleRepository.push(new AdminAuthRuleProvider());
38
+ this.apiGuardian = new APIGuard(authRuleRepository, this.oauthProvider);
39
+ // Initial auth handler
40
+ this.logToHelper = new LogToHelper();
41
+ }
42
+ async setup(next) {
43
+ if (!this.isSetup) {
44
+ const _r = await this.logToHelper.setup();
45
+ if (_r.status !== StatusCodes.OK) {
46
+ return response.status(StatusCodes.BAD_GATEWAY).json({
47
+ error: _r.error,
48
+ });
49
+ }
50
+ this.isSetup = true;
51
+ }
52
+ return next();
53
+ }
54
+ async handleError(error, request, response, next) {
55
+ if (error) {
56
+ return response.status(StatusCodes.UNAUTHORIZED).send({
57
+ error: `${error.message}`,
58
+ });
59
+ }
60
+ return next();
61
+ }
62
+ async accessControl(request, response, next) {
63
+ if (this.apiGuardian.skipPath(request.path))
64
+ return next();
65
+ // ToDo: Make it more readable
66
+ if (ENABLE_EXTERNAL_DB === 'false') {
67
+ if (['/account', '/did/create', '/key/create'].includes(request.path)) {
68
+ return response.status(StatusCodes.METHOD_NOT_ALLOWED).json({
69
+ error: 'Api not supported',
70
+ });
71
+ }
72
+ }
73
+ next();
74
+ }
75
+ async wrapperHandleAuthRoutes(request, response, next) {
76
+ const resources = await this.logToHelper.getAllResourcesWithNames();
77
+ return handleAuthRoutes({ ...configLogToExpress, scopes: ['roles'], resources: resources })(request, response, next);
78
+ }
79
+ async withLogtoWrapper(request, response, next) {
80
+ if (this.apiGuardian.skipPath(request.path))
81
+ return next();
82
+ try {
83
+ return withLogto({ ...configLogToExpress, scopes: ['roles'] })(request, response, next);
84
+ }
85
+ catch (err) {
86
+ return response.status(500).send({
87
+ authenticated: false,
88
+ error: `${err}`,
89
+ customerId: null,
90
+ });
91
+ }
92
+ }
93
+ // ToDo: refactor it or keep for the moment of setting up the admin panel
94
+ // private isBootstrapping(request: Request) {
95
+ // return ['/account/create'].includes(request.path);
96
+ // }
97
+ async guard(request, response, next) {
98
+ if (this.apiGuardian.skipPath(request.path))
99
+ return next();
100
+ try {
101
+ return await this.apiGuardian.guard(request, response, next);
102
+ }
103
+ catch (err) {
104
+ return response.status(StatusCodes.INTERNAL_SERVER_ERROR).send({
105
+ error: `Unexpected error: While guarding API request ${err}`,
106
+ });
107
+ }
108
+ }
109
+ }
110
+ //# sourceMappingURL=authentication.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"authentication.js","sourceRoot":"","sources":["../../src/middleware/authentication.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmC,QAAQ,EAAE,MAAM,SAAS,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,qBAAqB,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAE3E,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,EAAE,4BAA4B,EAAE,MAAM,wCAAwC,CAAC;AACtF,OAAO,EAAE,wBAAwB,EAAE,MAAM,oCAAoC,CAAC;AAC9E,OAAO,EAAE,0BAA0B,EAAE,MAAM,sCAAsC,CAAC;AAClF,OAAO,EAAE,gCAAgC,EAAE,MAAM,6CAA6C,CAAC;AAC/F,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AAGvE,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,EAAE,kBAAkB,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC;AAE3C,MAAM,OAAO,cAAc;IAClB,WAAW,CAAW;IACtB,OAAO,GAAG,KAAK,CAAC;IAChB,WAAW,CAAc;IACzB,aAAa,CAAiB;IAEtC;QACC,IAAI,CAAC,aAAa,GAAG,IAAI,aAAa,EAAE,CAAC;QACzC,MAAM,kBAAkB,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAEpD,kBAAkB,CAAC,IAAI,CAAC,IAAI,gBAAgB,EAAE,CAAC,CAAC;QAEhD,kBAAkB,CAAC,IAAI,CAAC,IAAI,mBAAmB,EAAE,CAAC,CAAC;QACnD,kBAAkB,CAAC,IAAI,CAAC,IAAI,eAAe,EAAE,CAAC,CAAC;QAE/C,kBAAkB,CAAC,IAAI,CAAC,IAAI,mBAAmB,EAAE,CAAC,CAAC;QACnD,kBAAkB,CAAC,IAAI,CAAC,IAAI,wBAAwB,EAAE,CAAC,CAAC;QACxD,kBAAkB,CAAC,IAAI,CAAC,IAAI,0BAA0B,EAAE,CAAC,CAAC;QAC1D,kBAAkB,CAAC,IAAI,CAAC,IAAI,gCAAgC,EAAE,CAAC,CAAC;QAChE,kBAAkB,CAAC,IAAI,CAAC,IAAI,4BAA4B,EAAE,CAAC,CAAC;QAE5D,kBAAkB,CAAC,IAAI,CAAC,IAAI,qBAAqB,EAAE,CAAC,CAAC;QAErD,IAAI,CAAC,WAAW,GAAG,IAAI,QAAQ,CAAC,kBAAkB,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACxE,uBAAuB;QACvB,IAAI,CAAC,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC;IACtC,CAAC;IAEM,KAAK,CAAC,KAAK,CAAC,IAAkB;QACpC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACnB,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;YAC1C,IAAI,EAAE,CAAC,MAAM,KAAK,WAAW,CAAC,EAAE,EAAE,CAAC;gBAClC,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC;oBACpD,KAAK,EAAE,EAAE,CAAC,KAAK;iBACf,CAAC,CAAC;YACJ,CAAC;YAED,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACrB,CAAC;QACD,OAAO,IAAI,EAAE,CAAC;IACf,CAAC;IAEM,KAAK,CAAC,WAAW,CAAC,KAAY,EAAE,OAAgB,EAAE,QAAkB,EAAE,IAAkB;QAC9F,IAAI,KAAK,EAAE,CAAC;YACX,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC;gBACrD,KAAK,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE;aACzB,CAAC,CAAC;QACJ,CAAC;QACD,OAAO,IAAI,EAAE,CAAC;IACf,CAAC;IAEM,KAAK,CAAC,aAAa,CAAC,OAAgB,EAAE,QAAkB,EAAE,IAAkB;QAClF,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,EAAE,CAAC;QAE3D,8BAA8B;QAC9B,IAAI,kBAAkB,KAAK,OAAO,EAAE,CAAC;YACpC,IAAI,CAAC,UAAU,EAAE,aAAa,EAAE,aAAa,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;gBACvE,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC;oBAC3D,KAAK,EAAE,mBAAmB;iBAC1B,CAAC,CAAC;YACJ,CAAC;QACF,CAAC;QACD,IAAI,EAAE,CAAC;IACR,CAAC;IAEM,KAAK,CAAC,uBAAuB,CAAC,OAAgB,EAAE,QAAkB,EAAE,IAAkB;QAC5F,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,wBAAwB,EAAE,CAAC;QACpE,OAAO,gBAAgB,CAAC,EAAE,GAAG,kBAAkB,EAAE,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,SAAqB,EAAE,CAAC,CACtG,OAAO,EACP,QAAQ,EACR,IAAI,CACJ,CAAC;IACH,CAAC;IAEM,KAAK,CAAC,gBAAgB,CAAC,OAAgB,EAAE,QAAkB,EAAE,IAAkB;QACrF,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,EAAE,CAAC;QAC3D,IAAI,CAAC;YACJ,OAAO,SAAS,CAAC,EAAE,GAAG,kBAAkB,EAAE,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;QACzF,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACd,OAAO,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;gBAChC,aAAa,EAAE,KAAK;gBACpB,KAAK,EAAE,GAAG,GAAG,EAAE;gBACf,UAAU,EAAE,IAAI;aAChB,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAED,yEAAyE;IACzE,8CAA8C;IAC9C,sDAAsD;IACtD,IAAI;IAEG,KAAK,CAAC,KAAK,CAAC,OAAgB,EAAE,QAAkB,EAAE,IAAkB;QAC1E,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,EAAE,CAAC;QAE3D,IAAI,CAAC;YACJ,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;QAC9D,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACd,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC;gBAC9D,KAAK,EAAE,gDAAgD,GAAG,EAAE;aACzB,CAAC,CAAC;QACvC,CAAC;IACF,CAAC;CACD"}