@social.dev/server-sdk 0.0.1-alpha.2 → 0.0.1-alpha.21

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.
Files changed (104) hide show
  1. package/dist/auth/auth.controller.d.ts +2 -0
  2. package/dist/auth/auth.controller.js +26 -0
  3. package/dist/auth/auth.controller.js.map +1 -1
  4. package/dist/auth/auth.module.js +2 -0
  5. package/dist/auth/auth.module.js.map +1 -1
  6. package/dist/auth/auth.service.d.ts +4 -8
  7. package/dist/auth/auth.service.js +6 -18
  8. package/dist/auth/auth.service.js.map +1 -1
  9. package/dist/auth/dto/login-success.dto.d.ts +1 -1
  10. package/dist/auth/dto/login-success.dto.js +3 -3
  11. package/dist/auth/dto/login-success.dto.js.map +1 -1
  12. package/dist/auth/enums/auth-method.enum.d.ts +2 -2
  13. package/dist/auth/enums/auth-method.enum.js +2 -2
  14. package/dist/auth/enums/auth-method.enum.js.map +1 -1
  15. package/dist/auth/oidc/dto/requests.d.ts +6 -0
  16. package/dist/auth/oidc/dto/requests.js +47 -0
  17. package/dist/auth/oidc/dto/requests.js.map +1 -0
  18. package/dist/auth/oidc/dto/responses.js +1 -1
  19. package/dist/auth/oidc/dto/responses.js.map +1 -1
  20. package/dist/auth/oidc/oidc.controller.d.ts +6 -2
  21. package/dist/auth/oidc/oidc.controller.js +25 -17
  22. package/dist/auth/oidc/oidc.controller.js.map +1 -1
  23. package/dist/auth/oidc/oidc.module.js +2 -0
  24. package/dist/auth/oidc/oidc.module.js.map +1 -1
  25. package/dist/auth/oidc/oidc.service.d.ts +13 -7
  26. package/dist/auth/oidc/oidc.service.js +37 -30
  27. package/dist/auth/oidc/oidc.service.js.map +1 -1
  28. package/dist/auth/session/session.controller.js +3 -3
  29. package/dist/auth/session/session.controller.js.map +1 -1
  30. package/dist/auth/session/session.service.d.ts +2 -2
  31. package/dist/auth/session/session.service.js +4 -4
  32. package/dist/auth/session/session.service.js.map +1 -1
  33. package/dist/bootstrap.d.ts +1 -1
  34. package/dist/bootstrap.js +3 -1
  35. package/dist/bootstrap.js.map +1 -1
  36. package/dist/chat/chat.controller.js +4 -0
  37. package/dist/chat/chat.controller.js.map +1 -1
  38. package/dist/chat/chat.module.js +2 -0
  39. package/dist/chat/chat.module.js.map +1 -1
  40. package/dist/chat/chat.service.js.map +1 -1
  41. package/dist/common/dto/paginated-response.dto.d.ts +2 -0
  42. package/dist/common/dto/paginated-response.dto.js +14 -3
  43. package/dist/common/dto/paginated-response.dto.js.map +1 -1
  44. package/dist/common/injection-tokens.d.ts +2 -0
  45. package/dist/common/injection-tokens.js +6 -0
  46. package/dist/common/injection-tokens.js.map +1 -0
  47. package/dist/community/community.controller.d.ts +1 -2
  48. package/dist/community/community.controller.js +9 -5
  49. package/dist/community/community.controller.js.map +1 -1
  50. package/dist/community/community.service.d.ts +10 -3
  51. package/dist/community/community.service.js +30 -12
  52. package/dist/community/community.service.js.map +1 -1
  53. package/dist/configs/configs.module.js +3 -0
  54. package/dist/configs/configs.module.js.map +1 -1
  55. package/dist/configs/configs.service.d.ts +15 -0
  56. package/dist/configs/configs.service.js +14 -1
  57. package/dist/configs/configs.service.js.map +1 -1
  58. package/dist/core/context/context.store.d.ts +1 -0
  59. package/dist/core/plugin/plugin.module.js +4 -1
  60. package/dist/core/plugin/plugin.module.js.map +1 -1
  61. package/dist/db.js +0 -1
  62. package/dist/db.js.map +1 -1
  63. package/dist/file-storage/file-storage.service.d.ts +1 -1
  64. package/dist/file-storage/file-storage.service.js +6 -6
  65. package/dist/file-storage/file-storage.service.js.map +1 -1
  66. package/dist/file-storage/utils.js +1 -1
  67. package/dist/file-storage/utils.js.map +1 -1
  68. package/dist/media/entities/media.entity.js +1 -1
  69. package/dist/media/entities/media.entity.js.map +1 -1
  70. package/dist/media/media.acl.d.ts +5 -2
  71. package/dist/media/media.acl.js +3 -0
  72. package/dist/media/media.acl.js.map +1 -1
  73. package/dist/media/media.service.js +13 -12
  74. package/dist/media/media.service.js.map +1 -1
  75. package/dist/network/entities/network.entity.js +4 -1
  76. package/dist/network/entities/network.entity.js.map +1 -1
  77. package/dist/network/network.middleware.js +6 -1
  78. package/dist/network/network.middleware.js.map +1 -1
  79. package/dist/post/post.controller.d.ts +3 -2
  80. package/dist/post/post.controller.js +28 -8
  81. package/dist/post/post.controller.js.map +1 -1
  82. package/dist/post/post.service.d.ts +4 -2
  83. package/dist/post/post.service.js +8 -4
  84. package/dist/post/post.service.js.map +1 -1
  85. package/dist/tsconfig.build.tsbuildinfo +1 -1
  86. package/dist/user/user.controller.d.ts +2 -1
  87. package/dist/user/user.controller.js +9 -4
  88. package/dist/user/user.controller.js.map +1 -1
  89. package/package.json +1 -1
  90. package/dist/1756201302119-migrations.d.ts +0 -6
  91. package/dist/1756201302119-migrations.js +0 -84
  92. package/dist/1756201302119-migrations.js.map +0 -1
  93. package/dist/auth/enums/auth-methods.enum.d.ts +0 -2
  94. package/dist/auth/enums/auth-methods.enum.js +0 -7
  95. package/dist/auth/enums/auth-methods.enum.js.map +0 -1
  96. package/dist/auth/session/auth.controller.d.ts +0 -10
  97. package/dist/auth/session/auth.controller.js +0 -92
  98. package/dist/auth/session/auth.controller.js.map +0 -1
  99. package/dist/auth/session/auth.service.d.ts +0 -12
  100. package/dist/auth/session/auth.service.js +0 -46
  101. package/dist/auth/session/auth.service.js.map +0 -1
  102. package/dist/common/entities/base.repository.d.ts +0 -7
  103. package/dist/common/entities/base.repository.js +0 -32
  104. package/dist/common/entities/base.repository.js.map +0 -1
