-
Notifications
You must be signed in to change notification settings - Fork 7
/
BundleV6.ts
147 lines (125 loc) · 3.5 KB
/
BundleV6.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
/**
Juju Bundle version 6.
This facade is available on:
Controllers
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 BundleChange {
args: object[];
id: string;
method: string;
requires: string[];
}
export interface BundleChangesMapArgs {
args: AdditionalProperties;
id: string;
method: string;
requires: string[];
}
export interface BundleChangesMapArgsResults {
changes?: BundleChangesMapArgs[];
errors?: string[];
}
export interface BundleChangesParams {
bundleURL: string;
yaml: string;
}
export interface BundleChangesResults {
changes?: BundleChange[];
errors?: string[];
}
export interface Error {
code: string;
info?: AdditionalProperties;
message: string;
}
export interface ExportBundleParams {
"include-charm-defaults"?: boolean;
"include-series"?: boolean;
}
export interface StringResult {
error?: Error;
result: string;
}
export interface AdditionalProperties {
[key: string]: any;
}
/**
APIv6 provides the Bundle API facade for version 6. It is otherwise
identical to V5 with the exception that the V6 adds the support for
multi-part yaml handling to GetChanges and GetChangesMapArgs.
*/
class BundleV6 implements Facade {
static NAME = "Bundle";
static VERSION = 6;
NAME = "Bundle";
VERSION = 6;
_transport: Transport;
_info: ConnectionInfo;
constructor(transport: Transport, info: ConnectionInfo) {
this._transport = transport;
this._info = info;
// Automatically bind all methods to instances.
autoBind(this);
}
/**
ExportBundle exports the current model configuration as bundle.
*/
exportBundle(params: ExportBundleParams): Promise<StringResult> {
return new Promise((resolve, reject) => {
const req: JujuRequest = {
type: "Bundle",
request: "ExportBundle",
version: 6,
params: params,
};
this._transport.write(req, resolve, reject);
});
}
/**
GetChanges returns the list of changes required to deploy the given bundle
data. The changes are sorted by requirements, so that they can be applied in
order.
GetChanges has been superseded in favour of GetChangesMapArgs. It's
preferable to use that new method to add new functionality and move clients
away from this one.
*/
getChanges(params: BundleChangesParams): Promise<BundleChangesResults> {
return new Promise((resolve, reject) => {
const req: JujuRequest = {
type: "Bundle",
request: "GetChanges",
version: 6,
params: params,
};
this._transport.write(req, resolve, reject);
});
}
/**
GetChangesMapArgs returns the list of changes required to deploy the given
bundle data. The changes are sorted by requirements, so that they can be
applied in order.
V4 GetChangesMapArgs is not supported on anything less than v4
*/
getChangesMapArgs(
params: BundleChangesParams
): Promise<BundleChangesMapArgsResults> {
return new Promise((resolve, reject) => {
const req: JujuRequest = {
type: "Bundle",
request: "GetChangesMapArgs",
version: 6,
params: params,
};
this._transport.write(req, resolve, reject);
});
}
}
export default BundleV6;