@p0security/cli 0.19.8 → 0.19.10

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.
Files changed (75) hide show
  1. package/build/dist/commands/scp.js +7 -1
  2. package/build/dist/commands/scp.js.map +1 -1
  3. package/build/dist/commands/ssh.js +7 -1
  4. package/build/dist/commands/ssh.js.map +1 -1
  5. package/build/dist/common/auth/server.d.ts +1 -1
  6. package/build/dist/common/auth/server.js +29 -9
  7. package/build/dist/common/auth/server.js.map +1 -1
  8. package/build/dist/common/fetch.d.ts +1 -3
  9. package/build/dist/common/fetch.js +1 -3
  10. package/build/dist/common/fetch.js.map +1 -1
  11. package/build/dist/drivers/config.d.ts +1 -0
  12. package/build/dist/drivers/config.js +8 -1
  13. package/build/dist/drivers/config.js.map +1 -1
  14. package/build/dist/drivers/env.js +2 -0
  15. package/build/dist/drivers/env.js.map +1 -1
  16. package/build/dist/middlewares/version.js +7 -0
  17. package/build/dist/middlewares/version.js.map +1 -1
  18. package/build/dist/plugins/okta/aws.js +36 -11
  19. package/build/dist/plugins/okta/aws.js.map +1 -1
  20. package/build/dist/plugins/okta/login.d.ts +20 -2
  21. package/build/dist/plugins/okta/login.js +42 -6
  22. package/build/dist/plugins/okta/login.js.map +1 -1
  23. package/build/dist/plugins/ssh/index.js +8 -39
  24. package/build/dist/plugins/ssh/index.js.map +1 -1
  25. package/build/dist/types/org.d.ts +1 -0
  26. package/build/dist/version.js +1 -1
  27. package/build/dist/version.js.map +1 -1
  28. package/build/tsconfig.build.tsbuildinfo +1 -0
  29. package/package.json +14 -10
  30. package/build/dist/commands/__tests__/grant.test.d.ts +0 -1
  31. package/build/dist/commands/__tests__/grant.test.js +0 -56
  32. package/build/dist/commands/__tests__/grant.test.js.map +0 -1
  33. package/build/dist/commands/__tests__/login.test.d.ts +0 -1
  34. package/build/dist/commands/__tests__/login.test.js +0 -204
  35. package/build/dist/commands/__tests__/login.test.js.map +0 -1
  36. package/build/dist/commands/__tests__/ls.test.d.ts +0 -1
  37. package/build/dist/commands/__tests__/ls.test.js +0 -86
  38. package/build/dist/commands/__tests__/ls.test.js.map +0 -1
  39. package/build/dist/commands/__tests__/request.test.d.ts +0 -1
  40. package/build/dist/commands/__tests__/request.test.js +0 -150
  41. package/build/dist/commands/__tests__/request.test.js.map +0 -1
  42. package/build/dist/commands/__tests__/ssh.test.d.ts +0 -1
  43. package/build/dist/commands/__tests__/ssh.test.js +0 -181
  44. package/build/dist/commands/__tests__/ssh.test.js.map +0 -1
  45. package/build/dist/commands/aws/__tests__/__input__/saml-response.d.ts +0 -11
  46. package/build/dist/commands/aws/__tests__/__input__/saml-response.js +0 -19
  47. package/build/dist/commands/aws/__tests__/__input__/saml-response.js.map +0 -1
  48. package/build/dist/commands/aws/__tests__/__input__/sts-response.d.ts +0 -11
  49. package/build/dist/commands/aws/__tests__/__input__/sts-response.js +0 -38
  50. package/build/dist/commands/aws/__tests__/__input__/sts-response.js.map +0 -1
  51. package/build/dist/commands/aws/__tests__/role.test.d.ts +0 -1
  52. package/build/dist/commands/aws/__tests__/role.test.js +0 -103
  53. package/build/dist/commands/aws/__tests__/role.test.js.map +0 -1
  54. package/build/dist/common/__mocks__/keys.d.ts +0 -15
  55. package/build/dist/common/__mocks__/keys.js +0 -23
  56. package/build/dist/common/__mocks__/keys.js.map +0 -1
  57. package/build/dist/drivers/__mocks__/stdio.d.ts +0 -14
  58. package/build/dist/drivers/__mocks__/stdio.js +0 -26
  59. package/build/dist/drivers/__mocks__/stdio.js.map +0 -1
  60. package/build/dist/drivers/__tests__/api.test.d.ts +0 -1
  61. package/build/dist/drivers/__tests__/api.test.js +0 -688
  62. package/build/dist/drivers/__tests__/api.test.js.map +0 -1
  63. package/build/dist/drivers/auth/__mocks__/index.d.ts +0 -30
  64. package/build/dist/drivers/auth/__mocks__/index.js +0 -47
  65. package/build/dist/drivers/auth/__mocks__/index.js.map +0 -1
  66. package/build/dist/plugins/__mocks__/login.d.ts +0 -14
  67. package/build/dist/plugins/__mocks__/login.js +0 -25
  68. package/build/dist/plugins/__mocks__/login.js.map +0 -1
  69. package/build/dist/plugins/aws/__mocks__/assumeRole.d.ts +0 -12
  70. package/build/dist/plugins/aws/__mocks__/assumeRole.js +0 -22
  71. package/build/dist/plugins/aws/__mocks__/assumeRole.js.map +0 -1
  72. package/build/dist/plugins/aws/__tests__/utils.test.d.ts +0 -1
  73. package/build/dist/plugins/aws/__tests__/utils.test.js +0 -82
  74. package/build/dist/plugins/aws/__tests__/utils.test.js.map +0 -1
  75. package/build/tsconfig.tsbuildinfo +0 -1
