@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,117 @@
1
+ import { StatusCodes } from 'http-status-codes';
2
+ import { SwaggerUserInfoFetcher } from './user-info-fetcher/swagger-ui.js';
3
+ import { PortalUserInfoFetcher } from './user-info-fetcher/portal-token.js';
4
+ import { IdTokenUserInfoFetcher } from './user-info-fetcher/idtoken.js';
5
+ import { M2MCredsTokenUserInfoFetcher } from './user-info-fetcher/m2m-creds-token.js';
6
+ import { APITokenUserInfoFetcher } from './user-info-fetcher/api-token.js';
7
+ export class APIGuard {
8
+ authRuleRepository;
9
+ userInfoFetcher;
10
+ oauthProvider;
11
+ static bearerTokenIdentifier = 'Bearer';
12
+ pathSkip = ['/swagger', '/static', '/logto', '/account/bootstrap', '/admin/webhook'];
13
+ constructor(authRuleRepository, oauthProvider) {
14
+ this.authRuleRepository = authRuleRepository;
15
+ this.oauthProvider = oauthProvider;
16
+ this.userInfoFetcher = new SwaggerUserInfoFetcher(this.oauthProvider);
17
+ }
18
+ /**
19
+ * Executes the authentication guard for incoming requests.
20
+ *
21
+ * @param {Request} request - The incoming request object.
22
+ * @param {Response} response - The outgoing response object.
23
+ * @param {NextFunction} next - The next middleware function in the chain.
24
+ * @return {void}
25
+ */
26
+ async guard(request, response, next) {
27
+ const authRule = this.authRuleRepository.match(request);
28
+ if (!authRule) {
29
+ return response.status(StatusCodes.BAD_REQUEST).send({
30
+ error: `Bad Request. No auth rules for handling such request: ${request.method} ${request.path} or please check that namespace scpecified correctly.`,
31
+ });
32
+ }
33
+ // Set user info fetcher
34
+ this.chooseUserFetcherStrategy(request);
35
+ // There some requests where API guarding is not needed
36
+ if (!request.user.isAuthenticated && authRule.isAllowedUnauthorized()) {
37
+ return next();
38
+ }
39
+ // Get User info. scopes and user id maybe placed in M2M, API token or using Swagger UI
40
+ const resp = await this.userInfoFetcher.fetch(request, response, this.oauthProvider);
41
+ if (resp) {
42
+ return resp;
43
+ }
44
+ // Checks if the list of scopes from user enough to make an action
45
+ if (!authRule.isAllowedUnauthorized() && !authRule.areValidScopes(response.locals.scopes)) {
46
+ return response.status(StatusCodes.FORBIDDEN).send({
47
+ error: `Unauthorized error: Your account is not authorized to carry out this action.`,
48
+ });
49
+ }
50
+ return next();
51
+ }
52
+ /**
53
+ * Chooses the appropriate user fetcher strategy based on the request headers.
54
+ *
55
+ * @param {Request} request - The request object containing the headers.
56
+ * @return {void} This function does not return a value.
57
+ */
58
+ chooseUserFetcherStrategy(request) {
59
+ const bearerToken = APIGuard.extractBearerTokenFromHeaders(request.headers);
60
+ const portalToken = request.headers['id-token'];
61
+ const m2mCreds = request.headers['customer-id'];
62
+ const apiToken = request.headers['x-api-key'];
63
+ if (apiToken) {
64
+ this.setUserInfoStrategy(new APITokenUserInfoFetcher(apiToken, this.oauthProvider));
65
+ return;
66
+ }
67
+ if (m2mCreds) {
68
+ this.setUserInfoStrategy(new M2MCredsTokenUserInfoFetcher(m2mCreds, this.oauthProvider));
69
+ return;
70
+ }
71
+ if (portalToken && bearerToken) {
72
+ this.setUserInfoStrategy(new PortalUserInfoFetcher(bearerToken, portalToken, this.oauthProvider));
73
+ return;
74
+ }
75
+ if (bearerToken) {
76
+ this.setUserInfoStrategy(new IdTokenUserInfoFetcher(bearerToken, this.oauthProvider));
77
+ return;
78
+ }
79
+ this.setUserInfoStrategy(new SwaggerUserInfoFetcher(this.oauthProvider));
80
+ }
81
+ /**
82
+ * Sets the user info strategy for the API guard.
83
+ *
84
+ * @param {IUserInfoFetcher} strategy - The strategy to set as the user info fetcher.
85
+ * @return {void} This function does not return anything.
86
+ */
87
+ setUserInfoStrategy(strategy) {
88
+ this.userInfoFetcher = strategy;
89
+ }
90
+ /**
91
+ * Extracts the bearer token from the incoming HTTP headers.
92
+ *
93
+ * @param {IncomingHttpHeaders} headers - The incoming HTTP headers
94
+ * @return {string | unknown} The extracted bearer token
95
+ */
96
+ static extractBearerTokenFromHeaders({ authorization }) {
97
+ if (authorization && authorization.startsWith(this.bearerTokenIdentifier)) {
98
+ return authorization.slice(this.bearerTokenIdentifier.length + 1);
99
+ }
100
+ return undefined;
101
+ }
102
+ /**
103
+ * Checks if the given path should be skipped based on the list of paths to skip.
104
+ *
105
+ * @param {string} path - The path to check.
106
+ * @return {boolean} True if the path should be skipped, false otherwise.
107
+ */
108
+ skipPath(path) {
109
+ for (const ps of this.pathSkip) {
110
+ if (path === '/' || path.startsWith(ps)) {
111
+ return true;
112
+ }
113
+ }
114
+ return false;
115
+ }
116
+ }
117
+ //# sourceMappingURL=auth-gaurd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-gaurd.js","sourceRoot":"","sources":["../../../src/middleware/auth/auth-gaurd.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,44 @@
1
+ import type { ICommonErrorResponse } from '../../types/authentication.js';
2
+ import type { IOAuthProvider } from './oauth/abstract.js';
3
+ import { OAuthProvider } from './oauth/abstract.js';
4
+ export declare class LogToHelper extends OAuthProvider implements IOAuthProvider {
5
+ private m2mToken;
6
+ private allScopes;
7
+ private allResourceWithNames;
8
+ defaultScopes: string[];
9
+ private m2mGetTokenAttempts;
10
+ constructor();
11
+ setup(): Promise<ICommonErrorResponse>;
12
+ private getM2MToken;
13
+ private isTokenExpired;
14
+ getAllScopes(): string[];
15
+ getDefaultScopes(): string[];
16
+ getAllResourcesWithNames(): string[];
17
+ setDefaultRoleForUser(userId: string): Promise<ICommonErrorResponse>;
18
+ setDefaultRoleForApp(appId: string): Promise<ICommonErrorResponse>;
19
+ private returnOk;
20
+ private returnError;
21
+ getUserScopes(userId: string): Promise<ICommonErrorResponse>;
22
+ getAppScopes(appId: string): Promise<ICommonErrorResponse>;
23
+ private setDefaultScopes;
24
+ private setAllScopes;
25
+ private getScopesForRole;
26
+ private getScopesForResource;
27
+ getScopesForRolesList(roles: string[]): Promise<ICommonErrorResponse>;
28
+ getRolesForUser(userId: string): Promise<ICommonErrorResponse>;
29
+ getRolesForApp(appId: string): Promise<ICommonErrorResponse>;
30
+ private getRoleInfo;
31
+ private assignDefaultRoleForUser;
32
+ private assignDefaultRoleForApp;
33
+ private getRoleIdByName;
34
+ updateCustomData(userId: string, customData: any): Promise<ICommonErrorResponse>;
35
+ private getUserInfo;
36
+ getCustomData(userId: string): Promise<ICommonErrorResponse>;
37
+ private setAllResourcesWithNames;
38
+ getAllResources(): Promise<ICommonErrorResponse>;
39
+ private patchToLogto;
40
+ private postToLogto;
41
+ private getToLogto;
42
+ private setM2MToken;
43
+ }
44
+ //# sourceMappingURL=logto-helper.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logto-helper.d.ts","sourceRoot":"","sources":["../../../src/middleware/auth/logto-helper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAI1E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAIpD,qBAAa,WAAY,SAAQ,aAAc,YAAW,cAAc;IACvE,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,SAAS,CAAW;IAC5B,OAAO,CAAC,oBAAoB,CAAW;IAChC,aAAa,EAAE,MAAM,EAAE,CAAC;IAC/B,OAAO,CAAC,mBAAmB,CAAK;;IAUnB,KAAK,IAAI,OAAO,CAAC,oBAAoB,CAAC;YAqBrC,WAAW;IAoBzB,OAAO,CAAC,cAAc;IAMf,YAAY,IAAI,MAAM,EAAE;IAIxB,gBAAgB,IAAI,MAAM,EAAE;IAI5B,wBAAwB,IAAI,MAAM,EAAE;IAI9B,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAepE,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAgB/E,OAAO,CAAC,QAAQ;IAQhB,OAAO,CAAC,WAAW;IASN,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAgB5D,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;YAgBzD,gBAAgB;YAwBhB,YAAY;YAmBZ,gBAAgB;YAoBhB,oBAAoB;IAoBrB,qBAAqB,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAiBrE,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAW9D,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;YAW3D,WAAW;YASX,wBAAwB;YAiCxB,uBAAuB;YAavB,eAAe;IAsBhB,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,GAAG,OAAO,CAAC,oBAAoB,CAAC;YAY/E,WAAW;IASZ,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;YAU3D,wBAAwB;IAczB,eAAe,IAAI,OAAO,CAAC,oBAAoB,CAAC;YAW/C,YAAY;YAgBZ,WAAW;YAgBX,UAAU;YAgBV,WAAW;CAgCzB"}
@@ -0,0 +1,438 @@
1
+ import { StatusCodes } from 'http-status-codes';
2
+ import jwt from 'jsonwebtoken';
3
+ import * as dotenv from 'dotenv';
4
+ import { OAuthProvider } from './oauth/abstract.js';
5
+ import { EventTracker, eventTracker } from '../../services/track/tracker.js';
6
+ dotenv.config();
7
+ export class LogToHelper extends OAuthProvider {
8
+ m2mToken;
9
+ allScopes;
10
+ allResourceWithNames;
11
+ defaultScopes;
12
+ m2mGetTokenAttempts = 5;
13
+ constructor() {
14
+ super();
15
+ this.m2mToken = '';
16
+ this.allScopes = [];
17
+ this.defaultScopes = [];
18
+ this.allResourceWithNames = [];
19
+ }
20
+ async setup() {
21
+ let _r = {};
22
+ _r = await this.setM2MToken();
23
+ if (_r.status !== StatusCodes.OK) {
24
+ return _r;
25
+ }
26
+ _r = await this.setDefaultScopes();
27
+ if (_r.status !== StatusCodes.OK) {
28
+ return _r;
29
+ }
30
+ _r = await this.setAllScopes();
31
+ if (_r.status !== StatusCodes.OK) {
32
+ return _r;
33
+ }
34
+ _r = await this.setAllResourcesWithNames();
35
+ if (_r.status !== StatusCodes.OK) {
36
+ return _r;
37
+ }
38
+ return this.returnOk({});
39
+ }
40
+ async getM2MToken() {
41
+ if (!this.m2mToken || this.isTokenExpired(this.m2mToken)) {
42
+ for (let i = 0; i < this.m2mGetTokenAttempts; i++) {
43
+ const response = await this.setM2MToken();
44
+ if (response.status === StatusCodes.OK) {
45
+ return this.m2mToken;
46
+ }
47
+ await eventTracker.notify({
48
+ message: EventTracker.compileBasicNotification('Failed to get M2M token, Attempt ' + i + ' of ' + this.m2mGetTokenAttempts, 'M2M token issuing'),
49
+ severity: 'error',
50
+ });
51
+ }
52
+ throw new Error('Failed to get M2M token after ' + this.m2mGetTokenAttempts + ' attempts');
53
+ }
54
+ return this.m2mToken;
55
+ }
56
+ isTokenExpired(token) {
57
+ const { exp } = jwt.decode(token);
58
+ return Date.now() >= exp * 1000;
59
+ }
60
+ getAllScopes() {
61
+ return this.allScopes;
62
+ }
63
+ getDefaultScopes() {
64
+ return this.defaultScopes;
65
+ }
66
+ getAllResourcesWithNames() {
67
+ return this.allResourceWithNames;
68
+ }
69
+ async setDefaultRoleForUser(userId) {
70
+ const roles = await this.getRolesForUser(userId);
71
+ if (roles.status !== StatusCodes.OK) {
72
+ return this.returnError(StatusCodes.BAD_GATEWAY, roles.error);
73
+ }
74
+ // Check that default role is set
75
+ for (const role of roles.data) {
76
+ if (role.id === process.env.LOGTO_DEFAULT_ROLE_ID) {
77
+ return this.returnOk(roles.data);
78
+ }
79
+ }
80
+ // Assign a default role to a user
81
+ return await this.assignDefaultRoleForUser(userId, process.env.LOGTO_DEFAULT_ROLE_ID);
82
+ }
83
+ async setDefaultRoleForApp(appId) {
84
+ const roles = await this.getRolesForUser(appId);
85
+ if (roles.status !== StatusCodes.OK) {
86
+ return this.returnError(StatusCodes.BAD_GATEWAY, roles.error);
87
+ }
88
+ // Check that default role is set
89
+ for (const role of roles.data) {
90
+ if (role.id === process.env.LOGTO_DEFAULT_ROLE_ID) {
91
+ return this.returnOk(roles.data);
92
+ }
93
+ }
94
+ // Assign a default role to a user
95
+ return await this.assignDefaultRoleForApp(appId, process.env.LOGTO_DEFAULT_ROLE_ID);
96
+ }
97
+ returnOk(data) {
98
+ return {
99
+ status: StatusCodes.OK,
100
+ error: '',
101
+ data: data,
102
+ };
103
+ }
104
+ returnError(status, error, data = {}) {
105
+ return {
106
+ status: status,
107
+ error: error,
108
+ data: data,
109
+ };
110
+ }
111
+ // Scopes
112
+ async getUserScopes(userId) {
113
+ const scopes = [];
114
+ const roles = await this.getRolesForUser(userId);
115
+ if (roles.status !== StatusCodes.OK) {
116
+ return this.returnError(StatusCodes.BAD_GATEWAY, roles.error);
117
+ }
118
+ // Check that default role is set
119
+ for (const role of roles.data) {
120
+ const _s = await this.getScopesForRole(role.id);
121
+ if (_s.status === StatusCodes.OK) {
122
+ scopes.push(..._s.data);
123
+ }
124
+ }
125
+ return this.returnOk(scopes);
126
+ }
127
+ async getAppScopes(appId) {
128
+ const scopes = [];
129
+ const roles = await this.getRolesForApp(appId);
130
+ if (roles.status !== StatusCodes.OK) {
131
+ return this.returnError(StatusCodes.BAD_GATEWAY, roles.error);
132
+ }
133
+ // Check that default role is set
134
+ for (const role of roles.data) {
135
+ const _s = await this.getScopesForRole(role.id);
136
+ if (_s.status === StatusCodes.OK) {
137
+ scopes.push(..._s.data);
138
+ }
139
+ }
140
+ return this.returnOk(scopes);
141
+ }
142
+ async setDefaultScopes() {
143
+ const _r = await this.getAllResources();
144
+ if (_r.status !== StatusCodes.OK) {
145
+ return this.returnError(StatusCodes.BAD_GATEWAY, `Looks like ${process.env.LOGTO_DEFAULT_RESOURCE_URL} is not setup on LogTo side`);
146
+ }
147
+ for (const r of _r.data) {
148
+ if (r.indicator === process.env.LOGTO_DEFAULT_RESOURCE_URL) {
149
+ const _rr = await this.getScopesForResource(r.id);
150
+ if (_rr.status === StatusCodes.OK) {
151
+ this.defaultScopes = _rr.data;
152
+ return this.returnOk({});
153
+ }
154
+ else {
155
+ return _rr;
156
+ }
157
+ }
158
+ }
159
+ return this.returnError(StatusCodes.BAD_GATEWAY, `Looks like resource with id ${process.env.LOGTO_DEFAULT_RESOURCE_URL} is not placed on LogTo`);
160
+ }
161
+ async setAllScopes() {
162
+ const allResources = await this.getAllResources();
163
+ if (allResources.status !== StatusCodes.OK) {
164
+ return this.returnError(StatusCodes.BAD_GATEWAY, `setAllScopes: Error while getting all resources`);
165
+ }
166
+ for (const resource of allResources.data) {
167
+ if (resource.id !== 'management-api') {
168
+ const scopes = await this.getScopesForResource(resource.id);
169
+ if (scopes.status !== StatusCodes.OK) {
170
+ return this.returnError(StatusCodes.BAD_GATEWAY, `setAllScopes: Error while getting the scopes for ${resource.id}`);
171
+ }
172
+ this.allScopes = this.allScopes.concat(scopes.data);
173
+ }
174
+ }
175
+ return this.returnOk({});
176
+ }
177
+ async getScopesForRole(roleId) {
178
+ const uri = new URL(`/api/roles/${roleId}/scopes`, process.env.LOGTO_ENDPOINT);
179
+ const scopes = [];
180
+ try {
181
+ const metadata = await this.getToLogto(uri, 'GET');
182
+ if (metadata && metadata.status !== StatusCodes.OK) {
183
+ return this.returnError(StatusCodes.BAD_GATEWAY, `askRoleForScopes: Error while getting the all scopes for the role ${roleId}`);
184
+ }
185
+ for (const sc of metadata.data) {
186
+ scopes.push(sc.name);
187
+ }
188
+ return this.returnOk(scopes);
189
+ }
190
+ catch (err) {
191
+ return this.returnError(StatusCodes.BAD_GATEWAY, `askRoleForScopes ${err}`);
192
+ }
193
+ }
194
+ async getScopesForResource(resourceId) {
195
+ const uri = new URL(`/api/resources/${resourceId}/scopes`, process.env.LOGTO_ENDPOINT);
196
+ const scopes = [];
197
+ try {
198
+ const metadata = await this.getToLogto(uri, 'GET');
199
+ if (metadata && metadata.status !== StatusCodes.OK) {
200
+ return this.returnError(StatusCodes.BAD_GATEWAY, `askResourceForScopes: Error while getting the all scopes for the resource ${resourceId}`);
201
+ }
202
+ for (const sc of metadata.data) {
203
+ scopes.push(sc.name);
204
+ }
205
+ return this.returnOk(scopes);
206
+ }
207
+ catch (err) {
208
+ return this.returnError(StatusCodes.BAD_GATEWAY, `askResourceForScopes ${err}`);
209
+ }
210
+ }
211
+ async getScopesForRolesList(roles) {
212
+ const scopes = [];
213
+ for (const role of roles) {
214
+ const roleId = await this.getRoleIdByName(role);
215
+ if (roleId.status !== StatusCodes.OK) {
216
+ return this.returnError(StatusCodes.BAD_GATEWAY, roleId.error);
217
+ }
218
+ const _r = await this.getScopesForRole(roleId.data);
219
+ if (_r.status !== StatusCodes.OK) {
220
+ return _r;
221
+ }
222
+ scopes.push(..._r.data);
223
+ }
224
+ return this.returnOk(scopes);
225
+ }
226
+ // Roles
227
+ async getRolesForUser(userId) {
228
+ const uri = new URL(`/api/users/${userId}/roles`, process.env.LOGTO_ENDPOINT);
229
+ try {
230
+ // Note: By default, the API returns first 20 roles.
231
+ // If our roles per user grows to more than 20, we need to implement pagination
232
+ return await this.getToLogto(uri, 'GET');
233
+ }
234
+ catch (err) {
235
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getRolesForUser ${err}`);
236
+ }
237
+ }
238
+ async getRolesForApp(appId) {
239
+ const uri = new URL(`/api/applications/${appId}/roles`, process.env.LOGTO_ENDPOINT);
240
+ try {
241
+ // Note: By default, the API returns first 20 roles.
242
+ // If our roles per user grows to more than 20, we need to implement pagination
243
+ return await this.getToLogto(uri, 'GET');
244
+ }
245
+ catch (err) {
246
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getRolesForUser ${err}`);
247
+ }
248
+ }
249
+ async getRoleInfo(roleId) {
250
+ const uri = new URL(`/api/roles/${roleId}`, process.env.LOGTO_ENDPOINT);
251
+ try {
252
+ return await this.getToLogto(uri, 'GET');
253
+ }
254
+ catch (err) {
255
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getRoleInfo ${err}`);
256
+ }
257
+ }
258
+ async assignDefaultRoleForUser(userId, roleId) {
259
+ const userInfo = await this.getUserInfo(userId);
260
+ const uri = new URL(`/api/users/${userId}/roles`, process.env.LOGTO_ENDPOINT);
261
+ if (userInfo.status !== StatusCodes.OK) {
262
+ return this.returnError(StatusCodes.BAD_GATEWAY, `Could not fetch the info about role with roleId ${roleId}`);
263
+ }
264
+ // Means that user exists
265
+ if (userInfo.data.isSuspended === 'true') {
266
+ return this.returnError(StatusCodes.FORBIDDEN, 'User is suspended');
267
+ }
268
+ // Means it's not suspended
269
+ const role = await this.getRoleInfo(roleId);
270
+ if (role.status !== StatusCodes.OK) {
271
+ return this.returnError(StatusCodes.BAD_GATEWAY, `Could not fetch the info about user with userId ${userId} because of error from authority server: ${role.error}`);
272
+ }
273
+ // Such role exists
274
+ try {
275
+ const body = {
276
+ roleIds: [roleId],
277
+ };
278
+ return await this.postToLogto(uri, body, { 'Content-Type': 'application/json' });
279
+ }
280
+ catch (err) {
281
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getRolesForUser ${err}`);
282
+ }
283
+ }
284
+ async assignDefaultRoleForApp(appId, roleId) {
285
+ const uri = new URL(`/api/applications/${appId}/roles`, process.env.LOGTO_ENDPOINT);
286
+ // Such role exists
287
+ try {
288
+ const body = {
289
+ roleIds: [roleId],
290
+ };
291
+ return await this.postToLogto(uri, body, { 'Content-Type': 'application/json' });
292
+ }
293
+ catch (err) {
294
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getRolesForUser ${err}`);
295
+ }
296
+ }
297
+ async getRoleIdByName(roleName) {
298
+ const uri = new URL(`/api/roles`, process.env.LOGTO_ENDPOINT);
299
+ try {
300
+ const metadata = await this.getToLogto(uri, 'GET');
301
+ if (metadata && metadata.status !== StatusCodes.OK) {
302
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getRoleIdByName: Error while getting the all roles`);
303
+ }
304
+ for (const role of metadata.data) {
305
+ if (role.name === roleName) {
306
+ return this.returnOk(role.id);
307
+ }
308
+ }
309
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getRoleIdByName: Could not find role with name ${roleName}`);
310
+ }
311
+ catch (err) {
312
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getRoleIdByName ${err}`);
313
+ }
314
+ }
315
+ // Users
316
+ async updateCustomData(userId, customData) {
317
+ const uri = new URL(`/api/users/${userId}/custom-data`, process.env.LOGTO_ENDPOINT);
318
+ try {
319
+ const body = {
320
+ customData: customData,
321
+ };
322
+ return await this.patchToLogto(uri, body, { 'Content-Type': 'application/json' });
323
+ }
324
+ catch (err) {
325
+ return this.returnError(500, `updateCustomData ${err}`);
326
+ }
327
+ }
328
+ async getUserInfo(userId) {
329
+ const uri = new URL(`/api/users/${userId}`, process.env.LOGTO_ENDPOINT);
330
+ try {
331
+ return await this.getToLogto(uri, 'GET');
332
+ }
333
+ catch (err) {
334
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getUserInfo ${err}`);
335
+ }
336
+ }
337
+ async getCustomData(userId) {
338
+ const uri = new URL(`/api/users/${userId}/custom-data`, process.env.LOGTO_ENDPOINT);
339
+ try {
340
+ return await this.getToLogto(uri, 'GET');
341
+ }
342
+ catch (err) {
343
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getCustomData ${err}`);
344
+ }
345
+ }
346
+ // Resources
347
+ async setAllResourcesWithNames() {
348
+ const allResources = await this.getAllResources();
349
+ if (allResources.status !== StatusCodes.OK) {
350
+ return this.returnError(StatusCodes.BAD_GATEWAY, `setAllResourcesWithNames: Error while getting all resources. Error: ${allResources.error}`);
351
+ }
352
+ for (const resource of allResources.data) {
353
+ this.allResourceWithNames.push(resource.indicator);
354
+ }
355
+ return this.returnOk({});
356
+ }
357
+ async getAllResources() {
358
+ const uri = new URL(`/api/resources`, process.env.LOGTO_ENDPOINT);
359
+ try {
360
+ return await this.getToLogto(uri, 'GET');
361
+ }
362
+ catch (err) {
363
+ return this.returnError(StatusCodes.BAD_GATEWAY, `getAllResources ${err}`);
364
+ }
365
+ }
366
+ // Utils
367
+ async patchToLogto(uri, body, headers = {}) {
368
+ const response = await fetch(uri, {
369
+ headers: {
370
+ ...headers,
371
+ Authorization: 'Bearer ' + this.m2mToken,
372
+ },
373
+ body: JSON.stringify(body),
374
+ method: 'PATCH',
375
+ });
376
+ if (!response.ok) {
377
+ return this.returnError(response.status, await response.json());
378
+ }
379
+ return this.returnOk({});
380
+ }
381
+ async postToLogto(uri, body, headers = {}) {
382
+ const response = await fetch(uri, {
383
+ headers: {
384
+ ...headers,
385
+ Authorization: 'Bearer ' + (await this.getM2MToken()),
386
+ },
387
+ body: JSON.stringify(body),
388
+ method: 'POST',
389
+ });
390
+ if (!response.ok) {
391
+ return this.returnError(StatusCodes.BAD_GATEWAY, await response.json());
392
+ }
393
+ return this.returnOk({});
394
+ }
395
+ async getToLogto(uri, headers = {}) {
396
+ const response = await fetch(uri, {
397
+ headers: {
398
+ ...headers,
399
+ Authorization: 'Bearer ' + (await this.getM2MToken()),
400
+ },
401
+ method: 'GET',
402
+ });
403
+ if (!response.ok) {
404
+ return this.returnError(StatusCodes.BAD_GATEWAY, await response.json());
405
+ }
406
+ const metadata = await response.json();
407
+ return this.returnOk(metadata);
408
+ }
409
+ async setM2MToken() {
410
+ const searchParams = new URLSearchParams({
411
+ grant_type: 'client_credentials',
412
+ resource: process.env.LOGTO_MANAGEMENT_API,
413
+ scope: 'all',
414
+ });
415
+ const uri = new URL('/oidc/token', process.env.LOGTO_ENDPOINT);
416
+ const token = `Basic ${btoa(process.env.LOGTO_M2M_APP_ID + ':' + process.env.LOGTO_M2M_APP_SECRET)}`;
417
+ try {
418
+ const response = await fetch(uri, {
419
+ method: 'POST',
420
+ body: searchParams,
421
+ headers: {
422
+ 'Content-Type': 'application/x-www-form-urlencoded',
423
+ Authorization: token,
424
+ },
425
+ });
426
+ if (!response.ok) {
427
+ return this.returnError(StatusCodes.BAD_GATEWAY, 'Error while bootstrapping the connection with authority server');
428
+ }
429
+ const data = await response.json();
430
+ this.m2mToken = data.access_token;
431
+ return this.returnOk({});
432
+ }
433
+ catch (err) {
434
+ return this.returnError(StatusCodes.BAD_GATEWAY, 'Error while communicating with authority server');
435
+ }
436
+ }
437
+ }
438
+ //# sourceMappingURL=logto-helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logto-helper.js","sourceRoot":"","sources":["../../../src/middleware/auth/logto-helper.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ import type { ICommonErrorResponse } from '../../../types/authentication.js';
2
+ export interface IOAuthProvider {
3
+ endpoint_issuer: string;
4
+ endpoint_jwks: string;
5
+ getAllScopes(): string[] | void;
6
+ getDefaultScopes(): string[] | void;
7
+ getAllResourcesWithNames(): string[] | void;
8
+ getUserScopes(userId: string): Promise<ICommonErrorResponse>;
9
+ getAppScopes(appId: string): Promise<ICommonErrorResponse>;
10
+ getScopesForRoles(rolesList: string[]): Promise<string[] | void>;
11
+ }
12
+ export declare abstract class OAuthProvider implements IOAuthProvider {
13
+ endpoint_issuer: string;
14
+ endpoint_jwks: string;
15
+ getAllScopes(): string[] | void;
16
+ getDefaultScopes(): string[] | void;
17
+ getAllResourcesWithNames(): string[] | void;
18
+ getUserScopes(userId: string): Promise<ICommonErrorResponse>;
19
+ getAppScopes(appId: string): Promise<ICommonErrorResponse>;
20
+ getScopesForRoles(rolesList: string[]): Promise<string[] | void>;
21
+ }
22
+ //# sourceMappingURL=abstract.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"abstract.d.ts","sourceRoot":"","sources":["../../../../src/middleware/auth/oauth/abstract.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AAI7E,MAAM,WAAW,cAAc;IAC9B,eAAe,EAAE,MAAM,CAAC;IACxB,aAAa,EAAE,MAAM,CAAC;IACtB,YAAY,IAAI,MAAM,EAAE,GAAG,IAAI,CAAC;IAChC,gBAAgB,IAAI,MAAM,EAAE,GAAG,IAAI,CAAC;IACpC,wBAAwB,IAAI,MAAM,EAAE,GAAG,IAAI,CAAC;IAC5C,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAAC;IAC7D,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAAC;IAC3D,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC;CACjE;AAED,8BAAsB,aAAc,YAAW,cAAc;IAC5D,eAAe,EAAE,MAAM,CAA4B;IACnD,aAAa,EAAE,MAAM,CAAiC;IAEtD,YAAY,IAAI,MAAM,EAAE,GAAG,IAAI;IAG/B,gBAAgB,IAAI,MAAM,EAAE,GAAG,IAAI;IAGnC,wBAAwB,IAAI,MAAM,EAAE,GAAG,IAAI;IAG3C,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAG5D,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAG1D,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC;CAGhE"}