@fdm-monster/server 1.8.1 → 1.8.3
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/.yarn/install-state.gz +0 -0
- package/.yarn/releases/{yarn-4.5.3.cjs → yarn-4.7.0.cjs} +256 -255
- package/.yarnrc.yml +1 -1
- package/README.md +14 -4
- package/RELEASE_NOTES.MD +35 -4
- package/dist/consoles/http-file-receiver.console.js +81 -0
- package/dist/consoles/http-file-receiver.console.js.map +1 -0
- package/dist/constants/event.constants.js +8 -0
- package/dist/constants/event.constants.js.map +1 -1
- package/dist/container.js +2 -14
- package/dist/container.js.map +1 -1
- package/dist/container.tokens.js +1 -3
- package/dist/container.tokens.js.map +1 -1
- package/dist/controllers/plugin-firmware-update.controller.js +4 -6
- package/dist/controllers/plugin-firmware-update.controller.js.map +1 -1
- package/dist/controllers/printer-files.controller.js +19 -22
- package/dist/controllers/printer-files.controller.js.map +1 -1
- package/dist/controllers/printer-settings.controller.js +3 -3
- package/dist/controllers/printer-settings.controller.js.map +1 -1
- package/dist/controllers/printer.controller.js +14 -8
- package/dist/controllers/printer.controller.js.map +1 -1
- package/dist/controllers/server-private.controller.js +2 -16
- package/dist/controllers/server-private.controller.js.map +1 -1
- package/dist/controllers/server-public.controller.js +0 -2
- package/dist/controllers/server-public.controller.js.map +1 -1
- package/dist/handlers/validators.js +9 -6
- package/dist/handlers/validators.js.map +1 -1
- package/dist/server.constants.js +1 -2
- package/dist/server.constants.js.map +1 -1
- package/dist/server.env.js +3 -25
- package/dist/server.env.js.map +1 -1
- package/dist/server.host.js +3 -1
- package/dist/server.host.js.map +1 -1
- package/dist/services/core/http-client.factory.js +40 -0
- package/dist/services/core/http-client.factory.js.map +1 -0
- package/dist/services/core/logs-manager.service.js +4 -3
- package/dist/services/core/logs-manager.service.js.map +1 -1
- package/dist/services/core/multer.service.js +72 -22
- package/dist/services/core/multer.service.js.map +1 -1
- package/dist/services/interfaces/file-upload-tracker.interface.js +6 -0
- package/dist/services/interfaces/file-upload-tracker.interface.js.map +1 -0
- package/dist/services/interfaces/printer.dto.js +6 -0
- package/dist/services/interfaces/printer.dto.js.map +1 -1
- package/dist/services/mongoose/printer.service.js +10 -3
- package/dist/services/mongoose/printer.service.js.map +1 -1
- package/dist/services/moonraker/moonraker-websocket.adapter.js +6 -2
- package/dist/services/moonraker/moonraker-websocket.adapter.js.map +1 -1
- package/dist/services/moonraker/moonraker.client.js +196 -156
- package/dist/services/moonraker/moonraker.client.js.map +1 -1
- package/dist/services/octoprint/dto/plugin.dto.js +6 -0
- package/dist/services/octoprint/dto/plugin.dto.js.map +1 -0
- package/dist/services/octoprint/octoprint-api.routes.js +0 -61
- package/dist/services/octoprint/octoprint-api.routes.js.map +1 -1
- package/dist/services/octoprint/octoprint-websocket.adapter.js +11 -5
- package/dist/services/octoprint/octoprint-websocket.adapter.js.map +1 -1
- package/dist/services/octoprint/octoprint.client.js +118 -201
- package/dist/services/octoprint/octoprint.client.js.map +1 -1
- package/dist/services/octoprint/plugin-base.service.js +15 -15
- package/dist/services/octoprint/plugin-base.service.js.map +1 -1
- package/dist/services/octoprint/plugin-firmware-update.service.js +1 -1
- package/dist/services/octoprint/plugin-firmware-update.service.js.map +1 -1
- package/dist/services/octoprint/plugin-repository.cache.js +2 -1
- package/dist/services/octoprint/plugin-repository.cache.js.map +1 -1
- package/dist/services/octoprint/utils/octoprint-http-client.builder.js +31 -0
- package/dist/services/octoprint/utils/octoprint-http-client.builder.js.map +1 -0
- package/dist/services/octoprint.api.js +6 -4
- package/dist/services/octoprint.api.js.map +1 -1
- package/dist/services/orm/printer.service.js +8 -3
- package/dist/services/orm/printer.service.js.map +1 -1
- package/dist/shared/default-http-client.builder.js +94 -0
- package/dist/shared/default-http-client.builder.js.map +1 -0
- package/dist/shared/websocket.adapter.js.map +1 -1
- package/dist/state/file-upload-tracker.cache.js +30 -40
- package/dist/state/file-upload-tracker.cache.js.map +1 -1
- package/dist/state/settings.store.js +4 -1
- package/dist/state/settings.store.js.map +1 -1
- package/dist/state/test-printer-socket.store.js.map +1 -1
- package/dist/state/validation/create-test-printer.validation.js +1 -0
- package/dist/state/validation/create-test-printer.validation.js.map +1 -1
- package/dist/tasks/boot.task.js +1 -2
- package/dist/tasks/boot.task.js.map +1 -1
- package/dist/tasks/printer-websocket-restore.task.js +1 -1
- package/dist/tasks/printer-websocket-restore.task.js.map +1 -1
- package/dist/tasks/socketio.task.js +2 -2
- package/dist/tasks/socketio.task.js.map +1 -1
- package/dist/tasks.js.map +1 -1
- package/dist/utils/env.utils.js +0 -42
- package/dist/utils/env.utils.js.map +1 -1
- package/dist/utils/normalize-url.js +3 -1
- package/dist/utils/normalize-url.js.map +1 -1
- package/dist/utils/pretty-print.utils.js +1 -1
- package/dist/utils/pretty-print.utils.js.map +1 -1
- package/dist/utils/url.utils.js +12 -14
- package/dist/utils/url.utils.js.map +1 -1
- package/package.json +40 -55
- package/dist/services/core/server-update.service.js +0 -71
- package/dist/services/core/server-update.service.js.map +0 -1
- package/requests/moonraker/api_job.http +0 -5
- package/requests/moonraker/api_printer.http +0 -5
- package/requests/moonraker/api_settings.http +0 -5
- package/requests/moonraker/printer_info.http +0 -5
- package/requests/moonraker/printer_objects_list.http +0 -6
- package/requests/moonraker/printer_objects_pause_resume.http +0 -6
- package/requests/moonraker/printer_objects_print_stats.http +0 -6
- package/requests/moonraker/printer_objects_webhooks.http +0 -6
- package/requests/moonraker/server_info.http +0 -5
- package/requests/octoprint/octoprint-api-printer-current.http +0 -7
- package/requests/octoprint/octoprint-pluginmanager-plugins.http +0 -7
- package/requests/printer-file/get-partial-file-moonraker.http +0 -5
- package/requests/printer-file/get-thumbnails.http +0 -5
- package/requests/printer-file/reload-printer-thumbnails.http +0 -10
- package/requests/printer-file/testfile.gcode +0 -5665
- package/requests/printer-file/upload-file.http +0 -11
- package/requests/printer-file/upload-slicer-file.http +0 -11
- package/requests/printers/list.http +0 -5
|
@@ -31,16 +31,16 @@ class PluginBaseService {
|
|
|
31
31
|
return this._pluginName;
|
|
32
32
|
}
|
|
33
33
|
async isPluginUpToDate(printerLogin) {
|
|
34
|
-
const response = await this
|
|
34
|
+
const response = await this.queryInstalledPlugin(printerLogin);
|
|
35
35
|
const result = this.pluginRepositoryCache.getPlugin(this.pluginName);
|
|
36
36
|
return result?.github?.latest_release.name === response.version;
|
|
37
37
|
}
|
|
38
|
-
async
|
|
38
|
+
async queryInstalledPlugin(printerLogin) {
|
|
39
39
|
const response = await this.octoprintClient.getPluginManagerPlugin(printerLogin, this.pluginName);
|
|
40
|
-
if (!response) {
|
|
40
|
+
if (!response.data) {
|
|
41
41
|
throw new _runtimeexceptions.InternalServerException("Plugin query response was empty");
|
|
42
42
|
}
|
|
43
|
-
return response.plugin;
|
|
43
|
+
return response.data.plugin;
|
|
44
44
|
}
|
|
45
45
|
async isPluginInstalled(printerLogin) {
|
|
46
46
|
const foundPlugin = await this.findPluginFromListQuery(printerLogin);
|
|
@@ -48,10 +48,10 @@ class PluginBaseService {
|
|
|
48
48
|
}
|
|
49
49
|
async findPluginFromListQuery(printerLogin) {
|
|
50
50
|
const response = await this.octoprintClient.getPluginManagerPlugins(printerLogin);
|
|
51
|
-
if (!response?.plugins?.length) {
|
|
51
|
+
if (!response.data?.plugins?.length) {
|
|
52
52
|
throw new _runtimeexceptions.InternalServerException("Plugin query response was empty");
|
|
53
53
|
}
|
|
54
|
-
return this.findPluginInList(response.plugins);
|
|
54
|
+
return this.findPluginInList(response.data.plugins);
|
|
55
55
|
}
|
|
56
56
|
findPluginInList(pluginList) {
|
|
57
57
|
return pluginList.find((p)=>p.key.toLowerCase() === this.pluginName.toLowerCase());
|
|
@@ -59,40 +59,40 @@ class PluginBaseService {
|
|
|
59
59
|
async updatePlugin(login) {
|
|
60
60
|
return await this.octoprintClient.postSoftwareUpdate(login, [
|
|
61
61
|
this.pluginName
|
|
62
|
-
]
|
|
62
|
+
]);
|
|
63
63
|
}
|
|
64
64
|
async installPlugin(login, restartAfter = false) {
|
|
65
65
|
const command = _octoprintserviceconstants.pluginManagerCommands.install.name;
|
|
66
66
|
const plugin = this.pluginRepositoryCache.getPlugin(this.pluginName);
|
|
67
67
|
await this.octoprintClient.postApiPluginManagerCommand(login, command, plugin.archive);
|
|
68
|
-
await this
|
|
68
|
+
await this.conditionalRestartCommand(login, restartAfter);
|
|
69
69
|
}
|
|
70
70
|
async uninstallPlugin(login, restartAfter = false) {
|
|
71
71
|
const command = _octoprintserviceconstants.pluginManagerCommands.uninstall.name;
|
|
72
72
|
await this.octoprintClient.postApiPluginManagerCommand(login, command, this.pluginName);
|
|
73
|
-
await this
|
|
73
|
+
await this.conditionalRestartCommand(login, restartAfter);
|
|
74
74
|
}
|
|
75
75
|
async enablePlugin(login, restartAfter = false) {
|
|
76
76
|
const command = _octoprintserviceconstants.pluginManagerCommands.enable.name;
|
|
77
77
|
await this.octoprintClient.postApiPluginManagerCommand(login, command, this.pluginName);
|
|
78
|
-
await this
|
|
78
|
+
await this.conditionalRestartCommand(login, restartAfter);
|
|
79
79
|
}
|
|
80
80
|
async disablePlugin(login, restartAfter = false) {
|
|
81
81
|
const command = _octoprintserviceconstants.pluginManagerCommands.disable.name;
|
|
82
82
|
await this.octoprintClient.postApiPluginManagerCommand(login, command, this.pluginName);
|
|
83
|
-
await this
|
|
83
|
+
await this.conditionalRestartCommand(login, restartAfter);
|
|
84
84
|
}
|
|
85
85
|
async cleanupPlugin(login, restartAfter = false) {
|
|
86
86
|
const command = _octoprintserviceconstants.pluginManagerCommands.cleanup.name;
|
|
87
87
|
await this.octoprintClient.postApiPluginManagerCommand(login, command, this.pluginName);
|
|
88
|
-
await this
|
|
88
|
+
await this.conditionalRestartCommand(login, restartAfter);
|
|
89
89
|
}
|
|
90
90
|
async cleanupAllPlugins(login, restartAfter = false) {
|
|
91
91
|
const command = _octoprintserviceconstants.pluginManagerCommands.cleanup_all.name;
|
|
92
|
-
await this.octoprintClient.postApiPluginManagerCommand(login, command);
|
|
93
|
-
await this
|
|
92
|
+
await this.octoprintClient.postApiPluginManagerCommand(login, command, this.pluginUrl);
|
|
93
|
+
await this.conditionalRestartCommand(login, restartAfter);
|
|
94
94
|
}
|
|
95
|
-
async
|
|
95
|
+
async conditionalRestartCommand(printerLogin, restartAfter = false) {
|
|
96
96
|
if (!restartAfter) return;
|
|
97
97
|
await this.octoprintClient.postServerRestartCommand(printerLogin);
|
|
98
98
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/octoprint/plugin-base.service.ts"],"names":["PluginBaseService","octoprintClient","pluginRepositoryCache","_pluginName","pluginUrl","logger","constructor","loggerFactory","pluginName","pluginReference","getPlugin","archive","ValidationException","isPluginUpToDate","printerLogin","response","result","github","latest_release","name","version","getPluginManagerPlugin","InternalServerException","plugin","isPluginInstalled","foundPlugin","findPluginFromListQuery","getPluginManagerPlugins","plugins","length","findPluginInList","pluginList","find","p","key","toLowerCase","updatePlugin","login","postSoftwareUpdate","installPlugin","restartAfter","command","pluginManagerCommands","install","postApiPluginManagerCommand","uninstallPlugin","uninstall","enablePlugin","enable","disablePlugin","disable","cleanupPlugin","cleanup","cleanupAllPlugins","cleanup_all","postServerRestartCommand"],"mappings":";;;;+BAQaA;;;eAAAA;;;mCARgD;2CACvB;AAO/B,MAAMA;IAEXC,gBAAiC;IACjCC,sBAA6C;IAC5BC,YAAoB;IACpBC,UAAkB;IAEzBC,OAAsB;IAEhCC,YACE,EACEL,eAAe,EACfC,qBAAqB,EACrBK,aAAa,EAKd,EACD,EAAEC,UAAU,EAAEJ,SAAS,EAA8C,CACrE;QACA,IAAI,CAACH,eAAe,GAAGA;QACvB,IAAI,CAACC,qBAAqB,GAAGA;QAC7B,IAAI,CAACC,WAAW,GAAGK;QACnB,IAAI,CAACH,MAAM,GAAGE,cAAc,CAAC,OAAO,EAAEC,YAAY;QAElD,MAAMC,kBAAkBP,sBAAsBQ,SAAS,CAACF;QACxD,IAAI,CAACJ,SAAS,GAAGA,aAAaK,gBAAgBE,OAAO;QAErD,IAAI,CAACH,cAAc,CAACJ,WAAW;YAC7B,MAAM,IAAIQ,sCAAmB,CAAC;QAChC;IACF;IAEA,IAAIJ,aAAa;QACf,OAAO,IAAI,CAACL,WAAW;IACzB;IAEA,MAAMU,iBAAiBC,YAAsB,EAAE;QAC7C,MAAMC,WAAW,MAAM,IAAI,
|
|
1
|
+
{"version":3,"sources":["../../../src/services/octoprint/plugin-base.service.ts"],"names":["PluginBaseService","octoprintClient","pluginRepositoryCache","_pluginName","pluginUrl","logger","constructor","loggerFactory","pluginName","pluginReference","getPlugin","archive","ValidationException","isPluginUpToDate","printerLogin","response","queryInstalledPlugin","result","github","latest_release","name","version","getPluginManagerPlugin","data","InternalServerException","plugin","isPluginInstalled","foundPlugin","findPluginFromListQuery","getPluginManagerPlugins","plugins","length","findPluginInList","pluginList","find","p","key","toLowerCase","updatePlugin","login","postSoftwareUpdate","installPlugin","restartAfter","command","pluginManagerCommands","install","postApiPluginManagerCommand","conditionalRestartCommand","uninstallPlugin","uninstall","enablePlugin","enable","disablePlugin","disable","cleanupPlugin","cleanup","cleanupAllPlugins","cleanup_all","postServerRestartCommand"],"mappings":"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"}
|
|
@@ -71,7 +71,7 @@ class PluginFirmwareUpdateService extends _pluginbaseservice.PluginBaseService {
|
|
|
71
71
|
}
|
|
72
72
|
async getPrinterFirmwareVersion(printerLogin) {
|
|
73
73
|
const response = await this.octoprintClient.getSystemInfo(printerLogin);
|
|
74
|
-
const systemInfo = response.systeminfo;
|
|
74
|
+
const systemInfo = response.data.systeminfo;
|
|
75
75
|
if (!Object.keys(systemInfo).includes(connectivityProp) || !Object.keys(systemInfo).includes(firmwareProp)) {
|
|
76
76
|
throw new _runtimeexceptions.ValidationException("Could not retrieve printer firmware version as the OctoPrint response was not recognized. Is it connected?");
|
|
77
77
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/octoprint/plugin-firmware-update.service.ts"],"names":["PluginFirmwareUpdateService","config","pluginName","pluginUrl","defaultRepos","prusaFirmwareOwner","prusaFirmwareRepo","connectivityProp","firmwareProp","firmwareDownloadPath","PluginBaseService","githubService","multerService","prusaFirmwareReleases","latestFirmware","constructor","octoprintClient","pluginRepositoryCache","loggerFactory","queryGithubPrusaFirmwareReleasesCache","response","getReleases","data","e","logger","error","length","log","url","tag_name","downloadFirmware","ValidationException","firmwareAsset","assets","find","asset","name","includes","downloadUrl","browser_download_url","downloadName","fileExists","downloadFile","getPrinterFirmwareVersion","printerLogin","getSystemInfo","systemInfo","systeminfo","Object","keys","connected","firmware","getPluginFirmwareStatus","getPluginFirmwareUpdateStatus","configureFirmwareUpdaterSettings","updateFirmwareUpdaterSettings","defaultFirmwareUpdaterSettings","flashPrusaFirmware","currentPrinterId","latestHexFilePath","getNewestFile","postPluginFirmwareUpdateFlash"],"mappings":";;;;+BA0BaA;;;eAAAA;;;mCA1BqB;mCACE;iDACW;AAU/C,MAAMC,SAAS;IACbC,YAAY;IACZC,WAAW;AACb;AAEA,MAAMC,eAAe;IACnBC,oBAAoB;IACpBC,mBAAmB;AACrB;AAEA,MAAMC,mBAAmB;AACzB,MAAMC,eAAe;AACrB,MAAMC,uBAAuB;AAEtB,MAAMT,oCAAoCU,oCAAiB;IAChEC,cAA6B;IACrBC,cAA6B;IAE7BC,sBAA6F;IAC7FC,eAA8F;IAEtGC,YAAY,EACVC,eAAe,EACfC,qBAAqB,EACrBN,aAAa,EACbC,aAAa,EACbM,aAAa,EAOd,CAAE;QACD,KAAK,CAAC;YAAEF;YAAiBC;YAAuBC;QAAc,GAAGjB;QACjE,IAAI,CAACe,eAAe,GAAGA;QACvB,IAAI,CAACL,aAAa,GAAGA;QACrB,IAAI,CAACC,aAAa,GAAGA;IACvB;IAEA,MAAMO,wCAAwC;QAC5C,IAAI;YACF,MAAMC,WAAW,MAAM,IAAI,CAACT,aAAa,CAACU,WAAW,CAACjB,aAAaC,kBAAkB,EAAED,aAAaE,iBAAiB;YACrH,IAAI,CAACO,qBAAqB,GAAGO,SAASE,IAAI;QAC5C,EAAE,OAAOC,GAAG;YACV,OAAO,IAAI,CAACC,MAAM,CAACC,KAAK,CAAC;QAC3B;QAEA,IAAI,CAAC,IAAI,CAACZ,qBAAqB,EAAEa,QAAQ,OAAO,EAAE;QAElD,IAAI,CAACZ,cAAc,GAAG,IAAI,CAACD,qBAAqB,CAAC,EAAE;QACnD,IAAI,CAACW,MAAM,CAACG,GAAG,CAAC,CAAC,yBAAyB,EAAE,IAAI,CAACd,qBAAqB,EAAEa,UAAU,IAAI,kBAAkB,CAAC,EAAE;YACzGE,KAAK,IAAI,CAACd,cAAc,CAACc,GAAG;YAC5BC,UAAU,IAAI,CAACf,cAAc,CAACe,QAAQ;QACxC;QAEA,OAAO,IAAI,CAAChB,qBAAqB;IACnC;IAEA,MAAMiB,mBAAmB;QACvB,IAAI,CAAC,IAAI,CAACjB,qBAAqB,EAAEa,UAAU,CAAC,IAAI,CAACZ,cAAc,EAAE;YAC/D,MAAM,IAAIiB,sCAAmB,CAAC;QAChC;QAEA,MAAMjB,iBAAiB,IAAI,CAACD,qBAAqB,CAAC,EAAE;QAGpD,MAAMmB,gBAAgBlB,eAAemB,MAAM,CAACC,IAAI,CAAC,CAACC,QAAUA,MAAMC,IAAI,CAACC,QAAQ,CAAC;QAChF,MAAMC,cAAcN,cAAcO,oBAAoB;QACtD,MAAMC,eAAeR,cAAcI,IAAI;QACvC,IAAI,CAACZ,MAAM,CAACG,GAAG,CAAC,CAAC,kBAAkB,EAAEa,cAAc;QACnD,IAAI,CAAC,IAAI,CAAC5B,aAAa,CAAC6B,UAAU,CAACD,cAAc/B,uBAAuB;YACtE,IAAI,CAACe,MAAM,CAACG,GAAG,CAAC,CAAC,0BAA0B,EAAEW,aAAa;YAC1D,MAAM,IAAI,CAAC1B,aAAa,CAAC8B,YAAY,CAACJ,aAAaE,cAAc/B;YACjE,IAAI,CAACe,MAAM,CAACG,GAAG,CAAC,CAAC,oBAAoB,EAAEa,cAAc;QACvD,OAAO;YACL,IAAI,CAAChB,MAAM,CAACG,GAAG,CAAC,CAAC,eAAe,EAAEa,cAAc;QAClD;IACF;IAEA,MAAMG,0BAA0BC,YAAsB,EAAE;QACtD,MAAMxB,WAAW,MAAM,IAAI,CAACJ,eAAe,CAAC6B,aAAa,CAACD;QAC1D,MAAME,aAAa1B,
|
|
1
|
+
{"version":3,"sources":["../../../src/services/octoprint/plugin-firmware-update.service.ts"],"names":["PluginFirmwareUpdateService","config","pluginName","pluginUrl","defaultRepos","prusaFirmwareOwner","prusaFirmwareRepo","connectivityProp","firmwareProp","firmwareDownloadPath","PluginBaseService","githubService","multerService","prusaFirmwareReleases","latestFirmware","constructor","octoprintClient","pluginRepositoryCache","loggerFactory","queryGithubPrusaFirmwareReleasesCache","response","getReleases","data","e","logger","error","length","log","url","tag_name","downloadFirmware","ValidationException","firmwareAsset","assets","find","asset","name","includes","downloadUrl","browser_download_url","downloadName","fileExists","downloadFile","getPrinterFirmwareVersion","printerLogin","getSystemInfo","systemInfo","systeminfo","Object","keys","connected","firmware","getPluginFirmwareStatus","getPluginFirmwareUpdateStatus","configureFirmwareUpdaterSettings","updateFirmwareUpdaterSettings","defaultFirmwareUpdaterSettings","flashPrusaFirmware","currentPrinterId","latestHexFilePath","getNewestFile","postPluginFirmwareUpdateFlash"],"mappings":";;;;+BA0BaA;;;eAAAA;;;mCA1BqB;mCACE;iDACW;AAU/C,MAAMC,SAAS;IACbC,YAAY;IACZC,WAAW;AACb;AAEA,MAAMC,eAAe;IACnBC,oBAAoB;IACpBC,mBAAmB;AACrB;AAEA,MAAMC,mBAAmB;AACzB,MAAMC,eAAe;AACrB,MAAMC,uBAAuB;AAEtB,MAAMT,oCAAoCU,oCAAiB;IAChEC,cAA6B;IACrBC,cAA6B;IAE7BC,sBAA6F;IAC7FC,eAA8F;IAEtGC,YAAY,EACVC,eAAe,EACfC,qBAAqB,EACrBN,aAAa,EACbC,aAAa,EACbM,aAAa,EAOd,CAAE;QACD,KAAK,CAAC;YAAEF;YAAiBC;YAAuBC;QAAc,GAAGjB;QACjE,IAAI,CAACe,eAAe,GAAGA;QACvB,IAAI,CAACL,aAAa,GAAGA;QACrB,IAAI,CAACC,aAAa,GAAGA;IACvB;IAEA,MAAMO,wCAAwC;QAC5C,IAAI;YACF,MAAMC,WAAW,MAAM,IAAI,CAACT,aAAa,CAACU,WAAW,CAACjB,aAAaC,kBAAkB,EAAED,aAAaE,iBAAiB;YACrH,IAAI,CAACO,qBAAqB,GAAGO,SAASE,IAAI;QAC5C,EAAE,OAAOC,GAAG;YACV,OAAO,IAAI,CAACC,MAAM,CAACC,KAAK,CAAC;QAC3B;QAEA,IAAI,CAAC,IAAI,CAACZ,qBAAqB,EAAEa,QAAQ,OAAO,EAAE;QAElD,IAAI,CAACZ,cAAc,GAAG,IAAI,CAACD,qBAAqB,CAAC,EAAE;QACnD,IAAI,CAACW,MAAM,CAACG,GAAG,CAAC,CAAC,yBAAyB,EAAE,IAAI,CAACd,qBAAqB,EAAEa,UAAU,IAAI,kBAAkB,CAAC,EAAE;YACzGE,KAAK,IAAI,CAACd,cAAc,CAACc,GAAG;YAC5BC,UAAU,IAAI,CAACf,cAAc,CAACe,QAAQ;QACxC;QAEA,OAAO,IAAI,CAAChB,qBAAqB;IACnC;IAEA,MAAMiB,mBAAmB;QACvB,IAAI,CAAC,IAAI,CAACjB,qBAAqB,EAAEa,UAAU,CAAC,IAAI,CAACZ,cAAc,EAAE;YAC/D,MAAM,IAAIiB,sCAAmB,CAAC;QAChC;QAEA,MAAMjB,iBAAiB,IAAI,CAACD,qBAAqB,CAAC,EAAE;QAGpD,MAAMmB,gBAAgBlB,eAAemB,MAAM,CAACC,IAAI,CAAC,CAACC,QAAUA,MAAMC,IAAI,CAACC,QAAQ,CAAC;QAChF,MAAMC,cAAcN,cAAcO,oBAAoB;QACtD,MAAMC,eAAeR,cAAcI,IAAI;QACvC,IAAI,CAACZ,MAAM,CAACG,GAAG,CAAC,CAAC,kBAAkB,EAAEa,cAAc;QACnD,IAAI,CAAC,IAAI,CAAC5B,aAAa,CAAC6B,UAAU,CAACD,cAAc/B,uBAAuB;YACtE,IAAI,CAACe,MAAM,CAACG,GAAG,CAAC,CAAC,0BAA0B,EAAEW,aAAa;YAC1D,MAAM,IAAI,CAAC1B,aAAa,CAAC8B,YAAY,CAACJ,aAAaE,cAAc/B;YACjE,IAAI,CAACe,MAAM,CAACG,GAAG,CAAC,CAAC,oBAAoB,EAAEa,cAAc;QACvD,OAAO;YACL,IAAI,CAAChB,MAAM,CAACG,GAAG,CAAC,CAAC,eAAe,EAAEa,cAAc;QAClD;IACF;IAEA,MAAMG,0BAA0BC,YAAsB,EAAE;QACtD,MAAMxB,WAAW,MAAM,IAAI,CAACJ,eAAe,CAAC6B,aAAa,CAACD;QAC1D,MAAME,aAAa1B,SAASE,IAAI,CAACyB,UAAU;QAG3C,IAAI,CAACC,OAAOC,IAAI,CAACH,YAAYT,QAAQ,CAAC9B,qBAAqB,CAACyC,OAAOC,IAAI,CAACH,YAAYT,QAAQ,CAAC7B,eAAe;YAC1G,MAAM,IAAIuB,sCAAmB,CAC3B;QAEJ;QAEA,MAAMmB,YAAYJ,UAAU,CAACvC,iBAAiB;QAC9C,IAAI,CAAC2C,WAAW;YACd,MAAM,IAAInB,sCAAmB,CAAC;QAChC;QAEA,MAAMoB,WAAWL,UAAU,CAACtC,aAAa;QACzC,IAAI,CAAC2C,UAAUzB,QAAQ;YACrB,MAAM,IAAIK,sCAAmB,CAAC;QAChC;QAEA,OAAOoB;IACT;IAEA,MAAMC,wBAAwBR,YAAsB,EAAE;QACpD,OAAO,MAAM,IAAI,CAAC5B,eAAe,CAACqC,6BAA6B,CAACT;IAClE;IAEA,MAAMU,iCAAiCV,YAAsB,EAAE;QAC7D,OAAO,MAAM,IAAI,CAAC5B,eAAe,CAACuC,6BAA6B,CAACX,cAAcY,+DAA8B;IAC9G;IAEA,MAAMC,mBAAmBC,gBAAwB,EAAEd,YAAsB,EAAE;QACzE,MAAMe,oBAAoB,IAAI,CAAC/C,aAAa,CAACgD,aAAa,CAACnD;QAE3D,OAAO,MAAM,IAAI,CAACO,eAAe,CAAC6C,6BAA6B,CAACH,kBAAkBd,cAAce;IAClG;AACF"}
|
|
@@ -34,7 +34,8 @@ class PluginRepositoryCache {
|
|
|
34
34
|
];
|
|
35
35
|
}
|
|
36
36
|
async queryCache() {
|
|
37
|
-
|
|
37
|
+
const response = await this.octoprintClient.fetchOctoPrintPlugins();
|
|
38
|
+
this.pluginCache = response.data || [];
|
|
38
39
|
this.wasCached = true;
|
|
39
40
|
this.lastQueried = Date.now();
|
|
40
41
|
this.logger.log(`Plugin Cache filled with ${this.pluginCache?.length || "?"} plugins`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/octoprint/plugin-repository.cache.ts"],"names":["PluginRepositoryCache","octoprintClient","logger","wasCached","pluginCache","lastQueried","undefined","constructor","loggerFactory","name","getPlugin","pluginName","isTestEnvironment","warn","getCache","find","p","id","toLowerCase","queryCache","fetchOctoPrintPlugins","Date","now","log","length"],"mappings":";;;;+
|
|
1
|
+
{"version":3,"sources":["../../../src/services/octoprint/plugin-repository.cache.ts"],"names":["PluginRepositoryCache","octoprintClient","logger","wasCached","pluginCache","lastQueried","undefined","constructor","loggerFactory","name","getPlugin","pluginName","isTestEnvironment","warn","getCache","find","p","id","toLowerCase","queryCache","response","fetchOctoPrintPlugins","data","Date","now","log","length"],"mappings":";;;;+BAMaA;;;eAAAA;;;0BANqB;AAM3B,MAAMA;IACXC,gBAAiC;IACjCC,OAAsB;IAEtBC,YAAY,MAAM;IAClBC,cAA8B,EAAE,CAAC;IACjCC,cAAuBC,UAAU;IAEjCC,YAAY,EAAEN,eAAe,EAAEO,aAAa,EAAuE,CAAE;QACnH,IAAI,CAACP,eAAe,GAAGA;QACvB,IAAI,CAACC,MAAM,GAAGM,cAAcR,sBAAsBS,IAAI;IACxD;IAEAC,UAAUC,UAAkB,EAAE;QAC5B,IAAI,CAAC,IAAI,CAACR,SAAS,EAAE;YACnB,IAAI,CAACS,IAAAA,2BAAiB,KAAI;gBACxB,IAAI,CAACV,MAAM,CAACW,IAAI,CAAC,CAAC,wBAAwB,EAAEF,WAAW,0BAA0B,CAAC;YACpF;YACA;QACF;QAEA,OAAO,IAAI,CAACG,QAAQ,GAAGC,IAAI,CAAC,CAACC,IAAMA,EAAEC,EAAE,CAACC,WAAW,OAAOP,WAAWO,WAAW;IAClF;IAEAJ,WAAW;QACT,OAAO;eAAI,IAAI,CAACV,WAAW;SAAC;IAC9B;IAEA,MAAMe,aAAa;QACjB,MAAMC,WAAW,MAAM,IAAI,CAACnB,eAAe,CAACoB,qBAAqB;QACjE,IAAI,CAACjB,WAAW,GAAGgB,SAASE,IAAI,IAAI,EAAE;QACtC,IAAI,CAACnB,SAAS,GAAG;QACjB,IAAI,CAACE,WAAW,GAAGkB,KAAKC,GAAG;QAE3B,IAAI,CAACtB,MAAM,CAACuB,GAAG,CAAC,CAAC,yBAAyB,EAAE,IAAI,CAACrB,WAAW,EAAEsB,UAAU,IAAI,QAAQ,CAAC;QAErF,OAAO,IAAI,CAACZ,QAAQ;IACtB;AACF"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "OctoprintHttpClientBuilder", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return OctoprintHttpClientBuilder;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _defaulthttpclientbuilder = require("../../../shared/default-http-client.builder");
|
|
12
|
+
const _octoprintserviceconstants = require("../constants/octoprint-service.constants");
|
|
13
|
+
class OctoprintHttpClientBuilder extends _defaulthttpclientbuilder.DefaultHttpClientBuilder {
|
|
14
|
+
build() {
|
|
15
|
+
if (!this.axiosOptions.baseURL) {
|
|
16
|
+
throw new Error("Base URL is required");
|
|
17
|
+
}
|
|
18
|
+
return super.build();
|
|
19
|
+
}
|
|
20
|
+
withXApiKeyHeader(apiKey) {
|
|
21
|
+
if (!apiKey?.length) {
|
|
22
|
+
throw new Error("XApiKey header may not be an empty string");
|
|
23
|
+
}
|
|
24
|
+
this.withHeaders({
|
|
25
|
+
[_octoprintserviceconstants.apiKeyHeaderKey]: apiKey
|
|
26
|
+
});
|
|
27
|
+
return this;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
//# sourceMappingURL=octoprint-http-client.builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/services/octoprint/utils/octoprint-http-client.builder.ts"],"names":["OctoprintHttpClientBuilder","DefaultHttpClientBuilder","build","axiosOptions","baseURL","Error","withXApiKeyHeader","apiKey","length","withHeaders","apiKeyHeaderKey"],"mappings":";;;;+BAIaA;;;eAAAA;;;0CAJ4B;2CACT;AAGzB,MAAMA,mCAAmCC,kDAAwB;IACtDC,QAAgC;QAC9C,IAAI,CAAC,IAAI,CAACC,YAAY,CAACC,OAAO,EAAE;YAC9B,MAAM,IAAIC,MAAM;QAClB;QAEA,OAAO,KAAK,CAACH;IACf;IAEOI,kBAAkBC,MAAc,EAA8B;QACnE,IAAI,CAACA,QAAQC,QAAQ;YACnB,MAAM,IAAIH,MAAM;QAClB;QAEA,IAAI,CAACI,WAAW,CAAC;YAAE,CAACC,0CAAe,CAAC,EAAEH;QAAO;QAE7C,OAAO,IAAI;IACb;AACF"}
|
|
@@ -104,12 +104,14 @@ class OctoprintApi {
|
|
|
104
104
|
await this.client.deleteFileOrFolder(this.login, path);
|
|
105
105
|
}
|
|
106
106
|
async getSettings() {
|
|
107
|
-
|
|
107
|
+
const response = await this.client.getSettings(this.login);
|
|
108
|
+
return response.data;
|
|
108
109
|
}
|
|
109
110
|
async getReprintState() {
|
|
110
|
-
const
|
|
111
|
-
const connectionState =
|
|
112
|
-
const
|
|
111
|
+
const connectedResponse = await this.client.getConnection(this.login);
|
|
112
|
+
const connectionState = connectedResponse.data.current?.state;
|
|
113
|
+
const selectedJobResponse = await this.client.getJob(this.login);
|
|
114
|
+
const selectedJob = selectedJobResponse.data;
|
|
113
115
|
const currentJobFile = selectedJob?.job?.file;
|
|
114
116
|
if (!currentJobFile?.name) {
|
|
115
117
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/octoprint.api.ts"],"names":["OctoprintApi","client","printerLogin","constructor","octoprintClient","type","OctoprintType","login","getVersion","result","getApiVersion","data","server","connect","sendConnectionCommand","connectCommand","disconnect","disconnectCommand","restartServer","postServerRestartCommand","restartHost","NotImplementedException","restartPrinterFirmware","startPrint","filePath","postSelectPrintFile","pausePrint","sendJobCommand","pauseJobCommand","resumePrint","resumeJobCommand","cancelPrint","cancelJobCommand","sendGcode","script","sendCustomGCodeCommand","quickStop","movePrintHead","amounts","sendPrintHeadJogCommand","homeAxes","axes","sendPrintHeadHomeCommand","getFile","path","file","size","date","getFiles","files","getLocalFiles","map","f","downloadFile","getFileChunk","startBytes","endBytes","uploadFile","fileOrBuffer","uploadToken","uploadFileAsMultiPart","select","print","deleteFile","deleteFileOrFolder","deleteFolder","getSettings","getReprintState","
|
|
1
|
+
{"version":3,"sources":["../../src/services/octoprint.api.ts"],"names":["OctoprintApi","client","printerLogin","constructor","octoprintClient","type","OctoprintType","login","getVersion","result","getApiVersion","data","server","connect","sendConnectionCommand","connectCommand","disconnect","disconnectCommand","restartServer","postServerRestartCommand","restartHost","NotImplementedException","restartPrinterFirmware","startPrint","filePath","postSelectPrintFile","pausePrint","sendJobCommand","pauseJobCommand","resumePrint","resumeJobCommand","cancelPrint","cancelJobCommand","sendGcode","script","sendCustomGCodeCommand","quickStop","movePrintHead","amounts","sendPrintHeadJogCommand","homeAxes","axes","sendPrintHeadHomeCommand","getFile","path","file","size","date","getFiles","files","getLocalFiles","map","f","downloadFile","getFileChunk","startBytes","endBytes","uploadFile","fileOrBuffer","uploadToken","uploadFileAsMultiPart","select","print","deleteFile","deleteFileOrFolder","deleteFolder","getSettings","response","getReprintState","connectedResponse","getConnection","connectionState","current","state","selectedJobResponse","getJob","selectedJob","currentJobFile","job","name","reprintState","ReprintState","NoLastPrint","LastPrintReady","getThumbnail"],"mappings":"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"}
|
|
@@ -11,10 +11,11 @@ Object.defineProperty(exports, "PrinterService", {
|
|
|
11
11
|
const _printerdto = require("../interfaces/printer.dto");
|
|
12
12
|
const _printerentity = require("../../entities/printer.entity");
|
|
13
13
|
const _baseservice = require("./base.service");
|
|
14
|
-
const _urlutils = require("../../utils/url.utils");
|
|
15
14
|
const _validators = require("../../handlers/validators");
|
|
16
15
|
const _printerservicevalidation = require("../validators/printer-service.validation");
|
|
17
16
|
const _eventconstants = require("../../constants/event.constants");
|
|
17
|
+
const _normalizeurl = require("../../utils/normalize-url");
|
|
18
|
+
const _urlutils = require("../../utils/url.utils");
|
|
18
19
|
class PrinterService extends (0, _baseservice.BaseService)(_printerentity.Printer, _printerdto.PrinterDto) {
|
|
19
20
|
logger;
|
|
20
21
|
eventEmitter2;
|
|
@@ -66,7 +67,9 @@ class PrinterService extends (0, _baseservice.BaseService)(_printerentity.Printe
|
|
|
66
67
|
async update(printerId, partial) {
|
|
67
68
|
const printer = await this.get(printerId);
|
|
68
69
|
if (partial.printerURL) {
|
|
69
|
-
partial.printerURL = (0,
|
|
70
|
+
partial.printerURL = (0, _normalizeurl.normalizeUrl)(partial.printerURL, {
|
|
71
|
+
defaultProtocol: _urlutils.defaultHttpProtocol
|
|
72
|
+
});
|
|
70
73
|
}
|
|
71
74
|
Object.assign(printer, partial);
|
|
72
75
|
const { printerURL, apiKey, enabled, name, printerType } = await (0, _validators.validateInput)(printer, _printerservicevalidation.createPrinterRules);
|
|
@@ -153,7 +156,9 @@ class PrinterService extends (0, _baseservice.BaseService)(_printerentity.Printe
|
|
|
153
156
|
...printer
|
|
154
157
|
};
|
|
155
158
|
if (mergedPrinter.printerURL?.length) {
|
|
156
|
-
mergedPrinter.printerURL = (0,
|
|
159
|
+
mergedPrinter.printerURL = (0, _normalizeurl.normalizeUrl)(mergedPrinter.printerURL, {
|
|
160
|
+
defaultProtocol: _urlutils.defaultHttpProtocol
|
|
161
|
+
});
|
|
157
162
|
}
|
|
158
163
|
return await (0, _validators.validateInput)(mergedPrinter, _printerservicevalidation.createPrinterRules);
|
|
159
164
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/services/orm/printer.service.ts"],"names":["PrinterService","BaseService","Printer","PrinterDto","logger","eventEmitter2","constructor","loggerFactory","typeormService","name","toUnsafeDto","entity","toDto","apiKey","printerURL","printerType","id","enabled","disabledReason","dateAdded","list","repository","find","order","create","newPrinter","emitEvent","mergedPrinter","validateAndDefault","Date","now","printer","emit","printerEvents","printerCreated","update","printerId","partial","get","
|
|
1
|
+
{"version":3,"sources":["../../../src/services/orm/printer.service.ts"],"names":["PrinterService","BaseService","Printer","PrinterDto","logger","eventEmitter2","constructor","loggerFactory","typeormService","name","toUnsafeDto","entity","toDto","apiKey","printerURL","printerType","id","enabled","disabledReason","dateAdded","list","repository","find","order","create","newPrinter","emitEvent","mergedPrinter","validateAndDefault","Date","now","printer","emit","printerEvents","printerCreated","update","printerId","partial","get","normalizeUrl","defaultProtocol","defaultHttpProtocol","Object","assign","validateInput","createPrinterRules","updatedPrinter","printerUpdated","batchImport","printers","length","log","newPrinters","createdPrinter","push","batchPrinterCreated","delete","result","printersDeleted","printerIds","deleteMany","updateConnectionSettings","updateDisabledReason","updateEnabled","updateFeedRate","feedRate","updateFlowRate","flowRate"],"mappings":"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"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "DefaultHttpClientBuilder", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return DefaultHttpClientBuilder;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
const _serversettingsconstants = require("../constants/server-settings.constants");
|
|
12
|
+
const _axios = /*#__PURE__*/ _interop_require_default(require("axios"));
|
|
13
|
+
const _octoprintserviceconstants = require("../services/octoprint/constants/octoprint-service.constants");
|
|
14
|
+
function _interop_require_default(obj) {
|
|
15
|
+
return obj && obj.__esModule ? obj : {
|
|
16
|
+
default: obj
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
class DefaultHttpClientBuilder {
|
|
20
|
+
axiosOptions;
|
|
21
|
+
constructor(){
|
|
22
|
+
this.axiosOptions = {
|
|
23
|
+
baseURL: "",
|
|
24
|
+
timeout: (0, _serversettingsconstants.getDefaultTimeout)().apiTimeout,
|
|
25
|
+
headers: {
|
|
26
|
+
[_octoprintserviceconstants.contentTypeHeaderKey]: _octoprintserviceconstants.jsonContentType
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
build() {
|
|
31
|
+
const axiosConfig = {
|
|
32
|
+
baseURL: this.axiosOptions.baseURL,
|
|
33
|
+
timeout: this.axiosOptions.timeout,
|
|
34
|
+
headers: this.axiosOptions.headers,
|
|
35
|
+
data: this.axiosOptions.data,
|
|
36
|
+
maxBodyLength: this.axiosOptions.maxBodyLength ?? 1000 * 1000 * 1000,
|
|
37
|
+
maxContentLength: this.axiosOptions.maxContentLength ?? 1000 * 1000 * 1000,
|
|
38
|
+
responseType: this.axiosOptions.responseType,
|
|
39
|
+
onUploadProgress: this.axiosOptions.onUploadProgress
|
|
40
|
+
};
|
|
41
|
+
return _axios.default.create(axiosConfig);
|
|
42
|
+
}
|
|
43
|
+
withMaxBodyLength(maxBodyLength) {
|
|
44
|
+
this.axiosOptions.maxBodyLength = maxBodyLength;
|
|
45
|
+
return this;
|
|
46
|
+
}
|
|
47
|
+
withMaxContentLength(maxContentLength) {
|
|
48
|
+
this.axiosOptions.maxContentLength = maxContentLength;
|
|
49
|
+
return this;
|
|
50
|
+
}
|
|
51
|
+
withBaseUrl(baseUrl) {
|
|
52
|
+
if (!baseUrl?.length) {
|
|
53
|
+
throw new Error("Base address may not be an empty string");
|
|
54
|
+
}
|
|
55
|
+
this.axiosOptions.baseURL = baseUrl;
|
|
56
|
+
return this;
|
|
57
|
+
}
|
|
58
|
+
withTimeout(timeout) {
|
|
59
|
+
if (!timeout || timeout <= 0) {
|
|
60
|
+
throw new Error("Timeout value (milliseconds) must be greater than 0");
|
|
61
|
+
}
|
|
62
|
+
this.axiosOptions.timeout = timeout;
|
|
63
|
+
return this;
|
|
64
|
+
}
|
|
65
|
+
withMultiPartFormData() {
|
|
66
|
+
this.withHeaders({
|
|
67
|
+
"Content-Type": _octoprintserviceconstants.multiPartContentType
|
|
68
|
+
});
|
|
69
|
+
return this;
|
|
70
|
+
}
|
|
71
|
+
withStreamResponse() {
|
|
72
|
+
this.axiosOptions.responseType = "stream";
|
|
73
|
+
return this;
|
|
74
|
+
}
|
|
75
|
+
withOnUploadProgress(handler) {
|
|
76
|
+
this.axiosOptions.onUploadProgress = handler;
|
|
77
|
+
return this;
|
|
78
|
+
}
|
|
79
|
+
withJsonContentTypeHeader() {
|
|
80
|
+
this.withHeaders({
|
|
81
|
+
[_octoprintserviceconstants.contentTypeHeaderKey]: _octoprintserviceconstants.jsonContentType
|
|
82
|
+
});
|
|
83
|
+
return this;
|
|
84
|
+
}
|
|
85
|
+
withHeaders(headers) {
|
|
86
|
+
this.axiosOptions.headers = {
|
|
87
|
+
...this.axiosOptions.headers,
|
|
88
|
+
...headers
|
|
89
|
+
};
|
|
90
|
+
return this;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
//# sourceMappingURL=default-http-client.builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/shared/default-http-client.builder.ts"],"names":["DefaultHttpClientBuilder","axiosOptions","constructor","baseURL","timeout","getDefaultTimeout","apiTimeout","headers","contentTypeHeaderKey","jsonContentType","build","axiosConfig","data","maxBodyLength","maxContentLength","responseType","onUploadProgress","axios","create","withMaxBodyLength","withMaxContentLength","withBaseUrl","baseUrl","length","Error","withTimeout","withMultiPartFormData","withHeaders","multiPartContentType","withStreamResponse","withOnUploadProgress","handler","withJsonContentTypeHeader"],"mappings":";;;;+BAYaA;;;eAAAA;;;yCAZqB;8DAC2C;2CAKtE;;;;;;AAMA,MAAMA;IACDC,aAAiC;IAE3CC,aAAc;QACZ,IAAI,CAACD,YAAY,GAAG;YAClBE,SAAS;YACTC,SAASC,IAAAA,0CAAiB,IAAGC,UAAU;YACvCC,SAAS;gBACP,CAACC,+CAAoB,CAAC,EAAEC,0CAAe;YACzC;QACF;IACF;IAEAC,QAAgC;QAC9B,MAAMC,cAAqC;YACzCR,SAAS,IAAI,CAACF,YAAY,CAACE,OAAO;YAClCC,SAAS,IAAI,CAACH,YAAY,CAACG,OAAO;YAClCG,SAAS,IAAI,CAACN,YAAY,CAACM,OAAO;YAClCK,MAAM,IAAI,CAACX,YAAY,CAACW,IAAI;YAC5BC,eAAe,IAAI,CAACZ,YAAY,CAACY,aAAa,IAAI,OAAO,OAAO;YAChEC,kBAAkB,IAAI,CAACb,YAAY,CAACa,gBAAgB,IAAI,OAAO,OAAO;YACtEC,cAAc,IAAI,CAACd,YAAY,CAACc,YAAY;YAC5CC,kBAAkB,IAAI,CAACf,YAAY,CAACe,gBAAgB;QACtD;QAEA,OAAOC,cAAK,CAACC,MAAM,CAACP;IACtB;IAEAQ,kBAAkBN,aAAqB,EAA4B;QACjE,IAAI,CAACZ,YAAY,CAACY,aAAa,GAAGA;QAClC,OAAO,IAAI;IACb;IAEAO,qBAAqBN,gBAAwB,EAA4B;QACvE,IAAI,CAACb,YAAY,CAACa,gBAAgB,GAAGA;QACrC,OAAO,IAAI;IACb;IAEAO,YAAYC,OAAe,EAA4B;QACrD,IAAI,CAACA,SAASC,QAAQ;YACpB,MAAM,IAAIC,MAAM;QAClB;QAEA,IAAI,CAACvB,YAAY,CAACE,OAAO,GAAGmB;QAC5B,OAAO,IAAI;IACb;IAMAG,YAAYrB,OAAe,EAA4B;QACrD,IAAI,CAACA,WAAWA,WAAW,GAAG;YAC5B,MAAM,IAAIoB,MAAM;QAClB;QAEA,IAAI,CAACvB,YAAY,CAACG,OAAO,GAAGA;QAC5B,OAAO,IAAI;IACb;IAEAsB,wBAA8B;QAC5B,IAAI,CAACC,WAAW,CAAC;YACf,gBAAgBC,+CAAoB;QACtC;QACA,OAAO,IAAI;IACb;IAEAC,qBAA2B;QACzB,IAAI,CAAC5B,YAAY,CAACc,YAAY,GAAG;QACjC,OAAO,IAAI;IACb;IAEAe,qBAAqBC,OAAoD,EAAQ;QAC/E,IAAI,CAAC9B,YAAY,CAACe,gBAAgB,GAAGe;QACrC,OAAO,IAAI;IACb;IAEAC,4BAAsD;QACpD,IAAI,CAACL,WAAW,CAAC;YAAE,CAACnB,+CAAoB,CAAC,EAAEC,0CAAe;QAAC;QAC3D,OAAO,IAAI;IACb;IAEAkB,YAAYpB,OAA+B,EAA4B;QACrE,IAAI,CAACN,YAAY,CAACM,OAAO,GAAG;YAC1B,GAAG,IAAI,CAACN,YAAY,CAACM,OAAO;YAC5B,GAAGA,OAAO;QACZ;QACA,OAAO,IAAI;IACb;AACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/shared/websocket.adapter.ts"],"names":["WebsocketAdapter","socket","logger","eventEmittingAllowed","constructor","loggerFactory","name","isOpened","readyState","WebSocket","OPEN","close","allowEmittingEvents","disallowEmittingEvents","open","url","handshakeTimeout","AppConstants","defaultWebsocketHandshakeTimeout","onopen","event","onOpen","onerror","error","onError","onclose","onClose","onmessage","message","onMessage","data","sendMessage","payload","Promise","resolve","reject","send","afterOpened","afterClosed"],"mappings":";;;;+BAOaA;;;eAAAA;;;iCAPgB;oBAC2D;AAMjF,MAAMA;IACXC,OAAmB;IACTC,OAAsB;IAChCC,uBAAgC,KAAK;IAErCC,YAAY,EAAEC,aAAa,EAAqC,CAAE;QAChE,IAAI,CAACH,MAAM,GAAGG,cAAcL,iBAAiBM,IAAI;IACnD;IAEA,IAAIC,WAAW;QACb,OAAO,IAAI,CAACN,MAAM,EAAEO,eAAeC,aAAS,CAACC,IAAI;IACnD;IAEOC,QAAQ;QACb,IAAI,CAACV,MAAM,EAAEU;QACb,OAAO,IAAI,CAACV,MAAM;IACpB;IAEOW,sBAAsB;QAC3B,IAAI,CAACT,oBAAoB,GAAG;IAC9B;IAEOU,yBAAyB;QAC9B,IAAI,CAACV,oBAAoB,GAAG;IAC9B;IASAW,KAAKC,GAAiB,EAAQ;QAC5B,IAAI,CAACd,MAAM,GAAG,IAAIQ,aAAS,CAACM,KAAK;
|
|
1
|
+
{"version":3,"sources":["../../src/shared/websocket.adapter.ts"],"names":["WebsocketAdapter","socket","logger","eventEmittingAllowed","constructor","loggerFactory","name","isOpened","readyState","WebSocket","OPEN","close","allowEmittingEvents","disallowEmittingEvents","open","url","handshakeTimeout","AppConstants","defaultWebsocketHandshakeTimeout","onopen","event","onOpen","onerror","error","onError","onclose","onClose","onmessage","message","onMessage","data","sendMessage","payload","Promise","resolve","reject","send","afterOpened","afterClosed"],"mappings":";;;;+BAOaA;;;eAAAA;;;iCAPgB;oBAC2D;AAMjF,MAAMA;IACXC,OAAmB;IACTC,OAAsB;IAChCC,uBAAgC,KAAK;IAErCC,YAAY,EAAEC,aAAa,EAAqC,CAAE;QAChE,IAAI,CAACH,MAAM,GAAGG,cAAcL,iBAAiBM,IAAI;IACnD;IAEA,IAAIC,WAAW;QACb,OAAO,IAAI,CAACN,MAAM,EAAEO,eAAeC,aAAS,CAACC,IAAI;IACnD;IAEOC,QAAQ;QACb,IAAI,CAACV,MAAM,EAAEU;QACb,OAAO,IAAI,CAACV,MAAM;IACpB;IAEOW,sBAAsB;QAC3B,IAAI,CAACT,oBAAoB,GAAG;IAC9B;IAEOU,yBAAyB;QAC9B,IAAI,CAACV,oBAAoB,GAAG;IAC9B;IASAW,KAAKC,GAAiB,EAAQ;QAC5B,IAAI,CAACd,MAAM,GAAG,IAAIQ,aAAS,CAACM,KAAK;YAC/BC,kBAAkBC,6BAAY,CAACC,gCAAgC;QACjE;QACA,IAAI,CAACjB,MAAM,CAACkB,MAAM,GAAG,CAACC,QAAU,IAAI,CAACC,MAAM,CAACD;QAC5C,IAAI,CAACnB,MAAM,CAACqB,OAAO,GAAG,CAACC,QAAU,IAAI,CAACC,OAAO,CAACD;QAC9C,IAAI,CAACtB,MAAM,CAACwB,OAAO,GAAG,CAACL,QAAU,IAAI,CAACM,OAAO,CAACN;QAC9C,IAAI,CAACnB,MAAM,CAAC0B,SAAS,GAAG,CAACC,UAAY,IAAI,CAACC,SAAS,CAACD,QAAQE,IAAI;IAClE;IASA,MAAgBC,YAAYC,OAAe,EAAiB;QAC1D,IAAI,CAAC,IAAI,CAACzB,QAAQ,IAAI,CAAC,IAAI,CAACN,MAAM,EAAE;YAClC,IAAI,CAACC,MAAM,CAACqB,KAAK,CAAC;YAClB;QACF;QACA,OAAO,MAAM,IAAIU,QAAQ,CAACC,SAASC;YACjC,IAAI,CAAClC,MAAM,CAAEmC,IAAI,CAACJ,SAAS,CAACT;gBAC1B,IAAIA,OAAOY,OAAOZ;gBAClBW;YACF;QACF;IACF;IASUV,QAAQD,KAAiB,EAAwB,CAAC;IASlDc,YAAYjB,KAAc,EAAwB,CAAC;IASnDkB,YAAYlB,KAAiB,EAAwB,CAAC;IAStDS,UAAUT,KAAW,EAAwB,CAAC;IAQxD,MAAcC,OAAOD,KAAc,EAAiB;QAClD,MAAM,IAAI,CAACiB,WAAW,CAACjB;IACzB;IAQA,MAAcM,QAAQN,KAAiB,EAAiB;QACtD,MAAM,IAAI,CAACkB,WAAW,CAAClB;IACzB;AACF"}
|
|
@@ -12,58 +12,53 @@ const _correlationtokenutil = require("../utils/correlation-token.util");
|
|
|
12
12
|
const _eventconstants = require("../constants/event.constants");
|
|
13
13
|
class FileUploadTrackerCache {
|
|
14
14
|
currentUploads = [];
|
|
15
|
-
uploadsDone = [];
|
|
16
|
-
uploadsFailed = [];
|
|
17
15
|
eventEmitter2;
|
|
18
16
|
logger;
|
|
19
17
|
constructor({ loggerFactory, eventEmitter2 }){
|
|
20
18
|
this.eventEmitter2 = eventEmitter2;
|
|
21
19
|
this.logger = loggerFactory(FileUploadTrackerCache.name);
|
|
20
|
+
this.eventEmitter2.on((0, _eventconstants.uploadProgressEvent)("*"), (token, progress)=>this.handleUploadProgress(token, progress));
|
|
21
|
+
this.eventEmitter2.on((0, _eventconstants.uploadDoneEvent)("*"), (token)=>this.handleUploadDone(token));
|
|
22
|
+
this.eventEmitter2.on((0, _eventconstants.uploadFailedEvent)("*"), (token, reason)=>this.handleUploadFailed(token, reason));
|
|
22
23
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
getUploads(filterHourOld = false) {
|
|
27
|
-
const currentTime = Date.now();
|
|
28
|
-
const done = this.uploadsDone.filter((d)=>currentTime - d.startedAt < 60 * 60 * 1000);
|
|
29
|
-
const failed = this.uploadsFailed.filter((d)=>currentTime - d.startedAt < 60 * 60 * 1000);
|
|
30
|
-
return filterHourOld ? {
|
|
31
|
-
current: this.currentUploads,
|
|
32
|
-
done,
|
|
33
|
-
failed
|
|
34
|
-
} : {
|
|
35
|
-
current: this.currentUploads,
|
|
36
|
-
done: this.uploadsDone,
|
|
37
|
-
failed: this.uploadsFailed
|
|
24
|
+
getUploads() {
|
|
25
|
+
return {
|
|
26
|
+
current: this.currentUploads
|
|
38
27
|
};
|
|
39
28
|
}
|
|
40
29
|
getUpload(correlationToken) {
|
|
41
30
|
return this.currentUploads.find((cu)=>cu.correlationToken === correlationToken);
|
|
42
31
|
}
|
|
43
|
-
addUploadTracker(multerFile) {
|
|
32
|
+
addUploadTracker(multerFile, printerId) {
|
|
44
33
|
const correlationToken = (0, _correlationtokenutil.generateCorrelationToken)();
|
|
45
34
|
this.logger.log(`Starting upload session with token ${correlationToken}`);
|
|
46
|
-
this.eventEmitter2.on((0, _eventconstants.uploadProgressEvent)(correlationToken), this.progressCallback);
|
|
47
35
|
this.currentUploads.push({
|
|
48
36
|
correlationToken,
|
|
37
|
+
printerId,
|
|
49
38
|
startedAt: Date.now(),
|
|
50
39
|
multerFile,
|
|
51
|
-
progress:
|
|
40
|
+
progress: 0,
|
|
41
|
+
completed: false,
|
|
42
|
+
completedAt: null,
|
|
43
|
+
success: null,
|
|
44
|
+
reason: null
|
|
52
45
|
});
|
|
53
46
|
return correlationToken;
|
|
54
47
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
this.eventEmitter2.off((0, _eventconstants.uploadProgressEvent)(token), this.progressCallback);
|
|
60
|
-
} else if (progress.failed) {
|
|
61
|
-
this.markUploadDone(token, false, reason);
|
|
62
|
-
this.eventEmitter2.off((0, _eventconstants.uploadProgressEvent)(token), this.progressCallback);
|
|
63
|
-
} else {
|
|
64
|
-
const upload = this.getUpload(token);
|
|
65
|
-
upload.progress = progress;
|
|
48
|
+
handleUploadProgress(token, event) {
|
|
49
|
+
const upload = this.getUpload(token);
|
|
50
|
+
if (!upload) {
|
|
51
|
+
return;
|
|
66
52
|
}
|
|
53
|
+
upload.progress = event.progress;
|
|
54
|
+
}
|
|
55
|
+
handleUploadFailed(token, reason) {
|
|
56
|
+
this.logger.log(`Upload tracker ${token} completed with failure`);
|
|
57
|
+
this.markUploadDone(token, false, reason);
|
|
58
|
+
}
|
|
59
|
+
handleUploadDone(token) {
|
|
60
|
+
this.logger.log(`Upload tracker ${token} completed with success`);
|
|
61
|
+
this.markUploadDone(token, true);
|
|
67
62
|
}
|
|
68
63
|
markUploadDone(token, success, reason) {
|
|
69
64
|
const trackedUploadIndex = this.currentUploads.findIndex((cu)=>cu.correlationToken === token);
|
|
@@ -72,15 +67,10 @@ class FileUploadTrackerCache {
|
|
|
72
67
|
return;
|
|
73
68
|
}
|
|
74
69
|
const trackedUpload = this.currentUploads[trackedUploadIndex];
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
} else {
|
|
80
|
-
trackedUpload.succeededAt = Date.now();
|
|
81
|
-
this.uploadsFailed.push(trackedUpload);
|
|
82
|
-
}
|
|
83
|
-
this.currentUploads.splice(trackedUploadIndex, 1);
|
|
70
|
+
trackedUpload.completed = true;
|
|
71
|
+
trackedUpload.success = success;
|
|
72
|
+
trackedUpload.completedAt = Date.now();
|
|
73
|
+
trackedUpload.reason = reason;
|
|
84
74
|
}
|
|
85
75
|
}
|
|
86
76
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/state/file-upload-tracker.cache.ts"],"names":["FileUploadTrackerCache","currentUploads","
|
|
1
|
+
{"version":3,"sources":["../../src/state/file-upload-tracker.cache.ts"],"names":["FileUploadTrackerCache","currentUploads","eventEmitter2","logger","constructor","loggerFactory","name","on","uploadProgressEvent","token","progress","handleUploadProgress","uploadDoneEvent","handleUploadDone","uploadFailedEvent","reason","handleUploadFailed","getUploads","current","getUpload","correlationToken","find","cu","addUploadTracker","multerFile","printerId","generateCorrelationToken","log","push","startedAt","Date","now","completed","completedAt","success","event","upload","markUploadDone","trackedUploadIndex","findIndex","warn","trackedUpload"],"mappings":";;;;+BASaA;;;eAAAA;;;sCAT4B;gCAC+B;AAQjE,MAAMA;IACHC,iBAAkC,EAAE,CAAC;IACrCC,cAA6B;IAC7BC,OAAsB;IAE9BC,YAAY,EAAEC,aAAa,EAAEH,aAAa,EAAmE,CAAE;QAC7G,IAAI,CAACA,aAAa,GAAGA;QACrB,IAAI,CAACC,MAAM,GAAGE,cAAcL,uBAAuBM,IAAI;QAEvD,IAAI,CAACJ,aAAa,CAACK,EAAE,CAACC,IAAAA,mCAAmB,EAAC,MAAM,CAACC,OAAOC,WAAa,IAAI,CAACC,oBAAoB,CAACF,OAAOC;QACtG,IAAI,CAACR,aAAa,CAACK,EAAE,CAACK,IAAAA,+BAAe,EAAC,MAAM,CAACH,QAAkB,IAAI,CAACI,gBAAgB,CAACJ;QACrF,IAAI,CAACP,aAAa,CAACK,EAAE,CAACO,IAAAA,iCAAiB,EAAC,MAAM,CAACL,OAAeM,SAAoB,IAAI,CAACC,kBAAkB,CAACP,OAAOM;IACnH;IAEAE,aAAa;QACX,OAAO;YACLC,SAAS,IAAI,CAACjB,cAAc;QAC9B;IACF;IAEAkB,UAAUC,gBAAwB,EAAE;QAClC,OAAO,IAAI,CAACnB,cAAc,CAACoB,IAAI,CAAC,CAACC,KAAOA,GAAGF,gBAAgB,KAAKA;IAClE;IAEAG,iBAAiBC,UAA+B,EAAEC,SAAiB,EAAE;QACnE,MAAML,mBAAmBM,IAAAA,8CAAwB;QACjD,IAAI,CAACvB,MAAM,CAACwB,GAAG,CAAC,CAAC,mCAAmC,EAAEP,kBAAkB;QAExE,IAAI,CAACnB,cAAc,CAAC2B,IAAI,CAAC;YACvBR;YACAK;YACAI,WAAWC,KAAKC,GAAG;YACnBP;YACAd,UAAU;YACVsB,WAAW;YACXC,aAAa;YACbC,SAAS;YACTnB,QAAQ;QACV;QAEA,OAAOK;IACT;IAEAT,qBAAqBF,KAAa,EAAE0B,KAAyB,EAAE;QAC7D,MAAMC,SAAS,IAAI,CAACjB,SAAS,CAACV;QAC9B,IAAI,CAAC2B,QAAQ;YACX;QACF;QACAA,OAAO1B,QAAQ,GAAGyB,MAAMzB,QAAQ;IAClC;IAEAM,mBAAmBP,KAAa,EAAEM,MAAe,EAAE;QACjD,IAAI,CAACZ,MAAM,CAACwB,GAAG,CAAC,CAAC,eAAe,EAAElB,MAAM,uBAAuB,CAAC;QAChE,IAAI,CAAC4B,cAAc,CAAC5B,OAAO,OAAOM;IACpC;IAEAF,iBAAiBJ,KAAa,EAAE;QAC9B,IAAI,CAACN,MAAM,CAACwB,GAAG,CAAC,CAAC,eAAe,EAAElB,MAAM,uBAAuB,CAAC;QAChE,IAAI,CAAC4B,cAAc,CAAC5B,OAAO;IAC7B;IAEA4B,eAAe5B,KAAa,EAAEyB,OAAgB,EAAEnB,MAAe,EAAE;QAC/D,MAAMuB,qBAAqB,IAAI,CAACrC,cAAc,CAACsC,SAAS,CAAC,CAACjB,KAAOA,GAAGF,gBAAgB,KAAKX;QACzF,IAAI6B,uBAAuB,CAAC,GAAG;YAC7B,IAAI,CAACnC,MAAM,CAACqC,IAAI,CAAC,CAAC,sDAAsD,EAAE/B,MAAM,8BAA8B,CAAC;YAC/G;QACF;QAEA,MAAMgC,gBAAgB,IAAI,CAACxC,cAAc,CAACqC,mBAAmB;QAE7DG,cAAcT,SAAS,GAAG;QAC1BS,cAAcP,OAAO,GAAGA;QACxBO,cAAcR,WAAW,GAAGH,KAAKC,GAAG;QACpCU,cAAc1B,MAAM,GAAGA;IACzB;AACF"}
|
|
@@ -109,6 +109,9 @@ class SettingsStore {
|
|
|
109
109
|
getServerSettings() {
|
|
110
110
|
return this.getSettings()[_serversettingsconstants.serverSettingsKey];
|
|
111
111
|
}
|
|
112
|
+
getTimeoutSettings() {
|
|
113
|
+
return this.getSettings()[_serversettingsconstants.timeoutSettingKey];
|
|
114
|
+
}
|
|
112
115
|
getFrontendSettings() {
|
|
113
116
|
return this.getSettings()[_serversettingsconstants.frontendSettingKey];
|
|
114
117
|
}
|
|
@@ -194,7 +197,7 @@ class SettingsStore {
|
|
|
194
197
|
this.logger.log("Disabling Sentry for remote diagnostics");
|
|
195
198
|
}
|
|
196
199
|
if ((0, _envutils.isTestEnvironment)()) return;
|
|
197
|
-
const client = (0, _node.
|
|
200
|
+
const client = (0, _node.getClient)();
|
|
198
201
|
if (!client) {
|
|
199
202
|
this.logger.warn("Could not apply Sentry. Was the SDK initialized?");
|
|
200
203
|
return;
|