@p0security/cli 0.10.0 → 0.10.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 -1
- package/dist/commands/__tests__/grant.test.js +1 -0
- package/dist/commands/__tests__/grant.test.js.map +1 -0
- package/dist/commands/__tests__/login.test.js +1 -0
- package/dist/commands/__tests__/login.test.js.map +1 -0
- package/dist/commands/__tests__/ls.test.js +1 -0
- package/dist/commands/__tests__/ls.test.js.map +1 -0
- package/dist/commands/__tests__/request.test.js +1 -0
- package/dist/commands/__tests__/request.test.js.map +1 -0
- package/dist/commands/__tests__/ssh.test.js +1 -0
- package/dist/commands/__tests__/ssh.test.js.map +1 -0
- package/dist/commands/allow.js +1 -0
- package/dist/commands/allow.js.map +1 -0
- package/dist/commands/aws/__tests__/__input__/saml-response.js +1 -0
- package/dist/commands/aws/__tests__/__input__/saml-response.js.map +1 -0
- package/dist/commands/aws/__tests__/__input__/sts-response.js +1 -0
- package/dist/commands/aws/__tests__/__input__/sts-response.js.map +1 -0
- package/dist/commands/aws/__tests__/role.test.js +1 -0
- package/dist/commands/aws/__tests__/role.test.js.map +1 -0
- package/dist/commands/aws/files.js +1 -0
- package/dist/commands/aws/files.js.map +1 -0
- package/dist/commands/aws/index.js +1 -0
- package/dist/commands/aws/index.js.map +1 -0
- package/dist/commands/aws/role.js +1 -0
- package/dist/commands/aws/role.js.map +1 -0
- package/dist/commands/grant.js +1 -0
- package/dist/commands/grant.js.map +1 -0
- package/dist/commands/index.js +3 -1
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/kubeconfig.d.ts +1 -1
- package/dist/commands/kubeconfig.js +1 -0
- package/dist/commands/kubeconfig.js.map +1 -0
- package/dist/commands/login.js +1 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/ls.js +2 -0
- package/dist/commands/ls.js.map +1 -0
- package/dist/commands/request.js +1 -0
- package/dist/commands/request.js.map +1 -0
- package/dist/commands/scp.js +2 -1
- package/dist/commands/scp.js.map +1 -0
- package/dist/commands/shared/index.js +1 -0
- package/dist/commands/shared/index.js.map +1 -0
- package/dist/commands/shared/request.js +1 -0
- package/dist/commands/shared/request.js.map +1 -0
- package/dist/commands/shared/ssh.d.ts +4 -4
- package/dist/commands/shared/ssh.js +1 -0
- package/dist/commands/shared/ssh.js.map +1 -0
- package/dist/commands/ssh.js +2 -1
- package/dist/commands/ssh.js.map +1 -0
- package/dist/common/__mocks__/keys.js +1 -0
- package/dist/common/__mocks__/keys.js.map +1 -0
- package/dist/common/auth/oidc.js +1 -0
- package/dist/common/auth/oidc.js.map +1 -0
- package/dist/common/auth/server.js +1 -0
- package/dist/common/auth/server.js.map +1 -0
- package/dist/common/fetch.js +1 -0
- package/dist/common/fetch.js.map +1 -0
- package/dist/common/install.d.ts +3 -3
- package/dist/common/install.js +1 -0
- package/dist/common/install.js.map +1 -0
- package/dist/common/keys.js +1 -0
- package/dist/common/keys.js.map +1 -0
- package/dist/common/mime.js +1 -0
- package/dist/common/mime.js.map +1 -0
- package/dist/common/retry.js +1 -0
- package/dist/common/retry.js.map +1 -0
- package/dist/common/subprocess.d.ts +4 -2
- package/dist/common/subprocess.js +10 -3
- package/dist/common/subprocess.js.map +1 -0
- package/dist/common/xml.js +1 -0
- package/dist/common/xml.js.map +1 -0
- package/dist/drivers/__mocks__/auth.js +1 -0
- package/dist/drivers/__mocks__/auth.js.map +1 -0
- package/dist/drivers/api.js +24 -13
- package/dist/drivers/api.js.map +1 -0
- package/dist/drivers/auth.js +1 -0
- package/dist/drivers/auth.js.map +1 -0
- package/dist/drivers/env.d.ts +1 -0
- package/dist/drivers/env.js +3 -1
- package/dist/drivers/env.js.map +1 -0
- package/dist/drivers/firestore.js +1 -0
- package/dist/drivers/firestore.js.map +1 -0
- package/dist/drivers/stdio.js +1 -0
- package/dist/drivers/stdio.js.map +1 -0
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -0
- package/dist/middlewares/version.js +1 -0
- package/dist/middlewares/version.js.map +1 -0
- package/dist/plugins/__mocks__/login.js +1 -0
- package/dist/plugins/__mocks__/login.js.map +1 -0
- package/dist/plugins/aws/__mocks__/assumeRole.js +1 -0
- package/dist/plugins/aws/__mocks__/assumeRole.js.map +1 -0
- package/dist/plugins/aws/api.js +1 -0
- package/dist/plugins/aws/api.js.map +1 -0
- package/dist/plugins/aws/assumeRole.js +1 -0
- package/dist/plugins/aws/assumeRole.js.map +1 -0
- package/dist/plugins/aws/config.js +1 -0
- package/dist/plugins/aws/config.js.map +1 -0
- package/dist/plugins/aws/idc/index.js +1 -0
- package/dist/plugins/aws/idc/index.js.map +1 -0
- package/dist/plugins/aws/ssh.js +1 -0
- package/dist/plugins/aws/ssh.js.map +1 -0
- package/dist/plugins/aws/ssm/install.js +1 -0
- package/dist/plugins/aws/ssm/install.js.map +1 -0
- package/dist/plugins/aws/types.d.ts +16 -16
- package/dist/plugins/aws/types.js +1 -0
- package/dist/plugins/aws/types.js.map +1 -0
- package/dist/plugins/google/install.js +1 -0
- package/dist/plugins/google/install.js.map +1 -0
- package/dist/plugins/google/login.js +1 -0
- package/dist/plugins/google/login.js.map +1 -0
- package/dist/plugins/google/ssh-key.js +4 -0
- package/dist/plugins/google/ssh-key.js.map +1 -0
- package/dist/plugins/google/ssh.js +1 -0
- package/dist/plugins/google/ssh.js.map +1 -0
- package/dist/plugins/google/types.d.ts +8 -8
- package/dist/plugins/google/types.js +1 -0
- package/dist/plugins/google/types.js.map +1 -0
- package/dist/plugins/kubeconfig/index.js +1 -0
- package/dist/plugins/kubeconfig/index.js.map +1 -0
- package/dist/plugins/kubeconfig/install.js +1 -0
- package/dist/plugins/kubeconfig/install.js.map +1 -0
- package/dist/plugins/kubeconfig/types.d.ts +5 -5
- package/dist/plugins/kubeconfig/types.js +1 -0
- package/dist/plugins/kubeconfig/types.js.map +1 -0
- package/dist/plugins/login.d.ts +1 -1
- package/dist/plugins/login.js +1 -0
- package/dist/plugins/login.js.map +1 -0
- package/dist/plugins/oidc/login.js +1 -0
- package/dist/plugins/oidc/login.js.map +1 -0
- package/dist/plugins/okta/aws.js +1 -0
- package/dist/plugins/okta/aws.js.map +1 -0
- package/dist/plugins/okta/login.js +1 -0
- package/dist/plugins/okta/login.js.map +1 -0
- package/dist/plugins/ping/login.js +1 -0
- package/dist/plugins/ping/login.js.map +1 -0
- package/dist/plugins/ssh/index.js +32 -29
- package/dist/plugins/ssh/index.js.map +1 -0
- package/dist/plugins/ssh/types.d.ts +3 -3
- package/dist/plugins/ssh/types.js +1 -0
- package/dist/plugins/ssh/types.js.map +1 -0
- package/dist/testing/firestore.js +1 -0
- package/dist/testing/firestore.js.map +1 -0
- package/dist/testing/yargs.js +1 -0
- package/dist/testing/yargs.js.map +1 -0
- package/dist/types/allow.d.ts +1 -1
- package/dist/types/allow.js +1 -0
- package/dist/types/allow.js.map +1 -0
- package/dist/types/aws/oidc.d.ts +3 -3
- package/dist/types/aws/oidc.js +1 -0
- package/dist/types/aws/oidc.js.map +1 -0
- package/dist/types/identity.d.ts +2 -2
- package/dist/types/identity.js +1 -0
- package/dist/types/identity.js.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/oidc.d.ts +5 -5
- package/dist/types/oidc.js +1 -0
- package/dist/types/oidc.js.map +1 -0
- package/dist/types/org.d.ts +3 -3
- package/dist/types/org.js +1 -0
- package/dist/types/org.js.map +1 -0
- package/dist/types/request.d.ts +4 -4
- package/dist/types/request.js +1 -0
- package/dist/types/request.js.map +1 -0
- package/dist/types/ssh.d.ts +6 -6
- package/dist/types/ssh.js +1 -0
- package/dist/types/ssh.js.map +1 -0
- package/dist/util.d.ts +0 -10
- package/dist/util.js +3 -1
- package/dist/util.js.map +1 -0
- package/package.json +5 -1
- package/dist/plugins/ssh-agent/index.d.ts +0 -4
- package/dist/plugins/ssh-agent/index.js +0 -102
- package/dist/plugins/ssh-agent/types.d.ts +0 -13
- package/dist/plugins/ssh-agent/types.js +0 -2
package/dist/plugins/okta/aws.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aws.js","sourceRoot":"","sources":["../../../src/plugins/okta/aws.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA;;;;;;;;;GASG;AACH,kDAAsE;AACtE,6CAA4C;AAE5C,kDAAuD;AAEhD,MAAM,sBAAsB,GAAG,CACpC,KAAY,EACZ,IAA0C,EAC1C,EAAE;IACF,OAAA,MAAM,IAAA,aAAM,EACV,YAAY,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,EAAE,EACzC,GAAS,EAAE;QACT,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,IAAA,mBAAY,EAC1D,KAAK,EACL,IAAI,CAAC,SAAS,CACf,CAAC;QACF,MAAM,EAAE,KAAK,EAAE,GAAG,IAAA,oBAAa,EAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QACvD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;YAC5B,MAAM,yCAAyC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACzF,OAAO,MAAM,IAAA,+BAAkB,EAAC;YAC9B,OAAO;YACP,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,IAAI,EAAE;gBACJ,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB;gBACpD,QAAQ,EAAE,YAAY;aACvB;SACF,CAAC,CAAC;IACL,CAAC,CAAA,EACD,EAAE,QAAQ,EAAE,MAAM,EAAE,CACrB,CAAA;EAAA,CAAC;AAxBS,QAAA,sBAAsB,0BAwB/B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../../src/plugins/okta/login.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../../src/plugins/ping/login.ts"],"names":[],"mappings":";;;;;;;;;;;;AAYA,yCAA0D;AAE1D,kCAAkC;AAC3B,MAAM,SAAS,GAAG,CAAO,GAAY,EAAE,EAAE;IAC9C,OAAA,IAAA,iBAAS,EACP,IAAA,sBAAc,EAAC,GAAG,EAAE,sBAAsB,EAAE,GAAG,EAAE;QAC/C,IAAI,GAAG,CAAC,YAAY,KAAK,MAAM,IAAI,GAAG,CAAC,YAAY,KAAK,SAAS,EAAE;YACjE,MAAM,yBAAyB,GAAG,CAAC,YAAY,oBAAoB,CAAC;SACrE;QACD,OAAO;YACL,sBAAsB,EAAE,WAAW,GAAG,CAAC,cAAc,IAAI,GAAG,CAAC,aAAa,0BAA0B;YACpG,QAAQ,EAAE,WAAW,GAAG,CAAC,cAAc,IAAI,GAAG,CAAC,aAAa,WAAW;SACxE,CAAC;IACJ,CAAC,CAAC,CACH,CAAA;EAAA,CAAC;AAXS,QAAA,SAAS,aAWlB"}
|
|
@@ -23,7 +23,6 @@ You should have received a copy of the GNU General Public License along with @p0
|
|
|
23
23
|
const ssh_1 = require("../../commands/shared/ssh");
|
|
24
24
|
const keys_1 = require("../../common/keys");
|
|
25
25
|
const stdio_1 = require("../../drivers/stdio");
|
|
26
|
-
const ssh_agent_1 = require("../ssh-agent");
|
|
27
26
|
const node_child_process_1 = require("node:child_process");
|
|
28
27
|
/** Matches the error message that AWS SSM print1 when access is not propagated */
|
|
29
28
|
// Note that the resource will randomly be either the SSM document or the EC2 instance
|
|
@@ -177,6 +176,13 @@ function spawnSshNode(options) {
|
|
|
177
176
|
const createCommand = (data, args, proxyCommand) => {
|
|
178
177
|
const commonArgs = [
|
|
179
178
|
...(args.debug ? ["-v"] : []),
|
|
179
|
+
// Explicitly specify which private key to use to avoid "Too many authentication failures"
|
|
180
|
+
// error caused by SSH trying every available key
|
|
181
|
+
"-i",
|
|
182
|
+
keys_1.PRIVATE_KEY_PATH,
|
|
183
|
+
// Only use the authentication identity specified by -i above
|
|
184
|
+
"-o",
|
|
185
|
+
"IdentitiesOnly=yes",
|
|
180
186
|
"-o",
|
|
181
187
|
`ProxyCommand=${proxyCommand.join(" ")}`,
|
|
182
188
|
];
|
|
@@ -255,34 +261,31 @@ const sshOrScp = (args) => __awaiter(void 0, void 0, void 0, function* () {
|
|
|
255
261
|
}
|
|
256
262
|
const credential = yield sshProvider.cloudProviderLogin(authn, request);
|
|
257
263
|
const proxyCommand = sshProvider.proxyCommand(request);
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
`${command} ${transformForShell(args).join(" ")}`,
|
|
268
|
-
].join("\n");
|
|
269
|
-
(0, stdio_1.print2)(`Execute the following commands to create a similar SSH/SCP session:\n*** COMMANDS BEGIN ***\n${repro}\n*** COMMANDS END ***"\n`);
|
|
270
|
-
}
|
|
264
|
+
const { command, args: commandArgs } = createCommand(request, cmdArgs, proxyCommand);
|
|
265
|
+
if (cmdArgs.debug) {
|
|
266
|
+
const reproCommands = sshProvider.reproCommands(request);
|
|
267
|
+
if (reproCommands) {
|
|
268
|
+
const repro = [
|
|
269
|
+
...reproCommands,
|
|
270
|
+
`${command} ${transformForShell(commandArgs).join(" ")}`,
|
|
271
|
+
].join("\n");
|
|
272
|
+
(0, stdio_1.print2)(`Execute the following commands to create a similar SSH/SCP session:\n*** COMMANDS BEGIN ***\n${repro}\n*** COMMANDS END ***"\n`);
|
|
271
273
|
}
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
})
|
|
274
|
+
}
|
|
275
|
+
const exitCode = yield preTestAccessPropagationIfNeeded(sshProvider, request, cmdArgs, proxyCommand, credential);
|
|
276
|
+
if (exitCode && exitCode !== 0) {
|
|
277
|
+
return exitCode; // Only exit if there was an error when pre-testing
|
|
278
|
+
}
|
|
279
|
+
return spawnSshNode({
|
|
280
|
+
credential,
|
|
281
|
+
abortController: new AbortController(),
|
|
282
|
+
command,
|
|
283
|
+
args: commandArgs,
|
|
284
|
+
stdio: ["inherit", "inherit", "pipe"],
|
|
285
|
+
debug: cmdArgs.debug,
|
|
286
|
+
provider: request.type,
|
|
287
|
+
attemptsRemaining: sshProvider.maxRetries,
|
|
288
|
+
});
|
|
287
289
|
});
|
|
288
290
|
exports.sshOrScp = sshOrScp;
|
|
291
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/plugins/ssh/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,14 +8,14 @@ This file is part of @p0security/cli
|
|
|
8
8
|
|
|
9
9
|
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
10
10
|
**/
|
|
11
|
-
|
|
11
|
+
type SshItemConfig = {
|
|
12
12
|
label?: string;
|
|
13
13
|
state: string;
|
|
14
14
|
};
|
|
15
|
-
export
|
|
15
|
+
export type SshConfig = {
|
|
16
16
|
"iam-write": Record<string, SshItemConfig>;
|
|
17
17
|
};
|
|
18
|
-
export
|
|
18
|
+
export type CommonSshPermissionSpec = {
|
|
19
19
|
publicKey: string;
|
|
20
20
|
sudo?: boolean;
|
|
21
21
|
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/plugins/ssh/types.ts"],"names":[],"mappings":""}
|
|
@@ -14,3 +14,4 @@ You should have received a copy of the GNU General Public License along with @p0
|
|
|
14
14
|
const firestore_1 = require("firebase/firestore");
|
|
15
15
|
const mockGetDoc = (data) => firestore_1.getDoc.mockResolvedValue({ data: () => data });
|
|
16
16
|
exports.mockGetDoc = mockGetDoc;
|
|
17
|
+
//# sourceMappingURL=firestore.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"firestore.js","sourceRoot":"","sources":["../../src/testing/firestore.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;GASG;AACH,kDAA4C;AAErC,MAAM,UAAU,GAAG,CAAC,IAAS,EAAE,EAAE,CACrC,kBAAoB,CAAC,iBAAiB,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;AADnD,QAAA,UAAU,cACyC"}
|
package/dist/testing/yargs.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"yargs.js","sourceRoot":"","sources":["../../src/testing/yargs.ts"],"names":[],"mappings":";;;;;;;;;;;;AAYO,MAAM,OAAO,GAAG,CAAO,IAAgB,EAAE,OAAe,EAAE,EAAE;IACjE,IAAI,KAAU,CAAC;IACf,IAAI;QACF,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;KAC3D;IAAC,OAAO,MAAW,EAAE;QACpB,KAAK,GAAG,MAAM,CAAC;KAChB;IACD,OAAO,KAAK,CAAC;AACf,CAAC,CAAA,CAAC;AARW,QAAA,OAAO,WAQlB"}
|
package/dist/types/allow.d.ts
CHANGED
|
@@ -8,7 +8,7 @@ This file is part of @p0security/cli
|
|
|
8
8
|
|
|
9
9
|
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
10
10
|
**/
|
|
11
|
-
export
|
|
11
|
+
export type AllowResponse = {
|
|
12
12
|
ok: true;
|
|
13
13
|
message: string;
|
|
14
14
|
};
|
package/dist/types/allow.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"allow.js","sourceRoot":"","sources":["../../src/types/allow.ts"],"names":[],"mappings":""}
|
package/dist/types/aws/oidc.d.ts
CHANGED
|
@@ -8,7 +8,7 @@ This file is part of @p0security/cli
|
|
|
8
8
|
|
|
9
9
|
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
10
10
|
**/
|
|
11
|
-
export
|
|
11
|
+
export type AWSClientInformation = {
|
|
12
12
|
authorizationEndpoint: string;
|
|
13
13
|
clientId: string;
|
|
14
14
|
clientIdIssuedAt: number;
|
|
@@ -19,14 +19,14 @@ export declare type AWSClientInformation = {
|
|
|
19
19
|
/**
|
|
20
20
|
* AWS OIDC token response uses camelCase instead of snake_case
|
|
21
21
|
*/
|
|
22
|
-
export
|
|
22
|
+
export type AWSTokenResponse = {
|
|
23
23
|
accessToken: string;
|
|
24
24
|
expiresIn: number;
|
|
25
25
|
idToken: string;
|
|
26
26
|
refreshToken: string;
|
|
27
27
|
tokenType: string;
|
|
28
28
|
};
|
|
29
|
-
export
|
|
29
|
+
export type AWSAuthorizeResponse = {
|
|
30
30
|
deviceCode: string;
|
|
31
31
|
expiresIn: number;
|
|
32
32
|
interval: number;
|
package/dist/types/aws/oidc.js
CHANGED
|
@@ -10,3 +10,4 @@ This file is part of @p0security/cli
|
|
|
10
10
|
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
11
11
|
**/
|
|
12
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
//# sourceMappingURL=oidc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"oidc.js","sourceRoot":"","sources":["../../../src/types/aws/oidc.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG"}
|
package/dist/types/identity.d.ts
CHANGED
|
@@ -11,13 +11,13 @@ You should have received a copy of the GNU General Public License along with @p0
|
|
|
11
11
|
import { TokenResponse } from "./oidc";
|
|
12
12
|
import { OrgData } from "./org";
|
|
13
13
|
import { UserCredential } from "firebase/auth";
|
|
14
|
-
export
|
|
14
|
+
export type Identity = {
|
|
15
15
|
credential: TokenResponse & {
|
|
16
16
|
expires_at: number;
|
|
17
17
|
};
|
|
18
18
|
org: OrgData;
|
|
19
19
|
};
|
|
20
|
-
export
|
|
20
|
+
export type Authn = {
|
|
21
21
|
identity: Identity;
|
|
22
22
|
userCredential: UserCredential;
|
|
23
23
|
};
|
package/dist/types/identity.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identity.js","sourceRoot":"","sources":["../../src/types/identity.ts"],"names":[],"mappings":""}
|
package/dist/types/index.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG;;;AAEI,MAAM,GAAG,GACd,CAAI,MAAoB,EAAE,EAAE,CAC5B,CAAC,IAAS,EAAa,EAAE,CACvB,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AAHb,QAAA,GAAG,OAGU"}
|
package/dist/types/oidc.d.ts
CHANGED
|
@@ -9,7 +9,7 @@ This file is part of @p0security/cli
|
|
|
9
9
|
|
|
10
10
|
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
11
11
|
**/
|
|
12
|
-
export
|
|
12
|
+
export type AuthorizeRequest = {
|
|
13
13
|
client_id: string;
|
|
14
14
|
code_challenge: string;
|
|
15
15
|
code_challenge_method: "plain" | "S256";
|
|
@@ -19,7 +19,7 @@ export declare type AuthorizeRequest = {
|
|
|
19
19
|
state?: string;
|
|
20
20
|
login_hint?: string;
|
|
21
21
|
};
|
|
22
|
-
export
|
|
22
|
+
export type AuthorizeResponse = {
|
|
23
23
|
device_code: string;
|
|
24
24
|
user_code: string;
|
|
25
25
|
verification_uri: string;
|
|
@@ -27,7 +27,7 @@ export declare type AuthorizeResponse = {
|
|
|
27
27
|
expires_in: number;
|
|
28
28
|
interval: number;
|
|
29
29
|
};
|
|
30
|
-
export
|
|
30
|
+
export type TokenResponse = {
|
|
31
31
|
access_token: string;
|
|
32
32
|
id_token: string;
|
|
33
33
|
token_type: string;
|
|
@@ -37,10 +37,10 @@ export declare type TokenResponse = {
|
|
|
37
37
|
device_secret: string;
|
|
38
38
|
expiry: string;
|
|
39
39
|
};
|
|
40
|
-
export
|
|
40
|
+
export type TokenErrorResponse = {
|
|
41
41
|
error: "access_denied" | "authorization_pending" | "bad grant type" | "expired_token" | "missing parameter" | "not found" | "slow_down";
|
|
42
42
|
};
|
|
43
|
-
export
|
|
43
|
+
export type OidcLoginSteps<A> = {
|
|
44
44
|
providerType: LoginPluginType;
|
|
45
45
|
validateResponse: (response: Response) => Promise<Response>;
|
|
46
46
|
buildAuthorizeRequest: () => {
|
package/dist/types/oidc.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"oidc.js","sourceRoot":"","sources":["../../src/types/oidc.ts"],"names":[],"mappings":""}
|
package/dist/types/org.d.ts
CHANGED
|
@@ -8,7 +8,7 @@ This file is part of @p0security/cli
|
|
|
8
8
|
|
|
9
9
|
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
10
10
|
**/
|
|
11
|
-
|
|
11
|
+
type BaseOrgData = {
|
|
12
12
|
clientId: string;
|
|
13
13
|
providerId: string;
|
|
14
14
|
providerDomain?: string;
|
|
@@ -16,13 +16,13 @@ declare type BaseOrgData = {
|
|
|
16
16
|
tenantId: string;
|
|
17
17
|
};
|
|
18
18
|
/** Publicly readable organization data */
|
|
19
|
-
export
|
|
19
|
+
export type RawOrgData = BaseOrgData & ({
|
|
20
20
|
providerType?: "okta";
|
|
21
21
|
} | {
|
|
22
22
|
providerType?: "ping";
|
|
23
23
|
environmentId: string;
|
|
24
24
|
});
|
|
25
|
-
export
|
|
25
|
+
export type OrgData = RawOrgData & {
|
|
26
26
|
slug: string;
|
|
27
27
|
};
|
|
28
28
|
export {};
|
package/dist/types/org.js
CHANGED
|
@@ -10,3 +10,4 @@ This file is part of @p0security/cli
|
|
|
10
10
|
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
11
11
|
**/
|
|
12
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
//# sourceMappingURL=org.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"org.js","sourceRoot":"","sources":["../../src/types/org.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG"}
|
package/dist/types/request.d.ts
CHANGED
|
@@ -13,19 +13,19 @@ import { PluginSshRequest } from "./ssh";
|
|
|
13
13
|
export declare const DONE_STATUSES: readonly ["DONE", "DONE_NOTIFIED"];
|
|
14
14
|
export declare const DENIED_STATUSES: readonly ["DENIED", "DENIED_NOTIFIED"];
|
|
15
15
|
export declare const ERROR_STATUSES: readonly ["ERRORED", "ERRORED", "ERRORED_NOTIFIED"];
|
|
16
|
-
export
|
|
16
|
+
export type PermissionSpec<K extends string, P extends {
|
|
17
17
|
type: string;
|
|
18
18
|
}, G extends object | undefined = undefined> = {
|
|
19
19
|
type: K;
|
|
20
20
|
permission: P;
|
|
21
21
|
generated: G;
|
|
22
22
|
};
|
|
23
|
-
export
|
|
24
|
-
export
|
|
23
|
+
export type PluginRequest = K8sPermissionSpec | PluginSshRequest;
|
|
24
|
+
export type Request<P extends PluginRequest> = P & {
|
|
25
25
|
status: string;
|
|
26
26
|
principal: string;
|
|
27
27
|
};
|
|
28
|
-
export
|
|
28
|
+
export type RequestResponse<T> = {
|
|
29
29
|
ok: true;
|
|
30
30
|
message: string;
|
|
31
31
|
id: string;
|
package/dist/types/request.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request.js","sourceRoot":"","sources":["../../src/types/request.ts"],"names":[],"mappings":";;;AAaa,QAAA,aAAa,GAAG,CAAC,MAAM,EAAE,eAAe,CAAU,CAAC;AACnD,QAAA,eAAe,GAAG,CAAC,QAAQ,EAAE,iBAAiB,CAAU,CAAC;AACzD,QAAA,cAAc,GAAG;IAC5B,SAAS;IACT,SAAS;IACT,kBAAkB;CACV,CAAC"}
|
package/dist/types/ssh.d.ts
CHANGED
|
@@ -13,14 +13,14 @@ import { AwsSsh, AwsSshPermissionSpec, AwsSshRequest } from "../plugins/aws/type
|
|
|
13
13
|
import { GcpSsh, GcpSshPermissionSpec, GcpSshRequest } from "../plugins/google/types";
|
|
14
14
|
import { Authn } from "./identity";
|
|
15
15
|
import { Request } from "./request";
|
|
16
|
-
export
|
|
17
|
-
export
|
|
18
|
-
export
|
|
16
|
+
export type CliSshRequest = AwsSsh | GcpSsh;
|
|
17
|
+
export type PluginSshRequest = AwsSshPermissionSpec | GcpSshPermissionSpec;
|
|
18
|
+
export type CliPermissionSpec<P extends PluginSshRequest, C extends object | undefined> = P & {
|
|
19
19
|
cliLocalData: C;
|
|
20
20
|
};
|
|
21
21
|
export declare const SupportedSshProviders: readonly ["aws", "gcloud"];
|
|
22
|
-
export
|
|
23
|
-
export
|
|
22
|
+
export type SupportedSshProvider = (typeof SupportedSshProviders)[number];
|
|
23
|
+
export type SshProvider<PR extends PluginSshRequest = PluginSshRequest, O extends object | undefined = undefined, SR extends SshRequest = SshRequest, C extends object | undefined = undefined> = {
|
|
24
24
|
requestToSsh: (request: CliPermissionSpec<PR, O>) => SR;
|
|
25
25
|
/** Converts a backend request to a CLI request */
|
|
26
26
|
toCliRequest: (request: Request<PR>, options?: {
|
|
@@ -45,4 +45,4 @@ export declare type SshProvider<PR extends PluginSshRequest = PluginSshRequest,
|
|
|
45
45
|
maxRetries: number;
|
|
46
46
|
friendlyName: string;
|
|
47
47
|
};
|
|
48
|
-
export
|
|
48
|
+
export type SshRequest = AwsSshRequest | GcpSshRequest;
|
package/dist/types/ssh.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ssh.js","sourceRoot":"","sources":["../../src/types/ssh.ts"],"names":[],"mappings":";;;AAkCA,kEAAkE;AACrD,QAAA,qBAAqB,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAU,CAAC"}
|
package/dist/util.d.ts
CHANGED
|
@@ -1,13 +1,3 @@
|
|
|
1
|
-
/** Copyright © 2024-present P0 Security
|
|
2
|
-
|
|
3
|
-
This file is part of @p0security/cli
|
|
4
|
-
|
|
5
|
-
@p0security/cli is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 3 of the License.
|
|
6
|
-
|
|
7
|
-
@p0security/cli is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
8
|
-
|
|
9
|
-
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
10
|
-
**/
|
|
11
1
|
import child_process from "node:child_process";
|
|
12
2
|
export declare const P0_PATH: string;
|
|
13
3
|
/** Waits the specified delay (in ms)
|
package/dist/util.js
CHANGED
|
@@ -23,10 +23,11 @@ This file is part of @p0security/cli
|
|
|
23
23
|
|
|
24
24
|
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
25
25
|
**/
|
|
26
|
+
const env_1 = require("./drivers/env");
|
|
26
27
|
const node_child_process_1 = __importDefault(require("node:child_process"));
|
|
27
28
|
const node_os_1 = __importDefault(require("node:os"));
|
|
28
29
|
const node_path_1 = __importDefault(require("node:path"));
|
|
29
|
-
exports.P0_PATH = node_path_1.default.join(node_os_1.default.homedir(), ".p0");
|
|
30
|
+
exports.P0_PATH = node_path_1.default.join(node_os_1.default.homedir(), env_1.config.environment === "production" ? ".p0" : `.p0-${env_1.config.environment}`);
|
|
30
31
|
/** Waits the specified delay (in ms)
|
|
31
32
|
*
|
|
32
33
|
* The returned promise is cancelable:
|
|
@@ -107,3 +108,4 @@ exports.unexpectedValueError = unexpectedValueError;
|
|
|
107
108
|
*/
|
|
108
109
|
const ciEquals = (a, b) => a.localeCompare(b, undefined, { sensitivity: "accent" }) === 0;
|
|
109
110
|
exports.ciEquals = ciEquals;
|
|
111
|
+
//# sourceMappingURL=util.js.map
|
package/dist/util.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@p0security/cli",
|
|
3
|
-
"version": "0.10.
|
|
3
|
+
"version": "0.10.1",
|
|
4
4
|
"description": "Execute infra CLI commands with P0 grants",
|
|
5
5
|
"main": "index.ts",
|
|
6
6
|
"repository": {
|
|
@@ -12,6 +12,9 @@
|
|
|
12
12
|
"bin": {
|
|
13
13
|
"p0": "p0"
|
|
14
14
|
},
|
|
15
|
+
"engines": {
|
|
16
|
+
"node": ">=20.14"
|
|
17
|
+
},
|
|
15
18
|
"files": [
|
|
16
19
|
"dist",
|
|
17
20
|
"p0",
|
|
@@ -62,6 +65,7 @@
|
|
|
62
65
|
"eslint-plugin-promise": "^6.1.1",
|
|
63
66
|
"jest": "^29.7.0",
|
|
64
67
|
"prettier": "^3.2.4",
|
|
68
|
+
"ts-node": "^10.9.2",
|
|
65
69
|
"ts-jest": "^29.1.2"
|
|
66
70
|
},
|
|
67
71
|
"scripts": {
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { AgentArgs } from "./types";
|
|
2
|
-
export declare const privateKeyExists: (args: AgentArgs) => Promise<boolean>;
|
|
3
|
-
export declare const addPrivateKey: (args: AgentArgs) => Promise<boolean>;
|
|
4
|
-
export declare const withSshAgent: <T>(args: AgentArgs, fn: () => Promise<T>) => Promise<T>;
|
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.withSshAgent = exports.addPrivateKey = exports.privateKeyExists = void 0;
|
|
13
|
-
/** Copyright © 2024-present P0 Security
|
|
14
|
-
|
|
15
|
-
This file is part of @p0security/cli
|
|
16
|
-
|
|
17
|
-
@p0security/cli is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 3 of the License.
|
|
18
|
-
|
|
19
|
-
@p0security/cli is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
20
|
-
|
|
21
|
-
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
22
|
-
**/
|
|
23
|
-
const keys_1 = require("../../common/keys");
|
|
24
|
-
const subprocess_1 = require("../../common/subprocess");
|
|
25
|
-
const stdio_1 = require("../../drivers/stdio");
|
|
26
|
-
const isSshAgentRunning = (args) => __awaiter(void 0, void 0, void 0, function* () {
|
|
27
|
-
try {
|
|
28
|
-
if (args.debug)
|
|
29
|
-
(0, stdio_1.print2)("Searching for active ssh-agents");
|
|
30
|
-
// TODO: There's a possible edge-case but unlikely that ssh-agent has an invalid process or PID.
|
|
31
|
-
// We can check to see if the active PID matches the current socket to mitigate this.
|
|
32
|
-
yield (0, subprocess_1.asyncSpawn)(args, `pgrep`, ["-x", "ssh-agent"]);
|
|
33
|
-
if (args.debug)
|
|
34
|
-
(0, stdio_1.print2)("At least one SSH agent is running");
|
|
35
|
-
return true;
|
|
36
|
-
}
|
|
37
|
-
catch (_a) {
|
|
38
|
-
if (args.debug)
|
|
39
|
-
(0, stdio_1.print2)("No SSH agent is running!");
|
|
40
|
-
return false;
|
|
41
|
-
}
|
|
42
|
-
});
|
|
43
|
-
const isSshAgentAuthSocketSet = (args) => __awaiter(void 0, void 0, void 0, function* () {
|
|
44
|
-
try {
|
|
45
|
-
yield (0, subprocess_1.asyncSpawn)(args, `sh`, ["-c", '[ -n "$SSH_AUTH_SOCK" ]']);
|
|
46
|
-
if (args.debug)
|
|
47
|
-
(0, stdio_1.print2)(`SSH_AUTH_SOCK=${process.env.SSH_AUTH_SOCK}`);
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
catch (_b) {
|
|
51
|
-
if (args.debug)
|
|
52
|
-
(0, stdio_1.print2)("SSH_AUTH_SOCK is not set!");
|
|
53
|
-
return false;
|
|
54
|
-
}
|
|
55
|
-
});
|
|
56
|
-
const privateKeyExists = (args) => __awaiter(void 0, void 0, void 0, function* () {
|
|
57
|
-
try {
|
|
58
|
-
yield (0, subprocess_1.asyncSpawn)(args, `sh`, [
|
|
59
|
-
"-c",
|
|
60
|
-
`KEY_PATH="${keys_1.PRIVATE_KEY_PATH}" && KEY_FINGERPRINT=$(ssh-keygen -lf "$KEY_PATH" | awk '{print $2}') && ssh-add -l | grep -q "$KEY_FINGERPRINT" && exit 0 || exit 1`,
|
|
61
|
-
]);
|
|
62
|
-
if (args.debug)
|
|
63
|
-
(0, stdio_1.print2)("Private key exists in ssh agent");
|
|
64
|
-
return true;
|
|
65
|
-
}
|
|
66
|
-
catch (_c) {
|
|
67
|
-
if (args.debug)
|
|
68
|
-
(0, stdio_1.print2)("Private key does not exist in ssh agent");
|
|
69
|
-
return false;
|
|
70
|
-
}
|
|
71
|
-
});
|
|
72
|
-
exports.privateKeyExists = privateKeyExists;
|
|
73
|
-
const addPrivateKey = (args) => __awaiter(void 0, void 0, void 0, function* () {
|
|
74
|
-
try {
|
|
75
|
-
yield (0, subprocess_1.asyncSpawn)(args, `ssh-add`, [
|
|
76
|
-
keys_1.PRIVATE_KEY_PATH,
|
|
77
|
-
...(args.debug ? ["-v", "-v", "-v"] : ["-q"]),
|
|
78
|
-
]);
|
|
79
|
-
if (args.debug)
|
|
80
|
-
(0, stdio_1.print2)("Private key added to ssh agent");
|
|
81
|
-
return true;
|
|
82
|
-
}
|
|
83
|
-
catch (_d) {
|
|
84
|
-
if (args.debug)
|
|
85
|
-
(0, stdio_1.print2)("Failed to add private key to ssh agent");
|
|
86
|
-
return false;
|
|
87
|
-
}
|
|
88
|
-
});
|
|
89
|
-
exports.addPrivateKey = addPrivateKey;
|
|
90
|
-
const withSshAgent = (args, fn) => __awaiter(void 0, void 0, void 0, function* () {
|
|
91
|
-
const isRunning = yield isSshAgentRunning(args);
|
|
92
|
-
const hasSocket = yield isSshAgentAuthSocketSet(args);
|
|
93
|
-
if (!isRunning || !hasSocket) {
|
|
94
|
-
throw "SSH agent is not running. Please start it by running: eval $(ssh-agent)";
|
|
95
|
-
}
|
|
96
|
-
const hasKey = yield (0, exports.privateKeyExists)(args);
|
|
97
|
-
if (!hasKey) {
|
|
98
|
-
yield (0, exports.addPrivateKey)(args);
|
|
99
|
-
}
|
|
100
|
-
return yield fn();
|
|
101
|
-
});
|
|
102
|
-
exports.withSshAgent = withSshAgent;
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
/** Copyright © 2024-present P0 Security
|
|
2
|
-
|
|
3
|
-
This file is part of @p0security/cli
|
|
4
|
-
|
|
5
|
-
@p0security/cli is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 3 of the License.
|
|
6
|
-
|
|
7
|
-
@p0security/cli is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
8
|
-
|
|
9
|
-
You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
|
|
10
|
-
**/
|
|
11
|
-
export declare type AgentArgs = {
|
|
12
|
-
debug?: boolean;
|
|
13
|
-
};
|