@anarchitects/auth-nest 0.5.0 → 0.6.0
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/README.md +102 -61
- package/package.json +25 -5
- package/src/application/application.module.js +61 -36
- package/src/application/application.module.js.map +1 -1
- package/src/application/index.d.ts +0 -2
- package/src/application/index.js +0 -2
- package/src/application/index.js.map +1 -1
- package/src/application/ports/auth-account.repository.d.ts +18 -0
- package/src/application/ports/auth-account.repository.js +12 -0
- package/src/application/ports/auth-account.repository.js.map +1 -0
- package/src/{infrastructure-persistence/repositories → application/ports}/auth-user.repository.d.ts +1 -2
- package/src/application/ports/auth-user.repository.js.map +1 -0
- package/src/application/resource-authorization.types.d.ts +1 -16
- package/src/application/services/auth-engine.port.d.ts +22 -17
- package/src/application/services/auth-engine.port.js.map +1 -1
- package/src/application/services/auth-orchestration.service.d.ts +15 -10
- package/src/application/services/auth-orchestration.service.js +78 -61
- package/src/application/services/auth-orchestration.service.js.map +1 -1
- package/src/application/services/auth.service.d.ts +10 -7
- package/src/application/services/auth.service.js.map +1 -1
- package/src/application/services/better-auth-database.port.d.ts +3 -0
- package/src/application/services/better-auth-database.port.js +12 -0
- package/src/application/services/better-auth-database.port.js.map +1 -0
- package/src/application/services/policies.service.d.ts +1 -1
- package/src/application/services/policies.service.js +1 -1
- package/src/application/services/policies.service.js.map +1 -1
- package/src/application/services/resource-authorization.d.ts +1 -1
- package/src/auth.module.js +29 -3
- package/src/auth.module.js.map +1 -1
- package/src/config/auth.config.d.ts +62 -48
- package/src/config/auth.config.js +82 -76
- package/src/config/auth.config.js.map +1 -1
- package/src/config/index.d.ts +1 -0
- package/src/config/index.js +1 -0
- package/src/config/index.js.map +1 -1
- package/src/config/module-options.d.ts +69 -49
- package/src/config/module-options.js +79 -50
- package/src/config/module-options.js.map +1 -1
- package/src/config/resource-authorization.types.d.ts +16 -0
- package/src/config/resource-authorization.types.js +3 -0
- package/src/config/resource-authorization.types.js.map +1 -0
- package/src/infrastructure-engine/better-auth/better-auth-auth-engine.adapter.d.ts +32 -10
- package/src/infrastructure-engine/better-auth/better-auth-auth-engine.adapter.js +190 -90
- package/src/infrastructure-engine/better-auth/better-auth-auth-engine.adapter.js.map +1 -1
- package/src/infrastructure-engine/better-auth/better-auth-options.d.ts +21 -0
- package/src/infrastructure-engine/better-auth/better-auth-options.js +94 -0
- package/src/infrastructure-engine/better-auth/better-auth-options.js.map +1 -0
- package/src/infrastructure-engine/better-auth/better-auth-typeorm-adapter-persistence.adapter.d.ts +14 -0
- package/src/infrastructure-engine/better-auth/better-auth-typeorm-adapter-persistence.adapter.js +62 -0
- package/src/infrastructure-engine/better-auth/better-auth-typeorm-adapter-persistence.adapter.js.map +1 -0
- package/src/infrastructure-engine/better-auth/better-auth.module-loader.d.ts +6 -0
- package/src/infrastructure-engine/better-auth/better-auth.module-loader.js +9 -1
- package/src/infrastructure-engine/better-auth/better-auth.module-loader.js.map +1 -1
- package/src/infrastructure-engine/better-auth/plugins/jwt/better-auth-jwt-plugin.service.d.ts +21 -0
- package/src/infrastructure-engine/{legacy-jwt-auth-engine.adapter.js → better-auth/plugins/jwt/better-auth-jwt-plugin.service.js} +31 -63
- package/src/infrastructure-engine/better-auth/plugins/jwt/better-auth-jwt-plugin.service.js.map +1 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/better-auth-jwt-typeorm-support.module.d.ts +2 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/better-auth-jwt-typeorm-support.module.js +26 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/better-auth-jwt-typeorm-support.module.js.map +1 -0
- package/src/{infrastructure-persistence/entities → infrastructure-engine/better-auth/plugins/jwt}/invalidated-token.entity.js +1 -1
- package/src/infrastructure-engine/better-auth/plugins/jwt/invalidated-token.entity.js.map +1 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/jwt-auth-plugin.controller.d.ts +10 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/jwt-auth-plugin.controller.js +65 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/jwt-auth-plugin.controller.js.map +1 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/jwt-token-invalidation.repository.d.ts +4 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/jwt-token-invalidation.repository.js +12 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/jwt-token-invalidation.repository.js.map +1 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/typeorm-jwt-token-invalidation.repository.d.ts +9 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/typeorm-jwt-token-invalidation.repository.js +33 -0
- package/src/infrastructure-engine/better-auth/plugins/jwt/typeorm-jwt-token-invalidation.repository.js.map +1 -0
- package/src/infrastructure-engine/better-auth/plugins/passkeys/better-auth-passkeys-typeorm-support.module.d.ts +2 -0
- package/src/infrastructure-engine/better-auth/plugins/passkeys/better-auth-passkeys-typeorm-support.module.js +17 -0
- package/src/infrastructure-engine/better-auth/plugins/passkeys/better-auth-passkeys-typeorm-support.module.js.map +1 -0
- package/src/infrastructure-engine/better-auth/plugins/passkeys/migrations/1760200001000-create-better-auth-passkeys-table.d.ts +6 -0
- package/src/infrastructure-engine/better-auth/plugins/passkeys/migrations/1760200001000-create-better-auth-passkeys-table.js +83 -0
- package/src/infrastructure-engine/better-auth/plugins/passkeys/migrations/1760200001000-create-better-auth-passkeys-table.js.map +1 -0
- package/src/infrastructure-engine/better-auth/plugins/passkeys/passkey.entity.d.ts +14 -0
- package/src/infrastructure-engine/better-auth/plugins/passkeys/passkey.entity.js +71 -0
- package/src/infrastructure-engine/better-auth/plugins/passkeys/passkey.entity.js.map +1 -0
- package/src/infrastructure-persistence/entities/account.entity.d.ts +16 -0
- package/src/infrastructure-persistence/entities/account.entity.js +81 -0
- package/src/infrastructure-persistence/entities/account.entity.js.map +1 -0
- package/src/infrastructure-persistence/entities/session.entity.d.ts +11 -0
- package/src/infrastructure-persistence/entities/session.entity.js +58 -0
- package/src/infrastructure-persistence/entities/session.entity.js.map +1 -0
- package/src/infrastructure-persistence/entities/user.entity.d.ts +3 -4
- package/src/infrastructure-persistence/entities/user.entity.js +5 -9
- package/src/infrastructure-persistence/entities/user.entity.js.map +1 -1
- package/src/infrastructure-persistence/entities/verification.entity.d.ts +9 -0
- package/src/infrastructure-persistence/entities/verification.entity.js +50 -0
- package/src/infrastructure-persistence/entities/verification.entity.js.map +1 -0
- package/src/infrastructure-persistence/index.d.ts +1 -2
- package/src/infrastructure-persistence/index.js +1 -2
- package/src/infrastructure-persistence/index.js.map +1 -1
- package/src/infrastructure-persistence/migrations/1720200000000-create-auth-schema.js +189 -93
- package/src/infrastructure-persistence/migrations/1720200000000-create-auth-schema.js.map +1 -1
- package/src/infrastructure-persistence/persistence.module-definition.d.ts +1 -1
- package/src/infrastructure-persistence/persistence.module-definition.js +2 -2
- package/src/infrastructure-persistence/persistence.module-definition.js.map +1 -1
- package/src/infrastructure-persistence/persistence.module.js +34 -26
- package/src/infrastructure-persistence/persistence.module.js.map +1 -1
- package/src/infrastructure-persistence/repositories/typeorm-auth-account.repository.d.ts +14 -0
- package/src/infrastructure-persistence/repositories/typeorm-auth-account.repository.js +64 -0
- package/src/infrastructure-persistence/repositories/typeorm-auth-account.repository.js.map +1 -0
- package/src/infrastructure-persistence/repositories/typeorm-auth-user.repository.d.ts +6 -7
- package/src/infrastructure-persistence/repositories/typeorm-auth-user.repository.js +27 -17
- package/src/infrastructure-persistence/repositories/typeorm-auth-user.repository.js.map +1 -1
- package/src/presentation/controllers/auth.controller.d.ts +12 -7
- package/src/presentation/controllers/auth.controller.js +46 -26
- package/src/presentation/controllers/auth.controller.js.map +1 -1
- package/src/presentation/presentation.module.js +32 -3
- package/src/presentation/presentation.module.js.map +1 -1
- package/src/application/services/jwt-auth.service.d.ts +0 -11
- package/src/application/services/jwt-auth.service.js +0 -27
- package/src/application/services/jwt-auth.service.js.map +0 -1
- package/src/application/strategies/jwt-strategy.d.ts +0 -17
- package/src/application/strategies/jwt-strategy.js +0 -27
- package/src/application/strategies/jwt-strategy.js.map +0 -1
- package/src/infrastructure-engine/better-auth/better-auth-spike.harness.d.ts +0 -17
- package/src/infrastructure-engine/better-auth/better-auth-spike.harness.js +0 -32
- package/src/infrastructure-engine/better-auth/better-auth-spike.harness.js.map +0 -1
- package/src/infrastructure-engine/legacy-jwt-auth-engine.adapter.d.ts +0 -22
- package/src/infrastructure-engine/legacy-jwt-auth-engine.adapter.js.map +0 -1
- package/src/infrastructure-persistence/entities/invalidated-token.entity.js.map +0 -1
- package/src/infrastructure-persistence/repositories/auth-user.repository.js.map +0 -1
- /package/src/{infrastructure-persistence/repositories → application/ports}/auth-user.repository.js +0 -0
- /package/src/{infrastructure-persistence/entities → infrastructure-engine/better-auth/plugins/jwt}/invalidated-token.entity.d.ts +0 -0
|
@@ -9,6 +9,9 @@ const PERMISSIONS_TABLE = `${schema_1.AUTH_SCHEMA}.permissions`;
|
|
|
9
9
|
const USER_ROLES_TABLE = `${schema_1.AUTH_SCHEMA}.user_roles`;
|
|
10
10
|
const ROLE_PERMISSIONS_TABLE = `${schema_1.AUTH_SCHEMA}.role_permissions`;
|
|
11
11
|
const INVALIDATED_TOKENS_TABLE = `${schema_1.AUTH_SCHEMA}.invalidated_tokens`;
|
|
12
|
+
const ACCOUNTS_TABLE = `${schema_1.AUTH_SCHEMA}.accounts`;
|
|
13
|
+
const SESSIONS_TABLE = `${schema_1.AUTH_SCHEMA}.sessions`;
|
|
14
|
+
const VERIFICATIONS_TABLE = `${schema_1.AUTH_SCHEMA}.verifications`;
|
|
12
15
|
class CreateAuthSchema1720200000000 {
|
|
13
16
|
constructor() {
|
|
14
17
|
this.name = 'CreateAuthSchema1720200000000';
|
|
@@ -20,11 +23,7 @@ class CreateAuthSchema1720200000000 {
|
|
|
20
23
|
schema: schema_1.AUTH_SCHEMA,
|
|
21
24
|
name: 'users',
|
|
22
25
|
columns: [
|
|
23
|
-
{
|
|
24
|
-
name: 'id',
|
|
25
|
-
type: 'uuid',
|
|
26
|
-
isPrimary: true,
|
|
27
|
-
},
|
|
26
|
+
{ name: 'id', type: 'uuid', isPrimary: true },
|
|
28
27
|
{
|
|
29
28
|
name: 'email',
|
|
30
29
|
type: 'varchar',
|
|
@@ -33,29 +32,23 @@ class CreateAuthSchema1720200000000 {
|
|
|
33
32
|
isUnique: true,
|
|
34
33
|
},
|
|
35
34
|
{
|
|
36
|
-
name: '
|
|
35
|
+
name: 'name',
|
|
37
36
|
type: 'varchar',
|
|
38
37
|
length: '100',
|
|
39
38
|
isNullable: true,
|
|
40
39
|
},
|
|
41
40
|
{
|
|
42
|
-
name: '
|
|
43
|
-
type: '
|
|
44
|
-
|
|
41
|
+
name: 'emailVerified',
|
|
42
|
+
type: 'boolean',
|
|
43
|
+
default: false,
|
|
45
44
|
isNullable: false,
|
|
46
45
|
},
|
|
47
46
|
{
|
|
48
|
-
name: '
|
|
47
|
+
name: 'image',
|
|
49
48
|
type: 'varchar',
|
|
50
49
|
length: '500',
|
|
51
50
|
isNullable: true,
|
|
52
51
|
},
|
|
53
|
-
{
|
|
54
|
-
name: 'isActive',
|
|
55
|
-
type: 'boolean',
|
|
56
|
-
default: false,
|
|
57
|
-
isNullable: false,
|
|
58
|
-
},
|
|
59
52
|
{
|
|
60
53
|
name: 'createdAt',
|
|
61
54
|
type: 'timestamptz',
|
|
@@ -76,11 +69,7 @@ class CreateAuthSchema1720200000000 {
|
|
|
76
69
|
schema: schema_1.AUTH_SCHEMA,
|
|
77
70
|
name: 'roles',
|
|
78
71
|
columns: [
|
|
79
|
-
{
|
|
80
|
-
name: 'id',
|
|
81
|
-
type: 'uuid',
|
|
82
|
-
isPrimary: true,
|
|
83
|
-
},
|
|
72
|
+
{ name: 'id', type: 'uuid', isPrimary: true },
|
|
84
73
|
{
|
|
85
74
|
name: 'name',
|
|
86
75
|
type: 'varchar',
|
|
@@ -88,11 +77,7 @@ class CreateAuthSchema1720200000000 {
|
|
|
88
77
|
isNullable: false,
|
|
89
78
|
isUnique: true,
|
|
90
79
|
},
|
|
91
|
-
{
|
|
92
|
-
name: 'description',
|
|
93
|
-
type: 'text',
|
|
94
|
-
isNullable: true,
|
|
95
|
-
},
|
|
80
|
+
{ name: 'description', type: 'text', isNullable: true },
|
|
96
81
|
{
|
|
97
82
|
name: 'createdAt',
|
|
98
83
|
type: 'timestamptz',
|
|
@@ -113,11 +98,7 @@ class CreateAuthSchema1720200000000 {
|
|
|
113
98
|
schema: schema_1.AUTH_SCHEMA,
|
|
114
99
|
name: 'permissions',
|
|
115
100
|
columns: [
|
|
116
|
-
{
|
|
117
|
-
name: 'id',
|
|
118
|
-
type: 'uuid',
|
|
119
|
-
isPrimary: true,
|
|
120
|
-
},
|
|
101
|
+
{ name: 'id', type: 'uuid', isPrimary: true },
|
|
121
102
|
{
|
|
122
103
|
name: 'name',
|
|
123
104
|
type: 'varchar',
|
|
@@ -125,11 +106,7 @@ class CreateAuthSchema1720200000000 {
|
|
|
125
106
|
isNullable: false,
|
|
126
107
|
isUnique: true,
|
|
127
108
|
},
|
|
128
|
-
{
|
|
129
|
-
name: 'description',
|
|
130
|
-
type: 'text',
|
|
131
|
-
isNullable: true,
|
|
132
|
-
},
|
|
109
|
+
{ name: 'description', type: 'text', isNullable: true },
|
|
133
110
|
{
|
|
134
111
|
name: 'action',
|
|
135
112
|
type: 'varchar',
|
|
@@ -142,27 +119,15 @@ class CreateAuthSchema1720200000000 {
|
|
|
142
119
|
length: '100',
|
|
143
120
|
isNullable: false,
|
|
144
121
|
},
|
|
145
|
-
{
|
|
146
|
-
|
|
147
|
-
type: 'jsonb',
|
|
148
|
-
isNullable: true,
|
|
149
|
-
},
|
|
150
|
-
{
|
|
151
|
-
name: 'fields',
|
|
152
|
-
type: 'jsonb',
|
|
153
|
-
isNullable: true,
|
|
154
|
-
},
|
|
122
|
+
{ name: 'conditions', type: 'jsonb', isNullable: true },
|
|
123
|
+
{ name: 'fields', type: 'jsonb', isNullable: true },
|
|
155
124
|
{
|
|
156
125
|
name: 'inverted',
|
|
157
126
|
type: 'boolean',
|
|
158
127
|
default: false,
|
|
159
128
|
isNullable: false,
|
|
160
129
|
},
|
|
161
|
-
{
|
|
162
|
-
name: 'reason',
|
|
163
|
-
type: 'text',
|
|
164
|
-
isNullable: true,
|
|
165
|
-
},
|
|
130
|
+
{ name: 'reason', type: 'text', isNullable: true },
|
|
166
131
|
{
|
|
167
132
|
name: 'createdAt',
|
|
168
133
|
type: 'timestamptz',
|
|
@@ -183,32 +148,24 @@ class CreateAuthSchema1720200000000 {
|
|
|
183
148
|
schema: schema_1.AUTH_SCHEMA,
|
|
184
149
|
name: 'user_roles',
|
|
185
150
|
columns: [
|
|
186
|
-
{
|
|
187
|
-
|
|
188
|
-
type: 'uuid',
|
|
189
|
-
isPrimary: true,
|
|
190
|
-
},
|
|
191
|
-
{
|
|
192
|
-
name: 'role_id',
|
|
193
|
-
type: 'uuid',
|
|
194
|
-
isPrimary: true,
|
|
195
|
-
},
|
|
151
|
+
{ name: 'user_id', type: 'uuid', isPrimary: true },
|
|
152
|
+
{ name: 'role_id', type: 'uuid', isPrimary: true },
|
|
196
153
|
],
|
|
197
154
|
foreignKeys: [
|
|
198
|
-
{
|
|
155
|
+
new typeorm_1.TableForeignKey({
|
|
199
156
|
name: 'fk_auth_user_roles_user_id',
|
|
200
157
|
columnNames: ['user_id'],
|
|
201
158
|
referencedTableName: USERS_TABLE,
|
|
202
159
|
referencedColumnNames: ['id'],
|
|
203
160
|
onDelete: 'CASCADE',
|
|
204
|
-
},
|
|
205
|
-
{
|
|
161
|
+
}),
|
|
162
|
+
new typeorm_1.TableForeignKey({
|
|
206
163
|
name: 'fk_auth_user_roles_role_id',
|
|
207
164
|
columnNames: ['role_id'],
|
|
208
165
|
referencedTableName: ROLES_TABLE,
|
|
209
166
|
referencedColumnNames: ['id'],
|
|
210
167
|
onDelete: 'CASCADE',
|
|
211
|
-
},
|
|
168
|
+
}),
|
|
212
169
|
],
|
|
213
170
|
}), true);
|
|
214
171
|
}
|
|
@@ -217,32 +174,24 @@ class CreateAuthSchema1720200000000 {
|
|
|
217
174
|
schema: schema_1.AUTH_SCHEMA,
|
|
218
175
|
name: 'role_permissions',
|
|
219
176
|
columns: [
|
|
220
|
-
{
|
|
221
|
-
|
|
222
|
-
type: 'uuid',
|
|
223
|
-
isPrimary: true,
|
|
224
|
-
},
|
|
225
|
-
{
|
|
226
|
-
name: 'permission_id',
|
|
227
|
-
type: 'uuid',
|
|
228
|
-
isPrimary: true,
|
|
229
|
-
},
|
|
177
|
+
{ name: 'role_id', type: 'uuid', isPrimary: true },
|
|
178
|
+
{ name: 'permission_id', type: 'uuid', isPrimary: true },
|
|
230
179
|
],
|
|
231
180
|
foreignKeys: [
|
|
232
|
-
{
|
|
181
|
+
new typeorm_1.TableForeignKey({
|
|
233
182
|
name: 'fk_auth_role_permissions_role_id',
|
|
234
183
|
columnNames: ['role_id'],
|
|
235
184
|
referencedTableName: ROLES_TABLE,
|
|
236
185
|
referencedColumnNames: ['id'],
|
|
237
186
|
onDelete: 'CASCADE',
|
|
238
|
-
},
|
|
239
|
-
{
|
|
187
|
+
}),
|
|
188
|
+
new typeorm_1.TableForeignKey({
|
|
240
189
|
name: 'fk_auth_role_permissions_permission_id',
|
|
241
190
|
columnNames: ['permission_id'],
|
|
242
191
|
referencedTableName: PERMISSIONS_TABLE,
|
|
243
192
|
referencedColumnNames: ['id'],
|
|
244
193
|
onDelete: 'CASCADE',
|
|
245
|
-
},
|
|
194
|
+
}),
|
|
246
195
|
],
|
|
247
196
|
}), true);
|
|
248
197
|
}
|
|
@@ -257,11 +206,7 @@ class CreateAuthSchema1720200000000 {
|
|
|
257
206
|
length: '128',
|
|
258
207
|
isPrimary: true,
|
|
259
208
|
},
|
|
260
|
-
{
|
|
261
|
-
name: 'userId',
|
|
262
|
-
type: 'uuid',
|
|
263
|
-
isNullable: true,
|
|
264
|
-
},
|
|
209
|
+
{ name: 'userId', type: 'uuid', isNullable: true },
|
|
265
210
|
{
|
|
266
211
|
name: 'expires_at',
|
|
267
212
|
type: 'timestamptz',
|
|
@@ -276,18 +221,158 @@ class CreateAuthSchema1720200000000 {
|
|
|
276
221
|
],
|
|
277
222
|
}), true);
|
|
278
223
|
}
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
if (!
|
|
283
|
-
await queryRunner.
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
224
|
+
await ensureIndex(queryRunner, INVALIDATED_TOKENS_TABLE, 'invalidated_tokens_expires_at_idx', [
|
|
225
|
+
'expires_at',
|
|
226
|
+
]);
|
|
227
|
+
if (!(await queryRunner.hasTable(ACCOUNTS_TABLE))) {
|
|
228
|
+
await queryRunner.createTable(new typeorm_1.Table({
|
|
229
|
+
schema: schema_1.AUTH_SCHEMA,
|
|
230
|
+
name: 'accounts',
|
|
231
|
+
columns: [
|
|
232
|
+
{ name: 'id', type: 'varchar', length: '255', isPrimary: true },
|
|
233
|
+
{
|
|
234
|
+
name: 'accountId',
|
|
235
|
+
type: 'varchar',
|
|
236
|
+
length: '255',
|
|
237
|
+
isNullable: false,
|
|
238
|
+
},
|
|
239
|
+
{
|
|
240
|
+
name: 'providerId',
|
|
241
|
+
type: 'varchar',
|
|
242
|
+
length: '255',
|
|
243
|
+
isNullable: false,
|
|
244
|
+
},
|
|
245
|
+
{ name: 'userId', type: 'uuid', isNullable: false },
|
|
246
|
+
{ name: 'accessToken', type: 'text', isNullable: true },
|
|
247
|
+
{ name: 'refreshToken', type: 'text', isNullable: true },
|
|
248
|
+
{ name: 'idToken', type: 'text', isNullable: true },
|
|
249
|
+
{ name: 'accessTokenExpiresAt', type: 'timestamptz', isNullable: true },
|
|
250
|
+
{ name: 'refreshTokenExpiresAt', type: 'timestamptz', isNullable: true },
|
|
251
|
+
{ name: 'scope', type: 'varchar', length: '500', isNullable: true },
|
|
252
|
+
{ name: 'password', type: 'varchar', length: '500', isNullable: true },
|
|
253
|
+
{
|
|
254
|
+
name: 'createdAt',
|
|
255
|
+
type: 'timestamptz',
|
|
256
|
+
default: 'CURRENT_TIMESTAMP',
|
|
257
|
+
isNullable: false,
|
|
258
|
+
},
|
|
259
|
+
{
|
|
260
|
+
name: 'updatedAt',
|
|
261
|
+
type: 'timestamptz',
|
|
262
|
+
default: 'CURRENT_TIMESTAMP',
|
|
263
|
+
isNullable: false,
|
|
264
|
+
},
|
|
265
|
+
],
|
|
266
|
+
foreignKeys: [
|
|
267
|
+
new typeorm_1.TableForeignKey({
|
|
268
|
+
name: 'FK_auth_accounts_userId',
|
|
269
|
+
columnNames: ['userId'],
|
|
270
|
+
referencedTableName: USERS_TABLE,
|
|
271
|
+
referencedColumnNames: ['id'],
|
|
272
|
+
onDelete: 'CASCADE',
|
|
273
|
+
}),
|
|
274
|
+
],
|
|
275
|
+
uniques: [
|
|
276
|
+
{
|
|
277
|
+
name: 'UQ_auth_accounts_provider_account',
|
|
278
|
+
columnNames: ['providerId', 'accountId'],
|
|
279
|
+
},
|
|
280
|
+
],
|
|
281
|
+
}), true);
|
|
288
282
|
}
|
|
283
|
+
await ensureIndex(queryRunner, ACCOUNTS_TABLE, 'IDX_auth_accounts_userId', [
|
|
284
|
+
'userId',
|
|
285
|
+
]);
|
|
286
|
+
if (!(await queryRunner.hasTable(SESSIONS_TABLE))) {
|
|
287
|
+
await queryRunner.createTable(new typeorm_1.Table({
|
|
288
|
+
schema: schema_1.AUTH_SCHEMA,
|
|
289
|
+
name: 'sessions',
|
|
290
|
+
columns: [
|
|
291
|
+
{ name: 'id', type: 'varchar', length: '255', isPrimary: true },
|
|
292
|
+
{ name: 'userId', type: 'uuid', isNullable: false },
|
|
293
|
+
{ name: 'expiresAt', type: 'timestamptz', isNullable: false },
|
|
294
|
+
{
|
|
295
|
+
name: 'token',
|
|
296
|
+
type: 'varchar',
|
|
297
|
+
length: '500',
|
|
298
|
+
isNullable: false,
|
|
299
|
+
isUnique: true,
|
|
300
|
+
},
|
|
301
|
+
{ name: 'ipAddress', type: 'varchar', length: '255', isNullable: true },
|
|
302
|
+
{ name: 'userAgent', type: 'varchar', length: '1000', isNullable: true },
|
|
303
|
+
{
|
|
304
|
+
name: 'createdAt',
|
|
305
|
+
type: 'timestamptz',
|
|
306
|
+
default: 'CURRENT_TIMESTAMP',
|
|
307
|
+
isNullable: false,
|
|
308
|
+
},
|
|
309
|
+
{
|
|
310
|
+
name: 'updatedAt',
|
|
311
|
+
type: 'timestamptz',
|
|
312
|
+
default: 'CURRENT_TIMESTAMP',
|
|
313
|
+
isNullable: false,
|
|
314
|
+
},
|
|
315
|
+
],
|
|
316
|
+
foreignKeys: [
|
|
317
|
+
new typeorm_1.TableForeignKey({
|
|
318
|
+
name: 'FK_auth_sessions_userId',
|
|
319
|
+
columnNames: ['userId'],
|
|
320
|
+
referencedTableName: USERS_TABLE,
|
|
321
|
+
referencedColumnNames: ['id'],
|
|
322
|
+
onDelete: 'CASCADE',
|
|
323
|
+
}),
|
|
324
|
+
],
|
|
325
|
+
}), true);
|
|
326
|
+
}
|
|
327
|
+
await ensureIndex(queryRunner, SESSIONS_TABLE, 'IDX_auth_sessions_userId', [
|
|
328
|
+
'userId',
|
|
329
|
+
]);
|
|
330
|
+
if (!(await queryRunner.hasTable(VERIFICATIONS_TABLE))) {
|
|
331
|
+
await queryRunner.createTable(new typeorm_1.Table({
|
|
332
|
+
schema: schema_1.AUTH_SCHEMA,
|
|
333
|
+
name: 'verifications',
|
|
334
|
+
columns: [
|
|
335
|
+
{ name: 'id', type: 'varchar', length: '255', isPrimary: true },
|
|
336
|
+
{
|
|
337
|
+
name: 'identifier',
|
|
338
|
+
type: 'varchar',
|
|
339
|
+
length: '255',
|
|
340
|
+
isNullable: false,
|
|
341
|
+
},
|
|
342
|
+
{
|
|
343
|
+
name: 'value',
|
|
344
|
+
type: 'varchar',
|
|
345
|
+
length: '500',
|
|
346
|
+
isNullable: false,
|
|
347
|
+
},
|
|
348
|
+
{ name: 'expiresAt', type: 'timestamptz', isNullable: false },
|
|
349
|
+
{
|
|
350
|
+
name: 'createdAt',
|
|
351
|
+
type: 'timestamptz',
|
|
352
|
+
default: 'CURRENT_TIMESTAMP',
|
|
353
|
+
isNullable: false,
|
|
354
|
+
},
|
|
355
|
+
{
|
|
356
|
+
name: 'updatedAt',
|
|
357
|
+
type: 'timestamptz',
|
|
358
|
+
default: 'CURRENT_TIMESTAMP',
|
|
359
|
+
isNullable: false,
|
|
360
|
+
},
|
|
361
|
+
],
|
|
362
|
+
}), true);
|
|
363
|
+
}
|
|
364
|
+
await ensureIndex(queryRunner, VERIFICATIONS_TABLE, 'IDX_auth_verifications_identifier', ['identifier']);
|
|
289
365
|
}
|
|
290
366
|
async down(queryRunner) {
|
|
367
|
+
if (await queryRunner.hasTable(VERIFICATIONS_TABLE)) {
|
|
368
|
+
await queryRunner.dropTable(VERIFICATIONS_TABLE, true, true, true);
|
|
369
|
+
}
|
|
370
|
+
if (await queryRunner.hasTable(SESSIONS_TABLE)) {
|
|
371
|
+
await queryRunner.dropTable(SESSIONS_TABLE, true, true, true);
|
|
372
|
+
}
|
|
373
|
+
if (await queryRunner.hasTable(ACCOUNTS_TABLE)) {
|
|
374
|
+
await queryRunner.dropTable(ACCOUNTS_TABLE, true, true, true);
|
|
375
|
+
}
|
|
291
376
|
if (await queryRunner.hasTable(ROLE_PERMISSIONS_TABLE)) {
|
|
292
377
|
await queryRunner.dropTable(ROLE_PERMISSIONS_TABLE, true, true, true);
|
|
293
378
|
}
|
|
@@ -309,4 +394,15 @@ class CreateAuthSchema1720200000000 {
|
|
|
309
394
|
}
|
|
310
395
|
}
|
|
311
396
|
exports.CreateAuthSchema1720200000000 = CreateAuthSchema1720200000000;
|
|
397
|
+
const ensureIndex = async (queryRunner, tableName, indexName, columnNames) => {
|
|
398
|
+
const table = await queryRunner.getTable(tableName);
|
|
399
|
+
const hasIndex = table?.indices.some((index) => index.name === indexName);
|
|
400
|
+
if (!hasIndex) {
|
|
401
|
+
await queryRunner.createIndex(tableName, new typeorm_1.TableIndex({
|
|
402
|
+
name: indexName,
|
|
403
|
+
columnNames,
|
|
404
|
+
isUnique: false,
|
|
405
|
+
}));
|
|
406
|
+
}
|
|
407
|
+
};
|
|
312
408
|
//# sourceMappingURL=1720200000000-create-auth-schema.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"1720200000000-create-auth-schema.js","sourceRoot":"","sources":["../../../../../../../libs/auth/nest/src/infrastructure-persistence/migrations/1720200000000-create-auth-schema.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"1720200000000-create-auth-schema.js","sourceRoot":"","sources":["../../../../../../../libs/auth/nest/src/infrastructure-persistence/migrations/1720200000000-create-auth-schema.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { ResolvedAuthPersistenceModuleOptions } from '../config';
|
|
2
2
|
export declare const ConfigurableModuleClass: import("@nestjs/common").ConfigurableModuleCls<ResolvedAuthPersistenceModuleOptions, "forRoot", "create", {
|
|
3
3
|
isGlobal?: boolean;
|
|
4
|
-
}>,
|
|
4
|
+
}>, AUTH_PERSISTENCE_OPTIONS: string | symbol, OPTIONS_TYPE: ResolvedAuthPersistenceModuleOptions & Partial<{
|
|
5
5
|
isGlobal?: boolean;
|
|
6
6
|
}>, ASYNC_OPTIONS_TYPE: import("@nestjs/common").ConfigurableModuleAsyncOptions<ResolvedAuthPersistenceModuleOptions, "create"> & Partial<{
|
|
7
7
|
isGlobal?: boolean;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var _a;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.ASYNC_OPTIONS_TYPE = exports.OPTIONS_TYPE = exports.
|
|
4
|
+
exports.ASYNC_OPTIONS_TYPE = exports.OPTIONS_TYPE = exports.AUTH_PERSISTENCE_OPTIONS = exports.ConfigurableModuleClass = void 0;
|
|
5
5
|
const common_1 = require("@nestjs/common");
|
|
6
6
|
_a = new common_1.ConfigurableModuleBuilder()
|
|
7
7
|
.setClassMethodName('forRoot')
|
|
@@ -9,5 +9,5 @@ _a = new common_1.ConfigurableModuleBuilder()
|
|
|
9
9
|
...definition,
|
|
10
10
|
global: extras.isGlobal ?? false,
|
|
11
11
|
}))
|
|
12
|
-
.build(), exports.ConfigurableModuleClass = _a.ConfigurableModuleClass, exports.
|
|
12
|
+
.build(), exports.ConfigurableModuleClass = _a.ConfigurableModuleClass, exports.AUTH_PERSISTENCE_OPTIONS = _a.MODULE_OPTIONS_TOKEN, exports.OPTIONS_TYPE = _a.OPTIONS_TYPE, exports.ASYNC_OPTIONS_TYPE = _a.ASYNC_OPTIONS_TYPE;
|
|
13
13
|
//# sourceMappingURL=persistence.module-definition.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"persistence.module-definition.js","sourceRoot":"","sources":["../../../../../../libs/auth/nest/src/infrastructure-persistence/persistence.module-definition.ts"],"names":[],"mappings":";;;;AAAA,2CAA2D;AAG9C,KAKT,IAAI,kCAAyB,EAAwC;KACtE,kBAAkB,CAAC,SAAS,CAAC;KAC7B,SAAS,CACR,EAAE,QAAQ,EAAE,IAAI,EAAE,EAClB,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IACvB,GAAG,UAAU;IACb,MAAM,EAAE,MAAM,CAAC,QAAQ,IAAI,KAAK;CACjC,CAAC,CACH;KACA,KAAK,EAAE,EAbR,+BAAuB,+BACD,
|
|
1
|
+
{"version":3,"file":"persistence.module-definition.js","sourceRoot":"","sources":["../../../../../../libs/auth/nest/src/infrastructure-persistence/persistence.module-definition.ts"],"names":[],"mappings":";;;;AAAA,2CAA2D;AAG9C,KAKT,IAAI,kCAAyB,EAAwC;KACtE,kBAAkB,CAAC,SAAS,CAAC;KAC7B,SAAS,CACR,EAAE,QAAQ,EAAE,IAAI,EAAE,EAClB,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IACvB,GAAG,UAAU;IACb,MAAM,EAAE,MAAM,CAAC,QAAQ,IAAI,KAAK;CACjC,CAAC,CACH;KACA,KAAK,EAAE,EAbR,+BAAuB,+BACD,gCAAwB,4BAC9C,oBAAY,oBACZ,0BAAkB,yBAUT"}
|
|
@@ -5,41 +5,49 @@ const tslib_1 = require("tslib");
|
|
|
5
5
|
const common_1 = require("@nestjs/common");
|
|
6
6
|
const config_1 = require("@nestjs/config");
|
|
7
7
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
8
|
-
const
|
|
8
|
+
const auth_account_repository_1 = require("../application/ports/auth-account.repository");
|
|
9
|
+
const auth_user_repository_1 = require("../application/ports/auth-user.repository");
|
|
10
|
+
const account_entity_1 = require("./entities/account.entity");
|
|
9
11
|
const permission_entity_1 = require("./entities/permission.entity");
|
|
10
12
|
const role_entity_1 = require("./entities/role.entity");
|
|
13
|
+
const session_entity_1 = require("./entities/session.entity");
|
|
11
14
|
const user_entity_1 = require("./entities/user.entity");
|
|
15
|
+
const verification_entity_1 = require("./entities/verification.entity");
|
|
12
16
|
const persistence_module_definition_1 = require("./persistence.module-definition");
|
|
13
|
-
const
|
|
17
|
+
const typeorm_auth_account_repository_1 = require("./repositories/typeorm-auth-account.repository");
|
|
14
18
|
const typeorm_auth_user_repository_1 = require("./repositories/typeorm-auth-user.repository");
|
|
15
19
|
const config_2 = require("../config");
|
|
16
20
|
let AuthPersistenceModule = class AuthPersistenceModule extends persistence_module_definition_1.ConfigurableModuleClass {
|
|
17
21
|
static forRoot(options = {}) {
|
|
18
22
|
const resolvedOptions = (0, config_2.resolveAuthPersistenceModuleOptions)(options);
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
23
|
+
return {
|
|
24
|
+
...super.forRoot(resolvedOptions),
|
|
25
|
+
imports: [
|
|
26
|
+
typeorm_1.TypeOrmModule.forFeature([
|
|
27
|
+
account_entity_1.AccountEntity,
|
|
28
|
+
session_entity_1.SessionEntity,
|
|
29
|
+
user_entity_1.UserEntity,
|
|
30
|
+
verification_entity_1.VerificationEntity,
|
|
31
|
+
role_entity_1.RoleEntity,
|
|
32
|
+
permission_entity_1.PermissionEntity,
|
|
33
|
+
]),
|
|
34
|
+
],
|
|
35
|
+
providers: [
|
|
36
|
+
// Application owns the repository ports; persistence binds the
|
|
37
|
+
// TypeORM-backed implementations for those ports here.
|
|
38
|
+
typeorm_auth_account_repository_1.TypeormAuthAccountRepository,
|
|
39
|
+
typeorm_auth_user_repository_1.TypeormAuthUserRepository,
|
|
40
|
+
{
|
|
41
|
+
provide: auth_account_repository_1.AuthAccountRepository,
|
|
42
|
+
useExisting: typeorm_auth_account_repository_1.TypeormAuthAccountRepository,
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
provide: auth_user_repository_1.AuthUserRepository,
|
|
46
|
+
useExisting: typeorm_auth_user_repository_1.TypeormAuthUserRepository,
|
|
47
|
+
},
|
|
48
|
+
],
|
|
49
|
+
exports: [auth_account_repository_1.AuthAccountRepository, auth_user_repository_1.AuthUserRepository, typeorm_1.TypeOrmModule],
|
|
50
|
+
};
|
|
43
51
|
}
|
|
44
52
|
static forRootFromConfig(overrides = {}) {
|
|
45
53
|
const configOptions = (0, config_2.mapAuthConfigToPersistenceModuleOptions)((0, config_2.authConfig)());
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"persistence.module.js","sourceRoot":"","sources":["../../../../../../libs/auth/nest/src/infrastructure-persistence/persistence.module.ts"],"names":[],"mappings":";;;;AAAA,2CAAuD;AACvD,2CAA8C;AAC9C,6CAAgD;AAChD,
|
|
1
|
+
{"version":3,"file":"persistence.module.js","sourceRoot":"","sources":["../../../../../../libs/auth/nest/src/infrastructure-persistence/persistence.module.ts"],"names":[],"mappings":";;;;AAAA,2CAAuD;AACvD,2CAA8C;AAC9C,6CAAgD;AAChD,0FAAqF;AACrF,oFAA+E;AAC/E,8DAA0D;AAC1D,oEAAgE;AAChE,wDAAoD;AACpD,8DAA0D;AAC1D,wDAAoD;AACpD,wEAAoE;AACpE,mFAGyC;AACzC,oGAA8F;AAC9F,8FAAwF;AACxF,sCAImB;AAIZ,IAAM,qBAAqB,GAA3B,MAAM,qBAAsB,SAAQ,uDAAuB;IAChE,MAAM,CAAC,OAAO,CAAC,UAAwC,EAAE;QACvD,MAAM,eAAe,GACnB,IAAA,4CAAmC,EAAC,OAAO,CAAC,CAAC;QAE/C,OAAO;YACL,GAAG,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC;YACjC,OAAO,EAAE;gBACP,uBAAa,CAAC,UAAU,CAAC;oBACvB,8BAAa;oBACb,8BAAa;oBACb,wBAAU;oBACV,wCAAkB;oBAClB,wBAAU;oBACV,oCAAgB;iBACjB,CAAC;aACH;YACD,SAAS,EAAE;gBACT,+DAA+D;gBAC/D,uDAAuD;gBACvD,8DAA4B;gBAC5B,wDAAyB;gBACzB;oBACE,OAAO,EAAE,+CAAqB;oBAC9B,WAAW,EAAE,8DAA4B;iBAC1C;gBACD;oBACE,OAAO,EAAE,yCAAkB;oBAC3B,WAAW,EAAE,wDAAyB;iBACvC;aACF;YACD,OAAO,EAAE,CAAC,+CAAqB,EAAE,yCAAkB,EAAE,uBAAa,CAAC;SACpE,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,iBAAiB,CACtB,YAA0C,EAAE;QAE5C,MAAM,aAAa,GAAG,IAAA,gDAAuC,EAAC,IAAA,mBAAU,GAAE,CAAC,CAAC;QAC5E,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC;YACpC,GAAG,aAAa;YAChB,GAAG,SAAS;SACb,CAAC,CAAC;QAEH,OAAO;YACL,GAAG,gBAAgB;YACnB,OAAO,EAAE;gBACP,qBAAY,CAAC,UAAU,CAAC,mBAAU,CAAC;gBACnC,GAAG,CAAC,gBAAgB,CAAC,OAAO,IAAI,EAAE,CAAC;aACpC;SACF,CAAC;IACJ,CAAC;CACF,CAAA;AApDY,sDAAqB;gCAArB,qBAAqB;IADjC,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,qBAAqB,CAoDjC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Repository } from 'typeorm';
|
|
2
|
+
import { AuthAccountRepository, CredentialAccount } from '../../application/ports/auth-account.repository';
|
|
3
|
+
import { AccountEntity } from '../entities/account.entity';
|
|
4
|
+
export declare class TypeormAuthAccountRepository implements AuthAccountRepository {
|
|
5
|
+
private readonly accountRepository;
|
|
6
|
+
constructor(accountRepository: Repository<AccountEntity>);
|
|
7
|
+
findCredentialAccountByUserId(userId: string): Promise<CredentialAccount | null>;
|
|
8
|
+
upsertCredentialAccount(input: {
|
|
9
|
+
userId: string;
|
|
10
|
+
passwordHash: string;
|
|
11
|
+
createdAt?: Date;
|
|
12
|
+
updatedAt?: Date;
|
|
13
|
+
}): Promise<CredentialAccount>;
|
|
14
|
+
}
|