UNPKG

@canonical/jujulib

Version:
282 lines (241 loc) 7.22 kB
/** Juju MigrationTarget version 3. This facade is available on: Controllers NOTE: This file was generated using the Juju schema from Juju 3.3 at the git SHA 65fa4c1ee5. Do not manually edit this file. */ import type { JujuRequest } from "../../../generator/interfaces.js"; import { ConnectionInfo, Transport } from "../../client.js"; import { Facade } from "../../types.js"; import { autoBind } from "../../utils.js"; export interface ActivateModelArgs { "controller-alias"?: string; "controller-tag": string; "cross-model-uuids": string[]; "model-tag": string; "source-api-addrs": string[]; "source-ca-cert": string; } export interface AdoptResourcesArgs { "model-tag": string; "source-controller-version": Number; } export interface BytesResult { result: number[]; } export interface Error { code: string; info?: AdditionalProperties; message: string; } export interface ErrorResult { error?: Error; } export interface ErrorResults { results: ErrorResult[]; } export interface MigrationModelInfo { "agent-version": string; "controller-agent-version": Number; "facade-versions"?: Record<string, number[]>; name: string; "owner-tag": string; uuid: string; } export interface ModelArgs { "model-tag": string; } export interface Number { Build: number; Major: number; Minor: number; Patch: number; Tag: string; } export interface SerializedModel { bytes: number[]; charms: string[]; resources: SerializedModelResource[]; tools: SerializedModelTools[]; } export interface SerializedModelResource { application: string; "application-revision": SerializedModelResourceRevision; "charmstore-revision": SerializedModelResourceRevision; name: string; "unit-revisions": Record<string, SerializedModelResourceRevision>; } export interface SerializedModelResourceRevision { description: string; fingerprint: string; origin: string; path: string; revision: number; size: number; timestamp: string; type: string; username?: string; } export interface SerializedModelTools { uri: string; version: string; } export interface AdditionalProperties { [key: string]: any; } /** API implements the API required for the model migration master worker when communicating with the target controller. */ class MigrationTargetV3 implements Facade { static NAME = "MigrationTarget"; static VERSION = 3; NAME = "MigrationTarget"; VERSION = 3; _transport: Transport; _info: ConnectionInfo; constructor(transport: Transport, info: ConnectionInfo) { this._transport = transport; this._info = info; // Automatically bind all methods to instances. autoBind(this); } /** Abort removes the specified model from the database. It is an error to attempt to Abort a model that has a migration mode other than importing. */ abort(params: ModelArgs): Promise<any> { return new Promise((resolve, reject) => { const req: JujuRequest = { type: "MigrationTarget", request: "Abort", version: 3, params: params, }; this._transport.write(req, resolve, reject); }); } /** Activate sets the migration mode of the model to "none", meaning it is ready for use. It is an error to attempt to Abort a model that has a migration mode other than importing. It also adds any required external controller records for those controllers hosting offers used by the model. */ activate(params: ActivateModelArgs): Promise<any> { return new Promise((resolve, reject) => { const req: JujuRequest = { type: "MigrationTarget", request: "Activate", version: 3, params: params, }; this._transport.write(req, resolve, reject); }); } /** AdoptResources asks the cloud provider to update the controller tags for a model's resources. This prevents the resources from being destroyed if the source controller is destroyed after the model is migrated away. */ adoptResources(params: AdoptResourcesArgs): Promise<any> { return new Promise((resolve, reject) => { const req: JujuRequest = { type: "MigrationTarget", request: "AdoptResources", version: 3, params: params, }; this._transport.write(req, resolve, reject); }); } /** CACert returns the certificate used to validate the state connection. */ cACert(params: any): Promise<BytesResult> { return new Promise((resolve, reject) => { const req: JujuRequest = { type: "MigrationTarget", request: "CACert", version: 3, params: params, }; this._transport.write(req, resolve, reject); }); } /** CheckMachines compares the machines in state with the ones reported by the provider and reports any discrepancies. */ checkMachines(params: ModelArgs): Promise<ErrorResults> { return new Promise((resolve, reject) => { const req: JujuRequest = { type: "MigrationTarget", request: "CheckMachines", version: 3, params: params, }; this._transport.write(req, resolve, reject); }); } /** Import takes a serialized Juju model, deserializes it, and recreates it in the receiving controller. */ import(params: SerializedModel): Promise<any> { return new Promise((resolve, reject) => { const req: JujuRequest = { type: "MigrationTarget", request: "Import", version: 3, params: params, }; this._transport.write(req, resolve, reject); }); } /** LatestLogTime returns the time of the most recent log record received by the logtransfer endpoint. This can be used as the start point for streaming logs from the source if the transfer was interrupted. For performance reasons, not every time is tracked, so if the target controller died during the transfer the latest log time might be up to 2 minutes earlier. If the transfer was interrupted in some other way (like the source controller going away or a network partition) the time will be up-to-date. Log messages are assumed to be sent in time order (which is how debug-log emits them). If that isn't the case then this mechanism can't be used to avoid duplicates when logtransfer is restarted. Returns the zero time if no logs have been transferred. */ latestLogTime(params: ModelArgs): Promise<string> { return new Promise((resolve, reject) => { const req: JujuRequest = { type: "MigrationTarget", request: "LatestLogTime", version: 3, params: params, }; this._transport.write(req, resolve, reject); }); } /** Prechecks ensure that the target controller is ready to accept a model migration. */ prechecks(params: MigrationModelInfo): Promise<any> { return new Promise((resolve, reject) => { const req: JujuRequest = { type: "MigrationTarget", request: "Prechecks", version: 3, params: params, }; this._transport.write(req, resolve, reject); }); } } export default MigrationTargetV3;