@canonical/jujulib
Version:
Juju API client
178 lines (173 loc) • 4.88 kB
TypeScript
/**
Juju Agent version 2.
This facade is available on:
Controller-machine-agent
Machine-agent
Unit-agent
NOTE: This file was generated using the Juju schema
from Juju 2.8.2 at the git SHA 516c1904ce.
Do not manually edit this file.
*/
import { ConnectionInfo, Transport } from "../../client.js";
import { Facade } from "../../types.js";
export interface AgentGetEntitiesResult {
"container-type": string;
error?: Error;
jobs: string[];
life: string;
}
export interface AgentGetEntitiesResults {
entities: AgentGetEntitiesResult[];
}
export interface CloudCredential {
attrs?: Record<string, string>;
"auth-type": string;
redacted?: string[];
}
export interface CloudSpec {
cacertificates?: string[];
credential?: CloudCredential;
endpoint?: string;
"identity-endpoint"?: string;
name: string;
region?: string;
"storage-endpoint"?: string;
type: string;
}
export interface CloudSpecResult {
error?: Error;
result?: CloudSpec;
}
export interface CloudSpecResults {
results?: CloudSpecResult[];
}
export interface ControllerAPIInfoResult {
addresses: string[];
cacert: string;
error?: Error;
}
export interface ControllerAPIInfoResults {
results: ControllerAPIInfoResult[];
}
export interface ControllerConfigResult {
config: AdditionalProperties;
}
export interface Entities {
entities: Entity[];
}
export interface Entity {
tag: string;
}
export interface EntityPassword {
password: string;
tag: string;
}
export interface EntityPasswords {
changes: EntityPassword[];
}
export interface Error {
code: string;
info?: AdditionalProperties;
message: string;
}
export interface ErrorResult {
error?: Error;
}
export interface ErrorResults {
results: ErrorResult[];
}
export interface IsMasterResult {
master: boolean;
}
export interface ModelConfigResult {
config: AdditionalProperties;
}
export interface ModelTag {
[key: string]: AdditionalProperties;
}
export interface NotifyWatchResult {
NotifyWatcherId: string;
error?: Error;
}
export interface NotifyWatchResults {
results: NotifyWatchResult[];
}
export interface StateServingInfo {
"api-port": number;
"ca-private-key": string;
cert: string;
"controller-api-port"?: number;
"private-key": string;
"shared-secret": string;
"state-port": number;
"system-identity": string;
}
export interface AdditionalProperties {
[key: string]: any;
}
/**
AgentAPIV2 implements the version 2 of the API provided to an agent.
*/
declare class AgentV2 implements Facade {
static NAME: string;
static VERSION: number;
NAME: string;
VERSION: number;
_transport: Transport;
_info: ConnectionInfo;
constructor(transport: Transport, info: ConnectionInfo);
/**
ClearReboot will clear the reboot flag on provided machines, if it exists.
*/
clearReboot(params: Entities): Promise<ErrorResults>;
/**
CloudSpec returns the model's cloud spec.
*/
cloudSpec(params: Entities): Promise<CloudSpecResults>;
/**
ControllerAPIInfoForModels returns the controller api connection details for the specified models.
*/
controllerAPIInfoForModels(params: Entities): Promise<ControllerAPIInfoResults>;
/**
ControllerConfig returns the controller's configuration.
*/
controllerConfig(params: any): Promise<ControllerConfigResult>;
/**
GetCloudSpec constructs the CloudSpec for a validated and authorized model.
*/
getCloudSpec(params: ModelTag): Promise<CloudSpecResult>;
/**
*/
getEntities(params: Entities): Promise<AgentGetEntitiesResults>;
/**
*/
isMaster(params: any): Promise<IsMasterResult>;
/**
ModelConfig returns the current model's configuration.
*/
modelConfig(params: any): Promise<ModelConfigResult>;
/**
SetPasswords sets the given password for each supplied entity, if possible.
*/
setPasswords(params: EntityPasswords): Promise<ErrorResults>;
/**
*/
stateServingInfo(params: any): Promise<StateServingInfo>;
/**
WatchCloudSpecsChanges returns a watcher for cloud spec changes.
*/
watchCloudSpecsChanges(params: Entities): Promise<NotifyWatchResults>;
/**
WatchCredentials watches for changes to the specified credentials.
*/
watchCredentials(params: Entities): Promise<NotifyWatchResults>;
/**
WatchForModelConfigChanges returns a NotifyWatcher that observes
changes to the model configuration.
Note that although the NotifyWatchResult contains an Error field,
it's not used because we are only returning a single watcher,
so we use the regular error return.
*/
watchForModelConfigChanges(params: any): Promise<NotifyWatchResult>;
}
export default AgentV2;