@builder6/server 0.2.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.
Files changed (185) hide show
  1. package/dist/app.controller.d.ts +3 -0
  2. package/dist/app.controller.js +29 -0
  3. package/dist/app.controller.js.map +1 -0
  4. package/dist/app.express.d.ts +2 -0
  5. package/dist/app.express.js +45 -0
  6. package/dist/app.express.js.map +1 -0
  7. package/dist/app.module.d.ts +2 -0
  8. package/dist/app.module.js +48 -0
  9. package/dist/app.module.js.map +1 -0
  10. package/dist/auth/admin.guard.d.ts +8 -0
  11. package/dist/auth/admin.guard.js +47 -0
  12. package/dist/auth/admin.guard.js.map +1 -0
  13. package/dist/auth/auth.controller.d.ts +7 -0
  14. package/dist/auth/auth.controller.js +80 -0
  15. package/dist/auth/auth.controller.js.map +1 -0
  16. package/dist/auth/auth.guard.d.ts +7 -0
  17. package/dist/auth/auth.guard.js +41 -0
  18. package/dist/auth/auth.guard.js.map +1 -0
  19. package/dist/auth/auth.module.d.ts +2 -0
  20. package/dist/auth/auth.module.js +34 -0
  21. package/dist/auth/auth.module.js.map +1 -0
  22. package/dist/auth/auth.service.d.ts +22 -0
  23. package/dist/auth/auth.service.js +172 -0
  24. package/dist/auth/auth.service.js.map +1 -0
  25. package/dist/auth/index.d.ts +5 -0
  26. package/dist/auth/index.js +22 -0
  27. package/dist/auth/index.js.map +1 -0
  28. package/dist/b6.config.d.ts +0 -0
  29. package/dist/b6.config.js +6 -0
  30. package/dist/b6.config.js.map +1 -0
  31. package/dist/b6.server.d.ts +2 -0
  32. package/dist/b6.server.js +276 -0
  33. package/dist/b6.server.js.map +1 -0
  34. package/dist/files/files.controller.d.ts +8 -0
  35. package/dist/files/files.controller.js +110 -0
  36. package/dist/files/files.controller.js.map +1 -0
  37. package/dist/files/files.module.d.ts +2 -0
  38. package/dist/files/files.module.js +25 -0
  39. package/dist/files/files.module.js.map +1 -0
  40. package/dist/files/files.service.d.ts +30 -0
  41. package/dist/files/files.service.js +206 -0
  42. package/dist/files/files.service.js.map +1 -0
  43. package/dist/files/index.d.ts +3 -0
  44. package/dist/files/index.js +20 -0
  45. package/dist/files/index.js.map +1 -0
  46. package/dist/index.d.ts +5 -0
  47. package/dist/index.js +28 -0
  48. package/dist/index.js.map +1 -0
  49. package/dist/main.d.ts +1 -0
  50. package/dist/main.js +10 -0
  51. package/dist/main.js.map +1 -0
  52. package/dist/microsoft365/microsoft365.controller.d.ts +8 -0
  53. package/dist/microsoft365/microsoft365.controller.js +83 -0
  54. package/dist/microsoft365/microsoft365.controller.js.map +1 -0
  55. package/dist/microsoft365/microsoft365.module.d.ts +2 -0
  56. package/dist/microsoft365/microsoft365.module.js +22 -0
  57. package/dist/microsoft365/microsoft365.module.js.map +1 -0
  58. package/dist/microsoft365/microsoft365.service.d.ts +3 -0
  59. package/dist/microsoft365/microsoft365.service.js +32 -0
  60. package/dist/microsoft365/microsoft365.service.js.map +1 -0
  61. package/dist/moleculer/env.config.d.ts +2 -0
  62. package/dist/moleculer/env.config.js +38 -0
  63. package/dist/moleculer/env.config.js.map +1 -0
  64. package/dist/moleculer/moleculer.config.d.ts +2 -0
  65. package/dist/moleculer/moleculer.config.js +78 -0
  66. package/dist/moleculer/moleculer.config.js.map +1 -0
  67. package/dist/moleculer/moleculer.module.d.ts +2 -0
  68. package/dist/moleculer/moleculer.module.js +20 -0
  69. package/dist/moleculer/moleculer.module.js.map +1 -0
  70. package/dist/moleculer/moleculer.service.d.ts +11 -0
  71. package/dist/moleculer/moleculer.service.js +95 -0
  72. package/dist/moleculer/moleculer.service.js.map +1 -0
  73. package/dist/mongodb/index.d.ts +2 -0
  74. package/dist/mongodb/index.js +19 -0
  75. package/dist/mongodb/index.js.map +1 -0
  76. package/dist/mongodb/mongodb.module.d.ts +2 -0
  77. package/dist/mongodb/mongodb.module.js +21 -0
  78. package/dist/mongodb/mongodb.module.js.map +1 -0
  79. package/dist/mongodb/mongodb.service.d.ts +17 -0
  80. package/dist/mongodb/mongodb.service.js +113 -0
  81. package/dist/mongodb/mongodb.service.js.map +1 -0
  82. package/dist/oidc/oidc.controller.d.ts +7 -0
  83. package/dist/oidc/oidc.controller.js +93 -0
  84. package/dist/oidc/oidc.controller.js.map +1 -0
  85. package/dist/oidc/oidc.module.d.ts +2 -0
  86. package/dist/oidc/oidc.module.js +22 -0
  87. package/dist/oidc/oidc.module.js.map +1 -0
  88. package/dist/oidc/oidc.service.d.ts +15 -0
  89. package/dist/oidc/oidc.service.js +38 -0
  90. package/dist/oidc/oidc.service.js.map +1 -0
  91. package/dist/rooms/globals/augmentation.d.ts +25 -0
  92. package/dist/rooms/globals/augmentation.js +3 -0
  93. package/dist/rooms/globals/augmentation.js.map +1 -0
  94. package/dist/rooms/lib/DateToString.d.ts +3 -0
  95. package/dist/rooms/lib/DateToString.js +3 -0
  96. package/dist/rooms/lib/DateToString.js.map +1 -0
  97. package/dist/rooms/lib/Json.d.ts +9 -0
  98. package/dist/rooms/lib/Json.js +18 -0
  99. package/dist/rooms/lib/Json.js.map +1 -0
  100. package/dist/rooms/lib/utils.d.ts +33 -0
  101. package/dist/rooms/lib/utils.js +122 -0
  102. package/dist/rooms/lib/utils.js.map +1 -0
  103. package/dist/rooms/protocol/AuthToken.d.ts +50 -0
  104. package/dist/rooms/protocol/AuthToken.js +49 -0
  105. package/dist/rooms/protocol/AuthToken.js.map +1 -0
  106. package/dist/rooms/protocol/Authentication.d.ts +22 -0
  107. package/dist/rooms/protocol/Authentication.js +3 -0
  108. package/dist/rooms/protocol/Authentication.js.map +1 -0
  109. package/dist/rooms/protocol/BaseActivitiesData.d.ts +4 -0
  110. package/dist/rooms/protocol/BaseActivitiesData.js +3 -0
  111. package/dist/rooms/protocol/BaseActivitiesData.js.map +1 -0
  112. package/dist/rooms/protocol/BaseRoomInfo.d.ts +6 -0
  113. package/dist/rooms/protocol/BaseRoomInfo.js +3 -0
  114. package/dist/rooms/protocol/BaseRoomInfo.js.map +1 -0
  115. package/dist/rooms/protocol/BaseUserMeta.d.ts +10 -0
  116. package/dist/rooms/protocol/BaseUserMeta.js +3 -0
  117. package/dist/rooms/protocol/BaseUserMeta.js.map +1 -0
  118. package/dist/rooms/protocol/ClientMsg.d.ts +41 -0
  119. package/dist/rooms/protocol/ClientMsg.js +13 -0
  120. package/dist/rooms/protocol/ClientMsg.js.map +1 -0
  121. package/dist/rooms/protocol/Comments.d.ts +146 -0
  122. package/dist/rooms/protocol/Comments.js +3 -0
  123. package/dist/rooms/protocol/Comments.js.map +1 -0
  124. package/dist/rooms/protocol/InboxNotifications.d.ts +49 -0
  125. package/dist/rooms/protocol/InboxNotifications.js +3 -0
  126. package/dist/rooms/protocol/InboxNotifications.js.map +1 -0
  127. package/dist/rooms/protocol/Op.d.ts +82 -0
  128. package/dist/rooms/protocol/Op.js +28 -0
  129. package/dist/rooms/protocol/Op.js.map +1 -0
  130. package/dist/rooms/protocol/SerializedCrdt.d.ts +40 -0
  131. package/dist/rooms/protocol/SerializedCrdt.js +19 -0
  132. package/dist/rooms/protocol/SerializedCrdt.js.map +1 -0
  133. package/dist/rooms/protocol/ServerMsg.d.ts +128 -0
  134. package/dist/rooms/protocol/ServerMsg.js +25 -0
  135. package/dist/rooms/protocol/ServerMsg.js.map +1 -0
  136. package/dist/rooms/protocol/VersionHistory.d.ts +9 -0
  137. package/dist/rooms/protocol/VersionHistory.js +3 -0
  138. package/dist/rooms/protocol/VersionHistory.js.map +1 -0
  139. package/dist/rooms/rooms.controller.d.ts +64 -0
  140. package/dist/rooms/rooms.controller.js +401 -0
  141. package/dist/rooms/rooms.controller.js.map +1 -0
  142. package/dist/rooms/rooms.gateway.d.ts +30 -0
  143. package/dist/rooms/rooms.gateway.js +189 -0
  144. package/dist/rooms/rooms.gateway.js.map +1 -0
  145. package/dist/rooms/rooms.guard.d.ts +9 -0
  146. package/dist/rooms/rooms.guard.js +48 -0
  147. package/dist/rooms/rooms.guard.js.map +1 -0
  148. package/dist/rooms/rooms.module.d.ts +2 -0
  149. package/dist/rooms/rooms.module.js +36 -0
  150. package/dist/rooms/rooms.module.js.map +1 -0
  151. package/dist/rooms/rooms.service.d.ts +51 -0
  152. package/dist/rooms/rooms.service.js +223 -0
  153. package/dist/rooms/rooms.service.js.map +1 -0
  154. package/dist/steedos/mongodb.controller.d.ts +13 -0
  155. package/dist/steedos/mongodb.controller.js +355 -0
  156. package/dist/steedos/mongodb.controller.js.map +1 -0
  157. package/dist/steedos/object.service.d.ts +6 -0
  158. package/dist/steedos/object.service.js +34 -0
  159. package/dist/steedos/object.service.js.map +1 -0
  160. package/dist/steedos/steedos.module.d.ts +2 -0
  161. package/dist/steedos/steedos.module.js +27 -0
  162. package/dist/steedos/steedos.module.js.map +1 -0
  163. package/dist/tables/meta.service.d.ts +6 -0
  164. package/dist/tables/meta.service.js +82 -0
  165. package/dist/tables/meta.service.js.map +1 -0
  166. package/dist/tables/records.service.d.ts +13 -0
  167. package/dist/tables/records.service.js +73 -0
  168. package/dist/tables/records.service.js.map +1 -0
  169. package/dist/tables/tables.controller.d.ts +24 -0
  170. package/dist/tables/tables.controller.js +414 -0
  171. package/dist/tables/tables.controller.js.map +1 -0
  172. package/dist/tables/tables.module.d.ts +2 -0
  173. package/dist/tables/tables.module.js +28 -0
  174. package/dist/tables/tables.module.js.map +1 -0
  175. package/package.json +112 -0
  176. package/public/ag-grid/locale_zh.js +595 -0
  177. package/public/grid/index.html +25 -0
  178. package/public/grid/index.js +207 -0
  179. package/public/grid/styles.css +4 -0
  180. package/public/pivot/index.html +30 -0
  181. package/public/pivot/index.js +109 -0
  182. package/public/pivot/styles.css +7 -0
  183. package/views/ag-grid/README.md +15 -0
  184. package/views/ag-grid/ag-grid.hbs +1099 -0
  185. package/views/devextreme/datagrid.hbs +240 -0
