@tomei/sso 0.56.2 → 0.57.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (160) hide show
  1. package/.commitlintrc.json +22 -22
  2. package/.gitlab-ci.yml +16 -16
  3. package/.husky/commit-msg +15 -15
  4. package/.husky/pre-commit +7 -7
  5. package/.prettierrc +4 -4
  6. package/Jenkinsfile +57 -57
  7. package/README.md +23 -23
  8. package/__tests__/unit/components/group/group.spec.ts +79 -79
  9. package/__tests__/unit/components/group-object-privilege/group-object-privilege.spec.ts +88 -88
  10. package/__tests__/unit/components/group-privilege/group-privilege.spec.ts +68 -68
  11. package/__tests__/unit/components/group-reporting-user/group-reporting-user.spec.ts +66 -66
  12. package/__tests__/unit/components/group-system-access/group-system-access.spec.ts +83 -83
  13. package/__tests__/unit/components/login-user/l.spec.ts +746 -746
  14. package/__tests__/unit/components/login-user/login.spec.ts +1164 -1164
  15. package/__tests__/unit/components/password-hash/password-hash.service.spec.ts +31 -31
  16. package/__tests__/unit/components/system/system.spec.ts +254 -254
  17. package/__tests__/unit/components/system-privilege/system-privilege.spec.ts +83 -83
  18. package/__tests__/unit/components/user-group/user-group.spec.ts +86 -86
  19. package/__tests__/unit/components/user-object-privilege/user-object-privilege.spec.ts +78 -78
  20. package/__tests__/unit/components/user-privilege/user-privilege.spec.ts +72 -72
  21. package/__tests__/unit/components/user-system-access/user-system-access.spec.ts +89 -89
  22. package/__tests__/unit/redis-client/redis.service.spec.ts +23 -23
  23. package/__tests__/unit/session/session.service.spec.ts +47 -47
  24. package/__tests__/unit/system-privilege/system-privilage.spec.ts +91 -91
  25. package/coverage/clover.xml +1452 -1452
  26. package/coverage/coverage-final.json +47 -47
  27. package/coverage/lcov-report/base.css +224 -224
  28. package/coverage/lcov-report/block-navigation.js +87 -87
  29. package/coverage/lcov-report/components/group/group.repository.ts.html +117 -117
  30. package/coverage/lcov-report/components/group/group.ts.html +327 -327
  31. package/coverage/lcov-report/components/group/index.html +130 -130
  32. package/coverage/lcov-report/components/group-object-privilege/group-object-privilege.repository.ts.html +117 -117
  33. package/coverage/lcov-report/components/group-object-privilege/group-object-privilege.ts.html +321 -321
  34. package/coverage/lcov-report/components/group-object-privilege/index.html +130 -130
  35. package/coverage/lcov-report/components/group-privilege/group-privilege.repository.ts.html +117 -117
  36. package/coverage/lcov-report/components/group-privilege/group-privilege.ts.html +303 -303
  37. package/coverage/lcov-report/components/group-privilege/index.html +130 -130
  38. package/coverage/lcov-report/components/group-reporting-user/group-reporting-user.repository.ts.html +117 -117
  39. package/coverage/lcov-report/components/group-reporting-user/group-reporting-user.ts.html +327 -327
  40. package/coverage/lcov-report/components/group-reporting-user/index.html +130 -130
  41. package/coverage/lcov-report/components/group-system-access/group-system-access.repository.ts.html +117 -117
  42. package/coverage/lcov-report/components/group-system-access/group-system-access.ts.html +309 -309
  43. package/coverage/lcov-report/components/group-system-access/index.html +130 -130
  44. package/coverage/lcov-report/components/login-history/index.html +115 -115
  45. package/coverage/lcov-report/components/login-history/login-history.repository.ts.html +117 -117
  46. package/coverage/lcov-report/components/login-user/index.html +130 -130
  47. package/coverage/lcov-report/components/login-user/login-user.ts.html +5007 -5007
  48. package/coverage/lcov-report/components/login-user/user.repository.ts.html +117 -117
  49. package/coverage/lcov-report/components/password-hash/index.html +115 -115
  50. package/coverage/lcov-report/components/password-hash/password-hash.service.ts.html +126 -126
  51. package/coverage/lcov-report/components/system/index.html +130 -130
  52. package/coverage/lcov-report/components/system/system.repository.ts.html +117 -117
  53. package/coverage/lcov-report/components/system/system.ts.html +909 -909
  54. package/coverage/lcov-report/components/system-privilege/index.html +130 -130
  55. package/coverage/lcov-report/components/system-privilege/system-privilege.repository.ts.html +120 -120
  56. package/coverage/lcov-report/components/system-privilege/system-privilege.ts.html +390 -390
  57. package/coverage/lcov-report/components/user-group/index.html +130 -130
  58. package/coverage/lcov-report/components/user-group/user-group.repository.ts.html +117 -117
  59. package/coverage/lcov-report/components/user-group/user-group.ts.html +354 -354
  60. package/coverage/lcov-report/components/user-object-privilege/index.html +130 -130
  61. package/coverage/lcov-report/components/user-object-privilege/user-object-privilege.repository.ts.html +117 -117
  62. package/coverage/lcov-report/components/user-object-privilege/user-object-privilege.ts.html +312 -312
  63. package/coverage/lcov-report/components/user-privilege/index.html +130 -130
  64. package/coverage/lcov-report/components/user-privilege/user-privilege.repository.ts.html +117 -117
  65. package/coverage/lcov-report/components/user-privilege/user-privilege.ts.html +306 -306
  66. package/coverage/lcov-report/components/user-system-access/index.html +130 -130
  67. package/coverage/lcov-report/components/user-system-access/user-system-access.repository.ts.html +117 -117
  68. package/coverage/lcov-report/components/user-system-access/user-system-access.ts.html +312 -312
  69. package/coverage/lcov-report/enum/group-type.enum.ts.html +108 -108
  70. package/coverage/lcov-report/enum/index.html +160 -160
  71. package/coverage/lcov-report/enum/index.ts.html +93 -93
  72. package/coverage/lcov-report/enum/user-status.enum.ts.html +105 -105
  73. package/coverage/lcov-report/enum/yn.enum.ts.html +96 -96
  74. package/coverage/lcov-report/index.html +370 -370
  75. package/coverage/lcov-report/models/group-object-privilege.entity.ts.html +333 -333
  76. package/coverage/lcov-report/models/group-privilege.entity.ts.html +315 -315
  77. package/coverage/lcov-report/models/group-reporting-user.entity.ts.html +339 -339
  78. package/coverage/lcov-report/models/group-system-access.entity.ts.html +324 -324
  79. package/coverage/lcov-report/models/group.entity.ts.html +435 -435
  80. package/coverage/lcov-report/models/index.html +310 -310
  81. package/coverage/lcov-report/models/login-history.entity.ts.html +252 -252
  82. package/coverage/lcov-report/models/staff.entity.ts.html +411 -411
  83. package/coverage/lcov-report/models/system-privilege.entity.ts.html +354 -354
  84. package/coverage/lcov-report/models/system.entity.ts.html +423 -423
  85. package/coverage/lcov-report/models/user-group.entity.ts.html +354 -354
  86. package/coverage/lcov-report/models/user-object-privilege.entity.ts.html +330 -330
  87. package/coverage/lcov-report/models/user-privilege.entity.ts.html +315 -315
  88. package/coverage/lcov-report/models/user-system-access.entity.ts.html +315 -315
  89. package/coverage/lcov-report/models/user.entity.ts.html +522 -522
  90. package/coverage/lcov-report/prettify.css +1 -1
  91. package/coverage/lcov-report/prettify.js +2 -2
  92. package/coverage/lcov-report/redis-client/index.html +115 -115
  93. package/coverage/lcov-report/redis-client/redis.service.ts.html +240 -240
  94. package/coverage/lcov-report/session/index.html +115 -115
  95. package/coverage/lcov-report/session/session.service.ts.html +246 -246
  96. package/coverage/lcov-report/sorter.js +196 -196
  97. package/coverage/lcov.info +2490 -2490
  98. package/coverage/test-report.xml +128 -128
  99. package/create-sso-user.sql +39 -39
  100. package/dist/__tests__/unit/components/group-privilege/group-privilege.test.d.ts +1 -0
  101. package/dist/__tests__/unit/components/group-privilege/group-privilege.test.js +71 -0
  102. package/dist/__tests__/unit/components/group-privilege/group-privilege.test.js.map +1 -0
  103. package/dist/__tests__/unit/components/login-user/login-user.spec.d.ts +0 -0
  104. package/dist/__tests__/unit/components/login-user/login-user.spec.js +6 -0
  105. package/dist/__tests__/unit/components/login-user/login-user.spec.js.map +1 -0
  106. package/dist/src/components/index.d.ts +1 -0
  107. package/dist/src/components/index.js +1 -0
  108. package/dist/src/components/index.js.map +1 -1
  109. package/dist/src/components/login-user/user.d.ts +8 -0
  110. package/dist/src/components/login-user/user.js +34 -0
  111. package/dist/src/components/login-user/user.js.map +1 -1
  112. package/dist/src/components/user-reporting-hierarchy/index.d.ts +2 -0
  113. package/dist/src/components/user-reporting-hierarchy/index.js +19 -0
  114. package/dist/src/components/user-reporting-hierarchy/index.js.map +1 -0
  115. package/dist/src/components/user-reporting-hierarchy/user-reporting-hierarchy.d.ts +25 -0
  116. package/dist/src/components/user-reporting-hierarchy/user-reporting-hierarchy.js +70 -0
  117. package/dist/src/components/user-reporting-hierarchy/user-reporting-hierarchy.js.map +1 -0
  118. package/dist/src/components/user-reporting-hierarchy/user-reporting-hierarchy.repository.d.ts +7 -0
  119. package/dist/src/components/user-reporting-hierarchy/user-reporting-hierarchy.repository.js +36 -0
  120. package/dist/src/components/user-reporting-hierarchy/user-reporting-hierarchy.repository.js.map +1 -0
  121. package/dist/src/interfaces/user-reporting-hierarchy.interface.d.ts +11 -0
  122. package/dist/src/interfaces/user-reporting-hierarchy.interface.js +3 -0
  123. package/dist/src/interfaces/user-reporting-hierarchy.interface.js.map +1 -0
  124. package/dist/src/models/user-reporting-hierarchy.entity.d.ts +18 -0
  125. package/dist/src/models/user-reporting-hierarchy.entity.js +116 -0
  126. package/dist/src/models/user-reporting-hierarchy.entity.js.map +1 -0
  127. package/dist/tsconfig.tsbuildinfo +1 -1
  128. package/eslint.config.mjs +58 -58
  129. package/jest.config.js +14 -14
  130. package/migrations/20240314080602-create-user-table.js +124 -124
  131. package/migrations/20240314080603-create-user-group-table.js +85 -85
  132. package/migrations/20240314080604-create-user-user-group-table.js +55 -55
  133. package/migrations/20240314080605-create-login-history-table.js +53 -53
  134. package/migrations/20240527064925-create-system-table.js +78 -78
  135. package/migrations/20240527064926-create-system-privilege-table.js +71 -71
  136. package/migrations/20240527065342-create-group-table.js +93 -93
  137. package/migrations/20240527065633-create-group-reporting-user-table.js +76 -76
  138. package/migrations/20240528011551-create-group-system-access-table.js +72 -72
  139. package/migrations/20240528023018-user-system-access-table.js +75 -75
  140. package/migrations/20240528032229-user-privilege-table.js +76 -76
  141. package/migrations/20240528063003-create-group-privilege-table.js +76 -76
  142. package/migrations/20240528063051-create-group-object-privilege-table.js +84 -84
  143. package/migrations/20240528063107-create-user-object-privilege-table.js +84 -84
  144. package/migrations/20240528063108-create-api-key-table.js +85 -85
  145. package/migrations/20241104104802-create-building-table.js +95 -95
  146. package/migrations/20250108091132-add-area-manager-user-id-to-building-table.js +14 -14
  147. package/migrations/20250108091133-add-passcode-to-user-table.js +36 -36
  148. package/migrations/20250210115636-create-user-reporting-hierarchy.js +76 -0
  149. package/package.json +90 -90
  150. package/sampledotenv +7 -7
  151. package/sonar-project.properties +22 -22
  152. package/src/components/index.ts +1 -0
  153. package/src/components/login-user/user.ts +42 -0
  154. package/src/components/user-reporting-hierarchy/index.ts +2 -0
  155. package/src/components/user-reporting-hierarchy/user-reporting-hierarchy.repository.ts +30 -0
  156. package/src/components/user-reporting-hierarchy/user-reporting-hierarchy.ts +90 -0
  157. package/src/interfaces/user-reporting-hierarchy.interface.ts +11 -0
  158. package/src/models/user-reporting-hierarchy.entity.ts +102 -0
  159. package/tsconfig.build.json +5 -5
  160. package/tsconfig.json +23 -23