@@ -1,181 +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
- var __await = (this && this.__await) || function (v) { return this instanceof __await ? (this.v = v, this) : new __await(v); }
12
- var __asyncGenerator = (this && this.__asyncGenerator) || function (thisArg, _arguments, generator) {
13
- if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
14
- var g = generator.apply(thisArg, _arguments || []), i, q = [];
15
- return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
16
- function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
17
- function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
18
- function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
19
- function fulfill(value) { resume("next", value); }
20
- function reject(value) { resume("throw", value); }
21
- function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
22
- };
23
- var __importDefault = (this && this.__importDefault) || function (mod) {
24
- return (mod && mod.__esModule) ? mod : { "default": mod };
25
- };
26
- Object.defineProperty(exports, "__esModule", { value: true });
27
- /** Copyright © 2024-present P0 Security
28
-
29
- This file is part of @p0security/cli
30
-
31
- @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.
32
-
33
- @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.
34
-
35
- You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
36
- **/
37
- const keys_1 = require("../../common/__mocks__/keys");
38
- const api_1 = require("../../drivers/api");
39
- const stdio_1 = require("../../drivers/stdio");
40
- const ssh_1 = require("../../plugins/ssh");
41
- const util_1 = require("../../util");
42
- const ssh_2 = require("../ssh");
43
- const lodash_1 = require("lodash");
44
- const yargs_1 = __importDefault(require("yargs"));
45
- jest.mock("../../drivers/api");
46
- jest.mock("../../drivers/auth");
47
- jest.mock("../../drivers/stdio", () => (Object.assign(Object.assign({}, jest.requireActual("../../drivers/stdio")), { print1: jest.fn(), print2: jest.fn() })));
48
- jest.mock("../../plugins/ssh");
49
- jest.mock("../../common/keys");
50
- const mockSshOrScp = ssh_1.sshOrScp;
51
- const mockPrint1 = stdio_1.print1;
52
- const mockPrint2 = stdio_1.print2;
53
- const mockIntegrationConfig = api_1.fetchIntegrationConfig;
54
- const mockFetchStreamingCommand = api_1.fetchStreamingCommand;
55
- const MOCK_PERMISSION = {
56
- provider: "aws",
57
- publicKey: keys_1.TEST_PUBLIC_KEY,
58
- region: "region",
59
- alias: "alias",
60
- resource: {
61
- account: "accountId",
62
- accountId: "accountId",
63
- arn: "arn",
64
- idcRegion: "idcRegion",
65
- idcId: "idcId",
66
- name: "name",
67
- userName: "userName",
68
- instanceId: "instanceId",
69
- },
70
- };
71
- const MOCK_GENERATED = {
72
- resource: {
73
- name: "name",
74
- },
75
- linuxUserName: "linuxUserName",
76
- };
77
- const MOCK_REQUEST = {
78
- status: "DONE",
79
- generated: MOCK_GENERATED,
80
- permission: MOCK_PERMISSION,
81
- };
82
- mockIntegrationConfig.mockResolvedValue({
83
- config: {
84
- "iam-write": {
85
- ["aws:test-account"]: {
86
- state: "installed",
87
- },
88
- },
89
- },
90
- });
91
- describe("ssh", () => {
92
- /**
93
- * mockStreaming simulates a streaming response from the API.
94
- * It yields an initial response and then a final response after a delay.
95
- * @param sleep sleep function to simulate delay in streaming response
96
- */
97
- const mockStreaming = (isPersistent, sleep) => {
98
- mockFetchStreamingCommand.mockImplementationOnce(function () {
99
- return __asyncGenerator(this, arguments, function* () {
100
- yield yield __await({
101
- ok: true,
102
- message: "a message",
103
- id: "abcefg",
104
- isPreexisting: false,
105
- isPersistent,
106
- request: { status: "NEW" },
107
- });
108
- yield __await((sleep === null || sleep === void 0 ? void 0 : sleep()));
109
- yield yield __await({
110
- ok: true,
111
- message: "Request approved",
112
- id: "abcefg",
113
- isPreexisting: false,
114
- isPersistent,
115
- request: {
116
- status: "DONE",
117
- id: "abcefg",
118
- generated: MOCK_GENERATED,
119
- permission: MOCK_PERMISSION,
120
- },
121
- });
122
- });
123
- });
124
- };
125
- describe.each([
126
- ["persistent", true],
127
- ["ephemeral", false],
128
- ])("%s access", (_, isPersistent) => {
129
- beforeEach(() => {
130
- jest.clearAllMocks();
131
- });
132
- afterEach(() => {
133
- mockFetchStreamingCommand.mockReset();
134
- });
135
- it("should call p0 request with reason arg", () => __awaiter(void 0, void 0, void 0, function* () {
136
- mockStreaming(isPersistent);
137
- const promise = (0, ssh_2.sshCommand)((0, yargs_1.default)())
138
- .fail(lodash_1.noop)
139
- .parse(`ssh some-instance --reason reason --provider aws`);
140
- // await for the first response to yield
141
- yield (0, util_1.sleep)(10);
142
- const hiddenFilenameRequestArgs = (0, lodash_1.omit)(mockFetchStreamingCommand.mock.calls[0][1], "$0");
143
- expect(hiddenFilenameRequestArgs).toMatchSnapshot("args");
144
- yield expect(promise).resolves.toBeDefined();
145
- }));
146
- it("should wait for access grant/provisioning", () => __awaiter(void 0, void 0, void 0, function* () {
147
- mockStreaming(isPersistent, () => __awaiter(void 0, void 0, void 0, function* () { return yield (0, util_1.sleep)(200); }));
148
- const promise = (0, ssh_2.sshCommand)((0, yargs_1.default)()).fail(lodash_1.noop).parse(`ssh some-instance`);
149
- const wait = (0, util_1.sleep)(100);
150
- yield Promise.race([wait, promise]);
151
- yield expect(wait).resolves.toBeUndefined();
152
- yield expect(promise).resolves.toBeDefined();
153
- }));
154
- /**
155
- * This test checks that the sshOrScp function is called with the correct parameters
156
- * when the command is parsed with a non-interactive command.
157
- * It mocks the sshOrScp function and verifies that it is called with the expected
158
- * arguments, including the generated resource and permission.
159
- * It also checks that the output is printed correctly.
160
- */
161
- it("should call sshOrScp with non-interactive command", () => __awaiter(void 0, void 0, void 0, function* () {
162
- mockStreaming(isPersistent);
163
- const promise = (0, ssh_2.sshCommand)((0, yargs_1.default)())
164
- .fail(lodash_1.noop)
165
- .parse(`ssh some-instance do something`);
166
- yield expect(promise).resolves.toBeDefined();
167
- expect(mockPrint2.mock.calls).toMatchSnapshot("stderr");
168
- expect(mockPrint1).not.toHaveBeenCalled();
169
- expect(mockSshOrScp).toHaveBeenCalled();
170
- }));
171
- it("should call sshOrScp with interactive session", () => __awaiter(void 0, void 0, void 0, function* () {
172
- mockStreaming(isPersistent);
173
- const promise = (0, ssh_2.sshCommand)((0, yargs_1.default)()).fail(lodash_1.noop).parse(`ssh some-instance`);
174
- yield expect(promise).resolves.toBeDefined();
175
- expect(mockPrint2.mock.calls).toMatchSnapshot("stderr");
176
- expect(mockPrint1).not.toHaveBeenCalled();
177
- expect(mockSshOrScp).toHaveBeenCalled();
178
- }));
179
- });
180
- });
181
- //# sourceMappingURL=ssh.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ssh.test.js","sourceRoot":"","sources":["../../../../src/commands/__tests__/ssh.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;;GASG;AACH,sDAA8D;AAC9D,2CAG2B;AAC3B,+CAAqD;AAErD,2CAA6C;AAC7C,qCAAmC;AACnC,gCAAoC;AACpC,mCAAoC;AACpC,kDAA0B;AAE1B,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;AAC/B,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;AAChC,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,GAAG,EAAE,CAAC,iCAClC,IAAI,CAAC,aAAa,CAAC,qBAAqB,CAAC,KAC5C,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,EACjB,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,IACjB,CAAC,CAAC;AACJ,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;AAC/B,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;AAE/B,MAAM,YAAY,GAAG,cAAqB,CAAC;AAC3C,MAAM,UAAU,GAAG,cAAmB,CAAC;AACvC,MAAM,UAAU,GAAG,cAAmB,CAAC;AACvC,MAAM,qBAAqB,GAAG,4BAAmC,CAAC;AAClE,MAAM,yBAAyB,GAAG,2BAAkC,CAAC;AAErE,MAAM,eAAe,GAAqB;IACxC,QAAQ,EAAE,KAAK;IACf,SAAS,EAAE,sBAAe;IAC1B,MAAM,EAAE,QAAQ;IAChB,KAAK,EAAE,OAAO;IACd,QAAQ,EAAE;QACR,OAAO,EAAE,WAAW;QACpB,SAAS,EAAE,WAAW;QACtB,GAAG,EAAE,KAAK;QACV,SAAS,EAAE,WAAW;QACtB,KAAK,EAAE,OAAO;QACd,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,UAAU;QACpB,UAAU,EAAE,YAAY;KACzB;CACF,CAAC;AAEF,MAAM,cAAc,GAAG;IACrB,QAAQ,EAAE;QACR,IAAI,EAAE,MAAM;KACb;IACD,aAAa,EAAE,eAAe;CACZ,CAAC;AAErB,MAAM,YAAY,GAAG;IACnB,MAAM,EAAE,MAAM;IACd,SAAS,EAAE,cAAc;IACzB,UAAU,EAAE,eAAe;CAC5B,CAAC;AAEF,qBAAqB,CAAC,iBAAiB,CAAC;IACtC,MAAM,EAAE;QACN,WAAW,EAAE;YACX,CAAC,kBAAkB,CAAC,EAAE;gBACpB,KAAK,EAAE,WAAW;aACnB;SACF;KACF;CACF,CAAC,CAAC;AAEH,QAAQ,CAAC,KAAK,EAAE,GAAG,EAAE;IACnB;;;;OAIG;IACH,MAAM,aAAa,GAAG,CACpB,YAAqB,EACrB,KAA2B,EAC3B,EAAE;QACF,yBAAyB,CAAC,sBAAsB,CAAC;;gBAC/C,oBAAM;oBACJ,EAAE,EAAE,IAAI;oBACR,OAAO,EAAE,WAAW;oBACpB,EAAE,EAAE,QAAQ;oBACZ,aAAa,EAAE,KAAK;oBACpB,YAAY;oBACZ,OAAO,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;iBAC3B,CAAA,CAAC;gBACF,cAAM,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,EAAI,CAAA,CAAA,CAAC;gBAChB,oBAAM;oBACJ,EAAE,EAAE,IAAI;oBACR,OAAO,EAAE,kBAAkB;oBAC3B,EAAE,EAAE,QAAQ;oBACZ,aAAa,EAAE,KAAK;oBACpB,YAAY;oBACZ,OAAO,EAAE;wBACP,MAAM,EAAE,MAAM;wBACd,EAAE,EAAE,QAAQ;wBACZ,SAAS,EAAE,cAAc;wBACzB,UAAU,EAAE,eAAe;qBAC5B;iBACF,CAAA,CAAC;YACJ,CAAC;SAAA,CAAC,CAAC;IACL,CAAC,CAAC;IACF,QAAQ,CAAC,IAAI,CAAC;QACZ,CAAC,YAAY,EAAE,IAAI,CAAC;QACpB,CAAC,WAAW,EAAE,KAAK,CAAC;KACrB,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,YAAY,EAAE,EAAE;QAClC,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,GAAG,EAAE;YACb,yBAAyB,CAAC,SAAS,EAAE,CAAC;QACxC,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,wCAAwC,EAAE,GAAS,EAAE;YACtD,aAAa,CAAC,YAAY,CAAC,CAAC;YAC5B,MAAM,OAAO,GAAG,IAAA,gBAAU,EAAC,IAAA,eAAK,GAAE,CAAC;iBAChC,IAAI,CAAC,aAAI,CAAC;iBACV,KAAK,CAAC,kDAAkD,CAAC,CAAC;YAC7D,wCAAwC;YACxC,MAAM,IAAA,YAAK,EAAC,EAAE,CAAC,CAAC;YAChB,MAAM,yBAAyB,GAAG,IAAA,aAAI,EACpC,yBAAyB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAC1C,IAAI,CACL,CAAC;YACF,MAAM,CAAC,yBAAyB,CAAC,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;YAC1D,MAAM,MAAM,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;QAC/C,CAAC,CAAA,CAAC,CAAC;QAEH,EAAE,CAAC,2CAA2C,EAAE,GAAS,EAAE;YACzD,aAAa,CAAC,YAAY,EAAE,GAAS,EAAE,kDAAC,OAAA,MAAM,IAAA,YAAK,EAAC,GAAG,CAAC,CAAA,GAAA,CAAC,CAAC;YAC1D,MAAM,OAAO,GAAG,IAAA,gBAAU,EAAC,IAAA,eAAK,GAAE,CAAC,CAAC,IAAI,CAAC,aAAI,CAAC,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;YAC1E,MAAM,IAAI,GAAG,IAAA,YAAK,EAAC,GAAG,CAAC,CAAC;YACxB,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;YACpC,MAAM,MAAM,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;YAC5C,MAAM,MAAM,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;QAC/C,CAAC,CAAA,CAAC,CAAC;QACH;;;;;;WAMG;QACH,EAAE,CAAC,mDAAmD,EAAE,GAAS,EAAE;YACjE,aAAa,CAAC,YAAY,CAAC,CAAC;YAC5B,MAAM,OAAO,GAAG,IAAA,gBAAU,EAAC,IAAA,eAAK,GAAE,CAAC;iBAChC,IAAI,CAAC,aAAI,CAAC;iBACV,KAAK,CAAC,gCAAgC,CAAC,CAAC;YAC3C,MAAM,MAAM,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;YAC7C,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;YACxD,MAAM,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YAC1C,MAAM,CAAC,YAAY,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAC1C,CAAC,CAAA,CAAC,CAAC;QAEH,EAAE,CAAC,+CAA+C,EAAE,GAAS,EAAE;YAC7D,aAAa,CAAC,YAAY,CAAC,CAAC;YAC5B,MAAM,OAAO,GAAG,IAAA,gBAAU,EAAC,IAAA,eAAK,GAAE,CAAC,CAAC,IAAI,CAAC,aAAI,CAAC,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;YAC1E,MAAM,MAAM,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;YAC7C,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;YACxD,MAAM,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;YAC1C,MAAM,CAAC,YAAY,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAC1C,CAAC,CAAA,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -1,11 +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 const samlResponse = "<html>\n <body>\n <input name=\"SAMLResponse\" type=\"hidden\" value=\"<?xml version="1.0" encoding="UTF-8"?>
 <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" xmlns:xs="http://www.w3.org/2001/XMLSchema" Destination="https://signin.aws.amazon.com/saml" ID="abc" IssueInstant="2024-01-01T00:00:00.000Z" Version="2.0">
  <saml2:Issuer xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity">http://www.okta.com/abcdef</saml2:Issuer>
  <ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
    <ds:SignedInfo>
      <ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
      <ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/>
      <ds:Reference URI="#abc">
        <ds:Transforms>
          <ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
          <ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#">
            <ec:InclusiveNamespaces xmlns:ec="http://www.w3.org/2001/10/xml-exc-c14n#" PrefixList="xs"/>
          </ds:Transform>
        </ds:Transforms>
        <ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
        <ds:DigestValue>digest</ds:DigestValue>
      </ds:Reference>
    </ds:SignedInfo>
    <ds:SignatureValue>signature</ds:SignatureValue>
    <ds:KeyInfo>
      <ds:X509Data>
        <ds:X509Certificate>certificate</ds:X509Certificate>
      </ds:X509Data>
    </ds:KeyInfo>
  </ds:Signature>
  <saml2p:Status xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol">
    <saml2p:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/>
  </saml2p:Status>
  <saml2:Assertion xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="abc" IssueInstant="2024-01-01T00:00:00.000Z" Version="2.0">
    <saml2:Issuer xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity">http://www.okta.com/abcdef</saml2:Issuer>
    <ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
      <ds:SignedInfo>
        <ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
        <ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/>
        <ds:Reference URI="#id8477729977532301927088708">
          <ds:Transforms>
            <ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
            <ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#">
              <ec:InclusiveNamespaces xmlns:ec="http://www.w3.org/2001/10/xml-exc-c14n#" PrefixList="xs"/>
            </ds:Transform>
          </ds:Transforms>
          <ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
          <ds:DigestValue>digest</ds:DigestValue>
        </ds:Reference>
      </ds:SignedInfo>
      <ds:SignatureValue>signature</ds:SignatureValue>
      <ds:KeyInfo>
        <ds:X509Data>
          <ds:X509Certificate>certificate</ds:X509Certificate>
        </ds:X509Data>
      </ds:KeyInfo>
    </ds:Signature>
    <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
      <saml2:NameID Format="urn:oasis:names:tc:SAML:2.0:nameid-format:unspecified">test-user@test.com</saml2:NameID>
      <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
        <saml2:SubjectConfirmationData NotOnOrAfter="2024-01-01T00:00:00.000Z" Recipient="https://signin.aws.amazon.com/saml"/>
      </saml2:SubjectConfirmation>
    </saml2:Subject>
    <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2024-01-01T00:00:00.000Z" NotOnOrAfter="2024-01-01T00:00:00.000Z">
      <saml2:AudienceRestriction>
        <saml2:Audience>urn:amazon:webservices</saml2:Audience>
      </saml2:AudienceRestriction>
    </saml2:Conditions>
    <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2024-01-01T00:00:00.000Z" SessionIndex="abc">
      <saml2:AuthnContext>
        <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
      </saml2:AuthnContext>
    </saml2:AuthnStatement>
    <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/Role" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">arn:aws:iam::1:saml-provider/test_okta,arn:aws:iam::1:role/Role1</saml2:AttributeValue>
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">arn:aws:iam::1:saml-provider/test_okta,arn:aws:iam::1:role/Role2</saml2:AttributeValue>
      </saml2:Attribute>
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/RoleSessionName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">test-user@test.com</saml2:AttributeValue>
      </saml2:Attribute>
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/SessionDuration" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">3600</saml2:AttributeValue>
      </saml2:Attribute>
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/PrincipalTag:org" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">test</saml2:AttributeValue>
      </saml2:Attribute>
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/SourceIdentity" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">test-user@test.com</saml2:AttributeValue>
      </saml2:Attribute>
    </saml2:AttributeStatement>
  </saml2:Assertion>
