@phystack/device-phyos 4.5.55-dev → 4.5.57-dev
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/bin/phydevice +0 -0
- package/package.json +10 -10
- package/bin/index.js +0 -2
- package/dist/edge-hub.js +0 -1125
- package/dist/edge-hub.js.map +0 -1
- package/dist/http-proxy.js +0 -54
- package/dist/http-proxy.js.map +0 -1
- package/dist/index.js +0 -491
- package/dist/index.js.map +0 -1
- package/dist/methods/devdevice.js +0 -123
- package/dist/methods/devdevice.js.map +0 -1
- package/dist/methods/environment.js +0 -356
- package/dist/methods/environment.js.map +0 -1
- package/dist/methods/index.js +0 -24
- package/dist/methods/index.js.map +0 -1
- package/dist/methods/network/ca.js +0 -48
- package/dist/methods/network/ca.js.map +0 -1
- package/dist/methods/network/hostname.js +0 -56
- package/dist/methods/network/hostname.js.map +0 -1
- package/dist/methods/network/lan.js +0 -193
- package/dist/methods/network/lan.js.map +0 -1
- package/dist/methods/network/wifi.js +0 -299
- package/dist/methods/network/wifi.js.map +0 -1
- package/dist/methods/password.js +0 -87
- package/dist/methods/password.js.map +0 -1
- package/dist/methods/reboot.js +0 -22
- package/dist/methods/reboot.js.map +0 -1
- package/dist/methods/ssh.js +0 -148
- package/dist/methods/ssh.js.map +0 -1
- package/dist/services/scheduler.service.js +0 -335
- package/dist/services/scheduler.service.js.map +0 -1
- package/dist/store/types/network-interface.type.js +0 -3
- package/dist/store/types/network-interface.type.js.map +0 -1
- package/dist/time-sync.js +0 -119
- package/dist/time-sync.js.map +0 -1
- package/dist/types/command.types.js +0 -8
- package/dist/types/command.types.js.map +0 -1
- package/dist/types/container.types.js +0 -3
- package/dist/types/container.types.js.map +0 -1
- package/dist/types/event.types.js +0 -9
- package/dist/types/event.types.js.map +0 -1
- package/dist/types/job.types.js +0 -15
- package/dist/types/job.types.js.map +0 -1
- package/dist/types/twin.types.js +0 -34
- package/dist/types/twin.types.js.map +0 -1
- package/dist/utilities/audio-control.js +0 -919
- package/dist/utilities/audio-control.js.map +0 -1
- package/dist/utilities/docker-progress-tracker.js +0 -33
- package/dist/utilities/docker-progress-tracker.js.map +0 -1
- package/dist/utilities/docker.js +0 -1090
- package/dist/utilities/docker.js.map +0 -1
- package/dist/utilities/instances.js +0 -236
- package/dist/utilities/instances.js.map +0 -1
- package/dist/utilities/jobs.js +0 -103
- package/dist/utilities/jobs.js.map +0 -1
- package/dist/utilities/local-twins.js +0 -204
- package/dist/utilities/local-twins.js.map +0 -1
- package/dist/utilities/network-settings.js +0 -147
- package/dist/utilities/network-settings.js.map +0 -1
- package/dist/utilities/symlink.js +0 -47
- package/dist/utilities/symlink.js.map +0 -1
- package/dist/utilities/sysinfo.js +0 -128
- package/dist/utilities/sysinfo.js.map +0 -1
- package/dist/utilities/twin-manager.js +0 -108
- package/dist/utilities/twin-manager.js.map +0 -1
package/dist/time-sync.js
DELETED
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
-
var ownKeys = function(o) {
|
|
20
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
-
var ar = [];
|
|
22
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
-
return ar;
|
|
24
|
-
};
|
|
25
|
-
return ownKeys(o);
|
|
26
|
-
};
|
|
27
|
-
return function (mod) {
|
|
28
|
-
if (mod && mod.__esModule) return mod;
|
|
29
|
-
var result = {};
|
|
30
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
-
__setModuleDefault(result, mod);
|
|
32
|
-
return result;
|
|
33
|
-
};
|
|
34
|
-
})();
|
|
35
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.default = syncTime;
|
|
37
|
-
const getAxiosInstanceWithProxy = async () => {
|
|
38
|
-
const module = await Promise.resolve().then(() => __importStar(require('@phystack/axios-proxy')));
|
|
39
|
-
return module.default;
|
|
40
|
-
};
|
|
41
|
-
const child_process_1 = require("child_process");
|
|
42
|
-
const util_1 = require("util");
|
|
43
|
-
const phy_logger_1 = require("@phystack/phy-logger");
|
|
44
|
-
const os_1 = require("os");
|
|
45
|
-
const execAsync = (0, util_1.promisify)(child_process_1.exec);
|
|
46
|
-
const ONE_HOUR_MS = 60 * 60 * 1000;
|
|
47
|
-
const RETRY_DELAY_MS = 5000;
|
|
48
|
-
const logger = new phy_logger_1.PhyLogger({
|
|
49
|
-
logToFile: false,
|
|
50
|
-
logToConsole: true,
|
|
51
|
-
includeTrace: true,
|
|
52
|
-
namespace: 'time-sync',
|
|
53
|
-
});
|
|
54
|
-
const url = 'http://screen.omborigrid.com/is-online.json';
|
|
55
|
-
function hasValidNetworkInterface() {
|
|
56
|
-
const interfaces = (0, os_1.networkInterfaces)();
|
|
57
|
-
for (const [, addresses] of Object.entries(interfaces)) {
|
|
58
|
-
if (!addresses)
|
|
59
|
-
continue;
|
|
60
|
-
for (const addr of addresses) {
|
|
61
|
-
if (addr.family === 'IPv4' && !addr.address.startsWith('169.254.')) {
|
|
62
|
-
return true;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
return false;
|
|
67
|
-
}
|
|
68
|
-
async function syncTimeLoop(axios) {
|
|
69
|
-
while (true) {
|
|
70
|
-
try {
|
|
71
|
-
while (!hasValidNetworkInterface()) {
|
|
72
|
-
logger.info('syncTime(): Waiting for valid network interface...');
|
|
73
|
-
await new Promise(resolve => setTimeout(resolve, RETRY_DELAY_MS));
|
|
74
|
-
}
|
|
75
|
-
const response = await axios.get(url, {
|
|
76
|
-
timeout: 10000,
|
|
77
|
-
validateStatus: () => true,
|
|
78
|
-
headers: {
|
|
79
|
-
'Cache-Control': 'no-cache, no-store, must-revalidate',
|
|
80
|
-
'Pragma': 'no-cache',
|
|
81
|
-
'Expires': '0'
|
|
82
|
-
}
|
|
83
|
-
});
|
|
84
|
-
const dateHeader = response.headers.date;
|
|
85
|
-
if (!dateHeader) {
|
|
86
|
-
logger.error('syncTime(): No date header received');
|
|
87
|
-
await new Promise(resolve => setTimeout(resolve, RETRY_DELAY_MS));
|
|
88
|
-
continue;
|
|
89
|
-
}
|
|
90
|
-
logger.info('syncTime(): Attempting to set system time to:', { targetDate: dateHeader });
|
|
91
|
-
const commands = [
|
|
92
|
-
`sudo date -s "${dateHeader}"`,
|
|
93
|
-
'sudo hwclock --systohc'
|
|
94
|
-
];
|
|
95
|
-
for (const command of commands) {
|
|
96
|
-
const { stderr } = await execAsync(command, { timeout: 3000 });
|
|
97
|
-
if (stderr) {
|
|
98
|
-
logger.error('syncTime(): Error executing command:', { command, error: stderr });
|
|
99
|
-
await new Promise(resolve => setTimeout(resolve, RETRY_DELAY_MS));
|
|
100
|
-
continue;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
logger.info('syncTime(): System time synchronized successfully');
|
|
104
|
-
await new Promise(resolve => setTimeout(resolve, ONE_HOUR_MS));
|
|
105
|
-
}
|
|
106
|
-
catch (error) {
|
|
107
|
-
logger.error('syncTime(): Failed to sync time:', error);
|
|
108
|
-
await new Promise(resolve => setTimeout(resolve, RETRY_DELAY_MS));
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
async function syncTime() {
|
|
113
|
-
const axios = await (await getAxiosInstanceWithProxy())();
|
|
114
|
-
syncTimeLoop(axios).catch(error => {
|
|
115
|
-
logger.error('syncTime(): Background sync loop failed:', error);
|
|
116
|
-
});
|
|
117
|
-
return Promise.resolve();
|
|
118
|
-
}
|
|
119
|
-
//# sourceMappingURL=time-sync.js.map
|
package/dist/time-sync.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"time-sync.js","sourceRoot":"","sources":["../src/time-sync.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4FA,2BAUC;AAtGD,MAAM,yBAAyB,GAAG,KAAK,IAAI,EAAE;IAC3C,MAAM,MAAM,GAAG,wDAAa,uBAAuB,GAAC,CAAC;IACrD,OAAO,MAAM,CAAC,OAAO,CAAC;AACxB,CAAC,CAAC;AAEF,iDAAqC;AACrC,+BAAiC;AACjC,qDAAiD;AACjD,2BAAuC;AAEvC,MAAM,SAAS,GAAG,IAAA,gBAAS,EAAC,oBAAI,CAAC,CAAC;AAClC,MAAM,WAAW,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;AACnC,MAAM,cAAc,GAAG,IAAI,CAAC;AAE5B,MAAM,MAAM,GAAG,IAAI,sBAAS,CAAC;IAC3B,SAAS,EAAE,KAAK;IAChB,YAAY,EAAE,IAAI;IAClB,YAAY,EAAE,IAAI;IAClB,SAAS,EAAE,WAAW;CACvB,CAAC,CAAC;AAEH,MAAM,GAAG,GAAG,6CAA6C,CAAC;AAG1D,SAAS,wBAAwB;IAC/B,MAAM,UAAU,GAAG,IAAA,sBAAiB,GAAE,CAAC;IACvC,KAAK,MAAM,CAAC,EAAE,SAAS,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;QACvD,IAAI,CAAC,SAAS;YAAE,SAAS;QACzB,KAAK,MAAM,IAAI,IAAI,SAAS,EAAE,CAAC;YAC7B,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;gBACnE,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,KAAK,UAAU,YAAY,CAAC,KAAU;IACpC,OAAO,IAAI,EAAE,CAAC;QACZ,IAAI,CAAC;YAEH,OAAO,CAAC,wBAAwB,EAAE,EAAE,CAAC;gBACnC,MAAM,CAAC,IAAI,CAAC,oDAAoD,CAAC,CAAC;gBAClE,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC;YACpE,CAAC;YAED,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;gBACpC,OAAO,EAAE,KAAK;gBACd,cAAc,EAAE,GAAG,EAAE,CAAC,IAAI;gBAC1B,OAAO,EAAE;oBACP,eAAe,EAAE,qCAAqC;oBACtD,QAAQ,EAAE,UAAU;oBACpB,SAAS,EAAE,GAAG;iBACf;aACF,CAAC,CAAC;YAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;YACzC,IAAI,CAAC,UAAU,EAAE,CAAC;gBAChB,MAAM,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAC;gBACpD,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC;gBAClE,SAAS;YACX,CAAC;YAED,MAAM,CAAC,IAAI,CAAC,+CAA+C,EAAE,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC;YAGzF,MAAM,QAAQ,GAAG;gBACf,iBAAiB,UAAU,GAAG;gBAC9B,wBAAwB;aACzB,CAAC;YAEF,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;gBAC/B,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;gBAC/D,IAAI,MAAM,EAAE,CAAC;oBACX,MAAM,CAAC,KAAK,CAAC,sCAAsC,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;oBACjF,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC;oBAClE,SAAS;gBACX,CAAC;YACH,CAAC;YAED,MAAM,CAAC,IAAI,CAAC,mDAAmD,CAAC,CAAC;YAEjE,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC;QAEjE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;YACxD,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;AACH,CAAC;AAGc,KAAK,UAAU,QAAQ;IACpC,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,yBAAyB,EAAE,CAAC,EAAE,CAAC;IAG1D,YAAY,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;QAChC,MAAM,CAAC,KAAK,CAAC,0CAA0C,EAAE,KAAK,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;IAGH,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;AAC3B,CAAC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DeviceCommand = void 0;
|
|
4
|
-
var DeviceCommand;
|
|
5
|
-
(function (DeviceCommand) {
|
|
6
|
-
DeviceCommand["Reboot"] = "reboot";
|
|
7
|
-
})(DeviceCommand || (exports.DeviceCommand = DeviceCommand = {}));
|
|
8
|
-
//# sourceMappingURL=command.types.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"command.types.js","sourceRoot":"","sources":["../../src/types/command.types.ts"],"names":[],"mappings":";;;AAAA,IAAY,aAEX;AAFD,WAAY,aAAa;IACvB,kCAAiB,CAAA;AACnB,CAAC,EAFW,aAAa,6BAAb,aAAa,QAExB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"container.types.js","sourceRoot":"","sources":["../../src/types/container.types.ts"],"names":[],"mappings":""}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.EventResponseStatus = void 0;
|
|
4
|
-
var EventResponseStatus;
|
|
5
|
-
(function (EventResponseStatus) {
|
|
6
|
-
EventResponseStatus["success"] = "success";
|
|
7
|
-
EventResponseStatus["error"] = "error";
|
|
8
|
-
})(EventResponseStatus || (exports.EventResponseStatus = EventResponseStatus = {}));
|
|
9
|
-
//# sourceMappingURL=event.types.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"event.types.js","sourceRoot":"","sources":["../../src/types/event.types.ts"],"names":[],"mappings":";;;AAEA,IAAY,mBAGX;AAHD,WAAY,mBAAmB;IAC7B,0CAAmB,CAAA;IACnB,sCAAe,CAAA;AACjB,CAAC,EAHW,mBAAmB,mCAAnB,mBAAmB,QAG9B"}
|
package/dist/types/job.types.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.JobTypeEnum = exports.JobStatusEnum = void 0;
|
|
4
|
-
var JobStatusEnum;
|
|
5
|
-
(function (JobStatusEnum) {
|
|
6
|
-
JobStatusEnum["Pending"] = "Pending";
|
|
7
|
-
JobStatusEnum["InProgress"] = "InProgress";
|
|
8
|
-
JobStatusEnum["Completed"] = "Completed";
|
|
9
|
-
})(JobStatusEnum || (exports.JobStatusEnum = JobStatusEnum = {}));
|
|
10
|
-
var JobTypeEnum;
|
|
11
|
-
(function (JobTypeEnum) {
|
|
12
|
-
JobTypeEnum["ScheduledCmd"] = "ScheduledCmd";
|
|
13
|
-
JobTypeEnum["InstantCmd"] = "InstantCmd";
|
|
14
|
-
})(JobTypeEnum || (exports.JobTypeEnum = JobTypeEnum = {}));
|
|
15
|
-
//# sourceMappingURL=job.types.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"job.types.js","sourceRoot":"","sources":["../../src/types/job.types.ts"],"names":[],"mappings":";;;AAEA,IAAY,aAIX;AAJD,WAAY,aAAa;IACvB,oCAAmB,CAAA;IACnB,0CAAyB,CAAA;IACzB,wCAAuB,CAAA;AACzB,CAAC,EAJW,aAAa,6BAAb,aAAa,QAIxB;AAED,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,4CAA6B,CAAA;IAC7B,wCAAyB,CAAA;AAC3B,CAAC,EAHW,WAAW,2BAAX,WAAW,QAGtB"}
|
package/dist/types/twin.types.js
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.TwinMessageResultStatus = exports.AvailabilityStatus = exports.TwinStatusEnum = exports.TwinTypeEnum = void 0;
|
|
4
|
-
var TwinTypeEnum;
|
|
5
|
-
(function (TwinTypeEnum) {
|
|
6
|
-
TwinTypeEnum["Device"] = "Device";
|
|
7
|
-
TwinTypeEnum["Screen"] = "Screen";
|
|
8
|
-
TwinTypeEnum["Edge"] = "Edge";
|
|
9
|
-
TwinTypeEnum["Cloud"] = "Cloud";
|
|
10
|
-
TwinTypeEnum["Web"] = "Web";
|
|
11
|
-
TwinTypeEnum["Peripheral"] = "Peripheral";
|
|
12
|
-
})(TwinTypeEnum || (exports.TwinTypeEnum = TwinTypeEnum = {}));
|
|
13
|
-
var TwinStatusEnum;
|
|
14
|
-
(function (TwinStatusEnum) {
|
|
15
|
-
TwinStatusEnum["Offline"] = "Offline";
|
|
16
|
-
TwinStatusEnum["Online"] = "Online";
|
|
17
|
-
TwinStatusEnum["Starting"] = "Starting";
|
|
18
|
-
TwinStatusEnum["Exited"] = "Exited";
|
|
19
|
-
TwinStatusEnum["ImageNotFound"] = "ImageNotFound";
|
|
20
|
-
})(TwinStatusEnum || (exports.TwinStatusEnum = TwinStatusEnum = {}));
|
|
21
|
-
var AvailabilityStatus;
|
|
22
|
-
(function (AvailabilityStatus) {
|
|
23
|
-
AvailabilityStatus["Available"] = "Available";
|
|
24
|
-
AvailabilityStatus["Unavailable"] = "Unavailable";
|
|
25
|
-
AvailabilityStatus["Unknown"] = "Unknown";
|
|
26
|
-
})(AvailabilityStatus || (exports.AvailabilityStatus = AvailabilityStatus = {}));
|
|
27
|
-
var TwinMessageResultStatus;
|
|
28
|
-
(function (TwinMessageResultStatus) {
|
|
29
|
-
TwinMessageResultStatus["Success"] = "success";
|
|
30
|
-
TwinMessageResultStatus["Error"] = "error";
|
|
31
|
-
TwinMessageResultStatus["Warning"] = "warning";
|
|
32
|
-
})(TwinMessageResultStatus || (exports.TwinMessageResultStatus = TwinMessageResultStatus = {}));
|
|
33
|
-
;
|
|
34
|
-
//# sourceMappingURL=twin.types.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"twin.types.js","sourceRoot":"","sources":["../../src/types/twin.types.ts"],"names":[],"mappings":";;;AAEA,IAAY,YAOX;AAPD,WAAY,YAAY;IACtB,iCAAiB,CAAA;IACjB,iCAAiB,CAAA;IACjB,6BAAa,CAAA;IACb,+BAAe,CAAA;IACf,2BAAW,CAAA;IACX,yCAAyB,CAAA;AAC3B,CAAC,EAPW,YAAY,4BAAZ,YAAY,QAOvB;AAED,IAAY,cAMX;AAND,WAAY,cAAc;IACxB,qCAAmB,CAAA;IACnB,mCAAiB,CAAA;IACjB,uCAAqB,CAAA;IACrB,mCAAiB,CAAA;IACjB,iDAA+B,CAAA;AACjC,CAAC,EANW,cAAc,8BAAd,cAAc,QAMzB;AA0TD,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,6CAAuB,CAAA;IACvB,iDAA2B,CAAA;IAC3B,yCAAmB,CAAA;AACrB,CAAC,EAJW,kBAAkB,kCAAlB,kBAAkB,QAI7B;AAucD,IAAY,uBAIX;AAJD,WAAY,uBAAuB;IACjC,8CAAmB,CAAA;IACnB,0CAAe,CAAA;IACf,8CAAmB,CAAA;AACrB,CAAC,EAJW,uBAAuB,uCAAvB,uBAAuB,QAIlC;AAAA,CAAC"}
|