@sphereon/ssi-sdk.data-store 0.28.1-next.6 → 0.28.1-next.60

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 (176) hide show
  1. package/dist/contact/ContactStore.d.ts.map +1 -1
  2. package/dist/contact/ContactStore.js.map +1 -1
  3. package/dist/digitalCredential/AbstractDigitalCredentialStore.d.ts +4 -5
  4. package/dist/digitalCredential/AbstractDigitalCredentialStore.d.ts.map +1 -1
  5. package/dist/digitalCredential/AbstractDigitalCredentialStore.js.map +1 -1
  6. package/dist/digitalCredential/DigitalCredentialStore.d.ts +4 -5
  7. package/dist/digitalCredential/DigitalCredentialStore.d.ts.map +1 -1
  8. package/dist/digitalCredential/DigitalCredentialStore.js +10 -10
  9. package/dist/digitalCredential/DigitalCredentialStore.js.map +1 -1
  10. package/dist/entities/contact/BaseContactEntity.d.ts.map +1 -1
  11. package/dist/entities/contact/BaseContactEntity.js +3 -2
  12. package/dist/entities/contact/BaseContactEntity.js.map +1 -1
  13. package/dist/entities/contact/ConnectionEntity.js +2 -2
  14. package/dist/entities/contact/ConnectionEntity.js.map +1 -1
  15. package/dist/entities/contact/ContactMetadataItemEntity.d.ts +1 -0
  16. package/dist/entities/contact/ContactMetadataItemEntity.d.ts.map +1 -1
  17. package/dist/entities/contact/ContactMetadataItemEntity.js +7 -6
  18. package/dist/entities/contact/ContactMetadataItemEntity.js.map +1 -1
  19. package/dist/entities/contact/CorrelationIdentifierEntity.js +2 -2
  20. package/dist/entities/contact/CorrelationIdentifierEntity.js.map +1 -1
  21. package/dist/entities/contact/DidAuthConfigEntity.js +5 -5
  22. package/dist/entities/contact/DidAuthConfigEntity.js.map +1 -1
  23. package/dist/entities/contact/ElectronicAddressEntity.d.ts.map +1 -1
  24. package/dist/entities/contact/ElectronicAddressEntity.js +8 -7
  25. package/dist/entities/contact/ElectronicAddressEntity.js.map +1 -1
  26. package/dist/entities/contact/IdentityEntity.d.ts.map +1 -1
  27. package/dist/entities/contact/IdentityEntity.js +7 -6
  28. package/dist/entities/contact/IdentityEntity.js.map +1 -1
  29. package/dist/entities/contact/IdentityMetadataItemEntity.d.ts +1 -0
  30. package/dist/entities/contact/IdentityMetadataItemEntity.d.ts.map +1 -1
  31. package/dist/entities/contact/IdentityMetadataItemEntity.js +7 -6
  32. package/dist/entities/contact/IdentityMetadataItemEntity.js.map +1 -1
  33. package/dist/entities/contact/NaturalPersonEntity.js +6 -6
  34. package/dist/entities/contact/NaturalPersonEntity.js.map +1 -1
  35. package/dist/entities/contact/OpenIdConfigEntity.js +5 -5
  36. package/dist/entities/contact/OpenIdConfigEntity.js.map +1 -1
  37. package/dist/entities/contact/OrganizationEntity.d.ts +0 -2
  38. package/dist/entities/contact/OrganizationEntity.d.ts.map +1 -1
  39. package/dist/entities/contact/OrganizationEntity.js +6 -12
  40. package/dist/entities/contact/OrganizationEntity.js.map +1 -1
  41. package/dist/entities/contact/PartyEntity.d.ts.map +1 -1
  42. package/dist/entities/contact/PartyEntity.js +6 -5
  43. package/dist/entities/contact/PartyEntity.js.map +1 -1
  44. package/dist/entities/contact/PartyRelationshipEntity.d.ts.map +1 -1
  45. package/dist/entities/contact/PartyRelationshipEntity.js +7 -6
  46. package/dist/entities/contact/PartyRelationshipEntity.js.map +1 -1
  47. package/dist/entities/contact/PartyTypeEntity.d.ts.map +1 -1
  48. package/dist/entities/contact/PartyTypeEntity.js +6 -5
  49. package/dist/entities/contact/PartyTypeEntity.js.map +1 -1
  50. package/dist/entities/contact/PhysicalAddressEntity.d.ts.map +1 -1
  51. package/dist/entities/contact/PhysicalAddressEntity.js +14 -13
  52. package/dist/entities/contact/PhysicalAddressEntity.js.map +1 -1
  53. package/dist/entities/digitalCredential/DigitalCredentialEntity.d.ts +3 -1
  54. package/dist/entities/digitalCredential/DigitalCredentialEntity.d.ts.map +1 -1
  55. package/dist/entities/digitalCredential/DigitalCredentialEntity.js +21 -12
  56. package/dist/entities/digitalCredential/DigitalCredentialEntity.js.map +1 -1
  57. package/dist/entities/eventLogger/AuditEventEntity.d.ts.map +1 -1
  58. package/dist/entities/eventLogger/AuditEventEntity.js +13 -12
  59. package/dist/entities/eventLogger/AuditEventEntity.js.map +1 -1
  60. package/dist/entities/issuanceBranding/BackgroundAttributesEntity.js +1 -1
  61. package/dist/entities/issuanceBranding/BackgroundAttributesEntity.js.map +1 -1
  62. package/dist/entities/issuanceBranding/BaseLocaleBrandingEntity.d.ts.map +1 -1
  63. package/dist/entities/issuanceBranding/BaseLocaleBrandingEntity.js +6 -5
  64. package/dist/entities/issuanceBranding/BaseLocaleBrandingEntity.js.map +1 -1
  65. package/dist/entities/issuanceBranding/CredentialBrandingEntity.d.ts.map +1 -1
  66. package/dist/entities/issuanceBranding/CredentialBrandingEntity.js +5 -4
  67. package/dist/entities/issuanceBranding/CredentialBrandingEntity.js.map +1 -1
  68. package/dist/entities/issuanceBranding/CredentialLocaleBrandingEntity.js +1 -1
  69. package/dist/entities/issuanceBranding/CredentialLocaleBrandingEntity.js.map +1 -1
  70. package/dist/entities/issuanceBranding/ImageAttributesEntity.js +4 -4
  71. package/dist/entities/issuanceBranding/ImageAttributesEntity.js.map +1 -1
  72. package/dist/entities/issuanceBranding/ImageDimensionsEntity.js +2 -2
  73. package/dist/entities/issuanceBranding/ImageDimensionsEntity.js.map +1 -1
  74. package/dist/entities/issuanceBranding/IssuerBrandingEntity.d.ts.map +1 -1
  75. package/dist/entities/issuanceBranding/IssuerBrandingEntity.js +4 -3
  76. package/dist/entities/issuanceBranding/IssuerBrandingEntity.js.map +1 -1
  77. package/dist/entities/issuanceBranding/IssuerLocaleBrandingEntity.js +1 -1
  78. package/dist/entities/issuanceBranding/IssuerLocaleBrandingEntity.js.map +1 -1
  79. package/dist/entities/issuanceBranding/TextAttributesEntity.js +1 -1
  80. package/dist/entities/issuanceBranding/TextAttributesEntity.js.map +1 -1
  81. package/dist/entities/machineState/MachineStateInfoEntity.d.ts.map +1 -1
  82. package/dist/entities/machineState/MachineStateInfoEntity.js +5 -4
  83. package/dist/entities/machineState/MachineStateInfoEntity.js.map +1 -1
  84. package/dist/entities/presentationDefinition/PresentationDefinitionItemEntity.d.ts.map +1 -1
  85. package/dist/entities/presentationDefinition/PresentationDefinitionItemEntity.js +8 -7
  86. package/dist/entities/presentationDefinition/PresentationDefinitionItemEntity.js.map +1 -1
  87. package/dist/entities/statusList2021/StatusList2021Entity.js +1 -1
  88. package/dist/entities/statusList2021/StatusList2021Entity.js.map +1 -1
  89. package/dist/entities/statusList2021/StatusList2021EntryEntity.js +5 -5
  90. package/dist/entities/statusList2021/StatusList2021EntryEntity.js.map +1 -1
  91. package/dist/index.d.ts +5 -2
  92. package/dist/index.d.ts.map +1 -1
  93. package/dist/index.js +8 -2
  94. package/dist/index.js.map +1 -1
  95. package/dist/migrations/postgres/1708525189001-CreateDigitalCredential.d.ts.map +1 -1
  96. package/dist/migrations/postgres/1708525189001-CreateDigitalCredential.js +4 -0
  97. package/dist/migrations/postgres/1708525189001-CreateDigitalCredential.js.map +1 -1
  98. package/dist/migrations/sqlite/1708525189002-CreateDigitalCredential.d.ts.map +1 -1
  99. package/dist/migrations/sqlite/1708525189002-CreateDigitalCredential.js +2 -0
  100. package/dist/migrations/sqlite/1708525189002-CreateDigitalCredential.js.map +1 -1
  101. package/dist/types/contact/contact.d.ts +8 -5
  102. package/dist/types/contact/contact.d.ts.map +1 -1
  103. package/dist/types/contact/contact.js +1 -7
  104. package/dist/types/contact/contact.js.map +1 -1
  105. package/dist/types/digitalCredential/IAbstractDigitalCredentialStore.d.ts +2 -1
  106. package/dist/types/digitalCredential/IAbstractDigitalCredentialStore.d.ts.map +1 -1
  107. package/dist/types/digitalCredential/digitalCredential.d.ts +7 -0
  108. package/dist/types/digitalCredential/digitalCredential.d.ts.map +1 -1
  109. package/dist/types/digitalCredential/digitalCredential.js +7 -1
  110. package/dist/types/digitalCredential/digitalCredential.js.map +1 -1
  111. package/dist/types/index.d.ts +2 -0
  112. package/dist/types/index.d.ts.map +1 -1
  113. package/dist/types/index.js +2 -0
  114. package/dist/types/index.js.map +1 -1
  115. package/dist/utils/digitalCredential/MappingUtils.d.ts.map +1 -1
  116. package/dist/utils/digitalCredential/MappingUtils.js +1 -1
  117. package/dist/utils/digitalCredential/MappingUtils.js.map +1 -1
  118. package/package.json +6 -5
  119. package/src/__tests__/contact.entities.test.ts +3 -0
  120. package/src/__tests__/contact.store.test.ts +2 -0
  121. package/src/__tests__/digitalCredential.entities.test.ts +9 -1
  122. package/src/__tests__/digitalCredential.store.test.ts +16 -2
  123. package/src/__tests__/eventLogger.entities.test.ts +2 -0
  124. package/src/__tests__/eventLogger.store.test.ts +3 -1
  125. package/src/__tests__/issuanceBranding.entities.test.ts +2 -0
  126. package/src/__tests__/issuanceBranding.store.test.ts +2 -0
  127. package/src/__tests__/machineState.entities.test.ts +2 -0
  128. package/src/__tests__/machineState.store.test.ts +2 -0
  129. package/src/__tests__/pd-manager.entities.test.ts +2 -0
  130. package/src/__tests__/pd-manager.store.test.ts +2 -0
  131. package/src/contact/ContactStore.ts +1 -0
  132. package/src/digitalCredential/AbstractDigitalCredentialStore.ts +9 -5
  133. package/src/digitalCredential/DigitalCredentialStore.ts +18 -12
  134. package/src/entities/contact/BaseContactEntity.ts +3 -2
  135. package/src/entities/contact/ConnectionEntity.ts +2 -2
  136. package/src/entities/contact/ContactMetadataItemEntity.ts +8 -7
  137. package/src/entities/contact/CorrelationIdentifierEntity.ts +2 -2
  138. package/src/entities/contact/DidAuthConfigEntity.ts +5 -5
  139. package/src/entities/contact/ElectronicAddressEntity.ts +8 -7
  140. package/src/entities/contact/IdentityEntity.ts +7 -6
  141. package/src/entities/contact/IdentityMetadataItemEntity.ts +8 -7
  142. package/src/entities/contact/NaturalPersonEntity.ts +6 -6
  143. package/src/entities/contact/OpenIdConfigEntity.ts +5 -5
  144. package/src/entities/contact/OrganizationEntity.ts +9 -14
  145. package/src/entities/contact/PartyEntity.ts +6 -5
  146. package/src/entities/contact/PartyRelationshipEntity.ts +7 -6
  147. package/src/entities/contact/PartyTypeEntity.ts +6 -5
  148. package/src/entities/contact/PhysicalAddressEntity.ts +14 -13
  149. package/src/entities/digitalCredential/DigitalCredentialEntity.ts +14 -12
  150. package/src/entities/eventLogger/AuditEventEntity.ts +13 -12
  151. package/src/entities/issuanceBranding/BackgroundAttributesEntity.ts +1 -1
  152. package/src/entities/issuanceBranding/BaseLocaleBrandingEntity.ts +6 -5
  153. package/src/entities/issuanceBranding/CredentialBrandingEntity.ts +5 -4
  154. package/src/entities/issuanceBranding/CredentialLocaleBrandingEntity.ts +1 -1
  155. package/src/entities/issuanceBranding/ImageAttributesEntity.ts +4 -4
  156. package/src/entities/issuanceBranding/ImageDimensionsEntity.ts +2 -2
  157. package/src/entities/issuanceBranding/IssuerBrandingEntity.ts +4 -3
  158. package/src/entities/issuanceBranding/IssuerLocaleBrandingEntity.ts +1 -1
  159. package/src/entities/issuanceBranding/TextAttributesEntity.ts +1 -1
  160. package/src/entities/machineState/MachineStateInfoEntity.ts +5 -4
  161. package/src/entities/presentationDefinition/PresentationDefinitionItemEntity.ts +8 -7
  162. package/src/entities/statusList2021/StatusList2021Entity.ts +1 -1
  163. package/src/entities/statusList2021/StatusList2021EntryEntity.ts +5 -5
  164. package/src/index.ts +4 -0
  165. package/src/migrations/postgres/1708525189001-CreateDigitalCredential.ts +4 -0
  166. package/src/migrations/sqlite/1708525189002-CreateDigitalCredential.ts +2 -0
  167. package/src/types/contact/contact.ts +10 -6
  168. package/src/types/digitalCredential/IAbstractDigitalCredentialStore.ts +2 -1
  169. package/src/types/digitalCredential/digitalCredential.ts +8 -0
  170. package/src/types/index.ts +2 -0
  171. package/src/utils/digitalCredential/MappingUtils.ts +1 -0
  172. package/dist/entities/contact/IMetadataEntity.d.ts +0 -8
  173. package/dist/entities/contact/IMetadataEntity.d.ts.map +0 -1
  174. package/dist/entities/contact/IMetadataEntity.js +0 -2
  175. package/dist/entities/contact/IMetadataEntity.js.map +0 -1
  176. package/src/entities/contact/IMetadataEntity.ts +0 -8
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,qCAAqC,CAAA;AACnD,cAAc,mDAAmD,CAAA;AACjE,cAAc,mBAAmB,CAAA;AACjC,cAAc,iDAAiD,CAAA;AAC/D,cAAc,2CAA2C,CAAA;AACzD,cAAc,iCAAiC,CAAA;AAC/C,cAAc,yBAAyB,CAAA;AACvC,cAAc,yBAAyB,CAAA;AACvC,cAAc,uCAAuC,CAAA;AACrD,cAAc,yCAAyC,CAAA;AACvD,cAAc,2BAA2B,CAAA;AACzC,cAAc,2CAA2C,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,qCAAqC,CAAA;AACnD,cAAc,mDAAmD,CAAA;AACjE,cAAc,mBAAmB,CAAA;AACjC,cAAc,iDAAiD,CAAA;AAC/D,cAAc,2CAA2C,CAAA;AACzD,cAAc,iCAAiC,CAAA;AAC/C,cAAc,yBAAyB,CAAA;AACvC,cAAc,yBAAyB,CAAA;AACvC,cAAc,uCAAuC,CAAA;AACrD,cAAc,yCAAyC,CAAA;AACvD,cAAc,2BAA2B,CAAA;AACzC,cAAc,2CAA2C,CAAA;AACzD,cAAc,uCAAuC,CAAA;AACrD,cAAc,qDAAqD,CAAA"}
@@ -26,4 +26,6 @@ __exportStar(require("./statusList/IAbstractStatusListStore"), exports);
26
26
  __exportStar(require("./eventLogger/IAbstractEventLoggerStore"), exports);
