2022-01-20 21:03:37 +01:00
|
|
|
import * as inquirer from "inquirer";
|
|
|
|
|
[AC-1011] Admin Console / Billing code ownership (#4973)
* refactor: move SCIM component to admin-console, refs EC-1011
* refactor: move scimProviderType to admin-console, refs EC-1011
* refactor: move scim-config.api to admin-console, refs EC-1011
* refactor: create models folder and nest existing api contents, refs EC-1011
* refactor: move scim-config to admin-console models, refs EC-1011
* refactor: move billing.component to billing, refs EC-1011
* refactor: remove nested app folder from new billing structure, refs EC-1011
* refactor: move organizations/billing to billing, refs EC-1011
* refactor: move add-credit and adjust-payment to billing/settings, refs EC-1011
* refactor: billing history/sync to billing, refs EC-1011
* refactor: move org plans, payment/method to billing/settings, refs EC-1011
* fix: update legacy file paths for payment-method and tax-info, refs EC-1011
* fix: update imports for scim component, refs EC-1011
* refactor: move subscription and tax-info into billing, refs EC-1011
* refactor: move user-subscription to billing, refs EC-1011
* refactor: move images/cards to billing and update base path, refs EC-1011
* refactor: move payment-method, plan subscription, and plan to billing, refs EC-1011
* refactor: move transaction-type to billing, refs EC-1011
* refactor: move billing-sync-config to billing, refs EC-1011
* refactor: move billing-sync and bit-pay-invoice request to billing, refs EC-1011
* refactor: move org subscription and tax info update requests to billing, refs EC-1011
* fix: broken paths to billing, refs EC-1011
* refactor: move payment request to billing, refs EC-1011
* fix: update remaining imports for payment-request, refs EC-1011
* refactor: move tax-info-update to billing, refs EC-1011
* refactor: move billing-payment, billing-history, and billing responses to billing, refs EC-1011
* refactor: move organization-subscription-responset to billing, refs EC-1011
* refactor: move payment and plan responses to billing, refs EC-1011
* refactor: move subscription response to billing ,refs EC-1011
* refactor: move tax info and rate responses to billing, refs EC-1011
* fix: update remaining path to base response for tax-rate response, refs EC-1011
* refactor: (browser) move organization-service to admin-console, refs EC-1011
* refactor: (browser) move organizaiton-service to admin-console, refs EC-1011
* refactor: (cli) move share command to admin-console, refs EC-1011
* refactor: move organization-collect request model to admin-console, refs EC-1011
* refactor: (web) move organization, collection/user responses to admin-console, refs EC-1011
* refactor: (cli) move selection-read-only to admin-console, refs EC-1011
* refactor: (desktop) move organization-filter to admin-console, refs EC-1011
* refactor: (web) move organization-switcher to admin-console, refs EC-1011
* refactor: (web) move access-selector to admin-console, refs EC-1011
* refactor: (web) move create folder to admin-console, refs EC-1011
* refactor: (web) move org guards folder to admin-console, refs EC-1011
* refactor: (web) move org layout to admin-console, refs EC-1011
* refactor: move manage collections to admin console, refs EC-1011
* refactor: (web) move collection-dialog to admin-console, refs EC-1011
* refactor: (web) move entity users/events and events component to admin-console, refs EC-1011
* refactor: (web) move groups/group-add-edit to admin-console, refs EC-1011
* refactor: (web) move manage, org-manage module, and user-confirm to admin-console, refs EC-1011
* refactor: (web) move people to admin-console, refs EC-1011
* refactor: (web) move reset-password to admin-console, refs EC-1011
* refactor: (web) move organization-routing and module to admin-console, refs EC-1011
* refactor: move admin-console and billing within app scope, refs EC-1011
* fix: update leftover merge conflicts, refs EC-1011
* refactor: (web) member-dialog to admin-console, refs EC-1011
* refactor: (web) move policies to admin-console, refs EC-1011
* refactor: (web) move reporting to admin-console, refs EC-1011
* refactor: (web) move settings to admin-console, refs EC-1011
* refactor: (web) move sponsorships to admin-console, refs EC-1011
* refactor: (web) move tools to admin-console, refs EC-1011
* refactor: (web) move users to admin-console, refs EC-1011
* refactor: (web) move collections to admin-console, refs EC-1011
* refactor: (web) move create-organization to admin-console, refs EC-1011
* refactor: (web) move licensed components to admin-console, refs EC-1011
* refactor: (web) move bit organization modules to admin-console, refs EC-1011
* fix: update leftover import statements for organizations.module, refs EC-1011
* refactor: (web) move personal vault and max timeout to admin-console, refs EC-1011
* refactor: (web) move providers to admin-console, refs EC-1011
* refactor: (libs) move organization service to admin-console, refs EC-1011
* refactor: (libs) move profile org/provider responses and other misc org responses to admin-console, refs EC-1011
* refactor: (libs) move provider request and selectionion-read-only request to admin-console, refs EC-1011
* fix: update missed import path for provider-user-update request, refs EC-1011
* refactor: (libs) move abstractions to admin-console, refs EC-1011
* refactor: (libs) move org/provider enums to admin-console, refs EC-1011
* fix: update downstream import statements from libs changes, refs EC-1011
* refactor: (libs) move data files to admin-console, refs EC-1011
* refactor: (libs) move domain to admin-console, refs EC-1011
* refactor: (libs) move request objects to admin-console, refs EC-1011
* fix: update downstream import changes from libs, refs EC-1011
* refactor: move leftover provider files to admin-console, refs EC-1011
* refactor: (browser) move group policy environment to admin-console, refs EC-1011
* fix: (browser) update downstream import statements, refs EC-1011
* fix: (desktop) update downstream libs moves, refs EC-1011
* fix: (cli) update downstream import changes from libs, refs EC-1011
* refactor: move org-auth related files to admin-console, refs EC-1011
* refactor: (libs) move request objects to admin-console, refs EC-1011
* refactor: move persmissions to admin-console, refs EC-1011
* refactor: move sponsored families to admin-console and fix libs changes, refs EC-1011
* refactor: move collections to admin-console, refs EC-1011
* refactor: move spec file back to spec scope, refs EC-1011
* fix: update downstream imports due to libs changes, refs EC-1011
* fix: udpate downstream import changes due to libs, refs EC-1011
* fix: update downstream imports due to libs changes, refs EC-1011
* fix: update downstream imports from libs changes, refs EC-1011
* fix: update path malformation in jslib-services.module, refs EC-1011
* fix: lint errors from improper casing, refs AC-1011
* fix: update downstream filename changes, refs AC-1011
* fix: (cli) update downstream filename changes, refs AC-1011
* fix: (desktop) update downstream filename changes, refs AC-1011
* fix: (browser) update downstream filename changes, refs AC-1011
* fix: lint errors, refs AC-1011
* fix: prettier, refs AC-1011
* fix: lint fixes for import order, refs AC-1011
* fix: update import path for provider user type, refs AC-1011
* fix: update new codes import paths for admin console structure, refs AC-1011
* fix: lint/prettier, refs AC-1011
* fix: update layout stories path, refs AC-1011
* fix: update comoponents card icons base variable in styles, refs AC-1011
* fix: update provider service path in permissions guard spec, refs AC-1011
* fix: update provider permission guard path, refs AC-1011
* fix: remove unecessary TODO for shared index export statement, refs AC-1011
* refactor: move browser-organization service and cli organization-user response out of admin-console, refs AC-1011
* refactor: move web/browser/desktop collections component to vault domain, refs AC-1011
* refactor: move organization.module out of admin-console scope, refs AC-1011
* fix: prettier, refs AC-1011
* refactor: move organizations-api-key.request out of admin-console scope, refs AC-1011
2023-03-22 16:03:50 +01:00
|
|
|
import { OrganizationApiServiceAbstraction } from "@bitwarden/common/admin-console/abstractions/organization/organization-api.service.abstraction";
|
2023-02-06 22:53:37 +01:00
|
|
|
import { KeyConnectorService } from "@bitwarden/common/auth/abstractions/key-connector.service";
|
2023-06-06 22:34:53 +02:00
|
|
|
import { EnvironmentService } from "@bitwarden/common/platform/abstractions/environment.service";
|
2023-01-31 22:08:37 +01:00
|
|
|
import { SyncService } from "@bitwarden/common/vault/abstractions/sync/sync.service.abstraction";
|
2022-11-18 13:20:19 +01:00
|
|
|
|
|
|
|
import { Response } from "../models/response";
|
|
|
|
import { MessageResponse } from "../models/response/message.response";
|
2022-01-20 21:03:37 +01:00
|
|
|
|
|
|
|
export class ConvertToKeyConnectorCommand {
|
|
|
|
constructor(
|
|
|
|
private keyConnectorService: KeyConnectorService,
|
|
|
|
private environmentService: EnvironmentService,
|
|
|
|
private syncService: SyncService,
|
2022-08-24 18:33:05 +02:00
|
|
|
private organizationApiService: OrganizationApiServiceAbstraction,
|
2023-11-29 22:15:20 +01:00
|
|
|
private logout: () => Promise<void>,
|
2022-01-20 21:03:37 +01:00
|
|
|
) {}
|
|
|
|
|
|
|
|
async run(): Promise<Response> {
|
|
|
|
// If no interaction available, alert user to use web vault
|
|
|
|
const canInteract = process.env.BW_NOINTERACTION !== "true";
|
|
|
|
if (!canInteract) {
|
|
|
|
await this.logout();
|
|
|
|
return Response.error(
|
|
|
|
new MessageResponse(
|
|
|
|
"An organization you are a member of is using Key Connector. " +
|
|
|
|
"In order to access the vault, you must opt-in to Key Connector now via the web vault. You have been logged out.",
|
2023-11-29 22:15:20 +01:00
|
|
|
null,
|
|
|
|
),
|
2022-01-20 21:03:37 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const organization = await this.keyConnectorService.getManagingOrganization();
|
|
|
|
|
|
|
|
const answer: inquirer.Answers = await inquirer.createPromptModule({ output: process.stderr })({
|
|
|
|
type: "list",
|
|
|
|
name: "convert",
|
|
|
|
message:
|
|
|
|
organization.name +
|
|
|
|
" is using a self-hosted key server. A master password is no longer required to log in for members of this organization. ",
|
|
|
|
choices: [
|
|
|
|
{
|
|
|
|
name: "Remove master password and unlock",
|
|
|
|
value: "remove",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Leave organization and unlock",
|
|
|
|
value: "leave",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Log out",
|
|
|
|
value: "exit",
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
|
|
|
|
|
|
|
if (answer.convert === "remove") {
|
|
|
|
try {
|
|
|
|
await this.keyConnectorService.migrateUser();
|
|
|
|
} catch (e) {
|
|
|
|
await this.logout();
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
|
|
|
|
await this.keyConnectorService.removeConvertAccountRequired();
|
|
|
|
await this.keyConnectorService.setUsesKeyConnector(true);
|
|
|
|
|
|
|
|
// Update environment URL - required for api key login
|
|
|
|
const urls = this.environmentService.getUrls();
|
|
|
|
urls.keyConnector = organization.keyConnectorUrl;
|
2022-01-28 16:09:24 +01:00
|
|
|
await this.environmentService.setUrls(urls);
|
2022-01-20 21:03:37 +01:00
|
|
|
|
|
|
|
return Response.success();
|
|
|
|
} else if (answer.convert === "leave") {
|
2022-08-24 18:33:05 +02:00
|
|
|
await this.organizationApiService.leave(organization.id);
|
2022-01-20 21:03:37 +01:00
|
|
|
await this.keyConnectorService.removeConvertAccountRequired();
|
|
|
|
return Response.success();
|
|
|
|
} else {
|
|
|
|
await this.logout();
|
|
|
|
return Response.error("You have been logged out.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|