@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 @@
|
|
|
1
|
+
{"version":3,"file":"event-tracker.d.ts","sourceRoot":"","sources":["../../src/middleware/event-tracker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAI/D,qBAAa,eAAe;IACd,SAAS,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;CA+B/E"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { eventTracker } from '../services/track/tracker.js';
|
|
2
|
+
export class ResponseTracker {
|
|
3
|
+
async trackJson(request, response, next) {
|
|
4
|
+
const originalJson = response.json;
|
|
5
|
+
response.json = (body) => {
|
|
6
|
+
// Message compiler
|
|
7
|
+
const compileMessage = () => {
|
|
8
|
+
const parts = [];
|
|
9
|
+
const date = new Date().toISOString();
|
|
10
|
+
parts.push(date);
|
|
11
|
+
parts.push('URL: ' + response.req.url);
|
|
12
|
+
parts.push('Method: ' + response.req.method);
|
|
13
|
+
parts.push('Status: ' + response.statusCode);
|
|
14
|
+
if (response.locals.customer) {
|
|
15
|
+
parts.push('Customer: ' + response.locals.customer.customerId);
|
|
16
|
+
}
|
|
17
|
+
if (body && body.error) {
|
|
18
|
+
parts.push('Message: ' + body.error);
|
|
19
|
+
}
|
|
20
|
+
return parts.join(' | ');
|
|
21
|
+
};
|
|
22
|
+
// Notify
|
|
23
|
+
if (body) {
|
|
24
|
+
eventTracker.emit('notify', {
|
|
25
|
+
message: compileMessage(),
|
|
26
|
+
severity: body.error ? 'error' : 'info',
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
return originalJson.apply(response, [body]);
|
|
30
|
+
};
|
|
31
|
+
return next();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=event-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-tracker.js","sourceRoot":"","sources":["../../src/middleware/event-tracker.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAG5D,MAAM,OAAO,eAAe;IACpB,KAAK,CAAC,SAAS,CAAC,OAAgB,EAAE,QAAkB,EAAE,IAAkB;QAC9E,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC;QACnC,QAAQ,CAAC,IAAI,GAAG,CAAC,IAAI,EAAE,EAAE;YACxB,mBAAmB;YACnB,MAAM,cAAc,GAAG,GAAG,EAAE;gBAC3B,MAAM,KAAK,GAAG,EAAE,CAAC;gBACjB,MAAM,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBACtC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACjB,KAAK,CAAC,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBACvC,KAAK,CAAC,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBAC7C,KAAK,CAAC,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;gBAC7C,IAAI,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;oBAC9B,KAAK,CAAC,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;gBAChE,CAAC;gBACD,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;oBACxB,KAAK,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;gBACtC,CAAC;gBACD,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1B,CAAC,CAAC;YACF,SAAS;YACT,IAAI,IAAI,EAAE,CAAC;gBACV,YAAY,CAAC,IAAI,CAAC,QAAQ,EAAE;oBAC3B,OAAO,EAAE,cAAc,EAAE;oBACzB,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;iBACd,CAAC,CAAC;YAC7B,CAAC;YAED,OAAO,YAAY,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QAC7C,CAAC,CAAC;QACF,OAAO,IAAI,EAAE,CAAC;IACf,CAAC;CACD"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Request, Response, NextFunction } from 'express';
|
|
2
|
+
export declare class LogToWebHook {
|
|
3
|
+
static verifyHookSignature(request: Request & {
|
|
4
|
+
rawBody?: Buffer;
|
|
5
|
+
}, response: Response, next: NextFunction): Promise<void | Response<any, Record<string, any>>>;
|
|
6
|
+
static getCustomerId(request: Request): string;
|
|
7
|
+
static isUserSuspended(request: Request): boolean;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=hook.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hook.d.ts","sourceRoot":"","sources":["../../src/middleware/hook.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAQ/D,qBAAa,YAAY;WACX,mBAAmB,CAAC,OAAO,EAAE,OAAO,GAAG;QAAE,OAAO,CAAC,EAAE,MAAM,CAAA;KAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;IAgBhH,MAAM,CAAC,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,MAAM;IAK9C,MAAM,CAAC,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO;CAIjD"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { StatusCodes } from 'http-status-codes';
|
|
2
|
+
import * as dotenv from 'dotenv';
|
|
3
|
+
import { verifyHookSignature } from '../helpers/helpers.js';
|
|
4
|
+
dotenv.config();
|
|
5
|
+
export class LogToWebHook {
|
|
6
|
+
static async verifyHookSignature(request, response, next) {
|
|
7
|
+
const logtoSignature = request.headers['logto-signature-sha-256'];
|
|
8
|
+
if (!verifyHookSignature(process.env.LOGTO_WEBHOOK_SECRET, request?.rawBody?.toString() || '', logtoSignature)) {
|
|
9
|
+
return response.status(StatusCodes.BAD_REQUEST).json({
|
|
10
|
+
error: 'Invalid signature in LogTo webhook',
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
return next();
|
|
14
|
+
}
|
|
15
|
+
static getCustomerId(request) {
|
|
16
|
+
const { body } = request;
|
|
17
|
+
return body.user.id;
|
|
18
|
+
}
|
|
19
|
+
static isUserSuspended(request) {
|
|
20
|
+
const { body } = request;
|
|
21
|
+
return body.user.isSuspended;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=hook.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hook.js","sourceRoot":"","sources":["../../src/middleware/hook.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,OAAO,YAAY;IACxB,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,OAAuC,EAAE,QAAkB,EAAE,IAAkB;QAC/G,MAAM,cAAc,GAAG,OAAO,CAAC,OAAO,CAAC,yBAAyB,CAAW,CAAC;QAC5E,IACC,CAAC,mBAAmB,CACnB,OAAO,CAAC,GAAG,CAAC,oBAA8B,EAC1C,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,EAClC,cAAc,CACd,EACA,CAAC;YACF,OAAO,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC;gBACpD,KAAK,EAAE,oCAAoC;aAC3C,CAAC,CAAC;QACJ,CAAC;QACD,OAAO,IAAI,EAAE,CAAC;IACf,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,OAAgB;QACpC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;QACzB,OAAO,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;IACrB,CAAC;IAED,MAAM,CAAC,eAAe,CAAC,OAAgB;QACtC,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;QACzB,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC;IAC9B,CAAC;CACD"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Request, Response, NextFunction } from 'express';
|
|
2
|
+
export declare class Middleware {
|
|
3
|
+
static parseUrlEncodedJson(request: Request, response: Response, next: NextFunction): Promise<void>;
|
|
4
|
+
static setStripeClient(request: Request, response: Response, next: NextFunction): Promise<void>;
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.d.ts","sourceRoot":"","sources":["../../src/middleware/middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAK/D,qBAAa,UAAU;WACT,mBAAmB,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;WAuB5E,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY;CAMrF"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import Stripe from 'stripe';
|
|
2
|
+
import * as dotenv from 'dotenv';
|
|
3
|
+
dotenv.config();
|
|
4
|
+
export class Middleware {
|
|
5
|
+
static async parseUrlEncodedJson(request, response, next) {
|
|
6
|
+
// Check if the request content type is URL-encoded
|
|
7
|
+
if (request.is('application/x-www-form-urlencoded')) {
|
|
8
|
+
// Parse the inner JSON strings
|
|
9
|
+
for (const key in request.body) {
|
|
10
|
+
try {
|
|
11
|
+
if (request.body[key] === '') {
|
|
12
|
+
request.body[key] = undefined;
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
if (typeof request.body[key] === 'string' && request.body[key].includes(',')) {
|
|
16
|
+
// Check if the value contains commas
|
|
17
|
+
request.body[key] = request.body[key].split(',');
|
|
18
|
+
}
|
|
19
|
+
request.body[key] = JSON.parse(request.body[key]);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
catch (error) {
|
|
23
|
+
// Failed to parse the value as JSON, leave it as is
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
next();
|
|
28
|
+
}
|
|
29
|
+
static async setStripeClient(request, response, next) {
|
|
30
|
+
// Set the Stripe client
|
|
31
|
+
const stripe = new Stripe(process.env.STRIPE_SECRET_KEY);
|
|
32
|
+
response.locals.stripe = stripe;
|
|
33
|
+
next();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../src/middleware/middleware.ts"],"names":[],"mappings":"AACA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,OAAO,UAAU;IACtB,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,OAAgB,EAAE,QAAkB,EAAE,IAAkB;QACxF,mDAAmD;QACnD,IAAI,OAAO,CAAC,EAAE,CAAC,mCAAmC,CAAC,EAAE,CAAC;YACrD,+BAA+B;YAC/B,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;gBAChC,IAAI,CAAC;oBACJ,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,CAAC;wBAC9B,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC;oBAC/B,CAAC;yBAAM,CAAC;wBACP,IAAI,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;4BAC9E,qCAAqC;4BACrC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;wBAClD,CAAC;wBACD,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;oBACnD,CAAC;gBACF,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBAChB,oDAAoD;gBACrD,CAAC;YACF,CAAC;QACF,CAAC;QACD,IAAI,EAAE,CAAC;IACR,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC,OAAgB,EAAE,QAAkB,EAAE,IAAkB;QACpF,wBAAwB;QACxB,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;QACzD,QAAQ,CAAC,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC;QAChC,IAAI,EAAE,CAAC;IACR,CAAC;CACD"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { Repository } from 'typeorm';
|
|
2
|
+
import type { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
3
|
+
import { APIKeyEntity } from '../../database/entities/api.key.entity.js';
|
|
4
|
+
import type { UserEntity } from '../../database/entities/user.entity.js';
|
|
5
|
+
import type { APIServiceOptions } from '../../types/admin.js';
|
|
6
|
+
export declare class APIKeyService {
|
|
7
|
+
apiKeyRepository: Repository<APIKeyEntity>;
|
|
8
|
+
private secretBox;
|
|
9
|
+
static instance: APIKeyService;
|
|
10
|
+
constructor();
|
|
11
|
+
create(apiKey: string, name: string, user: UserEntity, expiresAt?: Date, revoked?: boolean, options?: APIServiceOptions): Promise<APIKeyEntity>;
|
|
12
|
+
update(item: {
|
|
13
|
+
apiKey: string;
|
|
14
|
+
name?: string;
|
|
15
|
+
expiresAt?: Date;
|
|
16
|
+
revoked?: boolean;
|
|
17
|
+
customer?: CustomerEntity;
|
|
18
|
+
user?: UserEntity;
|
|
19
|
+
}, options?: APIServiceOptions): Promise<APIKeyEntity>;
|
|
20
|
+
revoke(apiKey: string, options?: APIServiceOptions): Promise<APIKeyEntity>;
|
|
21
|
+
decryptAPIKey(apiKey: string): Promise<string>;
|
|
22
|
+
encryptAPIKey(apiKey: string): Promise<string>;
|
|
23
|
+
get(apiKey: string, options?: APIServiceOptions): Promise<APIKeyEntity | null>;
|
|
24
|
+
find(where: Record<string, unknown>, order?: Record<string, 'ASC' | 'DESC'>, options?: APIServiceOptions): Promise<APIKeyEntity[]>;
|
|
25
|
+
static generateAPIKey(userId: string): string;
|
|
26
|
+
static getExpiryDateJWT(apiKey: string): Date;
|
|
27
|
+
static hashAPIKey(apiKey: string): Promise<string>;
|
|
28
|
+
static compareAPIKey(apiKey: string, hash: string): Promise<boolean>;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=api-key.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api-key.d.ts","sourceRoot":"","sources":["../../../src/services/admin/api-key.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAO1C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAE,YAAY,EAAE,MAAM,2CAA2C,CAAC;AACzE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wCAAwC,CAAC;AAGzE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAG9D,qBAAa,aAAa;IAClB,gBAAgB,EAAE,UAAU,CAAC,YAAY,CAAC,CAAC;IAClD,OAAO,CAAC,SAAS,CAAY;IAE7B,OAAc,QAAQ,gBAAuB;;IAUhC,MAAM,CAClB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,UAAU,EAChB,SAAS,CAAC,EAAE,IAAI,EAChB,OAAO,UAAQ,EACf,OAAO,CAAC,EAAE,iBAAiB,GACzB,OAAO,CAAC,YAAY,CAAC;IAoCX,MAAM,CAClB,IAAI,EAAE;QACL,MAAM,EAAE,MAAM,CAAC;QACf,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,SAAS,CAAC,EAAE,IAAI,CAAC;QACjB,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,QAAQ,CAAC,EAAE,cAAc,CAAC;QAC1B,IAAI,CAAC,EAAE,UAAU,CAAC;KAClB,EACD,OAAO,CAAC,EAAE,iBAAiB;IAiCf,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,iBAAiB;IAUlD,aAAa,CAAC,MAAM,EAAE,MAAM;IAI5B,aAAa,CAAC,MAAM,EAAE,MAAM;IAI5B,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,iBAAiB;IAe/C,IAAI,CAChB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,GAAG,MAAM,CAAC,EACtC,OAAO,CAAC,EAAE,iBAAiB;WAqBd,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;WAKtC,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;WAKhC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;WAI3C,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;CAGjF"}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import { decodeJWT } from 'did-jwt';
|
|
2
|
+
import bcrypt from 'bcrypt';
|
|
3
|
+
import { randomBytes, createHmac } from 'crypto';
|
|
4
|
+
import { Connection } from '../../database/connection/connection.js';
|
|
5
|
+
import * as dotenv from 'dotenv';
|
|
6
|
+
import { APIKeyEntity } from '../../database/entities/api.key.entity.js';
|
|
7
|
+
import { SecretBox } from '@veramo/kms-local';
|
|
8
|
+
import { API_SECRET_KEY_LENGTH, API_KEY_PREFIX, API_KEY_EXPIRATION } from '../../types/constants.js';
|
|
9
|
+
dotenv.config();
|
|
10
|
+
export class APIKeyService {
|
|
11
|
+
apiKeyRepository;
|
|
12
|
+
secretBox;
|
|
13
|
+
static instance = new APIKeyService();
|
|
14
|
+
constructor() {
|
|
15
|
+
this.apiKeyRepository = Connection.instance.dbConnection.getRepository(APIKeyEntity);
|
|
16
|
+
this.secretBox = new SecretBox(process.env.EXTERNAL_DB_ENCRYPTION_KEY);
|
|
17
|
+
}
|
|
18
|
+
// ToDo: Maybe we also need to store not the API key but the hash of it?
|
|
19
|
+
// But in that case the API key will be shown once and then it will be lost.
|
|
20
|
+
async create(apiKey, name, user, expiresAt, revoked = false, options) {
|
|
21
|
+
const apiKeyHash = await APIKeyService.hashAPIKey(apiKey);
|
|
22
|
+
const { decryptionNeeded } = options || {};
|
|
23
|
+
if (!apiKey) {
|
|
24
|
+
throw new Error('API key is not specified');
|
|
25
|
+
}
|
|
26
|
+
if (!name) {
|
|
27
|
+
throw new Error('API key name is not specified');
|
|
28
|
+
}
|
|
29
|
+
if (!user) {
|
|
30
|
+
throw new Error('API key user is not specified');
|
|
31
|
+
}
|
|
32
|
+
if (!expiresAt) {
|
|
33
|
+
expiresAt = new Date();
|
|
34
|
+
expiresAt.setMonth(expiresAt.getDay() + API_KEY_EXPIRATION);
|
|
35
|
+
}
|
|
36
|
+
const encryptedAPIKey = await this.encryptAPIKey(apiKey);
|
|
37
|
+
// Create entity
|
|
38
|
+
const apiKeyEntity = new APIKeyEntity(apiKeyHash, encryptedAPIKey, name, expiresAt, user.customer, user, revoked);
|
|
39
|
+
const apiKeyRecord = (await this.apiKeyRepository.insert(apiKeyEntity)).identifiers[0];
|
|
40
|
+
if (!apiKeyRecord)
|
|
41
|
+
throw new Error(`Cannot create a new API key`);
|
|
42
|
+
if (decryptionNeeded) {
|
|
43
|
+
apiKeyEntity.apiKey = apiKey;
|
|
44
|
+
}
|
|
45
|
+
return apiKeyEntity;
|
|
46
|
+
}
|
|
47
|
+
async update(item, options) {
|
|
48
|
+
const { apiKey, name, expiresAt, customer, revoked, user } = item;
|
|
49
|
+
const { decryptionNeeded } = options || {};
|
|
50
|
+
const existingAPIKey = await this.get(apiKey);
|
|
51
|
+
if (!existingAPIKey) {
|
|
52
|
+
throw new Error(`API key not found`);
|
|
53
|
+
}
|
|
54
|
+
if (name) {
|
|
55
|
+
existingAPIKey.name = name;
|
|
56
|
+
}
|
|
57
|
+
if (expiresAt) {
|
|
58
|
+
existingAPIKey.expiresAt = expiresAt;
|
|
59
|
+
}
|
|
60
|
+
if (customer) {
|
|
61
|
+
existingAPIKey.customer = customer;
|
|
62
|
+
}
|
|
63
|
+
if (user) {
|
|
64
|
+
existingAPIKey.user = user;
|
|
65
|
+
}
|
|
66
|
+
if (revoked) {
|
|
67
|
+
existingAPIKey.revoked = revoked;
|
|
68
|
+
}
|
|
69
|
+
const entity = await this.apiKeyRepository.save(existingAPIKey);
|
|
70
|
+
if (entity && decryptionNeeded) {
|
|
71
|
+
entity.apiKey = await this.decryptAPIKey(existingAPIKey.apiKey);
|
|
72
|
+
}
|
|
73
|
+
return entity;
|
|
74
|
+
}
|
|
75
|
+
async revoke(apiKey, options) {
|
|
76
|
+
return this.update({
|
|
77
|
+
apiKey: apiKey,
|
|
78
|
+
revoked: true,
|
|
79
|
+
}, options);
|
|
80
|
+
}
|
|
81
|
+
async decryptAPIKey(apiKey) {
|
|
82
|
+
return await this.secretBox.decrypt(apiKey);
|
|
83
|
+
}
|
|
84
|
+
async encryptAPIKey(apiKey) {
|
|
85
|
+
return await this.secretBox.encrypt(apiKey);
|
|
86
|
+
}
|
|
87
|
+
async get(apiKey, options) {
|
|
88
|
+
const { decryptionNeeded } = options || {};
|
|
89
|
+
// ToDo: possible bottleneck cause we are fetching all the keys
|
|
90
|
+
for (const record of await this.find({})) {
|
|
91
|
+
if (await APIKeyService.compareAPIKey(apiKey, record.apiKeyHash)) {
|
|
92
|
+
if (decryptionNeeded) {
|
|
93
|
+
record.apiKey = await this.decryptAPIKey(record.apiKey);
|
|
94
|
+
}
|
|
95
|
+
return record;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
return null;
|
|
99
|
+
}
|
|
100
|
+
async find(where, order, options) {
|
|
101
|
+
try {
|
|
102
|
+
const { decryptionNeeded } = options || {};
|
|
103
|
+
const apiKeyList = await this.apiKeyRepository.find({
|
|
104
|
+
where: where,
|
|
105
|
+
relations: ['customer', 'user'],
|
|
106
|
+
order: order,
|
|
107
|
+
});
|
|
108
|
+
if (decryptionNeeded) {
|
|
109
|
+
for (const apiKey of apiKeyList) {
|
|
110
|
+
apiKey.apiKey = await this.decryptAPIKey(apiKey.apiKey);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
return apiKeyList;
|
|
114
|
+
}
|
|
115
|
+
catch {
|
|
116
|
+
return [];
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
// Utils
|
|
120
|
+
static generateAPIKey(userId) {
|
|
121
|
+
const apiKey = createHmac('sha512', randomBytes(API_SECRET_KEY_LENGTH)).update(userId).digest('hex');
|
|
122
|
+
return `${API_KEY_PREFIX}_${apiKey}`;
|
|
123
|
+
}
|
|
124
|
+
static getExpiryDateJWT(apiKey) {
|
|
125
|
+
const decrypted = decodeJWT(apiKey);
|
|
126
|
+
return new Date(decrypted.payload.exp ? decrypted.payload.exp * 1000 : 0);
|
|
127
|
+
}
|
|
128
|
+
static async hashAPIKey(apiKey) {
|
|
129
|
+
return bcrypt.hash(apiKey, 12);
|
|
130
|
+
}
|
|
131
|
+
static async compareAPIKey(apiKey, hash) {
|
|
132
|
+
return bcrypt.compare(apiKey, hash);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
//# sourceMappingURL=api-key.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api-key.js","sourceRoot":"","sources":["../../../src/services/admin/api-key.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import Stripe from 'stripe';
|
|
2
|
+
import type { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
3
|
+
import type { SubscriptionEntity } from '../../database/entities/subscription.entity.js';
|
|
4
|
+
import { SubscriptionSubmitter } from '../track/admin/subscription-submitter.js';
|
|
5
|
+
import type { NextFunction } from 'express';
|
|
6
|
+
export declare class StripeService {
|
|
7
|
+
submitter: SubscriptionSubmitter;
|
|
8
|
+
private isFullySynced;
|
|
9
|
+
constructor();
|
|
10
|
+
syncAll(next: NextFunction): Promise<void>;
|
|
11
|
+
syncFull(): Promise<void>;
|
|
12
|
+
syncCustomer(customer: CustomerEntity): Promise<void>;
|
|
13
|
+
syncOne(customer: CustomerEntity): Promise<void>;
|
|
14
|
+
createSubscription(subscription: Stripe.Subscription, customer?: CustomerEntity): Promise<void>;
|
|
15
|
+
updateSubscription(subscription: Stripe.Subscription, current: SubscriptionEntity): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
export declare const stripeService: StripeService;
|
|
18
|
+
//# sourceMappingURL=stripe.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stripe.d.ts","sourceRoot":"","sources":["../../../src/services/admin/stripe.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAG5B,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AAEjF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,gDAAgD,CAAC;AAGzF,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;AACjF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAI5C,qBAAa,aAAa;IACzB,SAAS,EAAE,qBAAqB,CAAC;IACjC,OAAO,CAAC,aAAa,CAAS;;IAMxB,OAAO,CAAC,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ1C,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAyBzB,YAAY,CAAC,QAAQ,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBrD,OAAO,CAAC,QAAQ,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IA0DhD,kBAAkB,CAAC,YAAY,EAAE,MAAM,CAAC,YAAY,EAAE,QAAQ,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAM/F,kBAAkB,CAAC,YAAY,EAAE,MAAM,CAAC,YAAY,EAAE,OAAO,EAAE,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC;CAgBvG;AAED,eAAO,MAAM,aAAa,eAAsB,CAAC"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import Stripe from 'stripe';
|
|
2
|
+
import * as dotenv from 'dotenv';
|
|
3
|
+
import { SubscriptionService } from './subscription.js';
|
|
4
|
+
import { EventTracker, eventTracker } from '../track/tracker.js';
|
|
5
|
+
import { buildSubmitOperation } from '../track/helpers.js';
|
|
6
|
+
import { OperationNameEnum } from '../../types/constants.js';
|
|
7
|
+
import { SubscriptionSubmitter } from '../track/admin/subscription-submitter.js';
|
|
8
|
+
dotenv.config();
|
|
9
|
+
export class StripeService {
|
|
10
|
+
submitter;
|
|
11
|
+
isFullySynced = false;
|
|
12
|
+
constructor() {
|
|
13
|
+
this.submitter = new SubscriptionSubmitter(eventTracker.getEmitter());
|
|
14
|
+
}
|
|
15
|
+
async syncAll(next) {
|
|
16
|
+
if (!this.isFullySynced) {
|
|
17
|
+
await this.syncFull();
|
|
18
|
+
this.isFullySynced = true;
|
|
19
|
+
}
|
|
20
|
+
next();
|
|
21
|
+
}
|
|
22
|
+
async syncFull() {
|
|
23
|
+
const stripe = new Stripe(process.env.STRIPE_SECRET_KEY);
|
|
24
|
+
// Sync all subscriptions
|
|
25
|
+
for await (const subscription of stripe.subscriptions.list({
|
|
26
|
+
status: 'all',
|
|
27
|
+
})) {
|
|
28
|
+
const current = await SubscriptionService.instance.subscriptionRepository.findOne({
|
|
29
|
+
where: { subscriptionId: subscription.id },
|
|
30
|
+
});
|
|
31
|
+
if (current) {
|
|
32
|
+
await this.updateSubscription(subscription, current);
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
await this.createSubscription(subscription);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
await eventTracker.notify({
|
|
39
|
+
message: EventTracker.compileBasicNotification(`Subscription synchronization completed`, 'Subscription synchronization'),
|
|
40
|
+
severity: 'info',
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
// Sync all the subscriptions for current customer
|
|
44
|
+
async syncCustomer(customer) {
|
|
45
|
+
const stripe = new Stripe(process.env.STRIPE_SECRET_KEY);
|
|
46
|
+
for await (const subscription of stripe.subscriptions.list({
|
|
47
|
+
customer: customer.paymentProviderId,
|
|
48
|
+
status: 'all',
|
|
49
|
+
})) {
|
|
50
|
+
const current = await SubscriptionService.instance.subscriptionRepository.findOne({
|
|
51
|
+
where: { subscriptionId: subscription.id },
|
|
52
|
+
});
|
|
53
|
+
if (current) {
|
|
54
|
+
await this.updateSubscription(subscription, current);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
await this.createSubscription(subscription, customer);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
async syncOne(customer) {
|
|
62
|
+
const stripe = new Stripe(process.env.STRIPE_SECRET_KEY);
|
|
63
|
+
const local = await SubscriptionService.instance.findCurrent(customer);
|
|
64
|
+
if (!local) {
|
|
65
|
+
await eventTracker.notify({
|
|
66
|
+
message: EventTracker.compileBasicNotification(`Active subscription not found for customer with id ${customer.customerId}`, 'Subscription synchronization'),
|
|
67
|
+
severity: 'debug',
|
|
68
|
+
});
|
|
69
|
+
const activeSubs = await stripe.subscriptions.list({
|
|
70
|
+
customer: customer.paymentProviderId,
|
|
71
|
+
status: 'active',
|
|
72
|
+
});
|
|
73
|
+
const trialSubs = await stripe.subscriptions.list({
|
|
74
|
+
customer: customer.paymentProviderId,
|
|
75
|
+
status: 'trialing',
|
|
76
|
+
});
|
|
77
|
+
const subs = [...activeSubs.data, ...trialSubs.data];
|
|
78
|
+
if (subs.length > 1) {
|
|
79
|
+
await eventTracker.notify({
|
|
80
|
+
message: EventTracker.compileBasicNotification(`Multiple active subscriptions found for customer with id ${customer.customerId}`, 'Subscription synchronization'),
|
|
81
|
+
severity: 'error',
|
|
82
|
+
});
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
if (subs.length > 0) {
|
|
86
|
+
await this.createSubscription(subs[0], customer);
|
|
87
|
+
}
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
const subscriptionId = local.subscriptionId;
|
|
91
|
+
const remote = await stripe.subscriptions.retrieve(subscriptionId);
|
|
92
|
+
if (!remote) {
|
|
93
|
+
await eventTracker.notify({
|
|
94
|
+
message: EventTracker.compileBasicNotification(`Subscription with id ${subscriptionId} could not be retrieved from Stripe`, 'Subscription synchronization'),
|
|
95
|
+
severity: 'error',
|
|
96
|
+
});
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
const current = await SubscriptionService.instance.subscriptionRepository.findOne({
|
|
100
|
+
where: { subscriptionId: remote.id },
|
|
101
|
+
});
|
|
102
|
+
if (current) {
|
|
103
|
+
await this.updateSubscription(remote, current);
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
await this.createSubscription(remote);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
async createSubscription(subscription, customer) {
|
|
110
|
+
await this.submitter.submitSubscriptionCreate(buildSubmitOperation(subscription, OperationNameEnum.SUBSCRIPTION_CREATE, { customer: customer }));
|
|
111
|
+
}
|
|
112
|
+
async updateSubscription(subscription, current) {
|
|
113
|
+
// Update only if there are changes
|
|
114
|
+
if (SubscriptionService.instance.equals(current, subscription)) {
|
|
115
|
+
await eventTracker.notify({
|
|
116
|
+
message: EventTracker.compileBasicNotification(`Subscription with id ${subscription.id} has no changes`, 'Subscription synchronization'),
|
|
117
|
+
severity: 'debug',
|
|
118
|
+
});
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
await this.submitter.submitSubscriptionUpdate(buildSubmitOperation(subscription, OperationNameEnum.SUBSCRIPTION_UPDATE));
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
export const stripeService = new StripeService();
|
|
125
|
+
//# sourceMappingURL=stripe.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stripe.js","sourceRoot":"","sources":["../../../src/services/admin/stripe.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { Repository } from 'typeorm';
|
|
2
|
+
import { SubscriptionEntity } from '../../database/entities/subscription.entity.js';
|
|
3
|
+
import type { CustomerEntity } from '../../database/entities/customer.entity.js';
|
|
4
|
+
import type Stripe from 'stripe';
|
|
5
|
+
export declare class SubscriptionService {
|
|
6
|
+
subscriptionRepository: Repository<SubscriptionEntity>;
|
|
7
|
+
static instance: SubscriptionService;
|
|
8
|
+
constructor();
|
|
9
|
+
create(subscriptionId: string, customer: CustomerEntity, status: string, currentPeriodStart: Date, currentPeriodEnd: Date, trialStart?: Date, trialEnd?: Date): Promise<SubscriptionEntity>;
|
|
10
|
+
update(subscriptionId: string, status?: string, currentPeriodStart?: Date, currentPeriodEnd?: Date, trialStart?: Date, trialEnd?: Date): Promise<SubscriptionEntity>;
|
|
11
|
+
get(subscriptionId?: string): Promise<SubscriptionEntity | null>;
|
|
12
|
+
findOne(where: Record<string, unknown>): Promise<SubscriptionEntity | null>;
|
|
13
|
+
findCurrent(customer: CustomerEntity): Promise<SubscriptionEntity | null>;
|
|
14
|
+
equals(subscriptionEntity: SubscriptionEntity, subscription: Stripe.Subscription): boolean;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=subscription.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"subscription.d.ts","sourceRoot":"","sources":["../../../src/services/admin/subscription.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAG1C,OAAO,EAAE,kBAAkB,EAAE,MAAM,gDAAgD,CAAC;AACpF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AAEjC,qBAAa,mBAAmB;IACxB,sBAAsB,EAAE,UAAU,CAAC,kBAAkB,CAAC,CAAC;IAG9D,OAAc,QAAQ,sBAA6B;;IAMtC,MAAM,CAClB,cAAc,EAAE,MAAM,EACtB,QAAQ,EAAE,cAAc,EACxB,MAAM,EAAE,MAAM,EACd,kBAAkB,EAAE,IAAI,EACxB,gBAAgB,EAAE,IAAI,EACtB,UAAU,CAAC,EAAE,IAAI,EACjB,QAAQ,CAAC,EAAE,IAAI,GACb,OAAO,CAAC,kBAAkB,CAAC;IAgBjB,MAAM,CAClB,cAAc,EAAE,MAAM,EACtB,MAAM,CAAC,EAAE,MAAM,EACf,kBAAkB,CAAC,EAAE,IAAI,EACzB,gBAAgB,CAAC,EAAE,IAAI,EACvB,UAAU,CAAC,EAAE,IAAI,EACjB,QAAQ,CAAC,EAAE,IAAI;IAcH,GAAG,CAAC,cAAc,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC;IAOhE,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAOtC,WAAW,CAAC,QAAQ,EAAE,cAAc;IAU1C,MAAM,CAAC,kBAAkB,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,CAAC,YAAY,GAAG,OAAO;CAqBjG"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { Connection } from '../../database/connection/connection.js';
|
|
2
|
+
import { SubscriptionEntity } from '../../database/entities/subscription.entity.js';
|
|
3
|
+
export class SubscriptionService {
|
|
4
|
+
subscriptionRepository;
|
|
5
|
+
// Get rid of such code and move it to the builder
|
|
6
|
+
static instance = new SubscriptionService();
|
|
7
|
+
constructor() {
|
|
8
|
+
this.subscriptionRepository = Connection.instance.dbConnection.getRepository(SubscriptionEntity);
|
|
9
|
+
}
|
|
10
|
+
async create(subscriptionId, customer, status, currentPeriodStart, currentPeriodEnd, trialStart, trialEnd) {
|
|
11
|
+
const subscriptionEntity = new SubscriptionEntity(subscriptionId, customer, status, currentPeriodStart, currentPeriodEnd, trialStart, trialEnd);
|
|
12
|
+
const res = await this.subscriptionRepository.insert(subscriptionEntity);
|
|
13
|
+
if (!res)
|
|
14
|
+
throw new Error(`Cannot create a new subscription`);
|
|
15
|
+
return subscriptionEntity;
|
|
16
|
+
}
|
|
17
|
+
async update(subscriptionId, status, currentPeriodStart, currentPeriodEnd, trialStart, trialEnd) {
|
|
18
|
+
const existing = await this.subscriptionRepository.findOneBy({ subscriptionId });
|
|
19
|
+
if (!existing) {
|
|
20
|
+
throw new Error(`Subscription with id ${subscriptionId} not found`);
|
|
21
|
+
}
|
|
22
|
+
if (status)
|
|
23
|
+
existing.status = status;
|
|
24
|
+
if (currentPeriodStart)
|
|
25
|
+
existing.currentPeriodStart = currentPeriodStart;
|
|
26
|
+
if (currentPeriodEnd)
|
|
27
|
+
existing.currentPeriodEnd = currentPeriodEnd;
|
|
28
|
+
if (trialStart)
|
|
29
|
+
existing.trialStart = trialStart;
|
|
30
|
+
if (trialEnd)
|
|
31
|
+
existing.trialEnd = trialEnd;
|
|
32
|
+
return await this.subscriptionRepository.save(existing);
|
|
33
|
+
}
|
|
34
|
+
async get(subscriptionId) {
|
|
35
|
+
return await this.subscriptionRepository.findOne({
|
|
36
|
+
where: { subscriptionId },
|
|
37
|
+
relations: ['customer'],
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
async findOne(where) {
|
|
41
|
+
return await this.subscriptionRepository.findOne({
|
|
42
|
+
where: where,
|
|
43
|
+
relations: ['customer'],
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
async findCurrent(customer) {
|
|
47
|
+
return await this.subscriptionRepository.findOne({
|
|
48
|
+
where: [
|
|
49
|
+
{ customer: customer, status: 'active' },
|
|
50
|
+
{ customer: customer, status: 'trialing' },
|
|
51
|
+
],
|
|
52
|
+
relations: ['customer'],
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
equals(subscriptionEntity, subscription) {
|
|
56
|
+
const required = subscriptionEntity.subscriptionId === subscription.id &&
|
|
57
|
+
subscriptionEntity.status === subscription.status &&
|
|
58
|
+
subscriptionEntity.currentPeriodStart.getTime() === subscription.current_period_start * 1000 &&
|
|
59
|
+
subscriptionEntity.currentPeriodEnd.getTime() === subscription.current_period_end * 1000;
|
|
60
|
+
if (!required)
|
|
61
|
+
return false;
|
|
62
|
+
// Check trial dates only if they are present in the subscription
|
|
63
|
+
if (subscription.trial_start) {
|
|
64
|
+
if (!subscriptionEntity.trialStart ||
|
|
65
|
+
subscriptionEntity.trialStart.getTime() !== subscription.trial_start * 1000)
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
if (subscription.trial_end) {
|
|
69
|
+
if (!subscriptionEntity.trialEnd || subscriptionEntity.trialEnd.getTime() !== subscription.trial_end * 1000)
|
|
70
|
+
return false;
|
|
71
|
+
}
|
|
72
|
+
return true;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=subscription.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"subscription.js","sourceRoot":"","sources":["../../../src/services/admin/subscription.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Repository } from 'typeorm';
|
|
2
|
+
import { CoinEntity } from '../../database/entities/coin.entity.js';
|
|
3
|
+
export declare class CoinService {
|
|
4
|
+
coinRepository: Repository<CoinEntity>;
|
|
5
|
+
static instance: CoinService;
|
|
6
|
+
constructor();
|
|
7
|
+
create(amount: bigint, denom?: string): Promise<CoinEntity>;
|
|
8
|
+
update(coinId: string, amount?: bigint, denom?: string): Promise<CoinEntity>;
|
|
9
|
+
get(coinId?: string): Promise<CoinEntity | null>;
|
|
10
|
+
findOne(where: Record<string, unknown>): Promise<CoinEntity | null>;
|
|
11
|
+
isExist(where: Record<string, unknown>): Promise<boolean>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=coin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coin.d.ts","sourceRoot":"","sources":["../../../src/services/api/coin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAG1C,OAAO,EAAE,UAAU,EAAE,MAAM,wCAAwC,CAAC;AAIpE,qBAAa,WAAW;IAChB,cAAc,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC;IAG9C,OAAc,QAAQ,cAAqB;;IAM9B,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,SAAgB,GAAG,OAAO,CAAC,UAAU,CAAC;IASlE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,SAAgB;IAU7D,GAAG,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IAMhD,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAMtC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAOnD"}
|