@forklaunch/implementation-iam-base 0.6.2 → 0.6.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/lib/domain/schemas/index.d.mts +733 -334
- package/lib/domain/schemas/index.d.ts +733 -334
- package/lib/domain/schemas/index.js +90 -58
- package/lib/domain/schemas/index.mjs +40 -36
- package/lib/domain/types/index.d.mts +166 -71
- package/lib/domain/types/index.d.ts +166 -71
- package/lib/domain/types/index.js +8 -4
- package/lib/eject/services/permission.service.ts +4 -4
- package/lib/eject/services/user.service.ts +16 -30
- package/lib/services/index.d.mts +250 -81
- package/lib/services/index.d.ts +250 -81
- package/lib/services/index.js +196 -175
- package/lib/services/index.mjs +181 -173
- package/package.json +10 -10
|
@@ -31,7 +31,6 @@ export class BaseUserService<
|
|
|
31
31
|
tracing?: boolean;
|
|
32
32
|
};
|
|
33
33
|
public em: EntityManager;
|
|
34
|
-
protected passwordEncryptionPublicKeyPath: string;
|
|
35
34
|
protected roleServiceFactory: () => RoleService;
|
|
36
35
|
protected organizationServiceFactory: () => OrganizationService<OrganizationStatus>;
|
|
37
36
|
protected openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>;
|
|
@@ -40,7 +39,6 @@ export class BaseUserService<
|
|
|
40
39
|
|
|
41
40
|
constructor(
|
|
42
41
|
em: EntityManager,
|
|
43
|
-
passwordEncryptionPublicKeyPath: string,
|
|
44
42
|
roleServiceFactory: () => RoleService,
|
|
45
43
|
organizationServiceFactory: () => OrganizationService<OrganizationStatus>,
|
|
46
44
|
openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>,
|
|
@@ -51,7 +49,6 @@ export class BaseUserService<
|
|
|
51
49
|
}
|
|
52
50
|
) {
|
|
53
51
|
this.em = em;
|
|
54
|
-
this.passwordEncryptionPublicKeyPath = passwordEncryptionPublicKeyPath;
|
|
55
52
|
this.roleServiceFactory = roleServiceFactory;
|
|
56
53
|
this.organizationServiceFactory = organizationServiceFactory;
|
|
57
54
|
this.openTelemetryCollector = openTelemetryCollector;
|
|
@@ -222,40 +219,29 @@ export class BaseUserService<
|
|
|
222
219
|
await (em ?? this.em).nativeDelete('User', idsDto);
|
|
223
220
|
}
|
|
224
221
|
|
|
225
|
-
async
|
|
222
|
+
async surfaceRoles(
|
|
223
|
+
idDto: IdDto,
|
|
224
|
+
em?: EntityManager
|
|
225
|
+
): Promise<MapperDomains['UserMapper']['roles']> {
|
|
226
226
|
if (this.evaluatedTelemetryOptions.logging) {
|
|
227
|
-
this.openTelemetryCollector.info('
|
|
228
|
-
idDto
|
|
229
|
-
roleId
|
|
227
|
+
this.openTelemetryCollector.info('Surfacing user roles', {
|
|
228
|
+
idDto
|
|
230
229
|
});
|
|
231
230
|
}
|
|
232
|
-
const user = await this.getUser(idDto);
|
|
233
|
-
|
|
234
|
-
user.roles.filter((role) => {
|
|
235
|
-
return roleId == role.id;
|
|
236
|
-
}).length === 0
|
|
237
|
-
) {
|
|
238
|
-
throw new Error(`User ${idDto.id} does not have role ${roleId}`);
|
|
239
|
-
}
|
|
231
|
+
const user = await this.getUser(idDto, em);
|
|
232
|
+
return user.roles;
|
|
240
233
|
}
|
|
241
234
|
|
|
242
|
-
async
|
|
235
|
+
async surfacePermissions(
|
|
236
|
+
idDto: IdDto,
|
|
237
|
+
em?: EntityManager
|
|
238
|
+
): Promise<MapperDomains['UserMapper']['roles'][0]['permissions']> {
|
|
243
239
|
if (this.evaluatedTelemetryOptions.logging) {
|
|
244
|
-
this.openTelemetryCollector.info('
|
|
245
|
-
idDto
|
|
246
|
-
permissionId
|
|
240
|
+
this.openTelemetryCollector.info('Surfacing user permissions', {
|
|
241
|
+
idDto
|
|
247
242
|
});
|
|
248
243
|
}
|
|
249
|
-
const user = await this.getUser(idDto);
|
|
250
|
-
|
|
251
|
-
user.roles
|
|
252
|
-
.map((role) => role.permissions.map((permission) => permission.id))
|
|
253
|
-
.flat()
|
|
254
|
-
.filter((id) => id == permissionId).length === 0
|
|
255
|
-
) {
|
|
256
|
-
throw new Error(
|
|
257
|
-
`User ${idDto.id} does not have permission ${permissionId}`
|
|
258
|
-
);
|
|
259
|
-
}
|
|
244
|
+
const user = await this.getUser(idDto, em);
|
|
245
|
+
return user.roles.map((role) => role.permissions).flat();
|
|
260
246
|
}
|
|
261
247
|
}
|
package/lib/services/index.d.mts
CHANGED
|
@@ -1,94 +1,263 @@
|
|
|
1
1
|
import { IdDto, IdsDto } from '@forklaunch/common';
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
2
|
+
import {
|
|
3
|
+
OpenTelemetryCollector,
|
|
4
|
+
MetricsDefinition,
|
|
5
|
+
TelemetryOptions
|
|
6
|
+
} from '@forklaunch/core/http';
|
|
7
|
+
import {
|
|
8
|
+
OrganizationService,
|
|
9
|
+
PermissionService,
|
|
10
|
+
RoleService,
|
|
11
|
+
UserService
|
|
12
|
+
} from '@forklaunch/interfaces-iam/interfaces';
|
|
13
|
+
import {
|
|
14
|
+
CreateOrganizationDto,
|
|
15
|
+
UpdateOrganizationDto,
|
|
16
|
+
CreatePermissionDto,
|
|
17
|
+
UpdatePermissionDto,
|
|
18
|
+
CreateRoleDto,
|
|
19
|
+
RoleDto,
|
|
20
|
+
UpdateRoleDto,
|
|
21
|
+
CreateUserDto,
|
|
22
|
+
UpdateUserDto
|
|
23
|
+
} from '@forklaunch/interfaces-iam/types';
|
|
5
24
|
import { AnySchemaValidator } from '@forklaunch/validator';
|
|
6
25
|
import { EntityManager } from '@mikro-orm/core';
|
|
7
|
-
import {
|
|
26
|
+
import {
|
|
27
|
+
OrganizationEntities,
|
|
28
|
+
OrganizationDtos,
|
|
29
|
+
OrganizationMappers,
|
|
30
|
+
PermissionEntities,
|
|
31
|
+
PermissionDtos,
|
|
32
|
+
PermissionMappers,
|
|
33
|
+
RoleEntities,
|
|
34
|
+
RoleDtos,
|
|
35
|
+
RoleMappers,
|
|
36
|
+
UserEntities,
|
|
37
|
+
UserDtos,
|
|
38
|
+
UserMappers
|
|
39
|
+
} from '../domain/types/index.mjs';
|
|
8
40
|
import '@forklaunch/core/services';
|
|
9
41
|
|
|
10
|
-
declare class BaseOrganizationService<
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
42
|
+
declare class BaseOrganizationService<
|
|
43
|
+
SchemaValidator extends AnySchemaValidator,
|
|
44
|
+
OrganizationStatus = unknown,
|
|
45
|
+
MapperEntities extends
|
|
46
|
+
OrganizationEntities<OrganizationStatus> = OrganizationEntities<OrganizationStatus>,
|
|
47
|
+
MapperDomains extends
|
|
48
|
+
OrganizationDtos<OrganizationStatus> = OrganizationDtos<OrganizationStatus>
|
|
49
|
+
> implements OrganizationService<OrganizationStatus>
|
|
50
|
+
{
|
|
51
|
+
private evaluatedTelemetryOptions;
|
|
52
|
+
em: EntityManager;
|
|
53
|
+
protected openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>;
|
|
54
|
+
protected schemaValidator: SchemaValidator;
|
|
55
|
+
protected mappers: OrganizationMappers<
|
|
56
|
+
OrganizationStatus,
|
|
57
|
+
MapperEntities,
|
|
58
|
+
MapperDomains
|
|
59
|
+
>;
|
|
60
|
+
constructor(
|
|
61
|
+
em: EntityManager,
|
|
62
|
+
openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>,
|
|
63
|
+
schemaValidator: SchemaValidator,
|
|
64
|
+
mappers: OrganizationMappers<
|
|
65
|
+
OrganizationStatus,
|
|
66
|
+
MapperEntities,
|
|
67
|
+
MapperDomains
|
|
68
|
+
>,
|
|
69
|
+
options?: {
|
|
70
|
+
telemetry?: TelemetryOptions;
|
|
71
|
+
}
|
|
72
|
+
);
|
|
73
|
+
createOrganization(
|
|
74
|
+
organizationDto: CreateOrganizationDto,
|
|
75
|
+
em?: EntityManager,
|
|
76
|
+
...args: unknown[]
|
|
77
|
+
): Promise<MapperDomains['OrganizationMapper']>;
|
|
78
|
+
getOrganization(
|
|
79
|
+
idDto: IdDto,
|
|
80
|
+
em?: EntityManager
|
|
81
|
+
): Promise<MapperDomains['OrganizationMapper']>;
|
|
82
|
+
updateOrganization(
|
|
83
|
+
organizationDto: UpdateOrganizationDto,
|
|
84
|
+
em?: EntityManager,
|
|
85
|
+
...args: unknown[]
|
|
86
|
+
): Promise<MapperDomains['OrganizationMapper']>;
|
|
87
|
+
deleteOrganization(idDto: IdDto, em?: EntityManager): Promise<void>;
|
|
23
88
|
}
|
|
24
89
|
|
|
25
|
-
declare class BasePermissionService<
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
90
|
+
declare class BasePermissionService<
|
|
91
|
+
SchemaValidator extends AnySchemaValidator,
|
|
92
|
+
MapperEntities extends PermissionEntities = PermissionEntities,
|
|
93
|
+
MapperDomains extends PermissionDtos = PermissionDtos
|
|
94
|
+
> implements PermissionService
|
|
95
|
+
{
|
|
96
|
+
private evaluatedTelemetryOptions;
|
|
97
|
+
em: EntityManager;
|
|
98
|
+
protected roleServiceFactory: () => RoleService;
|
|
99
|
+
protected openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>;
|
|
100
|
+
protected schemaValidator: SchemaValidator;
|
|
101
|
+
protected mappers: PermissionMappers<MapperEntities, MapperDomains>;
|
|
102
|
+
constructor(
|
|
103
|
+
em: EntityManager,
|
|
104
|
+
roleServiceFactory: () => RoleService,
|
|
105
|
+
openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>,
|
|
106
|
+
schemaValidator: SchemaValidator,
|
|
107
|
+
mappers: PermissionMappers<MapperEntities, MapperDomains>,
|
|
108
|
+
options?: {
|
|
109
|
+
telemetry?: TelemetryOptions;
|
|
110
|
+
}
|
|
111
|
+
);
|
|
112
|
+
private updateRolesWithPermissions;
|
|
113
|
+
private removePermissionsFromRoles;
|
|
114
|
+
private getBatchRoles;
|
|
115
|
+
private createPermissionEntity;
|
|
116
|
+
private extractCreatePermissionEntityToEntityData;
|
|
117
|
+
createPermission(
|
|
118
|
+
createPermissionEntity: CreatePermissionDto,
|
|
119
|
+
em?: EntityManager,
|
|
120
|
+
...args: unknown[]
|
|
121
|
+
): Promise<MapperDomains['PermissionMapper']>;
|
|
122
|
+
createBatchPermissions(
|
|
123
|
+
permissionDtos: CreatePermissionDto[],
|
|
124
|
+
em?: EntityManager
|
|
125
|
+
): Promise<MapperDomains['PermissionMapper'][]>;
|
|
126
|
+
getPermission(
|
|
127
|
+
idDto: IdDto,
|
|
128
|
+
em?: EntityManager
|
|
129
|
+
): Promise<MapperDomains['PermissionMapper']>;
|
|
130
|
+
getBatchPermissions(
|
|
131
|
+
idsDto: IdsDto,
|
|
132
|
+
em?: EntityManager
|
|
133
|
+
): Promise<MapperDomains['PermissionMapper'][]>;
|
|
134
|
+
private updatePermissionDto;
|
|
135
|
+
updatePermission(
|
|
136
|
+
permissionDto: UpdatePermissionDto,
|
|
137
|
+
em?: EntityManager
|
|
138
|
+
): Promise<MapperDomains['PermissionMapper']>;
|
|
139
|
+
updateBatchPermissions(
|
|
140
|
+
permissionDtos: UpdatePermissionDto[],
|
|
141
|
+
em?: EntityManager
|
|
142
|
+
): Promise<MapperDomains['PermissionMapper'][]>;
|
|
143
|
+
deletePermission(idDto: IdDto, em?: EntityManager): Promise<void>;
|
|
144
|
+
deleteBatchPermissions(idsDto: IdsDto, em?: EntityManager): Promise<void>;
|
|
49
145
|
}
|
|
50
146
|
|
|
51
|
-
declare class BaseRoleService<
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
147
|
+
declare class BaseRoleService<
|
|
148
|
+
SchemaValidator extends AnySchemaValidator,
|
|
149
|
+
MapperEntities extends RoleEntities = RoleEntities,
|
|
150
|
+
MapperDomains extends RoleDtos = RoleDtos
|
|
151
|
+
> implements RoleService
|
|
152
|
+
{
|
|
153
|
+
private evaluatedTelemetryOptions;
|
|
154
|
+
em: EntityManager;
|
|
155
|
+
protected openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>;
|
|
156
|
+
protected schemaValidator: SchemaValidator;
|
|
157
|
+
protected mappers: RoleMappers<MapperEntities, MapperDomains>;
|
|
158
|
+
constructor(
|
|
159
|
+
em: EntityManager,
|
|
160
|
+
openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>,
|
|
161
|
+
schemaValidator: SchemaValidator,
|
|
162
|
+
mappers: RoleMappers<MapperEntities, MapperDomains>,
|
|
163
|
+
options?: {
|
|
164
|
+
telemetry?: TelemetryOptions;
|
|
165
|
+
}
|
|
166
|
+
);
|
|
167
|
+
createRole(
|
|
168
|
+
roleDto: CreateRoleDto,
|
|
169
|
+
em?: EntityManager,
|
|
170
|
+
...args: unknown[]
|
|
171
|
+
): Promise<RoleDto>;
|
|
172
|
+
createBatchRoles(
|
|
173
|
+
roleDtos: CreateRoleDto[],
|
|
174
|
+
em?: EntityManager,
|
|
175
|
+
...args: unknown[]
|
|
176
|
+
): Promise<RoleDto[]>;
|
|
177
|
+
getRole({ id }: IdDto, em?: EntityManager): Promise<RoleDto>;
|
|
178
|
+
getBatchRoles({ ids }: IdsDto, em?: EntityManager): Promise<RoleDto[]>;
|
|
179
|
+
updateRole(
|
|
180
|
+
roleDto: UpdateRoleDto,
|
|
181
|
+
em?: EntityManager,
|
|
182
|
+
...args: unknown[]
|
|
183
|
+
): Promise<RoleDto>;
|
|
184
|
+
updateBatchRoles(
|
|
185
|
+
roleDtos: UpdateRoleDto[],
|
|
186
|
+
em?: EntityManager,
|
|
187
|
+
...args: unknown[]
|
|
188
|
+
): Promise<RoleDto[]>;
|
|
189
|
+
deleteRole(idDto: IdDto, em?: EntityManager): Promise<void>;
|
|
190
|
+
deleteBatchRoles(idsDto: IdsDto, em?: EntityManager): Promise<void>;
|
|
68
191
|
}
|
|
69
192
|
|
|
70
|
-
declare class BaseUserService<
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
193
|
+
declare class BaseUserService<
|
|
194
|
+
SchemaValidator extends AnySchemaValidator,
|
|
195
|
+
OrganizationStatus = unknown,
|
|
196
|
+
MapperEntities extends UserEntities = UserEntities,
|
|
197
|
+
MapperDomains extends UserDtos = UserDtos
|
|
198
|
+
> implements UserService
|
|
199
|
+
{
|
|
200
|
+
private evaluatedTelemetryOptions;
|
|
201
|
+
em: EntityManager;
|
|
202
|
+
protected roleServiceFactory: () => RoleService;
|
|
203
|
+
protected organizationServiceFactory: () => OrganizationService<OrganizationStatus>;
|
|
204
|
+
protected openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>;
|
|
205
|
+
protected schemaValidator: SchemaValidator;
|
|
206
|
+
protected mappers: UserMappers<MapperEntities, MapperDomains>;
|
|
207
|
+
constructor(
|
|
208
|
+
em: EntityManager,
|
|
209
|
+
roleServiceFactory: () => RoleService,
|
|
210
|
+
organizationServiceFactory: () => OrganizationService<OrganizationStatus>,
|
|
211
|
+
openTelemetryCollector: OpenTelemetryCollector<MetricsDefinition>,
|
|
212
|
+
schemaValidator: SchemaValidator,
|
|
213
|
+
mappers: UserMappers<MapperEntities, MapperDomains>,
|
|
214
|
+
options?: {
|
|
215
|
+
telemetry?: TelemetryOptions;
|
|
216
|
+
}
|
|
217
|
+
);
|
|
218
|
+
createUser(
|
|
219
|
+
userDto: CreateUserDto,
|
|
220
|
+
em?: EntityManager,
|
|
221
|
+
...args: unknown[]
|
|
222
|
+
): Promise<MapperDomains['UserMapper']>;
|
|
223
|
+
createBatchUsers(
|
|
224
|
+
userDtos: CreateUserDto[],
|
|
225
|
+
em?: EntityManager,
|
|
226
|
+
...args: unknown[]
|
|
227
|
+
): Promise<MapperDomains['UserMapper'][]>;
|
|
228
|
+
getUser(
|
|
229
|
+
idDto: IdDto,
|
|
230
|
+
em?: EntityManager
|
|
231
|
+
): Promise<MapperDomains['UserMapper']>;
|
|
232
|
+
getBatchUsers(
|
|
233
|
+
idsDto: IdsDto,
|
|
234
|
+
em?: EntityManager
|
|
235
|
+
): Promise<MapperDomains['UserMapper'][]>;
|
|
236
|
+
updateUser(
|
|
237
|
+
userDto: UpdateUserDto,
|
|
238
|
+
em?: EntityManager,
|
|
239
|
+
...args: unknown[]
|
|
240
|
+
): Promise<MapperDomains['UserMapper']>;
|
|
241
|
+
updateBatchUsers(
|
|
242
|
+
userDtos: UpdateUserDto[],
|
|
243
|
+
em?: EntityManager,
|
|
244
|
+
...args: unknown[]
|
|
245
|
+
): Promise<MapperDomains['UserMapper'][]>;
|
|
246
|
+
deleteUser(idDto: IdDto, em?: EntityManager): Promise<void>;
|
|
247
|
+
deleteBatchUsers(idsDto: IdsDto, em?: EntityManager): Promise<void>;
|
|
248
|
+
surfaceRoles(
|
|
249
|
+
idDto: IdDto,
|
|
250
|
+
em?: EntityManager
|
|
251
|
+
): Promise<MapperDomains['UserMapper']['roles']>;
|
|
252
|
+
surfacePermissions(
|
|
253
|
+
idDto: IdDto,
|
|
254
|
+
em?: EntityManager
|
|
255
|
+
): Promise<MapperDomains['UserMapper']['roles'][0]['permissions']>;
|
|
92
256
|
}
|
|
93
257
|
|
|
94
|
-
export {
|
|
258
|
+
export {
|
|
259
|
+
BaseOrganizationService,
|
|
260
|
+
BasePermissionService,
|
|
261
|
+
BaseRoleService,
|
|
262
|
+
BaseUserService
|
|
263
|
+
};
|