@velocitycareerlabs/server-careerwallet 1.25.0-dev-build.12642c864

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 (252) hide show
  1. package/.localdev.env +47 -0
  2. package/.standalone.env +13 -0
  3. package/LICENSE +248 -0
  4. package/jest.config.js +20 -0
  5. package/migrate-mongo.config.js +25 -0
  6. package/migrations/20211017180227-create-personas.js +478 -0
  7. package/migrations/20211026185916-create-vanessa.js +79 -0
  8. package/migrations/20211026185917-update-personas.js +30 -0
  9. package/migrations/20211108124410-remove-surplus-personas.js +33 -0
  10. package/migrations/20211108132353-fix-vanessa-and-sheila.js +25 -0
  11. package/migrations/20220222123110-add-career-wallet-app-config.js +6 -0
  12. package/migrations/20220411104157-add-min-app-versions.js +15 -0
  13. package/migrations/20220419131726-create-nicole-flores-persona.js +63 -0
  14. package/migrations/20220515114034-update-persona-id-credentials.js +628 -0
  15. package/migrations/20220608093743-disable-mainnet-holderapp-id-verification.js +21 -0
  16. package/migrations/20220609063708-enable-mainnet-holderapp-id-verification.js +21 -0
  17. package/migrations/20220623091507-add-push-url.js +43 -0
  18. package/migrations/20220624133205-set-min-app-versions-to-11.js +16 -0
  19. package/migrations/20220710125326-set-min-app-version-to-0.10.7.js +16 -0
  20. package/migrations/20220811103500-add-verification-service-disclosure-deeplink.js +45 -0
  21. package/migrations/20220811123751-add-holderapp-dids-to-config.js +74 -0
  22. package/migrations/20220818072306-add-holderapp-endpoints-to-config.js +21 -0
  23. package/migrations/20220825090656-update-deeplink.js +46 -0
  24. package/migrations/20221003151823-app-config-add-public-verification-api.js +18 -0
  25. package/migrations/20221116085242-add-holderapp-sdk-to-config.js +15 -0
  26. package/migrations/20221121091030-update-holderapp-deeplink.js +19 -0
  27. package/migrations/20221128103425-update-holderapp-presentation-template.js +19 -0
  28. package/migrations/20221221091436-app-config-add-oauth.js +13 -0
  29. package/migrations/20221226205900-app-config-add-presentation-extension-api.js +18 -0
  30. package/migrations/20230120113141-update-holderapp-cashSiquence.js +15 -0
  31. package/migrations/20230123084103-update-holderapp-cacheSequence.js +15 -0
  32. package/migrations/20230214083430-update-holderapp-cache-Sequence.js +15 -0
  33. package/migrations/20230225173335-set-min-app-version-1.5.1.js +30 -0
  34. package/migrations/20230323120629-add-sunil-singh-persona.js +87 -0
  35. package/migrations/20230329081529-add-personas-by-env.js +294 -0
  36. package/migrations/20230329103219-remove-unused-personas.js +14 -0
  37. package/migrations/20230504090208-disable-yoti-migration.js +21 -0
  38. package/migrations/20230504123425-set-min-app-version-1.8.1.js +38 -0
  39. package/migrations/20230504185047-enable-yoti-migration.js +21 -0
  40. package/migrations/20230524053203-add-devices-index.js +16 -0
  41. package/migrations/20230704000002-add-common-holder-endpoints-to-config.js +16 -0
  42. package/migrations/20230704000003-add-linkedin-holder-endpoints-to-config.js +18 -0
  43. package/migrations/20230704104055-update-push-url-and-yoti-url.js +18 -0
  44. package/migrations/20230705000001-add-liburl-to-holderapp-config.js +20 -0
  45. package/migrations/20230814113134-app-config-add-oauth-client-id.js +18 -0
  46. package/migrations/20230821154136-yoti-new-session-url-fix.js +19 -0
  47. package/migrations/20230907134442-update-holderapp-cache-Sequence.js +15 -0
  48. package/migrations/20230919180000-set-holderapp-min-app-versions-1.15.0.js +16 -0
  49. package/migrations/20231011083137-update-holderapp-cache-sequence-6.js +15 -0
  50. package/migrations/20231102083252-set-holderapp-min-app-versions-1.14.0.js +16 -0
  51. package/migrations/20231108202229-set-holderapp-min-app-versions-1.15.0.js +16 -0
  52. package/migrations/20231115143332-holderapp-isDirectIssuerCheckOn-true.js +16 -0
  53. package/migrations/20231120100020-insert-didKeyMetadatum-for-old-accounts.js +59 -0
  54. package/migrations/20231207142742-remove-devices-from-accounts.js +46 -0
  55. package/migrations/20231226090805-app-config-set-direct-issuer-check.js +13 -0
  56. package/migrations/202312271524-set-holderapp-app-version-1.15.1.js +16 -0
  57. package/migrations/20232211171700-app-config-update-base-urls.js +18 -0
  58. package/migrations/20240102093506-holderapp-revert-version-1.15.0.js +16 -0
  59. package/migrations/202401041618111-holderapp-isDebugOn-false.js +17 -0
  60. package/migrations/20240131095122-test-personas-add-did.js +102 -0
  61. package/migrations/202402051547000-update-sdk.js +18 -0
  62. package/migrations/20240206101448-update-personas-vc-to-v2.js +137 -0
  63. package/migrations/202402061233000-set-xVnfProtocolVersion-2.js +13 -0
  64. package/migrations/202402081240000-set-xVnfProtocolVersion-1.js +13 -0
  65. package/migrations/202402131319-set-holderapp-min-versions-1.17.js +16 -0
  66. package/migrations/202402141152-set-holderapp-min-version-1.16.js +16 -0
  67. package/migrations/20240221123501-transform-account-keys-to-stringified-jwk.js +81 -0
  68. package/migrations/202402290955-update-holderapp-to-verifyMyCreds.js +36 -0
  69. package/migrations/20240311134223-update-keyid-persona.js +66 -0
  70. package/migrations/20240312141618-vl-7409-persona-update-maria-williams.js +82 -0
  71. package/migrations/202403181733000-remove-devices-from-all-accounts.js +27 -0
  72. package/migrations/20240401091041-set-holderapp-min-version-1.18.1.js +16 -0
  73. package/migrations/202404071847-app-config-update-yoti-url.js +19 -0
  74. package/migrations/20240724063405-vl-3827-new-yoti-session-url.js +19 -0
  75. package/migrations/20240731112302-vl-8160-add-persona-keys.js +101 -0
  76. package/migrations/20240911115206-vanessa-lin-id-credentials.js +57 -0
  77. package/migrations/202409201219-add-isWalletAvailable-field.js +13 -0
  78. package/migrations/202409221012-set-isWalletAvailable-true.js +13 -0
  79. package/migrations/20240922114643-holderapp-isWalletAvailable-refactor.js +36 -0
  80. package/migrations/20240923132213-update-android-ios-app-config.js +36 -0
  81. package/migrations/20240926061732-inc-cacheSequence-to-7.js +15 -0
  82. package/migrations/20240926073339-inc-cacheSequence-to-7-fix.js +18 -0
  83. package/migrations/202410081217-adam-smith-id-credntials.js +57 -0
  84. package/migrations/202410101243-adam_smith-id-credential.js +57 -0
  85. package/migrations/20241015124307-persona-key-id-type-fix.js +26 -0
  86. package/migrations/202501291027000-set-holderapp-did-web.js +37 -0
  87. package/migrations/environments/dev.env +34 -0
  88. package/migrations/environments/localdev.env +22 -0
  89. package/migrations/environments/prod.env +18 -0
  90. package/migrations/environments/qa.env +54 -0
  91. package/migrations/environments/staging.env +31 -0
  92. package/migrations/environments/test.env +18 -0
  93. package/package.json +84 -0
  94. package/src/assets/category-icons/assessment.png +0 -0
  95. package/src/assets/category-icons/badge.png +0 -0
  96. package/src/assets/category-icons/certification.png +0 -0
  97. package/src/assets/category-icons/education.png +0 -0
  98. package/src/assets/category-icons/employment.png +0 -0
  99. package/src/assets/category-icons/gig.png +0 -0
  100. package/src/assets/category-icons/identity.png +0 -0
  101. package/src/assets/category-icons/pharmacy.png +0 -0
  102. package/src/assets/category-icons/training.png +0 -0
  103. package/src/assets/credentialCategories.json +119 -0
  104. package/src/config/config.js +156 -0
  105. package/src/controllers/api/v0.6/accounts/autohooks.js +36 -0
  106. package/src/controllers/api/v0.6/accounts/controller.js +288 -0
  107. package/src/controllers/api/v0.6/accounts/schemas/careerwallet-accounts-didkeymetadatum-response.schema.js +41 -0
  108. package/src/controllers/api/v0.6/accounts/schemas/careerwallet-accounts-request.schema.js +49 -0
  109. package/src/controllers/api/v0.6/accounts/schemas/careerwallet-accounts-response.schema.js +74 -0
  110. package/src/controllers/api/v0.6/accounts/schemas/careerwallet-get-account-response.schema.js +72 -0
  111. package/src/controllers/api/v0.6/accounts/schemas/index.js +6 -0
  112. package/src/controllers/api/v0.6/careerwallet/appconfig/controller.js +25 -0
  113. package/src/controllers/api/v0.6/careerwallet/appconfig/repo.js +40 -0
  114. package/src/controllers/api/v0.6/careerwallet/autohooks.js +5 -0
  115. package/src/controllers/api/v0.6/careerwallet/consents/controller.js +66 -0
  116. package/src/controllers/api/v0.6/careerwallet/consents/latest/autohooks.js +7 -0
  117. package/src/controllers/api/v0.6/careerwallet/consents/latest/controller.js +76 -0
  118. package/src/controllers/api/v0.6/careerwallet/consents/repo.js +24 -0
  119. package/src/controllers/api/v0.6/careerwallet/consents/schemas/careerwallet-consent-response.schema.js +23 -0
  120. package/src/controllers/api/v0.6/careerwallet/consents/schemas/index.js +3 -0
  121. package/src/controllers/api/v0.6/create_did_key/autohooks.js +10 -0
  122. package/src/controllers/api/v0.6/create_did_key/controller.js +84 -0
  123. package/src/controllers/api/v0.6/create_did_key/schemas/index.js +4 -0
  124. package/src/controllers/api/v0.6/create_did_key/schemas/jwk-did-request.schema.js +20 -0
  125. package/src/controllers/api/v0.6/create_did_key/schemas/jwk-did-response.schema.js +41 -0
  126. package/src/controllers/api/v0.6/create_jwk/autohooks.js +10 -0
  127. package/src/controllers/api/v0.6/create_jwk/controller.js +46 -0
  128. package/src/controllers/api/v0.6/create_jwk/schemas/index.js +3 -0
  129. package/src/controllers/api/v0.6/create_jwk/schemas/jwk-response.schema.js +33 -0
  130. package/src/controllers/api/v0.6/credential-categories/controller.js +35 -0
  131. package/src/controllers/api/v0.6/devices/autohooks.js +11 -0
  132. package/src/controllers/api/v0.6/devices/controller.js +323 -0
  133. package/src/controllers/api/v0.6/devices/repo.js +27 -0
  134. package/src/controllers/api/v0.6/devices/schemas/device.schema.json +43 -0
  135. package/src/controllers/api/v0.6/devices/schemas/index.js +3 -0
  136. package/src/controllers/api/v0.6/feedback/controller.js +24 -0
  137. package/src/controllers/api/v0.6/feedback/schemas/index.js +3 -0
  138. package/src/controllers/api/v0.6/feedback/schemas/new-feedback.schema.js +47 -0
  139. package/src/controllers/api/v0.6/jwt/autohooks.js +10 -0
  140. package/src/controllers/api/v0.6/jwt/controller.js +44 -0
  141. package/src/controllers/api/v0.6/jwt/schemas/index.js +4 -0
  142. package/src/controllers/api/v0.6/jwt/schemas/jwt-request.schema.js +40 -0
  143. package/src/controllers/api/v0.6/jwt/schemas/jwt-response.schema.js +14 -0
  144. package/src/controllers/api/v0.6/oauth/controller.js +131 -0
  145. package/src/controllers/api/v0.6/push/controller.js +296 -0
  146. package/src/controllers/api/v0.6/push/firebase-initializer.js +21 -0
  147. package/src/controllers/api/v0.6/push/notification-types.js +37 -0
  148. package/src/controllers/api/v0.6/push/push-gateway-auth.js +123 -0
  149. package/src/controllers/api/v0.6/push/repo.js +24 -0
  150. package/src/controllers/api/v0.6/verification-offers/repo.js +25 -0
  151. package/src/controllers/api/v0.6/verify/autohooks.js +15 -0
  152. package/src/controllers/api/v0.6/verify/controller.js +348 -0
  153. package/src/controllers/api/v0.6/verify/repo.js +23 -0
  154. package/src/controllers/api/v0.6/verify/verification-credential-types.js +6 -0
  155. package/src/controllers/jwt/autohooks.js +10 -0
  156. package/src/controllers/jwt/controller.js +106 -0
  157. package/src/controllers/jwt/schemas/index.js +31 -0
  158. package/src/controllers/jwt/schemas/jwt-decode.response.200.schema.json +20 -0
  159. package/src/controllers/jwt/schemas/jwt-decode.schema.json +15 -0
  160. package/src/controllers/jwt/schemas/jwt-sign.response.200.schema.json +14 -0
  161. package/src/controllers/jwt/schemas/jwt-sign.schema.json +40 -0
  162. package/src/controllers/jwt/schemas/jwt-verify.response.200.schema.json +17 -0
  163. package/src/controllers/jwt/schemas/jwt-verify.schema.json +19 -0
  164. package/src/controllers/reference/autohooks.js +5 -0
  165. package/src/controllers/reference/countries/controller.js +81 -0
  166. package/src/controllers/reference/personas/controller.js +91 -0
  167. package/src/controllers/reference/personas/repo.js +29 -0
  168. package/src/controllers/reference/personas/schemas/index.js +3 -0
  169. package/src/controllers/reference/personas/schemas/persona.schema.json +108 -0
  170. package/src/controllers/root/controller.js +27 -0
  171. package/src/entities/accounts/constants.js +18 -0
  172. package/src/entities/accounts/domain/index.js +3 -0
  173. package/src/entities/accounts/domain/merge-scopes.js +9 -0
  174. package/src/entities/accounts/index.js +5 -0
  175. package/src/entities/accounts/repos/accounts.repo.js +64 -0
  176. package/src/entities/accounts/repos/id-token-claims-extension.js +31 -0
  177. package/src/entities/accounts/repos/index.js +3 -0
  178. package/src/entities/devices/constants.js +7 -0
  179. package/src/entities/devices/index.js +3 -0
  180. package/src/entities/feedback/domain/generate-feedback-email.js +23 -0
  181. package/src/entities/feedback/domain/index.js +3 -0
  182. package/src/entities/feedback/index.js +3 -0
  183. package/src/entities/index.js +9 -0
  184. package/src/entities/key-pairs/index.js +4 -0
  185. package/src/entities/key-pairs/orchestrators/generate-jwk.js +28 -0
  186. package/src/entities/key-pairs/orchestrators/get-key-pair.js +58 -0
  187. package/src/entities/key-pairs/orchestrators/index.js +4 -0
  188. package/src/entities/key-pairs/repos/index.js +3 -0
  189. package/src/entities/key-pairs/repos/key-pairs.repo.js +23 -0
  190. package/src/entities/oauth/constants.js +13 -0
  191. package/src/entities/oauth/domain/build-access-token.js +14 -0
  192. package/src/entities/oauth/domain/index.js +10 -0
  193. package/src/entities/oauth/domain/validate-audience.js +13 -0
  194. package/src/entities/oauth/domain/validate-client-id.js +13 -0
  195. package/src/entities/oauth/domain/validate-credential.js +16 -0
  196. package/src/entities/oauth/domain/validate-presentation.js +17 -0
  197. package/src/entities/oauth/domain/validate-refresh-token.js +17 -0
  198. package/src/entities/oauth/domain/validate-scope.js +30 -0
  199. package/src/entities/oauth/domain/verify-presentation.js +24 -0
  200. package/src/entities/oauth/index.js +4 -0
  201. package/src/entities/pushes/domains/errors.js +11 -0
  202. package/src/entities/pushes/domains/index.js +3 -0
  203. package/src/entities/pushes/index.js +3 -0
  204. package/src/entities/verification-code-attempts/index.js +3 -0
  205. package/src/entities/verification-code-attempts/orchestrators/index.js +3 -0
  206. package/src/entities/verification-code-attempts/orchestrators/validate-verification-code-attempts.js +79 -0
  207. package/src/entities/verification-code-attempts/repo.js +99 -0
  208. package/src/entities/verifications/constants.js +8 -0
  209. package/src/entities/verifications/index.js +3 -0
  210. package/src/helpers/caching-constants.js +6 -0
  211. package/src/helpers/index.js +3 -0
  212. package/src/index.js +15 -0
  213. package/src/init-server.js +88 -0
  214. package/src/plugins/index.js +4 -0
  215. package/src/plugins/vcl-verification-version-plugin.js +10 -0
  216. package/src/plugins/verify-access-token-plugin.js +116 -0
  217. package/src/standalone.js +8 -0
  218. package/test/accounts-controller.test.js +893 -0
  219. package/test/accounts-repo.test.js +92 -0
  220. package/test/careerwallet-config-controller.test.js +142 -0
  221. package/test/careerwallet-consents-controller.test.js +409 -0
  222. package/test/create_did_key-controller.test.js +397 -0
  223. package/test/create_jwk-controller.test.js +188 -0
  224. package/test/credential-categories-controller.test.js +29 -0
  225. package/test/credential-icons-controller.test.js +36 -0
  226. package/test/devices-controller.test.js +1025 -0
  227. package/test/factories/accounts-factory.js +15 -0
  228. package/test/factories/career-wallet-config-factory.js +60 -0
  229. package/test/factories/consents-career-wallet-factory.js +21 -0
  230. package/test/factories/devices-factory.js +16 -0
  231. package/test/factories/key-pairs-factory.js +18 -0
  232. package/test/factories/notifications-factory.js +16 -0
  233. package/test/factories/persona-factory.js +17 -0
  234. package/test/factories/refresh-tokens-factory.js +14 -0
  235. package/test/factories/verification-code-attempts-factory.js +17 -0
  236. package/test/factories/verification-factory.js +15 -0
  237. package/test/factories/verification-offer-factory.js +20 -0
  238. package/test/feedback-controller.test.js +225 -0
  239. package/test/helpers/.env.test +39 -0
  240. package/test/helpers/access-token.js +59 -0
  241. package/test/helpers/careerwallet-build-fastify.js +20 -0
  242. package/test/helpers/yoti.js +96 -0
  243. package/test/id-verification-controller.test.js +27 -0
  244. package/test/jwt-controller.test.js +1519 -0
  245. package/test/oauth-controller.test.js +639 -0
  246. package/test/push-controller.test.js +733 -0
  247. package/test/push-gateway-auth.test.js +208 -0
  248. package/test/reference-countries-controller.test.js +45 -0
  249. package/test/reference-personas-controller.test.js +179 -0
  250. package/test/root.test.js +21 -0
  251. package/test/swagger.test.js +21 -0
  252. package/test/verification-controller.test.js +1372 -0
