@alwaysai/device-agent 2.0.2 → 2.1.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.
Files changed (146) hide show
  1. package/lib/application-control/config.js +1 -1
  2. package/lib/application-control/config.js.map +1 -1
  3. package/lib/application-control/install.d.ts.map +1 -1
  4. package/lib/application-control/install.js +2 -2
  5. package/lib/application-control/install.js.map +1 -1
  6. package/lib/cloud-connection/base-message-handler.d.ts.map +1 -1
  7. package/lib/cloud-connection/base-message-handler.js +5 -4
  8. package/lib/cloud-connection/base-message-handler.js.map +1 -1
  9. package/lib/cloud-connection/bootstrap-agent.d.ts +16 -0
  10. package/lib/cloud-connection/bootstrap-agent.d.ts.map +1 -0
  11. package/lib/cloud-connection/{device-agent.js → bootstrap-agent.js} +45 -22
  12. package/lib/cloud-connection/bootstrap-agent.js.map +1 -0
  13. package/lib/cloud-connection/connection-manager.d.ts +18 -6
  14. package/lib/cloud-connection/connection-manager.d.ts.map +1 -1
  15. package/lib/cloud-connection/connection-manager.js +85 -38
  16. package/lib/cloud-connection/connection-manager.js.map +1 -1
  17. package/lib/cloud-connection/device-agent-cloud-connection.d.ts.map +1 -1
  18. package/lib/cloud-connection/device-agent-cloud-connection.js +13 -12
  19. package/lib/cloud-connection/device-agent-cloud-connection.js.map +1 -1
  20. package/lib/cloud-connection/device-agent-message-handler.d.ts.map +1 -1
  21. package/lib/cloud-connection/device-agent-message-handler.js +19 -18
  22. package/lib/cloud-connection/device-agent-message-handler.js.map +1 -1
  23. package/lib/cloud-connection/live-updates-handler.d.ts.map +1 -1
  24. package/lib/cloud-connection/live-updates-handler.js +11 -4
  25. package/lib/cloud-connection/live-updates-handler.js.map +1 -1
  26. package/lib/cloud-connection/passthrough-handler.d.ts +3 -3
  27. package/lib/cloud-connection/passthrough-handler.d.ts.map +1 -1
  28. package/lib/cloud-connection/passthrough-handler.js +105 -79
  29. package/lib/cloud-connection/passthrough-handler.js.map +1 -1
  30. package/lib/cloud-connection/publisher.d.ts +1 -1
  31. package/lib/cloud-connection/publisher.d.ts.map +1 -1
  32. package/lib/cloud-connection/publisher.js +22 -20
  33. package/lib/cloud-connection/publisher.js.map +1 -1
  34. package/lib/cloud-connection/shadow-handler.js +3 -3
  35. package/lib/cloud-connection/shadow-handler.js.map +1 -1
  36. package/lib/cloud-connection/shadow.d.ts.map +1 -1
  37. package/lib/cloud-connection/shadow.js +1 -1
  38. package/lib/cloud-connection/shadow.js.map +1 -1
  39. package/lib/cloud-connection/transaction-manager.d.ts.map +1 -1
  40. package/lib/cloud-connection/transaction-manager.js +17 -7
  41. package/lib/cloud-connection/transaction-manager.js.map +1 -1
  42. package/lib/cloud-connection/transaction-manager.test.js +52 -44
  43. package/lib/cloud-connection/transaction-manager.test.js.map +1 -1
  44. package/lib/device-control/device-control.d.ts.map +1 -1
  45. package/lib/device-control/device-control.js +13 -9
  46. package/lib/device-control/device-control.js.map +1 -1
  47. package/lib/docker/docker-compose.d.ts.map +1 -1
  48. package/lib/docker/docker-compose.js +1 -1
  49. package/lib/docker/docker-compose.js.map +1 -1
  50. package/lib/environment.d.ts.map +1 -1
  51. package/lib/environment.js +1 -1
  52. package/lib/environment.js.map +1 -1
  53. package/lib/index.js +12 -0
  54. package/lib/index.js.map +1 -1
  55. package/lib/infrastructure/config-check-utility.js +2 -2
  56. package/lib/infrastructure/config-check-utility.js.map +1 -1
  57. package/lib/infrastructure/legacy-migration/legacy-migration.d.ts.map +1 -1
  58. package/lib/infrastructure/legacy-migration/legacy-migration.js +6 -10
  59. package/lib/infrastructure/legacy-migration/legacy-migration.js.map +1 -1
  60. package/lib/local-connection/rabbitmq-container.d.ts +6 -0
  61. package/lib/local-connection/rabbitmq-container.d.ts.map +1 -0
  62. package/lib/local-connection/rabbitmq-container.js +111 -0
  63. package/lib/local-connection/rabbitmq-container.js.map +1 -0
  64. package/lib/local-connection/rabbitmq-container.test.d.ts +2 -0
  65. package/lib/local-connection/rabbitmq-container.test.d.ts.map +1 -0
  66. package/lib/local-connection/rabbitmq-container.test.js +219 -0
  67. package/lib/local-connection/rabbitmq-container.test.js.map +1 -0
  68. package/lib/subcommands/device/clean.d.ts.map +1 -1
  69. package/lib/subcommands/device/clean.js +15 -17
  70. package/lib/subcommands/device/clean.js.map +1 -1
  71. package/lib/subcommands/device/index.d.ts.map +1 -1
  72. package/lib/subcommands/device/index.js +3 -1
  73. package/lib/subcommands/device/index.js.map +1 -1
  74. package/lib/subcommands/device/local-connection.d.ts +2 -0
  75. package/lib/subcommands/device/local-connection.d.ts.map +1 -0
  76. package/lib/subcommands/device/local-connection.js +17 -0
  77. package/lib/subcommands/device/local-connection.js.map +1 -0
  78. package/lib/subcommands/index.d.ts +4 -1
  79. package/lib/subcommands/index.d.ts.map +1 -1
  80. package/lib/subcommands/index.js +1 -3
  81. package/lib/subcommands/index.js.map +1 -1
  82. package/lib/util/check-for-updates.d.ts.map +1 -1
  83. package/lib/util/check-for-updates.js +2 -2
  84. package/lib/util/check-for-updates.js.map +1 -1
  85. package/lib/util/file.d.ts.map +1 -1
  86. package/lib/util/file.js +6 -1
  87. package/lib/util/file.js.map +1 -1
  88. package/lib/util/file.test.js +1 -1
  89. package/lib/util/file.test.js.map +1 -1
  90. package/lib/util/get-device-id.d.ts.map +1 -1
  91. package/lib/util/get-device-id.js +1 -1
  92. package/lib/util/get-device-id.js.map +1 -1
  93. package/package.json +3 -3
  94. package/src/application-control/config.ts +1 -1
  95. package/src/application-control/install.ts +3 -2
  96. package/src/cloud-connection/base-message-handler.ts +10 -5
  97. package/src/cloud-connection/{device-agent.ts → bootstrap-agent.ts} +68 -35
  98. package/src/cloud-connection/connection-manager.ts +151 -51
  99. package/src/cloud-connection/device-agent-cloud-connection.ts +17 -19
  100. package/src/cloud-connection/device-agent-message-handler.ts +10 -7
  101. package/src/cloud-connection/live-updates-handler.ts +12 -5
  102. package/src/cloud-connection/passthrough-handler.ts +137 -92
  103. package/src/cloud-connection/publisher.ts +30 -28
  104. package/src/cloud-connection/shadow-handler.ts +3 -3
  105. package/src/cloud-connection/shadow.ts +3 -1
  106. package/src/cloud-connection/transaction-manager.test.ts +60 -41
  107. package/src/cloud-connection/transaction-manager.ts +26 -12
  108. package/src/device-control/device-control.ts +23 -13
  109. package/src/docker/docker-compose.ts +3 -1
  110. package/src/environment.ts +1 -2
  111. package/src/index.ts +19 -0
  112. package/src/infrastructure/config-check-utility.ts +2 -2
  113. package/src/infrastructure/legacy-migration/legacy-migration.ts +8 -13
  114. package/src/local-connection/rabbitmq-container.test.ts +255 -0
  115. package/src/local-connection/rabbitmq-container.ts +151 -0
  116. package/src/subcommands/device/clean.ts +20 -19
  117. package/src/subcommands/device/index.ts +3 -1
  118. package/src/subcommands/device/local-connection.ts +16 -0
  119. package/src/subcommands/index.ts +1 -3
  120. package/src/util/check-for-updates.ts +4 -2
  121. package/src/util/file.test.ts +1 -1
  122. package/src/util/file.ts +7 -1
  123. package/src/util/get-device-id.ts +3 -1
  124. package/lib/cloud-connection/bootstrap-provision.d.ts +0 -2
  125. package/lib/cloud-connection/bootstrap-provision.d.ts.map +0 -1
  126. package/lib/cloud-connection/bootstrap-provision.js +0 -35
  127. package/lib/cloud-connection/bootstrap-provision.js.map +0 -1
  128. package/lib/cloud-connection/device-agent.d.ts +0 -21
  129. package/lib/cloud-connection/device-agent.d.ts.map +0 -1
  130. package/lib/cloud-connection/device-agent.js.map +0 -1
  131. package/lib/local-connection/rabbitmq-connection.d.ts +0 -7
  132. package/lib/local-connection/rabbitmq-connection.d.ts.map +0 -1
  133. package/lib/local-connection/rabbitmq-connection.js +0 -95
  134. package/lib/local-connection/rabbitmq-connection.js.map +0 -1
  135. package/lib/subcommands/rabbitmq-connection.d.ts +0 -2
  136. package/lib/subcommands/rabbitmq-connection.d.ts.map +0 -1
  137. package/lib/subcommands/rabbitmq-connection.js +0 -14
  138. package/lib/subcommands/rabbitmq-connection.js.map +0 -1
  139. package/lib/util/clean-certs.d.ts +0 -2
  140. package/lib/util/clean-certs.d.ts.map +0 -1
  141. package/lib/util/clean-certs.js +0 -17
  142. package/lib/util/clean-certs.js.map +0 -1
  143. package/src/cloud-connection/bootstrap-provision.ts +0 -43
  144. package/src/local-connection/rabbitmq-connection.ts +0 -124
  145. package/src/subcommands/rabbitmq-connection.ts +0 -11
  146. package/src/util/clean-certs.ts +0 -16
