UNPKG

zwave-js

Version:

Z-Wave driver written entirely in JavaScript/TypeScript

110 lines (109 loc) 5.63 kB
"use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var UpdateConfig_exports = {}; __export(UpdateConfig_exports, { checkForConfigUpdates: () => checkForConfigUpdates, installConfigUpdate: () => installConfigUpdate }); module.exports = __toCommonJS(UpdateConfig_exports); var import_untar = require("@andrewbranch/untar.js"); var import_core = require("@zwave-js/core"); var import_shared = require("@zwave-js/shared"); var import_typeguards = require("alcalzone-shared/typeguards"); var import_pathe = __toESM(require("pathe"), 1); var import_inc = __toESM(require("semver/functions/inc.js"), 1); var import_valid = __toESM(require("semver/functions/valid.js"), 1); var import_max_satisfying = __toESM(require("semver/ranges/max-satisfying.js"), 1); async function checkForConfigUpdates(currentVersion) { const { default: ky } = await import("ky"); let registry; try { registry = await ky.get("https://registry.npmjs.org/@zwave-js/config").json(); } catch { throw new import_core.ZWaveError(`Could not check for config updates: Failed to download package information!`, import_core.ZWaveErrorCodes.Config_Update_RegistryError); } if (!(0, import_typeguards.isObject)(registry) || !(0, import_typeguards.isObject)(registry.versions)) { throw new import_core.ZWaveError(`Could not check for config updates: Downloaded package information does not contain version information!`, import_core.ZWaveErrorCodes.Config_Update_RegistryError); } const allVersions = Object.keys(registry.versions).filter((v) => !!(0, import_valid.default)(v)).filter((v) => /-\d{8}$/.test(v)); const updateRange = `>${currentVersion} <${(0, import_inc.default)(currentVersion, "patch")}`; const updateVersion = (0, import_max_satisfying.default)(allVersions, updateRange, { includePrerelease: true }); if (updateVersion) return updateVersion; } __name(checkForConfigUpdates, "checkForConfigUpdates"); async function installConfigUpdate(fs, newVersion, external) { const { default: ky } = await import("ky"); let registryInfo; try { registryInfo = await ky.get(`https://registry.npmjs.org/@zwave-js/config/${newVersion}`).json(); } catch { throw new import_core.ZWaveError(`Config update failed: Could not fetch package info from npm registry!`, import_core.ZWaveErrorCodes.Config_Update_InstallFailed); } const url = registryInfo?.dist?.tarball; if (typeof url !== "string") { throw new import_core.ZWaveError(`Config update failed: Could not fetch package tarball URL from npm registry!`, import_core.ZWaveErrorCodes.Config_Update_InstallFailed); } let tarballData; try { tarballData = new Uint8Array(await ky.get(url).arrayBuffer()); } catch (e) { throw new import_core.ZWaveError(`Config update failed: Could not download tarball. Reason: ${(0, import_shared.getErrorMessage)(e)}`, import_core.ZWaveErrorCodes.Config_Update_InstallFailed); } try { const tarFiles = (0, import_untar.untar)((0, import_core.gunzipSync)(tarballData).buffer); await fs.deleteDir(external.configDir); await fs.ensureDir(external.configDir); const prefix = "package/config/"; for (const file of tarFiles) { if (!file.filename.startsWith(prefix) || !file.filename.endsWith(".json")) { continue; } const filename = file.filename.slice(prefix.length); const targetFileName = import_pathe.default.join(external.configDir, filename); const targetDirName = import_pathe.default.dirname(targetFileName); await fs.ensureDir(targetDirName); await fs.writeFile(targetFileName, new Uint8Array(file.fileData)); } const externalVersionFilename = import_pathe.default.join(external.configDir, "version"); await (0, import_shared.writeTextFile)(fs, externalVersionFilename, newVersion); } catch { throw new import_core.ZWaveError(`Config update failed: Could not extract tarball`, import_core.ZWaveErrorCodes.Config_Update_InstallFailed); } } __name(installConfigUpdate, "installConfigUpdate"); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { checkForConfigUpdates, installConfigUpdate }); //# sourceMappingURL=UpdateConfig.js.map