@alwaysai/device-agent 1.5.0 → 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/lib/application-control/config.d.ts.map +1 -1
- package/lib/application-control/config.js +8 -3
- package/lib/application-control/config.js.map +1 -1
- package/lib/application-control/environment-variables.d.ts +1 -5
- package/lib/application-control/environment-variables.d.ts.map +1 -1
- package/lib/application-control/environment-variables.js +9 -26
- package/lib/application-control/environment-variables.js.map +1 -1
- package/lib/application-control/environment-variables.test.js +27 -7
- package/lib/application-control/environment-variables.test.js.map +1 -1
- package/lib/application-control/index.d.ts +4 -4
- package/lib/application-control/index.d.ts.map +1 -1
- package/lib/application-control/index.js +1 -4
- package/lib/application-control/index.js.map +1 -1
- package/lib/application-control/install.d.ts.map +1 -1
- package/lib/application-control/install.js +8 -7
- package/lib/application-control/install.js.map +1 -1
- package/lib/application-control/models.d.ts +0 -11
- package/lib/application-control/models.d.ts.map +1 -1
- package/lib/application-control/models.js +5 -54
- package/lib/application-control/models.js.map +1 -1
- package/lib/application-control/utils.d.ts +0 -4
- package/lib/application-control/utils.d.ts.map +1 -1
- package/lib/application-control/utils.js +1 -24
- package/lib/application-control/utils.js.map +1 -1
- package/lib/cloud-connection/bootstrap-provision.js +3 -2
- package/lib/cloud-connection/bootstrap-provision.js.map +1 -1
- package/lib/cloud-connection/device-agent-cloud-connection.d.ts +10 -15
- package/lib/cloud-connection/device-agent-cloud-connection.d.ts.map +1 -1
- package/lib/cloud-connection/device-agent-cloud-connection.js +279 -250
- package/lib/cloud-connection/device-agent-cloud-connection.js.map +1 -1
- package/lib/cloud-connection/device-agent.d.ts.map +1 -1
- package/lib/cloud-connection/device-agent.js +11 -9
- package/lib/cloud-connection/device-agent.js.map +1 -1
- package/lib/cloud-connection/live-updates-handler.d.ts +18 -28
- package/lib/cloud-connection/live-updates-handler.d.ts.map +1 -1
- package/lib/cloud-connection/live-updates-handler.js +54 -169
- package/lib/cloud-connection/live-updates-handler.js.map +1 -1
- package/lib/cloud-connection/live-updates-handler.test.js +71 -165
- package/lib/cloud-connection/live-updates-handler.test.js.map +1 -1
- package/lib/cloud-connection/passthrough-handler.d.ts +4 -1
- package/lib/cloud-connection/passthrough-handler.d.ts.map +1 -1
- package/lib/cloud-connection/passthrough-handler.js +30 -11
- package/lib/cloud-connection/passthrough-handler.js.map +1 -1
- package/lib/cloud-connection/shadow-handler.d.ts +5 -3
- package/lib/cloud-connection/shadow-handler.d.ts.map +1 -1
- package/lib/cloud-connection/shadow-handler.js +59 -27
- package/lib/cloud-connection/shadow-handler.js.map +1 -1
- package/lib/cloud-connection/shadow-handler.test.js +45 -57
- package/lib/cloud-connection/shadow-handler.test.js.map +1 -1
- package/lib/cloud-connection/shadow.d.ts.map +1 -1
- package/lib/cloud-connection/shadow.js +2 -1
- package/lib/cloud-connection/shadow.js.map +1 -1
- package/lib/cloud-connection/transaction-manager.d.ts +4 -2
- package/lib/cloud-connection/transaction-manager.d.ts.map +1 -1
- package/lib/cloud-connection/transaction-manager.js +18 -29
- package/lib/cloud-connection/transaction-manager.js.map +1 -1
- package/lib/cloud-connection/transaction-manager.test.js +3 -3
- package/lib/cloud-connection/transaction-manager.test.js.map +1 -1
- package/lib/device-control/device-control.d.ts +8 -8
- package/lib/device-control/device-control.d.ts.map +1 -1
- package/lib/device-control/device-control.js +95 -71
- package/lib/device-control/device-control.js.map +1 -1
- package/lib/docker/docker-compose.d.ts.map +1 -1
- package/lib/docker/docker-compose.js +2 -1
- package/lib/docker/docker-compose.js.map +1 -1
- package/lib/infrastructure/agent-config.d.ts +2 -1
- package/lib/infrastructure/agent-config.d.ts.map +1 -1
- package/lib/infrastructure/agent-config.js +7 -7
- package/lib/infrastructure/agent-config.js.map +1 -1
- package/lib/infrastructure/agent-config.test.js +3 -1
- package/lib/infrastructure/agent-config.test.js.map +1 -1
- package/lib/infrastructure/config-check-utility.d.ts +6 -0
- package/lib/infrastructure/config-check-utility.d.ts.map +1 -0
- package/lib/infrastructure/config-check-utility.js +67 -0
- package/lib/infrastructure/config-check-utility.js.map +1 -0
- package/lib/infrastructure/config-check-utility.test.d.ts +2 -0
- package/lib/infrastructure/config-check-utility.test.d.ts.map +1 -0
- package/lib/infrastructure/config-check-utility.test.js +109 -0
- package/lib/infrastructure/config-check-utility.test.js.map +1 -0
- package/lib/infrastructure/device-certificate.d.ts +10 -0
- package/lib/infrastructure/device-certificate.d.ts.map +1 -0
- package/lib/infrastructure/device-certificate.js +47 -0
- package/lib/infrastructure/device-certificate.js.map +1 -0
- package/lib/infrastructure/device-certificate.test.d.ts +2 -0
- package/lib/infrastructure/device-certificate.test.d.ts.map +1 -0
- package/lib/infrastructure/device-certificate.test.js +24 -0
- package/lib/infrastructure/device-certificate.test.js.map +1 -0
- package/lib/infrastructure/legacy-migration/legacy-file.test.d.ts +2 -0
- package/lib/infrastructure/legacy-migration/legacy-file.test.d.ts.map +1 -0
- package/lib/infrastructure/legacy-migration/legacy-file.test.js +61 -0
- package/lib/infrastructure/legacy-migration/legacy-file.test.js.map +1 -0
- package/lib/infrastructure/legacy-migration/legacy-files.d.ts +75 -0
- package/lib/infrastructure/legacy-migration/legacy-files.d.ts.map +1 -0
- package/lib/infrastructure/legacy-migration/legacy-files.js +75 -0
- package/lib/infrastructure/legacy-migration/legacy-files.js.map +1 -0
- package/lib/infrastructure/legacy-migration/legacy-migration.d.ts +6 -0
- package/lib/infrastructure/legacy-migration/legacy-migration.d.ts.map +1 -0
- package/lib/infrastructure/legacy-migration/legacy-migration.js +149 -0
- package/lib/infrastructure/legacy-migration/legacy-migration.js.map +1 -0
- package/lib/infrastructure/legacy-migration/legacy-migration.test.d.ts +2 -0
- package/lib/infrastructure/legacy-migration/legacy-migration.test.d.ts.map +1 -0
- package/lib/infrastructure/legacy-migration/legacy-migration.test.js +226 -0
- package/lib/infrastructure/legacy-migration/legacy-migration.test.js.map +1 -0
- package/lib/infrastructure/require-files-present-ready.test.d.ts +2 -0
- package/lib/infrastructure/require-files-present-ready.test.d.ts.map +1 -0
- package/lib/infrastructure/require-files-present-ready.test.js +44 -0
- package/lib/infrastructure/require-files-present-ready.test.js.map +1 -0
- package/lib/infrastructure/required-config-checks.d.ts +2 -0
- package/lib/infrastructure/required-config-checks.d.ts.map +1 -0
- package/lib/infrastructure/required-config-checks.js +30 -0
- package/lib/infrastructure/required-config-checks.js.map +1 -0
- package/lib/infrastructure/tokens-and-device-cfg.d.ts.map +1 -1
- package/lib/infrastructure/tokens-and-device-cfg.js +11 -8
- package/lib/infrastructure/tokens-and-device-cfg.js.map +1 -1
- package/lib/local-connection/rabbitmq-connection.d.ts.map +1 -1
- package/lib/local-connection/rabbitmq-connection.js +14 -14
- package/lib/local-connection/rabbitmq-connection.js.map +1 -1
- package/lib/secure-tunneling/secure-tunneling.d.ts +9 -9
- package/lib/secure-tunneling/secure-tunneling.d.ts.map +1 -1
- package/lib/secure-tunneling/secure-tunneling.js +21 -16
- package/lib/secure-tunneling/secure-tunneling.js.map +1 -1
- package/lib/secure-tunneling/secure-tunneling.test.js +11 -13
- package/lib/secure-tunneling/secure-tunneling.test.js.map +1 -1
- package/lib/subcommands/app/analytics.d.ts.map +1 -1
- package/lib/subcommands/app/analytics.js +1 -2
- package/lib/subcommands/app/analytics.js.map +1 -1
- package/lib/subcommands/app/env-vars.d.ts +4 -0
- package/lib/subcommands/app/env-vars.d.ts.map +1 -1
- package/lib/subcommands/app/env-vars.js +52 -6
- package/lib/subcommands/app/env-vars.js.map +1 -1
- package/lib/subcommands/app/index.d.ts.map +1 -1
- package/lib/subcommands/app/index.js +1 -3
- package/lib/subcommands/app/index.js.map +1 -1
- package/lib/subcommands/app/models.d.ts +0 -11
- package/lib/subcommands/app/models.d.ts.map +1 -1
- package/lib/subcommands/app/models.js +2 -58
- package/lib/subcommands/app/models.js.map +1 -1
- package/lib/subcommands/app/shadow.d.ts.map +1 -1
- package/lib/subcommands/app/shadow.js +6 -5
- package/lib/subcommands/app/shadow.js.map +1 -1
- package/lib/subcommands/app/version.d.ts.map +1 -1
- package/lib/subcommands/app/version.js +2 -4
- package/lib/subcommands/app/version.js.map +1 -1
- package/lib/subcommands/config.d.ts +2 -0
- package/lib/subcommands/config.d.ts.map +1 -0
- package/lib/subcommands/config.js +39 -0
- package/lib/subcommands/config.js.map +1 -0
- package/lib/subcommands/device/clean.d.ts +1 -1
- package/lib/subcommands/device/clean.d.ts.map +1 -1
- package/lib/subcommands/device/clean.js +23 -13
- package/lib/subcommands/device/clean.js.map +1 -1
- package/lib/subcommands/device/index.d.ts.map +1 -1
- package/lib/subcommands/device/index.js +3 -1
- package/lib/subcommands/device/index.js.map +1 -1
- package/lib/subcommands/device/init.js +8 -8
- package/lib/subcommands/device/init.js.map +1 -1
- package/lib/subcommands/device/migrate.d.ts +2 -0
- package/lib/subcommands/device/migrate.d.ts.map +1 -0
- package/lib/subcommands/device/migrate.js +24 -0
- package/lib/subcommands/device/migrate.js.map +1 -0
- package/lib/subcommands/device/refresh.d.ts.map +1 -1
- package/lib/subcommands/device/refresh.js +1 -0
- package/lib/subcommands/device/refresh.js.map +1 -1
- package/lib/subcommands/index.d.ts +1 -1
- package/lib/subcommands/index.d.ts.map +1 -1
- package/lib/subcommands/index.js +3 -1
- package/lib/subcommands/index.js.map +1 -1
- package/lib/subcommands/rabbitmq-connection.d.ts +1 -1
- package/lib/subcommands/rabbitmq-connection.d.ts.map +1 -1
- package/lib/util/aai-error.d.ts +12 -0
- package/lib/util/aai-error.d.ts.map +1 -0
- package/lib/util/aai-error.js +11 -0
- package/lib/util/aai-error.js.map +1 -0
- package/lib/util/aws-regions.d.ts +2 -0
- package/lib/util/aws-regions.d.ts.map +1 -0
- package/lib/util/{cloud-mode-ready.js → aws-regions.js} +2 -20
- package/lib/util/aws-regions.js.map +1 -0
- package/lib/util/check-for-updates.d.ts.map +1 -1
- package/lib/util/check-for-updates.js +5 -28
- package/lib/util/check-for-updates.js.map +1 -1
- package/lib/util/clean-certs.d.ts.map +1 -1
- package/lib/util/clean-certs.js +5 -4
- package/lib/util/clean-certs.js.map +1 -1
- package/lib/util/directories.d.ts +4 -18
- package/lib/util/directories.d.ts.map +1 -1
- package/lib/util/directories.js +18 -32
- package/lib/util/directories.js.map +1 -1
- package/lib/util/file.d.ts +4 -0
- package/lib/util/file.d.ts.map +1 -1
- package/lib/util/file.js +65 -4
- package/lib/util/file.js.map +1 -1
- package/lib/util/get-device-id.d.ts.map +1 -1
- package/lib/util/get-device-id.js +7 -1
- package/lib/util/get-device-id.js.map +1 -1
- package/lib/util/http-client.js +3 -3
- package/lib/util/http-client.js.map +1 -1
- package/package.json +19 -17
- package/readme.md +12 -32
- package/src/application-control/config.ts +9 -12
- package/src/application-control/environment-variables.test.ts +28 -7
- package/src/application-control/environment-variables.ts +13 -40
- package/src/application-control/index.ts +3 -16
- package/src/application-control/install.ts +15 -10
- package/src/application-control/models.ts +6 -87
- package/src/application-control/utils.ts +0 -28
- package/src/cloud-connection/bootstrap-provision.ts +7 -7
- package/src/cloud-connection/device-agent-cloud-connection.ts +639 -525
- package/src/cloud-connection/device-agent.ts +16 -7
- package/src/cloud-connection/live-updates-handler.test.ts +121 -189
- package/src/cloud-connection/live-updates-handler.ts +99 -234
- package/src/cloud-connection/passthrough-handler.ts +55 -18
- package/src/cloud-connection/shadow-handler.test.ts +45 -57
- package/src/cloud-connection/shadow-handler.ts +103 -57
- package/src/cloud-connection/shadow.ts +4 -1
- package/src/cloud-connection/transaction-manager.test.ts +3 -3
- package/src/cloud-connection/transaction-manager.ts +53 -39
- package/src/device-control/device-control.ts +102 -70
- package/src/docker/docker-compose.ts +3 -2
- package/src/infrastructure/agent-config.test.ts +6 -2
- package/src/infrastructure/agent-config.ts +8 -7
- package/src/infrastructure/config-check-utility.test.ts +154 -0
- package/src/infrastructure/config-check-utility.ts +77 -0
- package/src/infrastructure/device-certificate.test.ts +40 -0
- package/src/infrastructure/device-certificate.ts +58 -0
- package/src/infrastructure/legacy-migration/legacy-file.test.ts +88 -0
- package/src/infrastructure/legacy-migration/legacy-files.ts +101 -0
- package/src/infrastructure/legacy-migration/legacy-migration.test.ts +396 -0
- package/src/infrastructure/legacy-migration/legacy-migration.ts +229 -0
- package/src/infrastructure/require-files-present-ready.test.ts +53 -0
- package/src/infrastructure/required-config-checks.ts +33 -0
- package/src/infrastructure/tokens-and-device-cfg.ts +12 -10
- package/src/local-connection/rabbitmq-connection.ts +22 -17
- package/src/secure-tunneling/secure-tunneling.test.ts +20 -22
- package/src/secure-tunneling/secure-tunneling.ts +41 -29
- package/src/subcommands/app/analytics.ts +2 -4
- package/src/subcommands/app/env-vars.ts +72 -9
- package/src/subcommands/app/index.ts +3 -11
- package/src/subcommands/app/models.ts +5 -81
- package/src/subcommands/app/shadow.ts +6 -5
- package/src/subcommands/app/version.ts +3 -4
- package/src/subcommands/config.ts +42 -0
- package/src/subcommands/device/clean.ts +31 -17
- package/src/subcommands/device/index.ts +3 -1
- package/src/subcommands/device/init.ts +11 -11
- package/src/subcommands/device/migrate.ts +20 -0
- package/src/subcommands/device/refresh.ts +1 -0
- package/src/subcommands/index.ts +3 -1
- package/src/util/aai-error.ts +20 -0
- package/src/util/{cloud-mode-ready.ts → aws-regions.ts} +0 -24
- package/src/util/check-for-updates.ts +14 -30
- package/src/util/clean-certs.ts +8 -4
- package/src/util/directories.ts +23 -67
- package/src/util/file.ts +83 -3
- package/src/util/get-device-id.ts +7 -7
- package/src/util/http-client.ts +2 -2
- package/lib/util/cloud-mode-ready.d.ts +0 -3
- package/lib/util/cloud-mode-ready.d.ts.map +0 -1
- package/lib/util/cloud-mode-ready.js.map +0 -1
- package/lib/util/download-file.d.ts +0 -6
- package/lib/util/download-file.d.ts.map +0 -1
- package/lib/util/download-file.js +0 -25
- package/lib/util/download-file.js.map +0 -1
- package/lib/util/fetch-with-timeout.d.ts +0 -4
- package/lib/util/fetch-with-timeout.d.ts.map +0 -1
- package/lib/util/fetch-with-timeout.js +0 -30
- package/lib/util/fetch-with-timeout.js.map +0 -1
- package/lib/util/parsing.d.ts +0 -2
- package/lib/util/parsing.d.ts.map +0 -1
- package/lib/util/parsing.js +0 -17
- package/lib/util/parsing.js.map +0 -1
- package/src/util/download-file.ts +0 -25
- package/src/util/fetch-with-timeout.ts +0 -35
- package/src/util/parsing.ts +0 -11
package/src/util/file.ts
CHANGED
|
@@ -2,6 +2,8 @@ import { rimraf } from 'rimraf';
|
|
|
2
2
|
import { logger } from '../util/logger';
|
|
3
3
|
import { readdir, stat, unlink, rmdir } from 'fs/promises';
|
|
4
4
|
import { join } from 'path';
|
|
5
|
+
import { stringifyError } from 'alwaysai/lib/util';
|
|
6
|
+
import { writeFileSync } from 'fs';
|
|
5
7
|
|
|
6
8
|
export async function safeRimraf(path: string) {
|
|
7
9
|
logger.debug(`Removing ${path}`);
|
|
@@ -11,7 +13,7 @@ export async function safeRimraf(path: string) {
|
|
|
11
13
|
logger.error(
|
|
12
14
|
`Failed to remove ${path}. Please manually delete the file or directory.`
|
|
13
15
|
);
|
|
14
|
-
logger.debug(`Error removing ${path}
|
|
16
|
+
logger.debug(`Error removing ${path}:\n${stringifyError(e)}`);
|
|
15
17
|
}
|
|
16
18
|
}
|
|
17
19
|
|
|
@@ -69,8 +71,86 @@ export async function pruneDir({
|
|
|
69
71
|
}
|
|
70
72
|
}
|
|
71
73
|
return canPruneParent;
|
|
72
|
-
} catch (
|
|
73
|
-
logger.error(`Error pruning directory ${path}
|
|
74
|
+
} catch (e) {
|
|
75
|
+
logger.error(`Error pruning directory ${path}!\n${stringifyError(e)}`);
|
|
74
76
|
return false;
|
|
75
77
|
}
|
|
76
78
|
}
|
|
79
|
+
|
|
80
|
+
export async function downloadToFile({
|
|
81
|
+
path,
|
|
82
|
+
url
|
|
83
|
+
}: {
|
|
84
|
+
path: string;
|
|
85
|
+
url: string;
|
|
86
|
+
}) {
|
|
87
|
+
const response = await fetch(url);
|
|
88
|
+
|
|
89
|
+
if (!response.ok) {
|
|
90
|
+
throw new Error(`Failed to fetch ${url}: ${response.statusText}`);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
const contentLength = response.headers.get('content-length');
|
|
94
|
+
const reader = response.body?.getReader();
|
|
95
|
+
|
|
96
|
+
if (reader) {
|
|
97
|
+
const chunks: Uint8Array[] = [];
|
|
98
|
+
const totalSize = contentLength ? parseInt(contentLength) : undefined;
|
|
99
|
+
|
|
100
|
+
const PROGRESS_PERC_LOG_INCREMENT = 5;
|
|
101
|
+
const BYTE_DOWNLOAD_LOG_INCREMENT = 5_000_000;
|
|
102
|
+
const [baseUrl, urlParams] = url.split('?');
|
|
103
|
+
const urlForLog = `${baseUrl}${
|
|
104
|
+
urlParams?.length ? `...(${urlParams.length} more characters)` : ''
|
|
105
|
+
}`;
|
|
106
|
+
let totalDownloadedBytes = 0;
|
|
107
|
+
let downloadedSize = 0;
|
|
108
|
+
let totalProgressPerc = 0;
|
|
109
|
+
|
|
110
|
+
// eslint-disable-next-line
|
|
111
|
+
while (true) {
|
|
112
|
+
const { done, value } = await reader.read();
|
|
113
|
+
if (done) {
|
|
114
|
+
logger.info(`Download complete - ${urlForLog}`);
|
|
115
|
+
break;
|
|
116
|
+
}
|
|
117
|
+
if (value) {
|
|
118
|
+
chunks.push(value);
|
|
119
|
+
downloadedSize += value.length;
|
|
120
|
+
if (totalSize) {
|
|
121
|
+
const progress = (downloadedSize / totalSize) * 100;
|
|
122
|
+
if (progress > totalProgressPerc + PROGRESS_PERC_LOG_INCREMENT) {
|
|
123
|
+
totalProgressPerc += PROGRESS_PERC_LOG_INCREMENT;
|
|
124
|
+
logger.debug(
|
|
125
|
+
`Download progress: ${progress.toFixed(2)}% - ${urlForLog}`
|
|
126
|
+
);
|
|
127
|
+
}
|
|
128
|
+
} else {
|
|
129
|
+
if (
|
|
130
|
+
downloadedSize >
|
|
131
|
+
totalDownloadedBytes + BYTE_DOWNLOAD_LOG_INCREMENT
|
|
132
|
+
) {
|
|
133
|
+
totalDownloadedBytes += BYTE_DOWNLOAD_LOG_INCREMENT;
|
|
134
|
+
logger.debug(
|
|
135
|
+
`Download progress: ${downloadedSize} total bytes - ${urlForLog}`
|
|
136
|
+
);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
logger.debug(`Writing downloaded chunks to file ${path}`);
|
|
143
|
+
const combinedSize = chunks.reduce((acc, chunk) => acc + chunk.length, 0);
|
|
144
|
+
const combinedChunks = new Uint8Array(combinedSize);
|
|
145
|
+
|
|
146
|
+
let offset = 0;
|
|
147
|
+
for (const chunk of chunks) {
|
|
148
|
+
combinedChunks.set(chunk, offset);
|
|
149
|
+
offset += chunk.length;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
writeFileSync(path, combinedChunks);
|
|
153
|
+
} else {
|
|
154
|
+
throw new Error('Unable to access response body when downloading file.');
|
|
155
|
+
}
|
|
156
|
+
}
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
import { DeviceConfigFile } from 'alwaysai/lib/core/device';
|
|
2
|
+
import { logger } from './logger';
|
|
3
|
+
import { stringifyError } from 'alwaysai/lib/util';
|
|
4
|
+
import AaiError from './aai-error';
|
|
2
5
|
|
|
3
6
|
export function getDeviceUuid() {
|
|
4
7
|
const deviceCfgFile = DeviceConfigFile();
|
|
@@ -9,12 +12,9 @@ export function getDeviceUuid() {
|
|
|
9
12
|
const cfg = deviceCfgFile.read();
|
|
10
13
|
return cfg.deviceUuid;
|
|
11
14
|
} catch (e) {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
2
|
|
17
|
-
)}`
|
|
18
|
-
);
|
|
15
|
+
logger.error(`Failed to read device configuration!\n${stringifyError(e)}`);
|
|
16
|
+
throw new AaiError('Failed to read device configuration', {
|
|
17
|
+
cause: deviceCfgFile.getErrors()
|
|
18
|
+
});
|
|
19
19
|
}
|
|
20
20
|
}
|
package/src/util/http-client.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import fetch from 'node-fetch';
|
|
2
1
|
import { serviceEndpointBuilder } from '../endpoints';
|
|
3
2
|
import { CliAuthenticationClient } from 'alwaysai/lib/infrastructure';
|
|
4
3
|
import { logger } from '../util/logger';
|
|
4
|
+
import { stringifyError } from 'alwaysai/lib/util';
|
|
5
5
|
|
|
6
6
|
export async function httpClient(
|
|
7
7
|
url: string,
|
|
@@ -23,7 +23,7 @@ export async function httpClient(
|
|
|
23
23
|
return await response.text();
|
|
24
24
|
}
|
|
25
25
|
} catch (e) {
|
|
26
|
-
logger.error(`HTTP Client error for ${url}
|
|
26
|
+
logger.error(`HTTP Client error for ${url}:\n${stringifyError(e)}`);
|
|
27
27
|
}
|
|
28
28
|
}
|
|
29
29
|
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cloud-mode-ready.d.ts","sourceRoot":"","sources":["../../src/util/cloud-mode-ready.ts"],"names":[],"mappings":"AAuCA,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAExD;AAED,wBAAgB,cAAc,YAe7B"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cloud-mode-ready.js","sourceRoot":"","sources":["../../src/util/cloud-mode-ready.ts"],"names":[],"mappings":";;;AAAA,2BAAgC;AAChC,qDAI6B;AAE7B,MAAM,iBAAiB,GAAG;IACxB,sCAAsC;IACtC,2CAA2C;IAC3C,4CAA4C;IAC5C,4CAA4C;IAC5C,4CAA4C;IAC5C,4CAA4C;IAC5C,yCAAyC;IACzC,gDAAgD;IAChD,6CAA6C;IAC7C,8CAA8C;IAC9C,gDAAgD;IAChD,sCAAsC;IACtC,wCAAwC;IACxC,kCAAkC;IAClC,iCAAiC;IACjC,wCAAwC;IACxC,qCAAqC;IACrC,sCAAsC;IACtC,kCAAkC;IAClC,kCAAkC;IAClC,mCAAmC;IACnC,uCAAuC;IACvC,yCAAyC;IACzC,uCAAuC;IACvC,2CAA2C;IAC3C,iCAAiC;IACjC,qCAAqC;IACrC,0CAA0C;IAC1C,WAAW,CAAC,mBAAmB;CAChC,CAAC;AAEF,SAAgB,gBAAgB,CAAC,MAAc;IAC7C,OAAO,iBAAiB,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;AAC5C,CAAC;AAFD,4CAEC;AAED,SAAgB,cAAc;IAC5B,IAAI,KAAK,GAAG,IAAI,CAAC;IACjB,MAAM,aAAa,GAAG;QACpB,0CAA4B;QAC5B,0CAA4B;QAC5B,4CAA8B;KAC/B,CAAC;IAEF,KAAK,MAAM,IAAI,IAAI,aAAa,EAAE;QAChC,IAAI,CAAC,IAAA,eAAU,EAAC,IAAI,CAAC,EAAE;YACrB,KAAK,GAAG,KAAK,CAAC;YACd,MAAM;SACP;KACF;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAfD,wCAeC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"download-file.d.ts","sourceRoot":"","sources":["../../src/util/download-file.ts"],"names":[],"mappings":"AAIA,wBAAsB,YAAY,CAAC,KAAK,EAAE;IACxC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,EAAE,MAAM,CAAC;CACtB,GAAG,OAAO,CAAC,IAAI,CAAC,CAgBhB"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.downloadFile = void 0;
|
|
4
|
-
const fs = require("fs");
|
|
5
|
-
const fetch_with_timeout_1 = require("./fetch-with-timeout");
|
|
6
|
-
const logger_1 = require("./logger");
|
|
7
|
-
async function downloadFile(props) {
|
|
8
|
-
const { url, path, errorMessage } = props;
|
|
9
|
-
logger_1.logger.debug(`Downloading package from ${url}`);
|
|
10
|
-
let response;
|
|
11
|
-
try {
|
|
12
|
-
response = await (0, fetch_with_timeout_1.fetchWithTimeout)(url);
|
|
13
|
-
}
|
|
14
|
-
catch (e) {
|
|
15
|
-
const errorBody = e.type === 'aborted' ? e : await e.response.text();
|
|
16
|
-
throw new Error(`${errorMessage}: Error=${e}\n${errorBody}`);
|
|
17
|
-
}
|
|
18
|
-
const stream = response.body.pipe(fs.createWriteStream(path));
|
|
19
|
-
await new Promise((resolve, reject) => {
|
|
20
|
-
stream.on('finish', resolve);
|
|
21
|
-
stream.on('error', reject);
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
exports.downloadFile = downloadFile;
|
|
25
|
-
//# sourceMappingURL=download-file.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"download-file.js","sourceRoot":"","sources":["../../src/util/download-file.ts"],"names":[],"mappings":";;;AAAA,yBAAyB;AACzB,6DAAwD;AACxD,qCAAkC;AAE3B,KAAK,UAAU,YAAY,CAAC,KAIlC;IACC,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG,KAAK,CAAC;IAC1C,eAAM,CAAC,KAAK,CAAC,4BAA4B,GAAG,EAAE,CAAC,CAAC;IAChD,IAAI,QAAa,CAAC;IAClB,IAAI;QACF,QAAQ,GAAG,MAAM,IAAA,qCAAgB,EAAC,GAAG,CAAC,CAAC;KACxC;IAAC,OAAO,CAAC,EAAE;QACV,MAAM,SAAS,GAAG,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrE,MAAM,IAAI,KAAK,CAAC,GAAG,YAAY,WAAW,CAAC,KAAK,SAAS,EAAE,CAAC,CAAC;KAC9D;IAED,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9D,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACpC,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QAC7B,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;AACL,CAAC;AApBD,oCAoBC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fetch-with-timeout.d.ts","sourceRoot":"","sources":["../../src/util/fetch-with-timeout.ts"],"names":[],"mappings":"AAmBA,wBAAsB,gBAAgB,CACpC,GAAG,EAAE,MAAM,EACX,OAAO,GAAE;IAAE,OAAO,CAAC,EAAE,MAAM,CAAA;CAAO,gBAanC"}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.fetchWithTimeout = void 0;
|
|
4
|
-
const node_fetch_1 = require("node-fetch");
|
|
5
|
-
class HTTPResponseError extends Error {
|
|
6
|
-
constructor(response) {
|
|
7
|
-
super(`HTTP Error Response: ${response.status} ${response.statusText}`);
|
|
8
|
-
this.response = response;
|
|
9
|
-
}
|
|
10
|
-
}
|
|
11
|
-
const checkStatus = (response) => {
|
|
12
|
-
if (response.ok) {
|
|
13
|
-
// response.status >= 200 && response.status < 300
|
|
14
|
-
return response;
|
|
15
|
-
}
|
|
16
|
-
else {
|
|
17
|
-
throw new HTTPResponseError(response);
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
async function fetchWithTimeout(url, options = {}) {
|
|
21
|
-
//time (ms)
|
|
22
|
-
const { timeout = 60000 } = options;
|
|
23
|
-
const controller = new AbortController();
|
|
24
|
-
const id = setTimeout(() => controller.abort(), timeout);
|
|
25
|
-
const response = await (0, node_fetch_1.default)(url, Object.assign(Object.assign({}, options), { signal: controller.signal }));
|
|
26
|
-
clearTimeout(id);
|
|
27
|
-
return checkStatus(response);
|
|
28
|
-
}
|
|
29
|
-
exports.fetchWithTimeout = fetchWithTimeout;
|
|
30
|
-
//# sourceMappingURL=fetch-with-timeout.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fetch-with-timeout.js","sourceRoot":"","sources":["../../src/util/fetch-with-timeout.ts"],"names":[],"mappings":";;;AAAA,2CAAmC;AAEnC,MAAM,iBAAkB,SAAQ,KAAK;IAEnC,YAAY,QAAQ;QAClB,KAAK,CAAC,wBAAwB,QAAQ,CAAC,MAAM,IAAI,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC;QACxE,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;CACF;AAED,MAAM,WAAW,GAAG,CAAC,QAAQ,EAAE,EAAE;IAC/B,IAAI,QAAQ,CAAC,EAAE,EAAE;QACf,kDAAkD;QAClD,OAAO,QAAQ,CAAC;KACjB;SAAM;QACL,MAAM,IAAI,iBAAiB,CAAC,QAAQ,CAAC,CAAC;KACvC;AACH,CAAC,CAAC;AAEK,KAAK,UAAU,gBAAgB,CACpC,GAAW,EACX,UAAgC,EAAE;IAElC,WAAW;IACX,MAAM,EAAE,OAAO,GAAG,KAAK,EAAE,GAAG,OAAO,CAAC;IAEpC,MAAM,UAAU,GAAG,IAAI,eAAe,EAAE,CAAC;IACzC,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,OAAO,CAAC,CAAC;IACzD,MAAM,QAAQ,GAAG,MAAM,IAAA,oBAAS,EAAC,GAAG,kCAC/B,OAAO,KACV,MAAM,EAAE,UAAU,CAAC,MAAM,IACzB,CAAC;IACH,YAAY,CAAC,EAAE,CAAC,CAAC;IACjB,OAAO,WAAW,CAAC,QAAQ,CAAC,CAAC;AAC/B,CAAC;AAfD,4CAeC"}
|
package/lib/util/parsing.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"parsing.d.ts","sourceRoot":"","sources":["../../src/util/parsing.ts"],"names":[],"mappings":"AAAA,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,QAUtE"}
|
package/lib/util/parsing.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.replaceFalseyWithNull = void 0;
|
|
4
|
-
function replaceFalseyWithNull(object, recurse) {
|
|
5
|
-
if (typeof object === 'string' || object instanceof String)
|
|
6
|
-
return;
|
|
7
|
-
object &&
|
|
8
|
-
Object.keys(object).forEach((key) => {
|
|
9
|
-
if (recurse) {
|
|
10
|
-
replaceFalseyWithNull(object[key], recurse);
|
|
11
|
-
}
|
|
12
|
-
if (!object[key])
|
|
13
|
-
object[key] = null;
|
|
14
|
-
});
|
|
15
|
-
}
|
|
16
|
-
exports.replaceFalseyWithNull = replaceFalseyWithNull;
|
|
17
|
-
//# sourceMappingURL=parsing.js.map
|
package/lib/util/parsing.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"parsing.js","sourceRoot":"","sources":["../../src/util/parsing.ts"],"names":[],"mappings":";;;AAAA,SAAgB,qBAAqB,CAAC,MAAc,EAAE,OAAiB;IACrE,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,MAAM,YAAY,MAAM;QAAE,OAAO;IAEnE,MAAM;QACJ,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,GAAW,EAAE,EAAE;YAC1C,IAAI,OAAO,EAAE;gBACX,qBAAqB,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,CAAC;aAC7C;YACD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC;gBAAE,MAAM,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QACvC,CAAC,CAAC,CAAC;AACP,CAAC;AAVD,sDAUC"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import * as fs from 'fs';
|
|
2
|
-
import { fetchWithTimeout } from './fetch-with-timeout';
|
|
3
|
-
import { logger } from './logger';
|
|
4
|
-
|
|
5
|
-
export async function downloadFile(props: {
|
|
6
|
-
url: string;
|
|
7
|
-
path: string;
|
|
8
|
-
errorMessage: string;
|
|
9
|
-
}): Promise<void> {
|
|
10
|
-
const { url, path, errorMessage } = props;
|
|
11
|
-
logger.debug(`Downloading package from ${url}`);
|
|
12
|
-
let response: any;
|
|
13
|
-
try {
|
|
14
|
-
response = await fetchWithTimeout(url);
|
|
15
|
-
} catch (e) {
|
|
16
|
-
const errorBody = e.type === 'aborted' ? e : await e.response.text();
|
|
17
|
-
throw new Error(`${errorMessage}: Error=${e}\n${errorBody}`);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
const stream = response.body.pipe(fs.createWriteStream(path));
|
|
21
|
-
await new Promise((resolve, reject) => {
|
|
22
|
-
stream.on('finish', resolve);
|
|
23
|
-
stream.on('error', reject);
|
|
24
|
-
});
|
|
25
|
-
}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import nodeFetch from 'node-fetch';
|
|
2
|
-
|
|
3
|
-
class HTTPResponseError extends Error {
|
|
4
|
-
public response;
|
|
5
|
-
constructor(response) {
|
|
6
|
-
super(`HTTP Error Response: ${response.status} ${response.statusText}`);
|
|
7
|
-
this.response = response;
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
const checkStatus = (response) => {
|
|
12
|
-
if (response.ok) {
|
|
13
|
-
// response.status >= 200 && response.status < 300
|
|
14
|
-
return response;
|
|
15
|
-
} else {
|
|
16
|
-
throw new HTTPResponseError(response);
|
|
17
|
-
}
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
export async function fetchWithTimeout(
|
|
21
|
-
url: string,
|
|
22
|
-
options: { timeout?: number } = {}
|
|
23
|
-
) {
|
|
24
|
-
//time (ms)
|
|
25
|
-
const { timeout = 60000 } = options;
|
|
26
|
-
|
|
27
|
-
const controller = new AbortController();
|
|
28
|
-
const id = setTimeout(() => controller.abort(), timeout);
|
|
29
|
-
const response = await nodeFetch(url, {
|
|
30
|
-
...options,
|
|
31
|
-
signal: controller.signal
|
|
32
|
-
});
|
|
33
|
-
clearTimeout(id);
|
|
34
|
-
return checkStatus(response);
|
|
35
|
-
}
|
package/src/util/parsing.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export function replaceFalseyWithNull(object: object, recurse?: boolean) {
|
|
2
|
-
if (typeof object === 'string' || object instanceof String) return;
|
|
3
|
-
|
|
4
|
-
object &&
|
|
5
|
-
Object.keys(object).forEach((key: string) => {
|
|
6
|
-
if (recurse) {
|
|
7
|
-
replaceFalseyWithNull(object[key], recurse);
|
|
8
|
-
}
|
|
9
|
-
if (!object[key]) object[key] = null;
|
|
10
|
-
});
|
|
11
|
-
}
|