sumor 3.3.0 → 3.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -14
- package/README.zh-CN.md +8 -14
- package/dist/server/mock/mockApiRoutes.d.ts.map +1 -1
- package/dist/server/mock/mockApiRoutes.js +1 -3
- package/dist/server/mock/mockApiRoutes.js.map +1 -1
- package/dist/server/mock/mockConfig.d.ts +0 -4
- package/dist/server/mock/mockConfig.d.ts.map +1 -1
- package/dist/server/mock/mockConfig.js +1 -5
- package/dist/server/mock/mockConfig.js.map +1 -1
- package/dist/server/mock/mockRoutes.d.ts.map +1 -1
- package/dist/server/mock/mockRoutes.js +1 -7
- package/dist/server/mock/mockRoutes.js.map +1 -1
- package/dist/server/utils/config.js +4 -4
- package/dist/server/utils/config.js.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
|
|
6
6
|
A comprehensive OAuth 2.0 authentication framework for Express.js applications with role-based access control (RBAC). Sumor simplifies OAuth integration, token management, and permission-based route protection in multi-service architectures.
|
|
7
7
|
|
|
8
|
-
[中文文档](
|
|
8
|
+
[中文文档](https://www.npmjs.com/package/sumor?activeTab=code)
|
|
9
9
|
|
|
10
10
|
## Key Features
|
|
11
11
|
|
|
@@ -424,21 +424,15 @@ OAUTH_MOCK_USER_ID=mock-user-001
|
|
|
424
424
|
OAUTH_MOCK_USER_ROLES=admin
|
|
425
425
|
OAUTH_MOCK_USER_PERMISSIONS=
|
|
426
426
|
OAUTH_MOCK_USER_IS_VERIFIED=1
|
|
427
|
-
|
|
428
|
-
# URLs returned by the mock token endpoint
|
|
429
|
-
OAUTH_MOCK_ENDPOINT=http://localhost
|
|
430
|
-
OAUTH_MOCK_REDIRECT_URI=http://localhost
|
|
431
427
|
```
|
|
432
428
|
|
|
433
|
-
| Variable | Default
|
|
434
|
-
| ----------------------------- |
|
|
435
|
-
| `OAUTH_MOCK` | `false`
|
|
436
|
-
| `OAUTH_MOCK_USER_ID` | `mock-user-001`
|
|
437
|
-
| `OAUTH_MOCK_USER_ROLES` | `admin`
|
|
438
|
-
| `OAUTH_MOCK_USER_PERMISSIONS` | _(empty)_
|
|
439
|
-
| `OAUTH_MOCK_USER_IS_VERIFIED` | `1`
|
|
440
|
-
| `OAUTH_MOCK_ENDPOINT` | `http://localhost` | Endpoint value returned in token response |
|
|
441
|
-
| `OAUTH_MOCK_REDIRECT_URI` | `http://localhost` | Origin to redirect after mock login |
|
|
429
|
+
| Variable | Default | Description |
|
|
430
|
+
| ----------------------------- | --------------- | ------------------------------------- |
|
|
431
|
+
| `OAUTH_MOCK` | `false` | Set to `true` to enable mock mode |
|
|
432
|
+
| `OAUTH_MOCK_USER_ID` | `mock-user-001` | Mock user ID |
|
|
433
|
+
| `OAUTH_MOCK_USER_ROLES` | `admin` | Comma-separated mock roles |
|
|
434
|
+
| `OAUTH_MOCK_USER_PERMISSIONS` | _(empty)_ | Comma-separated mock permissions |
|
|
435
|
+
| `OAUTH_MOCK_USER_IS_VERIFIED` | `1` | Mock verification status (`0` or `1`) |
|
|
442
436
|
|
|
443
437
|
### Mock Routes (registered only when `OAUTH_MOCK=true`)
|
|
444
438
|
|
package/README.zh-CN.md
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
|
|
6
6
|
Sumor 是一个面向 Express.js 应用的完整 OAuth 2.0 认证框架,内置基于角色的访问控制(RBAC)。它将 OAuth 集成、令牌管理和权限路由保护简化为开箱即用的中间件与工具函数,适用于多服务架构。
|
|
7
7
|
|
|
8
|
-
[English Documentation](README.md)
|
|
8
|
+
[English Documentation](https://www.npmjs.com/package/sumor?activeTab=explore&filePath=README.md)
|
|
9
9
|
|
|
10
10
|
## 核心特性
|
|
11
11
|
|
|
@@ -423,21 +423,15 @@ OAUTH_MOCK_USER_ID=mock-user-001
|
|
|
423
423
|
OAUTH_MOCK_USER_ROLES=admin
|
|
424
424
|
OAUTH_MOCK_USER_PERMISSIONS=
|
|
425
425
|
OAUTH_MOCK_USER_IS_VERIFIED=1
|
|
426
|
-
|
|
427
|
-
# Mock 令牌响应中返回的地址
|
|
428
|
-
OAUTH_MOCK_ENDPOINT=http://localhost
|
|
429
|
-
OAUTH_MOCK_REDIRECT_URI=http://localhost
|
|
430
426
|
```
|
|
431
427
|
|
|
432
|
-
| 变量 | 默认值
|
|
433
|
-
| ----------------------------- |
|
|
434
|
-
| `OAUTH_MOCK` | `false`
|
|
435
|
-
| `OAUTH_MOCK_USER_ID` | `mock-user-001`
|
|
436
|
-
| `OAUTH_MOCK_USER_ROLES` | `admin`
|
|
437
|
-
| `OAUTH_MOCK_USER_PERMISSIONS` | _(空)_
|
|
438
|
-
| `OAUTH_MOCK_USER_IS_VERIFIED` | `1`
|
|
439
|
-
| `OAUTH_MOCK_ENDPOINT` | `http://localhost` | 令牌响应中返回的 endpoint 值 |
|
|
440
|
-
| `OAUTH_MOCK_REDIRECT_URI` | `http://localhost` | Mock 登录后跳转的 origin |
|
|
428
|
+
| 变量 | 默认值 | 说明 |
|
|
429
|
+
| ----------------------------- | --------------- | --------------------------- |
|
|
430
|
+
| `OAUTH_MOCK` | `false` | 设为 `true` 启用 Mock 模式 |
|
|
431
|
+
| `OAUTH_MOCK_USER_ID` | `mock-user-001` | Mock 用户 ID |
|
|
432
|
+
| `OAUTH_MOCK_USER_ROLES` | `admin` | 逗号分隔的 Mock 角色 |
|
|
433
|
+
| `OAUTH_MOCK_USER_PERMISSIONS` | _(空)_ | 逗号分隔的 Mock 权限 |
|
|
434
|
+
| `OAUTH_MOCK_USER_IS_VERIFIED` | `1` | Mock 认证状态(`0` 或 `1`) |
|
|
441
435
|
|
|
442
436
|
### Mock 专用路由(仅在 `OAUTH_MOCK=true` 时注册)
|
|
443
437
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockApiRoutes.d.ts","sourceRoot":"","sources":["../../../server/mock/mockApiRoutes.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAYH,QAAA,MAAM,aAAa,4CAAmB,CAAA;
|
|
1
|
+
{"version":3,"file":"mockApiRoutes.d.ts","sourceRoot":"","sources":["../../../server/mock/mockApiRoutes.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAYH,QAAA,MAAM,aAAa,4CAAmB,CAAA;AA0ItC,eAAe,aAAa,CAAA"}
|
|
@@ -25,7 +25,7 @@ const mockApiRoutes = express_1.default.Router();
|
|
|
25
25
|
* web SDK 拿到用户信息后直接更新 store,无需页面跳转
|
|
26
26
|
*/
|
|
27
27
|
mockApiRoutes.post('/login', (_req, res) => {
|
|
28
|
-
const { user
|
|
28
|
+
const { user } = (0, mockConfig_1.getMockConfig)();
|
|
29
29
|
const accessToken = (0, mockTokenUtils_1.generateMockAccessToken)(user);
|
|
30
30
|
const refreshToken = (0, mockTokenUtils_1.generateMockRefreshToken)(user);
|
|
31
31
|
(0, oauthTokenUtils_1.setOAuthTokenCookie)(res, accessToken, mockTokenUtils_1.MOCK_ACCESS_TOKEN_EXPIRES_IN, 'access');
|
|
@@ -35,8 +35,6 @@ mockApiRoutes.post('/login', (_req, res) => {
|
|
|
35
35
|
message: '登录成功',
|
|
36
36
|
data: {
|
|
37
37
|
isMock: true,
|
|
38
|
-
endpoint,
|
|
39
|
-
authorizeUrl: '',
|
|
40
38
|
user: {
|
|
41
39
|
id: user.userId,
|
|
42
40
|
isVerified: user.isVerified,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockApiRoutes.js","sourceRoot":"","sources":["../../../server/mock/mockApiRoutes.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;;;;;AAEH,sDAAoD;AACpD,6CAA4C;AAC5C,qDAKyB;AACzB,8DAA8D;AAE9D,MAAM,aAAa,GAAG,iBAAO,CAAC,MAAM,EAAE,CAAA;AAEtC;;;;GAIG;AACH,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAa,EAAE,GAAa,EAAE,EAAE;IAC5D,MAAM,EAAE,IAAI,EAAE,
|
|
1
|
+
{"version":3,"file":"mockApiRoutes.js","sourceRoot":"","sources":["../../../server/mock/mockApiRoutes.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;;;;;AAEH,sDAAoD;AACpD,6CAA4C;AAC5C,qDAKyB;AACzB,8DAA8D;AAE9D,MAAM,aAAa,GAAG,iBAAO,CAAC,MAAM,EAAE,CAAA;AAEtC;;;;GAIG;AACH,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAa,EAAE,GAAa,EAAE,EAAE;IAC5D,MAAM,EAAE,IAAI,EAAE,GAAG,IAAA,0BAAa,GAAE,CAAA;IAEhC,MAAM,WAAW,GAAG,IAAA,wCAAuB,EAAC,IAAI,CAAC,CAAA;IACjD,MAAM,YAAY,GAAG,IAAA,yCAAwB,EAAC,IAAI,CAAC,CAAA;IAEnD,IAAA,qCAAmB,EAAC,GAAG,EAAE,WAAW,EAAE,6CAA4B,EAAE,QAAQ,CAAC,CAAA;IAC7E,IAAA,qCAAmB,EAAC,GAAG,EAAE,YAAY,EAAE,8CAA6B,EAAE,SAAS,CAAC,CAAA;IAEhF,OAAO,GAAG,CAAC,IAAI,CAAC;QACd,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,MAAM;QACf,IAAI,EAAE;YACJ,MAAM,EAAE,IAAI;YACZ,IAAI,EAAE;gBACJ,EAAE,EAAE,IAAI,CAAC,MAAM;gBACf,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,WAAW,EAAE,IAAI,CAAC,WAAW;aAC9B;SACF;KACF,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF;;;GAGG;AACH,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,IAAa,EAAE,GAAa,EAAE,EAAE;IAC7D,GAAG,CAAC,WAAW,CAAC,cAAc,CAAC,CAAA;IAC/B,GAAG,CAAC,WAAW,CAAC,eAAe,CAAC,CAAA;IAEhC,OAAO,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAA;AAClD,CAAC,CAAC,CAAA;AAEF;;;GAGG;AACH,aAAa,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,IAAa,EAAE,GAAa,EAAE,EAAE;IAChE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAA;AACvB,CAAC,CAAC,CAAA;AAEF,MAAM,UAAU,GAA2B;IACzC,IAAI,EAAE,IAAI;IACV,IAAI,EAAE,MAAM;IACZ,IAAI,EAAE,MAAM;IACZ,QAAQ,EAAE,MAAM;CACjB,CAAA;AAED;;;GAGG;AACH,aAAa,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC,GAAY,EAAE,GAAa,EAAE,EAAE;IAChE,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAW,CAAA;IAC7C,MAAM,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC,IAAI,MAAM,CAAA;IAE1C,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,0BAA0B,CAAC,CAAA;IACzD,GAAG,CAAC,IAAI,CAAC;;;;;kBAKO,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UA2Db,KAAK;uDACwC,KAAK;;;;QAIpD,CAAC,CAAA;AACT,CAAC,CAAC,CAAA;AAEF,kBAAe,aAAa,CAAA"}
|
|
@@ -8,8 +8,6 @@
|
|
|
8
8
|
* OAUTH_MOCK_USER_ROLES - 用户角色,逗号分隔(默认:admin)
|
|
9
9
|
* OAUTH_MOCK_USER_PERMISSIONS - 用户权限,逗号分隔(默认:空)
|
|
10
10
|
* OAUTH_MOCK_USER_IS_VERIFIED - 是否已认证 0/1(默认:1)
|
|
11
|
-
* OAUTH_MOCK_ENDPOINT - Mock 时返回的 endpoint(默认:http://localhost)
|
|
12
|
-
* OAUTH_MOCK_REDIRECT_URI - Mock 回调后跳转的 origin(默认:http://localhost)
|
|
13
11
|
*/
|
|
14
12
|
export interface MockUserConfig {
|
|
15
13
|
userId: string;
|
|
@@ -20,8 +18,6 @@ export interface MockUserConfig {
|
|
|
20
18
|
export interface MockConfig {
|
|
21
19
|
enabled: boolean;
|
|
22
20
|
user: MockUserConfig;
|
|
23
|
-
endpoint: string;
|
|
24
|
-
redirectUri: string;
|
|
25
21
|
}
|
|
26
22
|
/**
|
|
27
23
|
* 判断是否启用了 Mock 模式
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockConfig.d.ts","sourceRoot":"","sources":["../../../server/mock/mockConfig.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"mockConfig.d.ts","sourceRoot":"","sources":["../../../server/mock/mockConfig.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,MAAM,CAAA;IACd,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,EAAE,MAAM,CAAA;IACnB,UAAU,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,OAAO,CAAA;IAChB,IAAI,EAAE,cAAc,CAAA;CACrB;AAID;;GAEG;AACH,wBAAgB,UAAU,IAAI,OAAO,CAEpC;AAED;;GAEG;AACH,wBAAgB,aAAa,IAAI,UAAU,CAa1C;AAED;;GAEG;AACH,wBAAgB,oBAAoB,IAAI,IAAI,CAE3C"}
|
|
@@ -9,8 +9,6 @@
|
|
|
9
9
|
* OAUTH_MOCK_USER_ROLES - 用户角色,逗号分隔(默认:admin)
|
|
10
10
|
* OAUTH_MOCK_USER_PERMISSIONS - 用户权限,逗号分隔(默认:空)
|
|
11
11
|
* OAUTH_MOCK_USER_IS_VERIFIED - 是否已认证 0/1(默认:1)
|
|
12
|
-
* OAUTH_MOCK_ENDPOINT - Mock 时返回的 endpoint(默认:http://localhost)
|
|
13
|
-
* OAUTH_MOCK_REDIRECT_URI - Mock 回调后跳转的 origin(默认:http://localhost)
|
|
14
12
|
*/
|
|
15
13
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
14
|
exports.isMockMode = isMockMode;
|
|
@@ -35,9 +33,7 @@ function getMockConfig() {
|
|
|
35
33
|
roles: process.env.OAUTH_MOCK_USER_ROLES || 'admin',
|
|
36
34
|
permissions: process.env.OAUTH_MOCK_USER_PERMISSIONS || '',
|
|
37
35
|
isVerified: parseInt(process.env.OAUTH_MOCK_USER_IS_VERIFIED || '1', 10)
|
|
38
|
-
}
|
|
39
|
-
endpoint: process.env.OAUTH_MOCK_ENDPOINT || 'http://localhost',
|
|
40
|
-
redirectUri: process.env.OAUTH_MOCK_REDIRECT_URI || 'http://localhost'
|
|
36
|
+
}
|
|
41
37
|
};
|
|
42
38
|
}
|
|
43
39
|
return cachedMockConfig;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockConfig.js","sourceRoot":"","sources":["../../../server/mock/mockConfig.ts"],"names":[],"mappings":";AAAA
|
|
1
|
+
{"version":3,"file":"mockConfig.js","sourceRoot":"","sources":["../../../server/mock/mockConfig.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;;AAmBH,gCAEC;AAKD,sCAaC;AAKD,oDAEC;AAhCD,IAAI,gBAAgB,GAAsB,IAAI,CAAA;AAE9C;;GAEG;AACH,SAAgB,UAAU;IACxB,OAAO,OAAO,CAAC,GAAG,CAAC,UAAU,KAAK,MAAM,CAAA;AAC1C,CAAC;AAED;;GAEG;AACH,SAAgB,aAAa;IAC3B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACtB,gBAAgB,GAAG;YACjB,OAAO,EAAE,UAAU,EAAE;YACrB,IAAI,EAAE;gBACJ,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,eAAe;gBACzD,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,qBAAqB,IAAI,OAAO;gBACnD,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,2BAA2B,IAAI,EAAE;gBAC1D,UAAU,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,2BAA2B,IAAI,GAAG,EAAE,EAAE,CAAC;aACzE;SACF,CAAA;IACH,CAAC;IACD,OAAO,gBAAgB,CAAA;AACzB,CAAC;AAED;;GAEG;AACH,SAAgB,oBAAoB;IAClC,gBAAgB,GAAG,IAAI,CAAA;AACzB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockRoutes.d.ts","sourceRoot":"","sources":["../../../server/mock/mockRoutes.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAYH,QAAA,MAAM,UAAU,4CAAmB,CAAA;
|
|
1
|
+
{"version":3,"file":"mockRoutes.d.ts","sourceRoot":"","sources":["../../../server/mock/mockRoutes.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAYH,QAAA,MAAM,UAAU,4CAAmB,CAAA;AAsFnC,eAAe,UAAU,CAAA"}
|
|
@@ -19,7 +19,7 @@ const mockRoutes = express_1.default.Router();
|
|
|
19
19
|
* 验证 mock token 并返回用户信息,响应中包含 isMock: true
|
|
20
20
|
*/
|
|
21
21
|
mockRoutes.put('/token', (req, res) => {
|
|
22
|
-
const { user
|
|
22
|
+
const { user } = (0, mockConfig_1.getMockConfig)();
|
|
23
23
|
const cookies = parseCookies(req.headers.cookie);
|
|
24
24
|
const accessTokenRaw = cookies.access_token || '';
|
|
25
25
|
const refreshTokenRaw = cookies.refresh_token || '';
|
|
@@ -33,8 +33,6 @@ mockRoutes.put('/token', (req, res) => {
|
|
|
33
33
|
message: 'Token 仍然有效',
|
|
34
34
|
data: {
|
|
35
35
|
isMock: true,
|
|
36
|
-
endpoint,
|
|
37
|
-
authorizeUrl: '',
|
|
38
36
|
user: {
|
|
39
37
|
id: claims.sub,
|
|
40
38
|
isVerified: claims.isVerified ?? user.isVerified,
|
|
@@ -60,8 +58,6 @@ mockRoutes.put('/token', (req, res) => {
|
|
|
60
58
|
message: 'Token 刷新成功',
|
|
61
59
|
data: {
|
|
62
60
|
isMock: true,
|
|
63
|
-
endpoint,
|
|
64
|
-
authorizeUrl: '',
|
|
65
61
|
user: {
|
|
66
62
|
id: user.userId,
|
|
67
63
|
isVerified: user.isVerified,
|
|
@@ -81,8 +77,6 @@ mockRoutes.put('/token', (req, res) => {
|
|
|
81
77
|
message: '未登录',
|
|
82
78
|
data: {
|
|
83
79
|
isMock: true,
|
|
84
|
-
endpoint,
|
|
85
|
-
authorizeUrl: '',
|
|
86
80
|
user: null
|
|
87
81
|
}
|
|
88
82
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mockRoutes.js","sourceRoot":"","sources":["../../../server/mock/mockRoutes.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;;;AAEH,sDAAoD;AACpD,6CAA4C;AAC5C,qDAKyB;AACzB,8DAA8D;AAE9D,MAAM,UAAU,GAAG,iBAAO,CAAC,MAAM,EAAE,CAAA;AAEnC;;;GAGG;AACH,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,GAAY,EAAE,GAAa,EAAE,EAAE;IACvD,MAAM,EAAE,IAAI,EAAE,
|
|
1
|
+
{"version":3,"file":"mockRoutes.js","sourceRoot":"","sources":["../../../server/mock/mockRoutes.ts"],"names":[],"mappings":"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"}
|
|
@@ -35,13 +35,13 @@ function getOAuthConfig() {
|
|
|
35
35
|
if (!oauthConfig) {
|
|
36
36
|
// Mock 模式下无需真实 OAuth 配置,使用 mock 占位值
|
|
37
37
|
if ((0, mockConfig_1.isMockMode)()) {
|
|
38
|
-
const
|
|
38
|
+
const mockEndpoint = 'http://localhost:3000';
|
|
39
39
|
oauthConfig = {
|
|
40
|
-
endpoint:
|
|
41
|
-
baseUrl: buildBaseUrl(
|
|
40
|
+
endpoint: mockEndpoint,
|
|
41
|
+
baseUrl: buildBaseUrl(mockEndpoint),
|
|
42
42
|
clientKey: 'mock-client-key',
|
|
43
43
|
clientSecret: 'mock-client-secret',
|
|
44
|
-
redirectUri:
|
|
44
|
+
redirectUri: 'http://localhost:3000/auth/callback'
|
|
45
45
|
};
|
|
46
46
|
return oauthConfig;
|
|
47
47
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../server/utils/config.ts"],"names":[],"mappings":";AAAA;;;GAGG;;AA+BH,wCA4CC;AAxED,
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../server/utils/config.ts"],"names":[],"mappings":";AAAA;;;GAGG;;AA+BH,wCA4CC;AAxED,mDAA+C;AAE/C,SAAS,oBAAoB,CAAC,GAAW;IACvC,MAAM,CAAC,GAAG,GAAG,CAAC,IAAI,EAAE,CAAA;IACpB,OAAO,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;AAC7D,CAAC;AAED;;;GAGG;AACH,SAAS,YAAY,CAAC,QAAgB;IACpC,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;IACzC,IAAI,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC;QAAE,OAAO,IAAI,CAAA;IAC5C,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;QAAE,OAAO,GAAG,IAAI,QAAQ,CAAA;IACjD,OAAO,GAAG,IAAI,YAAY,CAAA;AAC5B,CAAC;AAED,UAAU;AACV,IAAI,WAAW,GAAuB,IAAI,CAAA;AAE1C;;;;;;GAMG;AACH,SAAgB,cAAc;IAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,oCAAoC;QACpC,IAAI,IAAA,uBAAU,GAAE,EAAE,CAAC;YACjB,MAAM,YAAY,GAAG,uBAAuB,CAAA;YAC5C,WAAW,GAAG;gBACZ,QAAQ,EAAE,YAAY;gBACtB,OAAO,EAAE,YAAY,CAAC,YAAY,CAAC;gBACnC,SAAS,EAAE,iBAAiB;gBAC5B,YAAY,EAAE,oBAAoB;gBAClC,WAAW,EAAE,qCAAqC;aACnD,CAAA;YACD,OAAO,WAAW,CAAA;QACpB,CAAC;QAED,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,CAAA;QAChD,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAA;QAClD,MAAM,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAA;QACzD,MAAM,mBAAmB,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAA;QAE1D,YAAY;QACZ,IAAI,CAAC,aAAa,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAA;QAC7C,CAAC;QAED,IAAI,CAAC,aAAa,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzC,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAA;QACzE,CAAC;QAED,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACzB,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAA;QACvD,CAAC;QAED,MAAM,WAAW,GAAG,oBAAoB,CAAC,mBAAmB,CAAC,CAAA;QAE7D,WAAW,GAAG;YACZ,QAAQ,EAAE,aAAa;YACvB,OAAO,EAAE,YAAY,CAAC,aAAa,CAAC;YACpC,SAAS,EAAE,aAAa;YACxB,YAAY,EAAE,iBAAiB;YAC/B,WAAW;SACZ,CAAA;IACH,CAAC;IACD,OAAO,WAAW,CAAA;AACpB,CAAC"}
|