@cheqd/studio 3.0.0-develop.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +190 -0
- package/README.md +246 -0
- package/dist/app.d.ts +4 -0
- package/dist/app.d.ts.map +1 -0
- package/dist/app.js +180 -0
- package/dist/app.js.map +1 -0
- package/dist/controllers/admin/api-key.d.ts +153 -0
- package/dist/controllers/admin/api-key.d.ts.map +1 -0
- package/dist/controllers/admin/api-key.js +389 -0
- package/dist/controllers/admin/api-key.js.map +1 -0
- package/dist/controllers/admin/organisation.d.ts +72 -0
- package/dist/controllers/admin/organisation.d.ts.map +1 -0
- package/dist/controllers/admin/organisation.js +139 -0
- package/dist/controllers/admin/organisation.js.map +1 -0
- package/dist/controllers/admin/prices.d.ts +37 -0
- package/dist/controllers/admin/prices.d.ts.map +1 -0
- package/dist/controllers/admin/prices.js +75 -0
- package/dist/controllers/admin/prices.js.map +1 -0
- package/dist/controllers/admin/product.d.ts +90 -0
- package/dist/controllers/admin/product.d.ts.map +1 -0
- package/dist/controllers/admin/product.js +187 -0
- package/dist/controllers/admin/product.js.map +1 -0
- package/dist/controllers/admin/subscriptions.d.ts +183 -0
- package/dist/controllers/admin/subscriptions.d.ts.map +1 -0
- package/dist/controllers/admin/subscriptions.js +512 -0
- package/dist/controllers/admin/subscriptions.js.map +1 -0
- package/dist/controllers/admin/webhook.d.ts +5 -0
- package/dist/controllers/admin/webhook.d.ts.map +1 -0
- package/dist/controllers/admin/webhook.js +90 -0
- package/dist/controllers/admin/webhook.js.map +1 -0
- package/dist/controllers/api/account.d.ts +84 -0
- package/dist/controllers/api/account.d.ts.map +1 -0
- package/dist/controllers/api/account.js +442 -0
- package/dist/controllers/api/account.js.map +1 -0
- package/dist/controllers/api/credential-status.d.ts +257 -0
- package/dist/controllers/api/credential-status.d.ts.map +1 -0
- package/dist/controllers/api/credential-status.js +1080 -0
- package/dist/controllers/api/credential-status.js.map +1 -0
- package/dist/controllers/api/credential.d.ts +207 -0
- package/dist/controllers/api/credential.d.ts.map +1 -0
- package/dist/controllers/api/credential.js +527 -0
- package/dist/controllers/api/credential.js.map +1 -0
- package/dist/controllers/api/did.d.ts +259 -0
- package/dist/controllers/api/did.d.ts.map +1 -0
- package/dist/controllers/api/did.js +673 -0
- package/dist/controllers/api/did.js.map +1 -0
- package/dist/controllers/api/key.d.ts +136 -0
- package/dist/controllers/api/key.d.ts.map +1 -0
- package/dist/controllers/api/key.js +268 -0
- package/dist/controllers/api/key.js.map +1 -0
- package/dist/controllers/api/presentation.d.ts +87 -0
- package/dist/controllers/api/presentation.d.ts.map +1 -0
- package/dist/controllers/api/presentation.js +264 -0
- package/dist/controllers/api/presentation.js.map +1 -0
- package/dist/controllers/api/resource.d.ts +118 -0
- package/dist/controllers/api/resource.d.ts.map +1 -0
- package/dist/controllers/api/resource.js +312 -0
- package/dist/controllers/api/resource.js.map +1 -0
- package/dist/controllers/validator/controller.d.ts +7 -0
- package/dist/controllers/validator/controller.d.ts.map +1 -0
- package/dist/controllers/validator/controller.js +31 -0
- package/dist/controllers/validator/controller.js.map +1 -0
- package/dist/controllers/validator/credential-status.d.ts +6 -0
- package/dist/controllers/validator/credential-status.d.ts.map +1 -0
- package/dist/controllers/validator/credential-status.js +36 -0
- package/dist/controllers/validator/credential-status.js.map +1 -0
- package/dist/controllers/validator/credential.d.ts +9 -0
- package/dist/controllers/validator/credential.d.ts.map +1 -0
- package/dist/controllers/validator/credential.js +103 -0
- package/dist/controllers/validator/credential.js.map +1 -0
- package/dist/controllers/validator/decorator.d.ts +2 -0
- package/dist/controllers/validator/decorator.d.ts.map +1 -0
- package/dist/controllers/validator/decorator.js +25 -0
- package/dist/controllers/validator/decorator.js.map +1 -0
- package/dist/controllers/validator/did-also-known-as.d.ts +8 -0
- package/dist/controllers/validator/did-also-known-as.d.ts.map +1 -0
- package/dist/controllers/validator/did-also-known-as.js +31 -0
- package/dist/controllers/validator/did-also-known-as.js.map +1 -0
- package/dist/controllers/validator/did-array.d.ts +7 -0
- package/dist/controllers/validator/did-array.d.ts.map +1 -0
- package/dist/controllers/validator/did-array.js +27 -0
- package/dist/controllers/validator/did-array.js.map +1 -0
- package/dist/controllers/validator/did-document-section-id.d.ts +7 -0
- package/dist/controllers/validator/did-document-section-id.d.ts.map +1 -0
- package/dist/controllers/validator/did-document-section-id.js +43 -0
- package/dist/controllers/validator/did-document-section-id.js.map +1 -0
- package/dist/controllers/validator/did-document.d.ts +11 -0
- package/dist/controllers/validator/did-document.d.ts.map +1 -0
- package/dist/controllers/validator/did-document.js +96 -0
- package/dist/controllers/validator/did-document.js.map +1 -0
- package/dist/controllers/validator/did-uri.d.ts +5 -0
- package/dist/controllers/validator/did-uri.d.ts.map +1 -0
- package/dist/controllers/validator/did-uri.js +14 -0
- package/dist/controllers/validator/did-uri.js.map +1 -0
- package/dist/controllers/validator/did.d.ts +35 -0
- package/dist/controllers/validator/did.d.ts.map +1 -0
- package/dist/controllers/validator/did.js +233 -0
- package/dist/controllers/validator/did.js.map +1 -0
- package/dist/controllers/validator/helpers.d.ts +7 -0
- package/dist/controllers/validator/helpers.d.ts.map +1 -0
- package/dist/controllers/validator/helpers.js +6 -0
- package/dist/controllers/validator/helpers.js.map +1 -0
- package/dist/controllers/validator/identifier.d.ts +20 -0
- package/dist/controllers/validator/identifier.d.ts.map +1 -0
- package/dist/controllers/validator/identifier.js +100 -0
- package/dist/controllers/validator/identifier.js.map +1 -0
- package/dist/controllers/validator/index.d.ts +42 -0
- package/dist/controllers/validator/index.d.ts.map +1 -0
- package/dist/controllers/validator/index.js +90 -0
- package/dist/controllers/validator/index.js.map +1 -0
- package/dist/controllers/validator/jsonld-proof.d.ts +5 -0
- package/dist/controllers/validator/jsonld-proof.d.ts.map +1 -0
- package/dist/controllers/validator/jsonld-proof.js +50 -0
- package/dist/controllers/validator/jsonld-proof.js.map +1 -0
- package/dist/controllers/validator/jwt-proof.d.ts +5 -0
- package/dist/controllers/validator/jwt-proof.d.ts.map +1 -0
- package/dist/controllers/validator/jwt-proof.js +45 -0
- package/dist/controllers/validator/jwt-proof.js.map +1 -0
- package/dist/controllers/validator/presentation.d.ts +9 -0
- package/dist/controllers/validator/presentation.d.ts.map +1 -0
- package/dist/controllers/validator/presentation.js +96 -0
- package/dist/controllers/validator/presentation.js.map +1 -0
- package/dist/controllers/validator/resource-also-known-as.d.ts +7 -0
- package/dist/controllers/validator/resource-also-known-as.d.ts.map +1 -0
- package/dist/controllers/validator/resource-also-known-as.js +47 -0
- package/dist/controllers/validator/resource-also-known-as.js.map +1 -0
- package/dist/controllers/validator/service-create-request.d.ts +10 -0
- package/dist/controllers/validator/service-create-request.d.ts.map +1 -0
- package/dist/controllers/validator/service-create-request.js +63 -0
- package/dist/controllers/validator/service-create-request.js.map +1 -0
- package/dist/controllers/validator/service.d.ts +11 -0
- package/dist/controllers/validator/service.d.ts.map +1 -0
- package/dist/controllers/validator/service.js +76 -0
- package/dist/controllers/validator/service.js.map +1 -0
- package/dist/controllers/validator/utils.d.ts +3 -0
- package/dist/controllers/validator/utils.d.ts.map +1 -0
- package/dist/controllers/validator/utils.js +21 -0
- package/dist/controllers/validator/utils.js.map +1 -0
- package/dist/controllers/validator/validator.d.ts +20 -0
- package/dist/controllers/validator/validator.d.ts.map +1 -0
- package/dist/controllers/validator/validator.js +2 -0
- package/dist/controllers/validator/validator.js.map +1 -0
- package/dist/controllers/validator/verification-method.d.ts +30 -0
- package/dist/controllers/validator/verification-method.d.ts.map +1 -0
- package/dist/controllers/validator/verification-method.js +211 -0
- package/dist/controllers/validator/verification-method.js.map +1 -0
- package/dist/database/connection/connection.d.ts +9 -0
- package/dist/database/connection/connection.d.ts.map +1 -0
- package/dist/database/connection/connection.js +27 -0
- package/dist/database/connection/connection.js.map +1 -0
- package/dist/database/entities/api.key.entity.d.ts +18 -0
- package/dist/database/entities/api.key.entity.d.ts.map +1 -0
- package/dist/database/entities/api.key.entity.js +102 -0
- package/dist/database/entities/api.key.entity.js.map +1 -0
- package/dist/database/entities/coin.entity.d.ts +11 -0
- package/dist/database/entities/coin.entity.d.ts.map +1 -0
- package/dist/database/entities/coin.entity.js +66 -0
- package/dist/database/entities/coin.entity.js.map +1 -0
- package/dist/database/entities/customer.entity.d.ts +14 -0
- package/dist/database/entities/customer.entity.d.ts.map +1 -0
- package/dist/database/entities/customer.entity.js +87 -0
- package/dist/database/entities/customer.entity.js.map +1 -0
- package/dist/database/entities/identifier.entity.d.ts +7 -0
- package/dist/database/entities/identifier.entity.d.ts.map +1 -0
- package/dist/database/entities/identifier.entity.js +26 -0
- package/dist/database/entities/identifier.entity.js.map +1 -0
- package/dist/database/entities/key.entity.d.ts +13 -0
- package/dist/database/entities/key.entity.d.ts.map +1 -0
- package/dist/database/entities/key.entity.js +63 -0
- package/dist/database/entities/key.entity.js.map +1 -0
- package/dist/database/entities/operation.entity.d.ts +17 -0
- package/dist/database/entities/operation.entity.d.ts.map +1 -0
- package/dist/database/entities/operation.entity.js +98 -0
- package/dist/database/entities/operation.entity.js.map +1 -0
- package/dist/database/entities/payment.account.entity.d.ts +16 -0
- package/dist/database/entities/payment.account.entity.d.ts.map +1 -0
- package/dist/database/entities/payment.account.entity.js +86 -0
- package/dist/database/entities/payment.account.entity.js.map +1 -0
- package/dist/database/entities/payment.entity.d.ts +20 -0
- package/dist/database/entities/payment.entity.d.ts.map +1 -0
- package/dist/database/entities/payment.entity.js +103 -0
- package/dist/database/entities/payment.entity.js.map +1 -0
- package/dist/database/entities/resource.entity.d.ts +21 -0
- package/dist/database/entities/resource.entity.d.ts.map +1 -0
- package/dist/database/entities/resource.entity.js +117 -0
- package/dist/database/entities/resource.entity.js.map +1 -0
- package/dist/database/entities/role.entity.d.ts +7 -0
- package/dist/database/entities/role.entity.d.ts.map +1 -0
- package/dist/database/entities/role.entity.js +60 -0
- package/dist/database/entities/role.entity.js.map +1 -0
- package/dist/database/entities/subscription.entity.d.ts +16 -0
- package/dist/database/entities/subscription.entity.d.ts.map +1 -0
- package/dist/database/entities/subscription.entity.js +102 -0
- package/dist/database/entities/subscription.entity.js.map +1 -0
- package/dist/database/entities/user.entity.d.ts +13 -0
- package/dist/database/entities/user.entity.d.ts.map +1 -0
- package/dist/database/entities/user.entity.js +67 -0
- package/dist/database/entities/user.entity.js.map +1 -0
- package/dist/database/migrations/AlterAPIKeyTable.d.ts +6 -0
- package/dist/database/migrations/AlterAPIKeyTable.d.ts.map +1 -0
- package/dist/database/migrations/AlterAPIKeyTable.js +51 -0
- package/dist/database/migrations/AlterAPIKeyTable.js.map +1 -0
- package/dist/database/migrations/AlterCustomerTable.d.ts +6 -0
- package/dist/database/migrations/AlterCustomerTable.d.ts.map +1 -0
- package/dist/database/migrations/AlterCustomerTable.js +15 -0
- package/dist/database/migrations/AlterCustomerTable.js.map +1 -0
- package/dist/database/migrations/AlterCustomerTableAddEmail.d.ts +6 -0
- package/dist/database/migrations/AlterCustomerTableAddEmail.d.ts.map +1 -0
- package/dist/database/migrations/AlterCustomerTableAddEmail.js +20 -0
- package/dist/database/migrations/AlterCustomerTableAddEmail.js.map +1 -0
- package/dist/database/migrations/AlterOperationTable.d.ts +6 -0
- package/dist/database/migrations/AlterOperationTable.d.ts.map +1 -0
- package/dist/database/migrations/AlterOperationTable.js +38 -0
- package/dist/database/migrations/AlterOperationTable.js.map +1 -0
- package/dist/database/migrations/AlterOperationTableAddCustomer.d.ts +6 -0
- package/dist/database/migrations/AlterOperationTableAddCustomer.d.ts.map +1 -0
- package/dist/database/migrations/AlterOperationTableAddCustomer.js +22 -0
- package/dist/database/migrations/AlterOperationTableAddCustomer.js.map +1 -0
- package/dist/database/migrations/AlterOperationTableNewCategory.d.ts +6 -0
- package/dist/database/migrations/AlterOperationTableNewCategory.d.ts.map +1 -0
- package/dist/database/migrations/AlterOperationTableNewCategory.js +17 -0
- package/dist/database/migrations/AlterOperationTableNewCategory.js.map +1 -0
- package/dist/database/migrations/AlterPaymentTable.d.ts +6 -0
- package/dist/database/migrations/AlterPaymentTable.d.ts.map +1 -0
- package/dist/database/migrations/AlterPaymentTable.js +61 -0
- package/dist/database/migrations/AlterPaymentTable.js.map +1 -0
- package/dist/database/migrations/AlterTableClaim.d.ts +6 -0
- package/dist/database/migrations/AlterTableClaim.d.ts.map +1 -0
- package/dist/database/migrations/AlterTableClaim.js +21 -0
- package/dist/database/migrations/AlterTableClaim.js.map +1 -0
- package/dist/database/migrations/AlterTableIdentifier.d.ts +6 -0
- package/dist/database/migrations/AlterTableIdentifier.d.ts.map +1 -0
- package/dist/database/migrations/AlterTableIdentifier.js +21 -0
- package/dist/database/migrations/AlterTableIdentifier.js.map +1 -0
- package/dist/database/migrations/AlterTableKey.d.ts +6 -0
- package/dist/database/migrations/AlterTableKey.d.ts.map +1 -0
- package/dist/database/migrations/AlterTableKey.js +36 -0
- package/dist/database/migrations/AlterTableKey.js.map +1 -0
- package/dist/database/migrations/CreateApiKeyMigration.d.ts +6 -0
- package/dist/database/migrations/CreateApiKeyMigration.d.ts.map +1 -0
- package/dist/database/migrations/CreateApiKeyMigration.js +40 -0
- package/dist/database/migrations/CreateApiKeyMigration.js.map +1 -0
- package/dist/database/migrations/CreateCoinTable.d.ts +6 -0
- package/dist/database/migrations/CreateCoinTable.d.ts.map +1 -0
- package/dist/database/migrations/CreateCoinTable.js +20 -0
- package/dist/database/migrations/CreateCoinTable.js.map +1 -0
- package/dist/database/migrations/CreateCustomerTable.d.ts +6 -0
- package/dist/database/migrations/CreateCustomerTable.d.ts.map +1 -0
- package/dist/database/migrations/CreateCustomerTable.js +24 -0
- package/dist/database/migrations/CreateCustomerTable.js.map +1 -0
- package/dist/database/migrations/CreateCustomersTable.d.ts +6 -0
- package/dist/database/migrations/CreateCustomersTable.d.ts.map +1 -0
- package/dist/database/migrations/CreateCustomersTable.js +21 -0
- package/dist/database/migrations/CreateCustomersTable.js.map +1 -0
- package/dist/database/migrations/CreateOperationTable.d.ts +6 -0
- package/dist/database/migrations/CreateOperationTable.d.ts.map +1 -0
- package/dist/database/migrations/CreateOperationTable.js +28 -0
- package/dist/database/migrations/CreateOperationTable.js.map +1 -0
- package/dist/database/migrations/CreatePaymentAccountTable.d.ts +6 -0
- package/dist/database/migrations/CreatePaymentAccountTable.d.ts.map +1 -0
- package/dist/database/migrations/CreatePaymentAccountTable.js +35 -0
- package/dist/database/migrations/CreatePaymentAccountTable.js.map +1 -0
- package/dist/database/migrations/CreatePaymentTable.d.ts +6 -0
- package/dist/database/migrations/CreatePaymentTable.d.ts.map +1 -0
- package/dist/database/migrations/CreatePaymentTable.js +55 -0
- package/dist/database/migrations/CreatePaymentTable.js.map +1 -0
- package/dist/database/migrations/CreateResourceTable.d.ts +6 -0
- package/dist/database/migrations/CreateResourceTable.d.ts.map +1 -0
- package/dist/database/migrations/CreateResourceTable.js +46 -0
- package/dist/database/migrations/CreateResourceTable.js.map +1 -0
- package/dist/database/migrations/CreateRoleTable.d.ts +6 -0
- package/dist/database/migrations/CreateRoleTable.d.ts.map +1 -0
- package/dist/database/migrations/CreateRoleTable.js +25 -0
- package/dist/database/migrations/CreateRoleTable.js.map +1 -0
- package/dist/database/migrations/CreateSubscriptionTable.d.ts +6 -0
- package/dist/database/migrations/CreateSubscriptionTable.d.ts.map +1 -0
- package/dist/database/migrations/CreateSubscriptionTable.js +30 -0
- package/dist/database/migrations/CreateSubscriptionTable.js.map +1 -0
- package/dist/database/migrations/CreateUserTable.d.ts +6 -0
- package/dist/database/migrations/CreateUserTable.d.ts.map +1 -0
- package/dist/database/migrations/CreateUserTable.js +32 -0
- package/dist/database/migrations/CreateUserTable.js.map +1 -0
- package/dist/database/migrations/MigrateData.d.ts +7 -0
- package/dist/database/migrations/MigrateData.d.ts.map +1 -0
- package/dist/database/migrations/MigrateData.js +138 -0
- package/dist/database/migrations/MigrateData.js.map +1 -0
- package/dist/database/ormconfig.d.ts +2 -0
- package/dist/database/ormconfig.d.ts.map +1 -0
- package/dist/database/ormconfig.js +3 -0
- package/dist/database/ormconfig.js.map +1 -0
- package/dist/database/types/enum.d.ts +21 -0
- package/dist/database/types/enum.d.ts.map +1 -0
- package/dist/database/types/enum.js +35 -0
- package/dist/database/types/enum.js.map +1 -0
- package/dist/database/types/types.d.ts +11 -0
- package/dist/database/types/types.d.ts.map +1 -0
- package/dist/database/types/types.js +127 -0
- package/dist/database/types/types.js.map +1 -0
- package/dist/helpers/faucet.d.ts +5 -0
- package/dist/helpers/faucet.d.ts.map +1 -0
- package/dist/helpers/faucet.js +24 -0
- package/dist/helpers/faucet.js.map +1 -0
- package/dist/helpers/fee-analyzer.d.ts +8 -0
- package/dist/helpers/fee-analyzer.d.ts.map +1 -0
- package/dist/helpers/fee-analyzer.js +73 -0
- package/dist/helpers/fee-analyzer.js.map +1 -0
- package/dist/helpers/helpers.d.ts +28 -0
- package/dist/helpers/helpers.d.ts.map +1 -0
- package/dist/helpers/helpers.js +167 -0
- package/dist/helpers/helpers.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +28 -0
- package/dist/index.js.map +1 -0
- package/dist/middleware/auth/auth-gaurd.d.ts +51 -0
- package/dist/middleware/auth/auth-gaurd.d.ts.map +1 -0
- package/dist/middleware/auth/auth-gaurd.js +117 -0
- package/dist/middleware/auth/auth-gaurd.js.map +1 -0
- package/dist/middleware/auth/logto-helper.d.ts +44 -0
- package/dist/middleware/auth/logto-helper.d.ts.map +1 -0
- package/dist/middleware/auth/logto-helper.js +438 -0
- package/dist/middleware/auth/logto-helper.js.map +1 -0
- package/dist/middleware/auth/oauth/abstract.d.ts +22 -0
- package/dist/middleware/auth/oauth/abstract.d.ts.map +1 -0
- package/dist/middleware/auth/oauth/abstract.js +24 -0
- package/dist/middleware/auth/oauth/abstract.js.map +1 -0
- package/dist/middleware/auth/oauth/logto-provider.d.ts +15 -0
- package/dist/middleware/auth/oauth/logto-provider.d.ts.map +1 -0
- package/dist/middleware/auth/oauth/logto-provider.js +42 -0
- package/dist/middleware/auth/oauth/logto-provider.js.map +1 -0
- package/dist/middleware/auth/routes/admin/admin-auth.d.ts +8 -0
- package/dist/middleware/auth/routes/admin/admin-auth.d.ts.map +1 -0
- package/dist/middleware/auth/routes/admin/admin-auth.js +44 -0
- package/dist/middleware/auth/routes/admin/admin-auth.js.map +1 -0
- package/dist/middleware/auth/routes/api/account-auth.d.ts +5 -0
- package/dist/middleware/auth/routes/api/account-auth.d.ts.map +1 -0
- package/dist/middleware/auth/routes/api/account-auth.js +9 -0
- package/dist/middleware/auth/routes/api/account-auth.js.map +1 -0
- package/dist/middleware/auth/routes/api/auth-user-info.d.ts +5 -0
- package/dist/middleware/auth/routes/api/auth-user-info.d.ts.map +1 -0
- package/dist/middleware/auth/routes/api/auth-user-info.js +8 -0
- package/dist/middleware/auth/routes/api/auth-user-info.js.map +1 -0
- package/dist/middleware/auth/routes/api/credential-auth.d.ts +5 -0
- package/dist/middleware/auth/routes/api/credential-auth.d.ts.map +1 -0
- package/dist/middleware/auth/routes/api/credential-auth.js +17 -0
- package/dist/middleware/auth/routes/api/credential-auth.js.map +1 -0
- package/dist/middleware/auth/routes/api/credential-status-auth.d.ts +5 -0
- package/dist/middleware/auth/routes/api/credential-status-auth.d.ts.map +1 -0
- package/dist/middleware/auth/routes/api/credential-status-auth.js +20 -0
- package/dist/middleware/auth/routes/api/credential-status-auth.js.map +1 -0
- package/dist/middleware/auth/routes/api/did-auth.d.ts +5 -0
- package/dist/middleware/auth/routes/api/did-auth.d.ts.map +1 -0
- package/dist/middleware/auth/routes/api/did-auth.js +19 -0
- package/dist/middleware/auth/routes/api/did-auth.js.map +1 -0
- package/dist/middleware/auth/routes/api/key-auth.d.ts +5 -0
- package/dist/middleware/auth/routes/api/key-auth.d.ts.map +1 -0
- package/dist/middleware/auth/routes/api/key-auth.js +11 -0
- package/dist/middleware/auth/routes/api/key-auth.js.map +1 -0
- package/dist/middleware/auth/routes/api/presentation-auth.d.ts +5 -0
- package/dist/middleware/auth/routes/api/presentation-auth.d.ts.map +1 -0
- package/dist/middleware/auth/routes/api/presentation-auth.js +10 -0
- package/dist/middleware/auth/routes/api/presentation-auth.js.map +1 -0
- package/dist/middleware/auth/routes/api/resource-auth.d.ts +5 -0
- package/dist/middleware/auth/routes/api/resource-auth.d.ts.map +1 -0
- package/dist/middleware/auth/routes/api/resource-auth.js +11 -0
- package/dist/middleware/auth/routes/api/resource-auth.js.map +1 -0
- package/dist/middleware/auth/routes/auth-rule-provider.d.ts +33 -0
- package/dist/middleware/auth/routes/auth-rule-provider.d.ts.map +1 -0
- package/dist/middleware/auth/routes/auth-rule-provider.js +39 -0
- package/dist/middleware/auth/routes/auth-rule-provider.js.map +1 -0
- package/dist/middleware/auth/routes/auth-rule-repository.d.ts +21 -0
- package/dist/middleware/auth/routes/auth-rule-repository.d.ts.map +1 -0
- package/dist/middleware/auth/routes/auth-rule-repository.js +28 -0
- package/dist/middleware/auth/routes/auth-rule-repository.js.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/api-token.d.ts +17 -0
- package/dist/middleware/auth/user-info-fetcher/api-token.d.ts.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/api-token.js +60 -0
- package/dist/middleware/auth/user-info-fetcher/api-token.js.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/base.d.ts +14 -0
- package/dist/middleware/auth/user-info-fetcher/base.d.ts.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/base.js +38 -0
- package/dist/middleware/auth/user-info-fetcher/base.js.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/idtoken.d.ts +18 -0
- package/dist/middleware/auth/user-info-fetcher/idtoken.d.ts.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/idtoken.js +56 -0
- package/dist/middleware/auth/user-info-fetcher/idtoken.js.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/m2m-creds-token.d.ts +18 -0
- package/dist/middleware/auth/user-info-fetcher/m2m-creds-token.d.ts.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/m2m-creds-token.js +52 -0
- package/dist/middleware/auth/user-info-fetcher/m2m-creds-token.js.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/portal-token.d.ts +20 -0
- package/dist/middleware/auth/user-info-fetcher/portal-token.d.ts.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/portal-token.js +79 -0
- package/dist/middleware/auth/user-info-fetcher/portal-token.js.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/swagger-ui.d.ts +16 -0
- package/dist/middleware/auth/user-info-fetcher/swagger-ui.d.ts.map +1 -0
- package/dist/middleware/auth/user-info-fetcher/swagger-ui.js +48 -0
- package/dist/middleware/auth/user-info-fetcher/swagger-ui.js.map +1 -0
- package/dist/middleware/authentication.d.ts +15 -0
- package/dist/middleware/authentication.d.ts.map +1 -0
- package/dist/middleware/authentication.js +110 -0
- package/dist/middleware/authentication.js.map +1 -0
- package/dist/middleware/event-tracker.d.ts +5 -0
- package/dist/middleware/event-tracker.d.ts.map +1 -0
- package/dist/middleware/event-tracker.js +34 -0
- package/dist/middleware/event-tracker.js.map +1 -0
- package/dist/middleware/hook.d.ts +9 -0
- package/dist/middleware/hook.d.ts.map +1 -0
- package/dist/middleware/hook.js +24 -0
- package/dist/middleware/hook.js.map +1 -0
- package/dist/middleware/middleware.d.ts +6 -0
- package/dist/middleware/middleware.d.ts.map +1 -0
- package/dist/middleware/middleware.js +36 -0
- package/dist/middleware/middleware.js.map +1 -0
- package/dist/services/admin/api-key.d.ts +30 -0
- package/dist/services/admin/api-key.d.ts.map +1 -0
- package/dist/services/admin/api-key.js +135 -0
- package/dist/services/admin/api-key.js.map +1 -0
- package/dist/services/admin/stripe.d.ts +18 -0
- package/dist/services/admin/stripe.d.ts.map +1 -0
- package/dist/services/admin/stripe.js +125 -0
- package/dist/services/admin/stripe.js.map +1 -0
- package/dist/services/admin/subscription.d.ts +16 -0
- package/dist/services/admin/subscription.d.ts.map +1 -0
- package/dist/services/admin/subscription.js +75 -0
- package/dist/services/admin/subscription.js.map +1 -0
- package/dist/services/api/coin.d.ts +13 -0
- package/dist/services/api/coin.d.ts.map +1 -0
- package/dist/services/api/coin.js +49 -0
- package/dist/services/api/coin.js.map +1 -0
- package/dist/services/api/credentials.d.ts +8 -0
- package/dist/services/api/credentials.d.ts.map +1 -0
- package/dist/services/api/credentials.js +38 -0
- package/dist/services/api/credentials.js.map +1 -0
- package/dist/services/api/customer.d.ts +19 -0
- package/dist/services/api/customer.d.ts.map +1 -0
- package/dist/services/api/customer.js +88 -0
- package/dist/services/api/customer.js.map +1 -0
- package/dist/services/api/identifier.d.ts +12 -0
- package/dist/services/api/identifier.d.ts.map +1 -0
- package/dist/services/api/identifier.js +38 -0
- package/dist/services/api/identifier.js.map +1 -0
- package/dist/services/api/key.d.ts +14 -0
- package/dist/services/api/key.d.ts.map +1 -0
- package/dist/services/api/key.js +49 -0
- package/dist/services/api/key.js.map +1 -0
- package/dist/services/api/operation.d.ts +14 -0
- package/dist/services/api/operation.d.ts.map +1 -0
- package/dist/services/api/operation.js +61 -0
- package/dist/services/api/operation.js.map +1 -0
- package/dist/services/api/payment-account.d.ts +14 -0
- package/dist/services/api/payment-account.d.ts.map +1 -0
- package/dist/services/api/payment-account.js +68 -0
- package/dist/services/api/payment-account.js.map +1 -0
- package/dist/services/api/payment.d.ts +17 -0
- package/dist/services/api/payment.d.ts.map +1 -0
- package/dist/services/api/payment.js +68 -0
- package/dist/services/api/payment.js.map +1 -0
- package/dist/services/api/resource.d.ts +17 -0
- package/dist/services/api/resource.d.ts.map +1 -0
- package/dist/services/api/resource.js +65 -0
- package/dist/services/api/resource.js.map +1 -0
- package/dist/services/api/role.d.ts +14 -0
- package/dist/services/api/role.d.ts.map +1 -0
- package/dist/services/api/role.js +53 -0
- package/dist/services/api/role.js.map +1 -0
- package/dist/services/api/store.d.ts +8 -0
- package/dist/services/api/store.d.ts.map +1 -0
- package/dist/services/api/store.js +18 -0
- package/dist/services/api/store.js.map +1 -0
- package/dist/services/api/user.d.ts +15 -0
- package/dist/services/api/user.d.ts.map +1 -0
- package/dist/services/api/user.js +54 -0
- package/dist/services/api/user.js.map +1 -0
- package/dist/services/connectors/verida.d.ts +40 -0
- package/dist/services/connectors/verida.d.ts.map +1 -0
- package/dist/services/connectors/verida.js +110 -0
- package/dist/services/connectors/verida.js.map +1 -0
- package/dist/services/helpers.d.ts +10 -0
- package/dist/services/helpers.d.ts.map +1 -0
- package/dist/services/helpers.js +44 -0
- package/dist/services/helpers.js.map +1 -0
- package/dist/services/identity/abstract.d.ts +51 -0
- package/dist/services/identity/abstract.d.ts.map +1 -0
- package/dist/services/identity/abstract.js +101 -0
- package/dist/services/identity/abstract.js.map +1 -0
- package/dist/services/identity/agent.d.ts +43 -0
- package/dist/services/identity/agent.d.ts.map +1 -0
- package/dist/services/identity/agent.js +625 -0
- package/dist/services/identity/agent.js.map +1 -0
- package/dist/services/identity/default.d.ts +19 -0
- package/dist/services/identity/default.d.ts.map +1 -0
- package/dist/services/identity/default.js +26 -0
- package/dist/services/identity/default.js.map +1 -0
- package/dist/services/identity/index.d.ts +59 -0
- package/dist/services/identity/index.d.ts.map +1 -0
- package/dist/services/identity/index.js +31 -0
- package/dist/services/identity/index.js.map +1 -0
- package/dist/services/identity/local.d.ts +33 -0
- package/dist/services/identity/local.d.ts.map +1 -0
- package/dist/services/identity/local.js +156 -0
- package/dist/services/identity/local.js.map +1 -0
- package/dist/services/identity/postgres.d.ts +59 -0
- package/dist/services/identity/postgres.d.ts.map +1 -0
- package/dist/services/identity/postgres.js +388 -0
- package/dist/services/identity/postgres.js.map +1 -0
- package/dist/services/identity/unauthorized.d.ts +6 -0
- package/dist/services/identity/unauthorized.d.ts.map +1 -0
- package/dist/services/identity/unauthorized.js +49 -0
- package/dist/services/identity/unauthorized.js.map +1 -0
- package/dist/services/track/admin/account-submitter.d.ts +11 -0
- package/dist/services/track/admin/account-submitter.d.ts.map +1 -0
- package/dist/services/track/admin/account-submitter.js +54 -0
- package/dist/services/track/admin/account-submitter.js.map +1 -0
- package/dist/services/track/admin/subscription-submitter.d.ts +13 -0
- package/dist/services/track/admin/subscription-submitter.d.ts.map +1 -0
- package/dist/services/track/admin/subscription-submitter.js +106 -0
- package/dist/services/track/admin/subscription-submitter.js.map +1 -0
- package/dist/services/track/api/credential-status-subscriber.d.ts +10 -0
- package/dist/services/track/api/credential-status-subscriber.d.ts.map +1 -0
- package/dist/services/track/api/credential-status-subscriber.js +35 -0
- package/dist/services/track/api/credential-status-subscriber.js.map +1 -0
- package/dist/services/track/api/credential-subscriber.d.ts +10 -0
- package/dist/services/track/api/credential-subscriber.d.ts.map +1 -0
- package/dist/services/track/api/credential-subscriber.js +35 -0
- package/dist/services/track/api/credential-subscriber.js.map +1 -0
- package/dist/services/track/api/did-subscriber.d.ts +10 -0
- package/dist/services/track/api/did-subscriber.d.ts.map +1 -0
- package/dist/services/track/api/did-subscriber.js +33 -0
- package/dist/services/track/api/did-subscriber.js.map +1 -0
- package/dist/services/track/api/key-subscriber.d.ts +10 -0
- package/dist/services/track/api/key-subscriber.d.ts.map +1 -0
- package/dist/services/track/api/key-subscriber.js +35 -0
- package/dist/services/track/api/key-subscriber.js.map +1 -0
- package/dist/services/track/api/presentation-subscriber.d.ts +10 -0
- package/dist/services/track/api/presentation-subscriber.d.ts.map +1 -0
- package/dist/services/track/api/presentation-subscriber.js +35 -0
- package/dist/services/track/api/presentation-subscriber.js.map +1 -0
- package/dist/services/track/api/resource-subscriber.d.ts +11 -0
- package/dist/services/track/api/resource-subscriber.d.ts.map +1 -0
- package/dist/services/track/api/resource-subscriber.js +107 -0
- package/dist/services/track/api/resource-subscriber.js.map +1 -0
- package/dist/services/track/base.d.ts +10 -0
- package/dist/services/track/base.d.ts.map +1 -0
- package/dist/services/track/base.js +26 -0
- package/dist/services/track/base.js.map +1 -0
- package/dist/services/track/helpers.d.ts +23 -0
- package/dist/services/track/helpers.d.ts.map +1 -0
- package/dist/services/track/helpers.js +35 -0
- package/dist/services/track/helpers.js.map +1 -0
- package/dist/services/track/notifiers.d.ts +12 -0
- package/dist/services/track/notifiers.d.ts.map +1 -0
- package/dist/services/track/notifiers.js +39 -0
- package/dist/services/track/notifiers.js.map +1 -0
- package/dist/services/track/observer.d.ts +14 -0
- package/dist/services/track/observer.d.ts.map +1 -0
- package/dist/services/track/observer.js +43 -0
- package/dist/services/track/observer.js.map +1 -0
- package/dist/services/track/operation-subscriber.d.ts +14 -0
- package/dist/services/track/operation-subscriber.d.ts.map +1 -0
- package/dist/services/track/operation-subscriber.js +112 -0
- package/dist/services/track/operation-subscriber.js.map +1 -0
- package/dist/services/track/submitter.d.ts +22 -0
- package/dist/services/track/submitter.d.ts.map +1 -0
- package/dist/services/track/submitter.js +2 -0
- package/dist/services/track/submitter.js.map +1 -0
- package/dist/services/track/tracker.d.ts +24 -0
- package/dist/services/track/tracker.d.ts.map +1 -0
- package/dist/services/track/tracker.js +79 -0
- package/dist/services/track/tracker.js.map +1 -0
- package/dist/services/track/types.d.ts +16 -0
- package/dist/services/track/types.d.ts.map +1 -0
- package/dist/services/track/types.js +2 -0
- package/dist/services/track/types.js.map +1 -0
- package/dist/services/w3c-credential.d.ts +32 -0
- package/dist/services/w3c-credential.d.ts.map +1 -0
- package/dist/services/w3c-credential.js +120 -0
- package/dist/services/w3c-credential.js.map +1 -0
- package/dist/services/w3c-presentation.d.ts +30 -0
- package/dist/services/w3c-presentation.d.ts.map +1 -0
- package/dist/services/w3c-presentation.js +95 -0
- package/dist/services/w3c-presentation.js.map +1 -0
- package/dist/static/custom-button.d.ts +2 -0
- package/dist/static/custom-button.d.ts.map +1 -0
- package/dist/static/custom-button.js +35 -0
- package/dist/static/custom-button.js.map +1 -0
- package/dist/static/swagger-admin.json +1191 -0
- package/dist/static/swagger-api.json +3564 -0
- package/dist/types/admin.d.ts +122 -0
- package/dist/types/admin.d.ts.map +1 -0
- package/dist/types/admin.js +2 -0
- package/dist/types/admin.js.map +1 -0
- package/dist/types/authentication.d.ts +30 -0
- package/dist/types/authentication.d.ts.map +1 -0
- package/dist/types/authentication.js +131 -0
- package/dist/types/authentication.js.map +1 -0
- package/dist/types/constants.d.ts +98 -0
- package/dist/types/constants.d.ts.map +1 -0
- package/dist/types/constants.js +138 -0
- package/dist/types/constants.js.map +1 -0
- package/dist/types/credential-status.d.ts +168 -0
- package/dist/types/credential-status.d.ts.map +1 -0
- package/dist/types/credential-status.js +12 -0
- package/dist/types/credential-status.js.map +1 -0
- package/dist/types/credential.d.ts +55 -0
- package/dist/types/credential.d.ts.map +1 -0
- package/dist/types/credential.js +2 -0
- package/dist/types/credential.js.map +1 -0
- package/dist/types/customer.d.ts +18 -0
- package/dist/types/customer.d.ts.map +1 -0
- package/dist/types/customer.js +2 -0
- package/dist/types/customer.js.map +1 -0
- package/dist/types/did.d.ts +56 -0
- package/dist/types/did.d.ts.map +1 -0
- package/dist/types/did.js +2 -0
- package/dist/types/did.js.map +1 -0
- package/dist/types/key.d.ts +23 -0
- package/dist/types/key.d.ts.map +1 -0
- package/dist/types/key.js +2 -0
- package/dist/types/key.js.map +1 -0
- package/dist/types/presentation.d.ts +19 -0
- package/dist/types/presentation.d.ts.map +1 -0
- package/dist/types/presentation.js +2 -0
- package/dist/types/presentation.js.map +1 -0
- package/dist/types/resource.d.ts +26 -0
- package/dist/types/resource.d.ts.map +1 -0
- package/dist/types/resource.js +2 -0
- package/dist/types/resource.js.map +1 -0
- package/dist/types/shared.d.ts +51 -0
- package/dist/types/shared.d.ts.map +1 -0
- package/dist/types/shared.js +24 -0
- package/dist/types/shared.js.map +1 -0
- package/dist/types/swagger-admin-types.d.ts +352 -0
- package/dist/types/swagger-admin-types.d.ts.map +1 -0
- package/dist/types/swagger-admin-types.js +353 -0
- package/dist/types/swagger-admin-types.js.map +1 -0
- package/dist/types/swagger-api-types.d.ts +1312 -0
- package/dist/types/swagger-api-types.d.ts.map +1 -0
- package/dist/types/swagger-api-types.js +1313 -0
- package/dist/types/swagger-api-types.js.map +1 -0
- package/dist/types/track.d.ts +72 -0
- package/dist/types/track.d.ts.map +1 -0
- package/dist/types/track.js +37 -0
- package/dist/types/track.js.map +1 -0
- package/dist/types/validation.d.ts +23 -0
- package/dist/types/validation.d.ts.map +1 -0
- package/dist/types/validation.js +2 -0
- package/dist/types/validation.js.map +1 -0
- package/dist/types/verida.d.ts +23 -0
- package/dist/types/verida.d.ts.map +1 -0
- package/dist/types/verida.js +2 -0
- package/dist/types/verida.js.map +1 -0
- package/example.env +43 -0
- package/package.json +156 -0
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Connection } from '../../database/connection/connection.js';
|
|
2
|
+
import { CoinEntity } from '../../database/entities/coin.entity.js';
|
|
3
|
+
import { MINIMAL_DENOM } from '../../types/constants.js';
|
|
4
|
+
import { v4 } from 'uuid';
|
|
5
|
+
export class CoinService {
|
|
6
|
+
coinRepository;
|
|
7
|
+
// Get rid of such code and move it to the builder
|
|
8
|
+
static instance = new CoinService();
|
|
9
|
+
constructor() {
|
|
10
|
+
this.coinRepository = Connection.instance.dbConnection.getRepository(CoinEntity);
|
|
11
|
+
}
|
|
12
|
+
async create(amount, denom = MINIMAL_DENOM) {
|
|
13
|
+
const coindId = v4();
|
|
14
|
+
const coinEntity = new CoinEntity(coindId, amount, denom);
|
|
15
|
+
const res = await this.coinRepository.insert(coinEntity);
|
|
16
|
+
if (!res)
|
|
17
|
+
throw new Error(`Cannot create a new coin`);
|
|
18
|
+
return coinEntity;
|
|
19
|
+
}
|
|
20
|
+
async update(coinId, amount, denom = MINIMAL_DENOM) {
|
|
21
|
+
const existing = await this.coinRepository.findOneBy({ coinId });
|
|
22
|
+
if (!existing) {
|
|
23
|
+
throw new Error(`logToId not found`);
|
|
24
|
+
}
|
|
25
|
+
if (amount)
|
|
26
|
+
existing.amount = amount;
|
|
27
|
+
existing.denom = denom;
|
|
28
|
+
return await this.coinRepository.save(existing);
|
|
29
|
+
}
|
|
30
|
+
async get(coinId) {
|
|
31
|
+
return await this.coinRepository.findOne({
|
|
32
|
+
where: { coinId },
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
async findOne(where) {
|
|
36
|
+
return await this.coinRepository.findOne({
|
|
37
|
+
where: where,
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
async isExist(where) {
|
|
41
|
+
try {
|
|
42
|
+
return (await this.coinRepository.findOne({ where })) ? true : false;
|
|
43
|
+
}
|
|
44
|
+
catch {
|
|
45
|
+
return false;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=coin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coin.js","sourceRoot":"","sources":["../../../src/services/api/coin.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,yCAAyC,CAAC;AACrE,OAAO,EAAE,UAAU,EAAE,MAAM,wCAAwC,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AAE1B,MAAM,OAAO,WAAW;IAChB,cAAc,CAAyB;IAE9C,kDAAkD;IAC3C,MAAM,CAAC,QAAQ,GAAG,IAAI,WAAW,EAAE,CAAC;IAE3C;QACC,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IAClF,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,MAAc,EAAE,KAAK,GAAG,aAAa;QACxD,MAAM,OAAO,GAAG,EAAE,EAAE,CAAC;QACrB,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;QAC1D,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAEtD,OAAO,UAAU,CAAC;IACnB,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,MAAc,EAAE,MAAe,EAAE,KAAK,GAAG,aAAa;QACzE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACjE,IAAI,CAAC,QAAQ,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,MAAM;YAAE,QAAQ,CAAC,MAAM,GAAG,MAAM,CAAC;QACrC,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;QACvB,OAAO,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACjD,CAAC;IAEM,KAAK,CAAC,GAAG,CAAC,MAAe;QAC/B,OAAO,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;YACxC,KAAK,EAAE,EAAE,MAAM,EAAE;SACjB,CAAC,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,OAAO,CAAC,KAA8B;QAClD,OAAO,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;YACxC,KAAK,EAAE,KAAK;SACZ,CAAC,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,OAAO,CAAC,KAA8B;QAClD,IAAI,CAAC;YACJ,OAAO,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACtE,CAAC;QAAC,MAAM,CAAC;YACR,OAAO,KAAK,CAAC;QACd,CAAC;IACF,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { VerifiableCredential } from '@veramo/core';
|
|
2
|
+
import type { CredentialRequest } from '../../types/credential.js';
|
|
3
|
+
import type { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
4
|
+
export declare class Credentials {
|
|
5
|
+
static instance: Credentials;
|
|
6
|
+
issue_credential(request: CredentialRequest, customer: CustomerEntity): Promise<VerifiableCredential>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=credentials.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credentials.d.ts","sourceRoot":"","sources":["../../../src/services/api/credentials.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAqB,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAG5E,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAInE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAMjF,qBAAa,WAAW;IACvB,OAAc,QAAQ,cAAqB;IAErC,gBAAgB,CAAC,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,cAAc,GAAG,OAAO,CAAC,oBAAoB,CAAC;CA0C3G"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { VC_CONTEXT, VC_TYPE } from '../../types/constants.js';
|
|
2
|
+
import { IdentityServiceStrategySetup } from '../identity/index.js';
|
|
3
|
+
import { v4 } from 'uuid';
|
|
4
|
+
import * as dotenv from 'dotenv';
|
|
5
|
+
import { VeridaDIDValidator } from '../../controllers/validator/did.js';
|
|
6
|
+
dotenv.config();
|
|
7
|
+
const { ENABLE_VERIDA_CONNECTOR } = process.env;
|
|
8
|
+
export class Credentials {
|
|
9
|
+
static instance = new Credentials();
|
|
10
|
+
async issue_credential(request, customer) {
|
|
11
|
+
const credential = {
|
|
12
|
+
'@context': [...(request['@context'] || []), ...VC_CONTEXT],
|
|
13
|
+
type: [...(request.type || []), VC_TYPE],
|
|
14
|
+
issuer: { id: request.issuerDid },
|
|
15
|
+
credentialSchema: request.credentialSchema,
|
|
16
|
+
credentialSubject: {
|
|
17
|
+
id: request.subjectDid,
|
|
18
|
+
...request.attributes,
|
|
19
|
+
},
|
|
20
|
+
issuanceDate: new Date().toISOString(),
|
|
21
|
+
};
|
|
22
|
+
if (request.expirationDate) {
|
|
23
|
+
credential.expirationDate = request.expirationDate;
|
|
24
|
+
}
|
|
25
|
+
const statusOptions = request.credentialStatus || null;
|
|
26
|
+
const verifiable_credential = await new IdentityServiceStrategySetup(customer.customerId).agent.createCredential(credential, request.format, statusOptions, customer);
|
|
27
|
+
const isVeridaDid = new VeridaDIDValidator().validate(request.subjectDid);
|
|
28
|
+
if (ENABLE_VERIDA_CONNECTOR === 'true' && isVeridaDid.valid && isVeridaDid.namespace) {
|
|
29
|
+
if (!request.credentialSchema)
|
|
30
|
+
throw new Error('Credential schema is required');
|
|
31
|
+
// dynamic import to avoid circular dependency
|
|
32
|
+
const { VeridaService } = await import('../connectors/verida.js');
|
|
33
|
+
await VeridaService.instance.sendCredential(isVeridaDid.namespace, request.subjectDid, 'New Verifiable Credential', verifiable_credential, request.credentialName || v4(), request.credentialSchema, request.credentialSummary);
|
|
34
|
+
}
|
|
35
|
+
return verifiable_credential;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=credentials.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credentials.js","sourceRoot":"","sources":["../../../src/services/api/credentials.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AAE/D,OAAO,EAAE,4BAA4B,EAAE,MAAM,sBAAsB,CAAC;AACpE,OAAO,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AAC1B,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AAEjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,EAAE,uBAAuB,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC;AAEhD,MAAM,OAAO,WAAW;IAChB,MAAM,CAAC,QAAQ,GAAG,IAAI,WAAW,EAAE,CAAC;IAE3C,KAAK,CAAC,gBAAgB,CAAC,OAA0B,EAAE,QAAwB;QAC1E,MAAM,UAAU,GAAsB;YACrC,UAAU,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,EAAE,GAAG,UAAU,CAAC;YAC3D,IAAI,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,IAAI,EAAE,CAAC,EAAE,OAAO,CAAC;YACxC,MAAM,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,SAAS,EAAE;YACjC,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;YAC1C,iBAAiB,EAAE;gBAClB,EAAE,EAAE,OAAO,CAAC,UAAU;gBACtB,GAAG,OAAO,CAAC,UAAU;aACrB;YACD,YAAY,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACtC,CAAC;QAEF,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;YAC5B,UAAU,CAAC,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC;QACpD,CAAC;QAED,MAAM,aAAa,GAAG,OAAO,CAAC,gBAAgB,IAAI,IAAI,CAAC;QAEvD,MAAM,qBAAqB,GAAG,MAAM,IAAI,4BAA4B,CACnE,QAAQ,CAAC,UAAU,CACnB,CAAC,KAAK,CAAC,gBAAgB,CAAC,UAAU,EAAE,OAAO,CAAC,MAAM,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;QAE9E,MAAM,WAAW,GAAG,IAAI,kBAAkB,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAC1E,IAAI,uBAAuB,KAAK,MAAM,IAAI,WAAW,CAAC,KAAK,IAAI,WAAW,CAAC,SAAS,EAAE,CAAC;YACtF,IAAI,CAAC,OAAO,CAAC,gBAAgB;gBAAE,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;YAEhF,8CAA8C;YAC9C,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,MAAM,CAAC,yBAAyB,CAAC,CAAC;YAElE,MAAM,aAAa,CAAC,QAAQ,CAAC,cAAc,CAC1C,WAAW,CAAC,SAAS,EACrB,OAAO,CAAC,UAAU,EAClB,2BAA2B,EAC3B,qBAAqB,EACrB,OAAO,CAAC,cAAc,IAAI,EAAE,EAAE,EAC9B,OAAO,CAAC,gBAAgB,EACxB,OAAO,CAAC,iBAAiB,CACzB,CAAC;QACH,CAAC;QACD,OAAO,qBAAqB,CAAC;IAC9B,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { Repository } from 'typeorm';
|
|
2
|
+
import { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
3
|
+
import type { UpdateCustomerEntity } from '../../types/customer.js';
|
|
4
|
+
export declare class CustomerService {
|
|
5
|
+
customerRepository: Repository<CustomerEntity>;
|
|
6
|
+
static instance: CustomerService;
|
|
7
|
+
constructor();
|
|
8
|
+
create(name: string, email?: string, description?: string): Promise<{
|
|
9
|
+
customerId: string;
|
|
10
|
+
name: string;
|
|
11
|
+
}>;
|
|
12
|
+
update(customer: UpdateCustomerEntity): Promise<CustomerEntity>;
|
|
13
|
+
get(customerId?: string): Promise<CustomerEntity | null>;
|
|
14
|
+
findOne(name?: string): Promise<CustomerEntity | null>;
|
|
15
|
+
find(where: Record<string, unknown>): Promise<CustomerEntity[]>;
|
|
16
|
+
findbyPaymentProviderId(paymentProviderId: string): Promise<CustomerEntity | null>;
|
|
17
|
+
isExist(where: Record<string, unknown>): Promise<boolean>;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=customer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"customer.d.ts","sourceRoot":"","sources":["../../../src/services/api/customer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAG1C,OAAO,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAO5E,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAIpE,qBAAa,eAAe;IACpB,kBAAkB,EAAE,UAAU,CAAC,cAAc,CAAC,CAAC;IAGtD,OAAc,QAAQ,kBAAyB;;IAMlC,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM;;;;IAyBzD,MAAM,CAAC,QAAQ,EAAE,oBAAoB;IAyBrC,GAAG,CAAC,UAAU,CAAC,EAAE,MAAM;IAIvB,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM;IAMrB,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAUnC,uBAAuB,CAAC,iBAAiB,EAAE,MAAM;IAMjD,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAOnD"}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { Connection } from '../../database/connection/connection.js';
|
|
2
|
+
import { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
3
|
+
import { IdentityServiceStrategySetup } from '../identity/index.js';
|
|
4
|
+
import * as dotenv from 'dotenv';
|
|
5
|
+
import { PaymentAccountService } from './payment-account.js';
|
|
6
|
+
import { CheqdNetwork } from '@cheqd/sdk';
|
|
7
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
8
|
+
import { SupportedKeyTypes } from '@veramo/utils';
|
|
9
|
+
dotenv.config();
|
|
10
|
+
export class CustomerService {
|
|
11
|
+
customerRepository;
|
|
12
|
+
// Get rid of such code and move it to the builder
|
|
13
|
+
static instance = new CustomerService();
|
|
14
|
+
constructor() {
|
|
15
|
+
this.customerRepository = Connection.instance.dbConnection.getRepository(CustomerEntity);
|
|
16
|
+
}
|
|
17
|
+
async create(name, email, description) {
|
|
18
|
+
// The sequence for creating a customer is supposed to be:
|
|
19
|
+
// 1. Create a new customer entity in the database;
|
|
20
|
+
// 2. Create new cosmos keypair
|
|
21
|
+
// 3. Get the cosmos address from the keypair
|
|
22
|
+
// 4. Create a new payment account entity in the database
|
|
23
|
+
if (await this.isExist({ name: name })) {
|
|
24
|
+
throw new Error(`Cannot create a new customer since the customer with same name ${name} already exists`);
|
|
25
|
+
}
|
|
26
|
+
const customerEntity = new CustomerEntity(uuidv4(), name, email, description);
|
|
27
|
+
await this.customerRepository.insert(customerEntity);
|
|
28
|
+
// Create a new Cosmos account for the customer and make a link with customer entity;
|
|
29
|
+
const key = await new IdentityServiceStrategySetup(name).agent.createKey(SupportedKeyTypes.Secp256k1, customerEntity);
|
|
30
|
+
await PaymentAccountService.instance.create(CheqdNetwork.Testnet, true, customerEntity, key);
|
|
31
|
+
return {
|
|
32
|
+
customerId: customerEntity.customerId,
|
|
33
|
+
name: customerEntity.name,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
async update(customer) {
|
|
37
|
+
const { customerId, name, email, description, paymentProviderId } = customer;
|
|
38
|
+
const existingCustomer = await this.customerRepository.findOneBy({ customerId });
|
|
39
|
+
if (!existingCustomer) {
|
|
40
|
+
throw new Error(`CustomerId not found`);
|
|
41
|
+
}
|
|
42
|
+
if (name) {
|
|
43
|
+
existingCustomer.name = name;
|
|
44
|
+
}
|
|
45
|
+
if (email) {
|
|
46
|
+
existingCustomer.email = email;
|
|
47
|
+
}
|
|
48
|
+
if (description) {
|
|
49
|
+
existingCustomer.description = description;
|
|
50
|
+
}
|
|
51
|
+
if (paymentProviderId) {
|
|
52
|
+
existingCustomer.paymentProviderId = paymentProviderId;
|
|
53
|
+
}
|
|
54
|
+
return await this.customerRepository.save(existingCustomer);
|
|
55
|
+
}
|
|
56
|
+
async get(customerId) {
|
|
57
|
+
return this.customerRepository.findOneBy({ customerId });
|
|
58
|
+
}
|
|
59
|
+
async findOne(name) {
|
|
60
|
+
return await this.customerRepository.findOne({
|
|
61
|
+
where: { name },
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
async find(where) {
|
|
65
|
+
try {
|
|
66
|
+
return await this.customerRepository.find({
|
|
67
|
+
where: where,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
catch {
|
|
71
|
+
return [];
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
async findbyPaymentProviderId(paymentProviderId) {
|
|
75
|
+
return await this.customerRepository.findOne({
|
|
76
|
+
where: { paymentProviderId: paymentProviderId },
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
async isExist(where) {
|
|
80
|
+
try {
|
|
81
|
+
return (await this.customerRepository.findOne({ where })) ? true : false;
|
|
82
|
+
}
|
|
83
|
+
catch {
|
|
84
|
+
return false;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
//# sourceMappingURL=customer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"customer.js","sourceRoot":"","sources":["../../../src/services/api/customer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Repository } from 'typeorm';
|
|
2
|
+
import { IdentifierEntity } from '../../database/entities/identifier.entity.js';
|
|
3
|
+
import type { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
4
|
+
export declare class IdentifierService {
|
|
5
|
+
identifierRepository: Repository<IdentifierEntity>;
|
|
6
|
+
static instance: IdentifierService;
|
|
7
|
+
constructor();
|
|
8
|
+
update(did: string, customer: CustomerEntity): Promise<IdentifierEntity>;
|
|
9
|
+
get(did?: string): Promise<IdentifierEntity | null>;
|
|
10
|
+
find(where: Record<string, unknown>): Promise<IdentifierEntity[]>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=identifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identifier.d.ts","sourceRoot":"","sources":["../../../src/services/api/identifier.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAG1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,8CAA8C,CAAC;AAEhF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAGjF,qBAAa,iBAAiB;IACtB,oBAAoB,EAAE,UAAU,CAAC,gBAAgB,CAAC,CAAC;IAG1D,OAAc,QAAQ,oBAA2B;;IAMpC,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,cAAc;IAS5C,GAAG,CAAC,GAAG,CAAC,EAAE,MAAM;IAOhB,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAUhD"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Connection } from '../../database/connection/connection.js';
|
|
2
|
+
import { IdentifierEntity } from '../../database/entities/identifier.entity.js';
|
|
3
|
+
import * as dotenv from 'dotenv';
|
|
4
|
+
dotenv.config();
|
|
5
|
+
export class IdentifierService {
|
|
6
|
+
identifierRepository;
|
|
7
|
+
// Get rid of such code and move it to the builder
|
|
8
|
+
static instance = new IdentifierService();
|
|
9
|
+
constructor() {
|
|
10
|
+
this.identifierRepository = Connection.instance.dbConnection.getRepository(IdentifierEntity);
|
|
11
|
+
}
|
|
12
|
+
async update(did, customer) {
|
|
13
|
+
const existing = await this.identifierRepository.findOneBy({ did });
|
|
14
|
+
if (!existing) {
|
|
15
|
+
throw new Error(`Did not found`);
|
|
16
|
+
}
|
|
17
|
+
existing.customer = customer;
|
|
18
|
+
return await this.identifierRepository.save(existing);
|
|
19
|
+
}
|
|
20
|
+
async get(did) {
|
|
21
|
+
return await this.identifierRepository.findOne({
|
|
22
|
+
where: { did },
|
|
23
|
+
relations: ['customer'],
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
async find(where) {
|
|
27
|
+
try {
|
|
28
|
+
return await this.identifierRepository.find({
|
|
29
|
+
where: where,
|
|
30
|
+
relations: ['customer'],
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
catch {
|
|
34
|
+
return [];
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=identifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identifier.js","sourceRoot":"","sources":["../../../src/services/api/identifier.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,yCAAyC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8CAA8C,CAAC;AAChF,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AAEjC,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,OAAO,iBAAiB;IACtB,oBAAoB,CAA+B;IAE1D,kDAAkD;IAC3C,MAAM,CAAC,QAAQ,GAAG,IAAI,iBAAiB,EAAE,CAAC;IAEjD;QACC,IAAI,CAAC,oBAAoB,GAAG,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;IAC9F,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,GAAW,EAAE,QAAwB;QACxD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;QAClC,CAAC;QACD,QAAQ,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC7B,OAAO,MAAM,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvD,CAAC;IAEM,KAAK,CAAC,GAAG,CAAC,GAAY;QAC5B,OAAO,MAAM,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC;YAC9C,KAAK,EAAE,EAAE,GAAG,EAAE;YACd,SAAS,EAAE,CAAC,UAAU,CAAC;SACvB,CAAC,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,KAA8B;QAC/C,IAAI,CAAC;YACJ,OAAO,MAAM,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC;gBAC3C,KAAK,EAAE,KAAK;gBACZ,SAAS,EAAE,CAAC,UAAU,CAAC;aACvB,CAAC,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACR,OAAO,EAAE,CAAC;QACX,CAAC;IACF,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Repository } from 'typeorm';
|
|
2
|
+
import { KeyEntity } from '../../database/entities/key.entity.js';
|
|
3
|
+
import type { Key } from '@veramo/data-store';
|
|
4
|
+
import type { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
5
|
+
export declare class KeyService {
|
|
6
|
+
keyRepository: Repository<KeyEntity>;
|
|
7
|
+
static instance: KeyService;
|
|
8
|
+
constructor();
|
|
9
|
+
update(kid: string, customer?: CustomerEntity, keyAlias?: string, createdAt?: Date): Promise<KeyEntity>;
|
|
10
|
+
get(kid: string): Promise<KeyEntity | null>;
|
|
11
|
+
find(where: Record<string, unknown>): Promise<KeyEntity[]>;
|
|
12
|
+
fromVeramoKey(key: Key): KeyEntity;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=key.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key.d.ts","sourceRoot":"","sources":["../../../src/services/api/key.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAK1C,OAAO,EAAE,SAAS,EAAE,MAAM,uCAAuC,CAAC;AAClE,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAGjF,qBAAa,UAAU;IACf,aAAa,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;IAE5C,OAAc,QAAQ,aAAoB;;IAM7B,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,cAAc,EAAE,QAAQ,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,IAAI;IAkBlF,GAAG,CAAC,GAAG,EAAE,MAAM;IAOf,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAWzC,aAAa,CAAC,GAAG,EAAE,GAAG;CAG7B"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Connection } from '../../database/connection/connection.js';
|
|
2
|
+
import * as dotenv from 'dotenv';
|
|
3
|
+
import { KeyEntity } from '../../database/entities/key.entity.js';
|
|
4
|
+
dotenv.config();
|
|
5
|
+
export class KeyService {
|
|
6
|
+
keyRepository;
|
|
7
|
+
static instance = new KeyService();
|
|
8
|
+
constructor() {
|
|
9
|
+
this.keyRepository = Connection.instance.dbConnection.getRepository(KeyEntity);
|
|
10
|
+
}
|
|
11
|
+
async update(kid, customer, keyAlias, createdAt) {
|
|
12
|
+
const existingKey = await this.keyRepository.findOneBy({ kid });
|
|
13
|
+
if (!existingKey) {
|
|
14
|
+
throw new Error(`kid not found`);
|
|
15
|
+
}
|
|
16
|
+
if (customer) {
|
|
17
|
+
existingKey.customer = customer;
|
|
18
|
+
}
|
|
19
|
+
if (keyAlias) {
|
|
20
|
+
existingKey.publicKeyAlias = keyAlias;
|
|
21
|
+
}
|
|
22
|
+
if (createdAt) {
|
|
23
|
+
// It's a workaround cause Veramo creates key inside without createdAt field
|
|
24
|
+
existingKey.createdAt = createdAt;
|
|
25
|
+
}
|
|
26
|
+
return await this.keyRepository.save(existingKey);
|
|
27
|
+
}
|
|
28
|
+
async get(kid) {
|
|
29
|
+
return await this.keyRepository.findOne({
|
|
30
|
+
where: { kid },
|
|
31
|
+
relations: ['customer'],
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
async find(where) {
|
|
35
|
+
try {
|
|
36
|
+
return await this.keyRepository.find({
|
|
37
|
+
where: where,
|
|
38
|
+
relations: ['customer'],
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
catch {
|
|
42
|
+
return [];
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
fromVeramoKey(key) {
|
|
46
|
+
return new KeyEntity(key.kid, key.type, key.publicKeyHex);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=key.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key.js","sourceRoot":"","sources":["../../../src/services/api/key.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,yCAAyC,CAAC;AAErE,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,OAAO,EAAE,SAAS,EAAE,MAAM,uCAAuC,CAAC;AAGlE,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,OAAO,UAAU;IACf,aAAa,CAAwB;IAErC,MAAM,CAAC,QAAQ,GAAG,IAAI,UAAU,EAAE,CAAC;IAE1C;QACC,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;IAChF,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,GAAW,EAAE,QAAyB,EAAE,QAAiB,EAAE,SAAgB;QAC9F,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;QAChE,IAAI,CAAC,WAAW,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;QAClC,CAAC;QACD,IAAI,QAAQ,EAAE,CAAC;YACd,WAAW,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACjC,CAAC;QACD,IAAI,QAAQ,EAAE,CAAC;YACd,WAAW,CAAC,cAAc,GAAG,QAAQ,CAAC;QACvC,CAAC;QACD,IAAI,SAAS,EAAE,CAAC;YACf,4EAA4E;YAC5E,WAAW,CAAC,SAAS,GAAG,SAAS,CAAC;QACnC,CAAC;QACD,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACnD,CAAC;IAEM,KAAK,CAAC,GAAG,CAAC,GAAW;QAC3B,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC;YACvC,KAAK,EAAE,EAAE,GAAG,EAAE;YACd,SAAS,EAAE,CAAC,UAAU,CAAC;SACvB,CAAC,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,KAA8B;QAC/C,IAAI,CAAC;YACJ,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;gBACpC,KAAK,EAAE,KAAK;gBACZ,SAAS,EAAE,CAAC,UAAU,CAAC;aACvB,CAAC,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACR,OAAO,EAAE,CAAC;QACX,CAAC;IACF,CAAC;IAEM,aAAa,CAAC,GAAQ;QAC5B,OAAO,IAAI,SAAS,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,YAAY,CAAC,CAAC;IAC3D,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Repository } from 'typeorm';
|
|
2
|
+
import { OperationEntity } from '../../database/entities/operation.entity.js';
|
|
3
|
+
import type { CoinEntity } from '../../database/entities/coin.entity.js';
|
|
4
|
+
import type { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
5
|
+
export declare class OperationService {
|
|
6
|
+
operationRepository: Repository<OperationEntity>;
|
|
7
|
+
static instance: OperationService;
|
|
8
|
+
constructor();
|
|
9
|
+
create(category: string, operationName: string, defaultFee: CoinEntity, deprecated: boolean | undefined, successful: boolean | undefined, customer: CustomerEntity): Promise<OperationEntity>;
|
|
10
|
+
update(operationId: string, category: string, operationName: string, defaultFee: CoinEntity, deprecated?: false, successful?: boolean): Promise<OperationEntity>;
|
|
11
|
+
get(operationId: string): Promise<OperationEntity | null>;
|
|
12
|
+
find(where: Record<string, unknown>): Promise<OperationEntity[]>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=operation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"operation.d.ts","sourceRoot":"","sources":["../../../src/services/api/operation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAK1C,OAAO,EAAE,eAAe,EAAE,MAAM,6CAA6C,CAAC;AAE9E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wCAAwC,CAAC;AACzE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAGjF,qBAAa,gBAAgB;IACrB,mBAAmB,EAAE,UAAU,CAAC,eAAe,CAAC,CAAC;IAExD,OAAc,QAAQ,mBAA0B;;IAMnC,MAAM,CAClB,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,MAAM,EACrB,UAAU,EAAE,UAAU,EACtB,UAAU,qBAAQ,EAClB,UAAU,qBAAO,EACjB,QAAQ,EAAE,cAAc,GACtB,OAAO,CAAC,eAAe,CAAC;IAuBd,MAAM,CAClB,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,MAAM,EACrB,UAAU,EAAE,UAAU,EACtB,UAAU,CAAC,EAAE,KAAK,EAClB,UAAU,CAAC,EAAE,OAAO;IAyBR,GAAG,CAAC,WAAW,EAAE,MAAM;IAOvB,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAMhD"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { Connection } from '../../database/connection/connection.js';
|
|
2
|
+
import * as dotenv from 'dotenv';
|
|
3
|
+
import { OperationEntity } from '../../database/entities/operation.entity.js';
|
|
4
|
+
import { v4 } from 'uuid';
|
|
5
|
+
dotenv.config();
|
|
6
|
+
export class OperationService {
|
|
7
|
+
operationRepository;
|
|
8
|
+
static instance = new OperationService();
|
|
9
|
+
constructor() {
|
|
10
|
+
this.operationRepository = Connection.instance.dbConnection.getRepository(OperationEntity);
|
|
11
|
+
}
|
|
12
|
+
async create(category, operationName, defaultFee, deprecated = false, successful = true, customer) {
|
|
13
|
+
if (!category) {
|
|
14
|
+
throw new Error('Operation category is not specified');
|
|
15
|
+
}
|
|
16
|
+
if (!operationName) {
|
|
17
|
+
throw new Error('Operation name is not specified');
|
|
18
|
+
}
|
|
19
|
+
const operationId = v4();
|
|
20
|
+
const operationEntity = new OperationEntity(operationId, category, operationName, defaultFee, deprecated, successful, customer);
|
|
21
|
+
const operation = (await this.operationRepository.insert(operationEntity)).identifiers[0];
|
|
22
|
+
if (!operation)
|
|
23
|
+
throw new Error(`Cannot create a new operation`);
|
|
24
|
+
return operationEntity;
|
|
25
|
+
}
|
|
26
|
+
async update(operationId, category, operationName, defaultFee, deprecated, successful) {
|
|
27
|
+
const existingOperation = await this.get(operationId);
|
|
28
|
+
if (!existingOperation) {
|
|
29
|
+
throw new Error(`Operation with id ${operationId} does not exist`);
|
|
30
|
+
}
|
|
31
|
+
if (category) {
|
|
32
|
+
existingOperation.category = category;
|
|
33
|
+
}
|
|
34
|
+
if (operationName) {
|
|
35
|
+
existingOperation.operationName = operationName;
|
|
36
|
+
}
|
|
37
|
+
if (defaultFee) {
|
|
38
|
+
existingOperation.defaultFee = defaultFee;
|
|
39
|
+
}
|
|
40
|
+
if (deprecated) {
|
|
41
|
+
existingOperation.deprecated = deprecated;
|
|
42
|
+
}
|
|
43
|
+
if (successful) {
|
|
44
|
+
existingOperation.successful = successful;
|
|
45
|
+
}
|
|
46
|
+
return await this.operationRepository.save(existingOperation);
|
|
47
|
+
}
|
|
48
|
+
async get(operationId) {
|
|
49
|
+
return await this.operationRepository.findOne({
|
|
50
|
+
where: { operationId },
|
|
51
|
+
relations: ['coin', 'customer'],
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
async find(where) {
|
|
55
|
+
return await this.operationRepository.find({
|
|
56
|
+
where: where,
|
|
57
|
+
relations: ['coin', 'customer'],
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=operation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"operation.js","sourceRoot":"","sources":["../../../src/services/api/operation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Repository } from 'typeorm';
|
|
2
|
+
import { PaymentAccountEntity } from '../../database/entities/payment.account.entity.js';
|
|
3
|
+
import type { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
4
|
+
import type { KeyEntity } from '../../database/entities/key.entity.js';
|
|
5
|
+
export declare class PaymentAccountService {
|
|
6
|
+
paymentAccountRepository: Repository<PaymentAccountEntity>;
|
|
7
|
+
static instance: PaymentAccountService;
|
|
8
|
+
constructor();
|
|
9
|
+
create(namespace: string, isDefault: boolean, customer: CustomerEntity, key: KeyEntity): Promise<PaymentAccountEntity>;
|
|
10
|
+
update(address: string, namespace?: string, isDefault?: boolean, customer?: CustomerEntity, key?: KeyEntity): Promise<PaymentAccountEntity>;
|
|
11
|
+
get(address: string): Promise<PaymentAccountEntity | null>;
|
|
12
|
+
find(where: Record<string, unknown>): Promise<PaymentAccountEntity[]>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=payment-account.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"payment-account.d.ts","sourceRoot":"","sources":["../../../src/services/api/payment-account.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAK1C,OAAO,EAAE,oBAAoB,EAAE,MAAM,mDAAmD,CAAC;AACzF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,uCAAuC,CAAC;AAIvE,qBAAa,qBAAqB;IAC1B,wBAAwB,EAAE,UAAU,CAAC,oBAAoB,CAAC,CAAC;IAElE,OAAc,QAAQ,wBAA+B;;IAMxC,MAAM,CAClB,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,OAAO,EAClB,QAAQ,EAAE,cAAc,EACxB,GAAG,EAAE,SAAS,GACZ,OAAO,CAAC,oBAAoB,CAAC;IA2BnB,MAAM,CAClB,OAAO,EAAE,MAAM,EACf,SAAS,CAAC,EAAE,MAAM,EAClB,SAAS,CAAC,EAAE,OAAO,EACnB,QAAQ,CAAC,EAAE,cAAc,EACzB,GAAG,CAAC,EAAE,SAAS;IAsBH,GAAG,CAAC,OAAO,EAAE,MAAM;IAOnB,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAMhD"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { Connection } from '../../database/connection/connection.js';
|
|
2
|
+
import * as dotenv from 'dotenv';
|
|
3
|
+
import { PaymentAccountEntity } from '../../database/entities/payment.account.entity.js';
|
|
4
|
+
import { getCosmosAccount } from '@cheqd/sdk';
|
|
5
|
+
dotenv.config();
|
|
6
|
+
export class PaymentAccountService {
|
|
7
|
+
paymentAccountRepository;
|
|
8
|
+
static instance = new PaymentAccountService();
|
|
9
|
+
constructor() {
|
|
10
|
+
this.paymentAccountRepository = Connection.instance.dbConnection.getRepository(PaymentAccountEntity);
|
|
11
|
+
}
|
|
12
|
+
async create(namespace, isDefault, customer, key) {
|
|
13
|
+
const address = getCosmosAccount(key.kid);
|
|
14
|
+
const existing = await this.find({ address: address });
|
|
15
|
+
if (!address) {
|
|
16
|
+
throw new Error('Account address is not specified');
|
|
17
|
+
}
|
|
18
|
+
if (existing.length > 0) {
|
|
19
|
+
throw new Error(`Cannot create a new payment account since the payment account with same address ${address} already exists`);
|
|
20
|
+
}
|
|
21
|
+
if (!namespace) {
|
|
22
|
+
throw new Error('Account namespace is not specified');
|
|
23
|
+
}
|
|
24
|
+
if (!customer) {
|
|
25
|
+
throw new Error('Customer id is not specified');
|
|
26
|
+
}
|
|
27
|
+
if (!key) {
|
|
28
|
+
throw new Error('Key id is not specified');
|
|
29
|
+
}
|
|
30
|
+
const paymentAccount = new PaymentAccountEntity(address, namespace, isDefault, customer, key);
|
|
31
|
+
const paymentAccountEntity = (await this.paymentAccountRepository.insert(paymentAccount)).identifiers[0];
|
|
32
|
+
if (!paymentAccountEntity)
|
|
33
|
+
throw new Error(`Cannot create a new payment account`);
|
|
34
|
+
return paymentAccount;
|
|
35
|
+
}
|
|
36
|
+
async update(address, namespace, isDefault, customer, key) {
|
|
37
|
+
const existingPaymentAccount = await this.paymentAccountRepository.findOneBy({ address });
|
|
38
|
+
if (!existingPaymentAccount) {
|
|
39
|
+
throw new Error(`address not found`);
|
|
40
|
+
}
|
|
41
|
+
if (customer) {
|
|
42
|
+
existingPaymentAccount.customer = customer;
|
|
43
|
+
}
|
|
44
|
+
if (namespace) {
|
|
45
|
+
existingPaymentAccount.namespace = namespace;
|
|
46
|
+
}
|
|
47
|
+
if (key) {
|
|
48
|
+
existingPaymentAccount.key = key;
|
|
49
|
+
}
|
|
50
|
+
if (isDefault) {
|
|
51
|
+
existingPaymentAccount.isDefault = isDefault;
|
|
52
|
+
}
|
|
53
|
+
return await this.paymentAccountRepository.save(existingPaymentAccount);
|
|
54
|
+
}
|
|
55
|
+
async get(address) {
|
|
56
|
+
return await this.paymentAccountRepository.findOne({
|
|
57
|
+
where: { address },
|
|
58
|
+
relations: ['customer', 'key'],
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
async find(where) {
|
|
62
|
+
return await this.paymentAccountRepository.find({
|
|
63
|
+
where: where,
|
|
64
|
+
relations: ['customer', 'key'],
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=payment-account.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"payment-account.js","sourceRoot":"","sources":["../../../src/services/api/payment-account.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { Repository } from 'typeorm';
|
|
2
|
+
import type { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
3
|
+
import { PaymentEntity } from '../../database/entities/payment.entity.js';
|
|
4
|
+
import type { OperationEntity } from '../../database/entities/operation.entity.js';
|
|
5
|
+
import type { ResourceEntity } from '../../database/entities/resource.entity.js';
|
|
6
|
+
import type { CheqdNetwork } from '@cheqd/sdk';
|
|
7
|
+
import type { CoinEntity } from '../../database/entities/coin.entity.js';
|
|
8
|
+
export declare class PaymentService {
|
|
9
|
+
paymentRepository: Repository<PaymentEntity>;
|
|
10
|
+
static instance: PaymentService;
|
|
11
|
+
constructor();
|
|
12
|
+
create(txHash: string, customer: CustomerEntity, operation: OperationEntity, fee: CoinEntity, amount: CoinEntity, successful: boolean, namespace: CheqdNetwork, resource: ResourceEntity, fromAccount: string, toAccount: string, timestamp: Date): Promise<PaymentEntity>;
|
|
13
|
+
update(txHash: string, customer: CustomerEntity, operation: OperationEntity, fee: CoinEntity, amount: CoinEntity, successful: boolean, namespace: CheqdNetwork, resource: ResourceEntity, fromAccount: string, toAccount: string, timestamp: Date): Promise<PaymentEntity>;
|
|
14
|
+
get(txHash: string): Promise<PaymentEntity | null>;
|
|
15
|
+
find(where: Record<string, unknown>): Promise<PaymentEntity[]>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=payment.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"payment.d.ts","sourceRoot":"","sources":["../../../src/services/api/payment.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAK1C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAE,aAAa,EAAE,MAAM,2CAA2C,CAAC;AAC1E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,6CAA6C,CAAC;AACnF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wCAAwC,CAAC;AAGzE,qBAAa,cAAc;IACnB,iBAAiB,EAAE,UAAU,CAAC,aAAa,CAAC,CAAC;IAEpD,OAAc,QAAQ,iBAAwB;;IAMjC,MAAM,CAClB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,cAAc,EACxB,SAAS,EAAE,eAAe,EAC1B,GAAG,EAAE,UAAU,EACf,MAAM,EAAE,UAAU,EAClB,UAAU,EAAE,OAAO,EACnB,SAAS,EAAE,YAAY,EACvB,QAAQ,EAAE,cAAc,EACxB,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,IAAI;IAoBH,MAAM,CAClB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,cAAc,EACxB,SAAS,EAAE,eAAe,EAC1B,GAAG,EAAE,UAAU,EACf,MAAM,EAAE,UAAU,EAClB,UAAU,EAAE,OAAO,EACnB,SAAS,EAAE,YAAY,EACvB,QAAQ,EAAE,cAAc,EACxB,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,IAAI;IAwCH,GAAG,CAAC,MAAM,EAAE,MAAM;IAOlB,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAMhD"}
|