@@ -33,6 +33,8 @@ import { LoginUser } from './login-user';
33
33
  import { SessionService } from '../../session/session.service';
34
34
  import { createHash, randomBytes, randomUUID } from 'crypto';
35
35
  import { AuthContext } from 'types';
36
+ import UserModel from '../../models/user.entity';
37
+ import { UserReportingHierarchyRepository } from '../user-reporting-hierarchy/user-reporting-hierarchy.repository';
36
38
 
37
39
  export class User extends UserBase {
38
40
  ObjectId: string;
@@ -77,6 +79,8 @@ export class User extends UserBase {
77
79
  protected static _UserSystemAccessRepo = new UserSystemAccessRepository();
78
80
  private static _GroupSystemAccessRepo = new GroupSystemAccessRepository();
79
81
  private static _GroupRepo = new GroupRepository();
82
+ protected static _UserReportingHierarchyRepo =
83
+ new UserReportingHierarchyRepository();
80
84
 
81
85
  private _dbTransaction: any;
82
86
 
@@ -2834,4 +2838,42 @@ export class User extends UserBase {
2834
2838
  throw error;
2835
2839
  }
2836
2840
  }
2841
+
2842
+ public async getReportingUser(dbTransaction: any): Promise<
2843
+ {
2844
+ Email: string;
2845
+ ContactNo: string;
2846
+ Name: string;
2847
+ Rank: number;
2848
+ }[]
2849
+ > {
2850
+ try {
2851
+ const data = await User._UserReportingHierarchyRepo.findAll({
2852
+ where: {
2853
+ ReportingUserId: this.UserId,
2854
+ },
2855
+ include: [
2856
+ {
2857
+ model: UserModel,
2858
+ as: 'User',
2859
+ attributes: ['Email', 'ContactNo', 'FullName'],
2860
+ },
2861
+ ],
2862
+ transaction: dbTransaction,
2863
+ });
2864
+
2865
+ //format the data
2866
+ const result = data.map((item) => {
2867
+ return {
2868
+ Email: item.User.Email,
2869
+ ContactNo: item.User.ContactNo,
2870
+ Name: item.User.FullName,
2871
+ Rank: item.Rank,
2872
+ };
2873
+ });
2874
+ return result;
2875
+ } catch (error) {
2876
+ throw error;
2877
+ }
2878
+ }
2837
2879
  }