@@ -0,0 +1,111 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.stopRabbitMQContainer = exports.runRabbitMQContainer = exports.checkRabbitMQContainerRunning = void 0;
4
+ const util_1 = require("alwaysai/lib/util");
5
+ const YAML = require("yaml");
6
+ const docker_compose_1 = require("../docker/docker-compose");
7
+ const directories_1 = require("../util/directories");
8
+ const logger_1 = require("../util/logger");
9
+ const sleep_1 = require("../util/sleep");
10
+ const constants_1 = require("./constants");
11
+ const rabbitMQServiceName = 'alwaysAIRabbitMQ';
12
+ const rabbitMQContainerName = 'alwaysAIRabbitMQContainer';
13
+ /*
14
+ Utility functions to control the Local Connection container (RabbitMQ).
15
+
16
+ All exported functions handle their own errors and log their status, returning a
17
+ boolean indicating whether the action was successful.
18
+ */
19
+ async function checkRabbitMQContainerRunning() {
20
+ logger_1.logger.debug('Checking Local Connection Container status');
21
+ const spawner = (0, util_1.JsSpawner)();
22
+ if (!(await spawner.exists((0, directories_1.getDeviceAgentDockerComposePath)()))) {
23
+ logger_1.logger.warn('Local Connection configuration file is not present');
24
+ return false;
25
+ }
26
+ const containerData = await docker_compose_1.compose.ps({ cwd: (0, directories_1.getDeviceAgentConfigPath)() });
27
+ for (const service of containerData.data.services) {
28
+ if ((service === null || service === void 0 ? void 0 : service.name) === rabbitMQContainerName) {
29
+ if (service.state.includes('Up')) {
30
+ logger_1.logger.debug('Local Connection container is up.');
31
+ return true;
32
+ }
33
+ logger_1.logger.debug(`Local Connection container is not up. Status: ${service.state}`);
34
+ return false;
35
+ }
36
+ }
37
+ logger_1.logger.warn(`Local Connection container not found in container data: ${JSON.stringify(containerData, null, 2)}`);
38
+ return false;
39
+ }
40
+ exports.checkRabbitMQContainerRunning = checkRabbitMQContainerRunning;
41
+ async function writeRabbitMQDockerComposeFile() {
42
+ const spawner = (0, util_1.JsSpawner)();
43
+ if (!(await spawner.exists((0, directories_1.getDeviceAgentConfigPath)()))) {
44
+ await (0, util_1.JsSpawner)().mkdirp((0, directories_1.getDeviceAgentConfigPath)());
45
+ }
46
+ logger_1.logger.debug(`Writing Local Connection Docker compose files with Local Connection port: ${constants_1.LOCAL_CONNECTION_PORT}`);
47
+ const rabbitmqDockerComposeCmd = {
48
+ services: {
49
+ [rabbitMQServiceName]: {
50
+ container_name: rabbitMQContainerName,
51
+ image: 'rabbitmq:3.11',
52
+ ports: [`${constants_1.LOCAL_CONNECTION_PORT}:${constants_1.LOCAL_CONNECTION_PORT}`],
53
+ hostname: 'my-rabbit',
54
+ restart: 'on-failure',
55
+ environment: [`RABBITMQ_NODE_PORT=${constants_1.LOCAL_CONNECTION_PORT}`],
56
+ volumes: [
57
+ './rabbitmq/:/var/lib/rabbitmq/',
58
+ './rabbitmq/log/:/var/log/rabbitmq/'
59
+ ]
60
+ }
61
+ }
62
+ };
63
+ const RabbitMQDockerComposeYaml = YAML.stringify(rabbitmqDockerComposeCmd);
64
+ await spawner.writeFile((0, directories_1.getDeviceAgentDockerComposePath)(), RabbitMQDockerComposeYaml);
65
+ }
66
+ async function runRabbitMQContainer(opts) {
67
+ const max_attempts = (opts === null || opts === void 0 ? void 0 : opts.max_attempts) || 10;
68
+ logger_1.logger.debug('Starting the Local Connection container');
69
+ try {
70
+ await writeRabbitMQDockerComposeFile();
71
+ const upOut = await docker_compose_1.compose.upAll({
72
+ cwd: (0, directories_1.getDeviceAgentConfigPath)()
73
+ });
74
+ logger_1.logger.debug(`Docker compose up for Local Connection:\n${JSON.stringify(upOut, null, 2)}`);
75
+ if (upOut.exitCode !== 0) {
76
+ throw new Error(`Failed to start Local Connection! stdout=${upOut.out} stderr=${upOut.err}`);
77
+ }
78
+ // check if the container is up
79
+ let attempts = 0;
80
+ while (!(await checkRabbitMQContainerRunning())) {
81
+ attempts++;
82
+ if (attempts >= max_attempts) {
83
+ throw new Error('Local Connection container failed to come up after start!');
84
+ }
85
+ await (0, sleep_1.default)(1000);
86
+ }
87
+ return true;
88
+ }
89
+ catch (e) {
90
+ logger_1.logger.error(`Unable to start Local Connection container!\n${(0, util_1.stringifyError)(e)}`);
91
+ return false;
92
+ }
93
+ }
94
+ exports.runRabbitMQContainer = runRabbitMQContainer;
95
+ async function stopRabbitMQContainer() {
96
+ logger_1.logger.debug(`Stopping alwaysAI Local Connection container`);
97
+ try {
98
+ const downOut = await docker_compose_1.compose.down({ cwd: (0, directories_1.getDeviceAgentConfigPath)() });
99
+ logger_1.logger.debug(`Local Connection docker-compose down: ${JSON.stringify(downOut, null, 2)}`);
100
+ if (downOut.exitCode !== 0) {
101
+ throw new Error(`Failed to stop Local Connection! stdout=${downOut.out} stderr=${downOut.err}`);
102
+ }
103
+ return true;
104
+ }
105
+ catch (e) {
106
+ logger_1.logger.error(`Unable to stop Local Connection Container:\n${(0, util_1.stringifyError)(e)}`);
107
+ return false;
108
+ }
109
+ }
110
+ exports.stopRabbitMQContainer = stopRabbitMQContainer;
111
+ //# sourceMappingURL=rabbitmq-container.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rabbitmq-container.js","sourceRoot":"","sources":["../../src/local-connection/rabbitmq-container.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=rabbitmq-container.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rabbitmq-container.test.d.ts","sourceRoot":"","sources":["../../src/local-connection/rabbitmq-container.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,219 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const rabbitmq_container_1 = require("./rabbitmq-container");
4
+ const mockJsSpawner = {
5
+ exists: jest.fn(),
6
+ mkdirp: jest.fn(),
7
+ writeFile: jest.fn()
8
+ };
9
+ jest.mock('alwaysai/lib/util/spawner', () => {
10
+ return {
11
+ JsSpawner: jest.fn(() => mockJsSpawner)
12
+ };
13
+ });
14
+ jest.mock('../docker/docker-compose', () => {
15
+ return {
16
+ compose: {
17
+ ps: jest.fn(),
18
+ upAll: jest.fn(),
19
+ down: jest.fn()
20
+ }
21
+ };
22
+ });
23
+ const docker_compose_1 = require("../docker/docker-compose");
24
+ describe('Test check RabbitMQ container running', () => {
25
+ afterEach(() => {
26
+ jest.clearAllMocks();
27
+ });
28
+ test('Compose file not found', async () => {
29
+ mockJsSpawner.exists.mockResolvedValue(false);
30
+ const running = await (0, rabbitmq_container_1.checkRabbitMQContainerRunning)();
31
+ expect(running).toBeFalsy();
32
+ });
33
+ test('Container not found', async () => {
34
+ mockJsSpawner.exists.mockResolvedValue(true);
35
+ jest.mocked(docker_compose_1.compose.ps).mockResolvedValue({
36
+ exitCode: 0,
37
+ out: '',
38
+ err: '',
39
+ data: {
40
+ services: []
41
+ }
42
+ });
43
+ const running = await (0, rabbitmq_container_1.checkRabbitMQContainerRunning)();
44
+ expect(running).toBeFalsy();
45
+ });
46
+ test('Container is not up', async () => {
47
+ mockJsSpawner.exists.mockResolvedValue(true);
48
+ jest.mocked(docker_compose_1.compose.ps).mockResolvedValue({
49
+ exitCode: 0,
50
+ out: '',
51
+ err: '',
52
+ data: {
53
+ services: [
54
+ {
55
+ name: 'alwaysAIRabbitMQContainer',
56
+ command: '',
57
+ state: 'Down',
58
+ ports: []
59
+ }
60
+ ]
61
+ }
62
+ });
63
+ const running = await (0, rabbitmq_container_1.checkRabbitMQContainerRunning)();
64
+ expect(running).toBeFalsy();
65
+ });
66
+ test('Container is up', async () => {
67
+ mockJsSpawner.exists.mockResolvedValue(true);
68
+ jest.mocked(docker_compose_1.compose.ps).mockResolvedValue({
69
+ exitCode: 0,
70
+ out: '',
71
+ err: '',
72
+ data: {
73
+ services: [
74
+ {
75
+ name: 'alwaysAIRabbitMQContainer',
76
+ command: '',
77
+ state: 'Up',
78
+ ports: []
79
+ }
80
+ ]
81
+ }
82
+ });
83
+ const running = await (0, rabbitmq_container_1.checkRabbitMQContainerRunning)();
84
+ expect(running).toBeTruthy();
85
+ });
86
+ });
87
+ describe('Test run RabbitMQ container', () => {
88
+ afterEach(() => {
89
+ jest.clearAllMocks();
90
+ });
91
+ test('Compose file write fails', async () => {
92
+ mockJsSpawner.exists.mockResolvedValueOnce(false);
93
+ mockJsSpawner.mkdirp.mockImplementation(async () => {
94
+ return;
95
+ });
96
+ mockJsSpawner.writeFile.mockImplementation(async () => {
97
+ throw new Error('Failed to write file!');
98
+ });
99
+ const running = await (0, rabbitmq_container_1.runRabbitMQContainer)();
100
+ expect(running).toBeFalsy();
101
+ });
102
+ test('Compose up fails', async () => {
103
+ mockJsSpawner.exists.mockResolvedValueOnce(true);
104
+ mockJsSpawner.writeFile.mockImplementation(async () => {
105
+ return;
106
+ });
107
+ jest.mocked(docker_compose_1.compose.upAll).mockResolvedValue({
108
+ exitCode: 1,
109
+ out: '',
110
+ err: ''
111
+ });
112
+ const running = await (0, rabbitmq_container_1.runRabbitMQContainer)();
113
+ expect(running).toBeFalsy();
114
+ });
115
+ test('Container fails to come up', async () => {
116
+ // exists(deviceAgentConfigPath)
117
+ mockJsSpawner.exists.mockResolvedValueOnce(true);
118
+ mockJsSpawner.writeFile.mockImplementation(async () => {
119
+ return;
120
+ });
121
+ jest.mocked(docker_compose_1.compose.upAll).mockResolvedValue({
122
+ exitCode: 0,
123
+ out: '',
124
+ err: ''
125
+ });
126
+ // exists(deviceAgentDockerComposePath)
127
+ mockJsSpawner.exists.mockResolvedValueOnce(true);
128
+ jest.mocked(docker_compose_1.compose.ps).mockResolvedValue({
129
+ exitCode: 0,
130
+ out: '',
131
+ err: '',
132
+ data: {
133
+ services: [
134
+ {
135
+ name: 'alwaysAIRabbitMQContainer',
136
+ command: '',
137
+ state: 'Down',
138
+ ports: []
139
+ }
140
+ ]
141
+ }
142
+ });
143
+ const running = await (0, rabbitmq_container_1.runRabbitMQContainer)({ max_attempts: 2 });
144
+ expect(jest.mocked(docker_compose_1.compose.ps)).toBeCalledTimes(2);
145
+ expect(running).toBeFalsy();
146
+ });
147
+ test('Container comes up successfully', async () => {
148
+ // exists(deviceAgentConfigPath)
149
+ mockJsSpawner.exists.mockResolvedValueOnce(true);
150
+ mockJsSpawner.writeFile.mockImplementation(async () => {
151
+ return;
152
+ });
153
+ jest.mocked(docker_compose_1.compose.upAll).mockResolvedValue({
154
+ exitCode: 0,
155
+ out: '',
156
+ err: ''
157
+ });
158
+ // exists(deviceAgentDockerComposePath)
159
+ mockJsSpawner.exists.mockResolvedValueOnce(true);
160
+ // Check status twice, one with container still down and next up
161
+ jest.mocked(docker_compose_1.compose.ps).mockResolvedValueOnce({
162
+ exitCode: 0,
163
+ out: '',
164
+ err: '',
165
+ data: {
166
+ services: [
167
+ {
168
+ name: 'alwaysAIRabbitMQContainer',
169
+ command: '',
170
+ state: 'Down',
171
+ ports: []
172
+ }
173
+ ]
174
+ }
175
+ });
176
+ jest.mocked(docker_compose_1.compose.ps).mockResolvedValueOnce({
177
+ exitCode: 0,
178
+ out: '',
179
+ err: '',
180
+ data: {
181
+ services: [
182
+ {
183
+ name: 'alwaysAIRabbitMQContainer',
184
+ command: '',
185
+ state: 'Up',
186
+ ports: []
187
+ }
188
+ ]
189
+ }
190
+ });
191
+ const running = await (0, rabbitmq_container_1.runRabbitMQContainer)({ max_attempts: 2 });
192
+ expect(jest.mocked(docker_compose_1.compose.ps)).toBeCalledTimes(2);
193
+ expect(running).toBeTruthy();
194
+ });
195
+ });
196
+ describe('Test stopping RabbitMQ container', () => {
197
+ afterEach(() => {
198
+ jest.clearAllMocks();
199
+ });
200
+ test('Compose down fails', async () => {
201
+ jest.mocked(docker_compose_1.compose.down).mockResolvedValue({
202
+ exitCode: 1,
203
+ out: '',
204
+ err: ''
205
+ });
206
+ const stopped = await (0, rabbitmq_container_1.stopRabbitMQContainer)();
207
+ expect(stopped).toBeFalsy();
208
+ });
209
+ test('Stop succeeds', async () => {
210
+ jest.mocked(docker_compose_1.compose.down).mockResolvedValue({
211
+ exitCode: 0,
212
+ out: '',
213
+ err: ''
214
+ });
215
+ const stopped = await (0, rabbitmq_container_1.stopRabbitMQContainer)();
216
+ expect(stopped).toBeTruthy();
217
+ });
218
+ });
219
+ //# sourceMappingURL=rabbitmq-container.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rabbitmq-container.test.js","sourceRoot":"","sources":["../../src/local-connection/rabbitmq-container.test.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"clean.d.ts","sourceRoot":"","sources":["../../../src/subcommands/device/clean.ts"],"names":[],"mappings":"AAuBA,eAAO,MAAM,YAAY,6NAgDvB,CAAC"}
1
+ {"version":3,"file":"clean.d.ts","sourceRoot":"","sources":["../../../src/subcommands/device/clean.ts"],"names":[],"mappings":"AAwBA,eAAO,MAAM,YAAY,6NAgDvB,CAAC"}
@@ -4,30 +4,26 @@ exports.cleanCliLeaf = void 0;
4
4
  const alwayscli_1 = require("@alwaysai/alwayscli");
