@verii/server-credentialagent 1.0.0-pre.1752076816

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 (395) hide show
  1. package/.localdev.e2e.env +40 -0
  2. package/.localdev.env +41 -0
  3. package/.standalone.env +5 -0
  4. package/LICENSE +202 -0
  5. package/NOTICE +1 -0
  6. package/README.md +19 -0
  7. package/docker/compose.yml +33 -0
  8. package/e2e/README.md +12 -0
  9. package/e2e/org-registration-and-issuing.e2e.test.js +624 -0
  10. package/jest.config.js +20 -0
  11. package/migrate-mongo.config.js +36 -0
  12. package/migrations/20210317133137-add-index-to-offers-repo.js +57 -0
  13. package/migrations/20210416145639-add-index-to-revocation-list.js +27 -0
  14. package/migrations/20210719120225-add_unique_did_index_to_tenant.js +45 -0
  15. package/migrations/20230524053029-add-vendorUserIdMappings-index.js +32 -0
  16. package/migrations/20230616111907-add-configuration-type-index.js +32 -0
  17. package/package.json +108 -0
  18. package/src/assets/public/favicon.ico +0 -0
  19. package/src/assets/public/logo192.png +0 -0
  20. package/src/assets/public/logo512.png +0 -0
  21. package/src/assets/public/manifest.json +28 -0
  22. package/src/assets/templates/app-redirect.hbs +16 -0
  23. package/src/config/config.js +44 -0
  24. package/src/config/core-config.js +143 -0
  25. package/src/config/holder-config.js +104 -0
  26. package/src/config/index.js +22 -0
  27. package/src/config/operator-config.js +64 -0
  28. package/src/controllers/autoload-holder-api-controllers.js +30 -0
  29. package/src/controllers/autoload-operator-api-controllers.js +31 -0
  30. package/src/controllers/autoload-root-api-controller.js +30 -0
  31. package/src/controllers/autoload-saasoperator-api-controllers.js +31 -0
  32. package/src/controllers/holder/autohooks.js +55 -0
  33. package/src/controllers/holder/get-exchange-progress/autohooks.js +27 -0
  34. package/src/controllers/holder/get-exchange-progress/controller.js +50 -0
  35. package/src/controllers/holder/inspect/autohooks.js +35 -0
  36. package/src/controllers/holder/inspect/get-presentation-request/controller.js +100 -0
  37. package/src/controllers/holder/inspect/schemas/holder-disclosure.schema.json +73 -0
  38. package/src/controllers/holder/inspect/schemas/index.js +33 -0
  39. package/src/controllers/holder/inspect/schemas/presentation-definition.v1.schema.json +461 -0
  40. package/src/controllers/holder/inspect/schemas/presentation-request.schema.json +279 -0
  41. package/src/controllers/holder/inspect/schemas/presentation-submission.schema.json +41 -0
  42. package/src/controllers/holder/inspect/schemas/siop-presentation-submission.schema.json +74 -0
  43. package/src/controllers/holder/inspect/schemas/velocity-presentation-submission.response.200.schema.json +36 -0
  44. package/src/controllers/holder/inspect/schemas/velocity-presentation-submission.schema.json +34 -0
  45. package/src/controllers/holder/inspect/submit-presentation/controller.js +89 -0
  46. package/src/controllers/holder/issue/autohooks.js +23 -0
  47. package/src/controllers/holder/issue/get-credential-manifest/controller.js +193 -0
  48. package/src/controllers/holder/issue/offers/autohooks.js +35 -0
  49. package/src/controllers/holder/issue/offers/controller.js +164 -0
  50. package/src/controllers/holder/issue/offers/credential-offers/controller.js +460 -0
  51. package/src/controllers/holder/issue/submit-identification/autohooks.js +37 -0
  52. package/src/controllers/holder/issue/submit-identification/controller.js +63 -0
  53. package/src/controllers/holder/oauth/autohooks.js +19 -0
  54. package/src/controllers/holder/oauth/controller.js +140 -0
  55. package/src/controllers/index.js +22 -0
  56. package/src/controllers/operator/tenants/_tenantId/autohooks.js +40 -0
  57. package/src/controllers/operator/tenants/_tenantId/check-credentials/autohooks.js +24 -0
  58. package/src/controllers/operator/tenants/_tenantId/check-credentials/controller-v0.8.js +200 -0
  59. package/src/controllers/operator/tenants/_tenantId/check-credentials/schemas/index.js +19 -0
  60. package/src/controllers/operator/tenants/_tenantId/check-credentials/schemas/vendor-credential.schema.json +244 -0
  61. package/src/controllers/operator/tenants/_tenantId/controller-v0.8.js +221 -0
  62. package/src/controllers/operator/tenants/_tenantId/disclosures/_id/autohooks.js +30 -0
  63. package/src/controllers/operator/tenants/_tenantId/disclosures/_id/controller-v0.8.js +271 -0
  64. package/src/controllers/operator/tenants/_tenantId/disclosures/_id/feeds/autohooks.js +45 -0
  65. package/src/controllers/operator/tenants/_tenantId/disclosures/_id/feeds/controller-v0.8.js +199 -0
  66. package/src/controllers/operator/tenants/_tenantId/disclosures/_id/feeds/schemas/add-feed.schema.js +14 -0
  67. package/src/controllers/operator/tenants/_tenantId/disclosures/_id/feeds/schemas/feed.schema.json +27 -0
  68. package/src/controllers/operator/tenants/_tenantId/disclosures/_id/feeds/schemas/index.js +25 -0
  69. package/src/controllers/operator/tenants/_tenantId/disclosures/_id/feeds/schemas/modify-feed-update-body.schema.js +18 -0
  70. package/src/controllers/operator/tenants/_tenantId/disclosures/_id/feeds/schemas/modify-feed.schema.json +19 -0
  71. package/src/controllers/operator/tenants/_tenantId/disclosures/autohooks.js +34 -0
  72. package/src/controllers/operator/tenants/_tenantId/disclosures/controller-v0.8.js +100 -0
  73. package/src/controllers/operator/tenants/_tenantId/disclosures/schemas/agent-disclosure-presentation-definition.schema.json +404 -0
  74. package/src/controllers/operator/tenants/_tenantId/disclosures/schemas/agent-disclosure.schema.js +24 -0
  75. package/src/controllers/operator/tenants/_tenantId/disclosures/schemas/index.js +29 -0
  76. package/src/controllers/operator/tenants/_tenantId/disclosures/schemas/new-agent-disclosure.schema.json +166 -0
  77. package/src/controllers/operator/tenants/_tenantId/disclosures/schemas/update-agent-disclosure.schema.js +20 -0
  78. package/src/controllers/operator/tenants/_tenantId/exchanges/_exchangeId/autohooks.js +30 -0
  79. package/src/controllers/operator/tenants/_tenantId/exchanges/_exchangeId/controller-v0.8.js +73 -0
  80. package/src/controllers/operator/tenants/_tenantId/exchanges/autohooks.js +19 -0
  81. package/src/controllers/operator/tenants/_tenantId/exchanges/controller-v0.8.js +150 -0
  82. package/src/controllers/operator/tenants/_tenantId/exchanges/schemas/get-exchange.response.body.json +147 -0
  83. package/src/controllers/operator/tenants/_tenantId/exchanges/schemas/index.js +21 -0
  84. package/src/controllers/operator/tenants/_tenantId/issued-credentials/autohooks.js +27 -0
  85. package/src/controllers/operator/tenants/_tenantId/issued-credentials/controller-v0.8.js +303 -0
  86. package/src/controllers/operator/tenants/_tenantId/issued-credentials/schemas/index.js +23 -0
  87. package/src/controllers/operator/tenants/_tenantId/issued-credentials/schemas/issued-credential.schema.json +115 -0
  88. package/src/controllers/operator/tenants/_tenantId/issued-credentials/schemas/revoke-credentials.schema.json +18 -0
  89. package/src/controllers/operator/tenants/_tenantId/keys/controller-v0.8.js +168 -0
  90. package/src/controllers/operator/tenants/_tenantId/offer-data/controller-v0.8.js +78 -0
  91. package/src/controllers/operator/tenants/_tenantId/offers/autohooks.js +34 -0
  92. package/src/controllers/operator/tenants/_tenantId/offers/controller-v0.8.js +253 -0
  93. package/src/controllers/operator/tenants/_tenantId/offers/schemas/index.js +23 -0
  94. package/src/controllers/operator/tenants/_tenantId/offers/schemas/new-vendor-offer.schema.js +47 -0
  95. package/src/controllers/operator/tenants/_tenantId/offers/schemas/vendor-offer.schema.json +56 -0
  96. package/src/controllers/operator/tenants/_tenantId/users/autohooks.js +24 -0
  97. package/src/controllers/operator/tenants/_tenantId/users/controller-v0.8.js +92 -0
  98. package/src/controllers/operator/tenants/_tenantId/users/schemas/index.js +23 -0
  99. package/src/controllers/operator/tenants/_tenantId/users/schemas/new-user.schema.json +13 -0
  100. package/src/controllers/operator/tenants/_tenantId/users/schemas/user.schema.json +16 -0
  101. package/src/controllers/operator/tenants/_tenantId/vc-api/credentials/autohooks.js +34 -0
  102. package/src/controllers/operator/tenants/_tenantId/vc-api/credentials/controller-v0.8.js +110 -0
  103. package/src/controllers/operator/tenants/_tenantId/vc-api/credentials/schemas/Credential.schema.js +18 -0
  104. package/src/controllers/operator/tenants/_tenantId/vc-api/credentials/schemas/IssueCredentialOptions.schema.json +42 -0
  105. package/src/controllers/operator/tenants/_tenantId/vc-api/credentials/schemas/IssueCredentialRequest.schema.json +13 -0
  106. package/src/controllers/operator/tenants/_tenantId/vc-api/credentials/schemas/IssueCredentialResponse.schema.json +19 -0
  107. package/src/controllers/operator/tenants/_tenantId/vc-api/credentials/schemas/LinkedDataProof.schema.json +43 -0
  108. package/src/controllers/operator/tenants/_tenantId/vc-api/credentials/schemas/VerifiableCredential.schema.js +16 -0
  109. package/src/controllers/operator/tenants/_tenantId/vc-api/credentials/schemas/index.js +31 -0
  110. package/src/controllers/operator/tenants/autohooks.js +65 -0
  111. package/src/controllers/operator/tenants/controller-v0.8.js +167 -0
  112. package/src/controllers/operator/tenants/schemas/index.js +41 -0
  113. package/src/controllers/operator/tenants/schemas/modify-secret.schema.json +11 -0
  114. package/src/controllers/operator/tenants/schemas/modify-tenant-v0.8.schema.json +44 -0
  115. package/src/controllers/operator/tenants/schemas/new-tenant-v0.8.schema.json +19 -0
  116. package/src/controllers/operator/tenants/schemas/new-tenant.response.200.schema.json +7 -0
  117. package/src/controllers/operator/tenants/schemas/secret-key-metadata.schema.json +31 -0
  118. package/src/controllers/operator/tenants/schemas/secret-key.schema.json +29 -0
  119. package/src/controllers/operator/tenants/schemas/secret-kid.schema.json +13 -0
  120. package/src/controllers/operator/tenants/schemas/secret-new-tenant-v0.8.schema.json +28 -0
  121. package/src/controllers/operator/tenants/schemas/secret-tenant-key-v0.8.schema.json +13 -0
  122. package/src/controllers/operator/tenants/schemas/tenant-key-v0.8.schema.json +14 -0
  123. package/src/controllers/operator/tenants/schemas/tenant-v0.8.schema.json +62 -0
  124. package/src/controllers/root/autohooks.js +23 -0
  125. package/src/controllers/root/controller.js +173 -0
  126. package/src/controllers/saasoperator/groups/_id/autohooks.js +9 -0
  127. package/src/controllers/saasoperator/groups/_id/controller.js +121 -0
  128. package/src/controllers/saasoperator/groups/autohooks.js +19 -0
  129. package/src/controllers/saasoperator/groups/controller.js +65 -0
  130. package/src/controllers/saasoperator/groups/schemas/group.schema.js +17 -0
  131. package/src/controllers/saasoperator/groups/schemas/index.js +4 -0
  132. package/src/controllers/saasoperator/groups/schemas/new-group.schema.js +13 -0
  133. package/src/entities/common/domains/get-json-at-path.js +28 -0
  134. package/src/entities/common/domains/index.js +17 -0
  135. package/src/entities/common/index.js +17 -0
  136. package/src/entities/credentials/domains/credential-format.js +22 -0
  137. package/src/entities/credentials/domains/index.js +19 -0
  138. package/src/entities/credentials/index.js +17 -0
  139. package/src/entities/deep-links/domains/extract-did.js +11 -0
  140. package/src/entities/deep-links/domains/index.js +20 -0
  141. package/src/entities/deep-links/domains/velocity-protocol-uri-to-http-uri.js +32 -0
  142. package/src/entities/deep-links/index.js +19 -0
  143. package/src/entities/disclosures/domains/assert-disclosure-active.js +21 -0
  144. package/src/entities/disclosures/domains/compute-disclosure-configuration-type.js +29 -0
  145. package/src/entities/disclosures/domains/constants.js +61 -0
  146. package/src/entities/disclosures/domains/errors.js +34 -0
  147. package/src/entities/disclosures/domains/get-disclosure-configuration-type.js +60 -0
  148. package/src/entities/disclosures/domains/index.js +32 -0
  149. package/src/entities/disclosures/domains/is-issuing-disclosure.js +23 -0
  150. package/src/entities/disclosures/domains/parse-body-to-disclosure.js +17 -0
  151. package/src/entities/disclosures/domains/validate-by-identification-method.js +69 -0
  152. package/src/entities/disclosures/domains/validate-commercial-entity.js +26 -0
  153. package/src/entities/disclosures/domains/validate-disclosure-by-configuration-type.js +47 -0
  154. package/src/entities/disclosures/domains/validate-disclosure-default-issuing.js +77 -0
  155. package/src/entities/disclosures/domains/validate-disclosure.js +37 -0
  156. package/src/entities/disclosures/domains/validate-feed.js +16 -0
  157. package/src/entities/disclosures/domains/validate-presentation-definition.js +54 -0
  158. package/src/entities/disclosures/domains/validate-vendor-endpoint.js +22 -0
  159. package/src/entities/disclosures/domains/validate-vendor-webhook.js +18 -0
  160. package/src/entities/disclosures/factories/disclosure-factory.js +94 -0
  161. package/src/entities/disclosures/factories/index.js +19 -0
  162. package/src/entities/disclosures/index.js +22 -0
  163. package/src/entities/disclosures/orchestrators/get-disclosure.js +18 -0
  164. package/src/entities/disclosures/orchestrators/index.js +20 -0
  165. package/src/entities/disclosures/orchestrators/update-disclosure-configuration-type.js +32 -0
  166. package/src/entities/disclosures/repos/index.js +20 -0
  167. package/src/entities/disclosures/repos/repo.js +118 -0
  168. package/src/entities/disclosures/repos/set-configuration-type.js +33 -0
  169. package/src/entities/exchanges/adapters/index.js +17 -0
  170. package/src/entities/exchanges/adapters/sign-exchange-response.js +45 -0
  171. package/src/entities/exchanges/domains/build-exchange-progress.js +56 -0
  172. package/src/entities/exchanges/domains/constants.js +24 -0
  173. package/src/entities/exchanges/domains/ensure-exchange-state-valid.js +35 -0
  174. package/src/entities/exchanges/domains/errors.js +33 -0
  175. package/src/entities/exchanges/domains/index.js +25 -0
  176. package/src/entities/exchanges/domains/states.js +43 -0
  177. package/src/entities/exchanges/domains/types.js +31 -0
  178. package/src/entities/exchanges/factories/disclosure-exchange-factory.js +46 -0
  179. package/src/entities/exchanges/factories/index.js +20 -0
  180. package/src/entities/exchanges/factories/offer-exchange-factory.js +48 -0
  181. package/src/entities/exchanges/index.js +23 -0
  182. package/src/entities/exchanges/orchestrators/build-exchange-request-deep-link.js +50 -0
  183. package/src/entities/exchanges/orchestrators/index.js +19 -0
  184. package/src/entities/exchanges/repos/exchange-repo-projections.js +45 -0
  185. package/src/entities/exchanges/repos/exchange-state-repo-extension.js +76 -0
  186. package/src/entities/exchanges/repos/index.js +20 -0
  187. package/src/entities/exchanges/repos/repo.js +44 -0
  188. package/src/entities/feeds/factories/feed-factory.js +47 -0
  189. package/src/entities/feeds/factories/index.js +19 -0
  190. package/src/entities/feeds/index.js +20 -0
  191. package/src/entities/feeds/repos/index.js +19 -0
  192. package/src/entities/feeds/repos/repo.js +95 -0
  193. package/src/entities/groups/domains/format-group.js +11 -0
  194. package/src/entities/groups/domains/index.js +3 -0
  195. package/src/entities/groups/factories/group-factory.js +40 -0
  196. package/src/entities/groups/factories/index.js +19 -0
  197. package/src/entities/groups/index.js +22 -0
  198. package/src/entities/groups/orchestrators/find-group-or-error.js +16 -0
  199. package/src/entities/groups/orchestrators/index.js +6 -0
  200. package/src/entities/groups/orchestrators/validate-did.js +24 -0
  201. package/src/entities/groups/orchestrators/validate-group-by-user.js +16 -0
  202. package/src/entities/groups/orchestrators/validate-group.js +39 -0
  203. package/src/entities/groups/repos/delete-tenant-extension.js +13 -0
  204. package/src/entities/groups/repos/index.js +19 -0
  205. package/src/entities/groups/repos/repo.js +38 -0
  206. package/src/entities/groups/repos/update-or-error-extension.js +46 -0
  207. package/src/entities/index.js +37 -0
  208. package/src/entities/keys/domains/constants.js +37 -0
  209. package/src/entities/keys/domains/index.js +21 -0
  210. package/src/entities/keys/domains/is-matching-private-key-kid.js +41 -0
  211. package/src/entities/keys/domains/validate-key.js +62 -0
  212. package/src/entities/keys/factories/index.js +19 -0
  213. package/src/entities/keys/factories/key-factory.js +56 -0
  214. package/src/entities/keys/index.js +22 -0
  215. package/src/entities/keys/orchestrators/index.js +3 -0
  216. package/src/entities/keys/orchestrators/validate-did-doc-keys.js +69 -0
  217. package/src/entities/metadata-list-allocations/index.js +19 -0
  218. package/src/entities/metadata-list-allocations/repos/index.js +19 -0
  219. package/src/entities/metadata-list-allocations/repos/repo.js +40 -0
  220. package/src/entities/notifications/domains/index.js +19 -0
  221. package/src/entities/notifications/domains/notification-types.js +25 -0
  222. package/src/entities/notifications/index.js +19 -0
  223. package/src/entities/offers/domains/build-clean-pii-filter.js +35 -0
  224. package/src/entities/offers/domains/build-deeplink-url.js +120 -0
  225. package/src/entities/offers/domains/build-offer.js +88 -0
  226. package/src/entities/offers/domains/build-qr-code-url.js +37 -0
  227. package/src/entities/offers/domains/constants.js +32 -0
  228. package/src/entities/offers/domains/filter-object-ids.js +34 -0
  229. package/src/entities/offers/domains/generate-issuing-challenge.js +26 -0
  230. package/src/entities/offers/domains/generate-link-code.js +35 -0
  231. package/src/entities/offers/domains/index.js +31 -0
  232. package/src/entities/offers/domains/post-validation-offers-handler.js +31 -0
  233. package/src/entities/offers/domains/prepare-linked-credentials-for-holder.js +36 -0
  234. package/src/entities/offers/domains/resolve-subject.js +142 -0
  235. package/src/entities/offers/domains/validate-offer-commercial-entity.js +24 -0
  236. package/src/entities/offers/domains/validate-offer.js +90 -0
  237. package/src/entities/offers/factories/index.js +19 -0
  238. package/src/entities/offers/factories/offer-factory.js +119 -0
  239. package/src/entities/offers/index.js +22 -0
  240. package/src/entities/offers/orchestrators/create-verifiable-credentials.js +131 -0
  241. package/src/entities/offers/orchestrators/finalize-exchange.js +44 -0
  242. package/src/entities/offers/orchestrators/index.js +23 -0
  243. package/src/entities/offers/orchestrators/load-credential-refs.js +57 -0
  244. package/src/entities/offers/orchestrators/load-credential-types-map.js +44 -0
  245. package/src/entities/offers/orchestrators/prepare-offers.js +35 -0
  246. package/src/entities/offers/orchestrators/trigger-issued-credentials-webhook.js +63 -0
  247. package/src/entities/offers/repos/clean-pii-extension.js +85 -0
  248. package/src/entities/offers/repos/index.js +20 -0
  249. package/src/entities/offers/repos/issued-credential-projection.js +44 -0
  250. package/src/entities/offers/repos/repo.js +177 -0
  251. package/src/entities/presentations/domains/build-identity-doc.js +120 -0
  252. package/src/entities/presentations/domains/build-request-response-schema.js +46 -0
  253. package/src/entities/presentations/domains/build-vendor-data.js +31 -0
  254. package/src/entities/presentations/domains/check-payment-requirement.js +30 -0
  255. package/src/entities/presentations/domains/errors.js +28 -0
  256. package/src/entities/presentations/domains/extract-fields-from-id-credential.js +35 -0
  257. package/src/entities/presentations/domains/index.js +26 -0
  258. package/src/entities/presentations/domains/merge-credential-check-results.js +24 -0
  259. package/src/entities/presentations/domains/validate-presentation.js +128 -0
  260. package/src/entities/presentations/index.js +20 -0
  261. package/src/entities/presentations/orchestrators/create-presentation-request.js +148 -0
  262. package/src/entities/presentations/orchestrators/deduplicate-disclosure-exchange.js +52 -0
  263. package/src/entities/presentations/orchestrators/handle-presentation-submission.js +47 -0
  264. package/src/entities/presentations/orchestrators/index.js +20 -0
  265. package/src/entities/presentations/orchestrators/match-identity-on-exchange.js +114 -0
  266. package/src/entities/presentations/orchestrators/share-identification-credentials.js +110 -0
  267. package/src/entities/presentations/orchestrators/share-presentation.js +234 -0
  268. package/src/entities/push-delegate/get-push-delegate.js +37 -0
  269. package/src/entities/push-delegate/index.js +17 -0
  270. package/src/entities/redirect/index.js +3 -0
  271. package/src/entities/redirect/orchestrators/index.js +3 -0
  272. package/src/entities/redirect/orchestrators/load-org-info.js +40 -0
  273. package/src/entities/revocation-list-allocations/index.js +19 -0
  274. package/src/entities/revocation-list-allocations/repos/index.js +19 -0
  275. package/src/entities/revocation-list-allocations/repos/repo.js +40 -0
  276. package/src/entities/schemas/index.js +19 -0
  277. package/src/entities/schemas/orchestrators/index.js +19 -0
  278. package/src/entities/schemas/orchestrators/load-schema-validation.js +73 -0
  279. package/src/entities/tenants/domains/build-service-ids.js +27 -0
  280. package/src/entities/tenants/domains/extract-service.js +27 -0
  281. package/src/entities/tenants/domains/index.js +21 -0
  282. package/src/entities/tenants/domains/validate-service-ids.js +35 -0
  283. package/src/entities/tenants/factories/index.js +19 -0
  284. package/src/entities/tenants/factories/tenant-factory.js +37 -0
  285. package/src/entities/tenants/index.js +22 -0
  286. package/src/entities/tenants/orchestrators/add-primary-address-to-tenant.js +47 -0
  287. package/src/entities/tenants/orchestrators/create-tenant.js +91 -0
  288. package/src/entities/tenants/orchestrators/index.js +22 -0
  289. package/src/entities/tenants/orchestrators/refresh-tenant-dids.js +146 -0
  290. package/src/entities/tenants/orchestrators/set-tenant-default-issuing-disclosure.js +31 -0
  291. package/src/entities/tenants/repos/index.js +20 -0
  292. package/src/entities/tenants/repos/insert-tenant-extension.js +33 -0
  293. package/src/entities/tenants/repos/repo.js +52 -0
  294. package/src/entities/tenants/repos/tenant-default-projection.js +33 -0
  295. package/src/entities/tokens/adapters/access-token.js +49 -0
  296. package/src/entities/tokens/adapters/index.js +19 -0
  297. package/src/entities/tokens/index.js +19 -0
  298. package/src/entities/users/factories/index.js +19 -0
  299. package/src/entities/users/factories/user-factory.js +36 -0
  300. package/src/entities/users/index.js +20 -0
  301. package/src/entities/users/repos/add-anonymous-user-repo-extension.js +23 -0
  302. package/src/entities/users/repos/find-or-insert-vendor-user-repo-extension.js +30 -0
  303. package/src/entities/users/repos/index.js +19 -0
  304. package/src/entities/users/repos/repo.js +50 -0
  305. package/src/fetchers/index.js +20 -0
  306. package/src/fetchers/operator/identify-fetcher.js +36 -0
  307. package/src/fetchers/operator/index.js +21 -0
  308. package/src/fetchers/operator/inspection-fetcher.js +35 -0
  309. package/src/fetchers/operator/issuing-fetcher.js +50 -0
  310. package/src/fetchers/operator/webhook-auth-header.js +45 -0
  311. package/src/fetchers/push-gateway/generate-push-gateway-token.js +40 -0
  312. package/src/fetchers/push-gateway/index.js +19 -0
  313. package/src/fetchers/push-gateway/push-fetcher.js +39 -0
  314. package/src/index.js +19 -0
  315. package/src/init-holder-server.js +108 -0
  316. package/src/init-operator-server.js +101 -0
  317. package/src/init-server.js +120 -0
  318. package/src/main-holder.js +18 -0
  319. package/src/main-operator.js +19 -0
  320. package/src/main.js +18 -0
  321. package/src/plugins/autoload-repos.js +28 -0
  322. package/src/plugins/disclosure-loader-plugin.js +56 -0
  323. package/src/plugins/ensure-disclosure-active-plugin.js +30 -0
  324. package/src/plugins/ensure-disclosure-configuration-type-plugin.js +29 -0
  325. package/src/plugins/ensure-tenant-default-issuing-disclosure-id-plugin.js +60 -0
  326. package/src/plugins/ensure-tenant-primary-address-plugin.js +44 -0
  327. package/src/plugins/exchange-error-handler-plugin.js +51 -0
  328. package/src/plugins/exchange-loader-plugin.js +50 -0
  329. package/src/plugins/group-loader-plugin.js +51 -0
  330. package/src/plugins/index.js +32 -0
  331. package/src/plugins/kms-plugin.js +57 -0
  332. package/src/plugins/tenant-loader-plugin.js +91 -0
  333. package/src/plugins/validate-cao-plugin.js +81 -0
  334. package/src/plugins/vendor-routes-auth-plugin.js +24 -0
  335. package/src/plugins/verify-access-token-plugin.js +88 -0
  336. package/src/standalone.js +24 -0
  337. package/src/start-app-server.js +38 -0
  338. package/test/combined/app-redirect.test.js +199 -0
  339. package/test/combined/helpers/credentialagent-build-fastify.js +29 -0
  340. package/test/combined/helpers/index.js +22 -0
  341. package/test/combined/helpers/nock-registrar-app-schema-name.js +50 -0
  342. package/test/combined/helpers/nock-registrar-get-organization-diddoc.js +26 -0
  343. package/test/combined/helpers/nock-registrar-get-organization-verified-profile.js +33 -0
  344. package/test/combined/manifest.json.test.js +55 -0
  345. package/test/combined/root-controller.test.js +42 -0
  346. package/test/combined/schemas/education-degree.schema.json +166 -0
  347. package/test/combined/schemas/employment-current-v1.1.schema.json +253 -0
  348. package/test/combined/schemas/open-badge-credential.schema.json +1285 -0
  349. package/test/combined/schemas/past-employment-position-with-uri-id.schema.js +22 -0
  350. package/test/combined/schemas/past-employment-position.schema.json +148 -0
  351. package/test/combined/schemas/will-always-validate.json +10 -0
  352. package/test/combined/validate-cao-plugin.test.js +155 -0
  353. package/test/get-push-delegate.test.js +54 -0
  354. package/test/helpers/jwt-vc-expectation.js +109 -0
  355. package/test/holder/build-request-response-schema.test.js +55 -0
  356. package/test/holder/credential-manifest-controller.test.js +3192 -0
  357. package/test/holder/e2e-issuing-controller.test.js +425 -0
  358. package/test/holder/get-exchange-progress-controller.test.js +521 -0
  359. package/test/holder/get-presentation-request.test.js +906 -0
  360. package/test/holder/helpers/credential-type-metadata.js +98 -0
  361. package/test/holder/helpers/credentialagent-holder-build-fastify.js +32 -0
  362. package/test/holder/helpers/generate-presentation.js +441 -0
  363. package/test/holder/helpers/generate-test-access-token.js +54 -0
  364. package/test/holder/helpers/jwt-access-token-expectation.js +32 -0
  365. package/test/holder/helpers/jwt-vc-expectation.js +115 -0
  366. package/test/holder/issuing-controller.test.js +7076 -0
  367. package/test/holder/oauth-token-controller.test.js +412 -0
  368. package/test/holder/presentation-submission.test.js +2365 -0
  369. package/test/holder/submit-identification.test.js +4815 -0
  370. package/test/operator/check-credentials-controller-v0.8.test.js +832 -0
  371. package/test/operator/credentials-revoke.test.js +536 -0
  372. package/test/operator/disclosures-controller-v0.8.test.js +4157 -0
  373. package/test/operator/exchanges-controller-v0.8.test.js +414 -0
  374. package/test/operator/exchanges-id-controller-v0.8.test.js +162 -0
  375. package/test/operator/feeds-controller-v0.8.test.js +659 -0
  376. package/test/operator/generate-push-gateway-token.test.js +116 -0
  377. package/test/operator/groups-controller.test.js +145 -0
  378. package/test/operator/groups-id-controller.test.js +287 -0
  379. package/test/operator/helpers/create-test-org-doc.js +60 -0
  380. package/test/operator/helpers/credentialagent-operator-build-fastify.js +32 -0
  381. package/test/operator/helpers/find-kms-key.js +31 -0
  382. package/test/operator/helpers/generate-primary-and-add-operator-to-primary.js +63 -0
  383. package/test/operator/helpers/init-agent-kms.js +22 -0
  384. package/test/operator/issued-credentials-controller-v0.8.test.js +398 -0
  385. package/test/operator/keys-controller-v0.8.test.js +1130 -0
  386. package/test/operator/offer-data-controller-v0.8.test.js +253 -0
  387. package/test/operator/offers-controller-v0.8.test.js +3026 -0
  388. package/test/operator/set-configuration-type-modifier.test.js +75 -0
  389. package/test/operator/swagger.test.js +37 -0
  390. package/test/operator/tenant-controller-v0.8.test.js +730 -0
  391. package/test/operator/tenant-loader-plugin.test.js +96 -0
  392. package/test/operator/tenants-controller-v0.8.test.js +2093 -0
  393. package/test/operator/users-controller-v0.8.test.js +137 -0
  394. package/test/operator/vc-api-credentials.test.js +963 -0
  395. package/verification.env +28 -0
