@drax/identity-back 0.5.2 → 0.5.4
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/dist/controllers/RoleController.js +84 -0
- package/dist/controllers/TenantController.js +1 -2
- package/dist/controllers/UserApiKeyController.js +127 -0
- package/dist/controllers/UserController.js +295 -0
- package/dist/index.js +1 -2
- package/dist/repository/mongo/RoleMongoRepository.js +12 -3
- package/dist/repository/mongo/TenantMongoRepository.js +11 -0
- package/dist/routes/RoleRoutes.js +11 -207
- package/dist/routes/TenantRoutes.js +1 -0
- package/dist/routes/UserApiKeyRoutes.js +6 -114
- package/dist/routes/UserRoutes.js +12 -218
- package/dist/services/RoleService.js +42 -2
- package/dist/services/TenantService.js +5 -0
- package/dist/services/UserApiKeyService.js +9 -1
- package/dist/services/UserService.js +14 -4
- package/dist/setup/CreateOrUpdateRole.js +1 -1
- package/package.json +5 -5
- package/src/controllers/RoleController.ts +94 -0
- package/src/controllers/TenantController.ts +1 -2
- package/src/controllers/UserApiKeyController.ts +144 -0
- package/src/controllers/UserController.ts +300 -0
- package/src/index.ts +0 -2
- package/src/repository/mongo/RoleMongoRepository.ts +12 -3
- package/src/repository/mongo/TenantMongoRepository.ts +11 -0
- package/src/routes/RoleRoutes.ts +11 -186
- package/src/routes/TenantRoutes.ts +2 -0
- package/src/routes/UserApiKeyRoutes.ts +6 -113
- package/src/routes/UserRoutes.ts +12 -202
- package/src/services/RoleService.ts +45 -4
- package/src/services/TenantService.ts +7 -1
- package/src/services/UserApiKeyService.ts +11 -1
- package/src/services/UserService.ts +16 -4
- package/src/setup/CreateOrUpdateRole.ts +1 -1
- package/tsconfig.tsbuildinfo +1 -1
- package/types/controllers/RoleController.d.ts +14 -0
- package/types/controllers/RoleController.d.ts.map +1 -0
- package/types/controllers/TenantController.d.ts.map +1 -1
- package/types/controllers/UserApiKeyController.d.ts +14 -0
- package/types/controllers/UserApiKeyController.d.ts.map +1 -0
- package/types/controllers/UserController.d.ts +27 -0
- package/types/controllers/UserController.d.ts.map +1 -0
- package/types/index.d.ts +1 -2
- package/types/index.d.ts.map +1 -1
- package/types/repository/mongo/RoleMongoRepository.d.ts +2 -0
- package/types/repository/mongo/RoleMongoRepository.d.ts.map +1 -1
- package/types/repository/mongo/TenantMongoRepository.d.ts +2 -0
- package/types/repository/mongo/TenantMongoRepository.d.ts.map +1 -1
- package/types/routes/RoleRoutes.d.ts.map +1 -1
- package/types/routes/TenantRoutes.d.ts.map +1 -1
- package/types/routes/UserApiKeyRoutes.d.ts.map +1 -1
- package/types/routes/UserRoutes.d.ts.map +1 -1
- package/types/services/RoleService.d.ts +5 -1
- package/types/services/RoleService.d.ts.map +1 -1
- package/types/services/TenantService.d.ts +1 -0
- package/types/services/TenantService.d.ts.map +1 -1
- package/types/services/UserApiKeyService.d.ts +2 -1
- package/types/services/UserApiKeyService.d.ts.map +1 -1
- package/types/services/UserService.d.ts +3 -1
- package/types/services/UserService.d.ts.map +1 -1
- package/src/routes/UserAvatarRoutes.ts +0 -82
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { IRole, IRoleBase } from "@drax/identity-share";
|
|
2
|
+
import { AbstractFastifyController } from "@drax/crud-back";
|
|
3
|
+
import RoleService from "../services/RoleService.js";
|
|
4
|
+
declare class RoleController extends AbstractFastifyController<IRole, IRoleBase, IRoleBase> {
|
|
5
|
+
protected service: RoleService;
|
|
6
|
+
constructor();
|
|
7
|
+
findByName(request: any, reply: any): Promise<IRole>;
|
|
8
|
+
all(request: any, reply: any): Promise<IRole[]>;
|
|
9
|
+
permissions(request: any, reply: any): Promise<string[]>;
|
|
10
|
+
xxxx(request: any, reply: any): Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
export default RoleController;
|
|
13
|
+
export { RoleController };
|
|
14
|
+
//# sourceMappingURL=RoleController.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RoleController.d.ts","sourceRoot":"","sources":["../../src/controllers/RoleController.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,KAAK,EAAE,SAAS,EAAC,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAC,yBAAyB,EAAC,MAAM,iBAAiB,CAAC;AAI1D,OAAO,WAAW,MAAM,4BAA4B,CAAC;AAIrD,cAAM,cAAe,SAAQ,yBAAyB,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,CAAC;IAE/E,SAAS,CAAC,OAAO,EAAE,WAAW,CAAA;;IAMxB,UAAU,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IAsBzB,GAAG,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IAyBlB,WAAW,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IAmB1B,IAAI,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;CAI5B;AAED,eAAe,cAAc,CAAC;AAC9B,OAAO,EACH,cAAc,EACjB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TenantController.d.ts","sourceRoot":"","sources":["../../src/controllers/TenantController.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,OAAO,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAC/D,OAAO,EAAC,yBAAyB,EAAC,MAAM,iBAAiB,CAAC;AAI1D,OAAO,aAAa,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"TenantController.d.ts","sourceRoot":"","sources":["../../src/controllers/TenantController.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,OAAO,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAC/D,OAAO,EAAC,yBAAyB,EAAC,MAAM,iBAAiB,CAAC;AAI1D,OAAO,aAAa,MAAM,8BAA8B,CAAC;AAGzD,cAAM,gBAAiB,SAAQ,yBAAyB,CAAC,OAAO,EAAE,WAAW,EAAE,WAAW,CAAC;IAEvF,SAAS,CAAC,OAAO,EAAE,aAAa,CAAA;;IAM1B,UAAU,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IAyBzB,GAAG,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;CAwB3B;AAED,eAAe,gBAAgB,CAAC;AAChC,OAAO,EACH,gBAAgB,EACnB,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { IUserApiKey, IUserApiKeyBase } from "@drax/identity-share";
|
|
2
|
+
import { AbstractFastifyController } from "@drax/crud-back";
|
|
3
|
+
import UserApiKeyService from "../services/UserApiKeyService.js";
|
|
4
|
+
declare class UserApiKeyController extends AbstractFastifyController<IUserApiKey, IUserApiKeyBase, IUserApiKeyBase> {
|
|
5
|
+
protected service: UserApiKeyService;
|
|
6
|
+
constructor();
|
|
7
|
+
paginate(request: any, reply: any): Promise<import("packages/crud/crud-share/types/index.js").IDraxPaginateResult<IUserApiKey>>;
|
|
8
|
+
create(request: any, reply: any): Promise<IUserApiKey>;
|
|
9
|
+
update(request: any, reply: any): Promise<IUserApiKey>;
|
|
10
|
+
delete(request: any, reply: any): Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
export default UserApiKeyController;
|
|
13
|
+
export { UserApiKeyController };
|
|
14
|
+
//# sourceMappingURL=UserApiKeyController.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserApiKeyController.d.ts","sourceRoot":"","sources":["../../src/controllers/UserApiKeyController.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,WAAW,EAAE,eAAe,EAAC,MAAM,sBAAsB,CAAC;AACvE,OAAO,EAAC,yBAAyB,EAAC,MAAM,iBAAiB,CAAC;AAI1D,OAAO,iBAAiB,MAAM,kCAAkC,CAAC;AAGjE,cAAM,oBAAqB,SAAQ,yBAAyB,CAAC,WAAW,EAAE,eAAe,EAAE,eAAe,CAAC;IAEvG,SAAS,CAAC,OAAO,EAAE,iBAAiB,CAAA;;IAO9B,QAAQ,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IAyCvB,MAAM,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IA0BrB,MAAM,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IA2BrB,MAAM,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA,GAAI,OAAO,CAAC,IAAI,CAAC;CA0B/C;AAED,eAAe,oBAAoB,CAAC;AACpC,OAAO,EACH,oBAAoB,EACvB,CAAA"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { IUser, IUserUpdate, IUserCreate } from "@drax/identity-share";
|
|
2
|
+
import { AbstractFastifyController } from "@drax/crud-back";
|
|
3
|
+
import UserService from "../services/UserService.js";
|
|
4
|
+
declare class UserController extends AbstractFastifyController<IUser, IUserCreate, IUserUpdate> {
|
|
5
|
+
protected service: UserService;
|
|
6
|
+
constructor();
|
|
7
|
+
auth(request: any, reply: any): Promise<{
|
|
8
|
+
accessToken: string;
|
|
9
|
+
}>;
|
|
10
|
+
me(request: any, reply: any): Promise<IUser>;
|
|
11
|
+
paginate(request: any, reply: any): Promise<import("packages/crud/crud-share/types/index.js").IDraxPaginateResult<IUser>>;
|
|
12
|
+
create(request: any, reply: any): Promise<IUser>;
|
|
13
|
+
update(request: any, reply: any): Promise<IUser>;
|
|
14
|
+
delete(request: any, reply: any): Promise<void>;
|
|
15
|
+
myPassword(request: any, reply: any): Promise<boolean>;
|
|
16
|
+
password(request: any, reply: any): Promise<boolean>;
|
|
17
|
+
updateAvatar(request: any, reply: any): Promise<{
|
|
18
|
+
filename: string;
|
|
19
|
+
size: number;
|
|
20
|
+
mimetype: string;
|
|
21
|
+
url: string;
|
|
22
|
+
}>;
|
|
23
|
+
getAvatar(request: any, reply: any): Promise<any>;
|
|
24
|
+
}
|
|
25
|
+
export default UserController;
|
|
26
|
+
export { UserController };
|
|
27
|
+
//# sourceMappingURL=UserController.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserController.d.ts","sourceRoot":"","sources":["../../src/controllers/UserController.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,KAAK,EAAE,WAAW,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAC1E,OAAO,EAAC,yBAAyB,EAAC,MAAM,iBAAiB,CAAC;AAI1D,OAAO,WAAW,MAAM,4BAA4B,CAAC;AAWrD,cAAM,cAAe,SAAQ,yBAAyB,CAAC,KAAK,EAAE,WAAW,EAAE,WAAW,CAAC;IAEnF,SAAS,CAAC,OAAO,EAAE,WAAW,CAAA;;IAMxB,IAAI,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;;;IAiBnB,EAAE,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IA0BjB,QAAQ,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IAiCvB,MAAM,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IAwBrB,MAAM,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IA6BrB,MAAM,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IAyBrB,UAAU,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IAyBzB,QAAQ,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;IA0BvB,YAAY,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;;;;;;IA2C3B,SAAS,CAAC,OAAO,KAAA,EAAE,KAAK,KAAA;CAqBjC;AAED,eAAe,cAAc,CAAC;AAC9B,OAAO,EACH,cAAc,EACjB,CAAA"}
|
package/types/index.d.ts
CHANGED
|
@@ -7,7 +7,6 @@ import TenantService from "./services/TenantService.js";
|
|
|
7
7
|
import PermissionService from "./services/PermissionService.js";
|
|
8
8
|
import Rbac from "./rbac/Rbac.js";
|
|
9
9
|
import { UserRoutes } from "./routes/UserRoutes.js";
|
|
10
|
-
import { UserAvatarRoutes } from "./routes/UserAvatarRoutes.js";
|
|
11
10
|
import { RoleRoutes } from "./routes/RoleRoutes.js";
|
|
12
11
|
import { TenantRoutes } from "./routes/TenantRoutes.js";
|
|
13
12
|
import { UserApiKeyRoutes } from "./routes/UserApiKeyRoutes.js";
|
|
@@ -34,5 +33,5 @@ import { UserApiKeyPermissions } from "./permissions/UserApiKeyPermissions.js";
|
|
|
34
33
|
declare const identityTypeDefs: import("@graphql-tools/utils").TypeSource;
|
|
35
34
|
declare const identityResolvers: import("@graphql-tools/utils").IResolvers;
|
|
36
35
|
export type { IRoleRepository, ITenantRepository, IUserRepository, IUserApiKeyRepository };
|
|
37
|
-
export { UserService, RoleService, TenantService, PermissionService, Rbac, UserServiceFactory, RoleServiceFactory, TenantServiceFactory, identityTypeDefs, identityResolvers, UserRoutes, RoleRoutes, TenantRoutes,
|
|
36
|
+
export { UserService, RoleService, TenantService, PermissionService, Rbac, UserServiceFactory, RoleServiceFactory, TenantServiceFactory, identityTypeDefs, identityResolvers, UserRoutes, RoleRoutes, TenantRoutes, UserApiKeyRoutes, AuthUtils, jwtMiddleware, rbacMiddleware, apiKeyMiddleware, IdentityPermissions, RolePermissions, TenantPermissions, UserPermissions, UserApiKeyPermissions, IdentityConfig, BadCredentialsError, LoadIdentityConfigFromEnv, LoadPermissions, CreateOrUpdateRole, CreateUserIfNotExist, RecoveryUserPassword };
|
|
38
37
|
//# sourceMappingURL=index.d.ts.map
|
package/types/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,kBAAkB,MAAM,iCAAiC,CAAC;AACjE,OAAO,kBAAkB,MAAM,iCAAiC,CAAC;AACjE,OAAO,oBAAoB,MAAM,mCAAmC,CAAC;AAErE,OAAO,WAAW,MAAM,2BAA2B,CAAC;AACpD,OAAO,WAAW,MAAM,2BAA2B,CAAC;AACpD,OAAO,aAAa,MAAM,6BAA6B,CAAC;AACxD,OAAO,iBAAiB,MAAM,iCAAiC,CAAC;AAEhE,OAAO,IAAI,MAAM,gBAAgB,CAAC;AAElC,OAAO,EAAC,UAAU,EAAC,MAAM,wBAAwB,CAAC;AAClD,OAAO,EAAC,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,kBAAkB,MAAM,iCAAiC,CAAC;AACjE,OAAO,kBAAkB,MAAM,iCAAiC,CAAC;AACjE,OAAO,oBAAoB,MAAM,mCAAmC,CAAC;AAErE,OAAO,WAAW,MAAM,2BAA2B,CAAC;AACpD,OAAO,WAAW,MAAM,2BAA2B,CAAC;AACpD,OAAO,aAAa,MAAM,6BAA6B,CAAC;AACxD,OAAO,iBAAiB,MAAM,iCAAiC,CAAC;AAEhE,OAAO,IAAI,MAAM,gBAAgB,CAAC;AAElC,OAAO,EAAC,UAAU,EAAC,MAAM,wBAAwB,CAAC;AAClD,OAAO,EAAC,UAAU,EAAC,MAAM,wBAAwB,CAAC;AAClD,OAAO,EAAC,YAAY,EAAC,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAC,gBAAgB,EAAC,MAAM,8BAA8B,CAAC;AAE9D,OAAO,SAAS,MAAM,sBAAsB,CAAC;AAC7C,OAAO,EAAC,aAAa,EAAC,MAAM,+BAA+B,CAAC;AAC5D,OAAO,EAAC,cAAc,EAAC,MAAM,gCAAgC,CAAC;AAC9D,OAAO,EAAC,gBAAgB,EAAC,MAAM,kCAAkC,CAAC;AAElE,OAAO,cAAc,MAAM,4BAA4B,CAAC;AACxD,OAAO,mBAAmB,MAAM,iCAAiC,CAAC;AAElE,OAAO,oBAAoB,MAAM,iCAAiC,CAAC;AACnE,OAAO,kBAAkB,MAAM,+BAA+B,CAAC;AAC/D,OAAO,eAAe,MAAM,4BAA4B,CAAC;AACzD,OAAO,yBAAyB,MAAM,sCAAsC,CAAC;AAC7E,OAAO,oBAAoB,MAAM,iCAAiC,CAAC;AAEnE,OAAO,KAAK,EAAC,eAAe,EAAC,MAAM,8BAA8B,CAAC;AAClE,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,gCAAgC,CAAC;AACtE,OAAO,KAAK,EAAC,eAAe,EAAC,MAAM,8BAA8B,CAAC;AAClE,OAAO,KAAK,EAAC,qBAAqB,EAAC,MAAM,oCAAoC,CAAC;AAG9E,OAAO,mBAAmB,MAAM,sCAAsC,CAAC;AAEvE,OAAO,EAAC,eAAe,EAAC,MAAM,kCAAkC,CAAC;AACjE,OAAO,EAAC,iBAAiB,EAAC,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAC,eAAe,EAAC,MAAM,kCAAkC,CAAC;AACjE,OAAO,EAAC,qBAAqB,EAAC,MAAM,wCAAwC,CAAC;AAI7E,QAAA,MAAM,gBAAgB,2CAAoC,CAAC;AAC3D,QAAA,MAAM,iBAAiB,2CAAqC,CAAC;AAG7D,YAAY,EACR,eAAe,EACf,iBAAiB,EACjB,eAAe,EACf,qBAAqB,EACxB,CAAA;AAED,OAAO,EAEH,WAAW,EACX,WAAW,EACX,aAAa,EACb,iBAAiB,EACjB,IAAI,EAGJ,kBAAkB,EAClB,kBAAkB,EAClB,oBAAoB,EAGpB,gBAAgB,EAChB,iBAAiB,EAGjB,UAAU,EACV,UAAU,EACV,YAAY,EACZ,gBAAgB,EAEhB,SAAS,EAGT,aAAa,EACb,cAAc,EACd,gBAAgB,EAGhB,mBAAmB,EACnB,eAAe,EACf,iBAAiB,EACjB,eAAe,EACf,qBAAqB,EAGrB,cAAc,EAGd,mBAAmB,EAGnB,yBAAyB,EACzB,eAAe,EACf,kBAAkB,EAClB,oBAAoB,EACpB,oBAAoB,EACvB,CAAA"}
|
|
@@ -2,12 +2,14 @@ import { IRoleRepository } from '../../interfaces/IRoleRepository';
|
|
|
2
2
|
import { IDraxPaginateOptions, IDraxPaginateResult } from "@drax/crud-share";
|
|
3
3
|
import { IRoleBase, IRole } from "@drax/identity-share";
|
|
4
4
|
declare class RoleMongoRepository implements IRoleRepository {
|
|
5
|
+
_searchFields: string[];
|
|
5
6
|
create(roleData: IRoleBase): Promise<IRole>;
|
|
6
7
|
update(id: string, roleData: IRoleBase): Promise<IRole>;
|
|
7
8
|
delete(id: string): Promise<boolean>;
|
|
8
9
|
findById(id: string): Promise<IRole | null>;
|
|
9
10
|
findByName(name: string): Promise<IRole | null>;
|
|
10
11
|
fetchAll(): Promise<IRole[]>;
|
|
12
|
+
search(value: string, limit?: number): Promise<IRole[]>;
|
|
11
13
|
paginate({ page, limit, orderBy, order, search, filters }: IDraxPaginateOptions): Promise<IDraxPaginateResult<IRole>>;
|
|
12
14
|
}
|
|
13
15
|
export default RoleMongoRepository;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RoleMongoRepository.d.ts","sourceRoot":"","sources":["../../../src/repository/mongo/RoleMongoRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,eAAe,EAAC,MAAM,kCAAkC,CAAA;AAIhE,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAC3E,OAAO,EAAC,SAAS,EAAE,KAAK,EAAC,MAAM,sBAAsB,CAAC;AAEtD,cAAM,mBAAoB,YAAW,eAAe;
|
|
1
|
+
{"version":3,"file":"RoleMongoRepository.d.ts","sourceRoot":"","sources":["../../../src/repository/mongo/RoleMongoRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,eAAe,EAAC,MAAM,kCAAkC,CAAA;AAIhE,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAC3E,OAAO,EAAC,SAAS,EAAE,KAAK,EAAC,MAAM,sBAAsB,CAAC;AAEtD,cAAM,mBAAoB,YAAW,eAAe;IAEhD,aAAa,WAAiB;IAExB,MAAM,CAAC,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC;IAO3C,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC;IAKvD,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAKpC,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;IAK3C,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;IAK/C,QAAQ,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAK5B,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,GAAE,MAAa,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAS7D,QAAQ,CAAC,EACI,IAAO,EACP,KAAQ,EACR,OAAW,EACX,KAAY,EACZ,MAAU,EACV,OAAW,EAAC,EAAG,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;CAoB/F;AAED,eAAe,mBAAmB,CAAA"}
|
|
@@ -2,12 +2,14 @@ import { ITenantRepository } from '../../interfaces/ITenantRepository';
|
|
|
2
2
|
import { IDraxFindOptions, IDraxPaginateOptions, IDraxPaginateResult } from "@drax/crud-share";
|
|
3
3
|
import { ITenant, ITenantBase } from "@drax/identity-share";
|
|
4
4
|
declare class TenantMongoRepository implements ITenantRepository {
|
|
5
|
+
_searchFields: string[];
|
|
5
6
|
create(tenantData: ITenantBase): Promise<ITenant>;
|
|
6
7
|
update(id: string, tenantData: ITenantBase): Promise<ITenant>;
|
|
7
8
|
delete(id: string): Promise<boolean>;
|
|
8
9
|
findById(id: string): Promise<ITenant | null>;
|
|
9
10
|
findByName(name: string): Promise<ITenant | null>;
|
|
10
11
|
fetchAll(): Promise<ITenant[]>;
|
|
12
|
+
search(value: string, limit?: number): Promise<ITenant[]>;
|
|
11
13
|
paginate({ page, limit, orderBy, order, search, filters }: IDraxPaginateOptions): Promise<IDraxPaginateResult<ITenant>>;
|
|
12
14
|
find({ cursor, limit, orderBy, order, search, filters }: IDraxFindOptions): Promise<ITenant[]>;
|
|
13
15
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TenantMongoRepository.d.ts","sourceRoot":"","sources":["../../../src/repository/mongo/TenantMongoRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,iBAAiB,EAAC,MAAM,oCAAoC,CAAA;AAIpE,OAAO,EAAC,gBAAgB,EAAE,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAC7F,OAAO,EAAC,OAAO,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAE1D,cAAM,qBAAsB,YAAW,iBAAiB;
|
|
1
|
+
{"version":3,"file":"TenantMongoRepository.d.ts","sourceRoot":"","sources":["../../../src/repository/mongo/TenantMongoRepository.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,iBAAiB,EAAC,MAAM,oCAAoC,CAAA;AAIpE,OAAO,EAAC,gBAAgB,EAAE,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAC7F,OAAO,EAAC,OAAO,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAE1D,cAAM,qBAAsB,YAAW,iBAAiB;IAEpD,aAAa,WAAiB;IAExB,MAAM,CAAC,UAAU,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;IAMjD,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;IAK7D,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAKpC,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IAK7C,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IAKjD,QAAQ,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;IAK9B,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,GAAE,MAAa,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAS/D,QAAQ,CAAC,EACI,IAAQ,EACR,KAAS,EACT,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;IAwBxE,IAAI,CAAC,EACI,MAAc,EACd,KAAS,EACT,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CAgBtD;AAED,eAAe,qBAAqB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RoleRoutes.d.ts","sourceRoot":"","sources":["../../src/routes/RoleRoutes.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"RoleRoutes.d.ts","sourceRoot":"","sources":["../../src/routes/RoleRoutes.ts"],"names":[],"mappings":"AAIA,iBAAe,UAAU,CAAC,OAAO,KAAA,EAAE,OAAO,KAAA,iBAsBzC;AAED,eAAe,UAAU,CAAC;AAC1B,OAAO,EAAC,UAAU,EAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TenantRoutes.d.ts","sourceRoot":"","sources":["../../src/routes/TenantRoutes.ts"],"names":[],"mappings":"AAEA,iBAAe,YAAY,CAAC,OAAO,KAAA,EAAE,OAAO,KAAA,
|
|
1
|
+
{"version":3,"file":"TenantRoutes.d.ts","sourceRoot":"","sources":["../../src/routes/TenantRoutes.ts"],"names":[],"mappings":"AAEA,iBAAe,YAAY,CAAC,OAAO,KAAA,EAAE,OAAO,KAAA,iBAsB3C;AAED,eAAe,YAAY,CAAC;AAC5B,OAAO,EAAC,YAAY,EAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserApiKeyRoutes.d.ts","sourceRoot":"","sources":["../../src/routes/UserApiKeyRoutes.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"UserApiKeyRoutes.d.ts","sourceRoot":"","sources":["../../src/routes/UserApiKeyRoutes.ts"],"names":[],"mappings":"AAGA,iBAAe,gBAAgB,CAAC,OAAO,KAAA,EAAE,OAAO,KAAA,iBAa/C;AAED,eAAe,gBAAgB,CAAC;AAChC,OAAO,EAAC,gBAAgB,EAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserRoutes.d.ts","sourceRoot":"","sources":["../../src/routes/UserRoutes.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"UserRoutes.d.ts","sourceRoot":"","sources":["../../src/routes/UserRoutes.ts"],"names":[],"mappings":"AAEA,iBAAe,UAAU,CAAC,OAAO,KAAA,EAAE,OAAO,KAAA,iBAwBzC;AAED,eAAe,UAAU,CAAC;AAC1B,OAAO,EAAC,UAAU,EAAC,CAAA"}
|
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
import { IRoleRepository } from "../interfaces/IRoleRepository";
|
|
2
|
+
import { AbstractService } from "@drax/crud-back";
|
|
2
3
|
import { IDraxPaginateOptions, IDraxPaginateResult } from "@drax/crud-share";
|
|
3
4
|
import type { IRoleBase, IRole } from "@drax/identity-share";
|
|
4
|
-
declare class RoleService {
|
|
5
|
+
declare class RoleService extends AbstractService<IRole, IRoleBase, IRoleBase> {
|
|
5
6
|
_repository: IRoleRepository;
|
|
6
7
|
constructor(roleRepostitory: IRoleRepository);
|
|
7
8
|
create(roleData: IRoleBase): Promise<IRole>;
|
|
8
9
|
update(id: string, roleData: IRoleBase): Promise<IRole>;
|
|
10
|
+
systemUpdate(id: string, roleData: IRoleBase): Promise<IRole>;
|
|
9
11
|
delete(id: string): Promise<boolean>;
|
|
12
|
+
systemDelete(id: string): Promise<boolean>;
|
|
10
13
|
findById(id: string): Promise<IRole | null>;
|
|
11
14
|
findByName(name: string): Promise<IRole | null>;
|
|
12
15
|
fetchAll(): Promise<IRole[]>;
|
|
16
|
+
search(value: any): Promise<IRole[]>;
|
|
13
17
|
paginate({ page, limit, orderBy, order, search, filters }: IDraxPaginateOptions): Promise<IDraxPaginateResult<IRole>>;
|
|
14
18
|
}
|
|
15
19
|
export default RoleService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RoleService.d.ts","sourceRoot":"","sources":["../../src/services/RoleService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAC,MAAM,+BAA+B,CAAC;
|
|
1
|
+
{"version":3,"file":"RoleService.d.ts","sourceRoot":"","sources":["../../src/services/RoleService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAC,MAAM,+BAA+B,CAAC;AAE9D,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAGjD,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAC3E,OAAO,KAAK,EAAC,SAAS,EAAE,KAAK,EAAC,MAAM,sBAAsB,CAAC;AAE3D,cAAM,WAAY,SAAQ,eAAe,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,CAAC;IAElE,WAAW,EAAE,eAAe,CAAA;gBAEhB,eAAe,EAAE,eAAe;IAMtC,MAAM,CAAC,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC;IAe3C,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC;IAmBvD,YAAY,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC;IAe7D,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAcpC,YAAY,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAU1C,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;IAW3C,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;IAW/C,QAAQ,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAK5B,MAAM,CAAC,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAMpC,QAAQ,CAAC,EACI,IAAQ,EACR,KAAS,EACT,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;CAY/E;AAED,eAAe,WAAW,CAAA"}
|
|
@@ -11,6 +11,7 @@ declare class TenantService extends AbstractService<ITenant, ITenantBase, ITenan
|
|
|
11
11
|
findById(id: string): Promise<ITenant | null>;
|
|
12
12
|
findByName(name: string): Promise<ITenant | null>;
|
|
13
13
|
fetchAll(): Promise<ITenant[]>;
|
|
14
|
+
search(value: any): Promise<ITenant[]>;
|
|
14
15
|
paginate({ page, limit, orderBy, order, search, filters }: IDraxPaginateOptions): Promise<IDraxPaginateResult<ITenant>>;
|
|
15
16
|
}
|
|
16
17
|
export default TenantService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TenantService.d.ts","sourceRoot":"","sources":["../../src/services/TenantService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,iBAAiB,EAAC,MAAM,iCAAiC,CAAC;AAIlE,OAAO,EAAC,WAAW,EAAE,OAAO,
|
|
1
|
+
{"version":3,"file":"TenantService.d.ts","sourceRoot":"","sources":["../../src/services/TenantService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,iBAAiB,EAAC,MAAM,iCAAiC,CAAC;AAIlE,OAAO,EAAC,WAAW,EAAE,OAAO,EAAQ,MAAM,sBAAsB,CAAC;AACjE,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAC3E,OAAO,EAAC,eAAe,EAAC,MAAM,iBAAiB,CAAC;AAEhD,cAAM,aAAc,SAAQ,eAAe,CAAC,OAAO,EAAC,WAAW,EAAC,WAAW,CAAC;IAExE,WAAW,EAAE,iBAAiB,CAAA;gBAElB,iBAAiB,EAAE,iBAAiB;IAM1C,MAAM,CAAC,UAAU,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;IAejD,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW;IAe1C,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAWpC,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IAW7C,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IAWjD,QAAQ,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;IAW9B,MAAM,CAAC,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAMtC,QAAQ,CAAC,EACI,IAAQ,EACR,KAAS,EACT,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;CAYjF;AAED,eAAe,aAAa,CAAA"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { IUserApiKeyRepository } from "../interfaces/IUserApiKeyRepository";
|
|
2
2
|
import { IUserApiKeyBase, IUserApiKey } from "@drax/identity-share";
|
|
3
3
|
import { IDraxPaginateOptions, IDraxPaginateResult } from "@drax/crud-share";
|
|
4
|
-
|
|
4
|
+
import { AbstractService } from "@drax/crud-back";
|
|
5
|
+
declare class UserApiKeyService extends AbstractService<IUserApiKey, IUserApiKeyBase, IUserApiKeyBase> {
|
|
5
6
|
_repository: IUserApiKeyRepository;
|
|
6
7
|
constructor(userApiKeyRepostitory: IUserApiKeyRepository);
|
|
7
8
|
create(userApiKeyData: IUserApiKeyBase): Promise<IUserApiKey>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserApiKeyService.d.ts","sourceRoot":"","sources":["../../src/services/UserApiKeyService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,qBAAqB,EAAC,MAAM,qCAAqC,CAAC;AAI1E,OAAO,EAAC,eAAe,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAClE,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"UserApiKeyService.d.ts","sourceRoot":"","sources":["../../src/services/UserApiKeyService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,qBAAqB,EAAC,MAAM,qCAAqC,CAAC;AAI1E,OAAO,EAAC,eAAe,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAClE,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAI3E,OAAO,EAAC,eAAe,EAAC,MAAM,iBAAiB,CAAC;AAEhD,cAAM,iBAAkB,SAAQ,eAAe,CAAC,WAAW,EAAE,eAAe,EAAE,eAAe,CAAC;IAE1F,WAAW,EAAE,qBAAqB,CAAA;gBAEtB,qBAAqB,EAAE,qBAAqB;IAMlD,MAAM,CAAC,cAAc,EAAE,eAAe,GAAG,OAAO,CAAC,WAAW,CAAC;IAsB7D,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,cAAc,EAAE,eAAe;IAgBlD,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAWpC,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IAajD,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IAiBzD,QAAQ,CAAC,EACI,IAAQ,EACR,KAAS,EACT,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,WAAW,CAAC,CAAC;CAWrF;AAED,eAAe,iBAAiB,CAAA"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import type { IUser, IUserCreate, IUserUpdate } from "@drax/identity-share";
|
|
2
2
|
import type { IUserRepository } from "../interfaces/IUserRepository";
|
|
3
3
|
import { IDraxPaginateOptions, IDraxPaginateResult } from "@drax/crud-share";
|
|
4
|
-
|
|
4
|
+
import { AbstractService } from "@drax/crud-back";
|
|
5
|
+
declare class UserService extends AbstractService<IUser, IUserCreate, IUserUpdate> {
|
|
5
6
|
_repository: IUserRepository;
|
|
6
7
|
constructor(userRepository: IUserRepository);
|
|
7
8
|
auth(username: string, password: string): Promise<{
|
|
@@ -16,6 +17,7 @@ declare class UserService {
|
|
|
16
17
|
findById(id: string): Promise<IUser>;
|
|
17
18
|
findByUsername(username: string): Promise<IUser | null>;
|
|
18
19
|
paginate({ page, limit, orderBy, order, search, filters }: IDraxPaginateOptions): Promise<IDraxPaginateResult<IUser>>;
|
|
20
|
+
search(value: any): Promise<IUser[]>;
|
|
19
21
|
}
|
|
20
22
|
export default UserService;
|
|
21
23
|
//# sourceMappingURL=UserService.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserService.d.ts","sourceRoot":"","sources":["../../src/services/UserService.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,KAAK,EAAE,WAAW,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAC1E,OAAO,KAAK,EAAC,eAAe,EAAC,MAAM,+BAA+B,CAAC;AAMnE,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"UserService.d.ts","sourceRoot":"","sources":["../../src/services/UserService.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,KAAK,EAAE,WAAW,EAAE,WAAW,EAAC,MAAM,sBAAsB,CAAC;AAC1E,OAAO,KAAK,EAAC,eAAe,EAAC,MAAM,+BAA+B,CAAC;AAMnE,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAC3E,OAAO,EAAC,eAAe,EAAC,MAAM,iBAAiB,CAAC;AAGhD,cAAM,WAAY,SAAQ,eAAe,CAAC,KAAK,EAAE,WAAW,EAAE,WAAW,CAAC;IAEtE,WAAW,EAAE,eAAe,CAAA;gBAEhB,cAAc,EAAE,eAAe;IAMrC,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM;;;IAcvC,kBAAkB,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;IAYtD,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;IAuB9E,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IAW3C,MAAM,CAAC,QAAQ,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,CAAC;IAwB7C,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW;IAqBxC,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAcpC,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC;IAWpC,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;IAWvD,QAAQ,CAAC,EACI,IAAQ,EACR,KAAS,EACT,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;IAWtE,MAAM,CAAC,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;CAK7C;AAED,eAAe,WAAW,CAAA"}
|
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import {join} from "path";
|
|
2
|
-
import {StoreManager, UploadFileError, DraxConfig, CommonConfig, UnauthorizedError} from "@drax/common-back";
|
|
3
|
-
import UserServiceFactory from "../factory/UserServiceFactory.js";
|
|
4
|
-
import IdentityConfig from "../config/IdentityConfig.js";
|
|
5
|
-
|
|
6
|
-
const BASE_FILE_DIR = DraxConfig.getOrLoad(CommonConfig.FileDir) || 'files';
|
|
7
|
-
const AVATAR_DIR = DraxConfig.getOrLoad(IdentityConfig.AvatarDir) || 'avatar';
|
|
8
|
-
const BASE_URL = DraxConfig.getOrLoad(CommonConfig.BaseUrl) ? DraxConfig.get(CommonConfig.BaseUrl).replace(/\/$/, '') : ''
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
async function UserAvatarRoutes(fastify, options) {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
fastify.post('/api/user/avatar', async (request, reply): Promise<any> => {
|
|
15
|
-
try {
|
|
16
|
-
request.rbac.assertAuthenticated()
|
|
17
|
-
const userId = request.rbac.getAuthUser.id
|
|
18
|
-
|
|
19
|
-
const data = await request.file()
|
|
20
|
-
|
|
21
|
-
const file = {
|
|
22
|
-
filename: data.filename,
|
|
23
|
-
fileStream: data.file,
|
|
24
|
-
mimetype: data.mimetype
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
const destinationPath = join(BASE_FILE_DIR, AVATAR_DIR)
|
|
28
|
-
const storedFile = await StoreManager.saveFile(file, destinationPath)
|
|
29
|
-
const urlFile = BASE_URL + '/api/user/avatar/' + storedFile.filename
|
|
30
|
-
|
|
31
|
-
//Save into DB
|
|
32
|
-
const userService = UserServiceFactory()
|
|
33
|
-
await userService.changeAvatar(userId, urlFile)
|
|
34
|
-
|
|
35
|
-
return {
|
|
36
|
-
filename: storedFile.filename,
|
|
37
|
-
size: storedFile.size,
|
|
38
|
-
mimetype: storedFile.mimetype,
|
|
39
|
-
url: urlFile,
|
|
40
|
-
}
|
|
41
|
-
} catch (e) {
|
|
42
|
-
console.error(e)
|
|
43
|
-
if (e instanceof UploadFileError) {
|
|
44
|
-
reply.statusCode = e.statusCode
|
|
45
|
-
reply.send({error: e.message})
|
|
46
|
-
} else if (e instanceof UnauthorizedError) {
|
|
47
|
-
reply.statusCode = e.statusCode
|
|
48
|
-
reply.send({error: e.message})
|
|
49
|
-
} else {
|
|
50
|
-
reply.statusCode = 500
|
|
51
|
-
reply.send({error: 'INTERNAL_SERVER_ERROR'})
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
})
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
fastify.get('/api/user/avatar/:filename', async (request, reply): Promise<any> => {
|
|
59
|
-
try {
|
|
60
|
-
const filename = request.params.filename
|
|
61
|
-
const subPath = 'avatar'
|
|
62
|
-
const fileDir = join(BASE_FILE_DIR, subPath)
|
|
63
|
-
console.log("FILE_DIR: ",fileDir, " FILENAME:", filename)
|
|
64
|
-
return reply.sendFile(filename, fileDir)
|
|
65
|
-
} catch (e) {
|
|
66
|
-
console.error(e)
|
|
67
|
-
if (e instanceof UnauthorizedError) {
|
|
68
|
-
reply.statusCode = e.statusCode
|
|
69
|
-
reply.send({error: e.message})
|
|
70
|
-
} else {
|
|
71
|
-
reply.statusCode = 500
|
|
72
|
-
reply.send({error: 'INTERNAL_SERVER_ERROR'})
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
})
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
export default UserAvatarRoutes;
|
|
82
|
-
export {UserAvatarRoutes}
|