@certd/plugin-lib 1.27.9

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.
@@ -0,0 +1,383 @@
1
+ // @ts-ignore
2
+ import ssh2 from "ssh2";
3
+ import path from "path";
4
+ import * as _ from "lodash-es";
5
+ import stripAnsi from "strip-ansi";
6
+ import { SocksClient } from "socks";
7
+ export class AsyncSsh2Client {
8
+ conn;
9
+ logger;
10
+ connConf;
11
+ windows = false;
12
+ encoding;
13
+ constructor(connConf, logger) {
14
+ this.connConf = connConf;
15
+ this.logger = logger;
16
+ this.windows = connConf.windows || false;
17
+ this.encoding = connConf.encoding;
18
+ }
19
+ convert(iconv, buffer) {
20
+ if (this.encoding) {
21
+ return iconv.decode(buffer, this.encoding);
22
+ }
23
+ return buffer.toString().replaceAll("\r\n", "\n");
24
+ }
25
+ async connect() {
26
+ this.logger.info(`开始连接,${this.connConf.host}:${this.connConf.port}`);
27
+ if (this.connConf.socksProxy) {
28
+ this.logger.info(`使用代理${this.connConf.socksProxy}`);
29
+ if (typeof this.connConf.port === "string") {
30
+ this.connConf.port = parseInt(this.connConf.port);
31
+ }
32
+ const proxyOption = this.parseSocksProxyFromUri(this.connConf.socksProxy);
33
+ const info = await SocksClient.createConnection({
34
+ proxy: proxyOption,
35
+ command: "connect",
36
+ destination: {
37
+ host: this.connConf.host,
38
+ port: this.connConf.port,
39
+ },
40
+ });
41
+ this.logger.info("代理连接成功");
42
+ this.connConf.sock = info.socket;
43
+ }
44
+ return new Promise((resolve, reject) => {
45
+ try {
46
+ const conn = new ssh2.Client();
47
+ conn
48
+ .on("error", (err) => {
49
+ this.logger.error("连接失败", err);
50
+ reject(err);
51
+ })
52
+ .on("ready", () => {
53
+ this.logger.info("连接成功");
54
+ this.conn = conn;
55
+ resolve(this.conn);
56
+ })
57
+ .connect(this.connConf);
58
+ }
59
+ catch (e) {
60
+ reject(e);
61
+ }
62
+ });
63
+ }
64
+ async getSftp() {
65
+ return new Promise((resolve, reject) => {
66
+ this.logger.info("获取sftp");
67
+ this.conn.sftp((err, sftp) => {
68
+ if (err) {
69
+ reject(err);
70
+ return;
71
+ }
72
+ resolve(sftp);
73
+ });
74
+ });
75
+ }
76
+ async fastPut(options) {
77
+ const { sftp, localPath, remotePath } = options;
78
+ return new Promise((resolve, reject) => {
79
+ this.logger.info(`开始上传:${localPath} => ${remotePath}`);
80
+ sftp.fastPut(localPath, remotePath, (err) => {
81
+ if (err) {
82
+ reject(err);
83
+ this.logger.error("请确认路径是否包含文件名,路径本身不能是目录,路径不能有*?之类的特殊符号,要有写入权限");
84
+ return;
85
+ }
86
+ this.logger.info(`上传文件成功:${localPath} => ${remotePath}`);
87
+ resolve({});
88
+ });
89
+ });
90
+ }
91
+ async exec(script, opts = {}) {
92
+ if (!script) {
93
+ this.logger.info("script 为空,取消执行");
94
+ return;
95
+ }
96
+ let iconv = await import("iconv-lite");
97
+ iconv = iconv.default;
98
+ // if (this.connConf.windows) {
99
+ // script += "\r\nexit\r\n";
100
+ // //保证windows下正常退出
101
+ // }
102
+ return new Promise((resolve, reject) => {
103
+ this.logger.info(`执行命令:[${this.connConf.host}][exec]: \n` + script);
104
+ this.conn.exec(script, (err, stream) => {
105
+ if (err) {
106
+ reject(err);
107
+ return;
108
+ }
109
+ let data = "";
110
+ let hasErrorLog = false;
111
+ stream
112
+ .on("close", (code, signal) => {
113
+ this.logger.info(`[${this.connConf.host}][close]:code:${code}`);
114
+ if (opts.throwOnStdErr == null && this.windows) {
115
+ opts.throwOnStdErr = true;
116
+ }
117
+ if (opts.throwOnStdErr && hasErrorLog) {
118
+ reject(new Error(data));
119
+ }
120
+ if (code === 0) {
121
+ resolve(data);
122
+ }
123
+ else {
124
+ reject(new Error(data));
125
+ }
126
+ })
127
+ .on("data", (ret) => {
128
+ const out = this.convert(iconv, ret);
129
+ data += out;
130
+ this.logger.info(`[${this.connConf.host}][info]: ` + out.trimEnd());
131
+ })
132
+ .on("error", (err) => {
133
+ reject(err);
134
+ this.logger.error(err);
135
+ })
136
+ .stderr.on("data", (ret) => {
137
+ const err = this.convert(iconv, ret);
138
+ data += err;
139
+ hasErrorLog = true;
140
+ this.logger.error(`[${this.connConf.host}][error]: ` + err.trimEnd());
141
+ });
142
+ });
143
+ });
144
+ }
145
+ async shell(script) {
146
+ return new Promise((resolve, reject) => {
147
+ this.logger.info(`执行shell脚本:[${this.connConf.host}][shell]: ` + script);
148
+ this.conn.shell((err, stream) => {
149
+ if (err) {
150
+ reject(err);
151
+ return;
152
+ }
153
+ let output = "";
154
+ function ansiHandle(data) {
155
+ data = data.replace(/\[[0-9]+;1H/g, "");
156
+ data = stripAnsi(data);
157
+ return data.replaceAll("\r\n", "\n");
158
+ }
159
+ stream
160
+ .on("close", (code) => {
161
+ this.logger.info("Stream :: close,code: " + code);
162
+ resolve(output);
163
+ })
164
+ .on("data", (ret) => {
165
+ const data = ansiHandle(ret.toString());
166
+ this.logger.info(data);
167
+ output += data;
168
+ })
169
+ .on("error", (err) => {
170
+ reject(err);
171
+ this.logger.error(err);
172
+ })
173
+ .stderr.on("data", (ret) => {
174
+ const data = ansiHandle(ret.toString());
175
+ output += data;
176
+ this.logger.error(`[${this.connConf.host}][error]: ` + data);
177
+ });
178
+ //保证windows下正常退出
179
+ const exit = "\r\nexit\r\n";
180
+ stream.end(script + exit);
181
+ });
182
+ });
183
+ }
184
+ end() {
185
+ if (this.conn) {
186
+ this.conn.end();
187
+ this.conn.destroy();
188
+ this.conn = null;
189
+ }
190
+ }
191
+ parseSocksProxyFromUri(socksProxyUri) {
192
+ const url = new URL(socksProxyUri);
193
+ let type = 5;
194
+ if (url.protocol.startsWith("socks4")) {
195
+ type = 4;
196
+ }
197
+ const proxy = {
198
+ host: url.hostname,
199
+ port: parseInt(url.port),
200
+ type,
201
+ };
202
+ if (url.username) {
203
+ proxy.userId = url.username;
204
+ }
205
+ if (url.password) {
206
+ proxy.password = url.password;
207
+ }
208
+ return proxy;
209
+ }
210
+ }
211
+ export class SshClient {
212
+ logger;
213
+ constructor(logger) {
214
+ this.logger = logger;
215
+ }
216
+ /**
217
+ *
218
+ * @param connectConf
219
+ {
220
+ host: '192.168.100.100',
221
+ port: 22,
222
+ username: 'frylock',
223
+ password: 'nodejsrules'
224
+ }
225
+ * @param options
226
+ */
227
+ async uploadFiles(options) {
228
+ const { connectConf, transports, mkdirs } = options;
229
+ await this._call({
230
+ connectConf,
231
+ callable: async (conn) => {
232
+ const sftp = await conn.getSftp();
233
+ this.logger.info("开始上传");
234
+ for (const transport of transports) {
235
+ if (mkdirs !== false) {
236
+ const filePath = path.dirname(transport.remotePath);
237
+ let mkdirCmd = `mkdir -p ${filePath} `;
238
+ if (conn.windows) {
239
+ if (filePath.indexOf("/") > -1) {
240
+ this.logger.info("--------------------------");
241
+ this.logger.info("请注意:windows下,文件目录分隔应该写成\\而不是/");
242
+ this.logger.info("--------------------------");
243
+ }
244
+ const isCmd = await this.isCmd(conn);
245
+ if (!isCmd) {
246
+ mkdirCmd = `New-Item -ItemType Directory -Path "${filePath}" -Force`;
247
+ }
248
+ else {
249
+ mkdirCmd = `if not exist "${filePath}" mkdir "${filePath}"`;
250
+ }
251
+ }
252
+ await conn.exec(mkdirCmd);
253
+ }
254
+ await conn.fastPut({ sftp, ...transport });
255
+ }
256
+ this.logger.info("文件全部上传成功");
257
+ },
258
+ });
259
+ }
260
+ async isCmd(conn) {
261
+ const spec = await conn.exec("echo %COMSPEC% ");
262
+ if (spec.toString().trim() === "%COMSPEC%") {
263
+ return false;
264
+ }
265
+ else {
266
+ return true;
267
+ }
268
+ }
269
+ async getIsCmd(options) {
270
+ const { connectConf } = options;
271
+ return await this._call({
272
+ connectConf,
273
+ callable: async (conn) => {
274
+ return await this.isCmd(conn);
275
+ },
276
+ });
277
+ }
278
+ /**
279
+ *
280
+ * Set-ItemProperty -Path "HKLM:\SOFTWARE\OpenSSH" -Name DefaultShell -Value "C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe"
281
+ * Start-Service sshd
282
+ *
283
+ * Set-ItemProperty -Path "HKLM:\SOFTWARE\OpenSSH" -Name DefaultShell -Value "C:\Windows\System32\cmd.exe"
284
+ * @param options
285
+ */
286
+ async exec(options) {
287
+ let { script } = options;
288
+ const { connectConf } = options;
289
+ // this.logger.info('命令:', script);
290
+ return await this._call({
291
+ connectConf,
292
+ callable: async (conn) => {
293
+ let isWinCmd = false;
294
+ const isLinux = !connectConf.windows;
295
+ const envScripts = [];
296
+ if (connectConf.windows) {
297
+ isWinCmd = await this.isCmd(conn);
298
+ }
299
+ if (options.env) {
300
+ for (const key in options.env) {
301
+ if (isLinux) {
302
+ envScripts.push(`export ${key}=${options.env[key]}`);
303
+ }
304
+ else if (isWinCmd) {
305
+ //win cmd
306
+ envScripts.push(`set ${key}=${options.env[key]}`);
307
+ }
308
+ else {
309
+ //powershell
310
+ envScripts.push(`$env:${key}="${options.env[key]}"`);
311
+ }
312
+ }
313
+ }
314
+ if (isWinCmd) {
315
+ //组合成&&的形式
316
+ if (typeof script === "string") {
317
+ script = script.split("\n");
318
+ }
319
+ script = envScripts.concat(script);
320
+ script = script;
321
+ script = script.join(" && ");
322
+ }
323
+ else {
324
+ const newLine = isLinux ? "\n" : "\r\n";
325
+ if (_.isArray(script)) {
326
+ script = script;
327
+ script = script.join(newLine);
328
+ }
329
+ if (envScripts.length > 0) {
330
+ script = envScripts.join(newLine) + newLine + script;
331
+ }
332
+ }
333
+ return await conn.exec(script);
334
+ },
335
+ });
336
+ }
337
+ async shell(options) {
338
+ let { script } = options;
339
+ const { connectConf } = options;
340
+ if (_.isArray(script)) {
341
+ script = script;
342
+ if (connectConf.windows) {
343
+ script = script.join("\r\n");
344
+ }
345
+ else {
346
+ script = script.join("\n");
347
+ }
348
+ }
349
+ else {
350
+ if (connectConf.windows) {
351
+ //@ts-ignore
352
+ script = script.replaceAll("\n", "\r\n");
353
+ }
354
+ }
355
+ return await this._call({
356
+ connectConf,
357
+ callable: async (conn) => {
358
+ return await conn.shell(script);
359
+ },
360
+ });
361
+ }
362
+ async _call(options) {
363
+ const { connectConf, callable } = options;
364
+ const conn = new AsyncSsh2Client(connectConf, this.logger);
365
+ try {
366
+ await conn.connect();
367
+ }
368
+ catch (e) {
369
+ if (e.message?.indexOf("All configured authentication methods failed") > -1) {
370
+ this.logger.error(e);
371
+ throw new Error("登录失败,请检查用户名/密码/密钥是否正确");
372
+ }
373
+ throw e;
374
+ }
375
+ try {
376
+ return await callable(conn);
377
+ }
378
+ finally {
379
+ conn.end();
380
+ }
381
+ }
382
+ }
383
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3NoLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NzaC9zc2gudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsYUFBYTtBQUNiLE9BQU8sSUFBb0MsTUFBTSxNQUFNLENBQUM7QUFDeEQsT0FBTyxJQUFJLE1BQU0sTUFBTSxDQUFDO0FBQ3hCLE9BQU8sS0FBSyxDQUFDLE1BQU0sV0FBVyxDQUFDO0FBRy9CLE9BQU8sU0FBUyxNQUFNLFlBQVksQ0FBQztBQUNuQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sT0FBTyxDQUFDO0FBR3BDLE1BQU0sT0FBTyxlQUFlO0lBQzFCLElBQUksQ0FBYztJQUNsQixNQUFNLENBQVU7SUFDaEIsUUFBUSxDQUFpQztJQUN6QyxPQUFPLEdBQUcsS0FBSyxDQUFDO0lBQ2hCLFFBQVEsQ0FBUztJQUNqQixZQUFZLFFBQW1CLEVBQUUsTUFBZTtRQUM5QyxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztRQUN6QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsT0FBTyxHQUFHLFFBQVEsQ0FBQyxPQUFPLElBQUksS0FBSyxDQUFDO1FBQ3pDLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQztJQUNwQyxDQUFDO0lBRUQsT0FBTyxDQUFDLEtBQVUsRUFBRSxNQUFjO1FBQ2hDLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ2xCLE9BQU8sS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQzdDLENBQUM7UUFDRCxPQUFPLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxVQUFVLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFRCxLQUFLLENBQUMsT0FBTztRQUNYLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFD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
package/package.json ADDED
@@ -0,0 +1,48 @@
1
+ {
2
+ "name": "@certd/plugin-lib",
3
+ "private": false,
4
+ "version": "1.27.9",
5
+ "type": "module",
6
+ "main": "./dist/index.js",
7
+ "types": "./dist/index.d.ts",
8
+ "scripts": {
9
+ "dev": "vite",
10
+ "before-build": "rimraf dist && rimraf tsconfig.tsbuildinfo && rimraf .rollup.cache",
11
+ "build": "npm run before-build &&tsc --skipLibCheck",
12
+ "dev-build": "npm run build",
13
+ "build3": "rollup -c",
14
+ "build2": "vue-tsc --noEmit && vite build",
15
+ "preview": "vite preview"
16
+ },
17
+ "dependencies": {
18
+ "@certd/basic": "^1.27.9",
19
+ "@certd/plugin-cert": "^1.27.9",
20
+ "@certd/pipeline": "^1.27.9",
21
+ "dayjs": "^1.11.7",
22
+ "lodash-es": "^4.17.21",
23
+ "rimraf": "^5.0.5",
24
+ "@alicloud/pop-core": "^1.7.10",
25
+ "ssh2": "^1.15.0",
26
+ "socks": "^2.8.3",
27
+ "socks-proxy-agent": "^8.0.4",
28
+ "strip-ansi": "^7.1.0",
29
+ "iconv-lite": "^0.6.3",
30
+ "@kubernetes/client-node": "0.21.0"
31
+ },
32
+ "devDependencies": {
33
+ "@types/chai": "^4.3.3",
34
+ "@types/mocha": "^10.0.0",
35
+ "@types/psl": "^1.1.3",
36
+ "@typescript-eslint/eslint-plugin": "^5.38.1",
37
+ "@typescript-eslint/parser": "^5.38.1",
38
+ "chai": "^4.3.6",
39
+ "eslint": "^8.24.0",
40
+ "eslint-config-prettier": "^8.5.0",
41
+ "eslint-plugin-prettier": "^4.2.1",
42
+ "mocha": "^10.1.0",
43
+ "prettier": "^2.8.8",
44
+ "tslib": "^2.8.1",
45
+ "typescript": "^5.4.2"
46
+ },
47
+ "gitHead": "cf1936309241d3cf05c2fba767f530bbb3b62b15"
48
+ }
package/tsconfig.json ADDED
@@ -0,0 +1,41 @@
1
+ {
2
+ "compileOnSave": true,
3
+ "compilerOptions": {
4
+ "target": "ESNext",
5
+ "module": "ESNext",
6
+ "moduleResolution": "node",
7
+ "esModuleInterop": true,
8
+ "experimentalDecorators": true,
9
+ "emitDecoratorMetadata": true,
10
+ "inlineSourceMap":true,
11
+ "noImplicitThis": true,
12
+ "noUnusedLocals": true,
13
+ "stripInternal": true,
14
+ "skipLibCheck": true,
15
+ "pretty": true,
16
+ "declaration": true,
17
+ "forceConsistentCasingInFileNames": true,
18
+ "typeRoots": [ "./typings", "./node_modules/@types"],
19
+ "outDir": "dist",
20
+ "rootDir": "src",
21
+ "composite": false,
22
+ "useDefineForClassFields": true,
23
+ "strict": false,
24
+ // "sourceMap": true,
25
+ "resolveJsonModule": true,
26
+ "isolatedModules": false,
27
+ "lib": ["ESNext", "DOM"],
28
+ },
29
+ "include": [
30
+ "src/**/*.ts",
31
+ "src/**/*.d.ts",
32
+ "src/**/*.json"
33
+ ],
34
+ "exclude": [
35
+ "*.js",
36
+ "*.ts",
37
+ "dist",
38
+ "node_modules",
39
+ "test"
40
+ ],
41
+ }