virtualizorjs 1.0.5 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +211 -126
- package/dist/index.d.mts +245 -0
- package/dist/index.d.ts +245 -0
- package/dist/index.js +272 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +262 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +49 -44
- package/.github/ISSUE_TEMPLATE/bug_report.md +0 -28
- package/.github/ISSUE_TEMPLATE/feature_request.md +0 -20
- package/.github/workflows/npm-publish-github-packages.yml +0 -36
- package/.github/workflows/release-package.yml +0 -33
- package/CODE_OF_CONDUCT.md +0 -128
- package/CONTRIBUTING.md +0 -92
- package/SECURITY.md +0 -26
- package/examples/createvps.js +0 -33
- package/examples/eventhandling.js +0 -36
- package/examples/listvps.js +0 -117
- package/src/Actions.js +0 -79
- package/src/VirtualizorClient.js +0 -491
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
interface VirtualizorError {
|
|
2
|
+
code: number;
|
|
3
|
+
msg: string;
|
|
4
|
+
}
|
|
5
|
+
interface VirtualizorResponse {
|
|
6
|
+
title?: string;
|
|
7
|
+
timenow?: number;
|
|
8
|
+
time_taken?: string;
|
|
9
|
+
error?: VirtualizorError[];
|
|
10
|
+
}
|
|
11
|
+
interface AsyncTaskResult extends VirtualizorResponse {
|
|
12
|
+
done?: 1;
|
|
13
|
+
taskid?: string;
|
|
14
|
+
}
|
|
15
|
+
type VirtType = 'kvm' | 'xen' | 'openvz' | 'lxc' | 'proxmox' | 'virtuozzo' | 'xcp' | 'hyperv';
|
|
16
|
+
|
|
17
|
+
interface VirtualizorConfig {
|
|
18
|
+
host: string;
|
|
19
|
+
apiKey: string;
|
|
20
|
+
apiPass?: string;
|
|
21
|
+
port?: number;
|
|
22
|
+
https?: boolean;
|
|
23
|
+
rejectUnauthorized?: boolean;
|
|
24
|
+
timeout?: number;
|
|
25
|
+
}
|
|
26
|
+
interface ResolvedConfig {
|
|
27
|
+
host: string;
|
|
28
|
+
apiKey: string;
|
|
29
|
+
apiPass: string;
|
|
30
|
+
port: number;
|
|
31
|
+
https: boolean;
|
|
32
|
+
rejectUnauthorized: boolean;
|
|
33
|
+
timeout: number;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
declare class VirtualizorApiError extends Error {
|
|
37
|
+
readonly code: number;
|
|
38
|
+
constructor(message: string, code: number);
|
|
39
|
+
}
|
|
40
|
+
type Params = Record<string, string | number | undefined>;
|
|
41
|
+
declare class HttpClient {
|
|
42
|
+
private readonly config;
|
|
43
|
+
constructor(config: ResolvedConfig);
|
|
44
|
+
parseResponse<T extends VirtualizorResponse>(data: T): T;
|
|
45
|
+
request<T extends VirtualizorResponse>(act: string, queryParams?: Params, bodyParams?: Params): Promise<T>;
|
|
46
|
+
private rawRequest;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
interface Plan {
|
|
50
|
+
pid: string;
|
|
51
|
+
plan_name: string;
|
|
52
|
+
disk: string;
|
|
53
|
+
ram: string;
|
|
54
|
+
bandwidth: string;
|
|
55
|
+
cpu: string;
|
|
56
|
+
virt?: string;
|
|
57
|
+
}
|
|
58
|
+
interface CreatePlanParams {
|
|
59
|
+
plan_name: string;
|
|
60
|
+
disk: number;
|
|
61
|
+
ram: number;
|
|
62
|
+
bandwidth: number;
|
|
63
|
+
cpu: number;
|
|
64
|
+
virt?: string;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
declare class PlansResource {
|
|
68
|
+
private readonly http;
|
|
69
|
+
constructor(http: HttpClient);
|
|
70
|
+
list(): Promise<Record<string, Plan>>;
|
|
71
|
+
create(params: CreatePlanParams): Promise<AsyncTaskResult>;
|
|
72
|
+
delete(planId: string): Promise<AsyncTaskResult>;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
interface Task {
|
|
76
|
+
id: string;
|
|
77
|
+
action: string;
|
|
78
|
+
status: string;
|
|
79
|
+
vpsid?: string;
|
|
80
|
+
data?: unknown;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
declare class TasksResource {
|
|
84
|
+
private readonly http;
|
|
85
|
+
constructor(http: HttpClient);
|
|
86
|
+
get(taskId: string): Promise<Task | undefined>;
|
|
87
|
+
wait(taskId: string, options?: {
|
|
88
|
+
pollIntervalMs?: number;
|
|
89
|
+
timeoutMs?: number;
|
|
90
|
+
}): Promise<Task>;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
interface User {
|
|
94
|
+
uid: string;
|
|
95
|
+
email: string;
|
|
96
|
+
fname?: string;
|
|
97
|
+
lname?: string;
|
|
98
|
+
status: string;
|
|
99
|
+
type: string;
|
|
100
|
+
}
|
|
101
|
+
interface CreateUserParams {
|
|
102
|
+
email: string;
|
|
103
|
+
password: string;
|
|
104
|
+
fname?: string;
|
|
105
|
+
lname?: string;
|
|
106
|
+
acttype?: number;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
declare class UsersResource {
|
|
110
|
+
private readonly http;
|
|
111
|
+
constructor(http: HttpClient);
|
|
112
|
+
list(): Promise<Record<string, User>>;
|
|
113
|
+
create(params: CreateUserParams): Promise<AsyncTaskResult>;
|
|
114
|
+
delete(uid: string): Promise<AsyncTaskResult>;
|
|
115
|
+
suspend(uid: string): Promise<AsyncTaskResult>;
|
|
116
|
+
unsuspend(uid: string): Promise<AsyncTaskResult>;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
interface VPS {
|
|
120
|
+
vpsid: string;
|
|
121
|
+
hostname: string;
|
|
122
|
+
status: string;
|
|
123
|
+
ram: string;
|
|
124
|
+
hdd: string;
|
|
125
|
+
bandwidth: string;
|
|
126
|
+
os_name: string;
|
|
127
|
+
ip: string;
|
|
128
|
+
serid?: string;
|
|
129
|
+
virt?: VirtType;
|
|
130
|
+
cpu?: string;
|
|
131
|
+
}
|
|
132
|
+
interface ListVPSParams {
|
|
133
|
+
user?: string | number;
|
|
134
|
+
vpsid?: string | number;
|
|
135
|
+
vpsname?: string;
|
|
136
|
+
vpsip?: string;
|
|
137
|
+
vpshostname?: string;
|
|
138
|
+
vsstatus?: string;
|
|
139
|
+
vstype?: VirtType;
|
|
140
|
+
serid?: number;
|
|
141
|
+
plid?: number;
|
|
142
|
+
bpid?: number;
|
|
143
|
+
}
|
|
144
|
+
interface CreateVPSParams {
|
|
145
|
+
hostname: string;
|
|
146
|
+
rootpass: string;
|
|
147
|
+
osid: number;
|
|
148
|
+
plid?: number;
|
|
149
|
+
user_email?: string;
|
|
150
|
+
ips?: number;
|
|
151
|
+
ips_int?: number;
|
|
152
|
+
space?: number;
|
|
153
|
+
ram?: number;
|
|
154
|
+
burst?: number;
|
|
155
|
+
bandwidth?: number;
|
|
156
|
+
cpu?: number;
|
|
157
|
+
cpu_percent?: number;
|
|
158
|
+
virt?: VirtType;
|
|
159
|
+
serid?: number;
|
|
160
|
+
node_select?: 0 | 1;
|
|
161
|
+
recipe?: number;
|
|
162
|
+
sshkey?: string;
|
|
163
|
+
nopassword?: 0 | 1;
|
|
164
|
+
}
|
|
165
|
+
interface RebuildVPSParams {
|
|
166
|
+
/** OS template ID to rebuild with */
|
|
167
|
+
osid: number;
|
|
168
|
+
/** New root password for the VPS */
|
|
169
|
+
newpass: string;
|
|
170
|
+
/** Must be set to 1 to confirm the rebuild */
|
|
171
|
+
conf: 1;
|
|
172
|
+
/** Format primary disk (0 = no, 1 = yes); defaults to 0 */
|
|
173
|
+
format_primary?: 0 | 1;
|
|
174
|
+
/** Send rebuild notification email (0 = no, 1 = yes) */
|
|
175
|
+
eu_send_rebuild_email?: 0 | 1;
|
|
176
|
+
/** Recipe ID to apply post-rebuild */
|
|
177
|
+
recipe?: number;
|
|
178
|
+
/** SSH key to inject */
|
|
179
|
+
sshkey?: string;
|
|
180
|
+
}
|
|
181
|
+
interface CloneVPSParams {
|
|
182
|
+
/** Hostname for the new cloned VPS */
|
|
183
|
+
hostname: string;
|
|
184
|
+
/** Root password for the new cloned VPS */
|
|
185
|
+
rootpass: string;
|
|
186
|
+
/** Source server ID (server where the VPS lives) */
|
|
187
|
+
from_server: number;
|
|
188
|
+
/** Destination server ID (server to clone into) */
|
|
189
|
+
to_server: number;
|
|
190
|
+
}
|
|
191
|
+
interface MigrateVPSParams {
|
|
192
|
+
/** Destination server ID */
|
|
193
|
+
serid: number;
|
|
194
|
+
/** Source server IP address */
|
|
195
|
+
from_ip: string;
|
|
196
|
+
/** Source server API/root password */
|
|
197
|
+
from_pass: string;
|
|
198
|
+
/** 0 = ignore VDF conflicts, 1 = error on conflict */
|
|
199
|
+
ignore_if_vdfconflict?: 0 | 1;
|
|
200
|
+
/** 0 = use gzip compression, 1 = disable gzip */
|
|
201
|
+
disable_gzip?: 0 | 1;
|
|
202
|
+
/** 0 = offline migration, 1 = live migration */
|
|
203
|
+
online?: 0 | 1;
|
|
204
|
+
}
|
|
205
|
+
interface VPSStatsResponse extends VirtualizorResponse {
|
|
206
|
+
vs_stats?: unknown;
|
|
207
|
+
vs_bandwidth?: unknown;
|
|
208
|
+
time_taken?: string;
|
|
209
|
+
}
|
|
210
|
+
interface VNCInfo extends VirtualizorResponse {
|
|
211
|
+
novnc?: string;
|
|
212
|
+
[key: string]: unknown;
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
declare class VpsResource {
|
|
216
|
+
private readonly http;
|
|
217
|
+
constructor(http: HttpClient);
|
|
218
|
+
list(filters?: ListVPSParams): Promise<Record<string, VPS>>;
|
|
219
|
+
get(vpsId: string): Promise<VPS>;
|
|
220
|
+
create(params: CreateVPSParams): Promise<AsyncTaskResult>;
|
|
221
|
+
delete(vpsId: string): Promise<AsyncTaskResult>;
|
|
222
|
+
start(vpsId: string): Promise<AsyncTaskResult>;
|
|
223
|
+
stop(vpsId: string): Promise<AsyncTaskResult>;
|
|
224
|
+
restart(vpsId: string): Promise<AsyncTaskResult>;
|
|
225
|
+
poweroff(vpsId: string): Promise<AsyncTaskResult>;
|
|
226
|
+
suspend(vpsId: string): Promise<AsyncTaskResult>;
|
|
227
|
+
unsuspend(vpsId: string): Promise<AsyncTaskResult>;
|
|
228
|
+
rebuild(vpsId: string, params: RebuildVPSParams): Promise<AsyncTaskResult>;
|
|
229
|
+
clone(vpsId: string, params: CloneVPSParams): Promise<AsyncTaskResult>;
|
|
230
|
+
migrate(vpsId: string, params: MigrateVPSParams): Promise<AsyncTaskResult>;
|
|
231
|
+
status(vpsId: string): Promise<unknown>;
|
|
232
|
+
vnc(vpsId: string): Promise<VNCInfo>;
|
|
233
|
+
stats(vpsId: string): Promise<VPSStatsResponse>;
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
declare class VirtualizorClient {
|
|
237
|
+
readonly vps: VpsResource;
|
|
238
|
+
readonly users: UsersResource;
|
|
239
|
+
readonly plans: PlansResource;
|
|
240
|
+
readonly tasks: TasksResource;
|
|
241
|
+
constructor(config: VirtualizorConfig);
|
|
242
|
+
}
|
|
243
|
+
declare function createVirtualizorClient(config: VirtualizorConfig): VirtualizorClient;
|
|
244
|
+
|
|
245
|
+
export { type AsyncTaskResult, type CloneVPSParams, type CreatePlanParams, type CreateUserParams, type CreateVPSParams, type ListVPSParams, type MigrateVPSParams, type Plan, type RebuildVPSParams, type Task, type User, type VPS, type VirtType, VirtualizorApiError, VirtualizorClient, type VirtualizorConfig, createVirtualizorClient };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,272 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var http = require('http');
|
|
4
|
+
var https = require('https');
|
|
5
|
+
var crypto = require('crypto');
|
|
6
|
+
|
|
7
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
8
|
+
|
|
9
|
+
var http__default = /*#__PURE__*/_interopDefault(http);
|
|
10
|
+
var https__default = /*#__PURE__*/_interopDefault(https);
|
|
11
|
+
var crypto__default = /*#__PURE__*/_interopDefault(crypto);
|
|
12
|
+
|
|
13
|
+
// src/http.ts
|
|
14
|
+
function generateSignature(apiKey, apiPass, params) {
|
|
15
|
+
const sorted = Object.keys(params).filter((k) => params[k] !== void 0).sort().map((k) => `${k}${params[k]}`).join("");
|
|
16
|
+
return crypto__default.default.createHash("sha256").update(apiKey + apiPass + sorted).digest("hex");
|
|
17
|
+
}
|
|
18
|
+
function buildQueryString(params, apiKey, apiPass) {
|
|
19
|
+
const clean = {};
|
|
20
|
+
for (const [key, value] of Object.entries(params)) {
|
|
21
|
+
if (value !== void 0) {
|
|
22
|
+
clean[key] = value;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
const sig = generateSignature(apiKey, apiPass, clean);
|
|
26
|
+
const urlParams = new URLSearchParams();
|
|
27
|
+
urlParams.set("api", "json");
|
|
28
|
+
urlParams.set("api_key", apiKey);
|
|
29
|
+
urlParams.set("api_sig", sig);
|
|
30
|
+
for (const [key, value] of Object.entries(clean)) {
|
|
31
|
+
urlParams.set(key, String(value));
|
|
32
|
+
}
|
|
33
|
+
return `?${urlParams.toString()}`;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
// src/http.ts
|
|
37
|
+
var VirtualizorApiError = class extends Error {
|
|
38
|
+
code;
|
|
39
|
+
constructor(message, code) {
|
|
40
|
+
super(message);
|
|
41
|
+
this.name = "VirtualizorApiError";
|
|
42
|
+
this.code = code;
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
var HttpClient = class {
|
|
46
|
+
constructor(config) {
|
|
47
|
+
this.config = config;
|
|
48
|
+
}
|
|
49
|
+
parseResponse(data) {
|
|
50
|
+
if (data.error && data.error.length > 0) {
|
|
51
|
+
const first = data.error[0];
|
|
52
|
+
if (first) {
|
|
53
|
+
throw new VirtualizorApiError(first.msg, first.code);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return data;
|
|
57
|
+
}
|
|
58
|
+
async request(act, queryParams = {}, bodyParams = {}) {
|
|
59
|
+
const allQueryParams = { act, ...queryParams };
|
|
60
|
+
const qs = buildQueryString(allQueryParams, this.config.apiKey, this.config.apiPass);
|
|
61
|
+
const path = `/index.php${qs}`;
|
|
62
|
+
const bodyString = Object.entries(bodyParams).filter(([, v]) => v !== void 0).map(([k, v]) => `${encodeURIComponent(k)}=${encodeURIComponent(String(v))}`).join("&");
|
|
63
|
+
const data = await this.rawRequest(path, bodyString || void 0);
|
|
64
|
+
return this.parseResponse(data);
|
|
65
|
+
}
|
|
66
|
+
rawRequest(path, body) {
|
|
67
|
+
const transport = this.config.https ? https__default.default : http__default.default;
|
|
68
|
+
const options = {
|
|
69
|
+
host: this.config.host,
|
|
70
|
+
port: this.config.port,
|
|
71
|
+
path,
|
|
72
|
+
method: body ? "POST" : "GET",
|
|
73
|
+
headers: {
|
|
74
|
+
"Content-Type": "application/x-www-form-urlencoded",
|
|
75
|
+
...body ? { "Content-Length": Buffer.byteLength(body) } : {}
|
|
76
|
+
},
|
|
77
|
+
...this.config.https ? { agent: new https__default.default.Agent({ rejectUnauthorized: this.config.rejectUnauthorized }) } : {}
|
|
78
|
+
};
|
|
79
|
+
return new Promise((resolve, reject) => {
|
|
80
|
+
const req = transport.request(options, (res) => {
|
|
81
|
+
let raw = "";
|
|
82
|
+
res.on("data", (chunk) => {
|
|
83
|
+
raw += chunk.toString();
|
|
84
|
+
});
|
|
85
|
+
res.on("end", () => {
|
|
86
|
+
try {
|
|
87
|
+
resolve(JSON.parse(raw));
|
|
88
|
+
} catch {
|
|
89
|
+
reject(new Error(`Failed to parse response: ${raw.slice(0, 200)}`));
|
|
90
|
+
}
|
|
91
|
+
});
|
|
92
|
+
});
|
|
93
|
+
req.setTimeout(this.config.timeout, () => {
|
|
94
|
+
req.destroy(new Error(`Request timed out after ${this.config.timeout}ms`));
|
|
95
|
+
});
|
|
96
|
+
req.on("error", reject);
|
|
97
|
+
if (body) {
|
|
98
|
+
req.write(body);
|
|
99
|
+
}
|
|
100
|
+
req.end();
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
// src/resources/plans.ts
|
|
106
|
+
var PlansResource = class {
|
|
107
|
+
constructor(http2) {
|
|
108
|
+
this.http = http2;
|
|
109
|
+
}
|
|
110
|
+
async list() {
|
|
111
|
+
const res = await this.http.request("plans", {}, {});
|
|
112
|
+
return res.plans;
|
|
113
|
+
}
|
|
114
|
+
async create(params) {
|
|
115
|
+
return this.http.request("addplan", {}, params);
|
|
116
|
+
}
|
|
117
|
+
async delete(planId) {
|
|
118
|
+
return this.http.request("plans", {}, { delete: planId });
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
// src/resources/tasks.ts
|
|
123
|
+
var TasksResource = class {
|
|
124
|
+
constructor(http2) {
|
|
125
|
+
this.http = http2;
|
|
126
|
+
}
|
|
127
|
+
async get(taskId) {
|
|
128
|
+
const res = await this.http.request("tasks", { taskid: taskId }, {});
|
|
129
|
+
return res.tasks[taskId];
|
|
130
|
+
}
|
|
131
|
+
async wait(taskId, options = {}) {
|
|
132
|
+
const { pollIntervalMs = 2e3, timeoutMs = 12e4 } = options;
|
|
133
|
+
const deadline = Date.now() + timeoutMs;
|
|
134
|
+
while (Date.now() < deadline) {
|
|
135
|
+
const task = await this.get(taskId);
|
|
136
|
+
if (!task) throw new Error(`Task ${taskId} not found`);
|
|
137
|
+
if (task.status === "1" || task.status === "done") return task;
|
|
138
|
+
if (task.status === "error" || task.status === "-1") {
|
|
139
|
+
throw new Error(`Task ${taskId} failed`);
|
|
140
|
+
}
|
|
141
|
+
await new Promise((r) => setTimeout(r, pollIntervalMs));
|
|
142
|
+
}
|
|
143
|
+
throw new Error(`Task ${taskId} timed out after ${timeoutMs}ms`);
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
|
|
147
|
+
// src/resources/users.ts
|
|
148
|
+
var UsersResource = class {
|
|
149
|
+
constructor(http2) {
|
|
150
|
+
this.http = http2;
|
|
151
|
+
}
|
|
152
|
+
async list() {
|
|
153
|
+
const res = await this.http.request("users", {}, {});
|
|
154
|
+
return res.users;
|
|
155
|
+
}
|
|
156
|
+
async create(params) {
|
|
157
|
+
return this.http.request("adduser", {}, params);
|
|
158
|
+
}
|
|
159
|
+
async delete(uid) {
|
|
160
|
+
return this.http.request("users", {}, { delete: uid });
|
|
161
|
+
}
|
|
162
|
+
async suspend(uid) {
|
|
163
|
+
return this.http.request("users", {}, { suspend: uid });
|
|
164
|
+
}
|
|
165
|
+
async unsuspend(uid) {
|
|
166
|
+
return this.http.request("users", {}, { unsuspend: uid });
|
|
167
|
+
}
|
|
168
|
+
};
|
|
169
|
+
|
|
170
|
+
// src/resources/vps.ts
|
|
171
|
+
var VpsResource = class {
|
|
172
|
+
constructor(http2) {
|
|
173
|
+
this.http = http2;
|
|
174
|
+
}
|
|
175
|
+
async list(filters = {}) {
|
|
176
|
+
const res = await this.http.request("listvs", {}, filters);
|
|
177
|
+
return res.vs;
|
|
178
|
+
}
|
|
179
|
+
async get(vpsId) {
|
|
180
|
+
const res = await this.http.request("vs", { vpsid: vpsId }, {});
|
|
181
|
+
const vps = res.vs[vpsId];
|
|
182
|
+
if (!vps) throw new Error(`VPS ${vpsId} not found in response`);
|
|
183
|
+
return vps;
|
|
184
|
+
}
|
|
185
|
+
async create(params) {
|
|
186
|
+
return this.http.request("addvs", {}, params);
|
|
187
|
+
}
|
|
188
|
+
async delete(vpsId) {
|
|
189
|
+
return this.http.request("vs", { delete: vpsId }, {});
|
|
190
|
+
}
|
|
191
|
+
async start(vpsId) {
|
|
192
|
+
return this.http.request("vs", { vpsid: vpsId, action: "start" }, {});
|
|
193
|
+
}
|
|
194
|
+
async stop(vpsId) {
|
|
195
|
+
return this.http.request("vs", { vpsid: vpsId, action: "stop" }, {});
|
|
196
|
+
}
|
|
197
|
+
async restart(vpsId) {
|
|
198
|
+
return this.http.request("vs", { vpsid: vpsId, action: "restart" }, {});
|
|
199
|
+
}
|
|
200
|
+
async poweroff(vpsId) {
|
|
201
|
+
return this.http.request("vs", { vpsid: vpsId, action: "poweroff" }, {});
|
|
202
|
+
}
|
|
203
|
+
async suspend(vpsId) {
|
|
204
|
+
return this.http.request("vs", { suspend: vpsId }, {});
|
|
205
|
+
}
|
|
206
|
+
async unsuspend(vpsId) {
|
|
207
|
+
return this.http.request("vs", { unsuspend: vpsId }, {});
|
|
208
|
+
}
|
|
209
|
+
async rebuild(vpsId, params) {
|
|
210
|
+
return this.http.request("rebuild", {}, {
|
|
211
|
+
vpsid: vpsId,
|
|
212
|
+
reos: 1,
|
|
213
|
+
...params
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
async clone(vpsId, params) {
|
|
217
|
+
return this.http.request("clone", {}, {
|
|
218
|
+
vpsid: vpsId,
|
|
219
|
+
...params
|
|
220
|
+
});
|
|
221
|
+
}
|
|
222
|
+
async migrate(vpsId, params) {
|
|
223
|
+
return this.http.request("migrate", {}, {
|
|
224
|
+
vpsid: vpsId,
|
|
225
|
+
migrate: 1,
|
|
226
|
+
migrate_but: 1,
|
|
227
|
+
...params
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
async status(vpsId) {
|
|
231
|
+
return this.http.request("vstatus", { vpsid: vpsId }, {});
|
|
232
|
+
}
|
|
233
|
+
async vnc(vpsId) {
|
|
234
|
+
return this.http.request("vnc", { vpsid: vpsId }, {});
|
|
235
|
+
}
|
|
236
|
+
async stats(vpsId) {
|
|
237
|
+
return this.http.request("vps_stats", {}, { vpsid: vpsId });
|
|
238
|
+
}
|
|
239
|
+
};
|
|
240
|
+
|
|
241
|
+
// src/client.ts
|
|
242
|
+
var VirtualizorClient = class {
|
|
243
|
+
vps;
|
|
244
|
+
users;
|
|
245
|
+
plans;
|
|
246
|
+
tasks;
|
|
247
|
+
constructor(config) {
|
|
248
|
+
const resolved = {
|
|
249
|
+
host: config.host,
|
|
250
|
+
apiKey: config.apiKey,
|
|
251
|
+
apiPass: config.apiPass ?? "",
|
|
252
|
+
port: config.port ?? 4085,
|
|
253
|
+
https: config.https ?? true,
|
|
254
|
+
rejectUnauthorized: config.rejectUnauthorized ?? false,
|
|
255
|
+
timeout: config.timeout ?? 3e4
|
|
256
|
+
};
|
|
257
|
+
const http2 = new HttpClient(resolved);
|
|
258
|
+
this.vps = new VpsResource(http2);
|
|
259
|
+
this.users = new UsersResource(http2);
|
|
260
|
+
this.plans = new PlansResource(http2);
|
|
261
|
+
this.tasks = new TasksResource(http2);
|
|
262
|
+
}
|
|
263
|
+
};
|
|
264
|
+
function createVirtualizorClient(config) {
|
|
265
|
+
return new VirtualizorClient(config);
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
exports.VirtualizorApiError = VirtualizorApiError;
|
|
269
|
+
exports.VirtualizorClient = VirtualizorClient;
|
|
270
|
+
exports.createVirtualizorClient = createVirtualizorClient;
|
|
271
|
+
//# sourceMappingURL=index.js.map
|
|
272
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/auth.ts","../src/http.ts","../src/resources/plans.ts","../src/resources/tasks.ts","../src/resources/users.ts","../src/resources/vps.ts","../src/client.ts"],"names":["crypto","https","http"],"mappings":"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","file":"index.js","sourcesContent":["import crypto from 'node:crypto';\n\ntype Params = Record<string, string | number | undefined>;\n\nfunction generateSignature(apiKey: string, apiPass: string, params: Params): string {\n const sorted = Object.keys(params)\n .filter((k) => params[k] !== undefined)\n .sort()\n .map((k) => `${k}${params[k]}`)\n .join('');\n return crypto\n .createHash('sha256')\n .update(apiKey + apiPass + sorted)\n .digest('hex');\n}\n\nexport function buildQueryString(params: Params, apiKey: string, apiPass: string): string {\n const clean: Params = {};\n for (const [key, value] of Object.entries(params)) {\n if (value !== undefined) {\n clean[key] = value;\n }\n }\n\n const sig = generateSignature(apiKey, apiPass, clean);\n\n const urlParams = new URLSearchParams();\n urlParams.set('api', 'json');\n urlParams.set('api_key', apiKey);\n urlParams.set('api_sig', sig);\n\n for (const [key, value] of Object.entries(clean)) {\n urlParams.set(key, String(value));\n }\n\n return `?${urlParams.toString()}`;\n}\n","import http from 'node:http';\nimport https from 'node:https';\nimport { buildQueryString } from './auth.js';\nimport type { VirtualizorResponse } from './types/common.js';\nimport type { ResolvedConfig } from './types/config.js';\n\nexport class VirtualizorApiError extends Error {\n readonly code: number;\n\n constructor(message: string, code: number) {\n super(message);\n this.name = 'VirtualizorApiError';\n this.code = code;\n }\n}\n\ntype Params = Record<string, string | number | undefined>;\n\nexport class HttpClient {\n constructor(private readonly config: ResolvedConfig) {}\n\n parseResponse<T extends VirtualizorResponse>(data: T): T {\n if (data.error && data.error.length > 0) {\n const first = data.error[0];\n if (first) {\n throw new VirtualizorApiError(first.msg, first.code);\n }\n }\n return data;\n }\n\n async request<T extends VirtualizorResponse>(\n act: string,\n queryParams: Params = {},\n bodyParams: Params = {},\n ): Promise<T> {\n const allQueryParams: Params = { act, ...queryParams };\n const qs = buildQueryString(allQueryParams, this.config.apiKey, this.config.apiPass);\n\n const path = `/index.php${qs}`;\n\n const bodyString = Object.entries(bodyParams)\n .filter(([, v]) => v !== undefined)\n .map(([k, v]) => `${encodeURIComponent(k)}=${encodeURIComponent(String(v))}`)\n .join('&');\n\n const data = await this.rawRequest(path, bodyString || undefined);\n return this.parseResponse(data as T);\n }\n\n private rawRequest(path: string, body?: string): Promise<VirtualizorResponse> {\n const transport = this.config.https ? https : http;\n const options: https.RequestOptions = {\n host: this.config.host,\n port: this.config.port,\n path,\n method: body ? 'POST' : 'GET',\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded',\n ...(body ? { 'Content-Length': Buffer.byteLength(body) } : {}),\n },\n ...(this.config.https\n ? { agent: new https.Agent({ rejectUnauthorized: this.config.rejectUnauthorized }) }\n : {}),\n };\n\n return new Promise((resolve, reject) => {\n const req = transport.request(options, (res) => {\n let raw = '';\n res.on('data', (chunk: Buffer) => {\n raw += chunk.toString();\n });\n res.on('end', () => {\n try {\n resolve(JSON.parse(raw) as VirtualizorResponse);\n } catch {\n reject(new Error(`Failed to parse response: ${raw.slice(0, 200)}`));\n }\n });\n });\n\n req.setTimeout(this.config.timeout, () => {\n req.destroy(new Error(`Request timed out after ${this.config.timeout}ms`));\n });\n\n req.on('error', reject);\n\n if (body) {\n req.write(body);\n }\n\n req.end();\n });\n }\n}\n","import type { HttpClient } from '../http.js';\nimport type { AsyncTaskResult, VirtualizorResponse } from '../types/common.js';\nimport type { CreatePlanParams, Plan } from '../types/plans.js';\n\ntype Params = Record<string, string | number | undefined>;\n\ninterface ListPlansResponse extends VirtualizorResponse {\n plans: Record<string, Plan>;\n}\nexport class PlansResource {\n constructor(private readonly http: HttpClient) {}\n\n async list(): Promise<Record<string, Plan>> {\n const res = await this.http.request<ListPlansResponse>('plans', {}, {});\n return res.plans;\n }\n\n async create(params: CreatePlanParams): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('addplan', {}, params as unknown as Params);\n }\n\n async delete(planId: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('plans', {}, { delete: planId });\n }\n}\n","import type { HttpClient } from '../http.js';\nimport type { VirtualizorResponse } from '../types/common.js';\nimport type { Task } from '../types/tasks.js';\n\ninterface TasksResponse extends VirtualizorResponse {\n tasks: Record<string, Task>;\n}\n\nexport class TasksResource {\n constructor(private readonly http: HttpClient) {}\n\n async get(taskId: string): Promise<Task | undefined> {\n const res = await this.http.request<TasksResponse>('tasks', { taskid: taskId }, {});\n return res.tasks[taskId];\n }\n\n async wait(\n taskId: string,\n options: { pollIntervalMs?: number; timeoutMs?: number } = {},\n ): Promise<Task> {\n const { pollIntervalMs = 2000, timeoutMs = 120000 } = options;\n const deadline = Date.now() + timeoutMs;\n\n while (Date.now() < deadline) {\n const task = await this.get(taskId);\n if (!task) throw new Error(`Task ${taskId} not found`);\n if (task.status === '1' || task.status === 'done') return task;\n if (task.status === 'error' || task.status === '-1') {\n throw new Error(`Task ${taskId} failed`);\n }\n await new Promise((r) => setTimeout(r, pollIntervalMs));\n }\n\n throw new Error(`Task ${taskId} timed out after ${timeoutMs}ms`);\n }\n}\n","import type { HttpClient } from '../http.js';\nimport type { AsyncTaskResult, VirtualizorResponse } from '../types/common.js';\nimport type { CreateUserParams, User } from '../types/users.js';\n\ntype Params = Record<string, string | number | undefined>;\n\ninterface ListUsersResponse extends VirtualizorResponse {\n users: Record<string, User>;\n}\n\nexport class UsersResource {\n constructor(private readonly http: HttpClient) {}\n\n async list(): Promise<Record<string, User>> {\n const res = await this.http.request<ListUsersResponse>('users', {}, {});\n return res.users;\n }\n\n async create(params: CreateUserParams): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('adduser', {}, params as unknown as Params);\n }\n\n async delete(uid: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('users', {}, { delete: uid });\n }\n\n async suspend(uid: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('users', {}, { suspend: uid });\n }\n\n async unsuspend(uid: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('users', {}, { unsuspend: uid });\n }\n}\n","import type { HttpClient } from '../http.js';\nimport type { AsyncTaskResult, VirtualizorResponse } from '../types/common.js';\nimport type {\n CloneVPSParams,\n CreateVPSParams,\n ListVPSParams,\n MigrateVPSParams,\n RebuildVPSParams,\n VNCInfo,\n VPS,\n VPSStatsResponse,\n} from '../types/vps.js';\n\ntype Params = Record<string, string | number | undefined>;\n\ninterface ListVPSResponse extends VirtualizorResponse {\n vs: Record<string, VPS>;\n}\ninterface GetVPSResponse extends VirtualizorResponse {\n vs: Record<string, VPS>;\n}\n\nexport class VpsResource {\n constructor(private readonly http: HttpClient) {}\n\n async list(filters: ListVPSParams = {}): Promise<Record<string, VPS>> {\n const res = await this.http.request<ListVPSResponse>('listvs', {}, filters as Params);\n return res.vs;\n }\n\n async get(vpsId: string): Promise<VPS> {\n const res = await this.http.request<GetVPSResponse>('vs', { vpsid: vpsId }, {});\n const vps = res.vs[vpsId];\n if (!vps) throw new Error(`VPS ${vpsId} not found in response`);\n return vps;\n }\n\n async create(params: CreateVPSParams): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('addvs', {}, params as unknown as Params);\n }\n\n async delete(vpsId: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('vs', { delete: vpsId }, {});\n }\n\n async start(vpsId: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('vs', { vpsid: vpsId, action: 'start' }, {});\n }\n\n async stop(vpsId: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('vs', { vpsid: vpsId, action: 'stop' }, {});\n }\n\n async restart(vpsId: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('vs', { vpsid: vpsId, action: 'restart' }, {});\n }\n\n async poweroff(vpsId: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('vs', { vpsid: vpsId, action: 'poweroff' }, {});\n }\n\n async suspend(vpsId: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('vs', { suspend: vpsId }, {});\n }\n\n async unsuspend(vpsId: string): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('vs', { unsuspend: vpsId }, {});\n }\n\n async rebuild(vpsId: string, params: RebuildVPSParams): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('rebuild', {}, {\n vpsid: vpsId,\n reos: 1,\n ...params,\n } as Params);\n }\n\n async clone(vpsId: string, params: CloneVPSParams): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('clone', {}, {\n vpsid: vpsId,\n ...params,\n } as Params);\n }\n\n async migrate(vpsId: string, params: MigrateVPSParams): Promise<AsyncTaskResult> {\n return this.http.request<AsyncTaskResult>('migrate', {}, {\n vpsid: vpsId,\n migrate: 1,\n migrate_but: 1,\n ...params,\n } as Params);\n }\n\n async status(vpsId: string): Promise<unknown> {\n return this.http.request('vstatus', { vpsid: vpsId }, {});\n }\n\n async vnc(vpsId: string): Promise<VNCInfo> {\n return this.http.request<VNCInfo>('vnc', { vpsid: vpsId }, {});\n }\n\n async stats(vpsId: string): Promise<VPSStatsResponse> {\n return this.http.request<VPSStatsResponse>('vps_stats', {}, { vpsid: vpsId });\n }\n}\n","import { HttpClient } from './http.js';\nimport { PlansResource } from './resources/plans.js';\nimport { TasksResource } from './resources/tasks.js';\nimport { UsersResource } from './resources/users.js';\nimport { VpsResource } from './resources/vps.js';\nimport type { ResolvedConfig, VirtualizorConfig } from './types/config.js';\n\nexport class VirtualizorClient {\n readonly vps: VpsResource;\n readonly users: UsersResource;\n readonly plans: PlansResource;\n readonly tasks: TasksResource;\n\n constructor(config: VirtualizorConfig) {\n const resolved: ResolvedConfig = {\n host: config.host,\n apiKey: config.apiKey,\n apiPass: config.apiPass ?? '',\n port: config.port ?? 4085,\n https: config.https ?? true,\n rejectUnauthorized: config.rejectUnauthorized ?? false,\n timeout: config.timeout ?? 30000,\n };\n const http = new HttpClient(resolved);\n this.vps = new VpsResource(http);\n this.users = new UsersResource(http);\n this.plans = new PlansResource(http);\n this.tasks = new TasksResource(http);\n }\n}\n\nexport function createVirtualizorClient(config: VirtualizorConfig): VirtualizorClient {\n return new VirtualizorClient(config);\n}\n"]}
|