@@ -1,6 +1,8 @@
1
1
  import { AuthService } from './auth.service';
2
+ import { AuthMethodEnum } from './enums/auth-method.enum';
2
3
  export declare class AuthController {
3
4
  private authService;
4
5
  constructor(authService: AuthService);
6
+ listAuthMethod(): AuthMethodEnum[];
5
7
  getProfile(req: any): any;
6
8
  }
@@ -17,16 +17,41 @@ const openapi = require("@nestjs/swagger");
17
17
  const common_1 = require("@nestjs/common");
18
18
  const auth_service_1 = require("./auth.service");
19
19
  const auth_guard_1 = require("./auth.guard");
20
+ const auth_method_enum_1 = require("./enums/auth-method.enum");
21
+ const swagger_1 = require("@nestjs/swagger");
20
22
  let AuthController = class AuthController {
21
23
  authService;
22
24
  constructor(authService) {
23
25
  this.authService = authService;
24
26
  }
27
+ listAuthMethod() {
28
+ return this.authService.getAuthMethods();
29
+ }
25
30
  getProfile(req) {
26
31
  return req.user;
27
32
  }
28
33
  };
29
34
  exports.AuthController = AuthController;
35
+ __decorate([
36
+ (0, common_1.Get)('auth.method.list'),
37
+ (0, swagger_1.ApiOperation)({ summary: 'List available authentication methods' }),
38
+ (0, swagger_1.ApiResponse)({
39
+ status: 200,
40
+ description: 'List of available authentication methods',
41
+ schema: {
42
+ type: 'array',
43
+ items: {
44
+ type: 'string',
45
+ enum: Object.values(auth_method_enum_1.AuthMethodEnum),
46
+ },
47
+ example: [auth_method_enum_1.AuthMethodEnum.Password, auth_method_enum_1.AuthMethodEnum.Oidc],
48
+ },
49
+ }),
50
+ openapi.ApiResponse({ status: 200 }),
51
+ __metadata("design:type", Function),
52
+ __metadata("design:paramtypes", []),
53
+ __metadata("design:returntype", Array)
54
+ ], AuthController.prototype, "listAuthMethod", null);
30
55
  __decorate([
31
56
  (0, common_1.UseGuards)(auth_guard_1.AuthGuard),
32
57
  (0, common_1.Get)('auth.profile.info'),
@@ -37,6 +62,7 @@ __decorate([
37
62
  __metadata("design:returntype", void 0)
38
63
  ], AuthController.prototype, "getProfile", null);
39
64
  exports.AuthController = AuthController = __decorate([
65
+ (0, swagger_1.ApiTags)('Auth'),
40
66
  (0, common_1.Controller)(),
41
67
  __metadata("design:paramtypes", [auth_service_1.AuthService])
42
68
  ], AuthController);
@@ -1 +1 @@
1
- {"version":3,"file":"auth.controller.js","sourceRoot":"","sources":["../../src/auth/auth.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAqE;AACrE,iDAA6C;AAC7C,6CAAyC;AAGlC,IAAM,cAAc,GAApB,MAAM,cAAc;IACL;IAApB,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAIhD,UAAU,CAAY,GAAG;QACvB,OAAO,GAAG,CAAC,IAAI,CAAC;IAClB,CAAC;CACF,CAAA;AARY,wCAAc;AAKzB;IAFC,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,YAAG,EAAC,mBAAmB,CAAC;;IACb,WAAA,IAAA,gBAAO,GAAE,CAAA;;;;gDAEpB;yBAPU,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAEsB,0BAAW;GADjC,cAAc,CAQ1B"}
1
+ {"version":3,"file":"auth.controller.js","sourceRoot":"","sources":["../../src/auth/auth.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAqE;AACrE,iDAA6C;AAC7C,6CAAyC;AACzC,+DAA0D;AAC1D,6CAAqE;AAI9D,IAAM,cAAc,GAApB,MAAM,cAAc;IACL;IAApB,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAgBhD,cAAc;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,CAAC;IAC3C,CAAC;IAID,UAAU,CAAY,GAAG;QACvB,OAAO,GAAG,CAAC,IAAI,CAAC;IAClB,CAAC;CACF,CAAA;AA1BY,wCAAc;AAiBzB;IAdC,IAAA,YAAG,EAAC,kBAAkB,CAAC;IACvB,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,uCAAuC,EAAE,CAAC;IAClE,IAAA,qBAAW,EAAC;QACX,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,0CAA0C;QACvD,MAAM,EAAE;YACN,IAAI,EAAE,OAAO;YACb,KAAK,EAAE;gBACL,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,iCAAc,CAAC;aACpC;YACD,OAAO,EAAE,CAAC,iCAAc,CAAC,QAAQ,EAAE,iCAAc,CAAC,IAAI,CAAC;SACxD;KACF,CAAC;;;;;oDAGD;AAID;IAFC,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,YAAG,EAAC,mBAAmB,CAAC;;IACb,WAAA,IAAA,gBAAO,GAAE,CAAA;;;;gDAEpB;yBAzBU,cAAc;IAF1B,IAAA,iBAAO,EAAC,MAAM,CAAC;IACf,IAAA,mBAAU,GAAE;qCAEsB,0BAAW;GADjC,cAAc,CA0B1B"}
@@ -14,6 +14,7 @@ const user_module_1 = require("../user/user.module");
14
14
  const jwt_1 = require("@nestjs/jwt");
15
15
  const constants_1 = require("./constants");
16
16
  const oidc_module_1 = require("./oidc/oidc.module");
17
+ const configs_module_1 = require("../configs/configs.module");
17
18
  let AuthModule = class AuthModule {
18
19
  };
19
20
  exports.AuthModule = AuthModule;
@@ -26,6 +27,7 @@ exports.AuthModule = AuthModule = __decorate([
26
27
  secret: constants_1.jwtConstants.secret,
27
28
  signOptions: { expiresIn: '30d' },
28
29
  }),
30
+ configs_module_1.ConfigsModule,
29
31
  oidc_module_1.OidcModule,
30
32
  ],
31
33
  controllers: [auth_controller_1.AuthController],
@@ -1 +1 @@
1
- {"version":3,"file":"auth.module.js","sourceRoot":"","sources":["../../src/auth/auth.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAoD;AACpD,uDAAmD;AACnD,iDAA6C;AAC7C,qDAAgD;AAChD,qCAAwC;AACxC,2CAA2C;AAC3C,oDAAgD;AAezC,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAbtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,eAAS,CAAC,QAAQ,CAAC;gBACjB,MAAM,EAAE,IAAI;gBACZ,MAAM,EAAE,wBAAY,CAAC,MAAM;gBAC3B,WAAW,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;aAClC,CAAC;YACF,wBAAU;SACX;QACD,WAAW,EAAE,CAAC,gCAAc,CAAC;QAC7B,SAAS,EAAE,CAAC,0BAAW,CAAC;KACzB,CAAC;GACW,UAAU,CAAG"}
1
+ {"version":3,"file":"auth.module.js","sourceRoot":"","sources":["../../src/auth/auth.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAoD;AACpD,uDAAmD;AACnD,iDAA6C;AAC7C,qDAAgD;AAChD,qCAAwC;AACxC,2CAA2C;AAC3C,oDAAgD;AAChD,8DAAyD;AAgBlD,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAdtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,eAAS,CAAC,QAAQ,CAAC;gBACjB,MAAM,EAAE,IAAI;gBACZ,MAAM,EAAE,wBAAY,CAAC,MAAM;gBAC3B,WAAW,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;aAClC,CAAC;YACF,8BAAa;YACb,wBAAU;SACX;QACD,WAAW,EAAE,CAAC,gCAAc,CAAC;QAC7B,SAAS,EAAE,CAAC,0BAAW,CAAC;KACzB,CAAC;GACW,UAAU,CAAG"}
@@ -1,11 +1,7 @@
1
- import { UserService } from '../user/user.service';
2
- import { JwtService } from '@nestjs/jwt';
3
1
  import { AuthMethodEnum } from './enums/auth-method.enum';
2
+ import { ConfigsService } from '~/configs/configs.service';
4
3
  export declare class AuthService {
5
- private userService;
6
- private jwtService;
7
- constructor(userService: UserService, jwtService: JwtService);
8
- getAuthMethods(): {
9
- method: AuthMethodEnum;
10
- }[];
4
+ private configs;
5
+ constructor(configs: ConfigsService);
6
+ getAuthMethods(): AuthMethodEnum[];
11
7
  }
@@ -11,31 +11,19 @@ var __metadata = (this && this.__metadata) || function (k, v) {
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.AuthService = void 0;
13
13
  const common_1 = require("@nestjs/common");
14
- const user_service_1 = require("../user/user.service");
15
- const jwt_1 = require("@nestjs/jwt");
16
- const auth_method_enum_1 = require("./enums/auth-method.enum");
14
+ const configs_service_1 = require("../configs/configs.service");
17
15
  let AuthService = class AuthService {
18
- userService;
19
- jwtService;
20
- constructor(userService, jwtService) {
21
- this.userService = userService;
22
- this.jwtService = jwtService;
16
+ configs;
17
+ constructor(configs) {
18
+ this.configs = configs;
23
19
  }
24
20
  getAuthMethods() {
25
- return [
26
- {
27
- method: auth_method_enum_1.AuthMethodEnum.Password,
28
- },
29
- {
30
- method: auth_method_enum_1.AuthMethodEnum.Oidc,
31
- },
32
- ];
21
+ return this.configs.get('auth')?.methods || [];
33
22
  }
34
23
  };
35
24
  exports.AuthService = AuthService;
36
25
  exports.AuthService = AuthService = __decorate([
37
26
  (0, common_1.Injectable)(),
38
- __metadata("design:paramtypes", [user_service_1.UserService,
39
- jwt_1.JwtService])
27
+ __metadata("design:paramtypes", [configs_service_1.ConfigsService])
40
28
  ], AuthService);
41
29
  //# sourceMappingURL=auth.service.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../src/auth/auth.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAmE;AACnE,uDAAmD;AACnD,qCAAyC;AAEzC,+DAA0D;AAGnD,IAAM,WAAW,GAAjB,MAAM,WAAW;IAEZ;IACA;IAFV,YACU,WAAwB,EACxB,UAAsB;QADtB,gBAAW,GAAX,WAAW,CAAa;QACxB,eAAU,GAAV,UAAU,CAAY;IAC7B,CAAC;IAKJ,cAAc;QACZ,OAAO;YAEL;gBACE,MAAM,EAAE,iCAAc,CAAC,QAAQ;aAChC;YAED;gBACE,MAAM,EAAE,iCAAc,CAAC,IAAI;aAC5B;SACF,CAAC;IACJ,CAAC;CACF,CAAA;AArBY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;qCAGY,0BAAW;QACZ,gBAAU;GAHrB,WAAW,CAqBvB"}
1
+ {"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../src/auth/auth.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAmE;AAKnE,gEAA2D;AAGpD,IAAM,WAAW,GAAjB,MAAM,WAAW;IACF;IAApB,YAAoB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;IAAG,CAAC;IAK/C,cAAc;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,OAAO,IAAI,EAAE,CAAC;IACjD,CAAC;CACF,CAAA;AATY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;qCAEkB,gCAAc;GADhC,WAAW,CASvB"}
@@ -1,5 +1,5 @@
1
1
  import { UserResponseDto } from '~/user/dto/user-response.dto';
2
2
  export declare class LoginSuccessResponseDto {
3
- accessToken: string;
3
+ authToken: string;
4
4
  user: UserResponseDto;
5
5
  }
@@ -14,17 +14,17 @@ const openapi = require("@nestjs/swagger");
14
14
  const swagger_1 = require("@nestjs/swagger");
15
15
  const user_response_dto_1 = require("../../user/dto/user-response.dto");
16
16
  class LoginSuccessResponseDto {
17
- accessToken;
17
+ authToken;
18
18
  user;
19
19
  static _OPENAPI_METADATA_FACTORY() {
20
- return { accessToken: { required: true, type: () => String }, user: { required: true, type: () => require("../../user/dto/user-response.dto").UserResponseDto } };
20
+ return { authToken: { required: true, type: () => String }, user: { required: true, type: () => require("../../user/dto/user-response.dto").UserResponseDto } };
21
21
  }
22
22
  }
23
23
  exports.LoginSuccessResponseDto = LoginSuccessResponseDto;
24
24
  __decorate([
25
25
  (0, swagger_1.ApiProperty)({ description: 'The session token' }),
26
26
  __metadata("design:type", String)
27
- ], LoginSuccessResponseDto.prototype, "accessToken", void 0);
27
+ ], LoginSuccessResponseDto.prototype, "authToken", void 0);
28
28
  __decorate([
29
29
  (0, swagger_1.ApiProperty)({
30
30
  description: 'User information',
@@ -1 +1 @@
1
- {"version":3,"file":"login-success.dto.js","sourceRoot":"","sources":["../../../src/auth/dto/login-success.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,wEAA+D;AAG/D,MAAa,uBAAuB;IAElC,WAAW,CAAS;IAWpB,IAAI,CAAkB;;;;CACvB;AAdD,0DAcC;AAZC;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,mBAAmB,EAAE,CAAC;;4DAC9B;AAWpB;IATC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,kBAAkB;QAC/B,OAAO,EAAE;YACP,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,UAAU;YAChB,QAAQ,EAAE,SAAS;YACnB,OAAO,EAAE,CAAC;SACX;KACF,CAAC;8BACI,mCAAe;qDAAC"}
1
+ {"version":3,"file":"login-success.dto.js","sourceRoot":"","sources":["../../../src/auth/dto/login-success.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,wEAA+D;AAG/D,MAAa,uBAAuB;IAElC,SAAS,CAAS;IAWlB,IAAI,CAAkB;;;;CACvB;AAdD,0DAcC;AAZC;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,mBAAmB,EAAE,CAAC;;0DAChC;AAWlB;IATC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,kBAAkB;QAC/B,OAAO,EAAE;YACP,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,UAAU;YAChB,QAAQ,EAAE,SAAS;YACnB,OAAO,EAAE,CAAC;SACX;KACF,CAAC;8BACI,mCAAe;qDAAC"}
@@ -1,4 +1,4 @@
1
1
  export declare enum AuthMethodEnum {
2
- Password = 0,
3
- Oidc = 1
2
+ Password = "PASSWORD",
3
+ Oidc = "OIDC"
4
4
  }
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.AuthMethodEnum = void 0;
4
4
  var AuthMethodEnum;
5
5
  (function (AuthMethodEnum) {
6
- AuthMethodEnum[AuthMethodEnum["Password"] = 0] = "Password";
7
- AuthMethodEnum[AuthMethodEnum["Oidc"] = 1] = "Oidc";
6
+ AuthMethodEnum["Password"] = "PASSWORD";
7
+ AuthMethodEnum["Oidc"] = "OIDC";
8
8
  })(AuthMethodEnum || (exports.AuthMethodEnum = AuthMethodEnum = {}));
9
9
  //# sourceMappingURL=auth-method.enum.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"auth-method.enum.js","sourceRoot":"","sources":["../../../src/auth/enums/auth-method.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,cAKX;AALD,WAAY,cAAc;IAExB,2DAAQ,CAAA;IAER,mDAAI,CAAA;AACN,CAAC,EALW,cAAc,8BAAd,cAAc,QAKzB"}
1
+ {"version":3,"file":"auth-method.enum.js","sourceRoot":"","sources":["../../../src/auth/enums/auth-method.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,cAKX;AALD,WAAY,cAAc;IAExB,uCAAqB,CAAA;IAErB,+BAAa,CAAA;AACf,CAAC,EALW,cAAc,8BAAd,cAAc,QAKzB"}
@@ -0,0 +1,6 @@
1
+ export declare class OidcExchangeCodeDto {
2
+ code: string;
3
+ provider: string;
4
+ redirectUri: string;
5
+ codeVerifier: string;
6
+ }
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.OidcExchangeCodeDto = void 0;
13
+ const swagger_1 = require("@nestjs/swagger");
14
+ class OidcExchangeCodeDto {
15
+ code;
16
+ provider;
17
+ redirectUri;
18
+ codeVerifier;
19
+ }
20
+ exports.OidcExchangeCodeDto = OidcExchangeCodeDto;
21
+ __decorate([
22
+ (0, swagger_1.ApiProperty)({
23
+ description: 'Authorization code, obtained from the authorization flow',
24
+ }),
25
+ __metadata("design:type", String)
26
+ ], OidcExchangeCodeDto.prototype, "code", void 0);
27
+ __decorate([
28
+ (0, swagger_1.ApiProperty)({
29
+ description: 'OIDC provider ID, relevant to the code that was obtained',
30
+ }),
31
+ __metadata("design:type", String)
32
+ ], OidcExchangeCodeDto.prototype, "provider", void 0);
33
+ __decorate([
34
+ (0, swagger_1.ApiProperty)({
35
+ description: 'Redirect Uri that was used to obtain the authorization code',
36
+ required: false,
37
+ }),
38
+ __metadata("design:type", String)
39
+ ], OidcExchangeCodeDto.prototype, "redirectUri", void 0);
40
+ __decorate([
41
+ (0, swagger_1.ApiProperty)({
42
+ description: 'The same code_verifier that was used to obtain the authorization code. Required if PKCE was used in the authorization code grant request',
43
+ required: false,
44
+ }),
45
+ __metadata("design:type", String)
46
+ ], OidcExchangeCodeDto.prototype, "codeVerifier", void 0);
47
+ //# sourceMappingURL=requests.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"requests.js","sourceRoot":"","sources":["../../../../src/auth/oidc/dto/requests.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6CAA8C;AAE9C,MAAa,mBAAmB;IAI9B,IAAI,CAAS;IAKb,QAAQ,CAAS;IAMjB,WAAW,CAAS;IAOpB,YAAY,CAAS;CACtB;AAvBD,kDAuBC;AAnBC;IAHC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,0DAA0D;KACxE,CAAC;;iDACW;AAKb;IAHC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,0DAA0D;KACxE,CAAC;;qDACe;AAMjB;IAJC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,6DAA6D;QAC1E,QAAQ,EAAE,KAAK;KAChB,CAAC;;wDACkB;AAOpB;IALC,IAAA,qBAAW,EAAC;QACX,WAAW,EACT,0IAA0I;QAC5I,QAAQ,EAAE,KAAK;KAChB,CAAC;;yDACmB"}
@@ -37,7 +37,7 @@ __decorate([
37
37
  description: 'Url to redirect the user to in order to start the OIDC flow',
38
38
  }),
39
39
  (0, class_transformer_1.Transform)(({ obj }) => {
40
- const baseUrl = context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.login';
40
+ const baseUrl = context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.authorize';
41
41
  return baseUrl + '?id=' + obj.id;
42
42
  }),
43
43
  __metadata("design:type", String)
@@ -1 +1 @@
1
- {"version":3,"file":"responses.js","sourceRoot":"","sources":["../../../../src/auth/oidc/dto/responses.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6CAA8C;AAC9C,yDAAsD;AACtD,2DAAiD;AAEjD,MAAa,uBAAuB;IAGlC,EAAE,CAAS;IAMX,IAAI,CAAS;IAWb,QAAQ,CAAS;CAClB;AArBD,0DAqBC;AAlBC;IAFC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,uBAAuB,EAAE,CAAC;;mDAC3C;AAMX;IAJC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,4DAA4D;KAC1E,CAAC;;qDACW;AAWb;IATC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,6DAA6D;KAC3E,CAAC;IACD,IAAA,6BAAS,EAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;QACrB,MAAM,OAAO,GAAG,iBAAO,CAAC,UAAU,EAAE,CAAC,UAAU,EAAE,GAAG,qBAAqB,CAAC;QAE1E,OAAO,OAAO,GAAG,MAAM,GAAG,GAAG,CAAC,EAAE,CAAC;IACnC,CAAC,CAAC;;yDACe"}
1
+ {"version":3,"file":"responses.js","sourceRoot":"","sources":["../../../../src/auth/oidc/dto/responses.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6CAA8C;AAC9C,yDAAsD;AACtD,2DAAiD;AAEjD,MAAa,uBAAuB;IAGlC,EAAE,CAAS;IAMX,IAAI,CAAS;IAYb,QAAQ,CAAS;CAClB;AAtBD,0DAsBC;AAnBC;IAFC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,uBAAuB,EAAE,CAAC;;mDAC3C;AAMX;IAJC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,4DAA4D;KAC1E,CAAC;;qDACW;AAYb;IAVC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,6DAA6D;KAC3E,CAAC;IACD,IAAA,6BAAS,EAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;QACrB,MAAM,OAAO,GACX,iBAAO,CAAC,UAAU,EAAE,CAAC,UAAU,EAAE,GAAG,yBAAyB,CAAC;QAEhE,OAAO,OAAO,GAAG,MAAM,GAAG,GAAG,CAAC,EAAE,CAAC;IACnC,CAAC,CAAC;;yDACe"}
@@ -2,11 +2,15 @@ import { Response } from 'express';
2
2
  import { OidcService } from './oidc.service';
3
3
  import { OidcProviderResponseDto } from './dto/responses';
4
4
  import { SessionService } from '../session/session.service';
5
+ import { OidcExchangeCodeDto } from './dto/requests';
5
6
  export declare class OidcController {
6
7
  private service;
7
8
  private sessions;
8
9
  constructor(service: OidcService, sessions: SessionService);
9
10
  listOidcProviders(): OidcProviderResponseDto[];
10
- login(id: string, res: Response): Promise<void>;
11
- callback(code: string, res: Response): Promise<string>;
11
+ login(id: string, params: Record<string, string>, res: Response): Promise<void>;
12
+ exchangeCode(dto: OidcExchangeCodeDto, res: Response): Promise<{
13
+ authToken: string;
14
+ user: import("../../user/entities/user.entity").User;
15
+ }>;
12
16
  }
@@ -20,6 +20,7 @@ const oidc_service_1 = require("./oidc.service");
20
20
  const class_transformer_1 = require("class-transformer");
21
21
  const responses_1 = require("./dto/responses");
22
22
  const session_service_1 = require("../session/session.service");
23
+ const requests_1 = require("./dto/requests");
23
24
  let OidcController = class OidcController {
24
25
  service;
25
26
  sessions;
@@ -32,16 +33,21 @@ let OidcController = class OidcController {
32
33
  .getProviders()
33
34
  .map((p) => (0, class_transformer_1.plainToInstance)(responses_1.OidcProviderResponseDto, p));
34
35
  }
35
- async login(id, res) {
36
+ async login(id, params, res) {
36
37
  const provider = this.service.getProviders()[0];
37
- const url = await this.service.getAuthorizationUrl(provider, 'todo');
38
+ const url = await this.service.getAuthorizationUrl(provider, 'todo', params);
38
39
  res.redirect(302, url);
39
40
  }
40
- async callback(code, res) {
41
+ async exchangeCode(dto, res) {
41
42
  const provider = this.service.getProviders()[0];
42
- const { accessToken } = await this.service.processAuthorizationCode(provider, code);
43
- this.sessions.setSessionCookie(accessToken, res);
44
- return 'Success. You can close this window';
43
+ const { authToken, user } = await this.service.processAuthorizationCode({
44
+ provider,
45
+ code: dto.code,
46
+ redirectUri: dto.redirectUri,
47
+ codeVerifier: dto.codeVerifier,
48
+ });
49
+ this.sessions.setSessionCookie(authToken, res);
50
+ return { authToken, user };
45
51
  }
46
52
  };
47
53
  exports.OidcController = OidcController;
@@ -58,30 +64,32 @@ __decorate([
58
64
  ], OidcController.prototype, "listOidcProviders", null);
59
65
  __decorate([
60
66
  (0, swagger_1.ApiOperation)({
61
- summary: 'Initiates an oidc login flow',
67
+ summary: 'Initiates an oidc authorization flow',
62
68
  description: `This OIDC API method kicks off the login flow for a given provider.`,
63
69
  }),
64
- (0, common_1.Get)('auth.oidc.login'),
70
+ (0, common_1.Get)('auth.oidc.authorize'),
65
71
  openapi.ApiResponse({ status: 200 }),
66
72
  __param(0, (0, common_1.Query)('id')),
67
- __param(1, (0, common_1.Res)()),
73
+ __param(1, (0, common_1.Query)()),
74
+ __param(2, (0, common_1.Res)()),
68
75
  __metadata("design:type", Function),
69
- __metadata("design:paramtypes", [String, Object]),
76
+ __metadata("design:paramtypes", [String, Object, Object]),
70
77
  __metadata("design:returntype", Promise)
71
78
  ], OidcController.prototype, "login", null);
72
79
  __decorate([
73
80
  (0, swagger_1.ApiOperation)({
74
- summary: 'Callback to respond to OIDC events',
75
- description: `This OIDC API method is to be used as the redirect_uri in the OIDC auth flow.`,
81
+ summary: 'Exchange an OIDC Authorization Code for a Social.Dev session',
82
+ description: `This OIDC API method is to be used to exchange and OAuth2 Authorization Code, obtained from the OIDC authorization flow,
83
+ for a Social.Dev session.`,
76
84
  }),
77
- (0, common_1.Get)('auth.oidc.callback'),
78
- openapi.ApiResponse({ status: 200, type: String }),
79
- __param(0, (0, common_1.Query)('code')),
85
+ (0, common_1.Post)('auth.oidc.exchangeCode'),
86
+ openapi.ApiResponse({ status: 201 }),
87
+ __param(0, (0, common_1.Body)()),
80
88
  __param(1, (0, common_1.Res)({ passthrough: true })),
81
89
  __metadata("design:type", Function),
82
- __metadata("design:paramtypes", [String, Object]),
90
+ __metadata("design:paramtypes", [requests_1.OidcExchangeCodeDto, Object]),
83
91
  __metadata("design:returntype", Promise)
84
- ], OidcController.prototype, "callback", null);
92
+ ], OidcController.prototype, "exchangeCode", null);
85
93
  exports.OidcController = OidcController = __decorate([
86
94
  (0, common_1.Controller)(),
87
95
  (0, swagger_1.ApiTags)('Auth'),
@@ -1 +1 @@
1
- {"version":3,"file":"oidc.controller.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAA6D;AAC7D,6CAAwD;AAExD,iDAA6C;AAC7C,yDAAqE;AACrE,+CAA0D;AAC1D,gEAA4D;AAIrD,IAAM,cAAc,GAApB,MAAM,cAAc;IAEf;IACA;IAFV,YACU,OAAoB,EACpB,QAAwB;QADxB,YAAO,GAAP,OAAO,CAAa;QACpB,aAAQ,GAAR,QAAQ,CAAgB;IAC/B,CAAC;IAOJ,iBAAiB;QACf,OAAO,IAAI,CAAC,OAAO;aAChB,YAAY,EAAE;aACd,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,mCAAe,EAAC,mCAAuB,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC;IAOK,AAAN,KAAK,CAAC,KAAK,CAAc,EAAU,EAAS,GAAa;QACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAErE,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IACzB,CAAC;IAOK,AAAN,KAAK,CAAC,QAAQ,CACG,IAAY,EACC,GAAa;QAEzC,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,wBAAwB,CACjE,QAAQ,EACR,IAAI,CACL,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;QAEjD,OAAO,oCAAoC,CAAC;IAC9C,CAAC;CACF,CAAA;AAhDY,wCAAc;AAWzB;IALC,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,qCAAqC;QAC9C,WAAW,EAAE,kFAAkF;KAChG,CAAC;IACD,IAAA,YAAG,EAAC,0BAA0B,CAAC;;;;;uDAK/B;AAOK;IALL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,8BAA8B;QACvC,WAAW,EAAE,qEAAqE;KACnF,CAAC;IACD,IAAA,YAAG,EAAC,iBAAiB,CAAC;;IACV,WAAA,IAAA,cAAK,EAAC,IAAI,CAAC,CAAA;IAAc,WAAA,IAAA,YAAG,GAAE,CAAA;;;;2CAK1C;AAOK;IALL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,oCAAoC;QAC7C,WAAW,EAAE,+EAA+E;KAC7F,CAAC;IACD,IAAA,YAAG,EAAC,oBAAoB,CAAC;;IAEvB,WAAA,IAAA,cAAK,EAAC,MAAM,CAAC,CAAA;IACb,WAAA,IAAA,YAAG,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;;;;8CAW5B;yBA/CU,cAAc;IAF1B,IAAA,mBAAU,GAAE;IACZ,IAAA,iBAAO,EAAC,MAAM,CAAC;qCAGK,0BAAW;QACV,gCAAc;GAHvB,cAAc,CAgD1B"}
1
+ {"version":3,"file":"oidc.controller.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyE;AACzE,6CAAwD;AAExD,iDAA6C;AAC7C,yDAAqE;AACrE,+CAA0D;AAC1D,gEAA4D;AAE5D,6CAAqD;AAI9C,IAAM,cAAc,GAApB,MAAM,cAAc;IAEf;IACA;IAFV,YACU,OAAoB,EACpB,QAAwB;QADxB,YAAO,GAAP,OAAO,CAAa;QACpB,aAAQ,GAAR,QAAQ,CAAgB;IAC/B,CAAC;IAOJ,iBAAiB;QACf,OAAO,IAAI,CAAC,OAAO;aAChB,YAAY,EAAE;aACd,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,mCAAe,EAAC,mCAAuB,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC;IAOK,AAAN,KAAK,CAAC,KAAK,CACI,EAAU,EACd,MAA8B,EAChC,GAAa;QAGpB,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAChD,QAAQ,EACR,MAAM,EACN,MAAM,CACP,CAAC;QAEF,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IACzB,CAAC;IAQK,AAAN,KAAK,CAAC,YAAY,CACR,GAAwB,EACJ,GAAa;QAEzC,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,wBAAwB,CAAC;YACtE,QAAQ;YACR,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,WAAW,EAAE,GAAG,CAAC,WAAW;YAC5B,YAAY,EAAE,GAAG,CAAC,YAAY;SAC/B,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QAE/C,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;IAC7B,CAAC;CACF,CAAA;AA5DY,wCAAc;AAWzB;IALC,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,qCAAqC;QAC9C,WAAW,EAAE,kFAAkF;KAChG,CAAC;IACD,IAAA,YAAG,EAAC,0BAA0B,CAAC;;;;;uDAK/B;AAOK;IALL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,sCAAsC;QAC/C,WAAW,EAAE,qEAAqE;KACnF,CAAC;IACD,IAAA,YAAG,EAAC,qBAAqB,CAAC;;IAExB,WAAA,IAAA,cAAK,EAAC,IAAI,CAAC,CAAA;IACX,WAAA,IAAA,cAAK,GAAE,CAAA;IACP,WAAA,IAAA,YAAG,GAAE,CAAA;;;;2CAWP;AAQK;IANL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,8DAA8D;QACvE,WAAW,EAAE;8BACa;KAC3B,CAAC;IACD,IAAA,aAAI,EAAC,wBAAwB,CAAC;;IAE5B,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,YAAG,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;;qCADd,8BAAmB;;kDAcjC;yBA3DU,cAAc;IAF1B,IAAA,mBAAU,GAAE;IACZ,IAAA,iBAAO,EAAC,MAAM,CAAC;qCAGK,0BAAW;QACV,gCAAc;GAHvB,cAAc,CA4D1B"}
@@ -15,6 +15,7 @@ const user_module_1 = require("../../user/user.module");
15
15
  const typeorm_1 = require("@nestjs/typeorm");
16
16
  const oidc_user_entity_1 = require("./entities/oidc-user.entity");
17
17
  const session_module_1 = require("../session/session.module");
18
+ const configs_module_1 = require("../../configs/configs.module");
18
19
  let OidcModule = class OidcModule {
19
20
  };
20
21
  exports.OidcModule = OidcModule;
@@ -25,6 +26,7 @@ exports.OidcModule = OidcModule = __decorate([
25
26
  axios_1.HttpModule,
26
27
  (0, common_1.forwardRef)(() => user_module_1.UserModule),
27
28
  session_module_1.SessionModule,
29
+ configs_module_1.ConfigsModule,
28
30
  ],
29
31
  providers: [oidc_service_1.OidcService],
30
32
  controllers: [oidc_controller_1.OidcController],
@@ -1 +1 @@
1
- {"version":3,"file":"oidc.module.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAoD;AACpD,uDAAmD;AACnD,iDAA6C;AAC7C,yCAA2C;AAC3C,wDAAgD;AAChD,6CAAgD;AAChD,kEAAuD;AACvD,8DAA0D;AAYnD,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAVtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,2BAAQ,CAAC,CAAC;YACpC,kBAAU;YACV,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,8BAAa;SACd;QACD,SAAS,EAAE,CAAC,0BAAW,CAAC;QACxB,WAAW,EAAE,CAAC,gCAAc,CAAC;KAC9B,CAAC;GACW,UAAU,CAAG"}
1
+ {"version":3,"file":"oidc.module.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAoD;AACpD,uDAAmD;AACnD,iDAA6C;AAC7C,yCAA2C;AAC3C,wDAAgD;AAChD,6CAAgD;AAChD,kEAAuD;AACvD,8DAA0D;AAC1D,iEAAyD;AAalD,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAXtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,2BAAQ,CAAC,CAAC;YACpC,kBAAU;YACV,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,8BAAa;YACb,8BAAa;SACd;QACD,SAAS,EAAE,CAAC,0BAAW,CAAC;QACxB,WAAW,EAAE,CAAC,gCAAc,CAAC;KAC9B,CAAC;GACW,UAAU,CAAG"}
@@ -4,7 +4,8 @@ import { User } from '~/user/entities/user.entity';
4
4
  import { DataSource, Repository } from 'typeorm';
5
5
  import { OidcUser } from './entities/oidc-user.entity';
6
6
  import { SessionService } from '../session/session.service';
7
- type OidcProvider = {
7
+ import { ConfigsService } from '~/configs/configs.service';
8
+ export type OidcProvider = {
8
9
  id: string;
9
10
  name: string;
10
11
  issuer: string;
@@ -17,16 +18,21 @@ export declare class OidcService {
17
18
  private http;
18
19
  private users;
19
20
  private sessions;
20
- constructor(oidcUserRepository: Repository<OidcUser>, dataSource: DataSource, http: HttpService, users: UserService, sessions: SessionService);
21
+ private configs;
22
+ constructor(oidcUserRepository: Repository<OidcUser>, dataSource: DataSource, http: HttpService, users: UserService, sessions: SessionService, configs: ConfigsService);
21
23
  getProviders(): OidcProvider[];
22
- getAuthorizationUrl(provider: OidcProvider, stateToken: string): Promise<string>;
23
- processAuthorizationCode(provider: OidcProvider, code: string): Promise<{
24
- accessToken: string;
24
+ getAuthorizationUrl(provider: OidcProvider, stateToken: string, extraParams?: Record<string, string>): Promise<string>;
25
+ processAuthorizationCode({ provider, code, redirectUri, codeVerifier, }: {
26
+ provider: OidcProvider;
27
+ code: string;
28
+ redirectUri?: string;
29
+ codeVerifier?: string;
30
+ }): Promise<{
31
+ authToken: string;
25
32
  user: User;
26
33
  }>;
27
- getUserInfo(endpoint: string, accessToken: string): Promise<Object>;
34
+ getUserInfo(endpoint: string, authToken: string): Promise<Object>;
28
35
  getUserFromSub(provider: OidcProvider, sub: string): Promise<User | null>;
29
36
  private getOpenIdConfiguration;
30
37
  private getJwk;
31
38
  }
32
- export {};
@@ -25,60 +25,66 @@ const typeorm_1 = require("typeorm");
25
25
  const oidc_user_entity_1 = require("./entities/oidc-user.entity");
26
26
  const typeorm_2 = require("@nestjs/typeorm");
27
27
  const session_service_1 = require("../session/session.service");
28
+ const configs_service_1 = require("../../configs/configs.service");
28
29
  let OidcService = class OidcService {
29
30
  oidcUserRepository;
30
31
  dataSource;
31
32
  http;
32
33
  users;
33
34
  sessions;
34
- constructor(oidcUserRepository, dataSource, http, users, sessions) {
35
+ configs;
36
+ constructor(oidcUserRepository, dataSource, http, users, sessions, configs) {
35
37
  this.oidcUserRepository = oidcUserRepository;
36
38
  this.dataSource = dataSource;
37
39
  this.http = http;
38
40
  this.users = users;
39
41
  this.sessions = sessions;
42
+ this.configs = configs;
40
43
  }
41
44
  getProviders() {
42
- return [
43
- {
44
- id: 'test',
45
- name: 'Zitadel',
46
- issuer: 'https://minds-test-hlrirg.zitadel.cloud',
47
- clientId: '241850086068397974@minds-test',
48
- clientSecret: '2QzFBlXKXCUall4gbU706hLKyOgfLQANLIFao7agxR33tRRV4SIJcgZJrAQT2IGP',
49
- },
50
- ];
45
+ return this.configs.get('auth')?.oidc?.providers || [];
51
46
  }
52
- async getAuthorizationUrl(provider, stateToken) {
47
+ async getAuthorizationUrl(provider, stateToken, extraParams) {
53
48
  const openidConfig = await this.getOpenIdConfiguration(provider);
54
49
  const authUrl = openidConfig['authorization_endpoint'];
55
50
  const supportedScopes = openidConfig['scopes_supported'];
56
51
  const scopes = ['openid', 'profile', 'email'].filter((scope) => supportedScopes.includes(scope));
57
52
  const params = new URLSearchParams({
53
+ ...extraParams,
58
54
  response_type: 'code',
59
55
  client_id: provider.clientId,
60
56
  state: stateToken,
61
57
  scope: scopes.join(' '),
62
- redirect_uri: context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
58
+ redirect_uri: extraParams?.redirect_uri ||
59
+ context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
63
60
  provider_id: provider.id,
64
61
  });
65
62
  return `${authUrl}?${params.toString()}`;
66
63
  }
67
- async processAuthorizationCode(provider, code) {
64
+ async processAuthorizationCode({ provider, code, redirectUri, codeVerifier, }) {
68
65
  const openidConfig = await this.getOpenIdConfiguration(provider);
69
66
  const tokenUrl = openidConfig['token_endpoint'];
70
- const res = await (0, rxjs_1.firstValueFrom)(this.http.post(tokenUrl, {
71
- code,
72
- client_id: provider.clientId,
73
- client_secret: provider.clientSecret,
74
- redirect_uri: context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
75
- grant_type: 'authorization_code',
76
- }, {
77
- headers: {
78
- 'Content-Type': 'application/x-www-form-urlencoded',
79
- },
80
- }));
81
- const data = res.data;
67
+ let data;
68
+ try {
69
+ const res = await (0, rxjs_1.firstValueFrom)(this.http.post(tokenUrl, {
70
+ code,
71
+ client_id: provider.clientId,
72
+ client_secret: provider.clientSecret,
73
+ redirect_uri: redirectUri ||
74
+ context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
75
+ grant_type: 'authorization_code',
76
+ code_verifier: codeVerifier,
77
+ }, {
78
+ headers: {
79
+ 'Content-Type': 'application/x-www-form-urlencoded',
80
+ },
81
+ }));
82
+ data = res.data;
83
+ }
84
+ catch (err) {
85
+ console.log(err);
86
+ throw new common_1.InternalServerErrorException();
87
+ }
82
88
  const jwks = await this.getJwk(provider);
83
89
  if (!jwks) {
84
90
  throw new common_1.NotAcceptableException("The OIDC provider does not have JWK's");
@@ -131,13 +137,13 @@ let OidcService = class OidcService {
131
137
  await queryRunner.commitTransaction();
132
138
  queryRunner.release();
133
139
  }
134
- const { accessToken } = await this.sessions.create(user);
135
- return { accessToken, user };
140
+ const { authToken } = await this.sessions.create(user);
141
+ return { authToken, user };
136
142
  }
137
- async getUserInfo(endpoint, accessToken) {
143
+ async getUserInfo(endpoint, authToken) {
138
144
  const res = await (0, rxjs_1.firstValueFrom)(this.http.get(endpoint, {
139
145
  headers: {
140
- Authorization: `Bearer ${accessToken}`,
146
+ Authorization: `Bearer ${authToken}`,
141
147
  },
142
148
  }));
143
149
  return res.data;
@@ -176,6 +182,7 @@ exports.OidcService = OidcService = __decorate([
176
182
  typeorm_1.DataSource,
177
183
  axios_1.HttpService,
178
184
  user_service_1.UserService,
179
- session_service_1.SessionService])
185
+ session_service_1.SessionService,
186
+ configs_service_1.ConfigsService])
180
187
  ], OidcService);
181
188
  //# sourceMappingURL=oidc.service.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"oidc.service.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.service.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"oidc.service.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.service.ts"],"names":[],"mappings":"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"}