@@ -0,0 +1,66 @@
1
+ const env = require('env-var');
2
+ const { map, isString, isEmpty } = require('lodash/fp');
3
+ const { ObjectId } = require('mongodb');
4
+
5
+ module.exports = {
6
+ up: async (db) => {
7
+ const isCi = env.get('IS_CI').default('false').asBool();
8
+
9
+ if (isCi) {
10
+ return;
11
+ }
12
+
13
+ const accounts = await db
14
+ .collection('accounts')
15
+ .find({ 'didKeyMetadatum.keyId': { $type: 'string' } })
16
+ .toArray();
17
+
18
+ const personas = await db
19
+ .collection('personas')
20
+ .find({ keyId: { $exists: true } })
21
+ .toArray();
22
+
23
+ const personaUpdates = map(
24
+ (persona) => ({
25
+ updateOne: {
26
+ filter: { _id: persona._id },
27
+ update: {
28
+ $set: {
29
+ keyId: new ObjectId(persona.keyId),
30
+ },
31
+ },
32
+ },
33
+ }),
34
+ personas
35
+ );
36
+
37
+ const accountUpdates = map(
38
+ (account) => ({
39
+ updateOne: {
40
+ filter: { _id: account._id },
41
+ update: {
42
+ $set: {
43
+ didKeyMetadatum: map(
44
+ (keyMetadatum) => ({
45
+ ...keyMetadatum,
46
+ keyId: isString(keyMetadatum.keyId)
47
+ ? new ObjectId(keyMetadatum.keyId)
48
+ : keyMetadatum.keyId,
49
+ }),
50
+ account.didKeyMetadatum
51
+ ),
52
+ },
53
+ },
54
+ },
55
+ }),
56
+ accounts
57
+ );
58
+
59
+ if (!isEmpty(personaUpdates)) {
60
+ await db.collection('personas').bulkWrite(personaUpdates);
61
+ }
62
+ if (!isEmpty(accountUpdates)) {
63
+ await db.collection('accounts').bulkWrite(accountUpdates);
64
+ }
65
+ },
66
+ };
@@ -0,0 +1,82 @@
1
+ const { exec } = require('child_process');
2
+ const env = require('env-var');
3
+ const console = require('console');
4
+
5
+ const getBranch = () =>
6
+ new Promise((resolve, reject) => {
7
+ return exec('git rev-parse --abbrev-ref HEAD', (err, stdout) => {
8
+ if (err) reject(new Error(`getBranch Error: ${err}`));
9
+ else if (typeof stdout === 'string') resolve(stdout.trim());
10
+ });
11
+ });
12
+
13
+ const getEnvValues = () => {
14
+ const isCi = env.get('IS_CI').default('false').asBool();
15
+ const personaCredentialEmail = env
16
+ .get('PERSONA_MARIA_WILLIAMS_CREDENTIAL_EMAIL')
17
+ .required(!isCi)
18
+ .asString();
19
+ const personaCredentialPhone = env
20
+ .get('PERSONA_MARIA_WILLIAMS_CREDENTIAL_PHONE')
21
+ .required(!isCi)
22
+ .asString();
23
+ const personaCredentialId = env
24
+ .get('PERSONA_MARIA_WILLIAMS_CREDENTIAL_PASSPORT')
25
+ .required(!isCi)
26
+ .asString();
27
+ return {
28
+ personaCredentialEmail,
29
+ personaCredentialPhone,
30
+ personaCredentialId,
31
+ };
32
+ };
33
+ module.exports = {
34
+ up: async (db) => {
35
+ const personaName = 'Maria Williams';
36
+ const personaEmail = 'maria.williams@example.com';
37
+ const branchName = await getBranch();
38
+ if (
39
+ branchName === 'master' ||
40
+ env.get('IGNORE_PERSONAS').default('false').asBool()
41
+ ) {
42
+ console.log(`skipping creating ${personaName} in production`);
43
+ return undefined;
44
+ }
45
+ const {
46
+ personaCredentialEmail,
47
+ personaCredentialPhone,
48
+ personaCredentialId,
49
+ } = getEnvValues();
50
+
51
+ const setDoc = {
52
+ vcs: [
53
+ {
54
+ type: ['PassportV1.0'],
55
+ jwt_vc: personaCredentialId,
56
+ },
57
+ {
58
+ type: ['EmailV1.0'],
59
+ jwt_vc: personaCredentialEmail,
60
+ },
61
+ {
62
+ type: ['PhoneV1.0'],
63
+ jwt_vc: personaCredentialPhone,
64
+ },
65
+ ],
66
+ };
67
+
68
+ console.log(`Updating ${personaName} persona`);
69
+
70
+ const now = new Date();
71
+ const filterDoc = {
72
+ email: personaEmail,
73
+ name: personaName,
74
+ };
75
+ const updateDoc = {
76
+ $set: { ...setDoc, updatedAt: now },
77
+ };
78
+ return db.collection('personas').updateOne(filterDoc, updateDoc);
79
+ },
80
+
81
+ down: async () => {},
82
+ };
@@ -0,0 +1,27 @@
1
+ module.exports = {
2
+ up: async (db) => {
3
+ const accountsCollection = db.collection('accounts');
4
+ const accounts = await accountsCollection.find().toArray();
5
+
6
+ const accountUpdates = [];
7
+
8
+ accounts.forEach((account) => {
9
+ if (account.devices) {
10
+ const accountUpdate = {
11
+ updateOne: {
12
+ filter: { _id: account._id },
13
+ update: { $unset: { devices: '' } },
14
+ },
15
+ };
16
+ // eslint-disable-next-line better-mutation/no-mutating-methods
17
+ accountUpdates.push(accountUpdate);
18
+ }
19
+ });
20
+
21
+ if (accountUpdates.length > 0) {
22
+ await accountsCollection.bulkWrite(accountUpdates);
23
+ }
24
+ },
25
+
26
+ down: async () => {},
27
+ };
@@ -0,0 +1,16 @@
1
+ module.exports = {
2
+ up: async (db) => {
3
+ await db.collection('careerWalletConfigs').updateOne(
4
+ {},
5
+ {
6
+ $set: {
7
+ minIOSVersion: '1.18.1',
8
+ minAndroidVersion: '1.18.1',
9
+ latestIOSVersion: '1.18.1',
10
+ latestAndroidVersion: '1.18.1',
11
+ },
12
+ }
13
+ );
14
+ },
15
+ down: async () => {},
16
+ };
@@ -0,0 +1,19 @@
1
+ const env = require('env-var');
2
+
3
+ const yotiNewSessionUrl = env
4
+ .get('YOTI_NEW_SESSION_URL')
5
+ .required(true)
6
+ .asString();
7
+ module.exports = {
8
+ up: async (db) => {
9
+ await db.collection('careerWalletConfigs').updateOne(
10
+ {},
11
+ {
12
+ $set: {
13
+ yotiNewSessionUrl,
14
+ },
15
+ }
16
+ );
17
+ },
18
+ down: async () => {},
19
+ };
@@ -0,0 +1,19 @@
1
+ const env = require('env-var');
2
+
3
+ const yotiNewSessionUrl = env
4
+ .get('YOTI_NEW_SESSION_URL')
5
+ .required(true)
6
+ .asString();
7
+ module.exports = {
8
+ up: async (db) => {
9
+ await db.collection('careerWalletConfigs').updateOne(
10
+ {},
11
+ {
12
+ $set: {
13
+ yotiNewSessionUrl,
14
+ },
15
+ }
16
+ );
17
+ },
18
+ down: async () => {},
19
+ };
@@ -0,0 +1,101 @@
1
+ const { initKmsClient } = require('@velocitycareerlabs/aws-clients');
2
+ const { generateKeyPair } = require('@velocitycareerlabs/crypto');
3
+ const { getDidUriFromJwk } = require('@velocitycareerlabs/did-doc');
4
+ const env = require('env-var');
5
+ const { map } = require('lodash/fp');
6
+ const { stringifyJwk } = require('@velocitycareerlabs/jwt');
7
+
8
+ const createContext = ({ db }) => {
9
+ const awsKmsClient = initKmsClient({
10
+ awsRegion: env.get('AWS_REGION').default('us-east-1').asString(),
11
+ awsEndpoint: env.get('AWS_ENDPOINT').default('').asString(),
12
+ });
13
+
14
+ return {
15
+ awsKmsClient,
16
+ managedAccountsKeyId: env
17
+ .get('MANAGED_ACCOUNTS_KEY_ID')
18
+ .required()
19
+ .asString(),
20
+ repos: {
21
+ personas: db.collection('personas'),
22
+ keyPairs: db.collection('keyPairs'),
23
+ },
24
+ };
25
+ };
26
+
27
+ const isCi = env.get('IS_CI').default('false').asBool();
28
+
29
+ module.exports = {
30
+ up: async (db) => {
31
+ if (isCi || env.get('IGNORE_PERSONAS').default('false').asBool()) {
32
+ return;
33
+ }
34
+
35
+ const context = createContext({ db });
36
+ const { repos } = context;
37
+
38
+ const personas = await repos.personas
39
+ .find({ did: { $exists: false } })
40
+ .toArray();
41
+
42
+ if (personas.length === 0) {
43
+ return;
44
+ }
45
+
46
+ const updates = await Promise.all(
47
+ map(async (persona) => {
48
+ const { publicKey, keyId } = await generateJwk('secp256k1', context);
49
+
50
+ const didJwk = getDidUriFromJwk(publicKey);
51
+
52
+ return {
53
+ updateOne: {
54
+ filter: { _id: persona._id },
55
+ update: {
56
+ $set: {
57
+ did: didJwk,
58
+ kid: `${didJwk}#0`,
59
+ publicJwk: publicKey,
60
+ keyId,
61
+ updatedAt: new Date(),
62
+ },
63
+ },
64
+ },
65
+ };
66
+ }, personas)
67
+ );
68
+
69
+ await repos.personas.bulkWrite(updates);
70
+ },
71
+ };
72
+
73
+ const generateJwk = async (curve, context) => {
74
+ const {
75
+ awsKmsClient,
76
+ repos: { keyPairs },
77
+ managedAccountsKeyId,
78
+ } = context;
79
+
80
+ const { privateKey, publicKey } = generateKeyPair({
81
+ curve,
82
+ format: 'jwk',
83
+ });
84
+
85
+ const { CiphertextBlob } = await awsKmsClient.encrypt(
86
+ managedAccountsKeyId,
87
+ stringifyJwk(privateKey)
88
+ );
89
+
90
+ const { insertedId } = await keyPairs.insertOne({
91
+ encryptedPrivateKey: CiphertextBlob,
92
+ publicKey,
93
+ createdAt: new Date(),
94
+ updatedAt: new Date(),
95
+ });
96
+
97
+ return {
98
+ publicKey,
99
+ keyId: insertedId.toString(),
100
+ };
101
+ };
@@ -0,0 +1,57 @@
1
+ /* eslint-disable */
2
+
3
+ const console = require('console');
4
+ const env = require('env-var');
5
+
6
+ const isCi = env.get('IS_CI').default('false').asBool();
7
+
8
+ module.exports = {
9
+ up: async (db) => {
10
+ if (env.get('MIGRATION_ENV').asString() === 'prod') {
11
+ console.log('skipping creating personas in production');
12
+ return;
13
+ }
14
+ if (env.get('IGNORE_PERSONAS').default('false').asBool()) {
15
+ console.log('IGNORE_PERSONAS: true, skipping personas migration');
16
+ return;
17
+ }
18
+
19
+ const personaVanessaLinCredentialPhone = env.get('PERSONA_VANESSA_LIN_CREDENTIAL_PHONE').required(!isCi).asString();
20
+ const personaVanessaLinCredentialEmail = env.get('PERSONA_VANESSA_LIN_CREDENTIAL_EMAIL').required(!isCi).asString();
21
+ const personaVanessaLinCredentialDriversLicense = env.get('PERSONA_VANESSA_LIN_CREDENTIAL_DRIVERS_LICENSE').required(!isCi).asString();
22
+
23
+ const now = new Date();
24
+
25
+ const filterDoc = {
26
+ email: 'vanessa.lin@example.com',
27
+ };
28
+ const updateDoc = {
29
+ $set: {
30
+ vcs: [
31
+ {
32
+ "type": [
33
+ "DriversLicenseV1.0"
34
+ ],
35
+ "jwt_vc": personaVanessaLinCredentialDriversLicense
36
+ },
37
+ {
38
+ "type": [
39
+ "EmailV1.0"
40
+ ],
41
+ "jwt_vc": personaVanessaLinCredentialEmail
42
+ },
43
+ {
44
+ "type": [
45
+ "PhoneV1.0"
46
+ ],
47
+ "jwt_vc": personaVanessaLinCredentialPhone
48
+ }
49
+ ],
50
+ updatedAt: now,
51
+ },
52
+ };
53
+ await db.collection('personas').updateOne(filterDoc, updateDoc)
54
+ },
55
+
56
+ down: async () => {},
57
+ };
@@ -0,0 +1,13 @@
1
+ module.exports = {
2
+ up: async (db) => {
3
+ await db.collection('careerWalletConfigs').updateOne(
4
+ {},
5
+ {
6
+ $set: {
7
+ isWalletAvailable: false,
8
+ },
9
+ }
10
+ );
11
+ },
12
+ down: async () => {},
13
+ };
@@ -0,0 +1,13 @@
1
+ module.exports = {
2
+ up: async (db) => {
3
+ await db.collection('careerWalletConfigs').updateOne(
4
+ {},
5
+ {
6
+ $set: {
7
+ isWalletAvailable: true,
8
+ },
9
+ }
10
+ );
11
+ },
12
+ down: async () => {},
13
+ };
@@ -0,0 +1,36 @@
1
+ const env = require('env-var');
2
+
3
+ const isCi = env.get('IS_CI').default('false').asBool();
4
+ const isIosWalletAvailable = env
5
+ .get('IS_IOS_WALLET_AVAILABLE')
6
+ .required(!isCi)
7
+ .asBool();
8
+ const isAndroidWalletAvailable = env
9
+ .get('IS_ANDROID_WALLET_AVAILABLE')
10
+ .required(!isCi)
11
+ .asBool();
12
+
13
+ module.exports = {
14
+ up: async (db) => {
15
+ if (isCi) {
16
+ return;
17
+ }
18
+ await db.collection('careerWalletConfigs').updateOne(
19
+ {},
20
+ {
21
+ $set: {
22
+ ios: {
23
+ isWalletAvailable: isIosWalletAvailable,
24
+ },
25
+ android: {
26
+ isWalletAvailable: isAndroidWalletAvailable,
27
+ },
28
+ },
29
+ $unset: {
30
+ isWalletAvailable: '',
31
+ },
32
+ }
33
+ );
34
+ },
35
+ down: async () => {},
36
+ };
@@ -0,0 +1,36 @@
1
+ const env = require('env-var');
2
+
3
+ const isCi = env.get('IS_CI').default('false').asBool();
4
+ const isIosWalletAvailable = env
5
+ .get('IS_IOS_WALLET_AVAILABLE')
6
+ .required(!isCi)
7
+ .asBool();
8
+ const isAndroidWalletAvailable = env
9
+ .get('IS_ANDROID_WALLET_AVAILABLE')
10
+ .required(!isCi)
11
+ .asBool();
12
+
13
+ module.exports = {
14
+ up: async (db) => {
15
+ if (isCi) {
16
+ return;
17
+ }
18
+ await db.collection('careerWalletConfigs').updateOne(
19
+ {},
20
+ {
21
+ $set: {
22
+ ios: {
23
+ isWalletAvailable: isIosWalletAvailable,
24
+ },
25
+ android: {
26
+ isWalletAvailable: isAndroidWalletAvailable,
27
+ },
28
+ },
29
+ $unset: {
30
+ isWalletAvailable: '',
31
+ },
32
+ }
33
+ );
34
+ },
35
+ down: async () => {},
36
+ };
@@ -0,0 +1,15 @@
1
+ module.exports = {
2
+ up: async (db) => {
3
+ await db.collection('careerWalletConfigs').updateOne(
4
+ {},
5
+ {
6
+ $set: {
7
+ sdk: {
8
+ cacheSequence: 7,
9
+ },
10
+ },
11
+ }
12
+ );
13
+ },
14
+ down: async () => {},
15
+ };
@@ -0,0 +1,18 @@
1
+ module.exports = {
2
+ up: async (db) => {
3
+ await db.collection('careerWalletConfigs').updateOne(
4
+ {},
5
+ {
6
+ $set: {
7
+ sdk: {
8
+ cacheSequence: 7,
9
+ isDirectIssuerCheckOn: true,
10
+ xVnfProtocolVersion: '1.0',
11
+ isDebugOn: false,
12
+ },
13
+ },
14
+ }
15
+ );
16
+ },
17
+ down: async () => {},
18
+ };
@@ -0,0 +1,57 @@
1
+ /* eslint-disable */
2
+
3
+ const console = require('console');
4
+ const env = require('env-var');
5
+
6
+ const isCi = env.get('IS_CI').default('false').asBool();
7
+
8
+ module.exports = {
9
+ up: async (db) => {
10
+ if (env.get('MIGRATION_ENV').asString() === 'prod') {
11
+ console.log('skipping creating personas in production');
12
+ return;
13
+ }
14
+ if (env.get('IGNORE_PERSONAS').default('false').asBool()) {
15
+ console.log('IGNORE_PERSONAS: true, skipping personas migration');
16
+ return;
17
+ }
18
+
19
+ const personaAdamSmithCredentialPhone = env.get('PERSONA_ADAM_SMITH_CREDENTIAL_PHONE').required(!isCi).asString();
20
+ const personaAdamSmithCredentialEmail = env.get('PERSONA_ADAM_SMITH_CREDENTIAL_EMAIL').required(!isCi).asString();
21
+ const personaAdamSmithCredentialDriversLicense = env.get('PERSONA_ADAM_SMITH_CREDENTIAL_DRIVER_LICENSE').required(!isCi).asString();
22
+
23
+ const now = new Date();
24
+
25
+ const filterDoc = {
26
+ email: 'adam.smith@example.com',
27
+ };
28
+ const updateDoc = {
29
+ $set: {
30
+ vcs: [
31
+ {
32
+ "type": [
33
+ "DriversLicenseV1.0"
34
+ ],
35
+ "jwt_vc": personaAdamSmithCredentialDriversLicense
36
+ },
37
+ {
38
+ "type": [
39
+ "EmailV1.0"
40
+ ],
41
+ "jwt_vc": personaAdamSmithCredentialEmail
42
+ },
43
+ {
44
+ "type": [
45
+ "PhoneV1.0"
46
+ ],
47
+ "jwt_vc": personaAdamSmithCredentialPhone
48
+ }
49
+ ],
50
+ updatedAt: now,
51
+ },
52
+ };
53
+ await db.collection('personas').updateOne(filterDoc, updateDoc)
54
+ },
55
+
56
+ down: async () => {},
57
+ };
@@ -0,0 +1,57 @@
1
+ /* eslint-disable */
2
+
3
+ const console = require('console');
4
+ const env = require('env-var');
5
+
6
+ const isCi = env.get('IS_CI').default('false').asBool();
7
+
8
+ module.exports = {
9
+ up: async (db) => {
10
+ if (env.get('MIGRATION_ENV').asString() === 'prod') {
11
+ console.log('skipping creating personas in production');
12
+ return;
13
+ }
14
+ if (env.get('IGNORE_PERSONAS').default('false').asBool()) {
15
+ console.log('IGNORE_PERSONAS: true, skipping personas migration');
16
+ return;
17
+ }
18
+
19
+ const personaAdamSmithCredentialPhone = env.get('PERSONA_ADAM_SMITH_CREDENTIAL_PHONE').required(!isCi).asString();
20
+ const personaAdamSmithCredentialEmail = env.get('PERSONA_ADAM_SMITH_CREDENTIAL_EMAIL').required(!isCi).asString();
21
+ const personaAdamSmithCredentialDriversLicense = env.get('PERSONA_ADAM_SMITH_CREDENTIAL_DRIVER_LICENSE').required(!isCi).asString();
22
+
23
+ const now = new Date();
24
+
25
+ const filterDoc = {
26
+ email: 'adam.smith@example.com',
27
+ };
28
+ const updateDoc = {
29
+ $set: {
30
+ vcs: [
31
+ {
32
+ "type": [
33
+ "DriversLicenseV1.0"
34
+ ],
35
+ "jwt_vc": personaAdamSmithCredentialDriversLicense
36
+ },
37
+ {
38
+ "type": [
39
+ "EmailV1.0"
40
+ ],
41
+ "jwt_vc": personaAdamSmithCredentialEmail
42
+ },
43
+ {
44
+ "type": [
45
+ "PhoneV1.0"
46
+ ],
47
+ "jwt_vc": personaAdamSmithCredentialPhone
48
+ }
49
+ ],
50
+ updatedAt: now,
51
+ },
52
+ };
53
+ await db.collection('personas').updateOne(filterDoc, updateDoc)
54
+ },
55
+
56
+ down: async () => {},
57
+ };
@@ -0,0 +1,26 @@
1
+ const { map, isEmpty } = require('lodash/fp');
2
+ const { ObjectId } = require('mongodb');
3
+
4
+ module.exports = {
5
+ up: async (db) => {
6
+ const personas = await db.collection('personas').find().toArray();
7
+
8
+ const updates = map(
9
+ (persona) => ({
10
+ updateOne: {
11
+ filter: { _id: persona._id },
12
+ update: {
13
+ $set: {
14
+ keyId: new ObjectId(persona.keyId),
15
+ },
16
+ },
17
+ },
18
+ }),
19
+ personas
20
+ );
21
+ if (isEmpty(updates)) {
22
+ return;
23
+ }
24
+ await db.collection('personas').bulkWrite(updates);
25
+ },
26
+ };