revisium 2.3.0 → 2.5.0-alpha.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/.github/workflows/build.yml +11 -30
- package/.github/workflows/ci.yml +0 -6
- package/.github/workflows/npm-publish.yml +13 -78
- package/.github/workflows/release-train.yml +90 -0
- package/AGENTS.md +98 -0
- package/README.md +31 -13
- package/dist/e2e/utils/cli-runner.d.ts +2 -0
- package/dist/e2e/utils/cli-runner.js +14 -7
- package/dist/e2e/utils/cli-runner.js.map +1 -1
- package/dist/e2e/utils/matrix-fixtures.d.ts +26 -0
- package/dist/e2e/utils/matrix-fixtures.js +109 -0
- package/dist/e2e/utils/matrix-fixtures.js.map +1 -0
- package/dist/e2e/utils/matrix-workspace.d.ts +25 -0
- package/dist/e2e/utils/matrix-workspace.js +61 -0
- package/dist/e2e/utils/matrix-workspace.js.map +1 -0
- package/dist/e2e/utils/standalone-api.d.ts +53 -0
- package/dist/e2e/utils/standalone-api.js +146 -0
- package/dist/e2e/utils/standalone-api.js.map +1 -0
- package/dist/e2e/utils/standalone-runner.d.ts +23 -0
- package/dist/e2e/utils/standalone-runner.js +182 -0
- package/dist/e2e/utils/standalone-runner.js.map +1 -0
- package/dist/package.json +6 -3
- package/dist/src/app.module.js +51 -0
- package/dist/src/app.module.js.map +1 -1
- package/dist/src/commands/auth/auth-command.utils.d.ts +8 -0
- package/dist/src/commands/auth/auth-command.utils.js +28 -0
- package/dist/src/commands/auth/auth-command.utils.js.map +1 -0
- package/dist/src/commands/auth/auth-login.command.d.ts +29 -0
- package/dist/src/commands/auth/auth-login.command.js +155 -0
- package/dist/src/commands/auth/auth-login.command.js.map +1 -0
- package/dist/src/commands/auth/auth-logout.command.d.ts +19 -0
- package/dist/src/commands/auth/auth-logout.command.js +86 -0
- package/dist/src/commands/auth/auth-logout.command.js.map +1 -0
- package/dist/src/commands/auth/auth-status.command.d.ts +19 -0
- package/dist/src/commands/auth/auth-status.command.js +101 -0
- package/dist/src/commands/auth/auth-status.command.js.map +1 -0
- package/dist/src/commands/auth/auth.command.d.ts +5 -0
- package/dist/src/commands/auth/auth.command.js +35 -0
- package/dist/src/commands/auth/auth.command.js.map +1 -0
- package/dist/src/commands/base-sync.command.d.ts +2 -2
- package/dist/src/commands/base-sync.command.js +1 -2
- package/dist/src/commands/base-sync.command.js.map +1 -1
- package/dist/src/commands/base.command.d.ts +2 -0
- package/dist/src/commands/base.command.js +13 -0
- package/dist/src/commands/base.command.js.map +1 -1
- package/dist/src/commands/context/context-create.command.d.ts +28 -0
- package/dist/src/commands/context/context-create.command.js +172 -0
- package/dist/src/commands/context/context-create.command.js.map +1 -0
- package/dist/src/commands/context/context-list.command.d.ts +9 -0
- package/dist/src/commands/context/context-list.command.js +46 -0
- package/dist/src/commands/context/context-list.command.js.map +1 -0
- package/dist/src/commands/context/context-remove.command.d.ts +9 -0
- package/dist/src/commands/context/context-remove.command.js +48 -0
- package/dist/src/commands/context/context-remove.command.js.map +1 -0
- package/dist/src/commands/context/context-show.command.d.ts +9 -0
- package/dist/src/commands/context/context-show.command.js +64 -0
- package/dist/src/commands/context/context-show.command.js.map +1 -0
- package/dist/src/commands/context/context-use.command.d.ts +9 -0
- package/dist/src/commands/context/context-use.command.js +45 -0
- package/dist/src/commands/context/context-use.command.js.map +1 -0
- package/dist/src/commands/context/context.command.d.ts +5 -0
- package/dist/src/commands/context/context.command.js +43 -0
- package/dist/src/commands/context/context.command.js.map +1 -0
- package/dist/src/commands/endpoint/endpoint-ensure.command.d.ts +18 -0
- package/dist/src/commands/endpoint/endpoint-ensure.command.js +90 -0
- package/dist/src/commands/endpoint/endpoint-ensure.command.js.map +1 -0
- package/dist/src/commands/endpoint/endpoint-list.command.d.ts +14 -0
- package/dist/src/commands/endpoint/endpoint-list.command.js +62 -0
- package/dist/src/commands/endpoint/endpoint-list.command.js.map +1 -0
- package/dist/src/commands/endpoint/endpoint.command.d.ts +5 -0
- package/dist/src/commands/endpoint/endpoint.command.js +34 -0
- package/dist/src/commands/endpoint/endpoint.command.js.map +1 -0
- package/dist/src/commands/example/example-bootstrap.command.d.ts +24 -0
- package/dist/src/commands/example/example-bootstrap.command.js +133 -0
- package/dist/src/commands/example/example-bootstrap.command.js.map +1 -0
- package/dist/src/commands/example/example.command.d.ts +5 -0
- package/dist/src/commands/example/example.command.js +33 -0
- package/dist/src/commands/example/example.command.js.map +1 -0
- package/dist/src/commands/instance/instance-add.command.d.ts +16 -0
- package/dist/src/commands/instance/instance-add.command.js +83 -0
- package/dist/src/commands/instance/instance-add.command.js.map +1 -0
- package/dist/src/commands/instance/instance-list.command.d.ts +9 -0
- package/dist/src/commands/instance/instance-list.command.js +45 -0
- package/dist/src/commands/instance/instance-list.command.js.map +1 -0
- package/dist/src/commands/instance/instance-remove.command.d.ts +9 -0
- package/dist/src/commands/instance/instance-remove.command.js +54 -0
- package/dist/src/commands/instance/instance-remove.command.js.map +1 -0
- package/dist/src/commands/instance/instance-show.command.d.ts +9 -0
- package/dist/src/commands/instance/instance-show.command.js +50 -0
- package/dist/src/commands/instance/instance-show.command.js.map +1 -0
- package/dist/src/commands/instance/instance.command.d.ts +5 -0
- package/dist/src/commands/instance/instance.command.js +41 -0
- package/dist/src/commands/instance/instance.command.js.map +1 -0
- package/dist/src/commands/migration/apply-migrations.command.js +1 -0
- package/dist/src/commands/migration/apply-migrations.command.js.map +1 -1
- package/dist/src/commands/project/project-ensure.command.d.ts +16 -0
- package/dist/src/commands/project/project-ensure.command.js +71 -0
- package/dist/src/commands/project/project-ensure.command.js.map +1 -0
- package/dist/src/commands/project/project.command.d.ts +5 -0
- package/dist/src/commands/project/project.command.js +33 -0
- package/dist/src/commands/project/project.command.js.map +1 -0
- package/dist/src/services/bootstrap/bootstrap.service.d.ts +112 -0
- package/dist/src/services/bootstrap/bootstrap.service.js +438 -0
- package/dist/src/services/bootstrap/bootstrap.service.js.map +1 -0
- package/dist/src/services/bootstrap/index.d.ts +1 -0
- package/dist/src/services/bootstrap/index.js +6 -0
- package/dist/src/services/bootstrap/index.js.map +1 -0
- package/dist/src/services/connection/api-client.d.ts +4 -0
- package/dist/src/services/connection/api-client.js +67 -5
- package/dist/src/services/connection/api-client.js.map +1 -1
- package/dist/src/services/connection/connection-factory.service.js +4 -3
- package/dist/src/services/connection/connection-factory.service.js.map +1 -1
- package/dist/src/services/connection/connection.service.d.ts +10 -2
- package/dist/src/services/connection/connection.service.js +49 -4
- package/dist/src/services/connection/connection.service.js.map +1 -1
- package/dist/src/services/credentials/credential-store.service.d.ts +19 -0
- package/dist/src/services/credentials/credential-store.service.js +112 -0
- package/dist/src/services/credentials/credential-store.service.js.map +1 -0
- package/dist/src/services/credentials/credential-target.service.d.ts +22 -0
- package/dist/src/services/credentials/credential-target.service.js +107 -0
- package/dist/src/services/credentials/credential-target.service.js.map +1 -0
- package/dist/src/services/credentials/index.d.ts +2 -0
- package/dist/src/services/credentials/index.js +8 -0
- package/dist/src/services/credentials/index.js.map +1 -0
- package/dist/src/services/index.d.ts +3 -0
- package/dist/src/services/index.js +3 -0
- package/dist/src/services/index.js.map +1 -1
- package/dist/src/services/url/auth-prompt.service.d.ts +3 -1
- package/dist/src/services/url/auth-prompt.service.js +3 -0
- package/dist/src/services/url/auth-prompt.service.js.map +1 -1
- package/dist/src/services/url/url-builder.service.js +3 -0
- package/dist/src/services/url/url-builder.service.js.map +1 -1
- package/dist/src/services/url/url-parser.service.d.ts +1 -1
- package/dist/src/services/url/url-parser.service.js +12 -6
- package/dist/src/services/url/url-parser.service.js.map +1 -1
- package/dist/src/services/workspace/index.d.ts +1 -0
- package/dist/src/services/workspace/index.js +11 -0
- package/dist/src/services/workspace/index.js.map +1 -0
- package/dist/src/services/workspace/workspace-config.service.d.ts +66 -0
- package/dist/src/services/workspace/workspace-config.service.js +313 -0
- package/dist/src/services/workspace/workspace-config.service.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/docs/authentication.md +69 -26
- package/docs/bootstrap-commands.md +105 -0
- package/docs/configuration.md +49 -22
- package/docs/url-format.md +27 -2
- package/docs/workspace-config.md +135 -0
- package/e2e/jest-matrix.json +14 -0
- package/e2e/matrix/M01-auth-commands.e2e-spec.ts +241 -0
- package/e2e/matrix/M02-instance-commands.e2e-spec.ts +213 -0
- package/e2e/matrix/M03-context-commands.e2e-spec.ts +279 -0
- package/e2e/matrix/M04-project-ensure.e2e-spec.ts +218 -0
- package/e2e/matrix/M05-endpoint-commands.e2e-spec.ts +172 -0
- package/e2e/matrix/M06-example-bootstrap.e2e-spec.ts +437 -0
- package/e2e/matrix/M07-migrate.e2e-spec.ts +229 -0
- package/e2e/matrix/M08-schema.e2e-spec.ts +163 -0
- package/e2e/matrix/M09-rows.e2e-spec.ts +185 -0
- package/e2e/matrix/M10-sync.e2e-spec.ts +224 -0
- package/e2e/matrix/M11-target-resolution.e2e-spec.ts +177 -0
- package/e2e/matrix/M12-error-paths.e2e-spec.ts +162 -0
- package/e2e/matrix/M13-no-auth-mode.e2e-spec.ts +119 -0
- package/e2e/matrix/M14-multi-instance-workspace.e2e-spec.ts +182 -0
- package/e2e/matrix/README.md +354 -0
- package/e2e/tests/01-auth.e2e-spec.ts +19 -0
- package/e2e/tests/07-workspace-config.e2e-spec.ts +492 -0
- package/e2e/tests/08-bootstrap.e2e-spec.ts +304 -0
- package/e2e/utils/cli-runner.ts +27 -8
- package/e2e/utils/matrix-fixtures.ts +141 -0
- package/e2e/utils/matrix-workspace.ts +106 -0
- package/e2e/utils/standalone-api.ts +314 -0
- package/e2e/utils/standalone-runner.ts +276 -0
- package/package.json +6 -3
- package/src/app.module.ts +54 -0
- package/src/commands/auth/__tests__/auth-command.utils.spec.ts +41 -0
- package/src/commands/auth/__tests__/auth-login.command.spec.ts +131 -0
- package/src/commands/auth/__tests__/auth-logout.command.spec.ts +85 -0
- package/src/commands/auth/__tests__/auth-status.command.spec.ts +106 -0
- package/src/commands/auth/__tests__/auth.command.spec.ts +18 -0
- package/src/commands/auth/auth-command.utils.ts +36 -0
- package/src/commands/auth/auth-login.command.ts +146 -0
- package/src/commands/auth/auth-logout.command.ts +71 -0
- package/src/commands/auth/auth-status.command.ts +89 -0
- package/src/commands/auth/auth.command.ts +20 -0
- package/src/commands/base-sync.command.ts +2 -3
- package/src/commands/base.command.ts +11 -0
- package/src/commands/context/context-create.command.ts +173 -0
- package/src/commands/context/context-list.command.ts +36 -0
- package/src/commands/context/context-remove.command.ts +35 -0
- package/src/commands/context/context-show.command.ts +59 -0
- package/src/commands/context/context-use.command.ts +31 -0
- package/src/commands/context/context.command.ts +28 -0
- package/src/commands/endpoint/__tests__/endpoint-ensure.command.spec.ts +129 -0
- package/src/commands/endpoint/__tests__/endpoint-list.command.spec.ts +59 -0
- package/src/commands/endpoint/__tests__/endpoint.command.spec.ts +14 -0
- package/src/commands/endpoint/endpoint-ensure.command.ts +74 -0
- package/src/commands/endpoint/endpoint-list.command.ts +48 -0
- package/src/commands/endpoint/endpoint.command.ts +19 -0
- package/src/commands/example/__tests__/example-bootstrap.command.spec.ts +145 -0
- package/src/commands/example/__tests__/example.command.spec.ts +14 -0
- package/src/commands/example/example-bootstrap.command.ts +122 -0
- package/src/commands/example/example.command.ts +18 -0
- package/src/commands/instance/instance-add.command.ts +72 -0
- package/src/commands/instance/instance-list.command.ts +31 -0
- package/src/commands/instance/instance-remove.command.ts +44 -0
- package/src/commands/instance/instance-show.command.ts +35 -0
- package/src/commands/instance/instance.command.ts +26 -0
- package/src/commands/migration/apply-migrations.command.ts +1 -0
- package/src/commands/project/__tests__/project-ensure.command.spec.ts +119 -0
- package/src/commands/project/__tests__/project.command.spec.ts +14 -0
- package/src/commands/project/project-ensure.command.ts +61 -0
- package/src/commands/project/project.command.ts +18 -0
- package/src/services/bootstrap/__tests__/bootstrap.service.spec.ts +798 -0
- package/src/services/bootstrap/bootstrap.service.ts +698 -0
- package/src/services/bootstrap/index.ts +12 -0
- package/src/services/connection/__tests__/api-client.spec.ts +262 -0
- package/src/services/connection/__tests__/connection-factory.service.spec.ts +2 -0
- package/src/services/connection/__tests__/connection.service.spec.ts +161 -0
- package/src/services/connection/api-client.ts +88 -5
- package/src/services/connection/connection-factory.service.ts +4 -3
- package/src/services/connection/connection.service.ts +74 -3
- package/src/services/credentials/__tests__/credential-store.service.spec.ts +128 -0
- package/src/services/credentials/__tests__/credential-target.service.spec.ts +126 -0
- package/src/services/credentials/credential-store.service.ts +145 -0
- package/src/services/credentials/credential-target.service.ts +145 -0
- package/src/services/credentials/index.ts +9 -0
- package/src/services/index.ts +3 -0
- package/src/services/url/__tests__/url-builder.service.spec.ts +17 -0
- package/src/services/url/__tests__/url-parser.service.spec.ts +162 -0
- package/src/services/url/auth-prompt.service.ts +6 -1
- package/src/services/url/url-builder.service.ts +4 -0
- package/src/services/url/url-parser.service.ts +21 -6
- package/src/services/workspace/__tests__/workspace-config.service.spec.ts +378 -0
- package/src/services/workspace/index.ts +14 -0
- package/src/services/workspace/workspace-config.service.ts +467 -0
- package/.github/workflows/bump-version.yml +0 -86
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.formatAuthTarget = formatAuthTarget;
|
|
4
|
+
exports.formatAuthLoginHint = formatAuthLoginHint;
|
|
5
|
+
exports.formatAuthRevisiumUrl = formatAuthRevisiumUrl;
|
|
6
|
+
function quoteArg(value) {
|
|
7
|
+
if (process.platform === 'win32') {
|
|
8
|
+
return `"${value.replaceAll('"', '""')}"`;
|
|
9
|
+
}
|
|
10
|
+
const escaped = value.replaceAll("'", String.raw `'\''`);
|
|
11
|
+
return `'${escaped}'`;
|
|
12
|
+
}
|
|
13
|
+
function formatAuthTarget(instanceName, baseUrl) {
|
|
14
|
+
return instanceName ? `instance "${instanceName}" (${baseUrl})` : baseUrl;
|
|
15
|
+
}
|
|
16
|
+
function formatAuthLoginHint(target) {
|
|
17
|
+
const targetSelector = target.instanceName
|
|
18
|
+
? `--instance ${quoteArg(target.instanceName)}`
|
|
19
|
+
: `--url ${quoteArg(formatAuthRevisiumUrl(target.baseUrl))}`;
|
|
20
|
+
return `${targetSelector} --credential ${quoteArg(target.credential)} --api-key`;
|
|
21
|
+
}
|
|
22
|
+
function formatAuthRevisiumUrl(baseUrl) {
|
|
23
|
+
if (baseUrl.startsWith('http://')) {
|
|
24
|
+
return `revisium+http://${baseUrl.slice('http://'.length)}`;
|
|
25
|
+
}
|
|
26
|
+
return `revisium://${baseUrl.replace(/^https:\/\//, '')}`;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=auth-command.utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-command.utils.js","sourceRoot":"","sources":["../../../../src/commands/auth/auth-command.utils.ts"],"names":[],"mappings":";;AAcA,4CAKC;AAED,kDAMC;AAED,sDAMC;AA7BD,SAAS,QAAQ,CAAC,KAAa;IAC7B,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE,CAAC;QACjC,OAAO,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC;IAC5C,CAAC;IACD,MAAM,OAAO,GAAG,KAAK,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,CAAA,MAAM,CAAC,CAAC;IACxD,OAAO,IAAI,OAAO,GAAG,CAAC;AACxB,CAAC;AAED,SAAgB,gBAAgB,CAC9B,YAAgC,EAChC,OAAe;IAEf,OAAO,YAAY,CAAC,CAAC,CAAC,aAAa,YAAY,MAAM,OAAO,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC;AAC5E,CAAC;AAED,SAAgB,mBAAmB,CAAC,MAAyB;IAC3D,MAAM,cAAc,GAAG,MAAM,CAAC,YAAY;QACxC,CAAC,CAAC,cAAc,QAAQ,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE;QAC/C,CAAC,CAAC,SAAS,QAAQ,CAAC,qBAAqB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;IAE/D,OAAO,GAAG,cAAc,iBAAiB,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC;AACnF,CAAC;AAED,SAAgB,qBAAqB,CAAC,OAAe;IACnD,IAAI,OAAO,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QAClC,OAAO,mBAAmB,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC;IAC9D,CAAC;IAED,OAAO,cAAc,OAAO,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,EAAE,CAAC;AAC5D,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { CommandRunner } from 'nest-commander';
|
|
2
|
+
import { CredentialStoreService, CredentialTargetService } from 'src/services/credentials';
|
|
3
|
+
import { InteractiveService, LoggerService } from 'src/services/common';
|
|
4
|
+
interface Options {
|
|
5
|
+
url?: string;
|
|
6
|
+
instance?: string;
|
|
7
|
+
credential?: string;
|
|
8
|
+
apiKey?: boolean;
|
|
9
|
+
apiKeyStdin?: boolean;
|
|
10
|
+
force?: boolean;
|
|
11
|
+
}
|
|
12
|
+
export declare class AuthLoginCommand extends CommandRunner {
|
|
13
|
+
private readonly credentialTargets;
|
|
14
|
+
private readonly credentialStore;
|
|
15
|
+
private readonly interactive;
|
|
16
|
+
private readonly logger;
|
|
17
|
+
constructor(credentialTargets: CredentialTargetService, credentialStore: CredentialStoreService, interactive: InteractiveService, logger: LoggerService);
|
|
18
|
+
run(_inputs: string[], options: Options): Promise<void>;
|
|
19
|
+
private promptForApiKey;
|
|
20
|
+
private readApiKeyFromStdin;
|
|
21
|
+
private validateApiKey;
|
|
22
|
+
parseUrl(value: string): string;
|
|
23
|
+
parseInstance(value: string): string;
|
|
24
|
+
parseCredential(value: string): string;
|
|
25
|
+
parseApiKey(): boolean;
|
|
26
|
+
parseApiKeyStdin(): boolean;
|
|
27
|
+
parseForce(value?: string): boolean;
|
|
28
|
+
}
|
|
29
|
+
export {};
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.AuthLoginCommand = void 0;
|
|
13
|
+
const nest_commander_1 = require("nest-commander");
|
|
14
|
+
const credentials_1 = require("../../services/credentials");
|
|
15
|
+
const common_1 = require("../../services/common");
|
|
16
|
+
const parse_boolean_utils_1 = require("../../utils/parse-boolean.utils");
|
|
17
|
+
const auth_command_utils_1 = require("./auth-command.utils");
|
|
18
|
+
let AuthLoginCommand = class AuthLoginCommand extends nest_commander_1.CommandRunner {
|
|
19
|
+
credentialTargets;
|
|
20
|
+
credentialStore;
|
|
21
|
+
interactive;
|
|
22
|
+
logger;
|
|
23
|
+
constructor(credentialTargets, credentialStore, interactive, logger) {
|
|
24
|
+
super();
|
|
25
|
+
this.credentialTargets = credentialTargets;
|
|
26
|
+
this.credentialStore = credentialStore;
|
|
27
|
+
this.interactive = interactive;
|
|
28
|
+
this.logger = logger;
|
|
29
|
+
}
|
|
30
|
+
async run(_inputs, options) {
|
|
31
|
+
if (options.apiKey && options.apiKeyStdin) {
|
|
32
|
+
throw new Error('Use only one credential input: --api-key or --api-key-stdin');
|
|
33
|
+
}
|
|
34
|
+
if (!options.apiKey && !options.apiKeyStdin) {
|
|
35
|
+
throw new Error('Pass --api-key to prompt, or --api-key-stdin for scripts');
|
|
36
|
+
}
|
|
37
|
+
const target = await this.credentialTargets.resolveRequired(options);
|
|
38
|
+
if (target.authMode === 'none' && !options.force) {
|
|
39
|
+
throw new Error(`Instance "${target.instanceName || target.baseUrl}" uses authMode "none". Pass --force to save credentials anyway.`);
|
|
40
|
+
}
|
|
41
|
+
const apiKey = options.apiKeyStdin
|
|
42
|
+
? await this.readApiKeyFromStdin()
|
|
43
|
+
: await this.promptForApiKey();
|
|
44
|
+
this.credentialStore.saveApiKey({
|
|
45
|
+
baseUrl: target.baseUrl,
|
|
46
|
+
credential: target.credential,
|
|
47
|
+
}, apiKey);
|
|
48
|
+
this.logger.success(`Saved API key credential "${target.credential}" for ${(0, auth_command_utils_1.formatAuthTarget)(target.instanceName, target.baseUrl)}`);
|
|
49
|
+
}
|
|
50
|
+
async promptForApiKey() {
|
|
51
|
+
const apiKey = await this.interactive.promptPassword('Enter Revisium API key:');
|
|
52
|
+
return this.validateApiKey(apiKey);
|
|
53
|
+
}
|
|
54
|
+
async readApiKeyFromStdin() {
|
|
55
|
+
const chunks = [];
|
|
56
|
+
for await (const chunk of process.stdin) {
|
|
57
|
+
chunks.push(Buffer.isBuffer(chunk) ? chunk : Buffer.from(String(chunk)));
|
|
58
|
+
if (Buffer.concat(chunks).includes(10)) {
|
|
59
|
+
break;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return this.validateApiKey(Buffer.concat(chunks).toString('utf-8').split(/\r?\n/, 1)[0]);
|
|
63
|
+
}
|
|
64
|
+
validateApiKey(value) {
|
|
65
|
+
const apiKey = value?.trim();
|
|
66
|
+
if (!apiKey) {
|
|
67
|
+
throw new Error('API key cannot be empty');
|
|
68
|
+
}
|
|
69
|
+
return apiKey;
|
|
70
|
+
}
|
|
71
|
+
parseUrl(value) {
|
|
72
|
+
return value;
|
|
73
|
+
}
|
|
74
|
+
parseInstance(value) {
|
|
75
|
+
return value;
|
|
76
|
+
}
|
|
77
|
+
parseCredential(value) {
|
|
78
|
+
return value;
|
|
79
|
+
}
|
|
80
|
+
parseApiKey() {
|
|
81
|
+
return true;
|
|
82
|
+
}
|
|
83
|
+
parseApiKeyStdin() {
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
parseForce(value) {
|
|
87
|
+
return (0, parse_boolean_utils_1.parseBooleanOption)(value);
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
exports.AuthLoginCommand = AuthLoginCommand;
|
|
91
|
+
__decorate([
|
|
92
|
+
(0, nest_commander_1.Option)({
|
|
93
|
+
flags: '--url <url>',
|
|
94
|
+
description: 'Revisium server or target URL',
|
|
95
|
+
}),
|
|
96
|
+
__metadata("design:type", Function),
|
|
97
|
+
__metadata("design:paramtypes", [String]),
|
|
98
|
+
__metadata("design:returntype", void 0)
|
|
99
|
+
], AuthLoginCommand.prototype, "parseUrl", null);
|
|
100
|
+
__decorate([
|
|
101
|
+
(0, nest_commander_1.Option)({
|
|
102
|
+
flags: '--instance <name>',
|
|
103
|
+
description: 'Instance name from workspace config',
|
|
104
|
+
}),
|
|
105
|
+
__metadata("design:type", Function),
|
|
106
|
+
__metadata("design:paramtypes", [String]),
|
|
107
|
+
__metadata("design:returntype", void 0)
|
|
108
|
+
], AuthLoginCommand.prototype, "parseInstance", null);
|
|
109
|
+
__decorate([
|
|
110
|
+
(0, nest_commander_1.Option)({
|
|
111
|
+
flags: '--credential <name>',
|
|
112
|
+
description: 'Credential name (default: default)',
|
|
113
|
+
}),
|
|
114
|
+
__metadata("design:type", Function),
|
|
115
|
+
__metadata("design:paramtypes", [String]),
|
|
116
|
+
__metadata("design:returntype", void 0)
|
|
117
|
+
], AuthLoginCommand.prototype, "parseCredential", null);
|
|
118
|
+
__decorate([
|
|
119
|
+
(0, nest_commander_1.Option)({
|
|
120
|
+
flags: '--api-key',
|
|
121
|
+
description: 'Prompt for an API key and save it',
|
|
122
|
+
}),
|
|
123
|
+
__metadata("design:type", Function),
|
|
124
|
+
__metadata("design:paramtypes", []),
|
|
125
|
+
__metadata("design:returntype", Boolean)
|
|
126
|
+
], AuthLoginCommand.prototype, "parseApiKey", null);
|
|
127
|
+
__decorate([
|
|
128
|
+
(0, nest_commander_1.Option)({
|
|
129
|
+
flags: '--api-key-stdin',
|
|
130
|
+
description: 'Read one API key line from stdin and save it',
|
|
131
|
+
}),
|
|
132
|
+
__metadata("design:type", Function),
|
|
133
|
+
__metadata("design:paramtypes", []),
|
|
134
|
+
__metadata("design:returntype", Boolean)
|
|
135
|
+
], AuthLoginCommand.prototype, "parseApiKeyStdin", null);
|
|
136
|
+
__decorate([
|
|
137
|
+
(0, nest_commander_1.Option)({
|
|
138
|
+
flags: '--force [boolean]',
|
|
139
|
+
description: 'Allow saving credentials for an authMode none instance',
|
|
140
|
+
}),
|
|
141
|
+
__metadata("design:type", Function),
|
|
142
|
+
__metadata("design:paramtypes", [String]),
|
|
143
|
+
__metadata("design:returntype", Boolean)
|
|
144
|
+
], AuthLoginCommand.prototype, "parseForce", null);
|
|
145
|
+
exports.AuthLoginCommand = AuthLoginCommand = __decorate([
|
|
146
|
+
(0, nest_commander_1.SubCommand)({
|
|
147
|
+
name: 'login',
|
|
148
|
+
description: 'Save an API key in the OS credential store',
|
|
149
|
+
}),
|
|
150
|
+
__metadata("design:paramtypes", [credentials_1.CredentialTargetService,
|
|
151
|
+
credentials_1.CredentialStoreService,
|
|
152
|
+
common_1.InteractiveService,
|
|
153
|
+
common_1.LoggerService])
|
|
154
|
+
], AuthLoginCommand);
|
|
155
|
+
//# sourceMappingURL=auth-login.command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-login.command.js","sourceRoot":"","sources":["../../../../src/commands/auth/auth-login.command.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { CommandRunner } from 'nest-commander';
|
|
2
|
+
import { CredentialStoreService, CredentialTargetService } from 'src/services/credentials';
|
|
3
|
+
import { LoggerService } from 'src/services/common';
|
|
4
|
+
interface Options {
|
|
5
|
+
url?: string;
|
|
6
|
+
instance?: string;
|
|
7
|
+
credential?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare class AuthLogoutCommand extends CommandRunner {
|
|
10
|
+
private readonly credentialTargets;
|
|
11
|
+
private readonly credentialStore;
|
|
12
|
+
private readonly logger;
|
|
13
|
+
constructor(credentialTargets: CredentialTargetService, credentialStore: CredentialStoreService, logger: LoggerService);
|
|
14
|
+
run(_inputs: string[], options: Options): Promise<void>;
|
|
15
|
+
parseUrl(value: string): string;
|
|
16
|
+
parseInstance(value: string): string;
|
|
17
|
+
parseCredential(value: string): string;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.AuthLogoutCommand = void 0;
|
|
13
|
+
const nest_commander_1 = require("nest-commander");
|
|
14
|
+
const credentials_1 = require("../../services/credentials");
|
|
15
|
+
const common_1 = require("../../services/common");
|
|
16
|
+
const auth_command_utils_1 = require("./auth-command.utils");
|
|
17
|
+
let AuthLogoutCommand = class AuthLogoutCommand extends nest_commander_1.CommandRunner {
|
|
18
|
+
credentialTargets;
|
|
19
|
+
credentialStore;
|
|
20
|
+
logger;
|
|
21
|
+
constructor(credentialTargets, credentialStore, logger) {
|
|
22
|
+
super();
|
|
23
|
+
this.credentialTargets = credentialTargets;
|
|
24
|
+
this.credentialStore = credentialStore;
|
|
25
|
+
this.logger = logger;
|
|
26
|
+
}
|
|
27
|
+
async run(_inputs, options) {
|
|
28
|
+
const target = await this.credentialTargets.resolveOrCurrentContext(options);
|
|
29
|
+
const deleted = this.credentialStore.deleteCredential({
|
|
30
|
+
baseUrl: target.baseUrl,
|
|
31
|
+
credential: target.credential,
|
|
32
|
+
});
|
|
33
|
+
if (deleted) {
|
|
34
|
+
this.logger.success(`Deleted saved credential "${target.credential}" for ${(0, auth_command_utils_1.formatAuthTarget)(target.instanceName, target.baseUrl)}`);
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
this.logger.warn(`No saved credential "${target.credential}" found for ${(0, auth_command_utils_1.formatAuthTarget)(target.instanceName, target.baseUrl)}`);
|
|
38
|
+
}
|
|
39
|
+
parseUrl(value) {
|
|
40
|
+
return value;
|
|
41
|
+
}
|
|
42
|
+
parseInstance(value) {
|
|
43
|
+
return value;
|
|
44
|
+
}
|
|
45
|
+
parseCredential(value) {
|
|
46
|
+
return value;
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
exports.AuthLogoutCommand = AuthLogoutCommand;
|
|
50
|
+
__decorate([
|
|
51
|
+
(0, nest_commander_1.Option)({
|
|
52
|
+
flags: '--url <url>',
|
|
53
|
+
description: 'Revisium server or target URL',
|
|
54
|
+
}),
|
|
55
|
+
__metadata("design:type", Function),
|
|
56
|
+
__metadata("design:paramtypes", [String]),
|
|
57
|
+
__metadata("design:returntype", void 0)
|
|
58
|
+
], AuthLogoutCommand.prototype, "parseUrl", null);
|
|
59
|
+
__decorate([
|
|
60
|
+
(0, nest_commander_1.Option)({
|
|
61
|
+
flags: '--instance <name>',
|
|
62
|
+
description: 'Instance name from workspace config',
|
|
63
|
+
}),
|
|
64
|
+
__metadata("design:type", Function),
|
|
65
|
+
__metadata("design:paramtypes", [String]),
|
|
66
|
+
__metadata("design:returntype", void 0)
|
|
67
|
+
], AuthLogoutCommand.prototype, "parseInstance", null);
|
|
68
|
+
__decorate([
|
|
69
|
+
(0, nest_commander_1.Option)({
|
|
70
|
+
flags: '--credential <name>',
|
|
71
|
+
description: 'Credential name',
|
|
72
|
+
}),
|
|
73
|
+
__metadata("design:type", Function),
|
|
74
|
+
__metadata("design:paramtypes", [String]),
|
|
75
|
+
__metadata("design:returntype", void 0)
|
|
76
|
+
], AuthLogoutCommand.prototype, "parseCredential", null);
|
|
77
|
+
exports.AuthLogoutCommand = AuthLogoutCommand = __decorate([
|
|
78
|
+
(0, nest_commander_1.SubCommand)({
|
|
79
|
+
name: 'logout',
|
|
80
|
+
description: 'Delete a saved Revisium credential',
|
|
81
|
+
}),
|
|
82
|
+
__metadata("design:paramtypes", [credentials_1.CredentialTargetService,
|
|
83
|
+
credentials_1.CredentialStoreService,
|
|
84
|
+
common_1.LoggerService])
|
|
85
|
+
], AuthLogoutCommand);
|
|
86
|
+
//# sourceMappingURL=auth-logout.command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-logout.command.js","sourceRoot":"","sources":["../../../../src/commands/auth/auth-logout.command.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,mDAAmE;AACnE,4DAGkC;AAClC,kDAAoD;AACpD,6DAAwD;AAYjD,IAAM,iBAAiB,GAAvB,MAAM,iBAAkB,SAAQ,8BAAa;IAE/B;IACA;IACA;IAHnB,YACmB,iBAA0C,EAC1C,eAAuC,EACvC,MAAqB;QAEtC,KAAK,EAAE,CAAC;QAJS,sBAAiB,GAAjB,iBAAiB,CAAyB;QAC1C,oBAAe,GAAf,eAAe,CAAwB;QACvC,WAAM,GAAN,MAAM,CAAe;IAGxC,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,OAAiB,EAAE,OAAgB;QAC3C,MAAM,MAAM,GACV,MAAM,IAAI,CAAC,iBAAiB,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;QAChE,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC;YACpD,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,UAAU,EAAE,MAAM,CAAC,UAAU;SAC9B,CAAC,CAAC;QAEH,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,MAAM,CAAC,OAAO,CACjB,6BAA6B,MAAM,CAAC,UAAU,SAAS,IAAA,qCAAgB,EAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,OAAO,CAAC,EAAE,CAC/G,CAAC;YACF,OAAO;QACT,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,wBAAwB,MAAM,CAAC,UAAU,eAAe,IAAA,qCAAgB,EAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,OAAO,CAAC,EAAE,CAChH,CAAC;IACJ,CAAC;IAMD,QAAQ,CAAC,KAAa;QACpB,OAAO,KAAK,CAAC;IACf,CAAC;IAMD,aAAa,CAAC,KAAa;QACzB,OAAO,KAAK,CAAC;IACf,CAAC;IAMD,eAAe,CAAC,KAAa;QAC3B,OAAO,KAAK,CAAC;IACf,CAAC;CACF,CAAA;AApDY,8CAAiB;AAiC5B;IAJC,IAAA,uBAAM,EAAC;QACN,KAAK,EAAE,aAAa;QACpB,WAAW,EAAE,+BAA+B;KAC7C,CAAC;;;;iDAGD;AAMD;IAJC,IAAA,uBAAM,EAAC;QACN,KAAK,EAAE,mBAAmB;QAC1B,WAAW,EAAE,qCAAqC;KACnD,CAAC;;;;sDAGD;AAMD;IAJC,IAAA,uBAAM,EAAC;QACN,KAAK,EAAE,qBAAqB;QAC5B,WAAW,EAAE,iBAAiB;KAC/B,CAAC;;;;wDAGD;4BAnDU,iBAAiB;IAJ7B,IAAA,2BAAU,EAAC;QACV,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,oCAAoC;KAClD,CAAC;qCAGsC,qCAAuB;QACzB,oCAAsB;QAC/B,sBAAa;GAJ7B,iBAAiB,CAoD7B"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { CommandRunner } from 'nest-commander';
|
|
2
|
+
import { CredentialStoreService, CredentialTargetService } from 'src/services/credentials';
|
|
3
|
+
import { LoggerService } from 'src/services/common';
|
|
4
|
+
interface Options {
|
|
5
|
+
url?: string;
|
|
6
|
+
instance?: string;
|
|
7
|
+
credential?: string;
|
|
8
|
+
}
|
|
9
|
+
export declare class AuthStatusCommand extends CommandRunner {
|
|
10
|
+
private readonly credentialTargets;
|
|
11
|
+
private readonly credentialStore;
|
|
12
|
+
private readonly logger;
|
|
13
|
+
constructor(credentialTargets: CredentialTargetService, credentialStore: CredentialStoreService, logger: LoggerService);
|
|
14
|
+
run(_inputs: string[], options: Options): Promise<void>;
|
|
15
|
+
parseUrl(value: string): string;
|
|
16
|
+
parseInstance(value: string): string;
|
|
17
|
+
parseCredential(value: string): string;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.AuthStatusCommand = void 0;
|
|
13
|
+
const nest_commander_1 = require("nest-commander");
|
|
14
|
+
const credentials_1 = require("../../services/credentials");
|
|
15
|
+
const common_1 = require("../../services/common");
|
|
16
|
+
const auth_command_utils_1 = require("./auth-command.utils");
|
|
17
|
+
let AuthStatusCommand = class AuthStatusCommand extends nest_commander_1.CommandRunner {
|
|
18
|
+
credentialTargets;
|
|
19
|
+
credentialStore;
|
|
20
|
+
logger;
|
|
21
|
+
constructor(credentialTargets, credentialStore, logger) {
|
|
22
|
+
super();
|
|
23
|
+
this.credentialTargets = credentialTargets;
|
|
24
|
+
this.credentialStore = credentialStore;
|
|
25
|
+
this.logger = logger;
|
|
26
|
+
}
|
|
27
|
+
async run(_inputs, options) {
|
|
28
|
+
const target = await this.credentialTargets.resolveOrCurrentContext(options);
|
|
29
|
+
const ref = {
|
|
30
|
+
baseUrl: target.baseUrl,
|
|
31
|
+
credential: target.credential,
|
|
32
|
+
};
|
|
33
|
+
if (target.contextName) {
|
|
34
|
+
this.logger.info(`Context: ${target.contextName}`);
|
|
35
|
+
}
|
|
36
|
+
if (target.instanceName) {
|
|
37
|
+
this.logger.info(`Instance: ${target.instanceName}`);
|
|
38
|
+
}
|
|
39
|
+
this.logger.info(`Base URL: ${target.baseUrl}`);
|
|
40
|
+
this.logger.info(`Credential: ${target.credential}`);
|
|
41
|
+
this.logger.info(`Auth mode: ${target.authMode || 'stored'}`);
|
|
42
|
+
if ((target.authMode || 'stored') === 'none') {
|
|
43
|
+
this.logger.info('Saved credentials are bypassed for authMode "none".');
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const hasCredential = this.credentialStore.hasCredential(ref);
|
|
47
|
+
if (hasCredential) {
|
|
48
|
+
this.logger.success('Saved credential found');
|
|
49
|
+
this.logger.info('API key identity verification is limited until auth principal introspection is available.');
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
this.logger.warn(`No saved credential found. Run: revisium auth login ${(0, auth_command_utils_1.formatAuthLoginHint)(target)}`);
|
|
53
|
+
}
|
|
54
|
+
parseUrl(value) {
|
|
55
|
+
return value;
|
|
56
|
+
}
|
|
57
|
+
parseInstance(value) {
|
|
58
|
+
return value;
|
|
59
|
+
}
|
|
60
|
+
parseCredential(value) {
|
|
61
|
+
return value;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
exports.AuthStatusCommand = AuthStatusCommand;
|
|
65
|
+
__decorate([
|
|
66
|
+
(0, nest_commander_1.Option)({
|
|
67
|
+
flags: '--url <url>',
|
|
68
|
+
description: 'Revisium server or target URL',
|
|
69
|
+
}),
|
|
70
|
+
__metadata("design:type", Function),
|
|
71
|
+
__metadata("design:paramtypes", [String]),
|
|
72
|
+
__metadata("design:returntype", void 0)
|
|
73
|
+
], AuthStatusCommand.prototype, "parseUrl", null);
|
|
74
|
+
__decorate([
|
|
75
|
+
(0, nest_commander_1.Option)({
|
|
76
|
+
flags: '--instance <name>',
|
|
77
|
+
description: 'Instance name from workspace config',
|
|
78
|
+
}),
|
|
79
|
+
__metadata("design:type", Function),
|
|
80
|
+
__metadata("design:paramtypes", [String]),
|
|
81
|
+
__metadata("design:returntype", void 0)
|
|
82
|
+
], AuthStatusCommand.prototype, "parseInstance", null);
|
|
83
|
+
__decorate([
|
|
84
|
+
(0, nest_commander_1.Option)({
|
|
85
|
+
flags: '--credential <name>',
|
|
86
|
+
description: 'Credential name',
|
|
87
|
+
}),
|
|
88
|
+
__metadata("design:type", Function),
|
|
89
|
+
__metadata("design:paramtypes", [String]),
|
|
90
|
+
__metadata("design:returntype", void 0)
|
|
91
|
+
], AuthStatusCommand.prototype, "parseCredential", null);
|
|
92
|
+
exports.AuthStatusCommand = AuthStatusCommand = __decorate([
|
|
93
|
+
(0, nest_commander_1.SubCommand)({
|
|
94
|
+
name: 'status',
|
|
95
|
+
description: 'Show saved Revisium credential status',
|
|
96
|
+
}),
|
|
97
|
+
__metadata("design:paramtypes", [credentials_1.CredentialTargetService,
|
|
98
|
+
credentials_1.CredentialStoreService,
|
|
99
|
+
common_1.LoggerService])
|
|
100
|
+
], AuthStatusCommand);
|
|
101
|
+
//# sourceMappingURL=auth-status.command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-status.command.js","sourceRoot":"","sources":["../../../../src/commands/auth/auth-status.command.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.AuthCommand = void 0;
|
|
13
|
+
const nest_commander_1 = require("nest-commander");
|
|
14
|
+
const auth_login_command_1 = require("./auth-login.command");
|
|
15
|
+
const auth_logout_command_1 = require("./auth-logout.command");
|
|
16
|
+
const auth_status_command_1 = require("./auth-status.command");
|
|
17
|
+
let AuthCommand = class AuthCommand extends nest_commander_1.CommandRunner {
|
|
18
|
+
constructor() {
|
|
19
|
+
super();
|
|
20
|
+
}
|
|
21
|
+
run() {
|
|
22
|
+
this.command.help();
|
|
23
|
+
return Promise.resolve();
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
exports.AuthCommand = AuthCommand;
|
|
27
|
+
exports.AuthCommand = AuthCommand = __decorate([
|
|
28
|
+
(0, nest_commander_1.Command)({
|
|
29
|
+
name: 'auth',
|
|
30
|
+
description: 'Manage saved Revisium credentials',
|
|
31
|
+
subCommands: [auth_login_command_1.AuthLoginCommand, auth_status_command_1.AuthStatusCommand, auth_logout_command_1.AuthLogoutCommand],
|
|
32
|
+
}),
|
|
33
|
+
__metadata("design:paramtypes", [])
|
|
34
|
+
], AuthCommand);
|
|
35
|
+
//# sourceMappingURL=auth.command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.command.js","sourceRoot":"","sources":["../../../../src/commands/auth/auth.command.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,mDAAwD;AACxD,6DAAwD;AACxD,+DAA0D;AAC1D,+DAA0D;AAOnD,IAAM,WAAW,GAAjB,MAAM,WAAY,SAAQ,8BAAa;IAC5C;QACE,KAAK,EAAE,CAAC;IACV,CAAC;IAED,GAAG;QACD,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QACpB,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;CACF,CAAA;AATY,kCAAW;sBAAX,WAAW;IALvB,IAAA,wBAAO,EAAC;QACP,IAAI,EAAE,MAAM;QACZ,WAAW,EAAE,mCAAmC;QAChD,WAAW,EAAE,CAAC,qCAAgB,EAAE,uCAAiB,EAAE,uCAAiB,CAAC;KACtE,CAAC;;GACW,WAAW,CASvB"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
+
import { CommandRunner } from 'nest-commander';
|
|
1
2
|
import { ConfigService } from '@nestjs/config';
|
|
2
|
-
import { BaseCommand } from 'src/commands/base.command';
|
|
3
3
|
import { SyncApiService, CommitRevisionService } from 'src/services/sync';
|
|
4
4
|
import { RevisiumUrlComplete, UrlBuilderService } from 'src/services/url';
|
|
5
5
|
export interface BaseSyncOptions {
|
|
@@ -12,7 +12,7 @@ export interface DataSyncOptions extends BaseSyncOptions {
|
|
|
12
12
|
tables?: string;
|
|
13
13
|
batchSize?: number;
|
|
14
14
|
}
|
|
15
|
-
export declare abstract class BaseSyncCommand extends
|
|
15
|
+
export declare abstract class BaseSyncCommand extends CommandRunner {
|
|
16
16
|
protected readonly configService: ConfigService;
|
|
17
17
|
protected readonly urlBuilder: UrlBuilderService;
|
|
18
18
|
protected readonly syncApi: SyncApiService;
|
|
@@ -11,9 +11,8 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.BaseSyncCommand = void 0;
|
|
13
13
|
const nest_commander_1 = require("nest-commander");
|
|
14
|
-
const base_command_1 = require("./base.command");
|
|
15
14
|
const parse_boolean_utils_1 = require("../utils/parse-boolean.utils");
|
|
16
|
-
class BaseSyncCommand extends
|
|
15
|
+
class BaseSyncCommand extends nest_commander_1.CommandRunner {
|
|
17
16
|
configService;
|
|
18
17
|
urlBuilder;
|
|
19
18
|
syncApi;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-sync.command.js","sourceRoot":"","sources":["../../../src/commands/base-sync.command.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"base-sync.command.js","sourceRoot":"","sources":["../../../src/commands/base-sync.command.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { CommandRunner } from 'nest-commander';
|
|
2
2
|
export type BaseOptions = {
|
|
3
3
|
url?: string;
|
|
4
|
+
context?: string;
|
|
4
5
|
};
|
|
5
6
|
export declare abstract class BaseCommand extends CommandRunner {
|
|
6
7
|
parseUrl(value: string): string;
|
|
8
|
+
parseContext(value: string): string;
|
|
7
9
|
}
|
|
@@ -15,6 +15,9 @@ class BaseCommand extends nest_commander_1.CommandRunner {
|
|
|
15
15
|
parseUrl(value) {
|
|
16
16
|
return value;
|
|
17
17
|
}
|
|
18
|
+
parseContext(value) {
|
|
19
|
+
return value;
|
|
20
|
+
}
|
|
18
21
|
}
|
|
19
22
|
exports.BaseCommand = BaseCommand;
|
|
20
23
|
__decorate([
|
|
@@ -27,4 +30,14 @@ __decorate([
|
|
|
27
30
|
__metadata("design:paramtypes", [String]),
|
|
28
31
|
__metadata("design:returntype", void 0)
|
|
29
32
|
], BaseCommand.prototype, "parseUrl", null);
|
|
33
|
+
__decorate([
|
|
34
|
+
(0, nest_commander_1.Option)({
|
|
35
|
+
flags: '--context <name>',
|
|
36
|
+
description: 'Named workspace context from .revisium/revisium-cli.config.json (single-target commands)',
|
|
37
|
+
required: false,
|
|
38
|
+
}),
|
|
39
|
+
__metadata("design:type", Function),
|
|
40
|
+
__metadata("design:paramtypes", [String]),
|
|
41
|
+
__metadata("design:returntype", void 0)
|
|
42
|
+
], BaseCommand.prototype, "parseContext", null);
|
|
30
43
|
//# sourceMappingURL=base.command.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base.command.js","sourceRoot":"","sources":["../../../src/commands/base.command.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,mDAAuD;
|
|
1
|
+
{"version":3,"file":"base.command.js","sourceRoot":"","sources":["../../../src/commands/base.command.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,mDAAuD;AAOvD,MAAsB,WAAY,SAAQ,8BAAa;IAO9C,QAAQ,CAAC,KAAa;QAC3B,OAAO,KAAK,CAAC;IACf,CAAC;IAQM,YAAY,CAAC,KAAa;QAC/B,OAAO,KAAK,CAAC;IACf,CAAC;CACF;AApBD,kCAoBC;AAbQ;IANN,IAAA,uBAAM,EAAC;QACN,KAAK,EAAE,aAAa;QACpB,WAAW,EACT,2JAA2J;QAC7J,QAAQ,EAAE,KAAK;KAChB,CAAC;;;;2CAGD;AAQM;IANN,IAAA,uBAAM,EAAC;QACN,KAAK,EAAE,kBAAkB;QACzB,WAAW,EACT,0FAA0F;QAC5F,QAAQ,EAAE,KAAK;KAChB,CAAC;;;;+CAGD"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { CommandRunner } from 'nest-commander';
|
|
2
|
+
import { LoggerService } from 'src/services/common';
|
|
3
|
+
import { WorkspaceConfigService } from 'src/services/workspace';
|
|
4
|
+
interface Options {
|
|
5
|
+
url?: string;
|
|
6
|
+
instance?: string;
|
|
7
|
+
credential?: string;
|
|
8
|
+
org?: string;
|
|
9
|
+
project?: string;
|
|
10
|
+
branch?: string;
|
|
11
|
+
revision?: string;
|
|
12
|
+
}
|
|
13
|
+
export declare class ContextCreateCommand extends CommandRunner {
|
|
14
|
+
private readonly workspaceConfig;
|
|
15
|
+
private readonly logger;
|
|
16
|
+
constructor(workspaceConfig: WorkspaceConfigService, logger: LoggerService);
|
|
17
|
+
run(inputs: string[], options: Options): Promise<void>;
|
|
18
|
+
private buildContext;
|
|
19
|
+
private withCredential;
|
|
20
|
+
parseUrl(value: string): string;
|
|
21
|
+
parseInstance(value: string): string;
|
|
22
|
+
parseCredential(value: string): string;
|
|
23
|
+
parseOrg(value: string): string;
|
|
24
|
+
parseProject(value: string): string;
|
|
25
|
+
parseBranch(value: string): string;
|
|
26
|
+
parseRevision(value: string): string;
|
|
27
|
+
}
|
|
28
|
+
export {};
|