@@ -0,0 +1,303 @@
1
+ /**
2
+ * Copyright 2023 Velocity Team
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ const newError = require('http-errors');
18
+ const ethUrlParser = require('eth-url-parser');
19
+ const { isEmpty, isNil, map, omitBy } = require('lodash/fp');
20
+ const { nanoid } = require('nanoid/non-secure');
21
+ const { initTransformToFinder } = require('@verii/rest-queries');
22
+ const { tableRegistry } = require('@spencejs/spence-mongo-repos');
23
+ const { KeyPurposes } = require('@verii/crypto');
24
+ const { getRevocationRegistry } = require('@verii/velocity-issuing');
25
+ const { sendPush } = require('../../../../../fetchers');
26
+ const { issuedCredentialProjection } = require('../../../../../entities');
27
+
28
+ const issuedCredentialsController = async (fastify) => {
29
+ const specificParams = {
30
+ type: 'object',
31
+ properties: {
32
+ credentialId: { type: 'string', minLength: 1 },
33
+ ...fastify.currentAutoSchemaPreset.params.properties,
34
+ },
35
+ };
36
+
37
+ fastify.post(
38
+ '/:credentialId/revoke',
39
+ {
40
+ schema: fastify.autoSchema({
41
+ params: specificParams,
42
+ body: {
43
+ $ref: 'https://velocitycareerlabs.io/revoke-credentials.schema.json#',
44
+ },
45
+ response: {
46
+ 200: {
47
+ type: 'object',
48
+ properties: {
49
+ notifiedOfRevocationAt: {
50
+ type: 'string',
51
+ format: 'date-time',
52
+ },
53
+ },
54
+ },
55
+ },
56
+ }),
57
+ },
58
+ async (req) => {
59
+ const {
60
+ params: { credentialId },
61
+ repos: { offers: offersRepo },
62
+ body,
63
+ } = req;
64
+ const offer = await offersRepo.findOne(
65
+ {
66
+ filter: {
67
+ did: credentialId,
68
+ },
69
+ },
70
+ { _id: 1, credentialStatus: 1, exchangeId: 1, did: 1, type: 1 }
71
+ );
72
+ if (!offer) {
73
+ throw newError.NotFound(`Credential ${credentialId} not found`);
74
+ }
75
+ if (isEmpty(offer.credentialStatus)) {
76
+ throw newError.BadRequest(
77
+ `Credential status not found for ${credentialId}`
78
+ );
79
+ }
80
+ if (offer.credentialStatus.revokedAt) {
81
+ return {};
82
+ }
83
+
84
+ await setRevokedOnChain(offer.credentialStatus.id, req);
85
+ await setRevokedTime(credentialId, req);
86
+ const { pushToken, pushUrl, exchange } = await getPushDelegate(
87
+ offer,
88
+ req
89
+ );
90
+ if (!pushToken || !pushUrl) {
91
+ return {};
92
+ }
93
+
94
+ await triggerPush(
95
+ {
96
+ pushToken,
97
+ offer,
98
+ ...body,
99
+ },
100
+ { ...req, exchange }
101
+ );
102
+ const [{ notifiedOfRevocationAt }] = await setNotifiedTime(
103
+ credentialId,
104
+ offer,
105
+ req
106
+ );
107
+ return {
108
+ notifiedOfRevocationAt,
109
+ };
110
+ }
111
+ );
112
+
113
+ fastify.get(
114
+ '/',
115
+ {
116
+ schema: fastify.autoSchema({
117
+ query: {
118
+ type: 'object',
119
+ properties: {
120
+ credentialId: {
121
+ type: 'string',
122
+ },
123
+ vendorOfferId: {
124
+ type: 'string',
125
+ },
126
+ vendorUserId: {
127
+ type: 'string',
128
+ },
129
+ page: {
130
+ type: 'object',
131
+ properties: {
132
+ size: { type: 'number' },
133
+ skip: { type: 'number' },
134
+ },
135
+ },
136
+ sort: {
137
+ type: 'array',
138
+ items: {
139
+ type: 'array',
140
+ items: { type: 'string' },
141
+ },
142
+ },
143
+ },
144
+ },
145
+ response: {
146
+ 200: {
147
+ type: 'object',
148
+ properties: {
149
+ issuedCredentials: {
150
+ type: 'array',
151
+ items: {
152
+ $ref: 'https://velocitycareerlabs.io/issued-credential.schema.json#',
153
+ },
154
+ },
155
+ },
156
+ },
157
+ },
158
+ }),
159
+ },
160
+ async (req) => {
161
+ const {
162
+ query: { page, sort, credentialId, vendorOfferId, vendorUserId },
163
+ repos,
164
+ } = req;
165
+ const filter = transformToFinder({
166
+ filter: omitBy(isNil, {
167
+ did: credentialId ?? { $exists: true },
168
+ offerId: vendorOfferId,
169
+ 'credentialSubject.vendorUserId': vendorUserId ?? { $exists: true },
170
+ }),
171
+ page,
172
+ sort,
173
+ });
174
+
175
+ const credentials = await repos.offers.find(
176
+ filter,
177
+ issuedCredentialProjection
178
+ );
179
+
180
+ return {
181
+ issuedCredentials: map(buildIssuedCredential(req), credentials),
182
+ };
183
+ }
184
+ );
185
+
186
+ const setRevokedOnChain = async (credentialStatusUrl, context) => {
187
+ const { tenant, tenantKeysByPurpose } = context;
188
+
189
+ const {
190
+ parameters: { address, listId, index },
191
+ } = ethUrlParser.parse(credentialStatusUrl);
192
+
193
+ const purpose =
194
+ address.toLowerCase() === tenant.primaryAddress.toLowerCase()
195
+ ? KeyPurposes.DLT_TRANSACTIONS
196
+ : KeyPurposes.REVOCATIONS_FALLBACK;
197
+
198
+ const revocationRegistry = await getRevocationRegistry(
199
+ { dltOperatorKMSKeyId: tenantKeysByPurpose[purpose].keyId },
200
+ context
201
+ );
202
+ return revocationRegistry.setRevokedStatusSigned({
203
+ accountId: tenant.primaryAddress,
204
+ listId,
205
+ index,
206
+ caoDid: context.caoDid,
207
+ });
208
+ };
209
+
210
+ const transformToFinder = initTransformToFinder(await tableRegistry.offers());
211
+
212
+ const getPushDelegate = async (offer, context) => {
213
+ const { repos } = context;
214
+
215
+ const exchange = await repos.exchanges.findOne({
216
+ filter: {
217
+ finalizedOfferIds: offer._id,
218
+ },
219
+ });
220
+
221
+ return {
222
+ pushToken: exchange?.pushDelegate?.pushToken,
223
+ pushUrl: exchange?.pushDelegate?.pushUrl,
224
+ exchange,
225
+ };
226
+ };
227
+ const triggerPush = async (
228
+ { offer, linkedOffer, message, pushToken },
229
+ context
230
+ ) => {
231
+ const { tenant } = context;
232
+ const notificationType = linkedOffer
233
+ ? 'CredentialReplaced'
234
+ : 'CredentialRevoked';
235
+ return sendPush(
236
+ {
237
+ id: nanoid(),
238
+ pushToken,
239
+ message,
240
+ data: {
241
+ exchangeId: offer.exchangeId,
242
+ notificationType,
243
+ replacementCredentialType: linkedOffer?.credentialType,
244
+ issuer: tenant.did,
245
+ credentialId: offer.did,
246
+ credentialTypes: offer.type,
247
+ count: 1,
248
+ },
249
+ },
250
+ context.exchange.pushDelegate,
251
+ context
252
+ );
253
+ };
254
+
255
+ const setRevokedTime = (credentialId, { repos }) =>
256
+ repos.offers.updateUsingFilter(
257
+ {
258
+ filter: {
259
+ did: credentialId,
260
+ },
261
+ },
262
+ {
263
+ 'credentialStatus.revokedAt': new Date(),
264
+ }
265
+ );
266
+
267
+ const setNotifiedTime = async (credentialId, offer, { repos }) =>
268
+ repos.offers.updateUsingFilter(
269
+ {
270
+ filter: {
271
+ did: credentialId,
272
+ },
273
+ },
274
+ {
275
+ notifiedOfRevocationAt: new Date(),
276
+ }
277
+ );
278
+ };
279
+
280
+ const buildIssuedCredential =
281
+ ({ config }) =>
282
+ (credential) => {
283
+ const issuedCredential = omitBy(
284
+ (v, k) => isNil(v) || k === 'issued',
285
+ credential
286
+ );
287
+ // eslint-disable-next-line better-mutation/no-mutation
288
+ issuedCredential.id = credential.did;
289
+
290
+ if (issuedCredential.issuanceDate == null) {
291
+ // eslint-disable-next-line better-mutation/no-mutation
292
+ issuedCredential.issuanceDate = credential.issued;
293
+ }
294
+
295
+ if (config.vendorCredentialsIncludeIssuedClaim) {
296
+ // eslint-disable-next-line better-mutation/no-mutation
297
+ issuedCredential.issued =
298
+ issuedCredential.issuanceDate ?? credential.issued;
299
+ }
300
+ return issuedCredential;
301
+ };
302
+
303
+ module.exports = issuedCredentialsController;
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Copyright 2023 Velocity Team
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ const revokeCredentialSchema = require('./revoke-credentials.schema.json');
18
+ const issuedCredentialSchema = require('./issued-credential.schema.json');
19
+
20
+ module.exports = {
21
+ revokeCredentialSchema,
22
+ issuedCredentialSchema,
23
+ };
@@ -0,0 +1,115 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/schema#",
3
+ "$id": "https://velocitycareerlabs.io/issued-credential.schema.json",
4
+ "type": "object",
5
+ "title": "issued-credential",
6
+ "description": "An issued credential is similar to an offer but has extra data generated by the agent",
7
+ "additionalProperties": false,
8
+ "allOf": [
9
+ {
10
+ "$ref": "https://velocitycareerlabs.io/new-vendor-offer.schema.json#"
11
+ },
12
+ {
13
+ "$ref": "mutable-entity#"
14
+ },
15
+ {
16
+ "type": "object",
17
+ "properties": {
18
+ "exchangeId": {
19
+ "type": "string"
20
+ },
21
+ "issuer": {
22
+ "type": "object",
23
+ "additionalProperties": false,
24
+ "properties": {
25
+ "id": {
26
+ "type": "string"
27
+ },
28
+ "name": {
29
+ "type": "string",
30
+ "description": "The name of brand"
31
+ },
32
+ "image": {
33
+ "type": "string",
34
+ "description": "The uri to image"
35
+ }
36
+ },
37
+ "required": [
38
+ "id"
39
+ ]
40
+ }
41
+ }
42
+ },
43
+ {
44
+ "type": "object",
45
+ "properties": {
46
+ "contentHash": {
47
+ "type": "object",
48
+ "additionalProperties": false,
49
+ "properties": {
50
+ "type": {
51
+ "type": "string"
52
+ },
53
+ "value": {
54
+ "type": "string"
55
+ }
56
+ },
57
+ "required": ["type", "value"]
58
+ },
59
+ "credentialStatus": {
60
+ "type": "object",
61
+ "properties": {
62
+ "id": {
63
+ "type": "string"
64
+ },
65
+ "linkCodeCommit": {
66
+ "type": "string"
67
+ },
68
+ "statusListCredential": {
69
+ "type": "string"
70
+ },
71
+ "statusListIndex": {
72
+ "type": "integer"
73
+ },
74
+ "type": {
75
+ "type": "string"
76
+ }
77
+ },
78
+ "required": ["type", "id"]
79
+ },
80
+ "credentialSchema": {
81
+ "type": "object",
82
+ "description": "Contains all the claims of the credential",
83
+ "properties": {
84
+ "type": {
85
+ "type": "string"
86
+ },
87
+ "id": {
88
+ "type": "string",
89
+ "format": "uri"
90
+ }
91
+ },
92
+ "required": ["type", "id"]
93
+ },
94
+ "issued": {
95
+ "type": "string",
96
+ "format": "date-time",
97
+ "deprecated": true,
98
+ "description": "issued is deprecated for issuanceDate"
99
+ },
100
+ "issuanceDate": {
101
+ "type": "string",
102
+ "format": "date-time"
103
+ }
104
+ }
105
+ }
106
+ ],
107
+ "required": [
108
+ "type",
109
+ "credentialSubject",
110
+ "id",
111
+ "exchangeId",
112
+ "issuer",
113
+ "contentHash"
114
+ ]
115
+ }
@@ -0,0 +1,18 @@
1
+ {
2
+ "$schema": "http://json-schema.org/draft-07/schema#",
3
+ "$id": "https://velocitycareerlabs.io/revoke-credentials.schema.json",
4
+ "type": "object",
5
+ "title": "revoke credentials schema",
6
+ "description": "Payload schema for calling revoke credentials API",
7
+ "additionalProperties": false,
8
+ "properties": {
9
+ "message": { "type": "string" },
10
+ "linkedOffer": {
11
+ "type": "object",
12
+ "properties": {
13
+ "credentialType": { "type": "string" }
14
+ },
15
+ "required": ["credentialType"]
16
+ }
17
+ }
18
+ }
@@ -0,0 +1,168 @@
1
+ /**
2
+ * Copyright 2023 Velocity Team
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ const { isEmpty, some, map } = require('lodash/fp');
18
+ const newError = require('http-errors');
19
+ const { KeyPurposes } = require('@verii/crypto');
20
+ const { resolveDid } = require('@verii/common-fetchers');
21
+
22
+ const {
23
+ addPrimaryAddressToTenant,
24
+ KeyEncodings,
25
+ validateDidDocKeys,
26
+ } = require('../../../../../entities');
27
+
28
+ const buildDuplicateKeyErrorString = (key, existingKey) => {
29
+ if (key.kidFragment === existingKey.kidFragment) {
30
+ return `Key with kidFragment ${key.kidFragment} already exists`;
31
+ }
32
+ return `Key with a purpose from ${JSON.stringify(
33
+ key.purposes
34
+ )} already exists`;
35
+ };
36
+
37
+ const keysController = async (fastify) => {
38
+ fastify.get(
39
+ '/',
40
+ {
41
+ schema: fastify.autoSchema({
42
+ response: {
43
+ 200: {
44
+ type: 'array',
45
+ items: {
46
+ $ref: 'https://velocitycareerlabs.io/tenant-key-v0.8.schema.json#',
47
+ },
48
+ },
49
+ },
50
+ }),
51
+ },
52
+ async (req) => {
53
+ const { repos, tenant } = req;
54
+ const keys = await repos.keys.find(
55
+ { filter: { tenantId: tenant._id }, sort: { _id: 1 } },
56
+ {
57
+ _id: 1,
58
+ purposes: 1,
59
+ algorithm: 1,
60
+ encoding: 1,
61
+ kidFragment: 1,
62
+ createdAt: 1,
63
+ }
64
+ );
65
+ return map(
66
+ (key) => ({
67
+ ...key,
68
+ encoding: KeyEncodings.HEX,
69
+ }),
70
+ keys
71
+ );
72
+ }
73
+ );
74
+
75
+ fastify.post(
76
+ '/',
77
+ {
78
+ schema: fastify.autoSchema({
79
+ body: {
80
+ $ref: 'https://velocitycareerlabs.io/secret-tenant-key-v0.8.schema.json#',
81
+ },
82
+ response: {
83
+ 201: {
84
+ $ref: 'https://velocitycareerlabs.io/tenant-key-v0.8.schema.json#',
85
+ },
86
+ 409: { $ref: 'error#' },
87
+ },
88
+ }),
89
+ },
90
+ async (req, reply) => {
91
+ const { body, repos, tenant, kms } = req;
92
+
93
+ const preexistingTenantKey = await repos.keys.findOne({
94
+ filter: {
95
+ tenantId: tenant._id,
96
+ $or: [
97
+ {
98
+ purposes: { $elemMatch: { $in: body.purposes } },
99
+ },
100
+ {
101
+ kidFragment: body.kidFragment,
102
+ },
103
+ ],
104
+ },
105
+ });
106
+
107
+ if (!isEmpty(preexistingTenantKey)) {
108
+ throw newError(
109
+ 409,
110
+ buildDuplicateKeyErrorString(body, preexistingTenantKey)
111
+ );
112
+ }
113
+
114
+ const organizationDidDoc = await resolveDid(tenant.did, req);
115
+ const [validatedKey] = await validateDidDocKeys(organizationDidDoc, [
116
+ body,
117
+ ]);
118
+
119
+ const key = await kms.importKey({
120
+ ...validatedKey,
121
+ encoding: KeyEncodings.JWK,
122
+ tenantId: tenant._id,
123
+ });
124
+
125
+ if (
126
+ !tenant.primaryAddress &&
127
+ some((p) => p === KeyPurposes.DLT_TRANSACTIONS, key.purposes)
128
+ ) {
129
+ await addPrimaryAddressToTenant(tenant, req);
130
+ }
131
+
132
+ reply.code(201);
133
+ return { ...key, encoding: KeyEncodings.HEX };
134
+ }
135
+ );
136
+
137
+ fastify.delete(
138
+ '/:kidFragment',
139
+ {
140
+ schema: fastify.autoSchema({
141
+ params: {
142
+ type: 'object',
143
+ properties: {
144
+ ...fastify.currentAutoSchemaPreset.params.properties,
145
+ kidFragment: { type: 'string', minLength: 1 },
146
+ },
147
+ },
148
+ response: { 204: { type: 'null', description: 'No Content' } },
149
+ }),
150
+ },
151
+ async ({ params, repos, tenant }, reply) => {
152
+ const { kidFragment } = params;
153
+ const result = await repos.keys.delUsingFilter({
154
+ filter: { kidFragment, tenantId: tenant._id },
155
+ });
156
+
157
+ if (isEmpty(result)) {
158
+ const kid = `${tenant.did}${kidFragment}`;
159
+ throw newError.NotFound(`kid: ${kid} not found on tenant`);
160
+ }
161
+
162
+ reply.code(204);
163
+ return null;
164
+ }
165
+ );
166
+ };
167
+
168
+ module.exports = keysController;
@@ -0,0 +1,78 @@
1
+ // eslint-disable-next-line import/no-extraneous-dependencies
2
+ const { parseToCsv } = require('@verii/csv-parser');
3
+ const { csvResponseHook } = require('@verii/fastify-plugins');
4
+ const { toStartOfDay, toEndOfDay } = require('@verii/rest-queries');
5
+
6
+ const offerDataController = async (fastify) => {
7
+ fastify.get(
8
+ '/',
9
+ {
10
+ onSend: csvResponseHook('get-offers.csv'),
11
+ schema: fastify.autoSchema({
12
+ querystring: {
13
+ type: 'object',
14
+ properties: {
15
+ StartDate: { type: 'string', format: 'date' },
16
+ EndDate: { type: 'string', format: 'date' },
17
+ claimed: { type: 'boolean' },
18
+ },
19
+ required: ['StartDate', 'EndDate'],
20
+ },
21
+ response: {
22
+ 200: { content: { 'text/csv': { schema: { type: 'null' } } } },
23
+ },
24
+ }),
25
+ },
26
+ async ({ repos, query }) => {
27
+ const offers = await repos.offers.find(
28
+ {
29
+ filter: buildOfferFilter(query),
30
+ limit: Number.MAX_SAFE_INTEGER,
31
+ sort: { createdAt: 1 },
32
+ },
33
+ {
34
+ did: 1,
35
+ type: 1,
36
+ credentialSubject: 1,
37
+ offerId: 1,
38
+ consentedAt: 1,
39
+ createdAt: 1,
40
+ credentialStatus: 1,
41
+ issuer: 1,
42
+ }
43
+ );
44
+
45
+ if (offers.length === 0) {
46
+ return '';
47
+ }
48
+
49
+ return parseToCsv(
50
+ offers.map((offer) => ({
51
+ '1. Offer Accepted': offer.did,
52
+ '2. User': offer.credentialSubject?.vendorUserId,
53
+ '3. Offer ID': offer.offerId,
54
+ '4. Credential Type': offer.type[0],
55
+ '5. Offer Creation Date': offer.createdAt,
56
+ '6. Offer Claim Date': offer.consentedAt,
57
+ '7. Revocation Status': offer.credentialStatus?.revokedAt,
58
+ '8. Issuer ID': offer.issuer.id,
59
+ }))
60
+ );
61
+ }
62
+ );
63
+ };
64
+
65
+ const buildOfferFilter = (query) => {
66
+ const filter = {
67
+ createdAt: {
68
+ $gte: toStartOfDay(query.StartDate),
69
+ $lte: toEndOfDay(query.EndDate),
70
+ },
71
+ };
72
+ if (query.claimed === true) {
73
+ filter.consentedAt = { $exists: true };
74
+ }
75
+ return filter;
76
+ };
77
+
78
+ module.exports = offerDataController;