@canonical/jujulib
Version:
Juju API client
119 lines (100 loc) • 2.87 kB
text/typescript
/**
Juju ActionPruner version 1.
This facade is available on:
Controller-machine-agent
Machine-agent
Unit-agent
Models
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 ActionPruneArgs {
"max-history-mb": number;
"max-history-time": number;
}
export interface Error {
code: string;
info?: AdditionalProperties;
message: string;
}
export interface ModelConfigResult {
config: AdditionalProperties;
}
export interface NotifyWatchResult {
NotifyWatcherId: string;
error?: Error;
}
export interface AdditionalProperties {
[key: string]: any;
}
/**
API provides access to the action pruner API.
*/
class ActionPrunerV1 implements Facade {
static NAME = "ActionPruner";
static VERSION = 1;
NAME = "ActionPruner";
VERSION = 1;
_transport: Transport;
_info: ConnectionInfo;
constructor(transport: Transport, info: ConnectionInfo) {
this._transport = transport;
this._info = info;
// Automatically bind all methods to instances.
autoBind(this);
}
/**
ModelConfig returns the current model's configuration.
*/
modelConfig(params: any): Promise<ModelConfigResult> {
return new Promise((resolve, reject) => {
const req: JujuRequest = {
type: "ActionPruner",
request: "ModelConfig",
version: 1,
params: params,
};
this._transport.write(req, resolve, reject);
});
}
/**
Prune endpoint removes action entries until
only the ones newer than now - p.MaxHistoryTime remain and
the history is smaller than p.MaxHistoryMB.
*/
prune(params: ActionPruneArgs): Promise<any> {
return new Promise((resolve, reject) => {
const req: JujuRequest = {
type: "ActionPruner",
request: "Prune",
version: 1,
params: params,
};
this._transport.write(req, resolve, reject);
});
}
/**
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> {
return new Promise((resolve, reject) => {
const req: JujuRequest = {
type: "ActionPruner",
request: "WatchForModelConfigChanges",
version: 1,
params: params,
};
this._transport.write(req, resolve, reject);
});
}
}
export default ActionPrunerV1;