@pengzi/kms 1.2.0 → 1.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 +794 -20
- package/dist/client.d.ts +25 -1
- package/dist/client.d.ts.map +1 -1
- package/dist/client.js +61 -3
- package/dist/client.js.map +1 -1
- package/dist/services/audit.service.d.ts +4 -0
- package/dist/services/audit.service.d.ts.map +1 -1
- package/dist/services/audit.service.js +16 -0
- package/dist/services/audit.service.js.map +1 -1
- package/dist/services/key.service.d.ts +14 -1
- package/dist/services/key.service.d.ts.map +1 -1
- package/dist/services/key.service.js +72 -13
- package/dist/services/key.service.js.map +1 -1
- package/dist/services/project.service.d.ts +14 -1
- package/dist/services/project.service.d.ts.map +1 -1
- package/dist/services/project.service.js +50 -0
- package/dist/services/project.service.js.map +1 -1
- package/dist/src/client.js +61 -3
- package/dist/src/services/audit.service.js +16 -0
- package/dist/src/services/key.service.js +72 -13
- package/dist/src/services/project.service.js +50 -0
- package/dist/types/index.d.ts +8 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js.map +1 -1
- package/package.json +1 -1
package/dist/client.d.ts
CHANGED
|
@@ -22,6 +22,8 @@ export declare class KMSClient {
|
|
|
22
22
|
private auditService;
|
|
23
23
|
private connected;
|
|
24
24
|
private currentUserId;
|
|
25
|
+
private defaultProjectId;
|
|
26
|
+
private defaultMasterPassword;
|
|
25
27
|
constructor(options: KMSClientOptions | EncryptedKMSClientOptions);
|
|
26
28
|
/**
|
|
27
29
|
* 解析连接字符串(支持加密配置)
|
|
@@ -43,6 +45,14 @@ export declare class KMSClient {
|
|
|
43
45
|
* 初始化数据库索引
|
|
44
46
|
*/
|
|
45
47
|
private initializeIndexes;
|
|
48
|
+
/**
|
|
49
|
+
* 初始化默认项目(简化 API 使用)
|
|
50
|
+
*/
|
|
51
|
+
private initDefaultProject;
|
|
52
|
+
/**
|
|
53
|
+
* 确保默认项目已初始化(简化 API 使用)
|
|
54
|
+
*/
|
|
55
|
+
private ensureDefaultProject;
|
|
46
56
|
/**
|
|
47
57
|
* 设置当前用户(用于权限验证)
|
|
48
58
|
*/
|
|
@@ -73,8 +83,11 @@ export declare class KMSClient {
|
|
|
73
83
|
createKey(projectId: string, masterPassword: string, keyData: CreateKeyData): Promise<Key>;
|
|
74
84
|
/**
|
|
75
85
|
* 获取密钥(解密)
|
|
86
|
+
* 支持两种调用方式:
|
|
87
|
+
* 1. 简化版: getKey(keyName) - 需要配置 defaultProjectName + masterPassword
|
|
88
|
+
* 2. 完整版: getKey(projectId, masterPassword, keyId) - 需要 setCurrentUser
|
|
76
89
|
*/
|
|
77
|
-
getKey(
|
|
90
|
+
getKey(arg1: string, arg2?: string, arg3?: string): Promise<any>;
|
|
78
91
|
/**
|
|
79
92
|
* 列出密钥
|
|
80
93
|
*/
|
|
@@ -93,6 +106,17 @@ export declare class KMSClient {
|
|
|
93
106
|
* 删除密钥
|
|
94
107
|
*/
|
|
95
108
|
deleteKey(projectId: string, keyId: string): Promise<void>;
|
|
109
|
+
/**
|
|
110
|
+
* 设置密钥(极简 API)
|
|
111
|
+
* 用法: await kms.setKey('api-key', 'secret123')
|
|
112
|
+
* 需要 KMSClient 配置 defaultProjectName + masterPassword
|
|
113
|
+
*/
|
|
114
|
+
setKey(keyName: string, value: string): Promise<void>;
|
|
115
|
+
/**
|
|
116
|
+
* 通过项目名称获取密钥(简化 API)
|
|
117
|
+
* 需要传入项目名称和主密码
|
|
118
|
+
*/
|
|
119
|
+
getKeyByName(projectName: string, keyName: string, masterPassword: string): Promise<KeyValue>;
|
|
96
120
|
/**
|
|
97
121
|
* 创建用户
|
|
98
122
|
*/
|
package/dist/client.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EACL,gBAAgB,EAChB,yBAAyB,EACzB,OAAO,EACP,GAAG,EACH,QAAQ,EACR,aAAa,EACb,aAAa,EACb,UAAU,EACV,cAAc,EACd,IAAI,EACJ,IAAI,EACJ,QAAQ,EACR,UAAU,
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
|
package/dist/client.js
CHANGED
|
@@ -37,6 +37,8 @@ class KMSClient {
|
|
|
37
37
|
auditService;
|
|
38
38
|
connected = false;
|
|
39
39
|
currentUserId = null;
|
|
40
|
+
defaultProjectId = null;
|
|
41
|
+
defaultMasterPassword = null;
|
|
40
42
|
constructor(options) {
|
|
41
43
|
this.options = options;
|
|
42
44
|
const connectionString = this.resolveConnectionString(options);
|
|
@@ -95,6 +97,8 @@ class KMSClient {
|
|
|
95
97
|
this.initializeServices();
|
|
96
98
|
// 创建索引
|
|
97
99
|
await this.initializeIndexes();
|
|
100
|
+
// 如果配置了默认项目和主密码,自动初始化
|
|
101
|
+
await this.initDefaultProject();
|
|
98
102
|
}
|
|
99
103
|
catch (error) {
|
|
100
104
|
throw (0, error_handler_1.createKMSError)(error_handler_1.ErrorCode.CONNECTION_FAILED, error instanceof Error ? error.message : 'Failed to connect to database');
|
|
@@ -132,6 +136,29 @@ class KMSClient {
|
|
|
132
136
|
async initializeIndexes() {
|
|
133
137
|
// 索引在Repository的构造函数中自动创建
|
|
134
138
|
}
|
|
139
|
+
/**
|
|
140
|
+
* 初始化默认项目(简化 API 使用)
|
|
141
|
+
*/
|
|
142
|
+
async initDefaultProject() {
|
|
143
|
+
const opts = this.options;
|
|
144
|
+
const projectName = opts.defaultProjectName;
|
|
145
|
+
const masterPassword = opts.masterPassword;
|
|
146
|
+
if (projectName && masterPassword) {
|
|
147
|
+
const { project } = await this.projectService.getOrCreateProject(projectName, masterPassword);
|
|
148
|
+
this.defaultProjectId = project.projectId;
|
|
149
|
+
this.defaultMasterPassword = masterPassword;
|
|
150
|
+
this.currentUserId = '__sdk_auto__';
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* 确保默认项目已初始化(简化 API 使用)
|
|
155
|
+
*/
|
|
156
|
+
ensureDefaultProject() {
|
|
157
|
+
if (!this.defaultProjectId || !this.defaultMasterPassword) {
|
|
158
|
+
throw (0, error_handler_1.createKMSError)(error_handler_1.ErrorCode.VALIDATION_ERROR, 'defaultProjectName and masterPassword must be set in KMSClient options to use simplified API');
|
|
159
|
+
}
|
|
160
|
+
return { projectId: this.defaultProjectId, masterPassword: this.defaultMasterPassword };
|
|
161
|
+
}
|
|
135
162
|
/**
|
|
136
163
|
* 设置当前用户(用于权限验证)
|
|
137
164
|
*/
|
|
@@ -189,11 +216,20 @@ class KMSClient {
|
|
|
189
216
|
}
|
|
190
217
|
/**
|
|
191
218
|
* 获取密钥(解密)
|
|
219
|
+
* 支持两种调用方式:
|
|
220
|
+
* 1. 简化版: getKey(keyName) - 需要配置 defaultProjectName + masterPassword
|
|
221
|
+
* 2. 完整版: getKey(projectId, masterPassword, keyId) - 需要 setCurrentUser
|
|
192
222
|
*/
|
|
193
|
-
async getKey(
|
|
223
|
+
async getKey(arg1, arg2, arg3) {
|
|
194
224
|
await this.ensureConnected();
|
|
195
|
-
|
|
196
|
-
|
|
225
|
+
// 完整版: getKey(projectId, masterPassword, keyId)
|
|
226
|
+
if (arg2 !== undefined && arg3 !== undefined) {
|
|
227
|
+
const userId = this.getCurrentUserId();
|
|
228
|
+
return await this.keyService.getKey(arg1, userId, arg2, arg3);
|
|
229
|
+
}
|
|
230
|
+
// 简化版: getKey(keyName)
|
|
231
|
+
const { projectId, masterPassword } = this.ensureDefaultProject();
|
|
232
|
+
return await this.keyService.getKeyByName(projectId, '__sdk_auto__', masterPassword, arg1).then((kv) => kv.value);
|
|
197
233
|
}
|
|
198
234
|
/**
|
|
199
235
|
* 列出密钥
|
|
@@ -219,6 +255,28 @@ class KMSClient {
|
|
|
219
255
|
const userId = this.getCurrentUserId();
|
|
220
256
|
await this.keyService.deleteKey(projectId, userId, keyId);
|
|
221
257
|
}
|
|
258
|
+
// ============ 简化 API(一行代码使用) ============
|
|
259
|
+
/**
|
|
260
|
+
* 设置密钥(极简 API)
|
|
261
|
+
* 用法: await kms.setKey('api-key', 'secret123')
|
|
262
|
+
* 需要 KMSClient 配置 defaultProjectName + masterPassword
|
|
263
|
+
*/
|
|
264
|
+
async setKey(keyName, value) {
|
|
265
|
+
await this.ensureConnected();
|
|
266
|
+
const { projectId, masterPassword } = this.ensureDefaultProject();
|
|
267
|
+
await this.keyService.setKey(projectId, '__sdk_auto__', masterPassword, keyName, value);
|
|
268
|
+
}
|
|
269
|
+
/**
|
|
270
|
+
* 通过项目名称获取密钥(简化 API)
|
|
271
|
+
* 需要传入项目名称和主密码
|
|
272
|
+
*/
|
|
273
|
+
async getKeyByName(projectName, keyName, masterPassword) {
|
|
274
|
+
await this.ensureConnected();
|
|
275
|
+
const { project } = await this.projectService.getOrCreateProject(projectName, masterPassword);
|
|
276
|
+
const userId = '__sdk_auto__';
|
|
277
|
+
this.currentUserId = userId;
|
|
278
|
+
return await this.keyService.getKeyByName(project.projectId, userId, masterPassword, keyName);
|
|
279
|
+
}
|
|
222
280
|
// ============ 用户管理 ============
|
|
223
281
|
/**
|
|
224
282
|
* 创建用户
|
package/dist/client.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,qCAA0C;
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -55,6 +55,10 @@ export declare class AuditService {
|
|
|
55
55
|
* 记录密钥读取
|
|
56
56
|
*/
|
|
57
57
|
logKeyRead(projectId: string, userId: string, keyId: string, keyName: string, success: boolean): Promise<void>;
|
|
58
|
+
/**
|
|
59
|
+
* 记录密钥更新
|
|
60
|
+
*/
|
|
61
|
+
logKeyUpdated(projectId: string, userId: string, keyId: string, keyName: string, success: boolean): Promise<void>;
|
|
58
62
|
/**
|
|
59
63
|
* 记录密钥删除
|
|
60
64
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"audit.service.d.ts","sourceRoot":"","sources":["../../src/services/audit.service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAG3E,qBAAa,YAAY;IACX,OAAO,CAAC,SAAS;gBAAT,SAAS,EAAE,eAAe;IAE9C;;OAEG;IACG,GAAG,CAAC,IAAI,EAAE;QACd,SAAS,EAAE,MAAM,CAAC;QAClB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,EAAE,WAAW,CAAC;QACpB,YAAY,EAAE,YAAY,CAAC;QAC3B,UAAU,EAAE,MAAM,CAAC;QACnB,OAAO,EAAE;YACP,OAAO,CAAC,EAAE,MAAM,CAAC;YACjB,OAAO,CAAC,EAAE,MAAM,CAAC;YACjB,SAAS,CAAC,EAAE,MAAM,CAAC;YACnB,SAAS,CAAC,EAAE,MAAM,CAAC;YACnB,OAAO,EAAE,OAAO,CAAC;YACjB,YAAY,CAAC,EAAE,MAAM,CAAC;YACtB,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;SACpB,CAAC;KACH,GAAG,OAAO,CAAC,IAAI,CAAC;IAKjB;;OAEG;IACG,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC;QAChE,IAAI,EAAE,QAAQ,EAAE,CAAC;QACjB,KAAK,EAAE,MAAM,CAAC;QACd,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IAUF;;OAEG;IACG,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,GAAE,MAAY,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAIhF;;OAEG;IACG,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC;IAI1F;;OAEG;IACG,iBAAiB,CACrB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,MAAM,EACnB,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;IAchB;;OAEG;IACG,aAAa,CACjB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;IAehB;;OAEG;IACG,UAAU,CACd,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;IAchB;;OAEG;IACG,aAAa,CACjB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;CAajB"}
|
|
1
|
+
{"version":3,"file":"audit.service.d.ts","sourceRoot":"","sources":["../../src/services/audit.service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAG3E,qBAAa,YAAY;IACX,OAAO,CAAC,SAAS;gBAAT,SAAS,EAAE,eAAe;IAE9C;;OAEG;IACG,GAAG,CAAC,IAAI,EAAE;QACd,SAAS,EAAE,MAAM,CAAC;QAClB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,EAAE,WAAW,CAAC;QACpB,YAAY,EAAE,YAAY,CAAC;QAC3B,UAAU,EAAE,MAAM,CAAC;QACnB,OAAO,EAAE;YACP,OAAO,CAAC,EAAE,MAAM,CAAC;YACjB,OAAO,CAAC,EAAE,MAAM,CAAC;YACjB,SAAS,CAAC,EAAE,MAAM,CAAC;YACnB,SAAS,CAAC,EAAE,MAAM,CAAC;YACnB,OAAO,EAAE,OAAO,CAAC;YACjB,YAAY,CAAC,EAAE,MAAM,CAAC;YACtB,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;SACpB,CAAC;KACH,GAAG,OAAO,CAAC,IAAI,CAAC;IAKjB;;OAEG;IACG,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC;QAChE,IAAI,EAAE,QAAQ,EAAE,CAAC;QACjB,KAAK,EAAE,MAAM,CAAC;QACd,IAAI,EAAE,MAAM,CAAC;QACb,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IAUF;;OAEG;IACG,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,GAAE,MAAY,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAIhF;;OAEG;IACG,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC;IAI1F;;OAEG;IACG,iBAAiB,CACrB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,MAAM,EACnB,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;IAchB;;OAEG;IACG,aAAa,CACjB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;IAehB;;OAEG;IACG,UAAU,CACd,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;IAchB;;OAEG;IACG,aAAa,CACjB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;IAchB;;OAEG;IACG,aAAa,CACjB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;CAajB"}
|
|
@@ -92,6 +92,22 @@ class AuditService {
|
|
|
92
92
|
},
|
|
93
93
|
});
|
|
94
94
|
}
|
|
95
|
+
/**
|
|
96
|
+
* 记录密钥更新
|
|
97
|
+
*/
|
|
98
|
+
async logKeyUpdated(projectId, userId, keyId, keyName, success) {
|
|
99
|
+
await this.log({
|
|
100
|
+
projectId,
|
|
101
|
+
userId,
|
|
102
|
+
action: types_1.AuditAction.UPDATE_KEY,
|
|
103
|
+
resourceType: types_1.ResourceType.KEY,
|
|
104
|
+
resourceId: keyId,
|
|
105
|
+
details: {
|
|
106
|
+
keyName,
|
|
107
|
+
success,
|
|
108
|
+
},
|
|
109
|
+
});
|
|
110
|
+
}
|
|
95
111
|
/**
|
|
96
112
|
* 记录密钥删除
|
|
97
113
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"audit.service.js","sourceRoot":"","sources":["../../src/services/audit.service.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"audit.service.js","sourceRoot":"","sources":["../../src/services/audit.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,7 +6,7 @@ import { KeyRepository } from '../repositories/key.repository';
|
|
|
6
6
|
import { AuditService } from './audit.service';
|
|
7
7
|
import { PermissionService } from './permission.service';
|
|
8
8
|
import { CryptoService } from '../core/crypto.service';
|
|
9
|
-
import { Key, KeyValue, CreateKeyData, UpdateKeyData, KeyFilters } from '../types';
|
|
9
|
+
import { Key, KeyValue, CreateKeyData, UpdateKeyData, KeyFilters, KeyType } from '../types';
|
|
10
10
|
export declare class KeyService {
|
|
11
11
|
private keyRepo;
|
|
12
12
|
private auditService;
|
|
@@ -44,6 +44,19 @@ export declare class KeyService {
|
|
|
44
44
|
* 删除密钥
|
|
45
45
|
*/
|
|
46
46
|
deleteKey(projectId: string, userId: string, keyId: string): Promise<void>;
|
|
47
|
+
/**
|
|
48
|
+
* 设置密钥(简化 API:自动创建或更新)
|
|
49
|
+
* 如果密钥已存在则更新,不存在则创建
|
|
50
|
+
*/
|
|
51
|
+
setKey(projectId: string, userId: string, masterPassword: string, keyName: string, value: string, options?: {
|
|
52
|
+
keyType?: KeyType;
|
|
53
|
+
tags?: string[];
|
|
54
|
+
description?: string;
|
|
55
|
+
}): Promise<KeyValue>;
|
|
56
|
+
/**
|
|
57
|
+
* 通过密钥名称获取密钥(简化 API)
|
|
58
|
+
*/
|
|
59
|
+
getKeyByName(projectId: string, userId: string, masterPassword: string, keyName: string): Promise<KeyValue>;
|
|
47
60
|
/**
|
|
48
61
|
* 获取项目主密钥(需要从项目服务获取)
|
|
49
62
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"key.service.d.ts","sourceRoot":"","sources":["../../src/services/key.service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EACL,GAAG,EACH,QAAQ,EACR,aAAa,EACb,aAAa,EACb,UAAU,
|
|
1
|
+
{"version":3,"file":"key.service.d.ts","sourceRoot":"","sources":["../../src/services/key.service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EACL,GAAG,EACH,QAAQ,EACR,aAAa,EACb,aAAa,EACb,UAAU,EACV,OAAO,EACR,MAAM,UAAU,CAAC;AAMlB,qBAAa,UAAU;IAInB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,aAAa;IANvB,OAAO,CAAC,cAAc,CAAC,CAAM;gBAGnB,OAAO,EAAE,aAAa,EACtB,YAAY,EAAE,YAAY,EAC1B,iBAAiB,EAAE,iBAAiB,EACpC,aAAa,EAAE,aAAa;IAGtC;;OAEG;IACH,iBAAiB,CAAC,cAAc,EAAE,GAAG,GAAG,IAAI;IAI5C;;OAEG;IACG,SAAS,CACb,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,MAAM,EACtB,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,GAAG,CAAC;IA0Cf;;OAEG;IACG,MAAM,CACV,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,MAAM,EACtB,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,QAAQ,CAAC;IAuCpB;;OAEG;IACG,QAAQ,CACZ,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,UAAU,EACpB,OAAO,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GAC1C,OAAO,CAAC;QAAE,IAAI,EAAE,GAAG,EAAE,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IAO1C;;OAEG;IACG,SAAS,CACb,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,MAAM,EACtB,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,GAAG,CAAC;IA2Bf;;OAEG;IACG,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBhF;;;OAGG;IACG,MAAM,CACV,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,MAAM,EACtB,OAAO,EAAE,MAAM,EACf,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE;QAAE,OAAO,CAAC,EAAE,OAAO,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAA;KAAE,GACrE,OAAO,CAAC,QAAQ,CAAC;IAuEpB;;OAEG;IACG,YAAY,CAChB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,MAAM,EACtB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,QAAQ,CAAC;IAQpB;;OAEG;YACW,YAAY;CAO3B"}
|
|
@@ -5,9 +5,10 @@
|
|
|
5
5
|
*/
|
|
6
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
7
|
exports.KeyService = void 0;
|
|
8
|
-
const key_model_1 = require("../models/key.model");
|
|
9
8
|
const types_1 = require("../types");
|
|
9
|
+
const key_model_1 = require("../models/key.model");
|
|
10
10
|
const types_2 = require("../types");
|
|
11
|
+
const types_3 = require("../types");
|
|
11
12
|
const crypto_1 = require("../core/crypto");
|
|
12
13
|
class KeyService {
|
|
13
14
|
keyRepo;
|
|
@@ -32,16 +33,16 @@ class KeyService {
|
|
|
32
33
|
*/
|
|
33
34
|
async createKey(projectId, userId, masterPassword, keyData) {
|
|
34
35
|
// 验证权限
|
|
35
|
-
await this.permissionService.requirePermission(projectId, userId,
|
|
36
|
+
await this.permissionService.requirePermission(projectId, userId, types_3.Permission.KEY_CREATE);
|
|
36
37
|
// 验证密钥数据
|
|
37
38
|
const validation = (0, key_model_1.validateKey)(keyData);
|
|
38
39
|
if (!validation.valid) {
|
|
39
|
-
throw new
|
|
40
|
+
throw new types_2.ValidationError(validation.errors.join(', '));
|
|
40
41
|
}
|
|
41
42
|
// 检查密钥名称是否已存在
|
|
42
43
|
const existingKey = await this.keyRepo.findByProjectAndName(projectId, keyData.keyName);
|
|
43
44
|
if (existingKey) {
|
|
44
|
-
throw new
|
|
45
|
+
throw new types_2.ValidationError('Key with this name already exists');
|
|
45
46
|
}
|
|
46
47
|
// 加密密钥值
|
|
47
48
|
const masterKeyHex = await this.getMasterKey(projectId, masterPassword);
|
|
@@ -59,19 +60,19 @@ class KeyService {
|
|
|
59
60
|
*/
|
|
60
61
|
async getKey(projectId, userId, masterPassword, keyId) {
|
|
61
62
|
// 验证权限
|
|
62
|
-
await this.permissionService.requirePermission(projectId, userId,
|
|
63
|
+
await this.permissionService.requirePermission(projectId, userId, types_3.Permission.KEY_READ);
|
|
63
64
|
// 获取密钥
|
|
64
65
|
const key = await this.keyRepo.findByKeyId(keyId);
|
|
65
66
|
if (!key) {
|
|
66
|
-
throw new
|
|
67
|
+
throw new types_2.KeyNotFoundError(keyId);
|
|
67
68
|
}
|
|
68
69
|
// 验证项目
|
|
69
70
|
if (key.projectId !== projectId) {
|
|
70
|
-
throw new
|
|
71
|
+
throw new types_2.ValidationError('Key does not belong to this project');
|
|
71
72
|
}
|
|
72
73
|
// 检查密钥是否可访问
|
|
73
74
|
if (!(0, key_model_1.isKeyAccessible)(key)) {
|
|
74
|
-
throw new
|
|
75
|
+
throw new types_2.ValidationError('Key is not accessible');
|
|
75
76
|
}
|
|
76
77
|
// 解密密钥值
|
|
77
78
|
const masterKeyHex = await this.getMasterKey(projectId, masterPassword);
|
|
@@ -88,7 +89,7 @@ class KeyService {
|
|
|
88
89
|
*/
|
|
89
90
|
async listKeys(projectId, userId, filters, options) {
|
|
90
91
|
// 验证权限
|
|
91
|
-
await this.permissionService.requirePermission(projectId, userId,
|
|
92
|
+
await this.permissionService.requirePermission(projectId, userId, types_3.Permission.KEY_LIST);
|
|
92
93
|
return await this.keyRepo.findByProjectId(projectId, filters, options);
|
|
93
94
|
}
|
|
94
95
|
/**
|
|
@@ -96,11 +97,11 @@ class KeyService {
|
|
|
96
97
|
*/
|
|
97
98
|
async updateKey(projectId, userId, masterPassword, keyId, updates) {
|
|
98
99
|
// 验证权限
|
|
99
|
-
await this.permissionService.requirePermission(projectId, userId,
|
|
100
|
+
await this.permissionService.requirePermission(projectId, userId, types_3.Permission.KEY_UPDATE);
|
|
100
101
|
const key = await this.keyRepo.getByKeyId(keyId);
|
|
101
102
|
// 验证项目
|
|
102
103
|
if (key.projectId !== projectId) {
|
|
103
|
-
throw new
|
|
104
|
+
throw new types_2.ValidationError('Key does not belong to this project');
|
|
104
105
|
}
|
|
105
106
|
let newEncryptedData;
|
|
106
107
|
// 如果更新密钥值,需要重新加密
|
|
@@ -118,16 +119,74 @@ class KeyService {
|
|
|
118
119
|
*/
|
|
119
120
|
async deleteKey(projectId, userId, keyId) {
|
|
120
121
|
// 验证权限
|
|
121
|
-
await this.permissionService.requirePermission(projectId, userId,
|
|
122
|
+
await this.permissionService.requirePermission(projectId, userId, types_3.Permission.KEY_DELETE);
|
|
122
123
|
const key = await this.keyRepo.getByKeyId(keyId);
|
|
123
124
|
// 验证项目
|
|
124
125
|
if (key.projectId !== projectId) {
|
|
125
|
-
throw new
|
|
126
|
+
throw new types_2.ValidationError('Key does not belong to this project');
|
|
126
127
|
}
|
|
127
128
|
await this.keyRepo.softDeleteKey(keyId);
|
|
128
129
|
// 记录审计日志
|
|
129
130
|
await this.auditService.logKeyDeleted(projectId, userId, keyId, key.keyName, true);
|
|
130
131
|
}
|
|
132
|
+
/**
|
|
133
|
+
* 设置密钥(简化 API:自动创建或更新)
|
|
134
|
+
* 如果密钥已存在则更新,不存在则创建
|
|
135
|
+
*/
|
|
136
|
+
async setKey(projectId, userId, masterPassword, keyName, value, options) {
|
|
137
|
+
// 验证权限
|
|
138
|
+
await this.permissionService.requirePermission(projectId, userId, types_3.Permission.KEY_CREATE);
|
|
139
|
+
// 检查密钥是否已存在
|
|
140
|
+
const existingKey = await this.keyRepo.findByProjectAndName(projectId, keyName);
|
|
141
|
+
if (existingKey) {
|
|
142
|
+
// 验证更新权限
|
|
143
|
+
await this.permissionService.requirePermission(projectId, userId, types_3.Permission.KEY_UPDATE);
|
|
144
|
+
let newEncryptedData;
|
|
145
|
+
const masterKeyHex = await this.getMasterKey(projectId, masterPassword);
|
|
146
|
+
const masterKey = (0, crypto_1.hexToBuffer)(masterKeyHex);
|
|
147
|
+
newEncryptedData = await this.cryptoService.encryptKey(value, masterKey);
|
|
148
|
+
const updatedKey = (0, key_model_1.updateKey)(existingKey, {
|
|
149
|
+
value,
|
|
150
|
+
tags: options?.tags,
|
|
151
|
+
description: options?.description,
|
|
152
|
+
}, newEncryptedData);
|
|
153
|
+
await this.keyRepo.updateKey(existingKey.keyId, updatedKey);
|
|
154
|
+
// 记录审计日志
|
|
155
|
+
await this.auditService.logKeyUpdated(projectId, userId, existingKey.keyId, keyName, true);
|
|
156
|
+
// 返回解密后的值
|
|
157
|
+
return (0, key_model_1.toKeyValue)(updatedKey, value);
|
|
158
|
+
}
|
|
159
|
+
// 创建新密钥
|
|
160
|
+
const keyData = {
|
|
161
|
+
keyName,
|
|
162
|
+
keyType: options?.keyType || types_1.KeyType.CUSTOM,
|
|
163
|
+
value,
|
|
164
|
+
tags: options?.tags,
|
|
165
|
+
description: options?.description,
|
|
166
|
+
};
|
|
167
|
+
const validation = (0, key_model_1.validateKey)(keyData);
|
|
168
|
+
if (!validation.valid) {
|
|
169
|
+
throw new types_2.ValidationError(validation.errors.join(', '));
|
|
170
|
+
}
|
|
171
|
+
const masterKeyHex = await this.getMasterKey(projectId, masterPassword);
|
|
172
|
+
const masterKey = (0, crypto_1.hexToBuffer)(masterKeyHex);
|
|
173
|
+
const encryptedData = await this.cryptoService.encryptKey(value, masterKey);
|
|
174
|
+
const key = (0, key_model_1.createKey)(projectId, keyData, encryptedData, userId);
|
|
175
|
+
await this.keyRepo.insertOne(key);
|
|
176
|
+
// 记录审计日志
|
|
177
|
+
await this.auditService.logKeyCreated(projectId, userId, key.keyId, key.keyName, key.keyType, true);
|
|
178
|
+
return (0, key_model_1.toKeyValue)(key, value);
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* 通过密钥名称获取密钥(简化 API)
|
|
182
|
+
*/
|
|
183
|
+
async getKeyByName(projectId, userId, masterPassword, keyName) {
|
|
184
|
+
const key = await this.keyRepo.findByProjectAndName(projectId, keyName);
|
|
185
|
+
if (!key) {
|
|
186
|
+
throw new types_2.KeyNotFoundError(keyName);
|
|
187
|
+
}
|
|
188
|
+
return await this.getKey(projectId, userId, masterPassword, key.keyId);
|
|
189
|
+
}
|
|
131
190
|
/**
|
|
132
191
|
* 获取项目主密钥(需要从项目服务获取)
|
|
133
192
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"key.service.js","sourceRoot":"","sources":["../../src/services/key.service.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;
|
|
1
|
+
{"version":3,"file":"key.service.js","sourceRoot":"","sources":["../../src/services/key.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,7 +6,7 @@ import { ProjectRepository } from '../repositories/project.repository';
|
|
|
6
6
|
import { UserRepository } from '../repositories/user.repository';
|
|
7
7
|
import { AuditService } from './audit.service';
|
|
8
8
|
import { CryptoService } from '../core/crypto.service';
|
|
9
|
-
import { Project, CreateProjectOptions } from '../types';
|
|
9
|
+
import { Project, CreateProjectOptions, User } from '../types';
|
|
10
10
|
export declare class ProjectService {
|
|
11
11
|
private projectRepo;
|
|
12
12
|
private userRepo;
|
|
@@ -33,5 +33,18 @@ export declare class ProjectService {
|
|
|
33
33
|
* 解锁项目主密钥(使用主密码)
|
|
34
34
|
*/
|
|
35
35
|
unlockProjectMasterKey(projectId: string, masterPassword: string): Promise<string>;
|
|
36
|
+
/**
|
|
37
|
+
* 获取或创建项目(简化 API 使用)
|
|
38
|
+
* 如果项目不存在,自动创建项目并生成默认 SDK 用户
|
|
39
|
+
*/
|
|
40
|
+
getOrCreateProject(projectName: string, masterPassword: string): Promise<{
|
|
41
|
+
project: Project;
|
|
42
|
+
isNew: boolean;
|
|
43
|
+
}>;
|
|
44
|
+
/**
|
|
45
|
+
* 确保项目存在 SDK 默认用户(用于简化 API 的权限绕过)
|
|
46
|
+
* 如果项目是通过 CLI 创建的,可能没有 __sdk_auto__ 用户,此时自动创建
|
|
47
|
+
*/
|
|
48
|
+
ensureSdkUser(projectId: string, masterPassword: string): Promise<User>;
|
|
36
49
|
}
|
|
37
50
|
//# sourceMappingURL=project.service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project.service.d.ts","sourceRoot":"","sources":["../../src/services/project.service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,oBAAoB,EAAQ,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"project.service.d.ts","sourceRoot":"","sources":["../../src/services/project.service.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,oBAAoB,EAAQ,IAAI,EAAE,MAAM,UAAU,CAAC;AAUrE,qBAAa,cAAc;IAEvB,OAAO,CAAC,WAAW;IACnB,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,aAAa;gBAHb,WAAW,EAAE,iBAAiB,EAC9B,QAAQ,EAAE,cAAc,EACxB,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,aAAa;IAGtC;;OAEG;IACG,aAAa,CAAC,OAAO,EAAE,oBAAoB,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAwDpF;;OAEG;IACG,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAUrD;;OAEG;IACG,YAAY,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;IAIxC;;OAEG;IACG,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBrE;;OAEG;IACG,sBAAsB,CAAC,SAAS,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAYxF;;;OAGG;IACG,kBAAkB,CACtB,WAAW,EAAE,MAAM,EACnB,cAAc,EAAE,MAAM,GACrB,OAAO,CAAC;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,KAAK,EAAE,OAAO,CAAA;KAAE,CAAC;IAqBhD;;;OAGG;IACG,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAsC9E"}
|
|
@@ -102,6 +102,56 @@ class ProjectService {
|
|
|
102
102
|
const masterKey = await this.cryptoService.unlockProjectMasterKey(masterPassword, project.salt, project.masterKeyHash);
|
|
103
103
|
return masterKey.toString('hex');
|
|
104
104
|
}
|
|
105
|
+
/**
|
|
106
|
+
* 获取或创建项目(简化 API 使用)
|
|
107
|
+
* 如果项目不存在,自动创建项目并生成默认 SDK 用户
|
|
108
|
+
*/
|
|
109
|
+
async getOrCreateProject(projectName, masterPassword) {
|
|
110
|
+
// 查找现有项目
|
|
111
|
+
let project = await this.projectRepo.findByProjectName(projectName);
|
|
112
|
+
if (project) {
|
|
113
|
+
// 验证主密码是否正确
|
|
114
|
+
await this.unlockProjectMasterKey(project.projectId, masterPassword);
|
|
115
|
+
// 确保存在 SDK 默认用户
|
|
116
|
+
await this.ensureSdkUser(project.projectId, masterPassword);
|
|
117
|
+
return { project, isNew: false };
|
|
118
|
+
}
|
|
119
|
+
// 创建新项目,使用 SDK 默认用户作为创建者
|
|
120
|
+
project = await this.createProject({ projectName, masterPassword }, '__sdk_auto__');
|
|
121
|
+
return { project, isNew: true };
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* 确保项目存在 SDK 默认用户(用于简化 API 的权限绕过)
|
|
125
|
+
* 如果项目是通过 CLI 创建的,可能没有 __sdk_auto__ 用户,此时自动创建
|
|
126
|
+
*/
|
|
127
|
+
async ensureSdkUser(projectId, masterPassword) {
|
|
128
|
+
// 尝试查找 SDK 默认用户
|
|
129
|
+
let user = await this.userRepo.findByProjectAndUsername(projectId, '__sdk_auto__');
|
|
130
|
+
if (user) {
|
|
131
|
+
return user;
|
|
132
|
+
}
|
|
133
|
+
// 不存在则自动创建(仅当主密码正确时)
|
|
134
|
+
// 先验证主密码
|
|
135
|
+
await this.unlockProjectMasterKey(projectId, masterPassword);
|
|
136
|
+
const sdkUser = (0, user_model_1.createUser)(projectId, {
|
|
137
|
+
username: '__sdk_auto__',
|
|
138
|
+
password: masterPassword,
|
|
139
|
+
roles: [types_1.Role.ADMIN],
|
|
140
|
+
}, await (0, bcrypt_1.hash)(masterPassword, 10));
|
|
141
|
+
await this.userRepo.insertOne(sdkUser);
|
|
142
|
+
await this.auditService.log({
|
|
143
|
+
projectId,
|
|
144
|
+
userId: '__sdk_auto__',
|
|
145
|
+
action: types_3.AuditAction.CREATE_USER,
|
|
146
|
+
resourceType: types_3.ResourceType.USER,
|
|
147
|
+
resourceId: sdkUser.userId,
|
|
148
|
+
details: {
|
|
149
|
+
success: true,
|
|
150
|
+
note: 'Auto-created SDK default user',
|
|
151
|
+
},
|
|
152
|
+
});
|
|
153
|
+
return sdkUser;
|
|
154
|
+
}
|
|
105
155
|
}
|
|
106
156
|
exports.ProjectService = ProjectService;
|
|
107
157
|
//# sourceMappingURL=project.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project.service.js","sourceRoot":"","sources":["../../src/services/project.service.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAMH,
|
|
1
|
+
{"version":3,"file":"project.service.js","sourceRoot":"","sources":["../../src/services/project.service.ts"],"names":[],"mappings":"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"}
|