@@ -0,0 +1,2 @@
1
+ export * from './user-reporting-hierarchy';
2
+ export * from './user-reporting-hierarchy.repository';
@@ -0,0 +1,30 @@
1
+ import UserReportingHierarchyModel from '../../models/user-reporting-hierarchy.entity';
2
+ import { RepositoryBase, IRepositoryBase } from '@tomei/general';
3
+
4
+ export class UserReportingHierarchyRepository
5
+ extends RepositoryBase<UserReportingHierarchyModel>
6
+ implements IRepositoryBase<UserReportingHierarchyModel>
7
+ {
8
+ constructor() {
9
+ super(UserReportingHierarchyModel);
10
+ }
11
+
12
+ async findByPk(
13
+ id: string,
14
+ options?: any,
15
+ ): Promise<UserReportingHierarchyModel> {
16
+ return await UserReportingHierarchyModel.findByPk(parseInt(id), options);
17
+ }
18
+
19
+ async destroy(
20
+ UserReportingHierarchyId: number,
21
+ dbTransaction: any,
22
+ ): Promise<void> {
23
+ await UserReportingHierarchyModel.destroy({
24
+ where: {
25
+ UserReportingHierarchyId: UserReportingHierarchyId,
26
+ },
27
+ transaction: dbTransaction,
28
+ });
29
+ }
30
+ }
@@ -0,0 +1,90 @@
1
+ import { ClassError, ObjectBase } from '@tomei/general';
2
+ import { IUserReportingHierarchyAttr } from '../../interfaces/user-reporting-hierarchy.interface';
3
+ import { UserReportingHierarchyRepository } from './user-reporting-hierarchy.repository';
4
+
5
+ export class UserReportingHierarchy
6
+ extends ObjectBase
7
+ implements IUserReportingHierarchyAttr
8
+ {
9
+ ObjectId: string;
10
+ ObjectName: string;
11
+ ObjectType = 'UserReportingHierarchy';
12
+ TableName = 'sso_UserReportingHierarchy';
13
+ ReportingUserId: number;
14
+ UserId: number;
15
+ Rank: number;
16
+ Status: string;
17
+ private _CreatedById: number;
18
+ private _CreatedAt: Date;
19
+ private _UpdatedById: number;
20
+ private _UpdatedAt: Date;
21
+
22
+ private static _Repo = new UserReportingHierarchyRepository();
23
+
24
+ get UserReportingHierarchyId(): number {
25
+ return parseInt(this.ObjectId);
26
+ }
27
+
28
+ set UserReportingHierarchyId(value: number) {
29
+ this.ObjectId = value.toString();
30
+ }
31
+
32
+ get CreatedById(): number {
33
+ return this._CreatedById;
34
+ }
35
+
36
+ get CreatedAt(): Date {
37
+ return this._CreatedAt;
38
+ }
39
+
40
+ get UpdatedById(): number {
41
+ return this._UpdatedById;
42
+ }
43
+
44
+ get UpdatedAt(): Date {
45
+ return this._UpdatedAt;
46
+ }
47
+
48
+ private constructor(params?: IUserReportingHierarchyAttr) {
49
+ super();
50
+ if (params) {
51
+ this.ObjectId = params.UserReportingHierarchyId.toString();
52
+ this.ReportingUserId = params.ReportingUserId;
53
+ this.UserId = params.UserId;
54
+ this.Rank = params.Rank;
55
+ this.Status = params.Status;
56
+ this._CreatedById = params.CreatedById;
57
+ this._CreatedAt = params.CreatedAt;
58
+ this._UpdatedById = params.UpdatedById;
59
+ this._UpdatedAt = params.UpdatedAt;
60
+ }
61
+ }
62
+
63
+ public static async init(
64
+ userReportingHierarchyId: number,
65
+ dbTransaction?: any,
66
+ ): Promise<UserReportingHierarchy> {
67
+ try {
68
+ if (userReportingHierarchyId) {
69
+ const data = await UserReportingHierarchy._Repo.findByPk(
70
+ userReportingHierarchyId.toString(),
71
+ dbTransaction,
72
+ );
73
+ if (!data) {
74
+ throw new ClassError(
75
+ 'UserReportingHierarchy',
76
+ 'UserReportingHierarchyErrMsg01',
77
+ 'UserReportingHierarchy not found',
78
+ 'init',
79
+ 400,
80
+ );
81
+ }
82
+
83
+ return new UserReportingHierarchy(data.get({ plain: true }));
84
+ }
85
+ return new UserReportingHierarchy();
86
+ } catch (error) {
87
+ throw error;
88
+ }
89
+ }
90
+ }
@@ -0,0 +1,11 @@
1
+ export interface IUserReportingHierarchyAttr {
2
+ UserReportingHierarchyId: number;
3
+ ReportingUserId: number;
4
+ UserId: number;
5
+ Rank: number;
6
+ Status: string;
7
+ CreatedById: number;
8
+ CreatedAt: Date;
9
+ UpdatedById: number;
10
+ UpdatedAt: Date;
11
+ }
@@ -0,0 +1,102 @@
1
+ import {
2
+ BelongsTo,
3
+ Column,
4
+ CreatedAt,
5
+ DataType,
6
+ ForeignKey,
7
+ Model,
8
+ Table,
9
+ UpdatedAt,
10
+ } from 'sequelize-typescript';
11
+ import User from './user.entity';
12
+ import GroupModel from './group.entity';
13
+ import { IUserReportingHierarchyAttr } from '../interfaces/user-reporting-hierarchy.interface';
14
+
15
+ @Table({
16
+ tableName: 'sso_UserReportingHierarchy',
17
+ timestamps: true,
18
+ createdAt: 'CreatedAt',
19
+ updatedAt: 'UpdatedAt',
20
+ })
21
+ export default class UserReportingHierarchyModel
22
+ extends Model
23
+ implements IUserReportingHierarchyAttr
24
+ {
25
+ @Column({
26
+ primaryKey: true,
27
+ allowNull: false,
28
+ type: DataType.INTEGER,
29
+ autoIncrement: true,
30
+ })
31
+ UserReportingHierarchyId: number;
32
+
33
+ @ForeignKey(() => User)
34
+ @Column({
35
+ allowNull: false,
36
+ type: DataType.INTEGER,
37
+ })
38
+ UserId: number;
39
+
40
+ @ForeignKey(() => User)
41
+ @Column({
42
+ allowNull: false,
43
+ type: DataType.INTEGER,
44
+ })
45
+ ReportingUserId: number;
46
+
47
+ @Column({
48
+ allowNull: false,
49
+ type: DataType.TINYINT,
50
+ })
51
+ Rank: number;
52
+
53
+ @Column({
54
+ allowNull: false,
55
+ type: DataType.CHAR(10),
56
+ })
57
+ Status: string;
58
+
59
+ @ForeignKey(() => User)
60
+ @Column({
61
+ allowNull: false,
62
+ type: DataType.INTEGER,
63
+ })
64
+ CreatedById: number;
65
+
66
+ @ForeignKey(() => User)
67
+ @Column({
68
+ allowNull: false,
69
+ type: DataType.INTEGER,
70
+ })
71
+ UpdatedById: number;
72
+
73
+ @CreatedAt
74
+ CreatedAt: Date;
75
+
76
+ @UpdatedAt
77
+ UpdatedAt: Date;
78
+
79
+ @BelongsTo(() => User, {
80
+ as: 'CreatedByUser',
81
+ foreignKey: 'CreatedById',
82
+ })
83
+ CreatedByUser: User;
84
+
85
+ @BelongsTo(() => User, {
86
+ as: 'ReportingUser',
87
+ foreignKey: 'ReportingUserId',
88
+ })
89
+ ReportingUser: User;
90
+
91
+ @BelongsTo(() => User, {
92
+ as: 'UpdatedByUser',
93
+ foreignKey: 'UpdatedById',
94
+ })
95
+ UpdatedByUser: User;
96
+
97
+ @BelongsTo(() => User, {
98
+ as: 'User',
99
+ foreignKey: 'UserId',
100
+ })
101
+ User: User;
102
+ }
@@ -1,6 +1,6 @@
1
- {
2
- "extends": "./tsconfig.json",
3
- "include": ["**/*.ts"],
4
- "exclude": ["node_modules", "__tests__", "dist", "**/*spec.ts"]
5
- }
1
+ {
2
+ "extends": "./tsconfig.json",
3
+ "include": ["**/*.ts"],
4
+ "exclude": ["node_modules", "__tests__", "dist", "**/*spec.ts"]
5
+ }
6
6
 
package/tsconfig.json CHANGED
@@ -1,24 +1,24 @@
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": false,
22
- },
23
- "exclude": ["node_modules", "dist"]
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": false,
22
+ },
23
+ "exclude": ["node_modules", "dist"]
24
24
  }