@tomei/sso 0.8.11 → 0.8.12
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/.commitlintrc.json +22 -22
- package/.eslintrc +16 -16
- package/.eslintrc.js +35 -35
- package/.husky/commit-msg +15 -15
- package/.husky/pre-commit +7 -7
- package/.prettierrc +4 -4
- package/Jenkinsfile +57 -57
- package/README.md +23 -23
- package/__tests__/unit/components/login-user/login-user.spec.ts +734 -731
- package/__tests__/unit/components/password-hash/password-hash.service.spec.ts +32 -32
- package/__tests__/unit/redis-client/redis.service.spec.ts +23 -23
- package/__tests__/unit/session/session.service.spec.ts +47 -47
- package/create-sso-user.sql +39 -39
- package/dist/__tests__/unit/components/login-user/login-user.spec.d.ts +1 -0
- package/dist/__tests__/unit/components/login-user/login-user.spec.js +652 -0
- package/dist/__tests__/unit/components/login-user/login-user.spec.js.map +1 -1
- package/dist/__tests__/unit/components/password-hash/password-hash.service.spec.d.ts +1 -0
- package/dist/__tests__/unit/components/password-hash/password-hash.service.spec.js +37 -0
- package/dist/__tests__/unit/components/password-hash/password-hash.service.spec.js.map +1 -1
- package/dist/__tests__/unit/redis-client/redis.service.spec.d.ts +1 -1
- package/dist/__tests__/unit/redis-client/redis.service.spec.js +31 -31
- package/dist/__tests__/unit/session/session.service.spec.d.ts +1 -1
- package/dist/__tests__/unit/session/session.service.spec.js +54 -54
- package/dist/index.d.ts +1 -1
- package/dist/index.js +17 -17
- package/dist/src/components/index.d.ts +7 -7
- package/dist/src/components/index.js +23 -23
- package/dist/src/components/login-history/index.d.ts +1 -1
- package/dist/src/components/login-history/index.js +17 -17
- package/dist/src/components/login-history/login-history.repository.d.ts +5 -5
- package/dist/src/components/login-history/login-history.repository.js +11 -11
- package/dist/src/components/login-user/index.d.ts +3 -3
- package/dist/src/components/login-user/index.js +19 -19
- package/dist/src/components/login-user/interfaces/index.d.ts +1 -1
- package/dist/src/components/login-user/interfaces/index.js +17 -17
- package/dist/src/components/login-user/interfaces/user-info.interface.d.ts +9 -9
- package/dist/src/components/login-user/interfaces/user-info.interface.js +2 -2
- package/dist/src/components/login-user/login-user.d.ts +44 -44
- package/dist/src/components/login-user/login-user.js +416 -416
- package/dist/src/components/login-user/login-user.js.map +1 -1
- package/dist/src/components/login-user/user.repository.d.ts +5 -5
- package/dist/src/components/login-user/user.repository.js +11 -11
- package/dist/src/components/password-hash/index.d.ts +2 -2
- package/dist/src/components/password-hash/index.js +18 -18
- package/dist/src/components/password-hash/interfaces/index.d.ts +1 -1
- package/dist/src/components/password-hash/interfaces/index.js +17 -17
- package/dist/src/components/password-hash/interfaces/password-hash-service.interface.d.ts +4 -4
- package/dist/src/components/password-hash/interfaces/password-hash-service.interface.js +2 -2
- package/dist/src/components/password-hash/password-hash.service.d.ts +6 -6
- package/dist/src/components/password-hash/password-hash.service.js +27 -27
- package/dist/src/components/system/index.d.ts +1 -1
- package/dist/src/components/system/index.js +17 -17
- package/dist/src/components/system/system.repository.d.ts +5 -5
- package/dist/src/components/system/system.repository.js +11 -11
- package/dist/src/components/system-access/index.d.ts +1 -1
- package/dist/src/components/system-access/index.js +17 -17
- package/dist/src/components/system-access/system-access.repository.d.ts +5 -5
- package/dist/src/components/system-access/system-access.repository.js +11 -11
- package/dist/src/components/user-group/index.d.ts +1 -1
- package/dist/src/components/user-group/index.js +17 -17
- package/dist/src/components/user-group/user-group.repository.d.ts +5 -5
- package/dist/src/components/user-group/user-group.repository.js +11 -11
- package/dist/src/components/user-user-group/index.d.ts +1 -1
- package/dist/src/components/user-user-group/index.js +17 -17
- package/dist/src/components/user-user-group/user-user-group.repository.d.ts +5 -5
- package/dist/src/components/user-user-group/user-user-group.repository.js +11 -11
- package/dist/src/database.d.ts +4 -4
- package/dist/src/database.js +14 -14
- package/dist/src/index.d.ts +5 -5
- package/dist/src/index.js +23 -23
- package/dist/src/interfaces/index.d.ts +2 -2
- package/dist/src/interfaces/index.js +18 -18
- package/dist/src/interfaces/system-login.interface.d.ts +6 -6
- package/dist/src/interfaces/system-login.interface.js +2 -2
- package/dist/src/interfaces/user-session.interface.d.ts +4 -4
- package/dist/src/interfaces/user-session.interface.js +2 -2
- package/dist/src/models/authorization-code.entity.d.ts +14 -14
- package/dist/src/models/authorization-code.entity.js +85 -85
- package/dist/src/models/bearer-token.entity.d.ts +11 -11
- package/dist/src/models/bearer-token.entity.js +71 -71
- package/dist/src/models/building-type.entity.d.ts +7 -7
- package/dist/src/models/building-type.entity.js +49 -49
- package/dist/src/models/building.entity.d.ts +39 -39
- package/dist/src/models/building.entity.js +250 -250
- package/dist/src/models/city.entity.d.ts +11 -11
- package/dist/src/models/city.entity.js +71 -71
- package/dist/src/models/company.entity.d.ts +18 -18
- package/dist/src/models/company.entity.js +113 -113
- package/dist/src/models/country.entity.d.ts +15 -15
- package/dist/src/models/country.entity.js +91 -91
- package/dist/src/models/department.entity.d.ts +19 -19
- package/dist/src/models/department.entity.js +111 -111
- package/dist/src/models/group-role-privilege.entity.d.ts +17 -17
- package/dist/src/models/group-role-privilege.entity.js +89 -89
- package/dist/src/models/group-system-access.entity.d.ts +11 -11
- package/dist/src/models/group-system-access.entity.js +61 -61
- package/dist/src/models/group-system-privilege.entity.d.ts +11 -11
- package/dist/src/models/group-system-privilege.entity.js +61 -61
- package/dist/src/models/group-system-role.entity.d.ts +11 -11
- package/dist/src/models/group-system-role.entity.js +61 -61
- package/dist/src/models/login-history.entity.d.ts +12 -12
- package/dist/src/models/login-history.entity.js +69 -69
- package/dist/src/models/oauth-token.entity.d.ts +14 -14
- package/dist/src/models/oauth-token.entity.js +85 -85
- package/dist/src/models/role.entity.d.ts +17 -17
- package/dist/src/models/role.entity.js +101 -101
- package/dist/src/models/staff-type.entity.d.ts +7 -7
- package/dist/src/models/staff-type.entity.js +49 -49
- package/dist/src/models/staff.entity.d.ts +39 -39
- package/dist/src/models/staff.entity.js +249 -249
- package/dist/src/models/state.entity.d.ts +10 -10
- package/dist/src/models/state.entity.js +63 -63
- package/dist/src/models/system-accesss.entity.d.ts +6 -6
- package/dist/src/models/system-accesss.entity.js +50 -50
- package/dist/src/models/system-privilege.entity.d.ts +16 -16
- package/dist/src/models/system-privilege.entity.js +89 -89
- package/dist/src/models/system-role-privilege.entity.d.ts +11 -11
- package/dist/src/models/system-role-privilege.entity.js +59 -59
- package/dist/src/models/system-role.entity.d.ts +11 -11
- package/dist/src/models/system-role.entity.js +82 -82
- package/dist/src/models/system.entity.d.ts +19 -19
- package/dist/src/models/system.entity.js +145 -145
- package/dist/src/models/user-group.entity.d.ts +23 -23
- package/dist/src/models/user-group.entity.js +139 -139
- package/dist/src/models/user-role.entity.d.ts +12 -12
- package/dist/src/models/user-role.entity.js +72 -72
- package/dist/src/models/user-system-privileges.entity.d.ts +13 -13
- package/dist/src/models/user-system-privileges.entity.js +88 -88
- package/dist/src/models/user-system-role.entity.d.ts +11 -11
- package/dist/src/models/user-system-role.entity.js +59 -59
- package/dist/src/models/user-user-group.entity.d.ts +14 -14
- package/dist/src/models/user-user-group.entity.js +72 -72
- package/dist/src/models/user.entity.d.ts +30 -30
- package/dist/src/models/user.entity.js +130 -130
- package/dist/src/redis-client/__mocks__/jest-initial-setup.d.ts +1 -1
- package/dist/src/redis-client/__mocks__/jest-initial-setup.js +4 -4
- package/dist/src/redis-client/__mocks__/redis-mock.d.ts +2 -2
- package/dist/src/redis-client/__mocks__/redis-mock.js +22 -22
- package/dist/src/redis-client/index.d.ts +1 -1
- package/dist/src/redis-client/index.js +17 -17
- package/dist/src/redis-client/redis.service.d.ts +7 -7
- package/dist/src/redis-client/redis.service.js +55 -55
- package/dist/src/session/index.d.ts +2 -2
- package/dist/src/session/index.js +18 -18
- package/dist/src/session/interfaces/index.d.ts +1 -1
- package/dist/src/session/interfaces/index.js +17 -17
- package/dist/src/session/interfaces/session-service.interface.d.ts +6 -6
- package/dist/src/session/interfaces/session-service.interface.js +2 -2
- package/dist/src/session/session.service.d.ts +10 -10
- package/dist/src/session/session.service.js +63 -63
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/jest.config.js +13 -14
- package/migrations/01-alter-system-privilege-table.js +13 -13
- package/migrations/02-alter-user-group-table.js +78 -78
- package/migrations/03-alter-user-system-privilege-table.js +38 -38
- package/migrations/04-create-user-user-group-table.js +55 -55
- package/migrations/05-create-login-history-table.js +49 -49
- package/package.json +77 -77
- package/sampledotenv +7 -7
- package/src/components/login-user/login-user.ts +6 -4
- package/tsconfig.build.json +5 -5
- package/tsconfig.json +23 -23
- package/__tests__/unit/components/login-history/login-history.repository.spec.ts +0 -95
- package/__tests__/unit/components/login-user/user.repository.spec.ts +0 -81
- package/__tests__/unit/components/system/system.repository.spec.ts +0 -88
- package/__tests__/unit/components/system-access/system-access.repository.spec.ts +0 -78
- package/dist/__tests__/unit/components/login-history/login-history.repository.spec.d.ts +0 -0
- package/dist/__tests__/unit/components/login-history/login-history.repository.spec.js +0 -1
- package/dist/__tests__/unit/components/login-history/login-history.repository.spec.js.map +0 -1
- package/dist/__tests__/unit/components/login-user/user.repository.spec.d.ts +0 -0
- package/dist/__tests__/unit/components/login-user/user.repository.spec.js +0 -1
- package/dist/__tests__/unit/components/login-user/user.repository.spec.js.map +0 -1
- package/dist/__tests__/unit/components/system/system.repository.spec.d.ts +0 -0
- package/dist/__tests__/unit/components/system/system.repository.spec.js +0 -1
- package/dist/__tests__/unit/components/system/system.repository.spec.js.map +0 -1
- package/dist/__tests__/unit/components/system-access/system-access.repository.spec.d.ts +0 -0
- package/dist/__tests__/unit/components/system-access/system-access.repository.spec.js +0 -1
- package/dist/__tests__/unit/components/system-access/system-access.repository.spec.js.map +0 -1
- package/dist/src/prisma-client/__mocks__/prisma.d.ts +0 -3
- package/dist/src/prisma-client/__mocks__/prisma.js +0 -14
- package/dist/src/prisma-client/__mocks__/prisma.js.map +0 -1
- package/dist/src/prisma-client/client.d.ts +0 -3
- package/dist/src/prisma-client/client.js +0 -6
- package/dist/src/prisma-client/client.js.map +0 -1
- package/dist/src/prisma-client/index.d.ts +0 -1
- package/dist/src/prisma-client/index.js +0 -18
- package/dist/src/prisma-client/index.js.map +0 -1
package/sampledotenv
CHANGED
@@ -1,8 +1,8 @@
|
|
1
|
-
DATABASE_URL=
|
2
|
-
SHADOW_DATABASE_URL=
|
3
|
-
REDIS_URL=
|
4
|
-
REDIS_PASSWORD=
|
5
|
-
SMTP_HOST=
|
6
|
-
SMTP_PORT=
|
7
|
-
EMAIL_SENDER=
|
1
|
+
DATABASE_URL=
|
2
|
+
SHADOW_DATABASE_URL=
|
3
|
+
REDIS_URL=
|
4
|
+
REDIS_PASSWORD=
|
5
|
+
SMTP_HOST=
|
6
|
+
SMTP_PORT=
|
7
|
+
EMAIL_SENDER=
|
8
8
|
EMAIL_PASSWORD=
|
@@ -107,7 +107,7 @@ export class LoginUser extends LoginUserBase {
|
|
107
107
|
FullName: user.Staff.FullName,
|
108
108
|
IDNo: user.Staff.IdNo,
|
109
109
|
ContactNo: user.Staff.Mobile,
|
110
|
-
Email: user.
|
110
|
+
Email: user.Email,
|
111
111
|
Password: user.Password,
|
112
112
|
staffs: user.Staff,
|
113
113
|
};
|
@@ -128,9 +128,7 @@ export class LoginUser extends LoginUserBase {
|
|
128
128
|
): Promise<string> {
|
129
129
|
try {
|
130
130
|
//validate email
|
131
|
-
if (this.ObjectId
|
132
|
-
throw new Error('Invalid credentials.');
|
133
|
-
} else {
|
131
|
+
if (!this.ObjectId) {
|
134
132
|
const user = await LoginUser._Repository.findOne({
|
135
133
|
where: {
|
136
134
|
Email: email,
|
@@ -161,6 +159,10 @@ export class LoginUser extends LoginUserBase {
|
|
161
159
|
this.staffs = userInfo.staffs;
|
162
160
|
}
|
163
161
|
|
162
|
+
if (this.ObjectId && this.Email !== email) {
|
163
|
+
throw new Error('Invalid credentials.');
|
164
|
+
}
|
165
|
+
|
164
166
|
//validate password
|
165
167
|
const isPasswordValid = await this._PasswordHashService.verify(
|
166
168
|
password,
|
package/tsconfig.build.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
|
-
{
|
2
|
-
"extends": "./tsconfig.json",
|
3
|
-
"include": ["**/*.ts"],
|
4
|
-
"exclude": ["node_modules", "__test__", "dist", "**/*spec.ts"]
|
5
|
-
}
|
1
|
+
{
|
2
|
+
"extends": "./tsconfig.json",
|
3
|
+
"include": ["**/*.ts"],
|
4
|
+
"exclude": ["node_modules", "__test__", "dist", "**/*spec.ts"]
|
5
|
+
}
|
6
6
|
|
package/tsconfig.json
CHANGED
@@ -1,23 +1,23 @@
|
|
1
|
-
{
|
2
|
-
"compilerOptions": {
|
3
|
-
"module": "commonjs",
|
4
|
-
"declaration": true,
|
5
|
-
"removeComments": true,
|
6
|
-
"emitDecoratorMetadata": true,
|
7
|
-
"experimentalDecorators": true,
|
8
|
-
"allowSyntheticDefaultImports": true,
|
9
|
-
"moduleResolution": "node",
|
10
|
-
"target": "es6",
|
11
|
-
"sourceMap": true,
|
12
|
-
"outDir": "./dist",
|
13
|
-
"baseUrl": "./src",
|
14
|
-
"rootDir": "./",
|
15
|
-
"incremental": true,
|
16
|
-
"skipLibCheck": true,
|
17
|
-
"noImplicitAny": false,
|
18
|
-
"strictBindCallApply": false,
|
19
|
-
"forceConsistentCasingInFileNames": false,
|
20
|
-
"noFallthroughCasesInSwitch": false,
|
21
|
-
"strictNullChecks": true,
|
22
|
-
},
|
23
|
-
}
|
1
|
+
{
|
2
|
+
"compilerOptions": {
|
3
|
+
"module": "commonjs",
|
4
|
+
"declaration": true,
|
5
|
+
"removeComments": true,
|
6
|
+
"emitDecoratorMetadata": true,
|
7
|
+
"experimentalDecorators": true,
|
8
|
+
"allowSyntheticDefaultImports": true,
|
9
|
+
"moduleResolution": "node",
|
10
|
+
"target": "es6",
|
11
|
+
"sourceMap": true,
|
12
|
+
"outDir": "./dist",
|
13
|
+
"baseUrl": "./src",
|
14
|
+
"rootDir": "./",
|
15
|
+
"incremental": true,
|
16
|
+
"skipLibCheck": true,
|
17
|
+
"noImplicitAny": false,
|
18
|
+
"strictBindCallApply": false,
|
19
|
+
"forceConsistentCasingInFileNames": false,
|
20
|
+
"noFallthroughCasesInSwitch": false,
|
21
|
+
"strictNullChecks": true,
|
22
|
+
},
|
23
|
+
}
|
@@ -1,95 +0,0 @@
|
|
1
|
-
// import { LoginHistory } from '@prisma/client';
|
2
|
-
// import { LoginHistoryRepository } from '../../../../src/components/login-history/login-history.repository';
|
3
|
-
// import { prismaMock } from '../../../../src/prisma-client/__mocks__/prisma';
|
4
|
-
|
5
|
-
// describe('login-history.repository', () => {
|
6
|
-
// afterEach(() => {
|
7
|
-
// jest.restoreAllMocks()
|
8
|
-
// })
|
9
|
-
// describe('findAll', () => {
|
10
|
-
// it('should return list of login history', async () => {
|
11
|
-
// const data = [{
|
12
|
-
// userId: 1,
|
13
|
-
// systemId: 1,
|
14
|
-
// originIp: '1.1.1.1',
|
15
|
-
// createdAt: new Date(),
|
16
|
-
// }]
|
17
|
-
// prismaMock.loginHistory.findMany.mockResolvedValueOnce(data as LoginHistory[])
|
18
|
-
// const loginHistoryRepository = new LoginHistoryRepository()
|
19
|
-
// expect(await loginHistoryRepository.findAll({})).toEqual(data)
|
20
|
-
// })
|
21
|
-
// })
|
22
|
-
|
23
|
-
// describe('findOne', () => {
|
24
|
-
// it('should return login history', async () => {
|
25
|
-
// const data = {
|
26
|
-
// userId: 1,
|
27
|
-
// systemId: 1,
|
28
|
-
// originIp: '1.1.1.1',
|
29
|
-
// createdAt: new Date(),
|
30
|
-
// }
|
31
|
-
// prismaMock.loginHistory.findFirst.mockResolvedValueOnce(data as LoginHistory)
|
32
|
-
// const loginHistoryRepository = new LoginHistoryRepository()
|
33
|
-
// expect(await loginHistoryRepository.findOne({
|
34
|
-
// where: {
|
35
|
-
// userId_systemId: {
|
36
|
-
// userId: data.userId,
|
37
|
-
// systemId: data.systemId,
|
38
|
-
// },
|
39
|
-
// },
|
40
|
-
// })).toEqual(data)
|
41
|
-
// })
|
42
|
-
// })
|
43
|
-
|
44
|
-
// describe('create', () => {
|
45
|
-
// it('should create login history', async () => {
|
46
|
-
// const data = {
|
47
|
-
// userId: 1,
|
48
|
-
// systemId: 1,
|
49
|
-
// originIp: '1.1.1.1',
|
50
|
-
// createdAt: new Date(),
|
51
|
-
// }
|
52
|
-
// prismaMock.loginHistory.create.mockResolvedValueOnce(data as LoginHistory)
|
53
|
-
// const loginHistoryRepository = new LoginHistoryRepository()
|
54
|
-
// expect(await loginHistoryRepository.create({data})).toEqual(data)
|
55
|
-
// })
|
56
|
-
// })
|
57
|
-
|
58
|
-
// describe('update', () => {
|
59
|
-
// it('should update login history', async () => {
|
60
|
-
// const data = {
|
61
|
-
// userId: 1,
|
62
|
-
// systemId: 1,
|
63
|
-
// originIp: '1.1.1.1',
|
64
|
-
// createdAt: new Date(),
|
65
|
-
// }
|
66
|
-
// prismaMock.loginHistory.update.mockResolvedValueOnce(data as LoginHistory)
|
67
|
-
// const loginHistoryRepository = new LoginHistoryRepository()
|
68
|
-
// expect(await loginHistoryRepository.update({
|
69
|
-
// where: {
|
70
|
-
// userId: data.userId
|
71
|
-
// }, data: data
|
72
|
-
// }, data)).toEqual(data)
|
73
|
-
// })
|
74
|
-
// })
|
75
|
-
|
76
|
-
// describe('delete', () => {
|
77
|
-
// it('should delete login history', async () => {
|
78
|
-
// const data = {
|
79
|
-
// userId: 1,
|
80
|
-
// systemId: 1,
|
81
|
-
// originIp: '1.1.1.1',
|
82
|
-
// createdAt: new Date(),
|
83
|
-
// }
|
84
|
-
// prismaMock.loginHistory.delete.mockResolvedValueOnce(data as LoginHistory)
|
85
|
-
// const loginHistoryRepository = new LoginHistoryRepository()
|
86
|
-
// expect(await loginHistoryRepository.delete({
|
87
|
-
// where: {
|
88
|
-
// userId: data.userId
|
89
|
-
// }
|
90
|
-
// })).toEqual(data)
|
91
|
-
// })
|
92
|
-
// })
|
93
|
-
|
94
|
-
// })
|
95
|
-
|
@@ -1,81 +0,0 @@
|
|
1
|
-
// import { UserRepository } from '../../../../src/components/login-user/user.repository';
|
2
|
-
// import { prismaMock } from '../../../../src/prisma-client/__mocks__/prisma';
|
3
|
-
|
4
|
-
// describe('system-access.repository', () => {
|
5
|
-
// const data = {
|
6
|
-
// id: 1,
|
7
|
-
// email: 'test@test.email.com',
|
8
|
-
// password: '@H34f5yRE',
|
9
|
-
// status: 'Active',
|
10
|
-
// defaultPasswordChanged: false,
|
11
|
-
// firstLoginAt: new Date(),
|
12
|
-
// createdAt: new Date(),
|
13
|
-
// updatedAt: new Date(),
|
14
|
-
// groupCode: 'RDAS',
|
15
|
-
// };
|
16
|
-
|
17
|
-
// afterEach(() => {
|
18
|
-
// jest.restoreAllMocks();
|
19
|
-
// });
|
20
|
-
// describe('findAll', () => {
|
21
|
-
// it('should return list of user', async () => {
|
22
|
-
// prismaMock.user.findMany.mockResolvedValueOnce([data]);
|
23
|
-
// const userRepository = new UserRepository();
|
24
|
-
// expect(await userRepository.findAll({})).toEqual([data]);
|
25
|
-
// });
|
26
|
-
// });
|
27
|
-
|
28
|
-
// describe('findOne', () => {
|
29
|
-
// it('should return user', async () => {
|
30
|
-
// prismaMock.user.findFirst.mockResolvedValueOnce(data);
|
31
|
-
// const userRepository = new UserRepository();
|
32
|
-
// expect(
|
33
|
-
// await userRepository.findOne({
|
34
|
-
// where: {
|
35
|
-
// id: data.id,
|
36
|
-
// },
|
37
|
-
// }),
|
38
|
-
// ).toEqual(data);
|
39
|
-
// });
|
40
|
-
// });
|
41
|
-
|
42
|
-
// describe('create', () => {
|
43
|
-
// it('should create user', async () => {
|
44
|
-
// prismaMock.user.create.mockResolvedValueOnce(data);
|
45
|
-
// const userRepository = new UserRepository();
|
46
|
-
// expect(await userRepository.create(data)).toEqual(data);
|
47
|
-
// });
|
48
|
-
// });
|
49
|
-
|
50
|
-
// describe('update', () => {
|
51
|
-
// it('should update user', async () => {
|
52
|
-
// prismaMock.user.update.mockResolvedValueOnce(data);
|
53
|
-
// const userRepository = new UserRepository();
|
54
|
-
// expect(
|
55
|
-
// await userRepository.update(
|
56
|
-
// {
|
57
|
-
// where: {
|
58
|
-
// id: data.id,
|
59
|
-
// },
|
60
|
-
// data: data,
|
61
|
-
// },
|
62
|
-
// data,
|
63
|
-
// ),
|
64
|
-
// ).toEqual(data);
|
65
|
-
// });
|
66
|
-
// });
|
67
|
-
|
68
|
-
// describe('delete', () => {
|
69
|
-
// it('should delete user', async () => {
|
70
|
-
// prismaMock.user.delete.mockResolvedValueOnce(data);
|
71
|
-
// const userRepository = new UserRepository();
|
72
|
-
// expect(
|
73
|
-
// await userRepository.delete({
|
74
|
-
// where: {
|
75
|
-
// id: data.id,
|
76
|
-
// },
|
77
|
-
// }),
|
78
|
-
// ).toEqual(data);
|
79
|
-
// });
|
80
|
-
// });
|
81
|
-
// });
|
@@ -1,88 +0,0 @@
|
|
1
|
-
// import { SystemRepository } from '../../../../src/components/system/system.repository';
|
2
|
-
// import { prismaMock } from '../../../../src/prisma-client/__mocks__/prisma';
|
3
|
-
|
4
|
-
// describe('system.repository', () => {
|
5
|
-
// const data = {
|
6
|
-
// id: 175,
|
7
|
-
// code: 'EZC',
|
8
|
-
// name: 'EzCash',
|
9
|
-
// description: 'Tomei Money Lending System',
|
10
|
-
// accessUrl: 'https://app.ezcash.com.my:22443/staff/login',
|
11
|
-
// googlePlayUrl: '',
|
12
|
-
// appleStoreUrl: '',
|
13
|
-
// apiKey: 'f3fef257jt',
|
14
|
-
// logo: 'https://sso-api.tomei.com.my/upload/2023/01/10/FJ3DoHdRZKjf2bGkgA4E-BrowserIcon.png',
|
15
|
-
// status: 'active',
|
16
|
-
// visible: true,
|
17
|
-
// createdAt: new Date(),
|
18
|
-
// updatedAt: new Date(),
|
19
|
-
// apiSecret: '12345',
|
20
|
-
// updatedById: 61,
|
21
|
-
// createdById: 100,
|
22
|
-
// };
|
23
|
-
|
24
|
-
// afterEach(() => {
|
25
|
-
// jest.restoreAllMocks();
|
26
|
-
// });
|
27
|
-
// describe('findAll', () => {
|
28
|
-
// it('should return list of system', async () => {
|
29
|
-
// prismaMock.system.findMany.mockResolvedValueOnce([data]);
|
30
|
-
// const systemRepository = new SystemRepository();
|
31
|
-
// expect(await systemRepository.findAll({})).toEqual([data]);
|
32
|
-
// });
|
33
|
-
// });
|
34
|
-
|
35
|
-
// describe('findOne', () => {
|
36
|
-
// it('should return system', async () => {
|
37
|
-
// prismaMock.system.findFirst.mockResolvedValueOnce(data);
|
38
|
-
// const systemRepository = new SystemRepository();
|
39
|
-
// expect(
|
40
|
-
// await systemRepository.findOne({
|
41
|
-
// where: {
|
42
|
-
// id: data.id,
|
43
|
-
// },
|
44
|
-
// }),
|
45
|
-
// ).toEqual(data);
|
46
|
-
// });
|
47
|
-
// });
|
48
|
-
|
49
|
-
// describe('create', () => {
|
50
|
-
// it('should create system', async () => {
|
51
|
-
// prismaMock.system.create.mockResolvedValueOnce(data);
|
52
|
-
// const systemRepository = new SystemRepository();
|
53
|
-
// expect(await systemRepository.create(data)).toEqual(data);
|
54
|
-
// });
|
55
|
-
// });
|
56
|
-
|
57
|
-
// describe('update', () => {
|
58
|
-
// it('should update system', async () => {
|
59
|
-
// prismaMock.system.update.mockResolvedValueOnce(data);
|
60
|
-
// const systemRepository = new SystemRepository();
|
61
|
-
// expect(
|
62
|
-
// await systemRepository.update(
|
63
|
-
// {
|
64
|
-
// where: {
|
65
|
-
// id: data.id,
|
66
|
-
// },
|
67
|
-
// data: data,
|
68
|
-
// },
|
69
|
-
// data,
|
70
|
-
// ),
|
71
|
-
// ).toEqual(data);
|
72
|
-
// });
|
73
|
-
// });
|
74
|
-
|
75
|
-
// describe('delete', () => {
|
76
|
-
// it('should delete system', async () => {
|
77
|
-
// prismaMock.system.delete.mockResolvedValueOnce(data);
|
78
|
-
// const systemRepository = new SystemRepository();
|
79
|
-
// expect(
|
80
|
-
// await systemRepository.delete({
|
81
|
-
// where: {
|
82
|
-
// id: data.id,
|
83
|
-
// },
|
84
|
-
// }),
|
85
|
-
// ).toEqual(data);
|
86
|
-
// });
|
87
|
-
// });
|
88
|
-
// });
|
@@ -1,78 +0,0 @@
|
|
1
|
-
// import { SystemAccessRepository } from '../../../../src/components/system-access/system-access.repository';
|
2
|
-
// import { prismaMock } from '../../../../src/prisma-client/__mocks__/prisma';
|
3
|
-
|
4
|
-
// describe('system-access.repository', () => {
|
5
|
-
// const data = {
|
6
|
-
// userId: 1,
|
7
|
-
// systemId: 175,
|
8
|
-
// updatedAt: new Date(),
|
9
|
-
// };
|
10
|
-
|
11
|
-
// afterEach(() => {
|
12
|
-
// jest.restoreAllMocks();
|
13
|
-
// });
|
14
|
-
// describe('findAll', () => {
|
15
|
-
// it('should return list of system access', async () => {
|
16
|
-
// prismaMock.systemAccess.findMany.mockResolvedValueOnce([data]);
|
17
|
-
// const systemAccessRepository = new SystemAccessRepository();
|
18
|
-
// expect(await systemAccessRepository.findAll({})).toEqual([data]);
|
19
|
-
// });
|
20
|
-
// });
|
21
|
-
|
22
|
-
// describe('findOne', () => {
|
23
|
-
// it('should return system access', async () => {
|
24
|
-
// prismaMock.systemAccess.findFirst.mockResolvedValueOnce(data);
|
25
|
-
// const systemAccessRepository = new SystemAccessRepository();
|
26
|
-
// expect(
|
27
|
-
// await systemAccessRepository.findOne({
|
28
|
-
// where: {
|
29
|
-
// userId: data.userId,
|
30
|
-
// systemId: data.systemId,
|
31
|
-
// },
|
32
|
-
// }),
|
33
|
-
// ).toEqual(data);
|
34
|
-
// });
|
35
|
-
// });
|
36
|
-
|
37
|
-
// describe('create', () => {
|
38
|
-
// it('should create system access', async () => {
|
39
|
-
// prismaMock.systemAccess.create.mockResolvedValueOnce(data);
|
40
|
-
// const systemAccessRepository = new SystemAccessRepository();
|
41
|
-
// expect(await systemAccessRepository.create(data)).toEqual(data);
|
42
|
-
// });
|
43
|
-
// });
|
44
|
-
|
45
|
-
// describe('update', () => {
|
46
|
-
// it('should update system access', async () => {
|
47
|
-
// prismaMock.systemAccess.update.mockResolvedValueOnce(data);
|
48
|
-
// const systemAccessRepository = new SystemAccessRepository();
|
49
|
-
// expect(
|
50
|
-
// await systemAccessRepository.update(
|
51
|
-
// {
|
52
|
-
// where: {
|
53
|
-
// userId: data.userId,
|
54
|
-
// systemId: data.systemId,
|
55
|
-
// },
|
56
|
-
// data: data,
|
57
|
-
// },
|
58
|
-
// data,
|
59
|
-
// ),
|
60
|
-
// ).toEqual(data);
|
61
|
-
// });
|
62
|
-
// });
|
63
|
-
|
64
|
-
// describe('delete', () => {
|
65
|
-
// it('should delete system access', async () => {
|
66
|
-
// prismaMock.systemAccess.delete.mockResolvedValueOnce(data);
|
67
|
-
// const systemAccessRepository = new SystemAccessRepository();
|
68
|
-
// expect(
|
69
|
-
// await systemAccessRepository.delete({
|
70
|
-
// where: {
|
71
|
-
// userId: data.userId,
|
72
|
-
// systemId: data.systemId,
|
73
|
-
// },
|
74
|
-
// }),
|
75
|
-
// ).toEqual(data);
|
76
|
-
// });
|
77
|
-
// });
|
78
|
-
// });
|
File without changes
|
@@ -1 +0,0 @@
|
|
1
|
-
//# sourceMappingURL=login-history.repository.spec.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"login-history.repository.spec.js","sourceRoot":"","sources":["../../../../../__tests__/unit/components/login-history/login-history.repository.spec.ts"],"names":[],"mappings":""}
|
File without changes
|
@@ -1 +0,0 @@
|
|
1
|
-
//# sourceMappingURL=user.repository.spec.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"user.repository.spec.js","sourceRoot":"","sources":["../../../../../__tests__/unit/components/login-user/user.repository.spec.ts"],"names":[],"mappings":""}
|
File without changes
|
@@ -1 +0,0 @@
|
|
1
|
-
//# sourceMappingURL=system.repository.spec.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"system.repository.spec.js","sourceRoot":"","sources":["../../../../../__tests__/unit/components/system/system.repository.spec.ts"],"names":[],"mappings":""}
|
File without changes
|
@@ -1 +0,0 @@
|
|
1
|
-
//# sourceMappingURL=system-access.repository.spec.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"system-access.repository.spec.js","sourceRoot":"","sources":["../../../../../__tests__/unit/components/system-access/system-access.repository.spec.ts"],"names":[],"mappings":""}
|
@@ -1,3 +0,0 @@
|
|
1
|
-
import { PrismaClient } from '@prisma/client';
|
2
|
-
import { DeepMockProxy } from 'jest-mock-extended';
|
3
|
-
export declare const prismaMock: DeepMockProxy<PrismaClient<import(".prisma/client").Prisma.PrismaClientOptions, never, import(".prisma/client").Prisma.RejectOnNotFound | import(".prisma/client").Prisma.RejectPerOperation | undefined>>;
|
@@ -1,14 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.prismaMock = void 0;
|
4
|
-
const jest_mock_extended_1 = require("jest-mock-extended");
|
5
|
-
const client_1 = require("../client");
|
6
|
-
jest.mock('../client', () => ({
|
7
|
-
__esModule: true,
|
8
|
-
default: (0, jest_mock_extended_1.mockDeep)(),
|
9
|
-
}));
|
10
|
-
beforeEach(() => {
|
11
|
-
(0, jest_mock_extended_1.mockReset)(exports.prismaMock);
|
12
|
-
});
|
13
|
-
exports.prismaMock = client_1.default;
|
14
|
-
//# sourceMappingURL=prisma.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"prisma.js","sourceRoot":"","sources":["../../../../src/prisma-client/__mocks__/prisma.ts"],"names":[],"mappings":";;;AACA,2DAAwE;AAExE,sCAA+B;AAE/B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,CAAC;IAC5B,UAAU,EAAE,IAAI;IAChB,OAAO,EAAE,IAAA,6BAAQ,GAAgB;CAClC,CAAC,CAAC,CAAC;AAEJ,UAAU,CAAC,GAAG,EAAE;IACd,IAAA,8BAAS,EAAC,kBAAU,CAAC,CAAC;AACxB,CAAC,CAAC,CAAC;AAEU,QAAA,UAAU,GAAG,gBAAgD,CAAC"}
|
@@ -1,3 +0,0 @@
|
|
1
|
-
import { PrismaClient } from '@prisma/client';
|
2
|
-
declare const prisma: PrismaClient<import(".prisma/client").Prisma.PrismaClientOptions, never, import(".prisma/client").Prisma.RejectOnNotFound | import(".prisma/client").Prisma.RejectPerOperation | undefined>;
|
3
|
-
export default prisma;
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/prisma-client/client.ts"],"names":[],"mappings":";;AAAA,2CAA8C;AAC9C,MAAM,MAAM,GAAG,IAAI,qBAAY,EAAE,CAAC;AAClC,kBAAe,MAAM,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
export * from './client';
|
@@ -1,18 +0,0 @@
|
|
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("./client"), exports);
|
18
|
-
//# sourceMappingURL=index.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/prisma-client/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB"}
|