-
Notifications
You must be signed in to change notification settings - Fork 7
/
MigrationTargetV2.ts
280 lines (240 loc) · 7.01 KB
/
MigrationTargetV2.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
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
/**
Juju MigrationTarget version 2.
This facade is available on:
Controllers
NOTE: This file was generated using the Juju schema
from Juju 3.2 at the git SHA 3a098707a1.
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;
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 MigrationTargetV2 implements Facade {
static NAME = "MigrationTarget";
static VERSION = 2;
NAME = "MigrationTarget";
VERSION = 2;
_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: 2,
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: 2,
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: 2,
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: 2,
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: 2,
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: 2,
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: 2,
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: 2,
params: params,
};
this._transport.write(req, resolve, reject);
});
}
}
export default MigrationTargetV2;