5
5
  const device_1 = require("alwaysai/lib/core/device");
6
6
  const infrastructure_1 = require("alwaysai/lib/infrastructure");
7
- const util_1 = require("alwaysai/lib/util");
8
7
  const promises_1 = require("fs/promises");
9
8
  const application_control_1 = require("../../application-control");
10
9
  const agent_config_1 = require("../../infrastructure/agent-config");
11
- const rabbitmq_connection_1 = require("../../local-connection/rabbitmq-connection");
10
+ const rabbitmq_container_1 = require("../../local-connection/rabbitmq-container");
12
11
  const directories_1 = require("../../util/directories");
13
12
  const file_1 = require("../../util/file");
14
13
  const logger_1 = require("../../util/logger");
14
+ const fs_1 = require("fs");
15
15
  exports.cleanCliLeaf = (0, alwayscli_1.CliLeaf)({
16
16
  name: 'clean',
17
17
  description: 'Remove all provisioning files',
18
18
  async action(_, opts) {
19
19
  logger_1.logger.info('Removing provisioning files.');
20
- try {
21
- if (await (0, rabbitmq_connection_1.checkRabbitMQContainerRunning)()) {
22
- await (0, rabbitmq_connection_1.stopRabbitMQContainer)();
20
+ if (await (0, rabbitmq_container_1.checkRabbitMQContainerRunning)()) {
21
+ if ((await (0, rabbitmq_container_1.stopRabbitMQContainer)()) === false) {
22
+ logger_1.logger.error(`You may need to manually stop the container by running docker-compose down in the following directory: ${(0, directories_1.getDeviceAgentDockerComposePath)()}`);
23
23
  }
24
24
  }
25
- catch (e) {
26
- logger_1.logger.error(`You may need to manually stop the container by running docker-compose down in the following directory: ${(0, directories_1.getDeviceAgentDockerComposePath)()}`);
27
- logger_1.logger.debug(`Error in checking / stopping RabbitMQ container!\n${(0, util_1.stringifyError)(e)}`);
28
- }
29
25
  await (0, file_1.safeRimraf)((0, directories_1.getDeviceAgentConfigPath)());
30
- logger_1.logger.debug('Checking for alwaysAI applications still running');
26
+ logger_1.logger.debug('Checking for alwaysAI applications still installed');
31
27
  const apps = await (0, agent_config_1.AgentConfigFile)().getApps();
32
28
  const uninstallAppPromises = [];
33
29
  for (const app of apps) {
@@ -43,14 +39,16 @@ exports.cleanCliLeaf = (0, alwayscli_1.CliLeaf)({
43
39
  logger_1.logger.debug(`Removing ${(0, device_1.DeviceConfigFile)().path}`);
44
40
  (0, device_1.DeviceConfigFile)().remove();
45
41
  await (0, file_1.safeRimraf)(directories_1.CREDENTIALS_FILE_PATH);
46
- const files = await (0, promises_1.readdir)(directories_1.APP_ROOT);
47
- logger_1.logger.debug(`${directories_1.APP_ROOT} folder contents ${JSON.stringify(files.length)}`);
48
- // This won't handle hidden files, but will remove if truly empty, which is safer
49
- if (files.length === 0) {
50
- logger_1.logger.debug('Applications directory is empty, removing.');
51
- await (0, file_1.safeRimraf)(directories_1.APP_ROOT);
42
+ if ((0, fs_1.existsSync)(directories_1.APP_ROOT)) {
43
+ const files = await (0, promises_1.readdir)(directories_1.APP_ROOT);
44
+ logger_1.logger.debug(`${directories_1.APP_ROOT} folder contents ${JSON.stringify(files.length)}`);
45
+ // This won't handle hidden files, but will remove if truly empty, which is safer
46
+ if (files.length === 0) {
47
+ logger_1.logger.debug('Applications directory is empty, removing.');
48
+ await (0, file_1.safeRimraf)(directories_1.APP_ROOT);
49
+ }
50
+ logger_1.logger.info('Device configuration cleaned');
52
51
  }
53
- logger_1.logger.info('Device configuration cleaned');
54
52
  }
55
53
  });
56
54
  //# sourceMappingURL=clean.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"clean.js","sourceRoot":"","sources":["../../../src/subcommands/device/clean.ts"],"names":[],"mappings":";;;AAAA,mDAA8C;AAC9C,qDAA4D;AAC5D,gEAGqC;AACrC,4CAAmD;AACnD,0CAAsC;AACtC,mEAAyD;AACzD,oEAAoE;AACpE,oFAGoD;AACpD,wDAKgC;AAChC,0CAA6C;AAC7C,8CAA2C;AAE9B,QAAA,YAAY,GAAG,IAAA,mBAAO,EAAC;IAClC,IAAI,EAAE,OAAO;IACb,WAAW,EAAE,+BAA+B;IAC5C,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI;QAClB,eAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;QAC5C,IAAI;YACF,IAAI,MAAM,IAAA,mDAA6B,GAAE,EAAE;gBACzC,MAAM,IAAA,2CAAqB,GAAE,CAAC;aAC/B;SACF;QAAC,OAAO,CAAC,EAAE;YACV,eAAM,CAAC,KAAK,CACV,0GAA0G,IAAA,6CAA+B,GAAE,EAAE,CAC9I,CAAC;YACF,eAAM,CAAC,KAAK,CACV,qDAAqD,IAAA,qBAAc,EAAC,CAAC,CAAC,EAAE,CACzE,CAAC;SACH;QAED,MAAM,IAAA,iBAAU,EAAC,IAAA,sCAAwB,GAAE,CAAC,CAAC;QAE7C,eAAM,CAAC,KAAK,CAAC,kDAAkD,CAAC,CAAC;QACjE,MAAM,IAAI,GAAG,MAAM,IAAA,8BAAe,GAAE,CAAC,OAAO,EAAE,CAAC;QAC/C,MAAM,oBAAoB,GAAoB,EAAE,CAAC;QACjD,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;YACtB,MAAM,EAAE,SAAS,EAAE,GAAG,GAAG,CAAC;YAC1B,oBAAoB,CAAC,IAAI,CAAC,IAAA,kCAAY,EAAC,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;SACxD;QACD,MAAM,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;QAExC,MAAM,IAAA,iBAAU,EAAC,uCAAsB,CAAC,CAAC;QACzC,MAAM,kBAAkB,GAAG,IAAI,8CAA6B,EAAE,CAAC;QAC/D,MAAM,IAAA,iBAAU,EAAC,kBAAkB,CAAC,2BAA2B,EAAE,CAAC,CAAC;QAEnE,eAAM,CAAC,KAAK,CAAC,YAAY,IAAA,8BAAe,GAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QACnD,IAAA,8BAAe,GAAE,CAAC,MAAM,EAAE,CAAC;QAC3B,eAAM,CAAC,KAAK,CAAC,YAAY,IAAA,yBAAgB,GAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QACpD,IAAA,yBAAgB,GAAE,CAAC,MAAM,EAAE,CAAC;QAE5B,MAAM,IAAA,iBAAU,EAAC,mCAAqB,CAAC,CAAC;QACxC,MAAM,KAAK,GAAG,MAAM,IAAA,kBAAO,EAAC,sBAAQ,CAAC,CAAC;QACtC,eAAM,CAAC,KAAK,CAAC,GAAG,sBAAQ,oBAAoB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC5E,iFAAiF;QACjF,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB,eAAM,CAAC,KAAK,CAAC,4CAA4C,CAAC,CAAC;YAC3D,MAAM,IAAA,iBAAU,EAAC,sBAAQ,CAAC,CAAC;SAC5B;QACD,eAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;IAC9C,CAAC;CACF,CAAC,CAAC"}
1
+ {"version":3,"file":"clean.js","sourceRoot":"","sources":["../../../src/subcommands/device/clean.ts"],"names":[],"mappings":";;;AAAA,mDAA8C;AAC9C,qDAA4D;AAC5D,gEAGqC;AAErC,0CAAsC;AACtC,mEAAyD;AACzD,oEAAoE;AACpE,kFAGmD;AACnD,wDAKgC;AAChC,0CAA6C;AAC7C,8CAA2C;AAC3C,2BAAgC;AAEnB,QAAA,YAAY,GAAG,IAAA,mBAAO,EAAC;IAClC,IAAI,EAAE,OAAO;IACb,WAAW,EAAE,+BAA+B;IAC5C,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI;QAClB,eAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;QAC5C,IAAI,MAAM,IAAA,kDAA6B,GAAE,EAAE;YACzC,IAAI,CAAC,MAAM,IAAA,0CAAqB,GAAE,CAAC,KAAK,KAAK,EAAE;gBAC7C,eAAM,CAAC,KAAK,CACV,0GAA0G,IAAA,6CAA+B,GAAE,EAAE,CAC9I,CAAC;aACH;SACF;QAED,MAAM,IAAA,iBAAU,EAAC,IAAA,sCAAwB,GAAE,CAAC,CAAC;QAE7C,eAAM,CAAC,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACnE,MAAM,IAAI,GAAG,MAAM,IAAA,8BAAe,GAAE,CAAC,OAAO,EAAE,CAAC;QAC/C,MAAM,oBAAoB,GAAoB,EAAE,CAAC;QACjD,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;YACtB,MAAM,EAAE,SAAS,EAAE,GAAG,GAAG,CAAC;YAC1B,oBAAoB,CAAC,IAAI,CAAC,IAAA,kCAAY,EAAC,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;SACxD;QACD,MAAM,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;QAExC,MAAM,IAAA,iBAAU,EAAC,uCAAsB,CAAC,CAAC;QACzC,MAAM,kBAAkB,GAAG,IAAI,8CAA6B,EAAE,CAAC;QAC/D,MAAM,IAAA,iBAAU,EAAC,kBAAkB,CAAC,2BAA2B,EAAE,CAAC,CAAC;QAEnE,eAAM,CAAC,KAAK,CAAC,YAAY,IAAA,8BAAe,GAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QACnD,IAAA,8BAAe,GAAE,CAAC,MAAM,EAAE,CAAC;QAC3B,eAAM,CAAC,KAAK,CAAC,YAAY,IAAA,yBAAgB,GAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QACpD,IAAA,yBAAgB,GAAE,CAAC,MAAM,EAAE,CAAC;QAE5B,MAAM,IAAA,iBAAU,EAAC,mCAAqB,CAAC,CAAC;QAExC,IAAI,IAAA,eAAU,EAAC,sBAAQ,CAAC,EAAE;YACxB,MAAM,KAAK,GAAG,MAAM,IAAA,kBAAO,EAAC,sBAAQ,CAAC,CAAC;YACtC,eAAM,CAAC,KAAK,CACV,GAAG,sBAAQ,oBAAoB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAC9D,CAAC;YACF,iFAAiF;YACjF,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;gBACtB,eAAM,CAAC,KAAK,CAAC,4CAA4C,CAAC,CAAC;gBAC3D,MAAM,IAAA,iBAAU,EAAC,sBAAQ,CAAC,CAAC;aAC5B;YACD,eAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;SAC7C;IACH,CAAC;CACF,CAAC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/subcommands/device/index.ts"],"names":[],"mappings":"AAQA,eAAO,MAAM,eAAe,mDAW1B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/subcommands/device/index.ts"],"names":[],"mappings":"AASA,eAAO,MAAM,eAAe,mDAY1B,CAAC"}
@@ -8,6 +8,7 @@ const init_1 = require("./init");
8
8
  const restart_1 = require("./restart");
9
9
  const refresh_1 = require("./refresh");
10
10
  const migrate_1 = require("./migrate");
11
+ const local_connection_1 = require("./local-connection");
11
12
  exports.deviceCliBranch = (0, alwayscli_1.CliBranch)({
12
13
  name: 'device',
13
14
  description: 'Manage current device',
@@ -17,7 +18,8 @@ exports.deviceCliBranch = (0, alwayscli_1.CliBranch)({
17
18
  refresh_1.refreshCliLeaf,
18
19
  clean_1.cleanCliLeaf,
19
20
  restart_1.restartCliLeaf,
20
- migrate_1.migrateCliLeaf
21
+ migrate_1.migrateCliLeaf,
22
+ local_connection_1.stopLocalConnectionCliLeaf
21
23
  ]
22
24
  });
23
25
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/subcommands/device/index.ts"],"names":[],"mappings":";;;AAAA,mDAAgD;AAChD,yCAA4C;AAC5C,mCAAuC;AACvC,iCAAqC;AACrC,uCAA2C;AAC3C,uCAA2C;AAC3C,uCAA2C;AAE9B,QAAA,eAAe,GAAG,IAAA,qBAAS,EAAC;IACvC,IAAI,EAAE,QAAQ;IACd,WAAW,EAAE,uBAAuB;IACpC,WAAW,EAAE;QACX,kBAAW;QACX,yBAAc;QACd,wBAAc;QACd,oBAAY;QACZ,wBAAc;QACd,wBAAc;KACf;CACF,CAAC,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/subcommands/device/index.ts"],"names":[],"mappings":";;;AAAA,mDAAgD;AAChD,yCAA4C;AAC5C,mCAAuC;AACvC,iCAAqC;AACrC,uCAA2C;AAC3C,uCAA2C;AAC3C,uCAA2C;AAC3C,yDAAgE;AAEnD,QAAA,eAAe,GAAG,IAAA,qBAAS,EAAC;IACvC,IAAI,EAAE,QAAQ;IACd,WAAW,EAAE,uBAAuB;IACpC,WAAW,EAAE;QACX,kBAAW;QACX,yBAAc;QACd,wBAAc;QACd,oBAAY;QACZ,wBAAc;QACd,wBAAc;QACd,6CAA0B;KAC3B;CACF,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const stopLocalConnectionCliLeaf: import("@alwaysai/alwayscli/lib/types").CliLeaf<import("@alwaysai/alwayscli").CliInput<undefined, false>, import("@alwaysai/alwayscli/lib/types").AnyNamedInputs, import("@alwaysai/alwayscli").CliInput<undefined, false>>;
2
+ //# sourceMappingURL=local-connection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"local-connection.d.ts","sourceRoot":"","sources":["../../../src/subcommands/device/local-connection.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,0BAA0B,6NAUrC,CAAC"}
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.stopLocalConnectionCliLeaf = void 0;
4
+ const alwayscli_1 = require("@alwaysai/alwayscli");
5
+ const rabbitmq_container_1 = require("../../local-connection/rabbitmq-container");
6
+ const logger_1 = require("../../util/logger");
7
+ const directories_1 = require("../../util/directories");
8
+ exports.stopLocalConnectionCliLeaf = (0, alwayscli_1.CliLeaf)({
9
+ name: 'stop-local-connection',
10
+ description: 'Stop the Device Agent local connection container',
11
+ async action(_, opts) {
12
+ if ((await (0, rabbitmq_container_1.stopRabbitMQContainer)()) === false) {
13
+ logger_1.logger.error(`You may need to manually stop the container by running docker-compose down in the following directory: ${(0, directories_1.getDeviceAgentDockerComposePath)()}`);
14
+ }
15
+ }
16
+ });
17
+ //# sourceMappingURL=local-connection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"local-connection.js","sourceRoot":"","sources":["../../../src/subcommands/device/local-connection.ts"],"names":[],"mappings":";;;AAAA,mDAA8C;AAC9C,kFAAkF;AAClF,8CAA2C;AAC3C,wDAAyE;AAE5D,QAAA,0BAA0B,GAAG,IAAA,mBAAO,EAAC;IAChD,IAAI,EAAE,uBAAuB;IAC7B,WAAW,EAAE,kDAAkD;IAC/D,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI;QAClB,IAAI,CAAC,MAAM,IAAA,0CAAqB,GAAE,CAAC,KAAK,KAAK,EAAE;YAC7C,eAAM,CAAC,KAAK,CACV,0GAA0G,IAAA,6CAA+B,GAAE,EAAE,CAC9I,CAAC;SACH;IACH,CAAC;CACF,CAAC,CAAC"}
@@ -1,5 +1,8 @@
1
- export declare const subcommands: (import("@alwaysai/alwayscli/lib/types").CliBranch | import("@alwaysai/alwayscli/lib/types").CliLeaf<import("@alwaysai/alwayscli").CliInput<undefined, false>, import("@alwaysai/alwayscli/lib/types").AnyNamedInputs, import("@alwaysai/alwayscli").CliInput<undefined, false>> | import("@alwaysai/alwayscli/lib/types").CliLeaf<import("@alwaysai/alwayscli").CliInput<string, true>, {
1
+ export declare const subcommands: (import("@alwaysai/alwayscli/lib/types").CliBranch | import("@alwaysai/alwayscli/lib/types").CliLeaf<import("@alwaysai/alwayscli").CliInput<string, true>, {
2
2
  version: import("@alwaysai/alwayscli").CliInput<number | undefined, boolean>;
3
3
  path: import("@alwaysai/alwayscli").CliInput<string | undefined, false>;
4
+ }, import("@alwaysai/alwayscli").CliInput<undefined, false>> | import("@alwaysai/alwayscli/lib/types").CliLeaf<import("@alwaysai/alwayscli").CliInput<undefined, false>, {
5
+ email: import("@alwaysai/alwayscli").CliInput<string, true>;
6
+ password: import("@alwaysai/alwayscli").CliInput<string, true>;
4
7
  }, import("@alwaysai/alwayscli").CliInput<undefined, false>>)[];
5
8
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/subcommands/index.ts"],"names":[],"mappings":"AAOA,eAAO,MAAM,WAAW;;;+DAOvB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/subcommands/index.ts"],"names":[],"mappings":"AAMA,eAAO,MAAM,WAAW;;;;;;+DAMvB,CAAC"}
@@ -6,13 +6,11 @@ const config_1 = require("./config");
6
6
  const device_1 = require("./device");
7
7
  const get_model_package_1 = require("./get-model-package");
8
8
  const login_1 = require("./login");
9
- const rabbitmq_connection_1 = require("./rabbitmq-connection");
10
9
  exports.subcommands = [
11
10
  login_1.loginCliLeaf,
12
11
  config_1.configBranch,
13
12
  app_1.appCliBranch,
14
13
  device_1.deviceCliBranch,
15
- get_model_package_1.getModelPackageCliLeaf,
16
- rabbitmq_connection_1.stopRabbitMQContainerCliLeaf
14
+ get_model_package_1.getModelPackageCliLeaf
17
15
  ];
18
16
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/subcommands/index.ts"],"names":[],"mappings":";;;AAAA,+BAAqC;AACrC,qCAAwC;AACxC,qCAA2C;AAC3C,2DAA6D;AAC7D,mCAAuC;AACvC,+DAAqE;AAExD,QAAA,WAAW,GAAG;IACzB,oBAAY;IACZ,qBAAY;IACZ,kBAAY;IACZ,wBAAe;IACf,0CAAsB;IACtB,kDAA4B;CAC7B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/subcommands/index.ts"],"names":[],"mappings":";;;AAAA,+BAAqC;AACrC,qCAAwC;AACxC,qCAA2C;AAC3C,2DAA6D;AAC7D,mCAAuC;AAE1B,QAAA,WAAW,GAAG;IACzB,oBAAY;IACZ,qBAAY;IACZ,kBAAY;IACZ,wBAAe;IACf,0CAAsB;CACvB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"check-for-updates.d.ts","sourceRoot":"","sources":["../../src/util/check-for-updates.ts"],"names":[],"mappings":"AAYA,wBAAsB,qBAAqB,IAAI,OAAO,CAAC,MAAM,CAAC,CAc7D;AAQD,wBAAsB,wBAAwB,kBAkB7C"}
1
+ {"version":3,"file":"check-for-updates.d.ts","sourceRoot":"","sources":["../../src/util/check-for-updates.ts"],"names":[],"mappings":"AAYA,wBAAsB,qBAAqB,IAAI,OAAO,CAAC,MAAM,CAAC,CAgB7D;AAQD,wBAAsB,wBAAwB,kBAkB7C"}
@@ -16,7 +16,7 @@ async function getDeviceAgentVersion() {
16
16
  daVersion = parsed.version;
17
17
  }
18
18
  catch (e) {
19
- logger_1.logger.error(`Could not retrieve the Device Agent version!\n${(0, util_1.stringifyError)(e)}`);
19
+ logger_1.logger.error(`Could not retrieve the Device Agent version! Error:\n${(0, util_1.stringifyError)(e)}`);
20
20
  }
21
21
  return daVersion;
22
22
  }
@@ -39,7 +39,7 @@ async function checkForUpdatesAndPrompt() {
39
39
  }
40
40
  }
41
41
  catch (e) {
42
- logger_1.logger.error(`Could not check for updates!\n${(0, util_1.stringifyError)(e)}`);
42
+ logger_1.logger.error(`Could not check for updates! Error:\n${(0, util_1.stringifyError)(e)}`);
43
43
  }
44
44
  }
45
45
  exports.checkForUpdatesAndPrompt = checkForUpdatesAndPrompt;
@@ -1 +1 @@
1
- {"version":3,"file":"check-for-updates.js","sourceRoot":"","sources":["../../src/util/check-for-updates.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AACxC,4CAI2B;AAC3B,6BAA6B;AAE7B,MAAM,SAAS,GACb,kEAAkE,CAAC;AACrE,MAAM,YAAY,GAAG,sDAAsD,CAAC;AAErE,KAAK,UAAU,qBAAqB;IACzC,IAAI,SAAS,GAAG,EAAE,CAAC;IACnB,IAAI;QACF,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QACnD,MAAM,OAAO,GAAG,IAAA,gBAAS,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC,CAAC;QACjD,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAClC,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC;KAC5B;IAAC,OAAO,CAAC,EAAE;QACV,eAAM,CAAC,KAAK,CACV,iDAAiD,IAAA,qBAAc,EAAC,CAAC,CAAC,EAAE,CACrE,CAAC;KACH;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAdD,sDAcC;AAED,SAAS,eAAe,CAAC,KAAgD;IACvE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC;IACxC,MAAM,MAAM,GAAG,GAAG,YAAY,GAAG,SAAS,mBAAmB,UAAU,qBAAqB,SAAS,EAAE,CAAC;IACxG,OAAO,MAAM,CAAC;AAChB,CAAC;AAEM,KAAK,UAAU,wBAAwB;IAC5C,IAAI;QACF,eAAM,CAAC,KAAK,CAAC,gDAAgD,CAAC,CAAC;QAC/D,MAAM,aAAa,GAAG,MAAM,IAAA,8BAAuB,EACjD,wBAAwB,CACzB,CAAC;QACF,MAAM,OAAO,GAAG,MAAM,qBAAqB,EAAE,CAAC;QAC9C,IAAI,OAAO,KAAK,aAAa,EAAE;YAC7B,eAAM,CAAC,IAAI,CACT,eAAe,CAAC;gBACd,UAAU,EAAE,OAAO;gBACnB,SAAS,EAAE,aAAa;aACzB,CAAC,CACH,CAAC;SACH;KACF;IAAC,OAAO,CAAC,EAAE;QACV,eAAM,CAAC,KAAK,CAAC,iCAAiC,IAAA,qBAAc,EAAC,CAAC,CAAC,EAAE,CAAC,CAAC;KACpE;AACH,CAAC;AAlBD,4DAkBC"}
1
+ {"version":3,"file":"check-for-updates.js","sourceRoot":"","sources":["../../src/util/check-for-updates.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AACxC,4CAI2B;AAC3B,6BAA6B;AAE7B,MAAM,SAAS,GACb,kEAAkE,CAAC;AACrE,MAAM,YAAY,GAAG,sDAAsD,CAAC;AAErE,KAAK,UAAU,qBAAqB;IACzC,IAAI,SAAS,GAAG,EAAE,CAAC;IACnB,IAAI;QACF,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QACnD,MAAM,OAAO,GAAG,IAAA,gBAAS,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC,CAAC;QACjD,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAClC,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC;KAC5B;IAAC,OAAO,CAAC,EAAE;QACV,eAAM,CAAC,KAAK,CACV,wDAAwD,IAAA,qBAAc,EACpE,CAAC,CACF,EAAE,CACJ,CAAC;KACH;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAhBD,sDAgBC;AAED,SAAS,eAAe,CAAC,KAAgD;IACvE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC;IACxC,MAAM,MAAM,GAAG,GAAG,YAAY,GAAG,SAAS,mBAAmB,UAAU,qBAAqB,SAAS,EAAE,CAAC;IACxG,OAAO,MAAM,CAAC;AAChB,CAAC;AAEM,KAAK,UAAU,wBAAwB;IAC5C,IAAI;QACF,eAAM,CAAC,KAAK,CAAC,gDAAgD,CAAC,CAAC;QAC/D,MAAM,aAAa,GAAG,MAAM,IAAA,8BAAuB,EACjD,wBAAwB,CACzB,CAAC;QACF,MAAM,OAAO,GAAG,MAAM,qBAAqB,EAAE,CAAC;QAC9C,IAAI,OAAO,KAAK,aAAa,EAAE;YAC7B,eAAM,CAAC,IAAI,CACT,eAAe,CAAC;gBACd,UAAU,EAAE,OAAO;gBACnB,SAAS,EAAE,aAAa;aACzB,CAAC,CACH,CAAC;SACH;KACF;IAAC,OAAO,CAAC,EAAE;QACV,eAAM,CAAC,KAAK,CAAC,wCAAwC,IAAA,qBAAc,EAAC,CAAC,CAAC,EAAE,CAAC,CAAC;KAC3E;AACH,CAAC;AAlBD,4DAkBC"}
@@ -1 +1 @@
1
- {"version":3,"file":"file.d.ts","sourceRoot":"","sources":["../../src/util/file.ts"],"names":[],"mappings":"AAOA,wBAAsB,UAAU,CAAC,IAAI,EAAE,MAAM,iBAU5C;AAED,wBAAsB,QAAQ,CAAC,EAC7B,IAAI,EACJ,OAAO,EACP,OAAO,EACR,EAAE;IACD,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,oBAkDA;AAED,wBAAsB,cAAc,CAAC,EACnC,IAAI,EACJ,GAAG,EACJ,EAAE;IACD,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;CACb,iBAsEA"}
1
+ {"version":3,"file":"file.d.ts","sourceRoot":"","sources":["../../src/util/file.ts"],"names":[],"mappings":"AAOA,wBAAsB,UAAU,CAAC,IAAI,EAAE,MAAM,iBAU5C;AAED,wBAAsB,QAAQ,CAAC,EAC7B,IAAI,EACJ,OAAO,EACP,OAAO,EACR,EAAE;IACD,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,oBAwDA;AAED,wBAAsB,cAAc,CAAC,EACnC,IAAI,EACJ,GAAG,EACJ,EAAE;IACD,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;CACb,iBAsEA"}
package/lib/util/file.js CHANGED
@@ -52,6 +52,11 @@ async function pruneDir({ path, exclude, recurse }) {
52
52
  canPruneParent = false;
53
53
  }
54
54
  }
55
+ else {
56
+ // Directory encountered but recursion is not allowed, parent cannot be pruned
57
+ logger_1.logger.debug(`Skipping directory ${filePath} as recurse is false.`);
58
+ canPruneParent = false;
59
+ }
55
60
  }
56
61
  else {
57
62
  await (0, promises_1.unlink)(filePath);
@@ -60,7 +65,7 @@ async function pruneDir({ path, exclude, recurse }) {
60
65
  return canPruneParent;
61
66
  }
62
67
  catch (e) {
63
- logger_1.logger.error(`Error pruning directory ${path}!\n${(0, util_1.stringifyError)(e)}`);
68
+ logger_1.logger.error(`Error pruning directory ${path}! Error:\n${(0, util_1.stringifyError)(e)}`);
64
69
  return false;
65
70
  }
66
71
  }
@@ -1 +1 @@
1
- {"version":3,"file":"file.js","sourceRoot":"","sources":["../../src/util/file.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"file.js","sourceRoot":"","sources":["../../src/util/file.ts"],"names":[],"mappings":";;;AAAA,mCAAgC;AAChC,2CAAwC;AACxC,0CAA2D;AAC3D,+BAA4B;AAC5B,4CAAmD;AACnD,2BAAmC;AAE5B,KAAK,UAAU,UAAU,CAAC,IAAY;IAC3C,eAAM,CAAC,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;IACjC,IAAI;QACF,MAAM,IAAA,eAAM,EAAC,IAAI,CAAC,CAAC;KACpB;IAAC,OAAO,CAAC,EAAE;QACV,eAAM,CAAC,KAAK,CACV,oBAAoB,IAAI,iDAAiD,CAC1E,CAAC;QACF,eAAM,CAAC,KAAK,CAAC,kBAAkB,IAAI,MAAM,IAAA,qBAAc,EAAC,CAAC,CAAC,EAAE,CAAC,CAAC;KAC/D;AACH,CAAC;AAVD,gCAUC;AAEM,KAAK,UAAU,QAAQ,CAAC,EAC7B,IAAI,EACJ,OAAO,EACP,OAAO,EAKR;IACC;;;;;;OAMG;IACH,IAAI;QACF,MAAM,KAAK,GAAG,MAAM,IAAA,kBAAO,EAAC,IAAI,CAAC,CAAC;QAElC,IAAI,cAAc,GAAG,IAAI,CAAC;QAE1B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;YACxB,MAAM,QAAQ,GAAG,IAAA,WAAI,EAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAElC,MAAM,UAAU,GAAG,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE,CAC/C,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAC/B,CAAC;YAEF,IAAI,UAAU,EAAE;gBACd,eAAM,CAAC,KAAK,CAAC,kBAAkB,QAAQ,kBAAkB,CAAC,CAAC;gBAC3D,cAAc,GAAG,KAAK,CAAC;gBACvB,SAAS;aACV;YAED,MAAM,SAAS,GAAG,MAAM,IAAA,eAAI,EAAC,QAAQ,CAAC,CAAC;YACvC,IAAI,SAAS,CAAC,WAAW,EAAE,EAAE;gBAC3B,IAAI,OAAO,EAAE;oBACX,MAAM,UAAU,GAAG,MAAM,QAAQ,CAAC;wBAChC,IAAI,EAAE,QAAQ;wBACd,OAAO;wBACP,OAAO;qBACR,CAAC,CAAC;oBAEH,IAAI,UAAU,EAAE;wBACd,MAAM,IAAA,gBAAK,EAAC,QAAQ,CAAC,CAAC;qBACvB;yBAAM;wBACL,cAAc,GAAG,KAAK,CAAC;qBACxB;iBACF;qBAAM;oBACL,8EAA8E;oBAC9E,eAAM,CAAC,KAAK,CAAC,sBAAsB,QAAQ,uBAAuB,CAAC,CAAC;oBACpE,cAAc,GAAG,KAAK,CAAC;iBACxB;aACF;iBAAM;gBACL,MAAM,IAAA,iBAAM,EAAC,QAAQ,CAAC,CAAC;aACxB;SACF;QACD,OAAO,cAAc,CAAC;KACvB;IAAC,OAAO,CAAC,EAAE;QACV,eAAM,CAAC,KAAK,CACV,2BAA2B,IAAI,aAAa,IAAA,qBAAc,EAAC,CAAC,CAAC,EAAE,CAChE,CAAC;QACF,OAAO,KAAK,CAAC;KACd;AACH,CAAC;AAhED,4BAgEC;AAEM,KAAK,UAAU,cAAc,CAAC,EACnC,IAAI,EACJ,GAAG,EAIJ;;IACC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;IAElC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;QAChB,MAAM,IAAI,KAAK,CAAC,mBAAmB,GAAG,KAAK,QAAQ,CAAC,UAAU,EAAE,CAAC,CAAC;KACnE;IAED,MAAM,aAAa,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;IAC7D,MAAM,MAAM,GAAG,MAAA,QAAQ,CAAC,IAAI,0CAAE,SAAS,EAAE,CAAC;IAE1C,IAAI,MAAM,EAAE;QACV,MAAM,MAAM,GAAiB,EAAE,CAAC;QAChC,MAAM,SAAS,GAAG,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAEtE,MAAM,2BAA2B,GAAG,CAAC,CAAC;QACtC,MAAM,2BAA2B,GAAG,OAAS,CAAC;QAC9C,MAAM,CAAC,OAAO,EAAE,SAAS,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC5C,MAAM,SAAS,GAAG,GAAG,OAAO,GAC1B,CAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,MAAM,EAAC,CAAC,CAAC,OAAO,SAAS,CAAC,MAAM,mBAAmB,CAAC,CAAC,CAAC,EACnE,EAAE,CAAC;QACH,IAAI,oBAAoB,GAAG,CAAC,CAAC;QAC7B,IAAI,cAAc,GAAG,CAAC,CAAC;QACvB,IAAI,iBAAiB,GAAG,CAAC,CAAC;QAE1B,2BAA2B;QAC3B,OAAO,IAAI,EAAE;YACX,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE,CAAC;YAC5C,IAAI,IAAI,EAAE;gBACR,eAAM,CAAC,IAAI,CAAC,uBAAuB,SAAS,EAAE,CAAC,CAAC;gBAChD,MAAM;aACP;YACD,IAAI,KAAK,EAAE;gBACT,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACnB,cAAc,IAAI,KAAK,CAAC,MAAM,CAAC;gBAC/B,IAAI,SAAS,EAAE;oBACb,MAAM,QAAQ,GAAG,CAAC,cAAc,GAAG,SAAS,CAAC,GAAG,GAAG,CAAC;oBACpD,IAAI,QAAQ,GAAG,iBAAiB,GAAG,2BAA2B,EAAE;wBAC9D,iBAAiB,IAAI,2BAA2B,CAAC;wBACjD,eAAM,CAAC,KAAK,CACV,sBAAsB,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,SAAS,EAAE,CAC5D,CAAC;qBACH;iBACF;qBAAM;oBACL,IACE,cAAc;wBACd,oBAAoB,GAAG,2BAA2B,EAClD;wBACA,oBAAoB,IAAI,2BAA2B,CAAC;wBACpD,eAAM,CAAC,KAAK,CACV,sBAAsB,cAAc,kBAAkB,SAAS,EAAE,CAClE,CAAC;qBACH;iBACF;aACF;SACF;QAED,eAAM,CAAC,KAAK,CAAC,qCAAqC,IAAI,EAAE,CAAC,CAAC;QAC1D,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,GAAG,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAC1E,MAAM,cAAc,GAAG,IAAI,UAAU,CAAC,YAAY,CAAC,CAAC;QAEpD,IAAI,MAAM,GAAG,CAAC,CAAC;QACf,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;YAC1B,cAAc,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;YAClC,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC;SACxB;QAED,IAAA,kBAAa,EAAC,IAAI,EAAE,cAAc,CAAC,CAAC;KACrC;SAAM;QACL,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;KAC1E;AACH,CAAC;AA5ED,wCA4EC"}
@@ -76,7 +76,7 @@ describe('pruneDir function', () => {
76
76
  return { isDirectory: () => true };
77
77
  });
78
78
  const result = await (0, file_1.pruneDir)({ path: rootPath, recurse: false });
79
- expect(result).toBe(true);
79
+ expect(result).toBe(false);
80
80
  expect(promises_1.readdir).toHaveBeenCalledWith(rootPath);
81
81
  expect(promises_1.stat).toHaveBeenCalledTimes(2); // Called for file1.txt and subdir
82
82
  expect(promises_1.unlink).toHaveBeenCalledWith(`${rootPath}/file1.txt`);