</saml2p:Response>\" />\n </body>\n</html>";
@@ -1,19 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.samlResponse = void 0;
4
- /** Copyright © 2024-present P0 Security
5
-
6
- This file is part of @p0security/cli
7
-
8
- @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.
9
-
10
- @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.
11
-
12
- You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
13
- **/
14
- exports.samlResponse = `<html>
15
- <body>
16
- <input name="SAMLResponse" type="hidden" value="<?xml version="1.0" encoding="UTF-8"?>
 <saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" xmlns:xs="http://www.w3.org/2001/XMLSchema" Destination="https://signin.aws.amazon.com/saml" ID="abc" IssueInstant="2024-01-01T00:00:00.000Z" Version="2.0">
  <saml2:Issuer xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity">http://www.okta.com/abcdef</saml2:Issuer>
  <ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
    <ds:SignedInfo>
      <ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
      <ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/>
      <ds:Reference URI="#abc">
        <ds:Transforms>
          <ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
          <ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#">
            <ec:InclusiveNamespaces xmlns:ec="http://www.w3.org/2001/10/xml-exc-c14n#" PrefixList="xs"/>
          </ds:Transform>
        </ds:Transforms>
        <ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
        <ds:DigestValue>digest</ds:DigestValue>
      </ds:Reference>
    </ds:SignedInfo>
    <ds:SignatureValue>signature</ds:SignatureValue>
    <ds:KeyInfo>
      <ds:X509Data>
        <ds:X509Certificate>certificate</ds:X509Certificate>
      </ds:X509Data>
    </ds:KeyInfo>
  </ds:Signature>
  <saml2p:Status xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol">
    <saml2p:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/>
  </saml2p:Status>
  <saml2:Assertion xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="abc" IssueInstant="2024-01-01T00:00:00.000Z" Version="2.0">
    <saml2:Issuer xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity">http://www.okta.com/abcdef</saml2:Issuer>
    <ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
      <ds:SignedInfo>
        <ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
        <ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/>
        <ds:Reference URI="#id8477729977532301927088708">
          <ds:Transforms>
            <ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
            <ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#">
              <ec:InclusiveNamespaces xmlns:ec="http://www.w3.org/2001/10/xml-exc-c14n#" PrefixList="xs"/>
            </ds:Transform>
          </ds:Transforms>
          <ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
          <ds:DigestValue>digest</ds:DigestValue>
        </ds:Reference>
      </ds:SignedInfo>
      <ds:SignatureValue>signature</ds:SignatureValue>
      <ds:KeyInfo>
        <ds:X509Data>
          <ds:X509Certificate>certificate</ds:X509Certificate>
        </ds:X509Data>
      </ds:KeyInfo>
    </ds:Signature>
    <saml2:Subject xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
      <saml2:NameID Format="urn:oasis:names:tc:SAML:2.0:nameid-format:unspecified">test-user@test.com</saml2:NameID>
      <saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer">
        <saml2:SubjectConfirmationData NotOnOrAfter="2024-01-01T00:00:00.000Z" Recipient="https://signin.aws.amazon.com/saml"/>
      </saml2:SubjectConfirmation>
    </saml2:Subject>
    <saml2:Conditions xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" NotBefore="2024-01-01T00:00:00.000Z" NotOnOrAfter="2024-01-01T00:00:00.000Z">
      <saml2:AudienceRestriction>
        <saml2:Audience>urn:amazon:webservices</saml2:Audience>
      </saml2:AudienceRestriction>
    </saml2:Conditions>
    <saml2:AuthnStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" AuthnInstant="2024-01-01T00:00:00.000Z" SessionIndex="abc">
      <saml2:AuthnContext>
        <saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef>
      </saml2:AuthnContext>
    </saml2:AuthnStatement>
    <saml2:AttributeStatement xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/Role" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">arn:aws:iam::1:saml-provider/test_okta,arn:aws:iam::1:role/Role1</saml2:AttributeValue>
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">arn:aws:iam::1:saml-provider/test_okta,arn:aws:iam::1:role/Role2</saml2:AttributeValue>
      </saml2:Attribute>
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/RoleSessionName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">test-user@test.com</saml2:AttributeValue>
      </saml2:Attribute>
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/SessionDuration" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">3600</saml2:AttributeValue>
      </saml2:Attribute>
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/PrincipalTag:org" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">test</saml2:AttributeValue>
      </saml2:Attribute>
      <saml2:Attribute Name="https://aws.amazon.com/SAML/Attributes/SourceIdentity" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri">
        <saml2:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">test-user@test.com</saml2:AttributeValue>
      </saml2:Attribute>
    </saml2:AttributeStatement>
  </saml2:Assertion>
</saml2p:Response>" />
17
- </body>
18
- </html>`;
19
- //# sourceMappingURL=saml-response.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"saml-response.js","sourceRoot":"","sources":["../../../../../../src/commands/aws/__tests__/__input__/saml-response.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;GASG;AACU,QAAA,YAAY,GAAG;;;;QAIpB,CAAC"}
@@ -1,11 +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 const stsResponse = "<AssumeRoleWithSAMLResponse xmlns=\"https://sts.amazonaws.com/doc/2011-06-15/\">\n<AssumeRoleWithSAMLResult>\n <Audience>https://signin.aws.amazon.com/saml</Audience>\n <AssumedRoleUser>\n <AssumedRoleId>ABCDEFGHIJLMNOPQRST:test-user@test.com</AssumedRoleId>\n <Arn>arn:aws:sts::1:assumed-role/Role1/test-user@test.com</Arn>\n </AssumedRoleUser>\n <Credentials>\n <AccessKeyId>test-access-key</AccessKeyId>\n <SecretAccessKey>secret-access-key</SecretAccessKey>\n <SessionToken>session-token</SessionToken>\n <Expiration>2024-02-22T00:18:21Z</Expiration>\n </Credentials>\n <Subject>test-user@test.com</Subject>\n <NameQualifier>abcdefghijklmnop</NameQualifier>\n <SourceIdentity>test-user@test.com</SourceIdentity>\n <PackedPolicySize>2</PackedPolicySize>\n <SubjectType>unspecified</SubjectType>\n <Issuer>http://www.okta.com/abc</Issuer>\n</AssumeRoleWithSAMLResult>\n<ResponseMetadata>\n <RequestId>f5b94ad4-f322-4d7b-b568-84f2ec184cd7</RequestId>\n</ResponseMetadata>\n</AssumeRoleWithSAMLResponse>";
@@ -1,38 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.stsResponse = void 0;
4
- /** Copyright © 2024-present P0 Security
5
-
6
- This file is part of @p0security/cli
7
-
8
- @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.
9
-
10
- @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.
11
-
12
- You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
13
- **/
14
- exports.stsResponse = `<AssumeRoleWithSAMLResponse xmlns="https://sts.amazonaws.com/doc/2011-06-15/">
15
- <AssumeRoleWithSAMLResult>
16
- <Audience>https://signin.aws.amazon.com/saml</Audience>
17
- <AssumedRoleUser>
18
- <AssumedRoleId>ABCDEFGHIJLMNOPQRST:test-user@test.com</AssumedRoleId>
19
- <Arn>arn:aws:sts::1:assumed-role/Role1/test-user@test.com</Arn>
20
- </AssumedRoleUser>
21
- <Credentials>
22
- <AccessKeyId>test-access-key</AccessKeyId>
23
- <SecretAccessKey>secret-access-key</SecretAccessKey>
24
- <SessionToken>session-token</SessionToken>
25
- <Expiration>2024-02-22T00:18:21Z</Expiration>
26
- </Credentials>
27
- <Subject>test-user@test.com</Subject>
28
- <NameQualifier>abcdefghijklmnop</NameQualifier>
29
- <SourceIdentity>test-user@test.com</SourceIdentity>
30
- <PackedPolicySize>2</PackedPolicySize>
31
- <SubjectType>unspecified</SubjectType>
32
- <Issuer>http://www.okta.com/abc</Issuer>
33
- </AssumeRoleWithSAMLResult>
34
- <ResponseMetadata>
35
- <RequestId>f5b94ad4-f322-4d7b-b568-84f2ec184cd7</RequestId>
36
- </ResponseMetadata>
37
- </AssumeRoleWithSAMLResponse>`;
38
- //# sourceMappingURL=sts-response.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sts-response.js","sourceRoot":"","sources":["../../../../../../src/commands/aws/__tests__/__input__/sts-response.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;GASG;AACU,QAAA,WAAW,GAAG;;;;;;;;;;;;;;;;;;;;;;;8BAuBG,CAAC"}
@@ -1 +0,0 @@
1
- export {};
@@ -1,103 +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
- var __importDefault = (this && this.__importDefault) || function (mod) {
12
- return (mod && mod.__esModule) ? mod : { "default": mod };
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- /** Copyright © 2024-present P0 Security
16
-
17
- This file is part of @p0security/cli
18
-
19
- @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.
20
-
21
- @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.
22
-
23
- You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
24
- **/
25
- const __1 = require("..");
26
- const api_1 = require("../../../drivers/api");
27
- const stdio_1 = require("../../../drivers/stdio");
28
- const yargs_1 = require("../../../testing/yargs");
29
- const saml_response_1 = require("./__input__/saml-response");
30
- const sts_response_1 = require("./__input__/sts-response");
31
- const yargs_2 = __importDefault(require("yargs"));
32
- jest.mock("fs/promises");
33
- jest.mock("../../../drivers/auth");
34
- jest.mock("../../../drivers/stdio");
35
- jest.mock("../../../drivers/api");
36
- jest.mock("typescript", () => (Object.assign(Object.assign({}, jest.requireActual("typescript")), { sys: {
37
- writeOutputIsTTY: () => true,
38
- } })));
39
- jest.mock("../../shared/request", () => ({
40
- provisionRequest: jest.fn(),
41
- }));
42
- jest.mock("../../../util", () => (Object.assign(Object.assign({}, jest.requireActual("../../../util")), { getAppName: () => "p0" })));
43
- const mockFetch = jest.spyOn(global, "fetch");
44
- const mockPrint1 = stdio_1.print1;
45
- const mockPrint2 = stdio_1.print2;
46
- const mockIntegrationConfigFetch = api_1.fetchIntegrationConfig;
47
- beforeEach(() => {
48
- jest.clearAllMocks();
49
- mockFetch.mockImplementation((url) => __awaiter(void 0, void 0, void 0, function* () {
50
- return ({
51
- ok: true,
52
- // This is the token response from fetchSsoWebToken
53
- json: () => __awaiter(void 0, void 0, void 0, function* () { return ({}); }),
54
- // This is the XML response from fetchSamlResponse or stsAssumeRole
55
- text: () => __awaiter(void 0, void 0, void 0, function* () { return url.match(/okta.com/) ? saml_response_1.samlResponse : sts_response_1.stsResponse; }),
56
- });
57
- }));
58
- });
59
- describe("aws role", () => {
60
- describe("a single installed account", () => {
61
- const item = {
62
- label: "test",
63
- state: "installed",
64
- };
65
- describe("without Okta SAML", () => {
66
- mockIntegrationConfigFetch.mockResolvedValue({
67
- config: { "iam-write": { "1": item } },
68
- });
69
- describe.each([["assume", "aws role assume Role1"]])("%s", (_, command) => {
70
- it("should print a friendly error message", () => __awaiter(void 0, void 0, void 0, function* () {
71
- const error = yield (0, yargs_1.failure)((0, __1.awsCommand)((0, yargs_2.default)()), command);
72
- expect(error).toMatchInlineSnapshot(`"Account test is not configured for Okta SAML login."`);
73
- }));
74
- });
75
- });
76
- describe("with Okta SAML", () => {
77
- beforeEach(() => {
78
- mockIntegrationConfigFetch.mockResolvedValue({
79
- config: {
80
- "iam-write": {
81
- "1": Object.assign(Object.assign({}, item), { login: {
82
- type: "federated",
83
- provider: {
84
- type: "okta",
85
- appId: "0oabcdefgh",
86
- identityProvider: "okta",
87
- },
88
- } }),
89
- },
90
- },
91
- });
92
- });
93
- describe("assume", () => {
94
- it("should assume a role", () => __awaiter(void 0, void 0, void 0, function* () {
95
- yield (0, __1.awsCommand)((0, yargs_2.default)()).parse("aws role assume Role1");
96
- expect(mockPrint2.mock.calls).toMatchSnapshot("stderr");
97
- expect(mockPrint1.mock.calls).toMatchSnapshot("stdout");
98
- }));
99
- });
100
- });
101
- });
102
- });
103
- //# sourceMappingURL=role.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"role.test.js","sourceRoot":"","sources":["../../../../../src/commands/aws/__tests__/role.test.ts"],"names":[],"mappings":"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"}
@@ -1,15 +0,0 @@
1
- /// <reference types="jest" />
2
- /** Copyright © 2024-present P0 Security
3
-
4
- This file is part of @p0security/cli
5
-
6
- @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.
7
-
8
- @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.
9
-
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
- **/
12
- export declare const TEST_PUBLIC_KEY = "test-public-key";
13
- export declare const createKeyPair: jest.Mock<any, any, any>;
14
- export declare const saveHostKeys: jest.Mock<any, any, any>;
15
- export declare const getKnownHostsFilePath: jest.Mock<any, any, any>;
@@ -1,23 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getKnownHostsFilePath = exports.saveHostKeys = exports.createKeyPair = exports.TEST_PUBLIC_KEY = void 0;
4
- /** Copyright © 2024-present P0 Security
5
-
6
- This file is part of @p0security/cli
7
-
8
- @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.
9
-
10
- @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.
11
-
12
- You should have received a copy of the GNU General Public License along with @p0security/cli. If not, see <https://www.gnu.org/licenses/>.
13
- **/
14
- exports.TEST_PUBLIC_KEY = "test-public-key";
15
- exports.createKeyPair = jest.fn().mockImplementation(() => ({
16
- publicKey: "test-public-key",
17
- privateKey: "test-private-key",
18
- }));
19
- exports.saveHostKeys = jest.fn().mockResolvedValue(undefined);
20
- exports.getKnownHostsFilePath = jest
21
- .fn()
22
- .mockReturnValue("/mock/path/to/known_hosts/instance");
23
- //# sourceMappingURL=keys.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"keys.js","sourceRoot":"","sources":["../../../../src/common/__mocks__/keys.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;GASG;AACU,QAAA,eAAe,GAAG,iBAAiB,CAAC;AACpC,QAAA,aAAa,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,GAAG,EAAE,CAAC,CAAC;IAC/D,SAAS,EAAE,iBAAiB;IAC5B,UAAU,EAAE,kBAAkB;CAC/B,CAAC,CAAC,CAAC;AACS,QAAA,YAAY,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;AACtD,QAAA,qBAAqB,GAAG,IAAI;KACtC,EAAE,EAAE;KACJ,eAAe,CAAC,oCAAoC,CAAC,CAAC"}
@@ -1,14 +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
- /// <reference types="jest" />
12
- export declare const print1: jest.Mock<any, any, any>;
13
- export declare const print2: jest.Mock<any, any, any>;
14
- export declare const spinUntil: jest.Mock<Promise<unknown>, [_message: string, promise: Promise<unknown>], any>;
@@ -1,26 +0,0 @@
1
- "use strict";
2
- /** Copyright © 2024-present P0 Security
3
-
4
- This file is part of @p0security/cli
5
-
6
- @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.
7
-
8
- @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.
9
-
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
- **/
12
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
- return new (P || (P = Promise))(function (resolve, reject) {
15
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
- step((generator = generator.apply(thisArg, _arguments || [])).next());
19
- });
20
- };
21
- Object.defineProperty(exports, "__esModule", { value: true });
22
- exports.spinUntil = exports.print2 = exports.print1 = void 0;
23
- exports.print1 = jest.fn();
24
- exports.print2 = jest.fn();
25
- exports.spinUntil = jest.fn((_message, promise) => __awaiter(void 0, void 0, void 0, function* () { return yield promise; }));
26
- //# sourceMappingURL=stdio.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"stdio.js","sourceRoot":"","sources":["../../../../src/drivers/__mocks__/stdio.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG;;;;;;;;;;;;AAEU,QAAA,MAAM,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACnB,QAAA,MAAM,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AAEnB,QAAA,SAAS,GAAG,IAAI,CAAC,EAAE,CAC9B,CAAU,QAAgB,EAAE,OAAmB,EAAE,EAAE,kDAAC,OAAA,MAAM,OAAO,CAAA,GAAA,CAClE,CAAC"}
@@ -1 +0,0 @@
1
- export {};