@minimaltech/node-infra 0.2.27
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 +26 -0
- package/README.md +8 -0
- package/dist/base/applications/base.application.d.ts +306 -0
- package/dist/base/applications/base.application.js +147 -0
- package/dist/base/applications/base.application.js.map +1 -0
- package/dist/base/applications/default.application.d.ts +19 -0
- package/dist/base/applications/default.application.js +78 -0
- package/dist/base/applications/default.application.js.map +1 -0
- package/dist/base/applications/index.d.ts +2 -0
- package/dist/base/applications/index.js +19 -0
- package/dist/base/applications/index.js.map +1 -0
- package/dist/base/base.component.d.ts +8 -0
- package/dist/base/base.component.js +12 -0
- package/dist/base/base.component.js.map +1 -0
- package/dist/base/base.datasource.d.ts +9 -0
- package/dist/base/base.datasource.js +13 -0
- package/dist/base/base.datasource.js.map +1 -0
- package/dist/base/base.model.d.ts +107 -0
- package/dist/base/base.model.js +79 -0
- package/dist/base/base.model.js.map +1 -0
- package/dist/base/base.provider.d.ts +7 -0
- package/dist/base/base.provider.js +12 -0
- package/dist/base/base.provider.js.map +1 -0
- package/dist/base/base.sequence.d.ts +8 -0
- package/dist/base/base.sequence.js +62 -0
- package/dist/base/base.sequence.js.map +1 -0
- package/dist/base/base.service.d.ts +8 -0
- package/dist/base/base.service.js +12 -0
- package/dist/base/base.service.js.map +1 -0
- package/dist/base/controllers/common.d.ts +17 -0
- package/dist/base/controllers/common.js +33 -0
- package/dist/base/controllers/common.js.map +1 -0
- package/dist/base/controllers/crud.controller.d.ts +39 -0
- package/dist/base/controllers/crud.controller.js +297 -0
- package/dist/base/controllers/crud.controller.js.map +1 -0
- package/dist/base/controllers/index.d.ts +4 -0
- package/dist/base/controllers/index.js +21 -0
- package/dist/base/controllers/index.js.map +1 -0
- package/dist/base/controllers/kv.controller.d.ts +20 -0
- package/dist/base/controllers/kv.controller.js +139 -0
- package/dist/base/controllers/kv.controller.js.map +1 -0
- package/dist/base/controllers/relational.controller.d.ts +40 -0
- package/dist/base/controllers/relational.controller.js +393 -0
- package/dist/base/controllers/relational.controller.js.map +1 -0
- package/dist/base/index.d.ts +9 -0
- package/dist/base/index.js +26 -0
- package/dist/base/index.js.map +1 -0
- package/dist/base/repositories/base.repository.d.ts +54 -0
- package/dist/base/repositories/base.repository.js +156 -0
- package/dist/base/repositories/base.repository.js.map +1 -0
- package/dist/base/repositories/index.d.ts +3 -0
- package/dist/base/repositories/index.js +20 -0
- package/dist/base/repositories/index.js.map +1 -0
- package/dist/base/repositories/searchable-tz-crud.repository.d.ts +42 -0
- package/dist/base/repositories/searchable-tz-crud.repository.js +241 -0
- package/dist/base/repositories/searchable-tz-crud.repository.js.map +1 -0
- package/dist/base/repositories/tz-crud.repository.d.ts +64 -0
- package/dist/base/repositories/tz-crud.repository.js +244 -0
- package/dist/base/repositories/tz-crud.repository.js.map +1 -0
- package/dist/common/constants.d.ts +62 -0
- package/dist/common/constants.js +87 -0
- package/dist/common/constants.js.map +1 -0
- package/dist/common/environments.d.ts +20 -0
- package/dist/common/environments.js +25 -0
- package/dist/common/environments.js.map +1 -0
- package/dist/common/index.d.ts +5 -0
- package/dist/common/index.js +22 -0
- package/dist/common/index.js.map +1 -0
- package/dist/common/keys.d.ts +4 -0
- package/dist/common/keys.js +9 -0
- package/dist/common/keys.js.map +1 -0
- package/dist/common/statuses.d.ts +36 -0
- package/dist/common/statuses.js +53 -0
- package/dist/common/statuses.js.map +1 -0
- package/dist/common/types.d.ts +96 -0
- package/dist/common/types.js +3 -0
- package/dist/common/types.js.map +1 -0
- package/dist/components/authenticate/common/constants.d.ts +15 -0
- package/dist/components/authenticate/common/constants.js +23 -0
- package/dist/components/authenticate/common/constants.js.map +1 -0
- package/dist/components/authenticate/common/index.d.ts +3 -0
- package/dist/components/authenticate/common/index.js +20 -0
- package/dist/components/authenticate/common/index.js.map +1 -0
- package/dist/components/authenticate/common/keys.d.ts +8 -0
- package/dist/components/authenticate/common/keys.js +13 -0
- package/dist/components/authenticate/common/keys.js.map +1 -0
- package/dist/components/authenticate/common/types.d.ts +80 -0
- package/dist/components/authenticate/common/types.js +146 -0
- package/dist/components/authenticate/common/types.js.map +1 -0
- package/dist/components/authenticate/component.d.ts +14 -0
- package/dist/components/authenticate/component.js +143 -0
- package/dist/components/authenticate/component.js.map +1 -0
- package/dist/components/authenticate/controllers/auth.controller.d.ts +21 -0
- package/dist/components/authenticate/controllers/auth.controller.js +125 -0
- package/dist/components/authenticate/controllers/auth.controller.js.map +1 -0
- package/dist/components/authenticate/controllers/index.d.ts +2 -0
- package/dist/components/authenticate/controllers/index.js +19 -0
- package/dist/components/authenticate/controllers/index.js.map +1 -0
- package/dist/components/authenticate/controllers/oauth2.controller.d.ts +46 -0
- package/dist/components/authenticate/controllers/oauth2.controller.js +227 -0
- package/dist/components/authenticate/controllers/oauth2.controller.js.map +1 -0
- package/dist/components/authenticate/index.d.ts +7 -0
- package/dist/components/authenticate/index.js +24 -0
- package/dist/components/authenticate/index.js.map +1 -0
- package/dist/components/authenticate/middleware.d.ts +11 -0
- package/dist/components/authenticate/middleware.js +89 -0
- package/dist/components/authenticate/middleware.js.map +1 -0
- package/dist/components/authenticate/models/index.d.ts +3 -0
- package/dist/components/authenticate/models/index.js +20 -0
- package/dist/components/authenticate/models/index.js.map +1 -0
- package/dist/components/authenticate/models/oauth2-client.model.d.ts +19 -0
- package/dist/components/authenticate/models/oauth2-client.model.js +100 -0
- package/dist/components/authenticate/models/oauth2-client.model.js.map +1 -0
- package/dist/components/authenticate/models/oauth2-scope.model.d.ts +8 -0
- package/dist/components/authenticate/models/oauth2-scope.model.js +61 -0
- package/dist/components/authenticate/models/oauth2-scope.model.js.map +1 -0
- package/dist/components/authenticate/models/oauth2-token.model.d.ts +12 -0
- package/dist/components/authenticate/models/oauth2-token.model.js +87 -0
- package/dist/components/authenticate/models/oauth2-token.model.js.map +1 -0
- package/dist/components/authenticate/oauth2-handlers/authorization-code.handler.d.ts +13 -0
- package/dist/components/authenticate/oauth2-handlers/authorization-code.handler.js +56 -0
- package/dist/components/authenticate/oauth2-handlers/authorization-code.handler.js.map +1 -0
- package/dist/components/authenticate/oauth2-handlers/base.d.ts +37 -0
- package/dist/components/authenticate/oauth2-handlers/base.js +192 -0
- package/dist/components/authenticate/oauth2-handlers/base.js.map +1 -0
- package/dist/components/authenticate/oauth2-handlers/client-credential.handler.d.ts +12 -0
- package/dist/components/authenticate/oauth2-handlers/client-credential.handler.js +28 -0
- package/dist/components/authenticate/oauth2-handlers/client-credential.handler.js.map +1 -0
- package/dist/components/authenticate/oauth2-handlers/index.d.ts +5 -0
- package/dist/components/authenticate/oauth2-handlers/index.js +22 -0
- package/dist/components/authenticate/oauth2-handlers/index.js.map +1 -0
- package/dist/components/authenticate/oauth2-handlers/oauth2.d.ts +15 -0
- package/dist/components/authenticate/oauth2-handlers/oauth2.js +36 -0
- package/dist/components/authenticate/oauth2-handlers/oauth2.js.map +1 -0
- package/dist/components/authenticate/oauth2-handlers/password.handler.d.ts +12 -0
- package/dist/components/authenticate/oauth2-handlers/password.handler.js +22 -0
- package/dist/components/authenticate/oauth2-handlers/password.handler.js.map +1 -0
- package/dist/components/authenticate/repositories/index.d.ts +1 -0
- package/dist/components/authenticate/repositories/index.js +18 -0
- package/dist/components/authenticate/repositories/index.js.map +1 -0
- package/dist/components/authenticate/repositories/oauth2.repository.d.ts +17 -0
- package/dist/components/authenticate/repositories/oauth2.repository.js +78 -0
- package/dist/components/authenticate/repositories/oauth2.repository.js.map +1 -0
- package/dist/components/authenticate/services/basic-token.service.d.ts +8 -0
- package/dist/components/authenticate/services/basic-token.service.js +42 -0
- package/dist/components/authenticate/services/basic-token.service.js.map +1 -0
- package/dist/components/authenticate/services/basic.strategy.d.ts +13 -0
- package/dist/components/authenticate/services/basic.strategy.js +64 -0
- package/dist/components/authenticate/services/basic.strategy.js.map +1 -0
- package/dist/components/authenticate/services/index.d.ts +6 -0
- package/dist/components/authenticate/services/index.js +23 -0
- package/dist/components/authenticate/services/index.js.map +1 -0
- package/dist/components/authenticate/services/jwt-token.service.d.ts +23 -0
- package/dist/components/authenticate/services/jwt-token.service.js +154 -0
- package/dist/components/authenticate/services/jwt-token.service.js.map +1 -0
- package/dist/components/authenticate/services/jwt.strategy.d.ts +9 -0
- package/dist/components/authenticate/services/jwt.strategy.js +34 -0
- package/dist/components/authenticate/services/jwt.strategy.js.map +1 -0
- package/dist/components/authenticate/services/oauth2.service.d.ts +51 -0
- package/dist/components/authenticate/services/oauth2.service.js +208 -0
- package/dist/components/authenticate/services/oauth2.service.js.map +1 -0
- package/dist/components/authenticate/services/oauth2.strategy.d.ts +23 -0
- package/dist/components/authenticate/services/oauth2.strategy.js +69 -0
- package/dist/components/authenticate/services/oauth2.strategy.js.map +1 -0
- package/dist/components/authenticate/views/fragments/footer.ejs +0 -0
- package/dist/components/authenticate/views/fragments/head.ejs +26 -0
- package/dist/components/authenticate/views/fragments/header.ejs +0 -0
- package/dist/components/authenticate/views/pages/auth.ejs +61 -0
- package/dist/components/authenticate/views/pages/error.ejs +21 -0
- package/dist/components/authorize/adapters/adapter-builder.d.ts +12 -0
- package/dist/components/authorize/adapters/adapter-builder.js +34 -0
- package/dist/components/authorize/adapters/adapter-builder.js.map +1 -0
- package/dist/components/authorize/adapters/base.adapter.d.ts +18 -0
- package/dist/components/authorize/adapters/base.adapter.js +67 -0
- package/dist/components/authorize/adapters/base.adapter.js.map +1 -0
- package/dist/components/authorize/adapters/casbin-postgres-adapter.helper.d.ts +12 -0
- package/dist/components/authorize/adapters/casbin-postgres-adapter.helper.js +91 -0
- package/dist/components/authorize/adapters/casbin-postgres-adapter.helper.js.map +1 -0
- package/dist/components/authorize/adapters/casbin-redis-adapter.helper.d.ts +7 -0
- package/dist/components/authorize/adapters/casbin-redis-adapter.helper.js +15 -0
- package/dist/components/authorize/adapters/casbin-redis-adapter.helper.js.map +1 -0
- package/dist/components/authorize/adapters/index.d.ts +4 -0
- package/dist/components/authorize/adapters/index.js +21 -0
- package/dist/components/authorize/adapters/index.js.map +1 -0
- package/dist/components/authorize/common/constants.d.ts +14 -0
- package/dist/components/authorize/common/constants.js +22 -0
- package/dist/components/authorize/common/constants.js.map +1 -0
- package/dist/components/authorize/common/index.d.ts +3 -0
- package/dist/components/authorize/common/index.js +20 -0
- package/dist/components/authorize/common/index.js.map +1 -0
- package/dist/components/authorize/common/keys.d.ts +17 -0
- package/dist/components/authorize/common/keys.js +22 -0
- package/dist/components/authorize/common/keys.js.map +1 -0
- package/dist/components/authorize/common/types.d.ts +16 -0
- package/dist/components/authorize/common/types.js +9 -0
- package/dist/components/authorize/common/types.js.map +1 -0
- package/dist/components/authorize/component.d.ts +12 -0
- package/dist/components/authorize/component.js +158 -0
- package/dist/components/authorize/component.js.map +1 -0
- package/dist/components/authorize/decorators/index.d.ts +8 -0
- package/dist/components/authorize/decorators/index.js +19 -0
- package/dist/components/authorize/decorators/index.js.map +1 -0
- package/dist/components/authorize/index.d.ts +9 -0
- package/dist/components/authorize/index.js +26 -0
- package/dist/components/authorize/index.js.map +1 -0
- package/dist/components/authorize/interceptor.d.ts +9 -0
- package/dist/components/authorize/interceptor.js +121 -0
- package/dist/components/authorize/interceptor.js.map +1 -0
- package/dist/components/authorize/migrations/0000-create-view-policy.d.ts +7 -0
- package/dist/components/authorize/migrations/0000-create-view-policy.js +83 -0
- package/dist/components/authorize/migrations/0000-create-view-policy.js.map +1 -0
- package/dist/components/authorize/migrations/index.d.ts +1 -0
- package/dist/components/authorize/migrations/index.js +18 -0
- package/dist/components/authorize/migrations/index.js.map +1 -0
- package/dist/components/authorize/models/defs.d.ts +173 -0
- package/dist/components/authorize/models/defs.js +243 -0
- package/dist/components/authorize/models/defs.js.map +1 -0
- package/dist/components/authorize/models/index.d.ts +6 -0
- package/dist/components/authorize/models/index.js +23 -0
- package/dist/components/authorize/models/index.js.map +1 -0
- package/dist/components/authorize/models/permission-mapping.model.d.ts +36 -0
- package/dist/components/authorize/models/permission-mapping.model.js +40 -0
- package/dist/components/authorize/models/permission-mapping.model.js.map +1 -0
- package/dist/components/authorize/models/permission.model.d.ts +44 -0
- package/dist/components/authorize/models/permission.model.js +34 -0
- package/dist/components/authorize/models/permission.model.js.map +1 -0
- package/dist/components/authorize/models/role.model.d.ts +40 -0
- package/dist/components/authorize/models/role.model.js +46 -0
- package/dist/components/authorize/models/role.model.js.map +1 -0
- package/dist/components/authorize/models/user-role.model.d.ts +34 -0
- package/dist/components/authorize/models/user-role.model.js +35 -0
- package/dist/components/authorize/models/user-role.model.js.map +1 -0
- package/dist/components/authorize/models/view-authorize-policy.model.d.ts +9 -0
- package/dist/components/authorize/models/view-authorize-policy.model.js +70 -0
- package/dist/components/authorize/models/view-authorize-policy.model.js.map +1 -0
- package/dist/components/authorize/provider.d.ts +30 -0
- package/dist/components/authorize/provider.js +157 -0
- package/dist/components/authorize/provider.js.map +1 -0
- package/dist/components/authorize/repositories/authorize.repository.d.ts +33 -0
- package/dist/components/authorize/repositories/authorize.repository.js +105 -0
- package/dist/components/authorize/repositories/authorize.repository.js.map +1 -0
- package/dist/components/authorize/repositories/index.d.ts +1 -0
- package/dist/components/authorize/repositories/index.js +18 -0
- package/dist/components/authorize/repositories/index.js.map +1 -0
- package/dist/components/authorize/services/enforcer.service.d.ts +13 -0
- package/dist/components/authorize/services/enforcer.service.js +99 -0
- package/dist/components/authorize/services/enforcer.service.js.map +1 -0
- package/dist/components/authorize/services/generator.service.d.ts +54 -0
- package/dist/components/authorize/services/generator.service.js +161 -0
- package/dist/components/authorize/services/generator.service.js.map +1 -0
- package/dist/components/authorize/services/index.d.ts +2 -0
- package/dist/components/authorize/services/index.js +19 -0
- package/dist/components/authorize/services/index.js.map +1 -0
- package/dist/components/grpc/common/constants.d.ts +2 -0
- package/dist/components/grpc/common/constants.js +6 -0
- package/dist/components/grpc/common/constants.js.map +1 -0
- package/dist/components/grpc/common/index.d.ts +3 -0
- package/dist/components/grpc/common/index.js +20 -0
- package/dist/components/grpc/common/index.js.map +1 -0
- package/dist/components/grpc/common/keys.d.ts +10 -0
- package/dist/components/grpc/common/keys.js +17 -0
- package/dist/components/grpc/common/keys.js.map +1 -0
- package/dist/components/grpc/common/types.d.ts +31 -0
- package/dist/components/grpc/common/types.js +3 -0
- package/dist/components/grpc/common/types.js.map +1 -0
- package/dist/components/grpc/components/index.d.ts +1 -0
- package/dist/components/grpc/components/index.js +18 -0
- package/dist/components/grpc/components/index.js.map +1 -0
- package/dist/components/grpc/components/server.component.d.ts +10 -0
- package/dist/components/grpc/components/server.component.js +65 -0
- package/dist/components/grpc/components/server.component.js.map +1 -0
- package/dist/components/grpc/controllers/base.d.ts +14 -0
- package/dist/components/grpc/controllers/base.js +31 -0
- package/dist/components/grpc/controllers/base.js.map +1 -0
- package/dist/components/grpc/controllers/index.d.ts +1 -0
- package/dist/components/grpc/controllers/index.js +18 -0
- package/dist/components/grpc/controllers/index.js.map +1 -0
- package/dist/components/grpc/decorators/index.d.ts +3 -0
- package/dist/components/grpc/decorators/index.js +14 -0
- package/dist/components/grpc/decorators/index.js.map +1 -0
- package/dist/components/grpc/helpers/grpc-client.d.ts +15 -0
- package/dist/components/grpc/helpers/grpc-client.js +58 -0
- package/dist/components/grpc/helpers/grpc-client.js.map +1 -0
- package/dist/components/grpc/helpers/grpc-server.d.ts +21 -0
- package/dist/components/grpc/helpers/grpc-server.js +152 -0
- package/dist/components/grpc/helpers/grpc-server.js.map +1 -0
- package/dist/components/grpc/helpers/index.d.ts +2 -0
- package/dist/components/grpc/helpers/index.js +19 -0
- package/dist/components/grpc/helpers/index.js.map +1 -0
- package/dist/components/grpc/index.d.ts +6 -0
- package/dist/components/grpc/index.js +23 -0
- package/dist/components/grpc/index.js.map +1 -0
- package/dist/components/grpc/persistents/grpc.connector.d.ts +27 -0
- package/dist/components/grpc/persistents/grpc.connector.js +39 -0
- package/dist/components/grpc/persistents/grpc.connector.js.map +1 -0
- package/dist/components/grpc/persistents/grpc.datasource.d.ts +21 -0
- package/dist/components/grpc/persistents/grpc.datasource.js +43 -0
- package/dist/components/grpc/persistents/grpc.datasource.js.map +1 -0
- package/dist/components/grpc/persistents/grpc.repository.d.ts +13 -0
- package/dist/components/grpc/persistents/grpc.repository.js +28 -0
- package/dist/components/grpc/persistents/grpc.repository.js.map +1 -0
- package/dist/components/grpc/persistents/index.d.ts +3 -0
- package/dist/components/grpc/persistents/index.js +20 -0
- package/dist/components/grpc/persistents/index.js.map +1 -0
- package/dist/components/index.d.ts +6 -0
- package/dist/components/index.js +23 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/migration/common/index.d.ts +2 -0
- package/dist/components/migration/common/index.js +19 -0
- package/dist/components/migration/common/index.js.map +1 -0
- package/dist/components/migration/common/keys.d.ts +5 -0
- package/dist/components/migration/common/keys.js +10 -0
- package/dist/components/migration/common/keys.js.map +1 -0
- package/dist/components/migration/common/types.d.ts +9 -0
- package/dist/components/migration/common/types.js +3 -0
- package/dist/components/migration/common/types.js.map +1 -0
- package/dist/components/migration/component.d.ts +11 -0
- package/dist/components/migration/component.js +55 -0
- package/dist/components/migration/component.js.map +1 -0
- package/dist/components/migration/index.d.ts +4 -0
- package/dist/components/migration/index.js +21 -0
- package/dist/components/migration/index.js.map +1 -0
- package/dist/components/migration/models/index.d.ts +1 -0
- package/dist/components/migration/models/index.js +18 -0
- package/dist/components/migration/models/index.js.map +1 -0
- package/dist/components/migration/models/migration.model.d.ts +6 -0
- package/dist/components/migration/models/migration.model.js +54 -0
- package/dist/components/migration/models/migration.model.js.map +1 -0
- package/dist/components/migration/repositories/index.d.ts +1 -0
- package/dist/components/migration/repositories/index.js +18 -0
- package/dist/components/migration/repositories/index.js.map +1 -0
- package/dist/components/migration/repositories/migration.repository.d.ts +13 -0
- package/dist/components/migration/repositories/migration.repository.js +53 -0
- package/dist/components/migration/repositories/migration.repository.js.map +1 -0
- package/dist/components/socket-io/common/constants.d.ts +12 -0
- package/dist/components/socket-io/common/constants.js +17 -0
- package/dist/components/socket-io/common/constants.js.map +1 -0
- package/dist/components/socket-io/common/index.d.ts +2 -0
- package/dist/components/socket-io/common/index.js +19 -0
- package/dist/components/socket-io/common/index.js.map +1 -0
- package/dist/components/socket-io/common/keys.d.ts +8 -0
- package/dist/components/socket-io/common/keys.js +13 -0
- package/dist/components/socket-io/common/keys.js.map +1 -0
- package/dist/components/socket-io/component.d.ts +9 -0
- package/dist/components/socket-io/component.js +73 -0
- package/dist/components/socket-io/component.js.map +1 -0
- package/dist/components/socket-io/helpers/index.d.ts +2 -0
- package/dist/components/socket-io/helpers/index.js +19 -0
- package/dist/components/socket-io/helpers/index.js.map +1 -0
- package/dist/components/socket-io/helpers/socket-io-client.helper.d.ts +34 -0
- package/dist/components/socket-io/helpers/socket-io-client.helper.js +89 -0
- package/dist/components/socket-io/helpers/socket-io-client.helper.js.map +1 -0
- package/dist/components/socket-io/helpers/socket-io-server.helper.d.ts +74 -0
- package/dist/components/socket-io/helpers/socket-io-server.helper.js +325 -0
- package/dist/components/socket-io/helpers/socket-io-server.helper.js.map +1 -0
- package/dist/components/socket-io/helpers/types.d.ts +15 -0
- package/dist/components/socket-io/helpers/types.js +3 -0
- package/dist/components/socket-io/helpers/types.js.map +1 -0
- package/dist/components/socket-io/index.d.ts +3 -0
- package/dist/components/socket-io/index.js +20 -0
- package/dist/components/socket-io/index.js.map +1 -0
- package/dist/components/static-asset/common/index.d.ts +1 -0
- package/dist/components/static-asset/common/index.js +18 -0
- package/dist/components/static-asset/common/index.js.map +1 -0
- package/dist/components/static-asset/common/keys.d.ts +6 -0
- package/dist/components/static-asset/common/keys.js +11 -0
- package/dist/components/static-asset/common/keys.js.map +1 -0
- package/dist/components/static-asset/component.d.ts +13 -0
- package/dist/components/static-asset/component.js +73 -0
- package/dist/components/static-asset/component.js.map +1 -0
- package/dist/components/static-asset/controllers/asset.controller.d.ts +18 -0
- package/dist/components/static-asset/controllers/asset.controller.js +239 -0
- package/dist/components/static-asset/controllers/asset.controller.js.map +1 -0
- package/dist/components/static-asset/controllers/index.d.ts +2 -0
- package/dist/components/static-asset/controllers/index.js +19 -0
- package/dist/components/static-asset/controllers/index.js.map +1 -0
- package/dist/components/static-asset/controllers/resource.controller.d.ts +14 -0
- package/dist/components/static-asset/controllers/resource.controller.js +140 -0
- package/dist/components/static-asset/controllers/resource.controller.js.map +1 -0
- package/dist/components/static-asset/index.d.ts +3 -0
- package/dist/components/static-asset/index.js +20 -0
- package/dist/components/static-asset/index.js.map +1 -0
- package/dist/datasources/index.d.ts +2 -0
- package/dist/datasources/index.js +19 -0
- package/dist/datasources/index.js.map +1 -0
- package/dist/datasources/kvmem.datasource.d.ts +9 -0
- package/dist/datasources/kvmem.datasource.js +36 -0
- package/dist/datasources/kvmem.datasource.js.map +1 -0
- package/dist/datasources/postgres.datasource.d.ts +14 -0
- package/dist/datasources/postgres.datasource.js +71 -0
- package/dist/datasources/postgres.datasource.js.map +1 -0
- package/dist/helpers/application-environment.helper.d.ts +13 -0
- package/dist/helpers/application-environment.helper.js +31 -0
- package/dist/helpers/application-environment.helper.js.map +1 -0
- package/dist/helpers/cron.helper.d.ts +21 -0
- package/dist/helpers/cron.helper.js +59 -0
- package/dist/helpers/cron.helper.js.map +1 -0
- package/dist/helpers/database/index.d.ts +1 -0
- package/dist/helpers/database/index.js +18 -0
- package/dist/helpers/database/index.js.map +1 -0
- package/dist/helpers/database/query-builder.helper.d.ts +43 -0
- package/dist/helpers/database/query-builder.helper.js +72 -0
- package/dist/helpers/database/query-builder.helper.js.map +1 -0
- package/dist/helpers/index.d.ts +9 -0
- package/dist/helpers/index.js +26 -0
- package/dist/helpers/index.js.map +1 -0
- package/dist/helpers/logger/application-logger.d.ts +13 -0
- package/dist/helpers/logger/application-logger.js +66 -0
- package/dist/helpers/logger/application-logger.js.map +1 -0
- package/dist/helpers/logger/default-logger.d.ts +4 -0
- package/dist/helpers/logger/default-logger.js +40 -0
- package/dist/helpers/logger/default-logger.js.map +1 -0
- package/dist/helpers/logger/factory.d.ts +4 -0
- package/dist/helpers/logger/factory.js +13 -0
- package/dist/helpers/logger/factory.js.map +1 -0
- package/dist/helpers/logger/index.d.ts +3 -0
- package/dist/helpers/logger/index.js +20 -0
- package/dist/helpers/logger/index.js.map +1 -0
- package/dist/helpers/network/base-network-request.d.ts +16 -0
- package/dist/helpers/network/base-network-request.js +65 -0
- package/dist/helpers/network/base-network-request.js.map +1 -0
- package/dist/helpers/network/index.d.ts +4 -0
- package/dist/helpers/network/index.js +21 -0
- package/dist/helpers/network/index.js.map +1 -0
- package/dist/helpers/network/network-tcp-client.helper.d.ts +45 -0
- package/dist/helpers/network/network-tcp-client.helper.js +136 -0
- package/dist/helpers/network/network-tcp-client.helper.js.map +1 -0
- package/dist/helpers/network/network-udp-client.helper.d.ts +43 -0
- package/dist/helpers/network/network-udp-client.helper.js +82 -0
- package/dist/helpers/network/network-udp-client.helper.js.map +1 -0
- package/dist/helpers/network/network.helper.d.ts +26 -0
- package/dist/helpers/network/network.helper.js +121 -0
- package/dist/helpers/network/network.helper.js.map +1 -0
- package/dist/helpers/queue/bullmq.helper.d.ts +32 -0
- package/dist/helpers/queue/bullmq.helper.js +94 -0
- package/dist/helpers/queue/bullmq.helper.js.map +1 -0
- package/dist/helpers/queue/index.d.ts +3 -0
- package/dist/helpers/queue/index.js +20 -0
- package/dist/helpers/queue/index.js.map +1 -0
- package/dist/helpers/queue/mqtt.helper.d.ts +35 -0
- package/dist/helpers/queue/mqtt.helper.js +99 -0
- package/dist/helpers/queue/mqtt.helper.js.map +1 -0
- package/dist/helpers/queue/queue.helper.d.ts +31 -0
- package/dist/helpers/queue/queue.helper.js +90 -0
- package/dist/helpers/queue/queue.helper.js.map +1 -0
- package/dist/helpers/redis.helper.d.ts +82 -0
- package/dist/helpers/redis.helper.js +238 -0
- package/dist/helpers/redis.helper.js.map +1 -0
- package/dist/helpers/storage/di-container.helper.d.ts +11 -0
- package/dist/helpers/storage/di-container.helper.js +28 -0
- package/dist/helpers/storage/di-container.helper.js.map +1 -0
- package/dist/helpers/storage/index.d.ts +2 -0
- package/dist/helpers/storage/index.js +19 -0
- package/dist/helpers/storage/index.js.map +1 -0
- package/dist/helpers/storage/minio.helper.d.ts +58 -0
- package/dist/helpers/storage/minio.helper.js +171 -0
- package/dist/helpers/storage/minio.helper.js.map +1 -0
- package/dist/helpers/testing/common.d.ts +6 -0
- package/dist/helpers/testing/common.js +10 -0
- package/dist/helpers/testing/common.js.map +1 -0
- package/dist/helpers/testing/describe.d.ts +15 -0
- package/dist/helpers/testing/describe.js +55 -0
- package/dist/helpers/testing/describe.js.map +1 -0
- package/dist/helpers/testing/index.d.ts +6 -0
- package/dist/helpers/testing/index.js +23 -0
- package/dist/helpers/testing/index.js.map +1 -0
- package/dist/helpers/testing/test-case.d.ts +20 -0
- package/dist/helpers/testing/test-case.js +18 -0
- package/dist/helpers/testing/test-case.js.map +1 -0
- package/dist/helpers/testing/test-handler.d.ts +23 -0
- package/dist/helpers/testing/test-handler.js +54 -0
- package/dist/helpers/testing/test-handler.js.map +1 -0
- package/dist/helpers/testing/test-plan/base.d.ts +28 -0
- package/dist/helpers/testing/test-plan/base.js +70 -0
- package/dist/helpers/testing/test-plan/base.js.map +1 -0
- package/dist/helpers/testing/test-plan/default.d.ts +5 -0
- package/dist/helpers/testing/test-plan/default.js +11 -0
- package/dist/helpers/testing/test-plan/default.js.map +1 -0
- package/dist/helpers/testing/test-plan/index.d.ts +2 -0
- package/dist/helpers/testing/test-plan/index.js +19 -0
- package/dist/helpers/testing/test-plan/index.js.map +1 -0
- package/dist/helpers/testing/types.d.ts +51 -0
- package/dist/helpers/testing/types.js +3 -0
- package/dist/helpers/testing/types.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.js +37 -0
- package/dist/index.js.map +1 -0
- package/dist/interceptors/content-range.interceptor.d.ts +26 -0
- package/dist/interceptors/content-range.interceptor.js +188 -0
- package/dist/interceptors/content-range.interceptor.js.map +1 -0
- package/dist/interceptors/index.d.ts +1 -0
- package/dist/interceptors/index.js +18 -0
- package/dist/interceptors/index.js.map +1 -0
- package/dist/middlewares/index.d.ts +2 -0
- package/dist/middlewares/index.js +19 -0
- package/dist/middlewares/index.js.map +1 -0
- package/dist/middlewares/request-body-parser.middleware.d.ts +9 -0
- package/dist/middlewares/request-body-parser.middleware.js +80 -0
- package/dist/middlewares/request-body-parser.middleware.js.map +1 -0
- package/dist/middlewares/request-spy.middleware.d.ts +8 -0
- package/dist/middlewares/request-spy.middleware.js +64 -0
- package/dist/middlewares/request-spy.middleware.js.map +1 -0
- package/dist/migrations/base-path.d.ts +1 -0
- package/dist/migrations/base-path.js +6 -0
- package/dist/migrations/base-path.js.map +1 -0
- package/dist/migrations/handler.d.ts +9 -0
- package/dist/migrations/handler.js +80 -0
- package/dist/migrations/handler.js.map +1 -0
- package/dist/migrations/index.d.ts +1 -0
- package/dist/migrations/index.js +18 -0
- package/dist/migrations/index.js.map +1 -0
- package/dist/mixins/data-type.mixin.d.ts +15 -0
- package/dist/mixins/data-type.mixin.js +68 -0
- package/dist/mixins/data-type.mixin.js.map +1 -0
- package/dist/mixins/index.d.ts +8 -0
- package/dist/mixins/index.js +25 -0
- package/dist/mixins/index.js.map +1 -0
- package/dist/mixins/object-search.mixin.d.ts +12 -0
- package/dist/mixins/object-search.mixin.js +31 -0
- package/dist/mixins/object-search.mixin.js.map +1 -0
- package/dist/mixins/principal.mixin.d.ts +13 -0
- package/dist/mixins/principal.mixin.js +41 -0
- package/dist/mixins/principal.mixin.js.map +1 -0
- package/dist/mixins/soft-delete.mixin.d.ts +11 -0
- package/dist/mixins/soft-delete.mixin.js +31 -0
- package/dist/mixins/soft-delete.mixin.js.map +1 -0
- package/dist/mixins/soft-persistent.mixin.d.ts +11 -0
- package/dist/mixins/soft-persistent.mixin.js +30 -0
- package/dist/mixins/soft-persistent.mixin.js.map +1 -0
- package/dist/mixins/text-search.mixin.d.ts +11 -0
- package/dist/mixins/text-search.mixin.js +31 -0
- package/dist/mixins/text-search.mixin.js.map +1 -0
- package/dist/mixins/tz.mixin.d.ts +12 -0
- package/dist/mixins/tz.mixin.js +42 -0
- package/dist/mixins/tz.mixin.js.map +1 -0
- package/dist/mixins/user-audit.mixin.d.ts +13 -0
- package/dist/mixins/user-audit.mixin.js +42 -0
- package/dist/mixins/user-audit.mixin.js.map +1 -0
- package/dist/static/security/authorize_model.conf +14 -0
- package/dist/static/security/authorize_model_match_subject.conf +14 -0
- package/dist/utilities/crypto.utility.d.ts +22 -0
- package/dist/utilities/crypto.utility.js +131 -0
- package/dist/utilities/crypto.utility.js.map +1 -0
- package/dist/utilities/date.utility.d.ts +13 -0
- package/dist/utilities/date.utility.js +59 -0
- package/dist/utilities/date.utility.js.map +1 -0
- package/dist/utilities/error.utility.d.ts +14 -0
- package/dist/utilities/error.utility.js +18 -0
- package/dist/utilities/error.utility.js.map +1 -0
- package/dist/utilities/index.d.ts +7 -0
- package/dist/utilities/index.js +24 -0
- package/dist/utilities/index.js.map +1 -0
- package/dist/utilities/parse.utility.d.ts +12 -0
- package/dist/utilities/parse.utility.js +160 -0
- package/dist/utilities/parse.utility.js.map +1 -0
- package/dist/utilities/performance.utility.d.ts +4 -0
- package/dist/utilities/performance.utility.js +11 -0
- package/dist/utilities/performance.utility.js.map +1 -0
- package/dist/utilities/request.utility.d.ts +17 -0
- package/dist/utilities/request.utility.js +41 -0
- package/dist/utilities/request.utility.js.map +1 -0
- package/dist/utilities/url.utility.d.ts +2 -0
- package/dist/utilities/url.utility.js +32 -0
- package/dist/utilities/url.utility.js.map +1 -0
- package/package.json +128 -0
@@ -0,0 +1,87 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
7
|
+
};
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
10
|
+
};
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
12
|
+
exports.OAuth2Token = void 0;
|
13
|
+
const base_model_1 = require("../../../base/base.model");
|
14
|
+
const common_1 = require("../../../common");
|
15
|
+
const repository_1 = require("@loopback/repository");
|
16
|
+
const oauth2_client_model_1 = require("./oauth2-client.model");
|
17
|
+
let OAuth2Token = class OAuth2Token extends base_model_1.BaseTzEntity {
|
18
|
+
constructor(data) {
|
19
|
+
super(data);
|
20
|
+
}
|
21
|
+
};
|
22
|
+
exports.OAuth2Token = OAuth2Token;
|
23
|
+
__decorate([
|
24
|
+
(0, repository_1.property)({
|
25
|
+
type: 'string',
|
26
|
+
}),
|
27
|
+
__metadata("design:type", String)
|
28
|
+
], OAuth2Token.prototype, "token", void 0);
|
29
|
+
__decorate([
|
30
|
+
(0, repository_1.property)({
|
31
|
+
type: 'string',
|
32
|
+
}),
|
33
|
+
__metadata("design:type", String)
|
34
|
+
], OAuth2Token.prototype, "type", void 0);
|
35
|
+
__decorate([
|
36
|
+
(0, repository_1.property)({
|
37
|
+
type: 'string',
|
38
|
+
default: common_1.OAuth2TokenStatuses.UNKNOWN,
|
39
|
+
}),
|
40
|
+
__metadata("design:type", String)
|
41
|
+
], OAuth2Token.prototype, "status", void 0);
|
42
|
+
__decorate([
|
43
|
+
(0, repository_1.property)({
|
44
|
+
type: 'array',
|
45
|
+
itemType: 'string',
|
46
|
+
default: [],
|
47
|
+
postgresql: {
|
48
|
+
columnName: 'scopes',
|
49
|
+
dataType: 'jsonb',
|
50
|
+
},
|
51
|
+
}),
|
52
|
+
__metadata("design:type", Array)
|
53
|
+
], OAuth2Token.prototype, "scopes", void 0);
|
54
|
+
__decorate([
|
55
|
+
(0, repository_1.belongsTo)(() => oauth2_client_model_1.OAuth2Client, { keyFrom: 'clientId' }, { postgresql: { columnName: 'client_id', dataType: 'integer' } }),
|
56
|
+
__metadata("design:type", Object)
|
57
|
+
], OAuth2Token.prototype, "clientId", void 0);
|
58
|
+
__decorate([
|
59
|
+
(0, repository_1.property)({
|
60
|
+
type: 'number',
|
61
|
+
postgresql: { columnName: 'user_id', dataType: 'integer' },
|
62
|
+
}),
|
63
|
+
__metadata("design:type", Object)
|
64
|
+
], OAuth2Token.prototype, "userId", void 0);
|
65
|
+
__decorate([
|
66
|
+
(0, repository_1.property)({
|
67
|
+
type: 'object',
|
68
|
+
postgresql: {
|
69
|
+
columnName: 'details',
|
70
|
+
dataType: 'jsonb',
|
71
|
+
},
|
72
|
+
}),
|
73
|
+
__metadata("design:type", Object)
|
74
|
+
], OAuth2Token.prototype, "details", void 0);
|
75
|
+
exports.OAuth2Token = OAuth2Token = __decorate([
|
76
|
+
(0, repository_1.model)({
|
77
|
+
settings: {
|
78
|
+
postgresql: {
|
79
|
+
schema: 'open_auth',
|
80
|
+
table: 'OAuth2Token',
|
81
|
+
},
|
82
|
+
hiddenProperties: ['createdAt', 'modifiedAt'],
|
83
|
+
},
|
84
|
+
}),
|
85
|
+
__metadata("design:paramtypes", [Object])
|
86
|
+
], OAuth2Token);
|
87
|
+
//# sourceMappingURL=oauth2-token.model.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"oauth2-token.model.js","sourceRoot":"","sources":["../../../../src/components/authenticate/models/oauth2-token.model.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,kDAAiD;AACjD,qCAAkE;AAClE,qDAAkE;AAClE,+DAAqD;AAW9C,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,yBAAY;IAkD3C,YAAY,IAA2B;QACrC,KAAK,CAAC,IAAI,CAAC,CAAC;IACd,CAAC;CACF,CAAA;AArDY,kCAAW;AAItB;IAHC,IAAA,qBAAQ,EAAC;QACR,IAAI,EAAE,QAAQ;KACf,CAAC;;0CACY;AAKd;IAHC,IAAA,qBAAQ,EAAC;QACR,IAAI,EAAE,QAAQ;KACf,CAAC;;yCACW;AAMb;IAJC,IAAA,qBAAQ,EAAC;QACR,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,4BAAmB,CAAC,OAAO;KACrC,CAAC;;2CACa;AAWf;IATC,IAAA,qBAAQ,EAAC;QACR,IAAI,EAAE,OAAO;QACb,QAAQ,EAAE,QAAQ;QAClB,OAAO,EAAE,EAAE;QACX,UAAU,EAAE;YACV,UAAU,EAAE,QAAQ;YACpB,QAAQ,EAAE,OAAO;SAClB;KACF,CAAC;8BACM,KAAK;2CAAS;AAOtB;IALC,IAAA,sBAAS,EACR,GAAG,EAAE,CAAC,kCAAY,EAClB,EAAE,OAAO,EAAE,UAAU,EAAE,EACvB,EAAE,UAAU,EAAE,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,EAAE,SAAS,EAAE,EAAE,CACjE;;6CACgB;AAMjB;IAJC,IAAA,qBAAQ,EAAC;QACR,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE;KAC3D,CAAC;;2CACa;AASf;IAPC,IAAA,qBAAQ,EAAC;QACR,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,UAAU,EAAE,SAAS;YACrB,QAAQ,EAAE,OAAO;SAClB;KACF,CAAC;;4CACkB;sBAhDT,WAAW;IATvB,IAAA,kBAAK,EAAC;QACL,QAAQ,EAAE;YACR,UAAU,EAAE;gBACV,MAAM,EAAE,WAAW;gBACnB,KAAK,EAAE,aAAa;aACrB;YACD,gBAAgB,EAAE,CAAC,WAAW,EAAE,YAAY,CAAC;SAC9C;KACF,CAAC;;GACW,WAAW,CAqDvB"}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import { TInjectionGetter } from '../../../common';
|
2
|
+
import { AuthorizationCode, AuthorizationCodeModel, Client, Falsey, User } from '@node-oauth/oauth2-server';
|
3
|
+
import { AbstractOAuth2AuthenticationHandler } from './base';
|
4
|
+
export declare class OAuth2AuthorizationCodeHandler extends AbstractOAuth2AuthenticationHandler implements AuthorizationCodeModel {
|
5
|
+
constructor(opts: {
|
6
|
+
scope?: string;
|
7
|
+
authServiceKey: string;
|
8
|
+
injectionGetter: TInjectionGetter;
|
9
|
+
});
|
10
|
+
getAuthorizationCode(authorizationCode: string): Promise<AuthorizationCode | Falsey>;
|
11
|
+
saveAuthorizationCode(code: Pick<AuthorizationCode, 'authorizationCode' | 'expiresAt' | 'redirectUri' | 'scope' | 'codeChallenge' | 'codeChallengeMethod'>, client: Client, user: User): Promise<AuthorizationCode | Falsey>;
|
12
|
+
revokeAuthorizationCode(code: AuthorizationCode): Promise<boolean>;
|
13
|
+
}
|
@@ -0,0 +1,56 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.OAuth2AuthorizationCodeHandler = void 0;
|
4
|
+
const common_1 = require("../common");
|
5
|
+
const base_1 = require("./base");
|
6
|
+
class OAuth2AuthorizationCodeHandler extends base_1.AbstractOAuth2AuthenticationHandler {
|
7
|
+
constructor(opts) {
|
8
|
+
super({
|
9
|
+
scope: opts.scope,
|
10
|
+
authServiceKey: opts.authServiceKey,
|
11
|
+
injectionGetter: opts.injectionGetter,
|
12
|
+
});
|
13
|
+
}
|
14
|
+
getAuthorizationCode(authorizationCode) {
|
15
|
+
return new Promise((resolve, reject) => {
|
16
|
+
this._getToken({
|
17
|
+
type: common_1.AuthenticationTokenTypes.TYPE_AUTHORIZATION_CODE,
|
18
|
+
token: authorizationCode,
|
19
|
+
})
|
20
|
+
.then(rs => {
|
21
|
+
var _a, _b;
|
22
|
+
const { token: oauth2Token, client, user } = rs;
|
23
|
+
resolve({
|
24
|
+
authorizationCode: oauth2Token.token,
|
25
|
+
expiresAt: new Date((_a = oauth2Token.details) === null || _a === void 0 ? void 0 : _a.expiresAt),
|
26
|
+
redirectUri: (_b = oauth2Token.details) === null || _b === void 0 ? void 0 : _b.redirectUri,
|
27
|
+
scope: oauth2Token.scopes,
|
28
|
+
client: Object.assign(Object.assign({}, client), { id: client.id.toString() }),
|
29
|
+
user,
|
30
|
+
});
|
31
|
+
})
|
32
|
+
.catch(reject);
|
33
|
+
});
|
34
|
+
}
|
35
|
+
saveAuthorizationCode(code, client, user) {
|
36
|
+
return new Promise((resolve, reject) => {
|
37
|
+
this._saveToken({
|
38
|
+
token: code.authorizationCode,
|
39
|
+
type: common_1.AuthenticationTokenTypes.TYPE_AUTHORIZATION_CODE,
|
40
|
+
client,
|
41
|
+
user,
|
42
|
+
details: code,
|
43
|
+
})
|
44
|
+
.then(() => {
|
45
|
+
resolve(Object.assign(Object.assign({}, code), { client, user }));
|
46
|
+
})
|
47
|
+
.catch(reject);
|
48
|
+
});
|
49
|
+
}
|
50
|
+
revokeAuthorizationCode(code) {
|
51
|
+
this.logger.debug('[revokeAuthorizationCode] Revoked code: %j', code);
|
52
|
+
return Promise.resolve(true);
|
53
|
+
}
|
54
|
+
}
|
55
|
+
exports.OAuth2AuthorizationCodeHandler = OAuth2AuthorizationCodeHandler;
|
56
|
+
//# sourceMappingURL=authorization-code.handler.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"authorization-code.handler.js","sourceRoot":"","sources":["../../../../src/components/authenticate/oauth2-handlers/authorization-code.handler.ts"],"names":[],"mappings":";;;AAEA,sCAAqD;AACrD,iCAA6D;AAE7D,MAAa,8BACX,SAAQ,0CAAmC;IAG3C,YAAY,IAAmF;QAC7F,KAAK,CAAC;YACJ,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,eAAe,EAAE,IAAI,CAAC,eAAe;SACtC,CAAC,CAAC;IACL,CAAC;IAED,oBAAoB,CAAC,iBAAyB;QAC5C,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC,SAAS,CAAC;gBACb,IAAI,EAAE,iCAAwB,CAAC,uBAAuB;gBACtD,KAAK,EAAE,iBAAiB;aACzB,CAAC;iBACC,IAAI,CAAC,EAAE,CAAC,EAAE;;gBACT,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC;gBAChD,OAAO,CAAC;oBACN,iBAAiB,EAAE,WAAW,CAAC,KAAK;oBACpC,SAAS,EAAE,IAAI,IAAI,CAAC,MAAA,WAAW,CAAC,OAAO,0CAAE,SAAS,CAAC;oBACnD,WAAW,EAAE,MAAA,WAAW,CAAC,OAAO,0CAAE,WAAW;oBAC7C,KAAK,EAAE,WAAW,CAAC,MAAM;oBACzB,MAAM,kCAAO,MAAM,KAAE,EAAE,EAAE,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAE;oBAC/C,IAAI;iBACL,CAAC,CAAC;YACL,CAAC,CAAC;iBACD,KAAK,CAAC,MAAM,CAAC,CAAC;QACnB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,qBAAqB,CACnB,IAGC,EACD,MAAc,EACd,IAAU;QAEV,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC,UAAU,CAAC;gBACd,KAAK,EAAE,IAAI,CAAC,iBAAiB;gBAC7B,IAAI,EAAE,iCAAwB,CAAC,uBAAuB;gBACtD,MAAM;gBACN,IAAI;gBACJ,OAAO,EAAE,IAAI;aACd,CAAC;iBACC,IAAI,CAAC,GAAG,EAAE;gBACT,OAAO,iCAAM,IAAI,KAAE,MAAM,EAAE,IAAI,IAAG,CAAC;YACrC,CAAC,CAAC;iBACD,KAAK,CAAC,MAAM,CAAC,CAAC;QACnB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,uBAAuB,CAAC,IAAuB;QAC7C,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,4CAA4C,EAAE,IAAI,CAAC,CAAC;QACtE,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;CACF;AA5DD,wEA4DC"}
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import { BaseTzEntity } from '../../../base/base.model';
|
2
|
+
import { AnyObject, TInjectionGetter } from '../../../common';
|
3
|
+
import { ApplicationLogger } from '../../../helpers';
|
4
|
+
import { BaseModel, Client, Falsey, RequestAuthenticationModel, Token, User } from '@node-oauth/oauth2-server';
|
5
|
+
import { OAuth2Token } from '../models';
|
6
|
+
export interface IOAuth2AuthenticationHandler extends BaseModel, RequestAuthenticationModel {
|
7
|
+
}
|
8
|
+
export declare abstract class AbstractOAuth2AuthenticationHandler implements IOAuth2AuthenticationHandler {
|
9
|
+
protected authServiceKey: string;
|
10
|
+
protected logger: ApplicationLogger;
|
11
|
+
protected injectionGetter: TInjectionGetter;
|
12
|
+
constructor(opts: {
|
13
|
+
scope?: string;
|
14
|
+
authServiceKey: string;
|
15
|
+
injectionGetter: TInjectionGetter;
|
16
|
+
});
|
17
|
+
getClient(clientId: string, clientSecret: string): Promise<Client | Falsey>;
|
18
|
+
generateAccessToken(client: Client, user: User, scopes: string[]): Promise<string>;
|
19
|
+
_saveToken(opts: {
|
20
|
+
type: string;
|
21
|
+
token: string;
|
22
|
+
client: Client;
|
23
|
+
user: User;
|
24
|
+
details?: AnyObject;
|
25
|
+
}): Promise<OAuth2Token | null>;
|
26
|
+
saveToken(token: Token, client: Client, user: User): Promise<Token | Falsey>;
|
27
|
+
_getToken(opts: {
|
28
|
+
type: string;
|
29
|
+
token: string;
|
30
|
+
}): Promise<{
|
31
|
+
token: OAuth2Token;
|
32
|
+
client: any;
|
33
|
+
user: BaseTzEntity;
|
34
|
+
}>;
|
35
|
+
getAccessToken(accessToken: string): Promise<Token | Falsey>;
|
36
|
+
verifyScope(token: Token, scopes: string[]): Promise<boolean>;
|
37
|
+
}
|
@@ -0,0 +1,192 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
9
|
+
});
|
10
|
+
};
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
13
|
+
};
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
15
|
+
exports.AbstractOAuth2AuthenticationHandler = void 0;
|
16
|
+
const common_1 = require("../../../common");
|
17
|
+
const helpers_1 = require("../../../helpers");
|
18
|
+
const utilities_1 = require("../../../utilities");
|
19
|
+
const security_1 = require("@loopback/security");
|
20
|
+
const get_1 = __importDefault(require("lodash/get"));
|
21
|
+
const common_2 = require("../common");
|
22
|
+
class AbstractOAuth2AuthenticationHandler {
|
23
|
+
constructor(opts) {
|
24
|
+
var _a;
|
25
|
+
this.logger = helpers_1.LoggerFactory.getLogger([(_a = opts === null || opts === void 0 ? void 0 : opts.scope) !== null && _a !== void 0 ? _a : AbstractOAuth2AuthenticationHandler.name]);
|
26
|
+
this.injectionGetter = opts.injectionGetter;
|
27
|
+
this.authServiceKey = opts.authServiceKey;
|
28
|
+
}
|
29
|
+
getClient(clientId, clientSecret) {
|
30
|
+
return new Promise((resolve, reject) => {
|
31
|
+
this.logger.debug('[getClient] Retreiving application client | client_id: %s | client_secret: %s', clientId, clientSecret);
|
32
|
+
const clientRepository = this.injectionGetter('repositories.OAuth2ClientRepository');
|
33
|
+
clientRepository
|
34
|
+
.findOne({
|
35
|
+
where: { or: [{ clientId }, { clientId, clientSecret }] },
|
36
|
+
fields: ['id', 'identifier', 'clientId', 'name', 'description', 'grants', 'userId', 'endpoints'],
|
37
|
+
})
|
38
|
+
.then((oauth2Client) => {
|
39
|
+
var _a, _b, _c, _d;
|
40
|
+
resolve({
|
41
|
+
id: oauth2Client.id.toString(),
|
42
|
+
identifier: oauth2Client.identifier,
|
43
|
+
clientId: oauth2Client.clientId,
|
44
|
+
name: oauth2Client.name,
|
45
|
+
description: oauth2Client.description,
|
46
|
+
grants: oauth2Client.grants,
|
47
|
+
userId: oauth2Client.userId,
|
48
|
+
redirectUris: (_b = (_a = oauth2Client === null || oauth2Client === void 0 ? void 0 : oauth2Client.endpoints) === null || _a === void 0 ? void 0 : _a.redirectUrls) !== null && _b !== void 0 ? _b : [],
|
49
|
+
callbackUrls: (_d = (_c = oauth2Client === null || oauth2Client === void 0 ? void 0 : oauth2Client.endpoints) === null || _c === void 0 ? void 0 : _c.callbackUrls) !== null && _d !== void 0 ? _d : [],
|
50
|
+
});
|
51
|
+
})
|
52
|
+
.catch(reject);
|
53
|
+
});
|
54
|
+
}
|
55
|
+
generateAccessToken(client, user, scopes) {
|
56
|
+
return __awaiter(this, void 0, void 0, function* () {
|
57
|
+
var _a, _b, _c;
|
58
|
+
const service = this.injectionGetter('services.JWTTokenService');
|
59
|
+
const userId = (0, get_1.default)(user, 'id');
|
60
|
+
if (!userId) {
|
61
|
+
throw (0, utilities_1.getError)({
|
62
|
+
message: '[generateAccessToken] Invalid userId | Please verify getUserInformation response!',
|
63
|
+
});
|
64
|
+
}
|
65
|
+
const authService = this.injectionGetter(this.authServiceKey);
|
66
|
+
const userInformation = yield ((_a = authService === null || authService === void 0 ? void 0 : authService.getUserInformation) === null || _a === void 0 ? void 0 : _a.call(authService, { userId }));
|
67
|
+
const tokenValue = service.generate({
|
68
|
+
[security_1.securityId]: userId.toString(),
|
69
|
+
userId: (_b = userInformation === null || userInformation === void 0 ? void 0 : userInformation.userId) !== null && _b !== void 0 ? _b : userId.toString(),
|
70
|
+
roles: (_c = userInformation === null || userInformation === void 0 ? void 0 : userInformation.roles) !== null && _c !== void 0 ? _c : [],
|
71
|
+
clientId: client.id,
|
72
|
+
scopes,
|
73
|
+
});
|
74
|
+
return Promise.resolve(tokenValue);
|
75
|
+
});
|
76
|
+
}
|
77
|
+
_saveToken(opts) {
|
78
|
+
const { type, token, client, user, details } = opts;
|
79
|
+
const oauth2TokenRepository = this.injectionGetter('repositories.OAuth2TokenRepository');
|
80
|
+
return oauth2TokenRepository.create({
|
81
|
+
token,
|
82
|
+
type,
|
83
|
+
status: common_1.OAuth2TokenStatuses.ACTIVATED,
|
84
|
+
clientId: (0, utilities_1.int)(client.id),
|
85
|
+
userId: (0, utilities_1.int)(user.id),
|
86
|
+
details,
|
87
|
+
});
|
88
|
+
}
|
89
|
+
saveToken(token, client, user) {
|
90
|
+
return new Promise((resolve, reject) => {
|
91
|
+
this._saveToken({
|
92
|
+
token: token.accessToken,
|
93
|
+
type: common_2.AuthenticationTokenTypes.TYPE_ACCESS_TOKEN,
|
94
|
+
client,
|
95
|
+
user,
|
96
|
+
details: token,
|
97
|
+
})
|
98
|
+
.then(() => {
|
99
|
+
resolve(Object.assign(Object.assign({}, token), { client, user }));
|
100
|
+
})
|
101
|
+
.catch(reject);
|
102
|
+
});
|
103
|
+
}
|
104
|
+
_getToken(opts) {
|
105
|
+
return __awaiter(this, void 0, void 0, function* () {
|
106
|
+
const { type, token } = opts;
|
107
|
+
const oauth2TokenRepository = this.injectionGetter('repositories.OAuth2TokenRepository');
|
108
|
+
const oauth2Token = yield oauth2TokenRepository.findOne({
|
109
|
+
where: { type, token },
|
110
|
+
});
|
111
|
+
if (!oauth2Token) {
|
112
|
+
this.logger.error('[_getToken] Not found OAuth2Token | type: %s | token: %s', type, token);
|
113
|
+
throw (0, utilities_1.getError)({
|
114
|
+
message: `[_getToken] Not found any OAuth2Token with type: ${type} | token: ${token}`,
|
115
|
+
});
|
116
|
+
}
|
117
|
+
if (oauth2Token.status !== common_1.OAuth2TokenStatuses.ACTIVATED) {
|
118
|
+
this.logger.error('[_getToken] Invalid OAuth2Token status | token: %j', oauth2Token);
|
119
|
+
throw (0, utilities_1.getError)({
|
120
|
+
message: `[_getToken] Invalid OAuth2Token status: ${oauth2Token.status}`,
|
121
|
+
});
|
122
|
+
}
|
123
|
+
const userRepository = this.injectionGetter('repositories.UserRepository');
|
124
|
+
const user = yield userRepository.findOne({
|
125
|
+
where: { id: (0, utilities_1.int)(oauth2Token.userId) },
|
126
|
+
fields: ['id'],
|
127
|
+
});
|
128
|
+
if (!user) {
|
129
|
+
this.logger.error('[_getToken] Not found User | type: %s | token: %s | oauth2Token: %j', type, token, oauth2Token);
|
130
|
+
throw (0, utilities_1.getError)({
|
131
|
+
message: `[_getToken] Not found any User with type: ${type} | token: ${token}`,
|
132
|
+
});
|
133
|
+
}
|
134
|
+
const oauth2ClientRepository = this.injectionGetter('repositories.OAuth2ClientRepository');
|
135
|
+
const oauth2Client = yield oauth2ClientRepository.findOne({
|
136
|
+
where: { id: (0, utilities_1.int)(oauth2Token.clientId) },
|
137
|
+
fields: ['id', 'identifier', 'name', 'description', 'userId'],
|
138
|
+
});
|
139
|
+
if (!oauth2Client) {
|
140
|
+
this.logger.error('[_getToken] Not found OAuth2Client | type: %s | token: %s | oauth2Token: %j', type, token, oauth2Token);
|
141
|
+
throw (0, utilities_1.getError)({
|
142
|
+
message: `[_getToken] Not found any OAuth2Client with type: ${type} | token: ${token}`,
|
143
|
+
});
|
144
|
+
}
|
145
|
+
return {
|
146
|
+
token: oauth2Token,
|
147
|
+
client: oauth2Client,
|
148
|
+
user,
|
149
|
+
};
|
150
|
+
});
|
151
|
+
}
|
152
|
+
getAccessToken(accessToken) {
|
153
|
+
return __awaiter(this, void 0, void 0, function* () {
|
154
|
+
const service = this.injectionGetter('services.JWTTokenService');
|
155
|
+
const tokenPayload = service.verify({
|
156
|
+
type: common_2.Authentication.TYPE_BEARER,
|
157
|
+
token: accessToken,
|
158
|
+
});
|
159
|
+
const clientId = tokenPayload['clientId'];
|
160
|
+
if (!clientId || clientId === 'NA') {
|
161
|
+
this.logger.error('[getAccessToken] Invalid clientId in tokenPayload | tokenPayload: %j', tokenPayload);
|
162
|
+
throw (0, utilities_1.getError)({
|
163
|
+
message: '[getAccessToken] Invalid clientId in token payload!',
|
164
|
+
});
|
165
|
+
}
|
166
|
+
const oauth2ClientRepository = this.injectionGetter('repositories.OAuth2ClientRepository');
|
167
|
+
const oauth2Client = yield oauth2ClientRepository.findOne({
|
168
|
+
where: { identifier: clientId },
|
169
|
+
fields: ['id', 'identifier', 'name', 'description', 'userId'],
|
170
|
+
});
|
171
|
+
if (!oauth2Client) {
|
172
|
+
throw (0, utilities_1.getError)({
|
173
|
+
message: `[getAccessToken] Not found any OAuth2Client with id: ${clientId}`,
|
174
|
+
});
|
175
|
+
}
|
176
|
+
return {
|
177
|
+
accessToken,
|
178
|
+
accessTokenExpiresAt: new Date((0, utilities_1.int)(tokenPayload['exp']) * 1000),
|
179
|
+
client: oauth2Client,
|
180
|
+
user: { id: tokenPayload.userId },
|
181
|
+
};
|
182
|
+
});
|
183
|
+
}
|
184
|
+
verifyScope(token, scopes) {
|
185
|
+
return new Promise(resolve => {
|
186
|
+
this.logger.info('[verifyScope] Token: %j | Scopes: %s', token, scopes);
|
187
|
+
resolve(token !== null);
|
188
|
+
});
|
189
|
+
}
|
190
|
+
}
|
191
|
+
exports.AbstractOAuth2AuthenticationHandler = AbstractOAuth2AuthenticationHandler;
|
192
|
+
//# sourceMappingURL=base.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/components/authenticate/oauth2-handlers/base.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
import { TInjectionGetter } from '../../../common';
|
2
|
+
import { Client, ClientCredentialsModel, Falsey, User } from '@node-oauth/oauth2-server';
|
3
|
+
import { AbstractOAuth2AuthenticationHandler } from './base';
|
4
|
+
export declare class OAuth2ClientCredentialHandler extends AbstractOAuth2AuthenticationHandler implements ClientCredentialsModel {
|
5
|
+
constructor(opts: {
|
6
|
+
scope?: string;
|
7
|
+
authServiceKey: string;
|
8
|
+
injectionGetter: TInjectionGetter;
|
9
|
+
serviceKey: string;
|
10
|
+
});
|
11
|
+
getUserFromClient(client: Client): Promise<User | Falsey>;
|
12
|
+
}
|
@@ -0,0 +1,28 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.OAuth2ClientCredentialHandler = void 0;
|
4
|
+
const utilities_1 = require("../../../utilities");
|
5
|
+
const base_1 = require("./base");
|
6
|
+
class OAuth2ClientCredentialHandler extends base_1.AbstractOAuth2AuthenticationHandler {
|
7
|
+
constructor(opts) {
|
8
|
+
super({
|
9
|
+
scope: opts.scope,
|
10
|
+
authServiceKey: opts.authServiceKey,
|
11
|
+
injectionGetter: opts.injectionGetter,
|
12
|
+
});
|
13
|
+
}
|
14
|
+
getUserFromClient(client) {
|
15
|
+
var _a;
|
16
|
+
this.logger.debug('[getUserFromClient] Client: %j', client);
|
17
|
+
const service = this.injectionGetter(this.authServiceKey);
|
18
|
+
if (!(service === null || service === void 0 ? void 0 : service.getUserInformation)) {
|
19
|
+
throw (0, utilities_1.getError)({
|
20
|
+
message: `${this.authServiceKey} has no 'getUserInformation' method!`,
|
21
|
+
});
|
22
|
+
}
|
23
|
+
const userInformation = (_a = service === null || service === void 0 ? void 0 : service.getUserInformation) === null || _a === void 0 ? void 0 : _a.call(service, client);
|
24
|
+
return Promise.resolve(userInformation);
|
25
|
+
}
|
26
|
+
}
|
27
|
+
exports.OAuth2ClientCredentialHandler = OAuth2ClientCredentialHandler;
|
28
|
+
//# sourceMappingURL=client-credential.handler.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"client-credential.handler.js","sourceRoot":"","sources":["../../../../src/components/authenticate/oauth2-handlers/client-credential.handler.ts"],"names":[],"mappings":";;;AACA,2CAAuC;AAGvC,iCAA6D;AAE7D,MAAa,6BACX,SAAQ,0CAAmC;IAG3C,YAAY,IAAuG;QACjH,KAAK,CAAC;YACJ,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,eAAe,EAAE,IAAI,CAAC,eAAe;SACtC,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAC,MAAc;;QAC9B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,EAAE,MAAM,CAAC,CAAC;QAC5D,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAe,IAAI,CAAC,cAAc,CAAC,CAAC;QAExE,IAAI,CAAC,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,kBAAkB,CAAA,EAAE,CAAC;YACjC,MAAM,IAAA,oBAAQ,EAAC;gBACb,OAAO,EAAE,GAAG,IAAI,CAAC,cAAc,sCAAsC;aACtE,CAAC,CAAC;QACL,CAAC;QAED,MAAM,eAAe,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,kBAAkB,wDAAG,MAAM,CAAC,CAAC;QAC9D,OAAO,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;IAC1C,CAAC;CACF;AAzBD,sEAyBC"}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
__exportStar(require("./base"), exports);
|
18
|
+
__exportStar(require("./oauth2"), exports);
|
19
|
+
__exportStar(require("./authorization-code.handler"), exports);
|
20
|
+
__exportStar(require("./client-credential.handler"), exports);
|
21
|
+
__exportStar(require("./password.handler"), exports);
|
22
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/authenticate/oauth2-handlers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,2CAAyB;AAEzB,+DAA6C;AAC7C,8DAA4C;AAC5C,qDAAmC"}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
import { ApplicationLogger } from '../../../helpers';
|
2
|
+
import OAuth2Server, { ServerOptions } from '@node-oauth/oauth2-server';
|
3
|
+
import { TInjectionGetter } from '../../../common';
|
4
|
+
export declare class OAuth2Handler extends OAuth2Server {
|
5
|
+
logger: ApplicationLogger;
|
6
|
+
constructor(opts: {
|
7
|
+
scope?: string;
|
8
|
+
handlerOptions: {
|
9
|
+
type: 'authorization_code';
|
10
|
+
authServiceKey: string;
|
11
|
+
injectionGetter: TInjectionGetter;
|
12
|
+
};
|
13
|
+
serverOptions: Omit<ServerOptions, 'model'>;
|
14
|
+
});
|
15
|
+
}
|
@@ -0,0 +1,36 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.OAuth2Handler = void 0;
|
7
|
+
const helpers_1 = require("../../../helpers");
|
8
|
+
const oauth2_server_1 = __importDefault(require("@node-oauth/oauth2-server"));
|
9
|
+
const utilities_1 = require("../../../utilities");
|
10
|
+
const authorization_code_handler_1 = require("./authorization-code.handler");
|
11
|
+
class OAuth2Handler extends oauth2_server_1.default {
|
12
|
+
constructor(opts) {
|
13
|
+
const { scope, handlerOptions, serverOptions } = opts;
|
14
|
+
let authHandler = null;
|
15
|
+
const { type: authType, authServiceKey } = handlerOptions;
|
16
|
+
switch (authType) {
|
17
|
+
case 'authorization_code': {
|
18
|
+
authHandler = new authorization_code_handler_1.OAuth2AuthorizationCodeHandler({
|
19
|
+
authServiceKey,
|
20
|
+
injectionGetter: handlerOptions.injectionGetter,
|
21
|
+
});
|
22
|
+
break;
|
23
|
+
}
|
24
|
+
default: {
|
25
|
+
break;
|
26
|
+
}
|
27
|
+
}
|
28
|
+
if (!authHandler) {
|
29
|
+
throw (0, utilities_1.getError)({ message: '[defineOAuth2] Invalid OAuth2 model handler!' });
|
30
|
+
}
|
31
|
+
super(Object.assign(Object.assign({}, serverOptions), { model: authHandler }));
|
32
|
+
this.logger = helpers_1.LoggerFactory.getLogger([scope !== null && scope !== void 0 ? scope : OAuth2Handler.name]);
|
33
|
+
}
|
34
|
+
}
|
35
|
+
exports.OAuth2Handler = OAuth2Handler;
|
36
|
+
//# sourceMappingURL=oauth2.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"oauth2.js","sourceRoot":"","sources":["../../../../src/components/authenticate/oauth2-handlers/oauth2.ts"],"names":[],"mappings":";;;;;;AAAA,uCAA6D;AAC7D,8EAAwE;AAGxE,2CAAuC;AACvC,6EAA8E;AAG9E,MAAa,aAAc,SAAQ,uBAAY;IAG7C,YAAY,IAQX;QACC,MAAM,EAAE,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,GAAG,IAAI,CAAC;QAEtD,IAAI,WAAW,GAAwC,IAAI,CAAC;QAC5D,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,cAAc,EAAE,GAAG,cAAc,CAAC;QAE1D,QAAQ,QAAQ,EAAE,CAAC;YACjB,KAAK,oBAAoB,CAAC,CAAC,CAAC;gBAC1B,WAAW,GAAG,IAAI,2DAA8B,CAAC;oBAC/C,cAAc;oBACd,eAAe,EAAE,cAAc,CAAC,eAAe;iBAChD,CAAC,CAAC;gBACH,MAAM;YACR,CAAC;YACD,OAAO,CAAC,CAAC,CAAC;gBACR,MAAM;YACR,CAAC;QACH,CAAC;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAA,oBAAQ,EAAC,EAAE,OAAO,EAAE,8CAA8C,EAAE,CAAC,CAAC;QAC9E,CAAC;QAED,KAAK,iCAAM,aAAa,KAAE,KAAK,EAAE,WAAW,IAAG,CAAC;QAChD,IAAI,CAAC,MAAM,GAAG,uBAAa,CAAC,SAAS,CAAC,CAAC,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC;IACvE,CAAC;CACF;AArCD,sCAqCC"}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
import { TInjectionGetter } from '../../../common';
|
2
|
+
import { Client, Falsey, PasswordModel, User } from '@node-oauth/oauth2-server';
|
3
|
+
import { AbstractOAuth2AuthenticationHandler } from './base';
|
4
|
+
export declare class OAuth2PasswordHandler extends AbstractOAuth2AuthenticationHandler implements PasswordModel {
|
5
|
+
constructor(opts: {
|
6
|
+
scope?: string;
|
7
|
+
authServiceKey: string;
|
8
|
+
injectionGetter: TInjectionGetter;
|
9
|
+
serviceKey: string;
|
10
|
+
});
|
11
|
+
getUser(username: string, password: string, _client: Client): Promise<User | Falsey>;
|
12
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.OAuth2PasswordHandler = void 0;
|
4
|
+
const base_1 = require("./base");
|
5
|
+
class OAuth2PasswordHandler extends base_1.AbstractOAuth2AuthenticationHandler {
|
6
|
+
constructor(opts) {
|
7
|
+
super({
|
8
|
+
scope: opts.scope,
|
9
|
+
authServiceKey: opts.authServiceKey,
|
10
|
+
injectionGetter: opts.injectionGetter,
|
11
|
+
});
|
12
|
+
}
|
13
|
+
getUser(username, password, _client) {
|
14
|
+
const service = this.injectionGetter(this.authServiceKey);
|
15
|
+
return service.signIn({
|
16
|
+
identifier: { scheme: 'username', value: username },
|
17
|
+
credential: { scheme: 'basic', value: password },
|
18
|
+
});
|
19
|
+
}
|
20
|
+
}
|
21
|
+
exports.OAuth2PasswordHandler = OAuth2PasswordHandler;
|
22
|
+
//# sourceMappingURL=password.handler.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"password.handler.js","sourceRoot":"","sources":["../../../../src/components/authenticate/oauth2-handlers/password.handler.ts"],"names":[],"mappings":";;;AAGA,iCAA6D;AAE7D,MAAa,qBAAsB,SAAQ,0CAAmC;IAC5E,YAAY,IAAuG;QACjH,KAAK,CAAC;YACJ,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,eAAe,EAAE,IAAI,CAAC,eAAe;SACtC,CAAC,CAAC;IACL,CAAC;IAED,OAAO,CAAC,QAAgB,EAAE,QAAgB,EAAE,OAAe;QACzD,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAe,IAAI,CAAC,cAAc,CAAC,CAAC;QACxE,OAAO,OAAO,CAAC,MAAM,CAAC;YACpB,UAAU,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE;YACnD,UAAU,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE;SACjD,CAAC,CAAC;IACL,CAAC;CACF;AAhBD,sDAgBC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
export * from './oauth2.repository';
|
@@ -0,0 +1,18 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
__exportStar(require("./oauth2.repository"), exports);
|
18
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/authenticate/repositories/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,sDAAoC"}
|
@@ -0,0 +1,17 @@
|
|
1
|
+
import { BaseDataSource } from '../../../base/base.datasource';
|
2
|
+
import { TzCrudRepository } from '../../../base/repositories';
|
3
|
+
import { Getter } from '@loopback/core';
|
4
|
+
import { OAuth2Client, OAuth2Scope, OAuth2Token } from '../models';
|
5
|
+
import { IdType } from '../../../common';
|
6
|
+
import { BelongsToAccessor } from '@loopback/repository';
|
7
|
+
export declare class OAuth2ClientRepository extends TzCrudRepository<OAuth2Client> {
|
8
|
+
constructor(dataSource: BaseDataSource);
|
9
|
+
}
|
10
|
+
export declare class OAuth2ScopeRepository extends TzCrudRepository<OAuth2Scope> {
|
11
|
+
constructor(dataSource: BaseDataSource);
|
12
|
+
}
|
13
|
+
export declare class OAuth2TokenRepository extends TzCrudRepository<OAuth2Token> {
|
14
|
+
protected oauth2ClientRepository: Getter<OAuth2ClientRepository>;
|
15
|
+
readonly client: BelongsToAccessor<OAuth2Client, IdType>;
|
16
|
+
constructor(dataSource: BaseDataSource, oauth2ClientRepository: Getter<OAuth2ClientRepository>);
|
17
|
+
}
|