@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,91 @@
|
|
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.CasbinPostgresAdapter = void 0;
|
16
|
+
const utilities_1 = require("../../../utilities");
|
17
|
+
const casbin_1 = require("casbin");
|
18
|
+
const flatten_1 = __importDefault(require("lodash/flatten"));
|
19
|
+
const get_1 = __importDefault(require("lodash/get"));
|
20
|
+
const isEmpty_1 = __importDefault(require("lodash/isEmpty"));
|
21
|
+
const common_1 = require("../common");
|
22
|
+
const base_adapter_1 = require("./base.adapter");
|
23
|
+
// -----------------------------------------------------------------------------------------
|
24
|
+
class CasbinPostgresAdapter extends base_adapter_1.AbstractCasbinAdapter {
|
25
|
+
constructor(datasource) {
|
26
|
+
super({ scope: CasbinPostgresAdapter.name, datasource });
|
27
|
+
}
|
28
|
+
// -----------------------------------------------------------------------------------------
|
29
|
+
generateGroupLine(rule) {
|
30
|
+
const { userId, roleId } = rule;
|
31
|
+
const rs = [
|
32
|
+
common_1.EnforcerDefinitions.PTYPE_GROUP,
|
33
|
+
`${common_1.EnforcerDefinitions.PREFIX_USER}_${userId}`,
|
34
|
+
`${common_1.EnforcerDefinitions.PREFIX_ROLE}_${roleId}`,
|
35
|
+
];
|
36
|
+
return rs.join(',');
|
37
|
+
}
|
38
|
+
// -----------------------------------------------------------------------------------------
|
39
|
+
loadFilteredPolicy(model, filter) {
|
40
|
+
return __awaiter(this, void 0, void 0, function* () {
|
41
|
+
var _a, _b;
|
42
|
+
if (((_a = filter === null || filter === void 0 ? void 0 : filter.principalType) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === 'role') {
|
43
|
+
throw (0, utilities_1.getError)({
|
44
|
+
statusCode: 500,
|
45
|
+
message: '[loadFilteredPolicy] Only "User" is allowed for filter principal type!',
|
46
|
+
});
|
47
|
+
}
|
48
|
+
const aclQueries = [
|
49
|
+
this.datasource.execute(`SELECT * FROM public."ViewAuthorizePolicy" WHERE subject=$1`, [
|
50
|
+
`user_${filter.principalValue}`,
|
51
|
+
]),
|
52
|
+
];
|
53
|
+
// Load role permission policies
|
54
|
+
const userRoles = yield this.datasource.execute(`SELECT * FROM public."UserRole" WHERE user_id=$1`, [
|
55
|
+
filter.principalValue,
|
56
|
+
]);
|
57
|
+
for (const userRole of userRoles) {
|
58
|
+
const execution = this.datasource.execute(`SELECT * FROM public."ViewAuthorizePolicy" WHERE subject=$1`, [
|
59
|
+
`role_${userRole.principal_id}`,
|
60
|
+
]);
|
61
|
+
aclQueries.push(execution);
|
62
|
+
}
|
63
|
+
// Load policy lines
|
64
|
+
const policyRs = (0, flatten_1.default)(yield Promise.all(aclQueries));
|
65
|
+
this.logger.debug('[loadFilteredPolicy] policyRs: %j | filter: %j', policyRs, filter);
|
66
|
+
for (const el of policyRs) {
|
67
|
+
if (!el) {
|
68
|
+
continue;
|
69
|
+
}
|
70
|
+
(_b = el.policies) === null || _b === void 0 ? void 0 : _b.forEach((policyLine) => {
|
71
|
+
casbin_1.Helper.loadPolicyLine(policyLine, model);
|
72
|
+
this.logger.debug('[loadFilteredPolicy] Load policy: %s', policyLine);
|
73
|
+
});
|
74
|
+
}
|
75
|
+
// Load group lines
|
76
|
+
for (const userRole of userRoles) {
|
77
|
+
const groupLine = this.generateGroupLine({
|
78
|
+
userId: (0, get_1.default)(userRole, 'user_id'),
|
79
|
+
roleId: (0, get_1.default)(userRole, 'principal_id'),
|
80
|
+
});
|
81
|
+
if (!groupLine || (0, isEmpty_1.default)(groupLine)) {
|
82
|
+
continue;
|
83
|
+
}
|
84
|
+
casbin_1.Helper.loadPolicyLine(groupLine, model);
|
85
|
+
this.logger.debug('[loadFilteredPolicy] Load groupLine: %s', groupLine);
|
86
|
+
}
|
87
|
+
});
|
88
|
+
}
|
89
|
+
}
|
90
|
+
exports.CasbinPostgresAdapter = CasbinPostgresAdapter;
|
91
|
+
//# sourceMappingURL=casbin-postgres-adapter.helper.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"casbin-postgres-adapter.helper.js","sourceRoot":"","sources":["../../../../src/components/authorize/adapters/casbin-postgres-adapter.helper.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,7 @@
|
|
1
|
+
import { BaseDataSource } from '../../../base/base.datasource';
|
2
|
+
import { Model } from 'casbin';
|
3
|
+
import { AbstractCasbinAdapter } from './base.adapter';
|
4
|
+
export declare class CasbinRedisAdapter extends AbstractCasbinAdapter {
|
5
|
+
constructor(datasource: BaseDataSource);
|
6
|
+
loadFilteredPolicy(_model: Model, _filter: any): Promise<void>;
|
7
|
+
}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.CasbinRedisAdapter = void 0;
|
4
|
+
const base_adapter_1 = require("./base.adapter");
|
5
|
+
// -----------------------------------------------------------------------------------------
|
6
|
+
class CasbinRedisAdapter extends base_adapter_1.AbstractCasbinAdapter {
|
7
|
+
constructor(datasource) {
|
8
|
+
super({ scope: CasbinRedisAdapter.name, datasource });
|
9
|
+
}
|
10
|
+
loadFilteredPolicy(_model, _filter) {
|
11
|
+
throw new Error('Method not implemented.');
|
12
|
+
}
|
13
|
+
}
|
14
|
+
exports.CasbinRedisAdapter = CasbinRedisAdapter;
|
15
|
+
//# sourceMappingURL=casbin-redis-adapter.helper.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"casbin-redis-adapter.helper.js","sourceRoot":"","sources":["../../../../src/components/authorize/adapters/casbin-redis-adapter.helper.ts"],"names":[],"mappings":";;;AAGA,iDAAuD;AAEvD,4FAA4F;AAC5F,MAAa,kBAAmB,SAAQ,oCAAqB;IAC3D,YAAY,UAA0B;QACpC,KAAK,CAAC,EAAE,KAAK,EAAE,kBAAkB,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;IACxD,CAAC;IAED,kBAAkB,CAAC,MAAa,EAAE,OAAY;QAC5C,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;CACF;AARD,gDAQC"}
|
@@ -0,0 +1,21 @@
|
|
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("./adapter-builder"), exports);
|
18
|
+
__exportStar(require("./base.adapter"), exports);
|
19
|
+
__exportStar(require("./casbin-postgres-adapter.helper"), exports);
|
20
|
+
__exportStar(require("./casbin-redis-adapter.helper"), exports);
|
21
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/authorize/adapters/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,iDAA+B;AAC/B,mEAAiD;AACjD,gEAA8C"}
|
@@ -0,0 +1,14 @@
|
|
1
|
+
export declare class FixedUserRoles {
|
2
|
+
static readonly SUPER_ADMIN = "999-super-admin";
|
3
|
+
static readonly ADMIN = "998-admin";
|
4
|
+
static readonly FULL_AUTHORIZE_ROLES: string[];
|
5
|
+
}
|
6
|
+
export declare class EnforcerDefinitions {
|
7
|
+
static readonly ACTION_EXECUTE = "execute";
|
8
|
+
static readonly ACTION_READ = "read";
|
9
|
+
static readonly ACTION_WRITE = "write";
|
10
|
+
static readonly PREFIX_USER = "user";
|
11
|
+
static readonly PREFIX_ROLE = "role";
|
12
|
+
static readonly PTYPE_POLICY = "p";
|
13
|
+
static readonly PTYPE_GROUP = "g";
|
14
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";
|
2
|
+
var _a;
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
4
|
+
exports.EnforcerDefinitions = exports.FixedUserRoles = void 0;
|
5
|
+
class FixedUserRoles {
|
6
|
+
}
|
7
|
+
exports.FixedUserRoles = FixedUserRoles;
|
8
|
+
_a = FixedUserRoles;
|
9
|
+
FixedUserRoles.SUPER_ADMIN = '999-super-admin';
|
10
|
+
FixedUserRoles.ADMIN = '998-admin';
|
11
|
+
FixedUserRoles.FULL_AUTHORIZE_ROLES = [_a.SUPER_ADMIN, _a.ADMIN];
|
12
|
+
class EnforcerDefinitions {
|
13
|
+
}
|
14
|
+
exports.EnforcerDefinitions = EnforcerDefinitions;
|
15
|
+
EnforcerDefinitions.ACTION_EXECUTE = 'execute';
|
16
|
+
EnforcerDefinitions.ACTION_READ = 'read';
|
17
|
+
EnforcerDefinitions.ACTION_WRITE = 'write';
|
18
|
+
EnforcerDefinitions.PREFIX_USER = 'user';
|
19
|
+
EnforcerDefinitions.PREFIX_ROLE = 'role';
|
20
|
+
EnforcerDefinitions.PTYPE_POLICY = 'p';
|
21
|
+
EnforcerDefinitions.PTYPE_GROUP = 'g';
|
22
|
+
//# sourceMappingURL=constants.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../src/components/authorize/common/constants.ts"],"names":[],"mappings":";;;;AAAA,MAAa,cAAc;;AAA3B,wCAIC;;AAHiB,0BAAW,GAAG,iBAAiB,AAApB,CAAqB;AAChC,oBAAK,GAAG,WAAW,AAAd,CAAe;AACpB,mCAAoB,GAAG,CAAC,EAAI,CAAC,WAAW,EAAE,EAAI,CAAC,KAAK,CAAC,AAAjC,CAAkC;AAGxE,MAAa,mBAAmB;;AAAhC,kDAQC;AAPiB,kCAAc,GAAG,SAAS,CAAC;AAC3B,+BAAW,GAAG,MAAM,CAAC;AACrB,gCAAY,GAAG,OAAO,CAAC;AACvB,+BAAW,GAAG,MAAM,CAAC;AACrB,+BAAW,GAAG,MAAM,CAAC;AACrB,gCAAY,GAAG,GAAG,CAAC;AACnB,+BAAW,GAAG,GAAG,CAAC"}
|
@@ -0,0 +1,20 @@
|
|
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("./keys"), exports);
|
18
|
+
__exportStar(require("./types"), exports);
|
19
|
+
__exportStar(require("./constants"), exports);
|
20
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/authorize/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,0CAAwB;AACxB,8CAA4B"}
|
@@ -0,0 +1,17 @@
|
|
1
|
+
export declare class AuthorizerKeys {
|
2
|
+
static readonly APPLICATION_NAME = "@app/authorize/component/application_name";
|
3
|
+
static readonly ROLE_MODEL = "@app/authorize/component/models/user";
|
4
|
+
static readonly PERMISSION_MODEL = "@app/authorize/component/models/permission";
|
5
|
+
static readonly PERMISSION_MAPPING_MODEL = "@app/authorize/component/models/permission_mapping";
|
6
|
+
static readonly USER_ROLE_MODEL = "@app/authorize/component/models/user_role";
|
7
|
+
static readonly ROLE_REPOSITORY = "@app/authorize/component/repositories/user";
|
8
|
+
static readonly PERMISSION_REPOSITORY = "@app/authorize/component/repositories/permission";
|
9
|
+
static readonly PERMISSION_MAPPING_REPOSITORY = "@app/authorize/component/repositories/permission_mapping";
|
10
|
+
static readonly USER_ROLE_REPOSITORY = "@app/authorize/component/repositories/user_role";
|
11
|
+
static readonly PROVIDER = "@app/authorize/provider";
|
12
|
+
static readonly ENFORCER = "@app/authorize/enforcer";
|
13
|
+
static readonly ALWAYS_ALLOW_ROLES = "@app/authorize/always_allow_roles";
|
14
|
+
static readonly AUTHORIZE_DATASOURCE = "@app/authorize/enforcer/adapter/datasource";
|
15
|
+
static readonly CONFIGURE_OPTIONS = "@app/authorize/configure_options";
|
16
|
+
static readonly NORMALIZE_PAYLOAD_FN = "@app/authorize/normalize_payload_fn";
|
17
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.AuthorizerKeys = void 0;
|
4
|
+
class AuthorizerKeys {
|
5
|
+
}
|
6
|
+
exports.AuthorizerKeys = AuthorizerKeys;
|
7
|
+
AuthorizerKeys.APPLICATION_NAME = '@app/authorize/component/application_name';
|
8
|
+
AuthorizerKeys.ROLE_MODEL = '@app/authorize/component/models/user';
|
9
|
+
AuthorizerKeys.PERMISSION_MODEL = '@app/authorize/component/models/permission';
|
10
|
+
AuthorizerKeys.PERMISSION_MAPPING_MODEL = '@app/authorize/component/models/permission_mapping';
|
11
|
+
AuthorizerKeys.USER_ROLE_MODEL = '@app/authorize/component/models/user_role';
|
12
|
+
AuthorizerKeys.ROLE_REPOSITORY = '@app/authorize/component/repositories/user';
|
13
|
+
AuthorizerKeys.PERMISSION_REPOSITORY = '@app/authorize/component/repositories/permission';
|
14
|
+
AuthorizerKeys.PERMISSION_MAPPING_REPOSITORY = '@app/authorize/component/repositories/permission_mapping';
|
15
|
+
AuthorizerKeys.USER_ROLE_REPOSITORY = '@app/authorize/component/repositories/user_role';
|
16
|
+
AuthorizerKeys.PROVIDER = '@app/authorize/provider';
|
17
|
+
AuthorizerKeys.ENFORCER = '@app/authorize/enforcer';
|
18
|
+
AuthorizerKeys.ALWAYS_ALLOW_ROLES = '@app/authorize/always_allow_roles';
|
19
|
+
AuthorizerKeys.AUTHORIZE_DATASOURCE = '@app/authorize/enforcer/adapter/datasource';
|
20
|
+
AuthorizerKeys.CONFIGURE_OPTIONS = '@app/authorize/configure_options';
|
21
|
+
AuthorizerKeys.NORMALIZE_PAYLOAD_FN = '@app/authorize/normalize_payload_fn';
|
22
|
+
//# sourceMappingURL=keys.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"keys.js","sourceRoot":"","sources":["../../../../src/components/authorize/common/keys.ts"],"names":[],"mappings":";;;AAAA,MAAa,cAAc;;AAA3B,wCAmBC;AAlBiB,+BAAgB,GAAG,2CAA2C,CAAC;AAE/D,yBAAU,GAAG,sCAAsC,CAAC;AACpD,+BAAgB,GAAG,4CAA4C,CAAC;AAChE,uCAAwB,GAAG,oDAAoD,CAAC;AAChF,8BAAe,GAAG,2CAA2C,CAAC;AAE9D,8BAAe,GAAG,4CAA4C,CAAC;AAC/D,oCAAqB,GAAG,kDAAkD,CAAC;AAC3E,4CAA6B,GAAG,0DAA0D,CAAC;AAC3F,mCAAoB,GAAG,iDAAiD,CAAC;AAEzE,uBAAQ,GAAG,yBAAyB,CAAC;AACrC,uBAAQ,GAAG,yBAAyB,CAAC;AACrC,iCAAkB,GAAG,mCAAmC,CAAC;AACzD,mCAAoB,GAAG,4CAA4C,CAAC;AACpE,gCAAiB,GAAG,kCAAkC,CAAC;AACvD,mCAAoB,GAAG,qCAAqC,CAAC"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import { FilteredAdapter } from 'casbin';
|
2
|
+
export interface IEnforcerFilterValue {
|
3
|
+
principalType: string;
|
4
|
+
principalValue: string | number | object;
|
5
|
+
}
|
6
|
+
export type TCasbinAdapter = 'casbin-postgres' | 'casbin-redis';
|
7
|
+
export declare class CasbinAdapterTypes {
|
8
|
+
static readonly POSTGRES: TCasbinAdapter;
|
9
|
+
static readonly REDIS: TCasbinAdapter;
|
10
|
+
}
|
11
|
+
export interface IAuthorizeConfigureOptions {
|
12
|
+
confPath: string;
|
13
|
+
adapterType?: TCasbinAdapter;
|
14
|
+
adapter?: FilteredAdapter;
|
15
|
+
useCache: boolean;
|
16
|
+
}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.CasbinAdapterTypes = void 0;
|
4
|
+
class CasbinAdapterTypes {
|
5
|
+
}
|
6
|
+
exports.CasbinAdapterTypes = CasbinAdapterTypes;
|
7
|
+
CasbinAdapterTypes.POSTGRES = 'casbin-postgres';
|
8
|
+
CasbinAdapterTypes.REDIS = 'casbin-redis';
|
9
|
+
//# sourceMappingURL=types.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/authorize/common/types.ts"],"names":[],"mappings":";;;AAQA,MAAa,kBAAkB;;AAA/B,gDAGC;AAFiB,2BAAQ,GAAmB,iBAAiB,CAAC;AAC7C,wBAAK,GAAmB,cAAc,CAAC"}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
import { BaseApplication } from '../../base/applications';
|
2
|
+
import { BaseComponent } from '../../base/base.component';
|
3
|
+
import { Binding } from '@loopback/core';
|
4
|
+
export declare class AuthorizeComponent extends BaseComponent {
|
5
|
+
protected application: BaseApplication;
|
6
|
+
bindings: Binding[];
|
7
|
+
constructor(application: BaseApplication);
|
8
|
+
defineModels(): void;
|
9
|
+
defineRepositories(): void;
|
10
|
+
verify(): Promise<void>;
|
11
|
+
binding(): void;
|
12
|
+
}
|
@@ -0,0 +1,158 @@
|
|
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
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
13
|
+
};
|
14
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
15
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
16
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
17
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
18
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
19
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
20
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
21
|
+
});
|
22
|
+
};
|
23
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
24
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
25
|
+
};
|
26
|
+
var AuthorizeComponent_1;
|
27
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
28
|
+
exports.AuthorizeComponent = void 0;
|
29
|
+
const applications_1 = require("../../base/applications");
|
30
|
+
const base_component_1 = require("../../base/base.component");
|
31
|
+
const utilities_1 = require("../../utilities");
|
32
|
+
const authorization_1 = require("@loopback/authorization");
|
33
|
+
const core_1 = require("@loopback/core");
|
34
|
+
const common_1 = require("./common");
|
35
|
+
const interceptor_1 = require("./interceptor");
|
36
|
+
const models_1 = require("./models");
|
37
|
+
const provider_1 = require("./provider");
|
38
|
+
const repositories_1 = require("./repositories");
|
39
|
+
const services_1 = require("./services");
|
40
|
+
const flatten_1 = __importDefault(require("lodash/flatten"));
|
41
|
+
const path_1 = __importDefault(require("path"));
|
42
|
+
const authorizeConfPath = path_1.default.resolve(__dirname, '../../static/security/authorize_model.conf');
|
43
|
+
let AuthorizeComponent = AuthorizeComponent_1 = class AuthorizeComponent extends base_component_1.BaseComponent {
|
44
|
+
constructor(application) {
|
45
|
+
super({ scope: AuthorizeComponent_1.name });
|
46
|
+
this.application = application;
|
47
|
+
this.bindings = [
|
48
|
+
// Model bindings
|
49
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.ROLE_MODEL).toClass(models_1.Role),
|
50
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_MODEL).toClass(models_1.Permission),
|
51
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_MAPPING_MODEL).toClass(models_1.PermissionMapping),
|
52
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.USER_ROLE_MODEL).toClass(models_1.UserRole),
|
53
|
+
// Repository bindings
|
54
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.ROLE_REPOSITORY).toClass(repositories_1.RoleRepository),
|
55
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_REPOSITORY).toClass(repositories_1.PermissionRepository),
|
56
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.PERMISSION_MAPPING_REPOSITORY).toClass(repositories_1.PermissionMappingRepository),
|
57
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.USER_ROLE_REPOSITORY).toClass(repositories_1.UserRoleRepository),
|
58
|
+
// Datasource
|
59
|
+
// Binding.bind(AuthorizerKeys.AUTHORIZE_DATASOURCE).to(null),
|
60
|
+
// Configure path
|
61
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.CONFIGURE_OPTIONS).to({
|
62
|
+
confPath: authorizeConfPath,
|
63
|
+
useCache: false,
|
64
|
+
}),
|
65
|
+
core_1.Binding.bind(common_1.AuthorizerKeys.NORMALIZE_PAYLOAD_FN).to(null),
|
66
|
+
];
|
67
|
+
this.binding();
|
68
|
+
}
|
69
|
+
defineModels() {
|
70
|
+
this.application.model(models_1.Role);
|
71
|
+
this.application.model(models_1.Permission);
|
72
|
+
this.application.model(models_1.PermissionMapping);
|
73
|
+
this.application.model(models_1.UserRole);
|
74
|
+
this.application.model(models_1.ViewAuthorizePolicy);
|
75
|
+
this.application.models.add(models_1.Role.name);
|
76
|
+
this.application.models.add(models_1.Permission.name);
|
77
|
+
this.application.models.add(models_1.PermissionMapping.name);
|
78
|
+
this.application.models.add(models_1.UserRole.name);
|
79
|
+
this.application.models.add(models_1.ViewAuthorizePolicy.name);
|
80
|
+
}
|
81
|
+
defineRepositories() {
|
82
|
+
this.application.repository(repositories_1.RoleRepository);
|
83
|
+
this.application.repository(repositories_1.PermissionRepository);
|
84
|
+
this.application.repository(repositories_1.PermissionMappingRepository);
|
85
|
+
this.application.repository(repositories_1.UserRoleRepository);
|
86
|
+
this.application.repository(repositories_1.ViewAuthorizePolicyRepository);
|
87
|
+
}
|
88
|
+
verify() {
|
89
|
+
return __awaiter(this, void 0, void 0, function* () {
|
90
|
+
const datasource = this.application.getSync(common_1.AuthorizerKeys.AUTHORIZE_DATASOURCE);
|
91
|
+
if (!datasource) {
|
92
|
+
throw (0, utilities_1.getError)({
|
93
|
+
statusCode: 500,
|
94
|
+
message: `[verify] Invalid binding datasource to key ${common_1.AuthorizerKeys.AUTHORIZE_DATASOURCE}`,
|
95
|
+
});
|
96
|
+
}
|
97
|
+
const checkTableExecutions = ['Role', 'Permission', 'UserRole', 'PermissionMapping'].map(tableName => {
|
98
|
+
return datasource.execute(`
|
99
|
+
SELECT EXISTS (
|
100
|
+
SELECT FROM information_schema.tables
|
101
|
+
WHERE table_schema='public'
|
102
|
+
AND table_name='${tableName}'
|
103
|
+
) as "isTableExisted"`);
|
104
|
+
});
|
105
|
+
const tableRs = yield Promise.all(checkTableExecutions);
|
106
|
+
const checkTableExistRs = (0, flatten_1.default)(tableRs);
|
107
|
+
for (const rs of checkTableExistRs) {
|
108
|
+
if (!rs.isTableExisted) {
|
109
|
+
throw (0, utilities_1.getError)({
|
110
|
+
statusCode: 500,
|
111
|
+
message: '[verify] Essential table IS NOT EXISTS | Please check again (Role, Permission, UserRole and PermissionMapping)',
|
112
|
+
});
|
113
|
+
}
|
114
|
+
}
|
115
|
+
const checkAuthorizeViewRs = yield datasource.execute(`
|
116
|
+
SELECT EXISTS (
|
117
|
+
SELECT FROM information_schema.views
|
118
|
+
WHERE table_schema='public'
|
119
|
+
AND table_name='ViewAuthorizePolicy'
|
120
|
+
) as "isViewExisted"`);
|
121
|
+
for (const rs of checkAuthorizeViewRs) {
|
122
|
+
if (!rs.isViewExisted) {
|
123
|
+
throw (0, utilities_1.getError)({
|
124
|
+
statusCode: 500,
|
125
|
+
message: '[verify] Essential view IS NOT EXISTS | Please check again (ViewAuthorizePolicy)',
|
126
|
+
});
|
127
|
+
}
|
128
|
+
}
|
129
|
+
});
|
130
|
+
}
|
131
|
+
binding() {
|
132
|
+
this.logger.info('[binding] Binding authorize component for application...');
|
133
|
+
this.defineModels();
|
134
|
+
this.defineRepositories();
|
135
|
+
if (process.env.RUN_MODE === 'migrate') {
|
136
|
+
return;
|
137
|
+
}
|
138
|
+
this.verify()
|
139
|
+
.then(() => {
|
140
|
+
this.application.interceptor(interceptor_1.AuthorizateInterceptor);
|
141
|
+
this.application.bind(common_1.AuthorizerKeys.ENFORCER).toInjectable(services_1.EnforcerService);
|
142
|
+
this.application.configure(authorization_1.AuthorizationBindings.COMPONENT).to({
|
143
|
+
precedence: authorization_1.AuthorizationDecision.DENY,
|
144
|
+
defaultDecision: authorization_1.AuthorizationDecision.DENY,
|
145
|
+
});
|
146
|
+
this.application.bind(common_1.AuthorizerKeys.PROVIDER).toProvider(provider_1.AuthorizeProvider).tag(authorization_1.AuthorizationTags.AUTHORIZER);
|
147
|
+
})
|
148
|
+
.catch(error => {
|
149
|
+
throw error;
|
150
|
+
});
|
151
|
+
}
|
152
|
+
};
|
153
|
+
exports.AuthorizeComponent = AuthorizeComponent;
|
154
|
+
exports.AuthorizeComponent = AuthorizeComponent = AuthorizeComponent_1 = __decorate([
|
155
|
+
__param(0, (0, core_1.inject)(core_1.CoreBindings.APPLICATION_INSTANCE)),
|
156
|
+
__metadata("design:paramtypes", [applications_1.BaseApplication])
|
157
|
+
], AuthorizeComponent);
|
158
|
+
//# sourceMappingURL=component.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../src/components/authorize/component.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
export declare class MetadataDecoratorKeys {
|
2
|
+
static readonly PERMISSION = "metadata-key-for-permission-decorator";
|
3
|
+
}
|
4
|
+
export interface IPermissionDecorator {
|
5
|
+
idx: number;
|
6
|
+
}
|
7
|
+
export declare function permission(spec: IPermissionDecorator): MethodDecorator;
|
8
|
+
export declare const getDecoratorData: (controllerPrototype: object, keyTargetDecorator: string) => import("@loopback/metadata").MetadataMap<any> | undefined;
|
@@ -0,0 +1,19 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.getDecoratorData = exports.MetadataDecoratorKeys = void 0;
|
4
|
+
exports.permission = permission;
|
5
|
+
const metadata_1 = require("@loopback/metadata");
|
6
|
+
class MetadataDecoratorKeys {
|
7
|
+
}
|
8
|
+
exports.MetadataDecoratorKeys = MetadataDecoratorKeys;
|
9
|
+
MetadataDecoratorKeys.PERMISSION = 'metadata-key-for-permission-decorator';
|
10
|
+
// Read more: https://loopback.io/doc/en/lb4/Creating-decorators.html#inspect-metadata-of-a-property
|
11
|
+
function permission(spec) {
|
12
|
+
return metadata_1.MethodDecoratorFactory.createDecorator(MetadataDecoratorKeys.PERMISSION, spec);
|
13
|
+
}
|
14
|
+
// Read more: https://loopback.io/doc/en/lb4/Creating-decorators.html#to-create-a-decorator-that-can-be-used-multiple-times-on-a-single-method
|
15
|
+
const getDecoratorData = (controllerPrototype, keyTargetDecorator) => {
|
16
|
+
return metadata_1.MetadataInspector.getAllPropertyMetadata(keyTargetDecorator, controllerPrototype);
|
17
|
+
};
|
18
|
+
exports.getDecoratorData = getDecoratorData;
|
19
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/authorize/decorators/index.ts"],"names":[],"mappings":";;;AAWA,gCAEC;AAbD,iDAA+E;AAE/E,MAAa,qBAAqB;;AAAlC,sDAEC;AADiB,gCAAU,GAAG,uCAAuC,CAAC;AAOvE,oGAAoG;AACpG,SAAgB,UAAU,CAAC,IAA0B;IACnD,OAAO,iCAAsB,CAAC,eAAe,CAAuB,qBAAqB,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;AAC9G,CAAC;AAED,8IAA8I;AACvI,MAAM,gBAAgB,GAAG,CAAC,mBAA2B,EAAE,kBAA0B,EAAE,EAAE;IAC1F,OAAO,4BAAiB,CAAC,sBAAsB,CAAM,kBAAkB,EAAE,mBAAmB,CAAC,CAAC;AAChG,CAAC,CAAC;AAFW,QAAA,gBAAgB,oBAE3B"}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
export * from './adapters';
|
2
|
+
export * from './common';
|
3
|
+
export * from './component';
|
4
|
+
export * from './decorators';
|
5
|
+
export * from './migrations';
|
6
|
+
export * from './models';
|
7
|
+
export * from './provider';
|
8
|
+
export * from './repositories';
|
9
|
+
export * from './services';
|
@@ -0,0 +1,26 @@
|
|
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("./adapters"), exports);
|
18
|
+
__exportStar(require("./common"), exports);
|
19
|
+
__exportStar(require("./component"), exports);
|
20
|
+
__exportStar(require("./decorators"), exports);
|
21
|
+
__exportStar(require("./migrations"), exports);
|
22
|
+
__exportStar(require("./models"), exports);
|
23
|
+
__exportStar(require("./provider"), exports);
|
24
|
+
__exportStar(require("./repositories"), exports);
|
25
|
+
__exportStar(require("./services"), exports);
|
26
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/authorize/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,2CAAyB;AACzB,8CAA4B;AAC5B,+CAA6B;AAC7B,+CAA6B;AAC7B,2CAAyB;AACzB,6CAA2B;AAC3B,iDAA+B;AAC/B,6CAA2B"}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
import { Interceptor, InvocationContext, Next, NonVoid, Provider } from '@loopback/core';
|
2
|
+
import { AuthorizationOptions } from '@loopback/authorization';
|
3
|
+
export declare class AuthorizateInterceptor implements Provider<Interceptor> {
|
4
|
+
private options;
|
5
|
+
private logger;
|
6
|
+
constructor(options?: AuthorizationOptions);
|
7
|
+
value(): Interceptor;
|
8
|
+
intercept(invocationCtx: InvocationContext, next: Next): Promise<NonVoid>;
|
9
|
+
}
|