27
27
  __exportStar(require("./eventLogger/eventLogger"), exports);
28
28
  __exportStar(require("./machineState/IAbstractMachineStateStore"), exports);
29
+ __exportStar(require("./digitalCredential/digitalCredential"), exports);
30
+ __exportStar(require("./digitalCredential/IAbstractDigitalCredentialStore"), exports);
29
31
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sEAAmD;AACnD,oFAAiE;AACjE,oDAAiC;AACjC,kFAA+D;AAC/D,4EAAyD;AACzD,kEAA+C;AAC/C,0DAAuC;AACvC,0DAAuC;AACvC,wEAAqD;AACrD,0EAAuD;AACvD,4DAAyC;AACzC,4EAAyD"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sEAAmD;AACnD,oFAAiE;AACjE,oDAAiC;AACjC,kFAA+D;AAC/D,4EAAyD;AACzD,kEAA+C;AAC/C,0DAAuC;AACvC,0DAAuC;AACvC,wEAAqD;AACrD,0EAAuD;AACvD,4DAAyC;AACzC,4EAAyD;AACzD,wEAAqD;AACrD,sFAAmE"}
@@ -1 +1 @@
1
- {"version":3,"file":"MappingUtils.d.ts","sourceRoot":"","sources":["../../../src/utils/digitalCredential/MappingUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,+DAA+D,CAAA;AACjG,OAAO,EAAE,uBAAuB,EAAE,MAAM,0DAA0D,CAAA;AAWlG,OAAO,EAGL,iBAAiB,EACjB,6BAA6B,EAC9B,MAAM,iDAAiD,CAAA;AAqExD,eAAO,MAAM,8CAA8C,sBAAuB,iBAAiB,KAAG,6BAyBrG,CAAA;AAED,eAAO,MAAM,qBAAqB,qBAAsB,uBAAuB,KAAG,iBAIjF,CAAA;AAED,eAAO,MAAM,sBAAsB,uBAAwB,MAAM,uBAAuB,CAAC,KAAG,iBAAiB,EAE5G,CAAA"}
1
+ {"version":3,"file":"MappingUtils.d.ts","sourceRoot":"","sources":["../../../src/utils/digitalCredential/MappingUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,+DAA+D,CAAA;AACjG,OAAO,EAAE,uBAAuB,EAAE,MAAM,0DAA0D,CAAA;AAWlG,OAAO,EAGL,iBAAiB,EACjB,6BAA6B,EAC9B,MAAM,iDAAiD,CAAA;AAqExD,eAAO,MAAM,8CAA8C,sBAAuB,iBAAiB,KAAG,6BA0BrG,CAAA;AAED,eAAO,MAAM,qBAAqB,qBAAsB,uBAAuB,KAAG,iBAIjF,CAAA;AAED,eAAO,MAAM,sBAAsB,uBAAwB,MAAM,uBAAuB,CAAC,KAAG,iBAAiB,EAE5G,CAAA"}
@@ -84,7 +84,7 @@ const nonPersistedDigitalCredentialEntityFromAddArgs = (addCredentialArgs) => {
84
84
  : ssi_types_1.CredentialMapper.toUniformPresentation(addCredentialArgs.rawDocument);
85
85
  const validFrom = getValidFrom(uniformDocument);
86
86
  const validUntil = getValidUntil(uniformDocument);
87
- return Object.assign(Object.assign({}, addCredentialArgs), { documentType, documentFormat: determineCredentialDocumentFormat(documentFormat), createdAt: new Date(), hash: (0, utils_1.computeEntryHash)(addCredentialArgs.rawDocument), uniformDocument: JSON.stringify(uniformDocument), validFrom,
87
+ return Object.assign(Object.assign({}, addCredentialArgs), { documentType, documentFormat: determineCredentialDocumentFormat(documentFormat), createdAt: new Date(), credentialId: uniformDocument.id, hash: (0, utils_1.computeEntryHash)(addCredentialArgs.rawDocument), uniformDocument: JSON.stringify(uniformDocument), validFrom,
88
88
  validUntil, lastUpdatedAt: new Date() });
89
89
  };
90
90
  exports.nonPersistedDigitalCredentialEntityFromAddArgs = nonPersistedDigitalCredentialEntityFromAddArgs;
@@ -1 +1 @@
1
- {"version":3,"file":"MappingUtils.js","sourceRoot":"","sources":["../../../src/utils/digitalCredential/MappingUtils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"MappingUtils.js","sourceRoot":"","sources":["../../../src/utils/digitalCredential/MappingUtils.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sphereon/ssi-sdk.data-store",
3
- "version": "0.28.1-next.6+e969b97b",
3
+ "version": "0.28.1-next.60+f7cb47bc",
4
4
  "source": "src/index.ts",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -15,9 +15,10 @@
15
15
  },
16
16
  "dependencies": {
17
17
  "@sphereon/pex": "^4.0.1",
18
- "@sphereon/ssi-sdk-ext.did-utils": "0.23.1-next.3",
19
- "@sphereon/ssi-sdk.core": "0.28.1-next.6+e969b97b",
20
- "@sphereon/ssi-types": "0.28.1-next.6+e969b97b",
18
+ "@sphereon/ssi-sdk-ext.did-utils": "0.24.0",
19
+ "@sphereon/ssi-sdk.agent-config": "0.28.1-next.60+f7cb47bc",
20
+ "@sphereon/ssi-sdk.core": "0.28.1-next.60+f7cb47bc",
21
+ "@sphereon/ssi-types": "0.28.1-next.60+f7cb47bc",
21
22
  "@veramo/core": "4.2.0",
22
23
  "@veramo/utils": "4.2.0",
23
24
  "blakejs": "^1.2.1",
@@ -48,5 +49,5 @@
48
49
  "PostgreSQL",
49
50
  "Contact Store"
50
51
  ],
51
- "gitHead": "e969b97b387e62e2def5a0bac655f1fe5c7100a7"
52
+ "gitHead": "f7cb47bcef0713060e698f73a168d69ad3758410"
52
53
  }
@@ -56,6 +56,8 @@ import {
56
56
  physicalAddressEntityFrom,
57
57
  } from '../utils/contact/MappingUtils'
58
58
  import { ContactMetadataItemEntity } from '../entities/contact/ContactMetadataItemEntity'
59
+ import { DataSources } from '@sphereon/ssi-sdk.agent-config'
60
+
59
61
 
60
62
  // TODO write test adding two contacts reusing the same contactType
61
63
 
@@ -63,6 +65,7 @@ describe('Database entities tests', (): void => {
63
65
  let dbConnection: DataSource
64
66
 
65
67
  beforeEach(async (): Promise<void> => {
68
+ DataSources.singleInstance().defaultDbType = 'sqlite'
66
69
  dbConnection = await new DataSource({
67
70
  type: 'sqlite',
68
71
  database: ':memory:',
@@ -1,3 +1,4 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { DataSource } from 'typeorm'
2
3
  import { DataStoreContactEntities, DataStoreMigrations, IdentityOrigin, MetadataItem, MetadataTypes, PartyOrigin } from '../index'
3
4
  import { ContactStore } from '../contact/ContactStore'
@@ -31,6 +32,7 @@ describe('Contact store tests', (): void => {
31
32
  let contactStore: ContactStore
32
33
 
33
34
  beforeEach(async (): Promise<void> => {
35
+ DataSources.singleInstance().defaultDbType = 'sqlite'
34
36
  dbConnection = await new DataSource({
35
37
  type: 'sqlite',
36
38
  database: ':memory:',
@@ -1,5 +1,6 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { DataSource } from 'typeorm'
2
- import { DataStoreDigitalCredentialEntities } from '../index'
3
+ import { CredentialRole, DataStoreDigitalCredentialEntities } from '../index'
3
4
  import { DataStoreDigitalCredentialMigrations } from '../migrations'
4
5
  import { DigitalCredentialEntity } from '../entities/digitalCredential/DigitalCredentialEntity'
5
6
  import {
@@ -17,6 +18,7 @@ describe('Database entities tests', (): void => {
17
18
  let dbConnection: DataSource
18
19
 
19
20
  beforeEach(async (): Promise<void> => {
21
+ DataSources.singleInstance().defaultDbType = 'sqlite'
20
22
  dbConnection = await new DataSource({
21
23
  type: 'sqlite',
22
24
  database: ':memory:',
@@ -43,6 +45,7 @@ describe('Database entities tests', (): void => {
43
45
  subjectCorrelationType: CredentialCorrelationType.DID,
44
46
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
45
47
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
48
+ credentialRole: CredentialRole.VERIFIER,
46
49
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
47
50
  }
48
51
 
@@ -69,6 +72,7 @@ describe('Database entities tests', (): void => {
69
72
  subjectCorrelationType: CredentialCorrelationType.DID,
70
73
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
71
74
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
75
+ credentialRole: CredentialRole.VERIFIER,
72
76
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
73
77
  })
74
78
  expect(digitalCredential.documentType).toEqual(DocumentType.VC)
@@ -85,6 +89,7 @@ describe('Database entities tests', (): void => {
85
89
  subjectCorrelationType: CredentialCorrelationType.DID,
86
90
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
87
91
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
92
+ credentialRole: CredentialRole.VERIFIER,
88
93
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
89
94
  })
90
95
  expect(digitalCredential.documentType).toEqual(DocumentType.VC)
@@ -128,6 +133,7 @@ describe('Database entities tests', (): void => {
128
133
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
129
134
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
130
135
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
136
+ credentialRole: CredentialRole.VERIFIER,
131
137
  })
132
138
  expect(digitalCredential.documentType).toEqual(DocumentType.VC)
133
139
  expect(digitalCredential.validFrom).toEqual(new Date('2022-01-07T11:54:12.000Z'))
@@ -225,6 +231,7 @@ describe('Database entities tests', (): void => {
225
231
  subjectCorrelationType: CredentialCorrelationType.DID,
226
232
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
227
233
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
234
+ credentialRole: CredentialRole.VERIFIER,
228
235
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
229
236
  })
230
237
  expect(digitalCredential.documentType).toEqual(DocumentType.VP)
@@ -241,6 +248,7 @@ describe('Database entities tests', (): void => {
241
248
  subjectCorrelationType: CredentialCorrelationType.DID,
242
249
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
243
250
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
251
+ credentialRole: CredentialRole.VERIFIER,
244
252
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
245
253
  opts: {
246
254
  hasher: (data, algorithm) => createHash(algorithm).update(data).digest(),
@@ -1,6 +1,7 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { DataSource } from 'typeorm'
2
3
  import { DataStoreDigitalCredentialMigrations } from '../migrations'
3
- import { DataStoreDigitalCredentialEntities } from '../index'
4
+ import { CredentialRole, DataStoreDigitalCredentialEntities } from '../index'
4
5
  import { DigitalCredentialStore } from '../digitalCredential/DigitalCredentialStore'
5
6
  import {
6
7
  CredentialCorrelationType,
@@ -18,6 +19,7 @@ describe('Database entities tests', (): void => {
18
19
  let digitalCredentialStore: DigitalCredentialStore
19
20
 
20
21
  beforeEach(async (): Promise<void> => {
22
+ DataSources.singleInstance().defaultDbType = 'sqlite'
21
23
  dbConnection = await new DataSource({
22
24
  type: 'sqlite',
23
25
  database: ':memory:',
@@ -45,6 +47,7 @@ describe('Database entities tests', (): void => {
45
47
  subjectCorrelationType: CredentialCorrelationType.DID,
46
48
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
47
49
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
50
+ credentialRole: CredentialRole.VERIFIER,
48
51
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
49
52
  }
50
53
 
@@ -60,6 +63,7 @@ describe('Database entities tests', (): void => {
60
63
  subjectCorrelationType: CredentialCorrelationType.DID,
61
64
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
62
65
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
66
+ credentialRole: CredentialRole.VERIFIER,
63
67
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
64
68
  }
65
69
 
@@ -76,6 +80,7 @@ describe('Database entities tests', (): void => {
76
80
  subjectCorrelationType: CredentialCorrelationType.DID,
77
81
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
78
82
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
83
+ credentialRole: CredentialRole.VERIFIER,
79
84
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
80
85
  }
81
86
  const addCredentialArgs2: AddCredentialArgs = {
@@ -85,6 +90,7 @@ describe('Database entities tests', (): void => {
85
90
  subjectCorrelationType: CredentialCorrelationType.DID,
86
91
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
87
92
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
93
+ credentialRole: CredentialRole.VERIFIER,
88
94
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
89
95
  }
90
96
 
@@ -105,6 +111,7 @@ describe('Database entities tests', (): void => {
105
111
  subjectCorrelationType: CredentialCorrelationType.DID,
106
112
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
107
113
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
114
+ credentialRole: CredentialRole.VERIFIER,
108
115
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
109
116
  }
110
117
 
@@ -148,11 +155,12 @@ describe('Database entities tests', (): void => {
148
155
  }
149
156
  const addCredentialArgs2: AddCredentialArgs = {
150
157
  rawDocument: JSON.stringify(sampleVP),
151
- tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
152
158
  issuerCorrelationType: CredentialCorrelationType.DID,
153
159
  issuerCorrelationId: 'did:example:holder',
154
160
  subjectCorrelationType: CredentialCorrelationType.DID,
155
161
  subjectCorrelationId: 'did:example:holder',
162
+ credentialRole: CredentialRole.VERIFIER,
163
+ tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
156
164
  }
157
165
  const addCredentialArgs3: AddCredentialArgs = {
158
166
  rawDocument:
@@ -161,6 +169,7 @@ describe('Database entities tests', (): void => {
161
169
  subjectCorrelationType: CredentialCorrelationType.DID,
162
170
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
163
171
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
172
+ credentialRole: CredentialRole.VERIFIER,
164
173
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
165
174
  opts: {
166
175
  hasher: (data, algorithm) => createHash(algorithm).update(data).digest(),
@@ -191,6 +200,7 @@ describe('Database entities tests', (): void => {
191
200
  const result3: GetCredentialsResponse = await digitalCredentialStore.getCredentials(args3)
192
201
  expect(result3.data.length).toEqual(3)
193
202
  expect(result3.data[1].documentFormat).toEqual(CredentialDocumentFormat.JSON_LD)
203
+ expect(result3.data[1].credentialId).toEqual('ebc6f1c2')
194
204
  })
195
205
 
196
206
  it('should return no digital credentials if filter does not match', async (): Promise<void> => {
@@ -212,6 +222,7 @@ describe('Database entities tests', (): void => {
212
222
  subjectCorrelationType: CredentialCorrelationType.DID,
213
223
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
214
224
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
225
+ credentialRole: CredentialRole.VERIFIER,
215
226
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
216
227
  }
217
228
 
@@ -234,6 +245,7 @@ describe('Database entities tests', (): void => {
234
245
  subjectCorrelationType: CredentialCorrelationType.DID,
235
246
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
236
247
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
248
+ credentialRole: CredentialRole.VERIFIER,
237
249
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
238
250
  }
239
251
 
@@ -256,6 +268,7 @@ describe('Database entities tests', (): void => {
256
268
  subjectCorrelationType: CredentialCorrelationType.DID,
257
269
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
258
270
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
271
+ credentialRole: CredentialRole.VERIFIER,
259
272
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
260
273
  }
261
274
 
@@ -278,6 +291,7 @@ describe('Database entities tests', (): void => {
278
291
  subjectCorrelationType: CredentialCorrelationType.DID,
279
292
  issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
280
293
  subjectCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
294
+ credentialRole: CredentialRole.VERIFIER,
281
295
  tenantId: 'urn:uuid:nnag4b43-1e7a-98f8-a32c-a48dbc5b10mj',
282
296
  }
283
297
 
@@ -1,3 +1,4 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { PartyCorrelationType } from '@sphereon/ssi-sdk.core'
2
3
  import { ActionType, InitiatorType, LogLevel, SubSystem, System, SystemCorrelationIdType } from '@sphereon/ssi-types'
3
4
  import { DataSource } from 'typeorm'
@@ -10,6 +11,7 @@ describe('Database entities tests', (): void => {
10
11
  let dbConnection: DataSource
11
12
 
12
13
  beforeEach(async (): Promise<void> => {
14
+ DataSources.singleInstance().defaultDbType = 'sqlite'
13
15
  dbConnection = await new DataSource({
14
16
  type: 'sqlite',
15
17
  database: ':memory:',
@@ -1,6 +1,7 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { ActionType, InitiatorType, LogLevel, SubSystem, System, SystemCorrelationIdType } from '@sphereon/ssi-types'
2
3
  import { DataSource } from 'typeorm'
3
- import { DataStoreEventLoggerMigrations } from '../migrations/generic'
4
+ import { DataStoreEventLoggerMigrations } from '../migrations'
4
5
  import { DataStoreEventLoggerEntities } from '../index'
5
6
  import { AuditLoggingEvent, PartyCorrelationType } from '@sphereon/ssi-sdk.core'
6
7
  import { EventLoggerStore } from '../eventLogger/EventLoggerStore'
@@ -11,6 +12,7 @@ describe('Database entities tests', (): void => {
11
12
  let eventLoggerStore: EventLoggerStore
12
13
 
13
14
  beforeEach(async (): Promise<void> => {
15
+ DataSources.singleInstance().defaultDbType = 'sqlite'
14
16
  dbConnection = await new DataSource({
15
17
  type: 'sqlite',
16
18
  database: ':memory:',
@@ -1,3 +1,4 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { DataSource, Repository } from 'typeorm'
2
3
  import { DataStoreMigrations } from '../migrations'
3
4
  import {
@@ -20,6 +21,7 @@ describe('Database entities tests', (): void => {
20
21
  let dbConnection: DataSource
21
22
 
22
23
  beforeEach(async (): Promise<void> => {
24
+ DataSources.singleInstance().defaultDbType = 'sqlite'
23
25
  dbConnection = await new DataSource({
24
26
  type: 'sqlite',
25
27
  database: ':memory:',
@@ -1,3 +1,4 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { DataSource } from 'typeorm'
2
3
  import { IssuanceBrandingStore } from '../issuanceBranding/IssuanceBrandingStore'
3
4
  import { DataStoreMigrations } from '../migrations'
@@ -31,6 +32,7 @@ describe('Issuance branding store tests', (): void => {
31
32
  let issuanceBrandingStore: IssuanceBrandingStore
32
33
 
33
34
  beforeEach(async (): Promise<void> => {
35
+ DataSources.singleInstance().defaultDbType = 'sqlite'
34
36
  dbConnection = await new DataSource({
35
37
  type: 'sqlite',
36
38
  database: ':memory:',
@@ -1,3 +1,4 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { DataSource } from 'typeorm'
2
3
  import { MachineStateInfoEntity } from '../entities/machineState/MachineStateInfoEntity'
3
4
 
@@ -7,6 +8,7 @@ describe('Machine State Info Database entities tests', (): void => {
7
8
  let dbConnection: DataSource
8
9
 
9
10
  beforeEach(async (): Promise<void> => {
11
+ DataSources.singleInstance().defaultDbType = 'sqlite'
10
12
  dbConnection = await new DataSource({
11
13
  type: 'sqlite',
12
14
  database: ':memory:',
@@ -1,3 +1,4 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { DataSource } from 'typeorm'
2
3
  import { DataStoreMachineStateEntities, MachineStateStore, StoreMachineStatesFindActiveArgs, StoreMachineStatePersistArgs } from '../index'
3
4
  import { DataStoreMachineStateMigrations } from '../migrations'
@@ -7,6 +8,7 @@ describe('Machine State store tests', (): void => {
7
8
  let store: MachineStateStore
8
9
 
9
10
  beforeEach(async (): Promise<void> => {
11
+ DataSources.singleInstance().defaultDbType = 'sqlite'
10
12
  dbConnection = await new DataSource({
11
13
  type: 'sqlite',
12
14
  database: ':memory:',
@@ -1,3 +1,4 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { DataSource } from 'typeorm'
2
3
  import { PresentationDefinitionItemEntity } from '../entities/presentationDefinition/PresentationDefinitionItemEntity'
3
4
  import { DataStorePresentationDefinitionMigrations } from '../migrations'
@@ -7,6 +8,7 @@ describe('PresentationDefinitionItemEntity tests', (): void => {
7
8
  let dbConnection: DataSource
8
9
 
9
10
  beforeEach(async (): Promise<void> => {
11
+ DataSources.singleInstance().defaultDbType = 'sqlite'
10
12
  dbConnection = await new DataSource({
11
13
  type: 'sqlite',
12
14
  database: ':memory:',
@@ -1,3 +1,4 @@
1
+ import {DataSources} from "@sphereon/ssi-sdk.agent-config";
1
2
  import { DataSource } from 'typeorm'
2
3
  import { DataStorePresentationDefinitionEntities, DataStorePresentationDefinitionMigrations, PDStore } from '../index'
3
4
  import { GetDefinitionsArgs, NonPersistedPresentationDefinitionItem, PresentationDefinitionItem } from '../types'
@@ -7,6 +8,7 @@ describe('PDStore tests', (): void => {
7
8
  let pdStore: PDStore
8
9
 
9
10
  beforeEach(async (): Promise<void> => {
11
+ DataSources.singleInstance().defaultDbType = 'sqlite'
10
12
  dbConnection = await new DataSource({
11
13
  type: 'sqlite',
12
14
  database: ':memory:',
@@ -53,6 +53,7 @@ import {
53
53
  GetPhysicalAddressesArgs,
54
54
  GetRelationshipArgs,
55
55
  GetRelationshipsArgs,
56
+ IMetadataEntity,
56
57
  Identity,
57
58
  MetadataItem,
58
59
  MetadataTypes,
@@ -1,17 +1,21 @@
1
1
  import {
2
2
  AddCredentialArgs,
3
+ DigitalCredential,
3
4
  GetCredentialArgs,
4
5
  GetCredentialsArgs,
5
6
  GetCredentialsResponse,
6
7
  RemoveCredentialArgs,
7
8
  UpdateCredentialStateArgs,
8
- } from '../types/digitalCredential/IAbstractDigitalCredentialStore'
9
- import { DigitalCredentialEntity } from '../entities/digitalCredential/DigitalCredentialEntity'
9
+ } from '../types'
10
10
 
11
11
  export abstract class AbstractDigitalCredentialStore {
12
- abstract getCredential(args: GetCredentialArgs): Promise<DigitalCredentialEntity>
12
+ abstract getCredential(args: GetCredentialArgs): Promise<DigitalCredential>
13
+
13
14
  abstract getCredentials(args?: GetCredentialsArgs): Promise<GetCredentialsResponse>
14
- abstract addCredential(args: AddCredentialArgs): Promise<DigitalCredentialEntity>
15
- abstract updateCredentialState(args: UpdateCredentialStateArgs): Promise<DigitalCredentialEntity>
15
+
16
+ abstract addCredential(args: AddCredentialArgs): Promise<DigitalCredential>
17
+
18
+ abstract updateCredentialState(args: UpdateCredentialStateArgs): Promise<DigitalCredential>
19
+
16
20
  abstract removeCredential(args: RemoveCredentialArgs): Promise<boolean>
17
21
  }
@@ -6,14 +6,20 @@ import {
6
6
  GetCredentialsResponse,
7
7
  RemoveCredentialArgs,
8
8
  UpdateCredentialStateArgs,
9
- } from '../types/digitalCredential/IAbstractDigitalCredentialStore'
9
+ CredentialStateType,
10
+ DigitalCredential,
11
+ NonPersistedDigitalCredential,
12
+ } from '../types'
10
13
  import { OrPromise } from '@sphereon/ssi-types'
11
14
  import { DataSource, FindOptionsOrder, Repository } from 'typeorm'
12
15
  import Debug from 'debug'
13
16
  import { DigitalCredentialEntity } from '../entities/digitalCredential/DigitalCredentialEntity'
14
- import { nonPersistedDigitalCredentialEntityFromAddArgs } from '../utils/digitalCredential/MappingUtils'
17
+ import {
18
+ digitalCredentialFrom,
19
+ digitalCredentialsFrom,
20
+ nonPersistedDigitalCredentialEntityFromAddArgs,
21
+ } from '../utils/digitalCredential/MappingUtils'
15
22
  import { FindOptionsWhere } from 'typeorm/find-options/FindOptionsWhere'
16
- import { CredentialStateType, DigitalCredential, NonPersistedDigitalCredential } from '../types/digitalCredential/digitalCredential'
17
23
  import { parseAndValidateOrderOptions } from '../utils/SortingUtils'
18
24
 
19
25
  const debug: Debug.Debugger = Debug('sphereon:ssi-sdk:credential-store')
@@ -26,23 +32,23 @@ export class DigitalCredentialStore extends AbstractDigitalCredentialStore {
26
32
  this.dbConnection = dbConnection
27
33
  }
28
34
 
29
- addCredential = async (args: AddCredentialArgs): Promise<DigitalCredentialEntity> => {
35
+ addCredential = async (args: AddCredentialArgs): Promise<DigitalCredential> => {
30
36
  debug('Adding credential', args)
31
37
  const digitalCredentialEntityRepository: Repository<DigitalCredentialEntity> = (await this.dbConnection).getRepository(DigitalCredentialEntity)
32
38
  const credentialEntity: NonPersistedDigitalCredential = nonPersistedDigitalCredentialEntityFromAddArgs(args)
33
39
  const createdResult: DigitalCredentialEntity = await digitalCredentialEntityRepository.save(credentialEntity)
34
- return Promise.resolve(createdResult)
40
+ return Promise.resolve(digitalCredentialFrom(createdResult))
35
41
  }
36
42
 
37
- getCredential = async (args: GetCredentialArgs): Promise<DigitalCredentialEntity> => {
43
+ getCredential = async (args: GetCredentialArgs): Promise<DigitalCredential> => {
38
44
  const result: DigitalCredentialEntity | null = await (await this.dbConnection).getRepository(DigitalCredentialEntity).findOne({
39
45
  where: args,
40
46
  })
41
47
 
42
48
  if (!result) {
43
- return Promise.reject(Error(`No credential found for arg: ${args.toString()}`))
49
+ return Promise.reject(Error(`No credential found for arg: ${JSON.stringify(args)}`))
44
50
  }
45
- return result
51
+ return digitalCredentialFrom(result)
46
52
  }
47
53
 
48
54
  getCredentials = async (args?: GetCredentialsArgs): Promise<GetCredentialsResponse> => {
@@ -58,7 +64,7 @@ export class DigitalCredentialStore extends AbstractDigitalCredentialStore {
58
64
  order: sortOptions,
59
65
  })
60
66
  return {
61
- data: result,
67
+ data: digitalCredentialsFrom(result),
62
68
  total,
63
69
  }
64
70
  }
@@ -87,7 +93,7 @@ export class DigitalCredentialStore extends AbstractDigitalCredentialStore {
87
93
  }
88
94
  }
89
95
 
90
- updateCredentialState = async (args: UpdateCredentialStateArgs): Promise<DigitalCredentialEntity> => {
96
+ updateCredentialState = async (args: UpdateCredentialStateArgs): Promise<DigitalCredential> => {
91
97
  const credentialRepository: Repository<DigitalCredentialEntity> = (await this.dbConnection).getRepository(DigitalCredentialEntity)
92
98
  const whereClause: Record<string, any> = {}
93
99
  if ('id' in args) {
@@ -111,7 +117,7 @@ export class DigitalCredentialStore extends AbstractDigitalCredentialStore {
111
117
  })
112
118
 
113
119
  if (!credential) {
114
- return Promise.reject(Error(`No credential found for args: ${whereClause}`))
120
+ return Promise.reject(Error(`No credential found for args: ${JSON.stringify(whereClause)}`))
115
121
  }
116
122
  const updatedCredential: DigitalCredential = {
117
123
  ...credential,
@@ -122,6 +128,6 @@ export class DigitalCredentialStore extends AbstractDigitalCredentialStore {
122
128
  }
123
129
  debug('Updating credential', credential)
124
130
  const updatedResult: DigitalCredentialEntity = await credentialRepository.save(updatedCredential, { transaction: true })
125
- return updatedResult
131
+ return digitalCredentialFrom(updatedResult)
126
132
  }
127
133
  }
@@ -11,6 +11,7 @@ import {
11
11
  TableInheritance,
12
12
  UpdateDateColumn,
13
13
  } from 'typeorm'
14
+ import {TYPEORM_DATE_TIME_TYPE} from "@sphereon/ssi-sdk.agent-config";
14
15
  import { PartyEntity } from './PartyEntity'
15
16
  import { ContactMetadataItemEntity } from './ContactMetadataItemEntity'
16
17
 
@@ -20,10 +21,10 @@ export abstract class BaseContactEntity extends BaseEntity {
20
21
  @PrimaryGeneratedColumn('uuid')
21
22
  id!: string
22
23
 
23
- @CreateDateColumn({ name: 'created_at', nullable: false })
24
+ @CreateDateColumn({ name: 'created_at', nullable: false, type: TYPEORM_DATE_TIME_TYPE })
24
25
  createdAt!: Date
25
26
 
26
- @UpdateDateColumn({ name: 'last_updated_at', nullable: false })
27
+ @UpdateDateColumn({ name: 'last_updated_at', nullable: false, type: TYPEORM_DATE_TIME_TYPE })
27
28
  lastUpdatedAt!: Date
28
29
 
29
30
  @OneToOne(() => PartyEntity, (party: PartyEntity) => party.contact, {
@@ -13,10 +13,10 @@ export class ConnectionEntity extends BaseEntity {
13
13
  @Column('simple-enum', { name: 'type', enum: ConnectionType, nullable: false })
14
14
  type!: ConnectionType
15
15
 
16
- @Column({ name: 'tenant_id', nullable: true })
16
+ @Column('text', { name: 'tenant_id', nullable: true })
17
17
  tenantId?: string
18
18
 
19
- @Column({ name: 'owner_id', nullable: true })
19
+ @Column('text', { name: 'owner_id', nullable: true })
20
20
  ownerId?: string
21
21
 
22
22
  @OneToOne(() => BaseConfigEntity, (config: OpenIdConfigEntity | DidAuthConfigEntity) => config.connection, {
@@ -1,5 +1,6 @@
1
1
  import { Entity, Column, PrimaryGeneratedColumn, BaseEntity, ManyToOne, BeforeInsert, BeforeUpdate } from 'typeorm'
2
- import { ValidationConstraint } from '../../types'
2
+ import { IMetadataEntity, ValidationConstraint } from '../../types'
3
+ import {TYPEORM_DATE_TIME_TYPE} from "@sphereon/ssi-sdk.agent-config";
3
4
  import { BaseContactEntity } from './BaseContactEntity'
4
5
  import { IsNotEmpty, validate, ValidationError } from 'class-validator'
5
6
  import { getConstraint } from '../../utils/ValidatorUtils'
@@ -9,24 +10,24 @@ export class ContactMetadataItemEntity extends BaseEntity implements IMetadataEn
9
10
  @PrimaryGeneratedColumn('uuid')
10
11
  id!: string
11
12
 
12
- @Column({ name: 'label', length: 255, nullable: false })
13
+ @Column('varchar', { name: 'label', length: 255, nullable: false })
13
14
  @IsNotEmpty({ message: 'Blank metadata labels are not allowed' })
14
15
  label!: string
15
16
 
16
- @Column({ name: 'valueType', nullable: false })
17
+ @Column('varchar', { name: 'valueType', nullable: false })
17
18
  @IsNotEmpty({ message: 'valueType must not be empty' })
18
19
  valueType!: string
19
20
 
20
- @Column({ name: 'stringValue', length: 255, nullable: true })
21
+ @Column('varchar', { name: 'stringValue', length: 255, nullable: true })
21
22
  stringValue?: string
22
23
 
23
- @Column({ name: 'numberValue', nullable: true })
24
+ @Column('numeric', { name: 'numberValue', nullable: true })
24
25
  numberValue?: number
25
26
 
26
- @Column({ name: 'dateValue', nullable: true })
27
+ @Column({ name: 'dateValue', nullable: true, type: TYPEORM_DATE_TIME_TYPE })
27
28
  dateValue?: Date
28
29
 
29
- @Column({ name: 'boolValue', nullable: true })
30
+ @Column('boolean', { name: 'boolValue', nullable: true })
30
31
  boolValue?: boolean
31
32
 
32
33
  @ManyToOne(() => BaseContactEntity, (contact: BaseContactEntity) => contact.metadata, {
@@ -16,10 +16,10 @@ export class CorrelationIdentifierEntity extends BaseEntity {
16
16
  @IsNotEmpty({ message: 'Blank correlation ids are not allowed' })
17
17
  correlationId!: string
18
18
 
19
- @Column({ name: 'owner_id', nullable: true })
19
+ @Column('text', { name: 'owner_id', nullable: true })
20
20
  ownerId?: string
21
21
 
22
- @Column({ name: 'tenant_id', nullable: true })
22
+ @Column('text', { name: 'tenant_id', nullable: true })
23
23
  tenantId?: string
24
24
 
25
25
  @OneToOne(() => IdentityEntity, (identity: IdentityEntity) => identity.identifier, {