@mongodb-js/signing-utils 0.3.8 → 0.4.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.
- package/dist/index.js +1 -2
- package/dist/index.js.map +1 -1
- package/dist/signing-clients/index.d.ts +0 -1
- package/dist/signing-clients/index.d.ts.map +1 -1
- package/dist/signing-clients/index.js +19 -9
- package/dist/signing-clients/index.js.map +1 -1
- package/dist/utils.d.ts +0 -1
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +2 -2
- package/dist/utils.js.map +1 -1
- package/package.json +12 -12
- package/src/index.ts +2 -2
- package/src/signing-clients/index.ts +1 -1
- package/src/signing-clients/local-signing-client.spec.ts +4 -4
- package/src/signing-clients/local-signing-client.ts +3 -3
- package/src/signing-clients/remote-signing-client.spec.ts +1 -1
- package/src/signing-clients/remote-signing-client.ts +2 -2
- package/src/ssh-client.spec.ts +1 -1
- package/src/ssh-client.ts +4 -4
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.sign =
|
|
3
|
+
exports.sign = sign;
|
|
4
4
|
const signing_clients_1 = require("./signing-clients");
|
|
5
5
|
const utils_1 = require("./utils");
|
|
6
6
|
async function sign(file, options) {
|
|
@@ -14,5 +14,4 @@ async function sign(file, options) {
|
|
|
14
14
|
throw err;
|
|
15
15
|
}
|
|
16
16
|
}
|
|
17
|
-
exports.sign = sign;
|
|
18
17
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;AAWA,oBAeC;AAxBD,uDAAqD;AACrD,mCAAgC;AAQzB,KAAK,UAAU,IAAI,CACxB,IAAY,EACZ,OAAsB;IAEtB,IAAA,aAAK,EACH,iBAAiB,IAAI,gBAAgB,OAAO,CAAC,MAAM,eAAe,EAClE,OAAO,CACR,CAAC;IACF,IAAI,CAAC;QACH,MAAM,aAAa,GAAG,MAAM,IAAA,kCAAgB,EAAC,OAAO,CAAC,CAAC;QACtD,MAAM,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,IAAA,aAAK,EAAC,uBAAuB,IAAI,EAAE,EAAE,GAAG,CAAC,CAAC;QAC1C,MAAM,GAAG,CAAC;IACZ,CAAC;AACH,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/signing-clients/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/signing-clients/index.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,OAAO,GAAG,SAAS,CAAC;AAExD,MAAM,MAAM,oBAAoB,GAAG;IACjC,gBAAgB,EAAE,MAAM,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,aAAa,CAAC;CAC9B,CAAC;AAEF,KAAK,oBAAoB,GAAG;IAO1B,aAAa,EAAE,aAAa,CAAC;CAC9B,CAAC;AAGF,MAAM,MAAM,oBAAoB,GAAG,oBAAoB,GAAG;IAExD,IAAI,CAAC,EAAE,MAAM,CAAC;IAEd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,IAAI,CAAC,EAAE,MAAM,CAAC;IAEd,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAK7B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,MAAM,EAAE,QAAQ,CAAC;CAClB,CAAC;AAGF,MAAM,MAAM,mBAAmB,GAAG,oBAAoB,GAAG;IACvD,MAAM,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,oBAAoB,GAAG,mBAAmB,CAAC;AAEvE,MAAM,WAAW,aAAa;IAC5B,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACnC;AAED,wBAAsB,gBAAgB,CACpC,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,aAAa,CAAC,CA2BxB"}
|
|
@@ -15,15 +15,26 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
15
15
|
}) : function(o, v) {
|
|
16
16
|
o["default"] = v;
|
|
17
17
|
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
};
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
25
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
-
exports.
|
|
36
|
+
exports.RemoteSigningClient = exports.LocalSigningClient = void 0;
|
|
37
|
+
exports.getSigningClient = getSigningClient;
|
|
27
38
|
const path = __importStar(require("path"));
|
|
28
39
|
const ssh_client_1 = require("../ssh-client");
|
|
29
40
|
const local_signing_client_1 = require("./local-signing-client");
|
|
@@ -55,5 +66,4 @@ async function getSigningClient(options) {
|
|
|
55
66
|
}
|
|
56
67
|
throw new Error(`Unknown client type: ${options.client}`);
|
|
57
68
|
}
|
|
58
|
-
exports.getSigningClient = getSigningClient;
|
|
59
69
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/signing-clients/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/signing-clients/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2DA,4CA6BC;AAtFD,2CAA6B;AAC7B,8CAA0C;AAC1C,iEAA4D;AAC5D,mEAA8D;AAE9D,+DAA4D;AAAnD,0HAAA,kBAAkB,OAAA;AAC3B,iEAA8D;AAArD,4HAAA,mBAAmB,OAAA;AAmDrB,KAAK,UAAU,gBAAgB,CACpC,OAAsB;IAEtB,KAAK,UAAU,YAAY,CAAC,UAAyB;QACnD,MAAM,SAAS,GAAG,IAAI,sBAAS,CAAC,UAAU,CAAC,CAAC;QAC5C,MAAM,SAAS,CAAC,OAAO,EAAE,CAAC;QAC1B,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,eAAe,CAAC,CAAC;IAE5E,IAAI,OAAO,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;QAChC,MAAM,SAAS,GAAG,MAAM,YAAY,CAAC,OAAO,CAAC,CAAC;QAE9C,OAAO,IAAI,2CAAmB,CAAC,SAAS,EAAE;YACxC,gBAAgB,EAAE,OAAO,CAAC,gBAAgB,IAAI,uBAAuB;YACrE,aAAa;YACb,aAAa,EAAE,OAAO,CAAC,aAAa;SACrC,CAAC,CAAC;IACL,CAAC;IACD,IAAI,OAAO,CAAC,MAAM,KAAK,OAAO,EAAE,CAAC;QAC/B,OAAO,IAAI,yCAAkB,CAAC;YAC5B,aAAa;YACb,aAAa,EAAE,OAAO,CAAC,aAAa;SACrC,CAAC,CAAC;IACL,CAAC;IAGD,MAAM,IAAI,KAAK,CAAC,wBAAwB,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;AAC5D,CAAC"}
|
package/dist/utils.d.ts
CHANGED
package/dist/utils.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,KAAK,0BAA2B,CAAC;AAE9C,wBAAgB,MAAM;;;;;EAgBrB"}
|
package/dist/utils.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.debug = void 0;
|
|
4
|
+
exports.getEnv = getEnv;
|
|
4
5
|
const debug_1 = require("debug");
|
|
5
6
|
exports.debug = (0, debug_1.debug)('signing-utils');
|
|
6
7
|
function getEnv() {
|
|
@@ -15,5 +16,4 @@ function getEnv() {
|
|
|
15
16
|
artifactory_password,
|
|
16
17
|
};
|
|
17
18
|
}
|
|
18
|
-
exports.getEnv = getEnv;
|
|
19
19
|
//# sourceMappingURL=utils.js.map
|
package/dist/utils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../src/utils.ts"],"names":[],"mappings":";;;AAIA,wBAgBC;AApBD,iCAAyC;AAE5B,QAAA,KAAK,GAAG,IAAA,aAAO,EAAC,eAAe,CAAC,CAAC;AAE9C,SAAgB,MAAM;IACpB,MAAM,iBAAiB,GACrB,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,IAAI,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;IACvE,MAAM,iBAAiB,GACrB,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,IAAI,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;IACvE,MAAM,oBAAoB,GACxB,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,IAAI,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;IAC7E,MAAM,oBAAoB,GACxB,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,IAAI,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;IAE7E,OAAO;QACL,iBAAiB;QACjB,iBAAiB;QACjB,oBAAoB;QACpB,oBAAoB;KACrB,CAAC;AACJ,CAAC"}
|
package/package.json
CHANGED
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
"email": "compass@mongodb.com"
|
|
14
14
|
},
|
|
15
15
|
"homepage": "https://github.com/mongodb-js/devtools-shared",
|
|
16
|
-
"version": "0.
|
|
16
|
+
"version": "0.4.0",
|
|
17
17
|
"repository": {
|
|
18
18
|
"type": "git",
|
|
19
19
|
"url": "https://github.com/mongodb-js/devtools-shared.git"
|
|
@@ -47,28 +47,28 @@
|
|
|
47
47
|
"reformat": "npm run prettier -- --write ."
|
|
48
48
|
},
|
|
49
49
|
"devDependencies": {
|
|
50
|
-
"@mongodb-js/eslint-config-devtools": "0.9.
|
|
51
|
-
"@mongodb-js/mocha-config-devtools": "^1.0.
|
|
52
|
-
"@mongodb-js/prettier-config-devtools": "^1.0.
|
|
53
|
-
"@mongodb-js/tsconfig-devtools": "^1.0.
|
|
50
|
+
"@mongodb-js/eslint-config-devtools": "0.9.11",
|
|
51
|
+
"@mongodb-js/mocha-config-devtools": "^1.0.5",
|
|
52
|
+
"@mongodb-js/prettier-config-devtools": "^1.0.2",
|
|
53
|
+
"@mongodb-js/tsconfig-devtools": "^1.0.3",
|
|
54
54
|
"@types/chai": "^4.2.21",
|
|
55
55
|
"@types/mocha": "^9.1.1",
|
|
56
|
-
"@types/node": "^
|
|
56
|
+
"@types/node": "^22.15.30",
|
|
57
57
|
"@types/sinon-chai": "^3.2.5",
|
|
58
|
-
"chai": "^4.
|
|
59
|
-
"depcheck": "^1.4.
|
|
58
|
+
"chai": "^4.5.0",
|
|
59
|
+
"depcheck": "^1.4.7",
|
|
60
60
|
"eslint": "^7.25.0",
|
|
61
|
-
"gen-esm-wrapper": "^1.1.
|
|
61
|
+
"gen-esm-wrapper": "^1.1.3",
|
|
62
62
|
"mocha": "^8.4.0",
|
|
63
63
|
"nyc": "^15.1.0",
|
|
64
|
-
"prettier": "^
|
|
64
|
+
"prettier": "^3.5.3",
|
|
65
65
|
"sinon": "^9.2.3",
|
|
66
66
|
"typescript": "^5.0.4"
|
|
67
67
|
},
|
|
68
68
|
"dependencies": {
|
|
69
69
|
"@types/ssh2": "^1.11.19",
|
|
70
|
-
"debug": "^4.
|
|
70
|
+
"debug": "^4.4.0",
|
|
71
71
|
"ssh2": "^1.15.0"
|
|
72
72
|
},
|
|
73
|
-
"gitHead": "
|
|
73
|
+
"gitHead": "005f6263e3a329d916f6936c9adcf35db47cfe9f"
|
|
74
74
|
}
|
package/src/index.ts
CHANGED
|
@@ -11,11 +11,11 @@ import { debug } from './utils';
|
|
|
11
11
|
*/
|
|
12
12
|
export async function sign(
|
|
13
13
|
file: string,
|
|
14
|
-
options: ClientOptions
|
|
14
|
+
options: ClientOptions,
|
|
15
15
|
): Promise<void> {
|
|
16
16
|
debug(
|
|
17
17
|
`Signing file: ${file} with client ${options.client} and options:`,
|
|
18
|
-
options
|
|
18
|
+
options,
|
|
19
19
|
);
|
|
20
20
|
try {
|
|
21
21
|
const signingClient = await getSigningClient(options);
|
|
@@ -58,7 +58,7 @@ export interface SigningClient {
|
|
|
58
58
|
}
|
|
59
59
|
|
|
60
60
|
export async function getSigningClient(
|
|
61
|
-
options: ClientOptions
|
|
61
|
+
options: ClientOptions,
|
|
62
62
|
): Promise<SigningClient> {
|
|
63
63
|
async function getSshClient(sshOptions: ConnectConfig) {
|
|
64
64
|
const sshClient = new SSHClient(sshOptions);
|
|
@@ -15,7 +15,7 @@ describe('LocalSigningClient', function () {
|
|
|
15
15
|
#!/bin/bash
|
|
16
16
|
echo "Signing script called with arguments: $@"
|
|
17
17
|
echo "signed content" > ${fileNameAfterGpgSigning}
|
|
18
|
-
|
|
18
|
+
`,
|
|
19
19
|
);
|
|
20
20
|
await fs.writeFile(fileToSign, 'original content');
|
|
21
21
|
});
|
|
@@ -23,8 +23,8 @@ describe('LocalSigningClient', function () {
|
|
|
23
23
|
afterEach(async function () {
|
|
24
24
|
await Promise.allSettled(
|
|
25
25
|
[signingScript, fileToSign, fileNameAfterGpgSigning].map((file) =>
|
|
26
|
-
fs.rm(file)
|
|
27
|
-
)
|
|
26
|
+
fs.rm(file),
|
|
27
|
+
),
|
|
28
28
|
);
|
|
29
29
|
});
|
|
30
30
|
|
|
@@ -51,7 +51,7 @@ describe('LocalSigningClient', function () {
|
|
|
51
51
|
echo "Signing script called with arguments: $@"
|
|
52
52
|
>&2 echo "error - something went wrong"
|
|
53
53
|
exit 1
|
|
54
|
-
|
|
54
|
+
`,
|
|
55
55
|
);
|
|
56
56
|
});
|
|
57
57
|
|
|
@@ -13,7 +13,7 @@ const localClientDebug = debug.extend('LocalSigningClient');
|
|
|
13
13
|
*/
|
|
14
14
|
export class LocalSigningClient implements SigningClient {
|
|
15
15
|
constructor(
|
|
16
|
-
private options: Omit<SigningClientOptions, 'workingDirectory'
|
|
16
|
+
private options: Omit<SigningClientOptions, 'workingDirectory'>,
|
|
17
17
|
) {}
|
|
18
18
|
|
|
19
19
|
// we want to wrap any errors in promise rejections, so even though there is no
|
|
@@ -37,7 +37,7 @@ export class LocalSigningClient implements SigningClient {
|
|
|
37
37
|
cwd: directoryOfFileToSign,
|
|
38
38
|
env,
|
|
39
39
|
encoding: 'utf-8',
|
|
40
|
-
}
|
|
40
|
+
},
|
|
41
41
|
);
|
|
42
42
|
|
|
43
43
|
localClientDebug({ stdout, stderr });
|
|
@@ -47,7 +47,7 @@ export class LocalSigningClient implements SigningClient {
|
|
|
47
47
|
JSON.stringify({
|
|
48
48
|
stdout,
|
|
49
49
|
stderr,
|
|
50
|
-
})
|
|
50
|
+
}),
|
|
51
51
|
);
|
|
52
52
|
}
|
|
53
53
|
localClientDebug(`Signed file ${file}`);
|
|
@@ -6,7 +6,7 @@ import type { SigningClient, SigningClientOptions } from '.';
|
|
|
6
6
|
export class RemoteSigningClient implements SigningClient {
|
|
7
7
|
constructor(
|
|
8
8
|
private sshClient: SSHClient,
|
|
9
|
-
private options: SigningClientOptions
|
|
9
|
+
private options: SigningClientOptions,
|
|
10
10
|
) {}
|
|
11
11
|
|
|
12
12
|
/**
|
|
@@ -28,7 +28,7 @@ export class RemoteSigningClient implements SigningClient {
|
|
|
28
28
|
|
|
29
29
|
private getRemoteFilePath(file: string) {
|
|
30
30
|
return `${this.options.workingDirectory}/temp-${Date.now()}-${path.basename(
|
|
31
|
-
file
|
|
31
|
+
file,
|
|
32
32
|
)}`;
|
|
33
33
|
}
|
|
34
34
|
|
package/src/ssh-client.spec.ts
CHANGED
|
@@ -128,7 +128,7 @@ describe('SSHClient', function () {
|
|
|
128
128
|
const error = await resultPromise.catch((e) => e);
|
|
129
129
|
expect(error).to.have.a.property(
|
|
130
130
|
'message',
|
|
131
|
-
'Command failed with code 10. Error: Some Error'
|
|
131
|
+
'Command failed with code 10. Error: Some Error',
|
|
132
132
|
);
|
|
133
133
|
expect(execStub.calledOnce).to.be.true;
|
|
134
134
|
expect(execStub.firstCall.firstArg).to.equal(COMMAND);
|
package/src/ssh-client.ts
CHANGED
|
@@ -58,7 +58,7 @@ export class SSHClient {
|
|
|
58
58
|
throw new Error('Not connected to ssh server');
|
|
59
59
|
}
|
|
60
60
|
const stream: ClientChannel = await promisify(
|
|
61
|
-
this.sshConnection.exec.bind(this.sshConnection)
|
|
61
|
+
this.sshConnection.exec.bind(this.sshConnection),
|
|
62
62
|
)(command);
|
|
63
63
|
let data = '';
|
|
64
64
|
stream.setEncoding('utf-8');
|
|
@@ -72,7 +72,7 @@ export class SSHClient {
|
|
|
72
72
|
const [code] = await once(stream, 'close');
|
|
73
73
|
if (code !== 0) {
|
|
74
74
|
throw new Error(
|
|
75
|
-
`Command failed with code ${code as number}. Error: ${data}
|
|
75
|
+
`Command failed with code ${code as number}. Error: ${data}`,
|
|
76
76
|
);
|
|
77
77
|
}
|
|
78
78
|
|
|
@@ -94,7 +94,7 @@ export class SSHClient {
|
|
|
94
94
|
const sftpConnection = await this.getSftpConnection();
|
|
95
95
|
return promisify(sftpConnection.fastPut.bind(sftpConnection))(
|
|
96
96
|
file,
|
|
97
|
-
remotePath
|
|
97
|
+
remotePath,
|
|
98
98
|
);
|
|
99
99
|
}
|
|
100
100
|
|
|
@@ -102,7 +102,7 @@ export class SSHClient {
|
|
|
102
102
|
const sftpConnection = await this.getSftpConnection();
|
|
103
103
|
return promisify(sftpConnection.fastGet.bind(sftpConnection))(
|
|
104
104
|
remotePath,
|
|
105
|
-
file
|
|
105
|
+
file,
|
|
106
106
|
);
|
|
107
107
|
}
|
|
108
108
|
|