-
Notifications
You must be signed in to change notification settings - Fork 70
/
user-tenant.repository.ts
81 lines (75 loc) · 2.71 KB
/
user-tenant.repository.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
// Copyright (c) 2023 Sourcefuse Technologies
//
// This software is released under the MIT License.
// https://opensource.org/licenses/MIT
import {Getter, inject} from '@loopback/core';
import {
BelongsToAccessor,
Entity,
HasManyRepositoryFactory,
juggler,
repository,
} from '@loopback/repository';
import {DefaultSoftCrudRepository} from '@sourceloop/core';
import {
Role,
Tenant,
User,
UserLevelPermission,
UserTenant,
UserTenantRelations,
} from '../models';
import {AuthDbSourceName} from '../types';
import {RoleRepository} from './role.repository';
import {TenantRepository} from './tenant.repository';
import {UserLevelPermissionRepository} from './user-level-permission.repository';
import {UserRepository} from './user.repository';
export class UserTenantRepository extends DefaultSoftCrudRepository<
UserTenant,
typeof UserTenant.prototype.id,
UserTenantRelations
> {
public readonly tenant: BelongsToAccessor<
Tenant,
typeof UserTenant.prototype.id
>;
public readonly user: BelongsToAccessor<User, typeof UserTenant.prototype.id>;
public readonly role: BelongsToAccessor<Role, typeof UserTenant.prototype.id>;
public readonly userLevelPermissions: HasManyRepositoryFactory<
UserLevelPermission,
typeof UserTenant.prototype.id
>;
constructor(
@inject(`datasources.${AuthDbSourceName}`)
dataSource: juggler.DataSource,
@repository.getter('TenantRepository')
protected tenantRepositoryGetter: Getter<TenantRepository>,
@repository.getter('UserRepository')
protected userRepositoryGetter: Getter<UserRepository>,
@repository.getter('RoleRepository')
protected roleRepositoryGetter: Getter<RoleRepository>,
@repository.getter('UserLevelPermissionRepository')
protected userLevelPermissionRepositoryGetter: Getter<UserLevelPermissionRepository>,
@inject('models.UserTenant')
private readonly userTenant: typeof Entity & {prototype: UserTenant},
) {
super(userTenant, dataSource);
this.userLevelPermissions = this.createHasManyRepositoryFactoryFor(
'userLevelPermissions',
userLevelPermissionRepositoryGetter,
);
this.registerInclusionResolver(
'userLevelPermissions',
this.userLevelPermissions.inclusionResolver,
);
this.role = this.createBelongsToAccessorFor('role', roleRepositoryGetter);
this.registerInclusionResolver('role', this.role.inclusionResolver);
this.user = this.createBelongsToAccessorFor('user', userRepositoryGetter);
this.registerInclusionResolver('user', this.user.inclusionResolver);
this.tenant = this.createBelongsToAccessorFor(
'tenant',
tenantRepositoryGetter,
);
this.registerInclusionResolver('tenant', this.tenant.inclusionResolver);
}
}