@volontariapp/domain-user 2.3.5-snap-effd3b6 → 2.3.5-snap-7ff4433
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/CHANGELOG.md +2 -0
- package/dist/entities/user.entity.d.ts +3 -1
- package/dist/entities/user.entity.d.ts.map +1 -1
- package/dist/entities/user.entity.js +41 -0
- package/dist/entities/user.entity.js.map +1 -1
- package/dist/models/mapper.d.ts +2 -0
- package/dist/models/mapper.d.ts.map +1 -0
- package/dist/models/mapper.js +36 -0
- package/dist/models/mapper.js.map +1 -0
- package/dist/models/user.model.js +3 -3
- package/dist/models/user.model.js.map +1 -1
- package/dist/repositories/index.d.ts +4 -0
- package/dist/repositories/index.d.ts.map +1 -0
- package/dist/repositories/index.js +4 -0
- package/dist/repositories/index.js.map +1 -0
- package/dist/repositories/interfaces/badge.repository.d.ts +11 -0
- package/dist/repositories/interfaces/badge.repository.d.ts.map +1 -0
- package/dist/repositories/interfaces/badge.repository.js +2 -0
- package/dist/repositories/interfaces/badge.repository.js.map +1 -0
- package/dist/repositories/interfaces/index.d.ts +3 -0
- package/dist/repositories/interfaces/index.d.ts.map +1 -0
- package/dist/repositories/interfaces/index.js +3 -0
- package/dist/repositories/interfaces/index.js.map +1 -0
- package/dist/repositories/interfaces/user.repository.d.ts +16 -0
- package/dist/repositories/interfaces/user.repository.d.ts.map +1 -0
- package/dist/repositories/interfaces/user.repository.js +2 -0
- package/dist/repositories/interfaces/user.repository.js.map +1 -0
- package/dist/repositories/postgres-badge.repository.d.ts +12 -0
- package/dist/repositories/postgres-badge.repository.d.ts.map +1 -0
- package/dist/repositories/postgres-badge.repository.js +38 -0
- package/dist/repositories/postgres-badge.repository.js.map +1 -0
- package/dist/repositories/postgres-user.repository.d.ts +23 -0
- package/dist/repositories/postgres-user.repository.d.ts.map +1 -0
- package/dist/repositories/postgres-user.repository.js +96 -0
- package/dist/repositories/postgres-user.repository.js.map +1 -0
- package/dist/services/auth.service.d.ts +29 -0
- package/dist/services/auth.service.d.ts.map +1 -0
- package/dist/services/auth.service.js +93 -0
- package/dist/services/auth.service.js.map +1 -0
- package/dist/services/badge.service.d.ts +15 -0
- package/dist/services/badge.service.d.ts.map +1 -0
- package/dist/services/badge.service.js +139 -0
- package/dist/services/badge.service.js.map +1 -0
- package/dist/services/user.service.d.ts +19 -0
- package/dist/services/user.service.d.ts.map +1 -0
- package/dist/services/user.service.js +188 -0
- package/dist/services/user.service.js.map +1 -0
- package/dist/test/__test-utils__/factories/badge.factory.d.ts +7 -0
- package/dist/test/__test-utils__/factories/badge.factory.d.ts.map +1 -0
- package/dist/test/__test-utils__/factories/badge.factory.js +29 -0
- package/dist/test/__test-utils__/factories/badge.factory.js.map +1 -0
- package/dist/test/__test-utils__/factories/commands.factory.d.ts +6 -0
- package/dist/test/__test-utils__/factories/commands.factory.d.ts.map +1 -0
- package/dist/test/__test-utils__/factories/commands.factory.js +24 -0
- package/dist/test/__test-utils__/factories/commands.factory.js.map +1 -0
- package/dist/test/__test-utils__/factories/user.factory.d.ts +8 -0
- package/dist/test/__test-utils__/factories/user.factory.d.ts.map +1 -0
- package/dist/test/__test-utils__/factories/user.factory.js +42 -0
- package/dist/test/__test-utils__/factories/user.factory.js.map +1 -0
- package/dist/test/__test-utils__/mocks/badge.repository.mock.d.ts +4 -0
- package/dist/test/__test-utils__/mocks/badge.repository.mock.d.ts.map +1 -0
- package/dist/test/__test-utils__/mocks/badge.repository.mock.js +11 -0
- package/dist/test/__test-utils__/mocks/badge.repository.mock.js.map +1 -0
- package/dist/test/__test-utils__/mocks/user.repository.mock.d.ts +4 -0
- package/dist/test/__test-utils__/mocks/user.repository.mock.d.ts.map +1 -0
- package/dist/test/__test-utils__/mocks/user.repository.mock.js +16 -0
- package/dist/test/__test-utils__/mocks/user.repository.mock.js.map +1 -0
- package/dist/test/data-source.d.ts +8 -0
- package/dist/test/data-source.d.ts.map +1 -0
- package/dist/test/data-source.js +36 -0
- package/dist/test/data-source.js.map +1 -0
- package/dist/test/integration/postgres-badge.repository.int.spec.d.ts +2 -0
- package/dist/test/integration/postgres-badge.repository.int.spec.d.ts.map +1 -0
- package/dist/test/integration/postgres-badge.repository.int.spec.js +129 -0
- package/dist/test/integration/postgres-badge.repository.int.spec.js.map +1 -0
- package/dist/test/integration/postgres-user.repository.int.spec.d.ts +2 -0
- package/dist/test/integration/postgres-user.repository.int.spec.d.ts.map +1 -0
- package/dist/test/integration/postgres-user.repository.int.spec.js +222 -0
- package/dist/test/integration/postgres-user.repository.int.spec.js.map +1 -0
- package/dist/test/migrations/1776334421317-InitialUserSchema.d.ts +7 -0
- package/dist/test/migrations/1776334421317-InitialUserSchema.d.ts.map +1 -0
- package/dist/test/migrations/1776334421317-InitialUserSchema.js +58 -0
- package/dist/test/migrations/1776334421317-InitialUserSchema.js.map +1 -0
- package/dist/test/setup.d.ts +2 -0
- package/dist/test/setup.d.ts.map +1 -0
- package/dist/test/setup.js +2 -0
- package/dist/test/setup.js.map +1 -0
- package/dist/test/unit/auth.service.unit.spec.d.ts +2 -0
- package/dist/test/unit/auth.service.unit.spec.d.ts.map +1 -0
- package/dist/test/unit/auth.service.unit.spec.js +236 -0
- package/dist/test/unit/auth.service.unit.spec.js.map +1 -0
- package/dist/test/unit/badge.service.unit.spec.d.ts +2 -0
- package/dist/test/unit/badge.service.unit.spec.d.ts.map +1 -0
- package/dist/test/unit/badge.service.unit.spec.js +120 -0
- package/dist/test/unit/badge.service.unit.spec.js.map +1 -0
- package/dist/test/unit/mapper.unit.spec.d.ts +2 -0
- package/dist/test/unit/mapper.unit.spec.d.ts.map +1 -0
- package/dist/test/unit/mapper.unit.spec.js +358 -0
- package/dist/test/unit/mapper.unit.spec.js.map +1 -0
- package/dist/test/unit/user.service.unit.spec.d.ts +2 -0
- package/dist/test/unit/user.service.unit.spec.d.ts.map +1 -0
- package/dist/test/unit/user.service.unit.spec.js +480 -0
- package/dist/test/unit/user.service.unit.spec.js.map +1 -0
- package/package.json +16 -4
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { BadgeEntity } from './badge.entity.js';
|
|
2
|
-
import
|
|
2
|
+
import { UserRoles } from '@volontariapp/shared';
|
|
3
3
|
export declare class UserEntity {
|
|
4
4
|
id: string;
|
|
5
5
|
email: string;
|
|
@@ -10,5 +10,7 @@ export declare class UserEntity {
|
|
|
10
10
|
role: UserRoles;
|
|
11
11
|
totalImpactScore: number;
|
|
12
12
|
badges: BadgeEntity[];
|
|
13
|
+
static isValidRna(rna?: string): boolean;
|
|
14
|
+
static create(data: Partial<UserEntity>): UserEntity;
|
|
13
15
|
}
|
|
14
16
|
//# sourceMappingURL=user.entity.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.entity.d.ts","sourceRoot":"","sources":["../../src/entities/user.entity.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"user.entity.d.ts","sourceRoot":"","sources":["../../src/entities/user.entity.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAYjD,qBAAa,UAAU;IACrB,EAAE,EAAG,MAAM,CAAC;IACZ,KAAK,EAAG,MAAM,CAAC;IACf,MAAM,EAAG,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,EAAG,SAAS,CAAC;IACjB,gBAAgB,EAAG,MAAM,CAAC;IAC1B,MAAM,EAAG,WAAW,EAAE,CAAC;IAEvB,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO;IAMxC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,UAAU,CAAC,GAAG,UAAU;CAsBrD"}
|
|
@@ -1,3 +1,13 @@
|
|
|
1
|
+
import { INVALID_RNA } from '@volontariapp/errors-nest';
|
|
2
|
+
import { UserRoles } from '@volontariapp/shared';
|
|
3
|
+
const ADJECTIVES = ['Green', 'Social', 'Eco', 'Solidary', 'Active', 'Bright', 'Kind', 'Wild'];
|
|
4
|
+
const NOUNS = ['Hero', 'Leaf', 'Heart', 'Action', 'Seed', 'Root', 'Planet', 'Citizen'];
|
|
5
|
+
const generateRandomPseudo = () => {
|
|
6
|
+
const adj = ADJECTIVES[Math.floor(Math.random() * ADJECTIVES.length)];
|
|
7
|
+
const noun = NOUNS[Math.floor(Math.random() * NOUNS.length)];
|
|
8
|
+
const suffix = Math.floor(100 + Math.random() * 900);
|
|
9
|
+
return `${adj}${noun}${suffix.toString()}`;
|
|
10
|
+
};
|
|
1
11
|
export class UserEntity {
|
|
2
12
|
id;
|
|
3
13
|
email;
|
|
@@ -8,5 +18,36 @@ export class UserEntity {
|
|
|
8
18
|
role;
|
|
9
19
|
totalImpactScore;
|
|
10
20
|
badges;
|
|
21
|
+
static isValidRna(rna) {
|
|
22
|
+
if (rna == null)
|
|
23
|
+
return true;
|
|
24
|
+
const rnaRegex = /^W[0-9]{9}$/;
|
|
25
|
+
return rnaRegex.test(rna);
|
|
26
|
+
}
|
|
27
|
+
static create(data) {
|
|
28
|
+
const user = new UserEntity();
|
|
29
|
+
Object.assign(user, data);
|
|
30
|
+
user.badges = data.badges ?? [];
|
|
31
|
+
user.totalImpactScore = data.totalImpactScore ?? 0;
|
|
32
|
+
if (user.rna != null) {
|
|
33
|
+
if (!UserEntity.isValidRna(user.rna)) {
|
|
34
|
+
throw INVALID_RNA(user.rna);
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
user.rna = user.rna.trim().toUpperCase();
|
|
38
|
+
user.role = data.role ?? UserRoles.ORGANIZATION;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
user.role = data.role ?? UserRoles.VOLUNTEER;
|
|
43
|
+
}
|
|
44
|
+
if (data.pseudo != null) {
|
|
45
|
+
user.pseudo = data.pseudo.trim();
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
user.pseudo = generateRandomPseudo();
|
|
49
|
+
}
|
|
50
|
+
return user;
|
|
51
|
+
}
|
|
11
52
|
}
|
|
12
53
|
//# sourceMappingURL=user.entity.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.entity.js","sourceRoot":"","sources":["../../src/entities/user.entity.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"user.entity.js","sourceRoot":"","sources":["../../src/entities/user.entity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAExD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEjD,MAAM,UAAU,GAAG,CAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;AAC9F,MAAM,KAAK,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;AAEvF,MAAM,oBAAoB,GAAG,GAAW,EAAE;IACxC,MAAM,GAAG,GAAG,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;IACtE,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IAC7D,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,GAAG,CAAC,CAAC;IACrD,OAAO,GAAG,GAAG,GAAG,IAAI,GAAG,MAAM,CAAC,QAAQ,EAAE,EAAE,CAAC;AAC7C,CAAC,CAAC;AAEF,MAAM,OAAO,UAAU;IACrB,EAAE,CAAU;IACZ,KAAK,CAAU;IACf,MAAM,CAAU;IAChB,QAAQ,CAAU;IAClB,GAAG,CAAU;IACb,GAAG,CAAU;IACb,IAAI,CAAa;IACjB,gBAAgB,CAAU;IAC1B,MAAM,CAAiB;IAEvB,MAAM,CAAC,UAAU,CAAC,GAAY;QAC5B,IAAI,GAAG,IAAI,IAAI;YAAE,OAAO,IAAI,CAAC;QAC7B,MAAM,QAAQ,GAAG,aAAa,CAAC;QAC/B,OAAO,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED,MAAM,CAAC,MAAM,CAAC,IAAyB;QACrC,MAAM,IAAI,GAAG,IAAI,UAAU,EAAE,CAAC;QAC9B,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC;QAChC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,IAAI,CAAC,CAAC;QACnD,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;gBACrC,MAAM,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC9B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;gBACzC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,SAAS,CAAC,YAAY,CAAC;YAClD,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,SAAS,CAAC,SAAS,CAAC;QAC/C,CAAC;QACD,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,EAAE,CAAC;YACxB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,GAAG,oBAAoB,EAAE,CAAC;QACvC,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mapper.d.ts","sourceRoot":"","sources":["../../src/models/mapper.ts"],"names":[],"mappings":"AAOA,wBAAgB,oBAAoB,SA8BnC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { databaseMapper } from '@volontariapp/database';
|
|
2
|
+
import { UserEntity } from '../entities/user.entity.js';
|
|
3
|
+
import { UserModel } from './user.model.js';
|
|
4
|
+
import { BadgeEntity } from '../entities/badge.entity.js';
|
|
5
|
+
import { BadgeModel } from './badge.model.js';
|
|
6
|
+
export function registerUserMappings() {
|
|
7
|
+
databaseMapper.registerBidirectional(UserEntity, UserModel, {
|
|
8
|
+
exclude: ['badges', 'userBadges', 'passwordHash'],
|
|
9
|
+
overridesAtoB: [
|
|
10
|
+
{
|
|
11
|
+
field: 'role',
|
|
12
|
+
resolve: (source) => source.role,
|
|
13
|
+
},
|
|
14
|
+
],
|
|
15
|
+
overridesBtoA: [
|
|
16
|
+
{
|
|
17
|
+
field: 'role',
|
|
18
|
+
resolve: (source) => source.role,
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
field: 'badges',
|
|
22
|
+
resolve: (source) => {
|
|
23
|
+
if (!Array.isArray(source.userBadges)) {
|
|
24
|
+
return [];
|
|
25
|
+
}
|
|
26
|
+
return source.userBadges
|
|
27
|
+
.map((ub) => ub.badge)
|
|
28
|
+
.filter((b) => b !== undefined && b !== null)
|
|
29
|
+
.map((b) => databaseMapper.map(b, BadgeModel, BadgeEntity));
|
|
30
|
+
},
|
|
31
|
+
},
|
|
32
|
+
],
|
|
33
|
+
});
|
|
34
|
+
databaseMapper.registerBidirectional(BadgeEntity, BadgeModel);
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=mapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mapper.js","sourceRoot":"","sources":["../../src/models/mapper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAG9C,MAAM,UAAU,oBAAoB;IAClC,cAAc,CAAC,qBAAqB,CAAC,UAAU,EAAE,SAAS,EAAE;QAC1D,OAAO,EAAE,CAAC,QAAQ,EAAE,YAAY,EAAE,cAAc,CAAC;QACjD,aAAa,EAAE;YACb;gBACE,KAAK,EAAE,MAAM;gBACb,OAAO,EAAE,CAAC,MAAkB,EAAE,EAAE,CAAC,MAAM,CAAC,IAAc;aACvD;SACF;QAED,aAAa,EAAE;YACb;gBACE,KAAK,EAAE,MAAM;gBACb,OAAO,EAAE,CAAC,MAAiB,EAAE,EAAE,CAAC,MAAM,CAAC,IAAiB;aACzD;YACD;gBACE,KAAK,EAAE,QAAQ;gBACf,OAAO,EAAE,CAAC,MAAiB,EAAiB,EAAE;oBAC5C,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC;wBACtC,OAAO,EAAE,CAAC;oBACZ,CAAC;oBACD,OAAO,MAAM,CAAC,UAAU;yBACrB,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC;yBACrB,MAAM,CAAC,CAAC,CAAC,EAAmB,EAAE,CAAE,CAAa,KAAK,SAAS,IAAK,CAAa,KAAK,IAAI,CAAC;yBACvF,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC;gBAChE,CAAC;aACF;SACF;KACF,CAAC,CAAC;IACH,cAAc,CAAC,qBAAqB,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;AAChE,CAAC"}
|
|
@@ -42,7 +42,7 @@ __decorate([
|
|
|
42
42
|
__metadata("design:type", String)
|
|
43
43
|
], UserModel.prototype, "role", void 0);
|
|
44
44
|
__decorate([
|
|
45
|
-
Column({ name:
|
|
45
|
+
Column({ name: 'password_hash' }),
|
|
46
46
|
__metadata("design:type", String)
|
|
47
47
|
], UserModel.prototype, "passwordHash", void 0);
|
|
48
48
|
__decorate([
|
|
@@ -50,7 +50,7 @@ __decorate([
|
|
|
50
50
|
__metadata("design:type", String)
|
|
51
51
|
], UserModel.prototype, "bio", void 0);
|
|
52
52
|
__decorate([
|
|
53
|
-
Column({ type: 'varchar', nullable: true }),
|
|
53
|
+
Column({ type: 'varchar', nullable: true, name: 'logo_path' }),
|
|
54
54
|
__metadata("design:type", String)
|
|
55
55
|
], UserModel.prototype, "logoPath", void 0);
|
|
56
56
|
__decorate([
|
|
@@ -58,7 +58,7 @@ __decorate([
|
|
|
58
58
|
__metadata("design:type", String)
|
|
59
59
|
], UserModel.prototype, "rna", void 0);
|
|
60
60
|
__decorate([
|
|
61
|
-
Column({ type: 'int', default: 0, name:
|
|
61
|
+
Column({ type: 'int', default: 0, name: 'total_impact_score' }),
|
|
62
62
|
__metadata("design:type", Number)
|
|
63
63
|
], UserModel.prototype, "totalImpactScore", void 0);
|
|
64
64
|
__decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.model.js","sourceRoot":"","sources":["../../src/models/user.model.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,sBAAsB,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAIrE,IAAM,SAAS,GAAf,MAAM,SAAS;IAEpB,EAAE,CAAU;IAGZ,KAAK,CAAU;IAGf,KAAK,CAAU;IAGf,MAAM,CAAU;IAGhB,IAAI,CAAU;IAGd,YAAY,CAAU;IAGtB,GAAG,CAAU;IAGb,QAAQ,CAAU;IAGlB,GAAG,CAAU;IAGb,gBAAgB,CAAU;IAG1B,UAAU,CAAoB;CAC/B,CAAA;AA/BC;IADC,sBAAsB,CAAC,MAAM,CAAC;;qCACnB;AAGZ;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;;wCACxC;AAGf;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;wCAC7B;AAGf;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;;yCACzB;AAGhB;IADC,MAAM,EAAE;;uCACK;AAGd;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,eAAe,
|
|
1
|
+
{"version":3,"file":"user.model.js","sourceRoot":"","sources":["../../src/models/user.model.ts"],"names":[],"mappings":";;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,sBAAsB,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAIrE,IAAM,SAAS,GAAf,MAAM,SAAS;IAEpB,EAAE,CAAU;IAGZ,KAAK,CAAU;IAGf,KAAK,CAAU;IAGf,MAAM,CAAU;IAGhB,IAAI,CAAU;IAGd,YAAY,CAAU;IAGtB,GAAG,CAAU;IAGb,QAAQ,CAAU;IAGlB,GAAG,CAAU;IAGb,gBAAgB,CAAU;IAG1B,UAAU,CAAoB;CAC/B,CAAA;AA/BC;IADC,sBAAsB,CAAC,MAAM,CAAC;;qCACnB;AAGZ;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;;wCACxC;AAGf;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;wCAC7B;AAGf;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;;yCACzB;AAGhB;IADC,MAAM,EAAE;;uCACK;AAGd;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC;;+CACZ;AAGtB;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;sCAC5B;AAGb;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;;2CAC7C;AAGlB;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;sCAC/B;AAGb;IADC,MAAM,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,oBAAoB,EAAE,CAAC;;mDACtC;AAG1B;IADC,SAAS,CAAC,gBAAgB,EAAE,MAAM,CAAC;;6CACN;AAhCnB,SAAS;IADrB,MAAM,CAAC,OAAO,CAAC;GACH,SAAS,CAiCrB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/repositories/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AAEtC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,+BAA+B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/repositories/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AAEtC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { BadgeEntity } from "../../entities/badge.entity.js";
|
|
2
|
+
export interface IBadgeRepository {
|
|
3
|
+
findById(id: string): Promise<BadgeEntity | null>;
|
|
4
|
+
findManyByIds(ids: string[]): Promise<BadgeEntity[]>;
|
|
5
|
+
findBySlug(slug: string): Promise<BadgeEntity | null>;
|
|
6
|
+
findAll(): Promise<BadgeEntity[]>;
|
|
7
|
+
create(badgeData: Partial<BadgeEntity>): Promise<BadgeEntity>;
|
|
8
|
+
update(id: string, badgeData: Partial<BadgeEntity>): Promise<BadgeEntity | null>;
|
|
9
|
+
delete(id: string): Promise<boolean>;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=badge.repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"badge.repository.d.ts","sourceRoot":"","sources":["../../../src/repositories/interfaces/badge.repository.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAElE,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;IAClD,aAAa,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;IACrD,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;IACtD,OAAO,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;IAClC,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAC9D,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;IACjF,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACtC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"badge.repository.js","sourceRoot":"","sources":["../../../src/repositories/interfaces/badge.repository.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/repositories/interfaces/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,uBAAuB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/repositories/interfaces/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,uBAAuB,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { UserEntity } from '../../entities/user.entity.js';
|
|
2
|
+
export interface IUserRepository {
|
|
3
|
+
findById(id: string): Promise<UserEntity | null>;
|
|
4
|
+
findByEmail(email: string): Promise<UserEntity | null>;
|
|
5
|
+
findByRna(rna: string): Promise<UserEntity | null>;
|
|
6
|
+
findAll(limit?: number, offset?: number): Promise<[UserEntity[], number]>;
|
|
7
|
+
create(user: Partial<UserEntity>): Promise<UserEntity>;
|
|
8
|
+
update(id: string, data: Partial<UserEntity>): Promise<UserEntity | null>;
|
|
9
|
+
delete(id: string): Promise<boolean>;
|
|
10
|
+
addBadgeToUser(userId: string, badgeId: string): Promise<void>;
|
|
11
|
+
removeBadgeFromUser(userId: string, badgeId: string): Promise<void>;
|
|
12
|
+
incrementImpactScore(userId: string, score: number): Promise<void>;
|
|
13
|
+
createWithHashedPassword(user: Partial<UserEntity>, password: string): Promise<UserEntity>;
|
|
14
|
+
findPasswordHashByEmail(email: string): Promise<string | null>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=user.repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.repository.d.ts","sourceRoot":"","sources":["../../../src/repositories/interfaces/user.repository.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAEhE,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;IACjD,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;IACvD,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;IACnD,OAAO,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC;IAC1E,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IACvD,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;IAC1E,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IACrC,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/D,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACpE,oBAAoB,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACnE,wBAAwB,CAAC,IAAI,EAAE,OAAO,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3F,uBAAuB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;CAChE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user.repository.js","sourceRoot":"","sources":["../../../src/repositories/interfaces/user.repository.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { BaseRepository } from '@volontariapp/database';
|
|
2
|
+
import type { Repository } from '@volontariapp/database';
|
|
3
|
+
import { BadgeModel } from '../models/badge.model.js';
|
|
4
|
+
import { BadgeEntity } from '../entities/badge.entity.js';
|
|
5
|
+
import { IBadgeRepository } from './interfaces/badge.repository.js';
|
|
6
|
+
export declare class PostgresBadgeRepository extends BaseRepository<BadgeModel, BadgeEntity> implements IBadgeRepository {
|
|
7
|
+
constructor(repository: Repository<BadgeModel>);
|
|
8
|
+
findManyByIds(ids: string[]): Promise<BadgeEntity[]>;
|
|
9
|
+
findBySlug(slug: string): Promise<BadgeEntity | null>;
|
|
10
|
+
findAll(): Promise<BadgeEntity[]>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=postgres-badge.repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-badge.repository.d.ts","sourceRoot":"","sources":["../../src/repositories/postgres-badge.repository.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAGpE,qBACa,uBACX,SAAQ,cAAc,CAAC,UAAU,EAAE,WAAW,CAC9C,YAAW,gBAAgB;gBACe,UAAU,EAAE,UAAU,CAAC,UAAU,CAAC;IAGtE,aAAa,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;IAGpD,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IAGrD,OAAO,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;CAItC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
11
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
12
|
+
};
|
|
13
|
+
import { Injectable } from '@nestjs/common';
|
|
14
|
+
import { BaseRepository } from '@volontariapp/database';
|
|
15
|
+
import { BadgeModel } from '../models/badge.model.js';
|
|
16
|
+
import { BadgeEntity } from '../entities/badge.entity.js';
|
|
17
|
+
import { InjectRepository } from '@nestjs/typeorm';
|
|
18
|
+
let PostgresBadgeRepository = class PostgresBadgeRepository extends BaseRepository {
|
|
19
|
+
constructor(repository) {
|
|
20
|
+
super(repository, BadgeEntity, BadgeModel);
|
|
21
|
+
}
|
|
22
|
+
async findManyByIds(ids) {
|
|
23
|
+
return this.findByIds(ids);
|
|
24
|
+
}
|
|
25
|
+
async findBySlug(slug) {
|
|
26
|
+
return this.findOne({ slug });
|
|
27
|
+
}
|
|
28
|
+
async findAll() {
|
|
29
|
+
return this.find();
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
PostgresBadgeRepository = __decorate([
|
|
33
|
+
Injectable(),
|
|
34
|
+
__param(0, InjectRepository(BadgeModel)),
|
|
35
|
+
__metadata("design:paramtypes", [Function])
|
|
36
|
+
], PostgresBadgeRepository);
|
|
37
|
+
export { PostgresBadgeRepository };
|
|
38
|
+
//# sourceMappingURL=postgres-badge.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-badge.repository.js","sourceRoot":"","sources":["../../src/repositories/postgres-badge.repository.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAExD,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAG5C,IAAM,uBAAuB,GAA7B,MAAM,uBACX,SAAQ,cAAuC;IAE/C,YAA0C,UAAkC;QAC1E,KAAK,CAAC,UAAU,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;IAC7C,CAAC;IACD,KAAK,CAAC,aAAa,CAAC,GAAa;QAC/B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAC7B,CAAC;IACD,KAAK,CAAC,UAAU,CAAC,IAAY;QAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;IAChC,CAAC;IACD,KAAK,CAAC,OAAO;QACX,OAAO,IAAI,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;CAEA,CAAA;AAhBU,uBAAuB;IADnC,UAAU,EAAE;IAIE,WAAA,gBAAgB,CAAC,UAAU,CAAC,CAAA;;GAH9B,uBAAuB,CAgBjC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { Repository } from '@volontariapp/database';
|
|
2
|
+
import { BaseRepository } from '@volontariapp/database';
|
|
3
|
+
import type { DeepPartial } from 'typeorm';
|
|
4
|
+
import { UserModel } from '../models/user.model.js';
|
|
5
|
+
import { UserEntity } from '../entities/user.entity.js';
|
|
6
|
+
import { IUserRepository } from './interfaces/user.repository.js';
|
|
7
|
+
export declare const EMAIL_ENCRYPTION_SECRET = "EMAIL_ENCRYPTION_SECRET";
|
|
8
|
+
export declare class PostgresUserRepository extends BaseRepository<UserModel, UserEntity> implements IUserRepository {
|
|
9
|
+
private readonly emailSecret;
|
|
10
|
+
constructor(repository: Repository<UserModel>, emailSecret: string);
|
|
11
|
+
toEntity(model: UserModel): UserEntity;
|
|
12
|
+
protected toModel(entity: Partial<UserEntity>): DeepPartial<UserModel>;
|
|
13
|
+
private encryptEmail;
|
|
14
|
+
findByEmail(email: string): Promise<UserEntity | null>;
|
|
15
|
+
findByRna(rna: string): Promise<UserEntity | null>;
|
|
16
|
+
findAll(limit?: number, offset?: number): Promise<[UserEntity[], number]>;
|
|
17
|
+
addBadgeToUser(userId: string, badgeId: string): Promise<void>;
|
|
18
|
+
removeBadgeFromUser(userId: string, badgeId: string): Promise<void>;
|
|
19
|
+
incrementImpactScore(userId: string, score: number): Promise<void>;
|
|
20
|
+
createWithHashedPassword(user: Partial<UserEntity>, password: string): Promise<UserEntity>;
|
|
21
|
+
findPasswordHashByEmail(email: string): Promise<string | null>;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=postgres-user.repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-user.repository.d.ts","sourceRoot":"","sources":["../../src/repositories/postgres-user.repository.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAGlE,eAAO,MAAM,uBAAuB,4BAA4B,CAAC;AAEjE,qBACa,sBACX,SAAQ,cAAc,CAAC,SAAS,EAAE,UAAU,CAC5C,YAAW,eAAe;IAIS,OAAO,CAAC,QAAQ,CAAC,WAAW;gBADhC,UAAU,EAAE,UAAU,CAAC,SAAS,CAAC,EACZ,WAAW,EAAE,MAAM;IAKvD,QAAQ,CAAC,KAAK,EAAE,SAAS,GAAG,UAAU;cAMnC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,GAAG,WAAW,CAAC,SAAS,CAAC;IAQ/E,OAAO,CAAC,YAAY;IAId,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IAItD,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;IAIlD,OAAO,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE,MAAM,CAAC,CAAC;IAQzE,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ9D,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQnE,oBAAoB,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKlE,wBAAwB,CAAC,IAAI,EAAE,OAAO,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAU1F,uBAAuB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;CAOrE"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
11
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
12
|
+
};
|
|
13
|
+
import { Injectable, Inject } from '@nestjs/common';
|
|
14
|
+
import { InjectRepository } from '@nestjs/typeorm';
|
|
15
|
+
import { BaseRepository } from '@volontariapp/database';
|
|
16
|
+
import { UserModel } from '../models/user.model.js';
|
|
17
|
+
import { UserEntity } from '../entities/user.entity.js';
|
|
18
|
+
import { encryptDeterministic, decrypt } from '@volontariapp/crypto';
|
|
19
|
+
export const EMAIL_ENCRYPTION_SECRET = 'EMAIL_ENCRYPTION_SECRET';
|
|
20
|
+
let PostgresUserRepository = class PostgresUserRepository extends BaseRepository {
|
|
21
|
+
emailSecret;
|
|
22
|
+
constructor(repository, emailSecret) {
|
|
23
|
+
super(repository, UserEntity, UserModel);
|
|
24
|
+
this.emailSecret = emailSecret;
|
|
25
|
+
}
|
|
26
|
+
toEntity(model) {
|
|
27
|
+
const entity = super.toEntity(model);
|
|
28
|
+
entity.email = decrypt(model.email, this.emailSecret);
|
|
29
|
+
return entity;
|
|
30
|
+
}
|
|
31
|
+
toModel(entity) {
|
|
32
|
+
const model = super.toModel(entity);
|
|
33
|
+
if (entity.email != null) {
|
|
34
|
+
model.email = encryptDeterministic(entity.email, this.emailSecret);
|
|
35
|
+
}
|
|
36
|
+
return model;
|
|
37
|
+
}
|
|
38
|
+
encryptEmail(email) {
|
|
39
|
+
return encryptDeterministic(email, this.emailSecret);
|
|
40
|
+
}
|
|
41
|
+
async findByEmail(email) {
|
|
42
|
+
return this.findOne({ email: this.encryptEmail(email) });
|
|
43
|
+
}
|
|
44
|
+
async findByRna(rna) {
|
|
45
|
+
return this.findOne({ rna });
|
|
46
|
+
}
|
|
47
|
+
async findAll(limit, offset) {
|
|
48
|
+
const [models, total] = await this.repository.findAndCount({
|
|
49
|
+
take: limit,
|
|
50
|
+
skip: offset,
|
|
51
|
+
});
|
|
52
|
+
return [this.toEntities(models), total];
|
|
53
|
+
}
|
|
54
|
+
async addBadgeToUser(userId, badgeId) {
|
|
55
|
+
const userBadgeRepo = this.repository.manager.getRepository('UserBadgeModel');
|
|
56
|
+
await userBadgeRepo.save({
|
|
57
|
+
user: { id: userId },
|
|
58
|
+
badge: { id: badgeId },
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
async removeBadgeFromUser(userId, badgeId) {
|
|
62
|
+
const userBadgeRepo = this.repository.manager.getRepository('UserBadgeModel');
|
|
63
|
+
await userBadgeRepo.delete({
|
|
64
|
+
user: { id: userId },
|
|
65
|
+
badge: { id: badgeId },
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
async incrementImpactScore(userId, score) {
|
|
69
|
+
const where = this.buildIdWhere(userId);
|
|
70
|
+
await this.increment(where, 'totalImpactScore', score);
|
|
71
|
+
}
|
|
72
|
+
async createWithHashedPassword(user, password) {
|
|
73
|
+
const model = this.repository.create({
|
|
74
|
+
...user,
|
|
75
|
+
email: user.email != null ? this.encryptEmail(user.email) : undefined,
|
|
76
|
+
passwordHash: password,
|
|
77
|
+
});
|
|
78
|
+
const savedModel = await this.repository.save(model);
|
|
79
|
+
return this.toEntity(savedModel);
|
|
80
|
+
}
|
|
81
|
+
async findPasswordHashByEmail(email) {
|
|
82
|
+
const user = await this.repository.findOne({
|
|
83
|
+
where: { email: this.encryptEmail(email) },
|
|
84
|
+
select: ['passwordHash'],
|
|
85
|
+
});
|
|
86
|
+
return user ? user.passwordHash : null;
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
PostgresUserRepository = __decorate([
|
|
90
|
+
Injectable(),
|
|
91
|
+
__param(0, InjectRepository(UserModel)),
|
|
92
|
+
__param(1, Inject(EMAIL_ENCRYPTION_SECRET)),
|
|
93
|
+
__metadata("design:paramtypes", [Function, String])
|
|
94
|
+
], PostgresUserRepository);
|
|
95
|
+
export { PostgresUserRepository };
|
|
96
|
+
//# sourceMappingURL=postgres-user.repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-user.repository.js","sourceRoot":"","sources":["../../src/repositories/postgres-user.repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import * as repositories from '../repositories/index.js';
|
|
2
|
+
import { JwtService } from '@volontariapp/auth';
|
|
3
|
+
export interface SignUpData {
|
|
4
|
+
email: string;
|
|
5
|
+
pseudo?: string;
|
|
6
|
+
password: string;
|
|
7
|
+
organisationInfo?: {
|
|
8
|
+
rna: string;
|
|
9
|
+
};
|
|
10
|
+
bio?: string;
|
|
11
|
+
logoPath?: string;
|
|
12
|
+
}
|
|
13
|
+
export interface LoginData {
|
|
14
|
+
email: string;
|
|
15
|
+
password: string;
|
|
16
|
+
}
|
|
17
|
+
export type AuthResult = {
|
|
18
|
+
accessToken: string;
|
|
19
|
+
refreshToken: string;
|
|
20
|
+
};
|
|
21
|
+
export declare class AuthService {
|
|
22
|
+
private readonly userRepository;
|
|
23
|
+
private readonly jwtService;
|
|
24
|
+
private readonly logger;
|
|
25
|
+
constructor(userRepository: repositories.IUserRepository, jwtService: JwtService);
|
|
26
|
+
signUp(command: SignUpData): Promise<AuthResult>;
|
|
27
|
+
logIn(command: LoginData): Promise<AuthResult>;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=auth.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.service.d.ts","sourceRoot":"","sources":["../../src/services/auth.service.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,YAAY,MAAM,0BAA0B,CAAC;AAUzD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAEhD,MAAM,WAAW,UAAU;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,gBAAgB,CAAC,EAAE;QACjB,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;IACF,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,MAAM,UAAU,GAAG;IACvB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF,qBACa,WAAW;IAKpB,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAL7B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA6C;gBAIjD,cAAc,EAAE,YAAY,CAAC,eAAe,EAC5C,UAAU,EAAE,UAAU;IAGnC,MAAM,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;IAyChD,KAAK,CAAC,OAAO,EAAE,SAAS,GAAG,OAAO,CAAC,UAAU,CAAC;CAsBrD"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
|
+
};
|
|
10
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
11
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
12
|
+
};
|
|
13
|
+
var AuthService_1;
|
|
14
|
+
import { Inject, Injectable } from '@nestjs/common';
|
|
15
|
+
import { Logger } from '@volontariapp/logger';
|
|
16
|
+
import * as repositories from '../repositories/index.js';
|
|
17
|
+
import { UserEntity } from '../entities/user.entity.js';
|
|
18
|
+
import { DATABASE_ERROR, INVALID_RNA, USER_ALREADY_EXISTS, USER_NOT_FOUND, } from '@volontariapp/errors-nest';
|
|
19
|
+
import { hashPassword, verifyPassword, calculateHash } from '@volontariapp/crypto';
|
|
20
|
+
import { isBaseError, isDatabaseDriverError } from '@volontariapp/errors';
|
|
21
|
+
import { JwtService } from '@volontariapp/auth';
|
|
22
|
+
let AuthService = AuthService_1 = class AuthService {
|
|
23
|
+
userRepository;
|
|
24
|
+
jwtService;
|
|
25
|
+
logger = new Logger({ context: AuthService_1.name });
|
|
26
|
+
constructor(userRepository, jwtService) {
|
|
27
|
+
this.userRepository = userRepository;
|
|
28
|
+
this.jwtService = jwtService;
|
|
29
|
+
}
|
|
30
|
+
async signUp(command) {
|
|
31
|
+
const existingUser = await this.userRepository.findByEmail(command.email);
|
|
32
|
+
if (existingUser) {
|
|
33
|
+
this.logger.warn(`Attempt to sign up with already registered email hash: ${calculateHash(command.email).slice(0, 8)}`);
|
|
34
|
+
throw USER_ALREADY_EXISTS(command.email);
|
|
35
|
+
}
|
|
36
|
+
const user = UserEntity.create({
|
|
37
|
+
email: command.email,
|
|
38
|
+
pseudo: command.pseudo,
|
|
39
|
+
rna: command.organisationInfo?.rna,
|
|
40
|
+
bio: command.bio,
|
|
41
|
+
logoPath: command.logoPath,
|
|
42
|
+
});
|
|
43
|
+
const hashedPassword = hashPassword(command.password);
|
|
44
|
+
try {
|
|
45
|
+
if (user.rna != null && !UserEntity.isValidRna(user.rna)) {
|
|
46
|
+
this.logger.warn(`Invalid RNA ${user.rna} for new user`);
|
|
47
|
+
throw INVALID_RNA(user.rna);
|
|
48
|
+
}
|
|
49
|
+
const userEntity = await this.userRepository.createWithHashedPassword(user, hashedPassword);
|
|
50
|
+
const authUser = { id: userEntity.id, email: userEntity.email, role: userEntity.role };
|
|
51
|
+
const [accessToken, refreshToken] = await Promise.all([
|
|
52
|
+
this.jwtService.signAccessToken(authUser),
|
|
53
|
+
this.jwtService.signRefreshToken(authUser),
|
|
54
|
+
]);
|
|
55
|
+
return { accessToken, refreshToken };
|
|
56
|
+
}
|
|
57
|
+
catch (error) {
|
|
58
|
+
if (isBaseError(error))
|
|
59
|
+
throw error;
|
|
60
|
+
if (isDatabaseDriverError(error) && error.code === '23505') {
|
|
61
|
+
throw USER_ALREADY_EXISTS(user.email);
|
|
62
|
+
}
|
|
63
|
+
const err = error;
|
|
64
|
+
this.logger.error(`Error while creating user: ${err.message}`);
|
|
65
|
+
throw DATABASE_ERROR('creating user', err.message);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
async logIn(command) {
|
|
69
|
+
const user = await this.userRepository.findByEmail(command.email);
|
|
70
|
+
if (!user) {
|
|
71
|
+
this.logger.warn(`Login attempt with non-existent email hash: ${calculateHash(command.email).slice(0, 8)}`);
|
|
72
|
+
throw USER_NOT_FOUND(command.email, 'email');
|
|
73
|
+
}
|
|
74
|
+
const passwordHash = await this.userRepository.findPasswordHashByEmail(command.email);
|
|
75
|
+
if (passwordHash == null || !verifyPassword(command.password, passwordHash)) {
|
|
76
|
+
this.logger.warn(`Invalid password attempt for email hash: ${calculateHash(command.email).slice(0, 8)}`);
|
|
77
|
+
throw USER_NOT_FOUND(command.email, 'email');
|
|
78
|
+
}
|
|
79
|
+
const authUser = { id: user.id, email: user.email, role: user.role };
|
|
80
|
+
const [accessToken, refreshToken] = await Promise.all([
|
|
81
|
+
this.jwtService.signAccessToken(authUser),
|
|
82
|
+
this.jwtService.signRefreshToken(authUser),
|
|
83
|
+
]);
|
|
84
|
+
return { accessToken, refreshToken };
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
AuthService = AuthService_1 = __decorate([
|
|
88
|
+
Injectable(),
|
|
89
|
+
__param(0, Inject(repositories.PostgresUserRepository)),
|
|
90
|
+
__metadata("design:paramtypes", [Object, JwtService])
|
|
91
|
+
], AuthService);
|
|
92
|
+
export { AuthService };
|
|
93
|
+
//# sourceMappingURL=auth.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../src/services/auth.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { IBadgeRepository } from '../repositories/index.js';
|
|
2
|
+
import { BadgeEntity } from '../entities/badge.entity.js';
|
|
3
|
+
export declare class BadgeService {
|
|
4
|
+
private readonly badgeRepository;
|
|
5
|
+
private readonly logger;
|
|
6
|
+
constructor(badgeRepository: IBadgeRepository);
|
|
7
|
+
findById(id: string): Promise<BadgeEntity>;
|
|
8
|
+
findBySlug(slug: string): Promise<BadgeEntity>;
|
|
9
|
+
findAll(): Promise<BadgeEntity[]>;
|
|
10
|
+
findManyByIds(ids: string[]): Promise<BadgeEntity[]>;
|
|
11
|
+
create(badgeData: Partial<BadgeEntity>): Promise<BadgeEntity>;
|
|
12
|
+
update(id: string, badgeData: Partial<BadgeEntity>): Promise<BadgeEntity>;
|
|
13
|
+
delete(id: string): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=badge.service.d.ts.map
|