@@ -0,0 +1,3 @@
1
+ export declare class AppController {
2
+ getRoot(): Promise<string>;
3
+ }
@@ -0,0 +1,29 @@
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.AppController = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ let AppController = class AppController {
15
+ async getRoot() {
16
+ return `Welcome to the API: <a href="/api/v6">/api/v6</a>`;
17
+ }
18
+ };
19
+ exports.AppController = AppController;
20
+ __decorate([
21
+ (0, common_1.Get)(''),
22
+ __metadata("design:type", Function),
23
+ __metadata("design:paramtypes", []),
24
+ __metadata("design:returntype", Promise)
25
+ ], AppController.prototype, "getRoot", null);
26
+ exports.AppController = AppController = __decorate([
27
+ (0, common_1.Controller)('/')
28
+ ], AppController);
29
+ //# sourceMappingURL=app.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.controller.js","sourceRoot":"","sources":["../src/app.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAmF;AAG5E,IAAM,aAAa,GAAnB,MAAM,aAAa;IAGlB,AAAN,KAAK,CAAC,OAAO;QACX,OAAO,mDAAmD,CAAC;IAC7D,CAAC;CAGF,CAAA;AARY,sCAAa;AAGlB;IADL,IAAA,YAAG,EAAC,EAAE,CAAC;;;;4CAGP;wBALU,aAAa;IADzB,IAAA,mBAAU,EAAC,GAAG,CAAC;GACH,aAAa,CAQzB"}
@@ -0,0 +1,2 @@
1
+ import { NestExpressApplication } from '@nestjs/platform-express';
2
+ export default function ExpressApplication(): Promise<NestExpressApplication>;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.default = ExpressApplication;
4
+ const core_1 = require("@nestjs/core");
5
+ const app_module_1 = require("./app.module");
6
+ const path_1 = require("path");
7
+ const swagger_1 = require("@nestjs/swagger");
8
+ const cookieParser = require("cookie-parser");
9
+ const compression = require("compression");
10
+ const express_1 = require("express");
11
+ const platform_ws_1 = require("@nestjs/platform-ws");
12
+ const session = require("express-session");
13
+ async function ExpressApplication() {
14
+ const app = await core_1.NestFactory.create(app_module_1.AppModule);
15
+ app.useWebSocketAdapter(new platform_ws_1.WsAdapter(app));
16
+ app.enableCors({
17
+ origin: function (origin, callback) {
18
+ callback(null, true);
19
+ },
20
+ methods: 'GET,PUT,POST,DELETE,UPDATE,OPTIONS',
21
+ credentials: true,
22
+ });
23
+ app.use(session({
24
+ secret: 'your_session_secret',
25
+ resave: false,
26
+ saveUninitialized: false,
27
+ }));
28
+ const swaggerConfig = new swagger_1.DocumentBuilder()
29
+ .setTitle('Builder6 API')
30
+ .setDescription('The Builder6 API description')
31
+ .setVersion('2.0')
32
+ .addBearerAuth()
33
+ .build();
34
+ const documentFactory = () => swagger_1.SwaggerModule.createDocument(app, swaggerConfig);
35
+ swagger_1.SwaggerModule.setup('api/v6', app, documentFactory);
36
+ app.useStaticAssets((0, path_1.join)(__dirname, '..', 'public'));
37
+ app.setBaseViewsDir((0, path_1.join)(__dirname, '..', 'views'));
38
+ app.setViewEngine('hbs');
39
+ app.use(cookieParser());
40
+ app.use((0, express_1.json)({ limit: '50mb' }));
41
+ app.use((0, express_1.urlencoded)({ extended: true, limit: '100mb', parameterLimit: 1000000 }));
42
+ app.use(compression());
43
+ return app;
44
+ }
45
+ //# sourceMappingURL=app.express.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.express.js","sourceRoot":"","sources":["../src/app.express.ts"],"names":[],"mappings":";;AAYA,qCAsCC;AAlDD,uCAA2C;AAC3C,6CAAyC;AACzC,+BAA4B;AAE5B,6CAAiE;AACjE,8CAA8C;AAC9C,2CAA2C;AAC3C,qCAA2C;AAC3C,qDAAgD;AAEhD,2CAA2C;AAE5B,KAAK,UAAU,kBAAkB;IAC9C,MAAM,GAAG,GAAG,MAAM,kBAAW,CAAC,MAAM,CAAyB,sBAAS,CAAC,CAAC;IACxE,GAAG,CAAC,mBAAmB,CAAC,IAAI,uBAAS,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5C,GAAG,CAAC,UAAU,CAAC;QACb,MAAM,EAAE,UAAU,MAAM,EAAE,QAAQ;YAChC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACvB,CAAC;QACD,OAAO,EAAE,oCAAoC;QAC7C,WAAW,EAAE,IAAI;KAClB,CAAC,CAAC;IACH,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC;QACd,MAAM,EAAE,qBAAqB;QAC7B,MAAM,EAAE,KAAK;QACb,iBAAiB,EAAE,KAAK;KACzB,CAAC,CAAC,CAAC;IAEJ,MAAM,aAAa,GAAG,IAAI,yBAAe,EAAE;SACxC,QAAQ,CAAC,cAAc,CAAC;SACxB,cAAc,CAAC,8BAA8B,CAAC;SAC9C,UAAU,CAAC,KAAK,CAAC;SACjB,aAAa,EAAE;SACf,KAAK,EAAE,CAAC;IAEX,MAAM,eAAe,GAAG,GAAG,EAAE,CAAC,uBAAa,CAAC,cAAc,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC;IAC/E,uBAAa,CAAC,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,eAAe,CAAC,CAAC;IAEpD,GAAG,CAAC,eAAe,CAAC,IAAA,WAAI,EAAC,SAAS,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;IACrD,GAAG,CAAC,eAAe,CAAC,IAAA,WAAI,EAAC,SAAS,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IACpD,GAAG,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAEzB,GAAG,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC;IACxB,GAAG,CAAC,GAAG,CAAC,IAAA,cAAI,EAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;IACjC,GAAG,CAAC,GAAG,CACL,IAAA,oBAAU,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,CAAC,CACxE,CAAC;IACF,GAAG,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;IAEvB,OAAO,GAAG,CAAC;AACb,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare class AppModule {
2
+ }
@@ -0,0 +1,48 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.AppModule = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const config_1 = require("@nestjs/config");
12
+ const mongodb_module_1 = require("./mongodb/mongodb.module");
13
+ const tables_module_1 = require("./tables/tables.module");
14
+ const auth_module_1 = require("./auth/auth.module");
15
+ const steedos_module_1 = require("./steedos/steedos.module");
16
+ const rooms_module_1 = require("./rooms/rooms.module");
17
+ const files_module_1 = require("./files/files.module");
18
+ const moleculer_module_1 = require("./moleculer/moleculer.module");
19
+ const microsoft365_module_1 = require("./microsoft365/microsoft365.module");
20
+ const oidc_module_1 = require("./oidc/oidc.module");
21
+ const app_controller_1 = require("./app.controller");
22
+ const moleculer_config_1 = require("./moleculer/moleculer.config");
23
+ let AppModule = class AppModule {
24
+ };
25
+ exports.AppModule = AppModule;
26
+ exports.AppModule = AppModule = __decorate([
27
+ (0, common_1.Module)({
28
+ imports: [
29
+ config_1.ConfigModule.forRoot({
30
+ envFilePath: ['.env.local', '.env'],
31
+ load: [moleculer_config_1.default],
32
+ isGlobal: true,
33
+ }),
34
+ auth_module_1.AuthModule,
35
+ mongodb_module_1.MongodbModule,
36
+ steedos_module_1.SteedosModule,
37
+ tables_module_1.TablesModule,
38
+ rooms_module_1.RoomsModule,
39
+ files_module_1.FilesModule,
40
+ moleculer_module_1.MoleculerModule,
41
+ microsoft365_module_1.Microsoft365Module,
42
+ ...(process.env.B6_OIDC_ENABLED ? [oidc_module_1.OidcModule] : []),
43
+ ],
44
+ controllers: [app_controller_1.AppController],
45
+ providers: [],
46
+ })
47
+ ], AppModule);
48
+ //# sourceMappingURL=app.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.module.js","sourceRoot":"","sources":["../src/app.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,2CAA8C;AAE9C,6DAAyD;AACzD,0DAAsD;AACtD,oDAAgD;AAChD,6DAAyD;AACzD,uDAAmD;AACnD,uDAAmD;AACnD,mEAA+D;AAC/D,4EAAwE;AACxE,oDAAgD;AAChD,qDAAiD;AACjD,mEAAkD;AAsB3C,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IApBrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,qBAAY,CAAC,OAAO,CAAC;gBACnB,WAAW,EAAE,CAAC,YAAY,EAAE,MAAM,CAAC;gBACnC,IAAI,EAAE,CAAC,0BAAM,CAAC;gBACd,QAAQ,EAAE,IAAI;aACf,CAAC;YACF,wBAAU;YACV,8BAAa;YACb,8BAAa;YACb,4BAAY;YACZ,0BAAW;YACX,0BAAW;YACX,kCAAe;YACf,wCAAkB;YAClB,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,wBAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;SACrD;QACD,WAAW,EAAE,CAAC,8BAAa,CAAC;QAC5B,SAAS,EAAE,EAAE;KACd,CAAC;GACW,SAAS,CAAG"}
@@ -0,0 +1,8 @@
1
+ import { CanActivate, ExecutionContext } from '@nestjs/common';
2
+ import { AuthService } from './auth.service';
3
+ export declare class AdminGuard implements CanActivate {
4
+ private authService;
5
+ constructor(authService: AuthService);
6
+ canActivate(context: ExecutionContext): Promise<boolean>;
7
+ private extractTokenFromHeader;
8
+ }
@@ -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.AdminGuard = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const auth_service_1 = require("./auth.service");
15
+ let AdminGuard = class AdminGuard {
16
+ constructor(authService) {
17
+ this.authService = authService;
18
+ }
19
+ async canActivate(context) {
20
+ const request = context.switchToHttp().getRequest();
21
+ const token = this.authService.extractTokenFromHeaderOrCookie(request);
22
+ if (!token) {
23
+ throw new common_1.UnauthorizedException();
24
+ }
25
+ try {
26
+ const user = (await this.authService.getUserByToken(token));
27
+ if (user?.profile != 'admin') {
28
+ throw new common_1.UnauthorizedException();
29
+ }
30
+ request['user'] = user;
31
+ }
32
+ catch {
33
+ throw new common_1.UnauthorizedException();
34
+ }
35
+ return true;
36
+ }
37
+ extractTokenFromHeader(request) {
38
+ const [type, token] = request.headers.authorization?.split(' ') ?? [];
39
+ return type === 'Bearer' ? token : undefined;
40
+ }
41
+ };
42
+ exports.AdminGuard = AdminGuard;
43
+ exports.AdminGuard = AdminGuard = __decorate([
44
+ (0, common_1.Injectable)(),
45
+ __metadata("design:paramtypes", [auth_service_1.AuthService])
46
+ ], AdminGuard);
47
+ //# sourceMappingURL=admin.guard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"admin.guard.js","sourceRoot":"","sources":["../../src/auth/admin.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAKwB;AAExB,iDAA6C;AAGtC,IAAM,UAAU,GAAhB,MAAM,UAAU;IACrB,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAEhD,KAAK,CAAC,WAAW,CAAC,OAAyB;QACzC,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;QACpD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,8BAA8B,CAAC,OAAO,CAAC,CAAC;QACvE,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,MAAM,IAAI,8BAAqB,EAAE,CAAC;QACpC,CAAC;QACD,IAAI,CAAC;YAGH,MAAM,IAAI,GAAG,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,KAAK,CAAC,CAAQ,CAAC;YACnE,IAAI,IAAI,EAAE,OAAO,IAAI,OAAO,EAAE,CAAC;gBAC7B,MAAM,IAAI,8BAAqB,EAAE,CAAC;YACpC,CAAC;YACD,OAAO,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC;QACzB,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,IAAI,8BAAqB,EAAE,CAAC;QACpC,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,sBAAsB,CAAC,OAAgB;QAC7C,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC,aAAa,EAAE,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QACtE,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/C,CAAC;CACF,CAAA;AA3BY,gCAAU;qBAAV,UAAU;IADtB,IAAA,mBAAU,GAAE;qCAEsB,0BAAW;GADjC,UAAU,CA2BtB"}
@@ -0,0 +1,7 @@
1
+ import { AuthService } from './auth.service';
2
+ import { Request, Response } from 'express';
3
+ export declare class AuthController {
4
+ private authService;
5
+ constructor(authService: AuthService);
6
+ login(req: Request, res: Response, signInDto: Record<string, any>): Promise<Response<any, Record<string, any>>>;
7
+ }
@@ -0,0 +1,80 @@
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
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.AuthController = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const auth_service_1 = require("./auth.service");
18
+ const swagger_1 = require("@nestjs/swagger");
19
+ let AuthController = class AuthController {
20
+ constructor(authService) {
21
+ this.authService = authService;
22
+ }
23
+ async login(req, res, signInDto) {
24
+ try {
25
+ const result = await this.authService.signIn(signInDto.username, signInDto.password);
26
+ const { user, space, authToken } = result;
27
+ const cookieOptions = {
28
+ httpOnly: true,
29
+ sameSite: 'strict',
30
+ maxAge: 2 * 365 * 24 * 60 * 60 * 1000,
31
+ };
32
+ if (process.env.STEEDOS_AUTH_COOKIES_USE_SAMESITE == 'None') {
33
+ cookieOptions.sameSite = 'none';
34
+ cookieOptions.secure = true;
35
+ }
36
+ res.cookie('X-Auth-Token', authToken, cookieOptions);
37
+ res.cookie('X-User-Id', user, cookieOptions);
38
+ res.cookie('X-Space-Id', space, cookieOptions);
39
+ return res.status(200).json(result);
40
+ }
41
+ catch (error) {
42
+ console.error('Error during signIn:', error);
43
+ return res.status(401).json({ message: 'Authentication failed' });
44
+ }
45
+ }
46
+ };
47
+ exports.AuthController = AuthController;
48
+ __decorate([
49
+ (0, common_1.HttpCode)(common_1.HttpStatus.OK),
50
+ (0, common_1.Post)('login'),
51
+ (0, swagger_1.ApiBody)({
52
+ schema: {
53
+ type: 'object',
54
+ properties: {
55
+ username: { type: 'string' },
56
+ password: { type: 'string' },
57
+ },
58
+ },
59
+ examples: {
60
+ test: {
61
+ summary: 'test',
62
+ value: {
63
+ username: 'test',
64
+ password: 'test',
65
+ },
66
+ },
67
+ },
68
+ }),
69
+ __param(0, (0, common_1.Req)()),
70
+ __param(1, (0, common_1.Res)()),
71
+ __param(2, (0, common_1.Body)()),
72
+ __metadata("design:type", Function),
73
+ __metadata("design:paramtypes", [Object, Object, Object]),
74
+ __metadata("design:returntype", Promise)
75
+ ], AuthController.prototype, "login", null);
76
+ exports.AuthController = AuthController = __decorate([
77
+ (0, common_1.Controller)('api/v6/auth'),
78
+ __metadata("design:paramtypes", [auth_service_1.AuthService])
79
+ ], AuthController);
80
+ //# sourceMappingURL=auth.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.controller.js","sourceRoot":"","sources":["../../src/auth/auth.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAQwB;AACxB,iDAA6C;AAC7C,6CAA0C;AAInC,IAAM,cAAc,GAApB,MAAM,cAAc;IACzB,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAsB1C,AAAN,KAAK,CAAC,KAAK,CACF,GAAY,EACZ,GAAa,EACZ,SAA8B;QAEtC,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,CAC1C,SAAS,CAAC,QAAQ,EAClB,SAAS,CAAC,QAAQ,CACnB,CAAC;YACF,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;YAE1C,MAAM,aAAa,GAAkB;gBACnC,QAAQ,EAAE,IAAI;gBACd,QAAQ,EAAE,QAAQ;gBAClB,MAAM,EAAE,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI;aACtC,CAAC;YAEF,IAAI,OAAO,CAAC,GAAG,CAAC,iCAAiC,IAAI,MAAM,EAAE,CAAC;gBAC5D,aAAa,CAAC,QAAQ,GAAG,MAAM,CAAC;gBAChC,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC;YAC9B,CAAC;YACD,GAAG,CAAC,MAAM,CAAC,cAAc,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;YACrD,GAAG,CAAC,MAAM,CAAC,WAAW,EAAE,IAAI,EAAE,aAAa,CAAC,CAAC;YAC7C,GAAG,CAAC,MAAM,CAAC,YAAY,EAAE,KAAK,EAAE,aAAa,CAAC,CAAC;YAE/C,OAAO,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACtC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAC;YAC7C,OAAO,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,uBAAuB,EAAE,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;CACF,CAAA;AAvDY,wCAAc;AAuBnB;IApBL,IAAA,iBAAQ,EAAC,mBAAU,CAAC,EAAE,CAAC;IACvB,IAAA,aAAI,EAAC,OAAO,CAAC;IACb,IAAA,iBAAO,EAAC;QACP,MAAM,EAAE;YACN,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;gBAC5B,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;aAC7B;SACF;QACD,QAAQ,EAAE;YACR,IAAI,EAAE;gBACJ,OAAO,EAAE,MAAM;gBACf,KAAK,EAAE;oBACL,QAAQ,EAAE,MAAM;oBAChB,QAAQ,EAAE,MAAM;iBACjB;aACF;SACF;KACF,CAAC;IAEC,WAAA,IAAA,YAAG,GAAE,CAAA;IACL,WAAA,IAAA,YAAG,GAAE,CAAA;IACL,WAAA,IAAA,aAAI,GAAE,CAAA;;;;2CA4BR;yBAtDU,cAAc;IAD1B,IAAA,mBAAU,EAAC,aAAa,CAAC;qCAES,0BAAW;GADjC,cAAc,CAuD1B"}
@@ -0,0 +1,7 @@
1
+ import { CanActivate, ExecutionContext } from '@nestjs/common';
2
+ import { AuthService } from './auth.service';
3
+ export declare class AuthGuard implements CanActivate {
4
+ private authService;
5
+ constructor(authService: AuthService);
6
+ canActivate(context: ExecutionContext): Promise<boolean>;
7
+ }
@@ -0,0 +1,41 @@
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.AuthGuard = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const auth_service_1 = require("./auth.service");
15
+ let AuthGuard = class AuthGuard {
16
+ constructor(authService) {
17
+ this.authService = authService;
18
+ }
19
+ async canActivate(context) {
20
+ const request = context.switchToHttp().getRequest();
21
+ const token = this.authService.extractTokenFromHeaderOrCookie(request);
22
+ if (!token) {
23
+ console.error('Token not found', token);
24
+ throw new common_1.UnauthorizedException();
25
+ }
26
+ try {
27
+ const user = await this.authService.getUserByToken(token);
28
+ request['user'] = user;
29
+ }
30
+ catch {
31
+ throw new common_1.UnauthorizedException();
32
+ }
33
+ return true;
34
+ }
35
+ };
36
+ exports.AuthGuard = AuthGuard;
37
+ exports.AuthGuard = AuthGuard = __decorate([
38
+ (0, common_1.Injectable)(),
39
+ __metadata("design:paramtypes", [auth_service_1.AuthService])
40
+ ], AuthGuard);
41
+ //# sourceMappingURL=auth.guard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.guard.js","sourceRoot":"","sources":["../../src/auth/auth.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAKwB;AACxB,iDAA6C;AAGtC,IAAM,SAAS,GAAf,MAAM,SAAS;IACpB,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAEhD,KAAK,CAAC,WAAW,CAAC,OAAyB;QACzC,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;QACpD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,8BAA8B,CAAC,OAAO,CAAC,CAAC;QACvE,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO,CAAC,KAAK,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAC;YACxC,MAAM,IAAI,8BAAqB,EAAE,CAAC;QACpC,CAAC;QACD,IAAI,CAAC;YAGH,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAC1D,OAAO,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC;QACzB,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,IAAI,8BAAqB,EAAE,CAAC;QACpC,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AApBY,8BAAS;oBAAT,SAAS;IADrB,IAAA,mBAAU,GAAE;qCAEsB,0BAAW;GADjC,SAAS,CAoBrB"}
@@ -0,0 +1,2 @@
1
+ export declare class AuthModule {
2
+ }
@@ -0,0 +1,34 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.AuthModule = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const jwt_1 = require("@nestjs/jwt");
12
+ const auth_controller_1 = require("./auth.controller");
13
+ const auth_service_1 = require("./auth.service");
14
+ const mongodb_module_1 = require("../mongodb/mongodb.module");
15
+ const admin_guard_1 = require("./admin.guard");
16
+ const auth_guard_1 = require("./auth.guard");
17
+ let AuthModule = class AuthModule {
18
+ };
19
+ exports.AuthModule = AuthModule;
20
+ exports.AuthModule = AuthModule = __decorate([
21
+ (0, common_1.Module)({
22
+ imports: [
23
+ mongodb_module_1.MongodbModule,
24
+ jwt_1.JwtModule.register({
25
+ secret: process.env.JWT_SECRET || 'secret',
26
+ signOptions: { expiresIn: '60s' },
27
+ }),
28
+ ],
29
+ controllers: [auth_controller_1.AuthController],
30
+ providers: [auth_service_1.AuthService, admin_guard_1.AdminGuard, auth_guard_1.AuthGuard],
31
+ exports: [auth_service_1.AuthService, admin_guard_1.AdminGuard, auth_guard_1.AuthGuard],
32
+ })
33
+ ], AuthModule);
34
+ //# sourceMappingURL=auth.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.module.js","sourceRoot":"","sources":["../../src/auth/auth.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qCAAwC;AACxC,uDAAmD;AACnD,iDAA6C;AAC7C,8DAAyD;AACzD,+CAA2C;AAC3C,6CAAyC;AAclC,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAZtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,8BAAa;YACb,eAAS,CAAC,QAAQ,CAAC;gBACjB,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,QAAQ;gBAC1C,WAAW,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;aAClC,CAAC;SACH;QACD,WAAW,EAAE,CAAC,gCAAc,CAAC;QAC7B,SAAS,EAAE,CAAC,0BAAW,EAAE,wBAAU,EAAE,sBAAS,CAAC;QAC/C,OAAO,EAAE,CAAC,0BAAW,EAAE,wBAAU,EAAE,sBAAS,CAAC;KAC9C,CAAC;GACW,UAAU,CAAG"}
@@ -0,0 +1,22 @@
1
+ import { MongodbService } from '@/mongodb/mongodb.service';
2
+ import { JwtService } from '@nestjs/jwt';
3
+ import { Request } from 'express';
4
+ export declare class AuthService {
5
+ private mongodbService;
6
+ private jwtService;
7
+ private masterSpaceId;
8
+ constructor(mongodbService: MongodbService, jwtService: JwtService);
9
+ signIn(username: string, password: string, spaceId?: string): Promise<any>;
10
+ getMasterSpaceId(): Promise<string>;
11
+ getSpaceUser(userId: string, spaceId: string): Promise<any>;
12
+ getUserByToken(token: string): Promise<any>;
13
+ extractTokenFromHeaderOrCookie(request: Request): string | undefined;
14
+ hashLoginToken(loginToken: any): string;
15
+ generateStampedLoginToken(token: any): {
16
+ token: any;
17
+ when: Date;
18
+ };
19
+ hashStampedToken(stampedToken: any): {
20
+ hashedToken: string;
21
+ };
22
+ }
@@ -0,0 +1,172 @@
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.AuthService = void 0;
13
+ const bcrypt = require("bcrypt");
14
+ const crypto = require("crypto");
15
+ const uuid_1 = require("uuid");
16
+ const common_1 = require("@nestjs/common");
17
+ const mongodb_service_1 = require("../mongodb/mongodb.service");
18
+ const jwt_1 = require("@nestjs/jwt");
19
+ let AuthService = class AuthService {
20
+ constructor(mongodbService, jwtService) {
21
+ this.mongodbService = mongodbService;
22
+ this.jwtService = jwtService;
23
+ }
24
+ async signIn(username, password, spaceId) {
25
+ if (!spaceId) {
26
+ spaceId = await this.getMasterSpaceId();
27
+ }
28
+ const hash = crypto.createHash('sha256');
29
+ hash.update(password);
30
+ const bcryptPassword = hash.digest('hex');
31
+ const user = (await this.mongodbService.findOne('users', {
32
+ $or: [
33
+ { username: username },
34
+ { 'emails.address': username },
35
+ { mobile: username },
36
+ ],
37
+ }));
38
+ if (!user) {
39
+ throw new common_1.UnauthorizedException();
40
+ }
41
+ const match = await bcrypt.compare(bcryptPassword, user.services.password.bcrypt);
42
+ if (!match) {
43
+ throw new common_1.UnauthorizedException();
44
+ }
45
+ const space_user = await this.getSpaceUser(user._id, spaceId);
46
+ if (!space_user) {
47
+ throw new common_1.UnauthorizedException();
48
+ }
49
+ const payload = {
50
+ sub: user._id,
51
+ name: space_user.name,
52
+ email: space_user.email,
53
+ space: spaceId,
54
+ profile: space_user.profile,
55
+ };
56
+ const access_token = this.jwtService.sign(payload);
57
+ const authToken = (0, uuid_1.v4)();
58
+ const stampedAuthToken = this.generateStampedLoginToken(authToken);
59
+ const hashedToken = this.hashStampedToken(stampedAuthToken);
60
+ if (!user['services']) {
61
+ user['services'] = {};
62
+ }
63
+ if (!user['services']['resume']) {
64
+ user['services']['resume'] = { loginTokens: [] };
65
+ }
66
+ user['services']['resume']['loginTokens'].push(hashedToken);
67
+ const data = { services: user['services'] };
68
+ await this.mongodbService.findOneAndUpdate('users', user._id, data);
69
+ return {
70
+ access_token: access_token,
71
+ authToken: authToken,
72
+ ...space_user,
73
+ };
74
+ }
75
+ async getMasterSpaceId() {
76
+ if (this.masterSpaceId) {
77
+ return this.masterSpaceId;
78
+ }
79
+ const space = await this.mongodbService.findOne('spaces', {}, { sort: { created: -1 } });
80
+ if (space) {
81
+ this.masterSpaceId = space._id;
82
+ }
83
+ return this.masterSpaceId;
84
+ }
85
+ async getSpaceUser(userId, spaceId) {
86
+ const spaceUser = await this.mongodbService.findOne('space_users', {
87
+ user: userId,
88
+ space: spaceId,
89
+ });
90
+ if (spaceUser) {
91
+ spaceUser['_id'] = userId;
92
+ delete spaceUser['password'];
93
+ }
94
+ return spaceUser;
95
+ }
96
+ async getUserByToken(token) {
97
+ const tokenArray = token.split(',');
98
+ let userId = null;
99
+ let spaceId = null;
100
+ if (tokenArray.length === 1) {
101
+ const payload = this.jwtService.decode(token);
102
+ console.log('payload', payload);
103
+ const user = (await this.mongodbService.findOne('users', {
104
+ '_id': payload.sub,
105
+ }));
106
+ if (user) {
107
+ userId = user._id;
108
+ spaceId = payload.space;
109
+ }
110
+ }
111
+ else if (tokenArray.length === 2 && tokenArray[0] === 'apikey') {
112
+ const apiKeyString = tokenArray[1];
113
+ const apiKey = await this.mongodbService.findOne('api_keys', { api_key: apiKeyString, active: true });
114
+ if (apiKey) {
115
+ userId = apiKey.owner;
116
+ spaceId = apiKey.space;
117
+ await this.mongodbService.findOneAndUpdate('api_keys', apiKey._id, { last_use_time: new Date() });
118
+ }
119
+ }
120
+ else if (tokenArray.length === 2) {
121
+ spaceId = tokenArray[0];
122
+ const authToken = tokenArray[1];
123
+ const hashedStampedToken = this.hashLoginToken(authToken);
124
+ const user = (await this.mongodbService.findOne('users', {
125
+ 'services.resume.loginTokens.hashedToken': hashedStampedToken,
126
+ }));
127
+ if (user)
128
+ userId = user._id;
129
+ }
130
+ if (userId && spaceId) {
131
+ const space_user = await this.getSpaceUser(userId, spaceId);
132
+ return space_user;
133
+ }
134
+ throw new common_1.UnauthorizedException();
135
+ }
136
+ extractTokenFromHeaderOrCookie(request) {
137
+ const [type, token] = request.headers.authorization?.split(' ') ?? [];
138
+ let spaceToken = type === 'Bearer' ? token : undefined;
139
+ if (!spaceToken &&
140
+ request.cookies &&
141
+ request.cookies['X-Auth-Token'] &&
142
+ request.cookies['X-Space-Id']) {
143
+ spaceToken = `${request.cookies['X-Space-Id']},${request.cookies['X-Auth-Token']}`;
144
+ }
145
+ return spaceToken;
146
+ }
147
+ hashLoginToken(loginToken) {
148
+ const hash = crypto.createHash('sha256');
149
+ hash.update(loginToken);
150
+ return hash.digest('base64');
151
+ }
152
+ generateStampedLoginToken(token) {
153
+ return {
154
+ token: token,
155
+ when: new Date(),
156
+ };
157
+ }
158
+ hashStampedToken(stampedToken) {
159
+ const hashedStampedToken = Object.keys(stampedToken).reduce((prev, key) => key === 'token' ? prev : { ...prev, [key]: stampedToken[key] }, {});
160
+ return {
161
+ ...hashedStampedToken,
162
+ hashedToken: this.hashLoginToken(stampedToken.token),
163
+ };
164
+ }
165
+ };
166
+ exports.AuthService = AuthService;
167
+ exports.AuthService = AuthService = __decorate([
168
+ (0, common_1.Injectable)(),
169
+ __metadata("design:paramtypes", [mongodb_service_1.MongodbService,
170
+ jwt_1.JwtService])
171
+ ], AuthService);
172
+ //# sourceMappingURL=auth.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../src/auth/auth.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export * from './admin.guard';
2
+ export * from './auth.controller';
3
+ export * from './auth.guard';
4
+ export * from './auth.module';
5
+ export * from './auth.service';
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./admin.guard"), exports);
18
+ __exportStar(require("./auth.controller"), exports);
19
+ __exportStar(require("./auth.guard"), exports);
20
+ __exportStar(require("./auth.module"), exports);
21
+ __exportStar(require("./auth.service"), exports);
22
+ //# sourceMappingURL=index.js.map