UNPKG

@oaklean/windows-sensorinterface

Version:

A library that provides a binary that utilizes the LibreHardwareMonitor library to capture energy measurements on Windows

136 lines 11.2 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.InstallHelper = void 0; const fs = __importStar(require("fs")); const https_1 = __importDefault(require("https")); const progress_1 = __importDefault(require("progress")); const profiler_core_1 = require("@oaklean/profiler-core"); const ZipHelper_1 = require("./ZipHelper"); const formatTime_1 = require("./formatTime"); const config_1 = require("../constants/config"); class InstallHelper { static makeRequest(url) { return new Promise((resolve, reject) => { https_1.default .get(url, (response) => __awaiter(this, void 0, void 0, function* () { if (response.statusCode !== undefined && response.statusCode >= 200 && response.statusCode < 300) { const totalLength = parseInt(response.headers['content-length'] || '0', 10); if (totalLength) { profiler_core_1.LoggerHelper.appPrefix.log(`File size (${(totalLength / (1024 * 1024)).toFixed(2)} MB)`); } let downloaded = 0; const startTime = Date.now(); const progressBar = new progress_1.default('-> downloading [:bar] :percent :rate/bps ETA: :remainingTime', { width: 40, total: totalLength || 0, complete: '=', incomplete: ' ', renderThrottle: 100 }); // eslint-disable-next-line @typescript-eslint/no-explicit-any const chunks = []; response.on('data', (chunk) => { downloaded += chunk.length; progressBar.tick(chunk.length, { remainingTime: (0, formatTime_1.formatTime)(((totalLength - downloaded) / downloaded) * ((Date.now() - startTime) / 1000)) }); chunks.push(chunk); }); response.on('end', () => { response.destroy(); progressBar.terminate(); resolve(Buffer.concat(chunks)); }); } else if (response.statusCode !== undefined && response.statusCode >= 300 && response.statusCode < 400 && response.headers.location) { // Follow redirects response.destroy(); InstallHelper.makeRequest(response.headers.location).then(resolve, reject); } else { reject(new Error(`Server responded with status code ${response.statusCode} when downloading the file!`)); } })) .on('error', (error) => { reject(error); }); }); } static downloadPlatformSpecificBinary(platform) { return __awaiter(this, void 0, void 0, function* () { // Download the tarball of the right binary distribution package const tarballDownloadBuffer = yield InstallHelper.makeRequest((0, config_1.getPlatformSpecificDownloadLink)(platform)); profiler_core_1.LoggerHelper.appPrefix.success('Download complete. Extracting...'); ZipHelper_1.ZipHelper.extractSpecificDirectory(tarballDownloadBuffer, new profiler_core_1.UnifiedPath('./'), (0, config_1.getPlatformSpecificBinaryDirectoryPath)(platform)); profiler_core_1.LoggerHelper.appPrefix.success('Installation complete.'); }); } static isPlatformSpecificPackageInstalled(platform) { return fs.existsSync((0, config_1.getPlatformSpecificBinaryPath)(platform).toPlatformString()); } static installPlatformSpecificPackage(platform) { return __awaiter(this, void 0, void 0, function* () { const platformSpecificPackageName = (0, config_1.getPlatformSpecificPackageName)(platform); if (!platformSpecificPackageName) { throw new Error('Platform not supported!'); } // Skip downloading the binary if it was already installed via optionalDependencies if (!InstallHelper.isPlatformSpecificPackageInstalled(platform)) { profiler_core_1.LoggerHelper.appPrefix.log('Energy measurement binary not found.'); profiler_core_1.LoggerHelper.appPrefix.log(`Downloading required binary for ${platform}...`); yield InstallHelper.downloadPlatformSpecificBinary(platform); } }); } } exports.InstallHelper = InstallHelper; //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5zdGFsbEhlbHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9oZWxwZXIvSW5zdGFsbEhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSx1Q0FBd0I7QUFDeEIsa0RBQXlCO0FBRXpCLHdEQUFrQztBQUNsQywwREFBa0U7QUFFbEUsMkNBQXVDO0FBQ3ZDLDZDQUF5QztBQUV6QyxnREFNNEI7QUFFNUIsTUFBYSxhQUFhO0lBQ3pCLE1BQU0sQ0FBQyxXQUFXLENBQUMsR0FBVztRQUM3QixPQUFPLElBQUksT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFO1lBQ3RDLGVBQUs7aUJBQ0gsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFPLFFBQVEsRUFBRSxFQUFFO2dCQUM1QixJQUFJLFFBQVEsQ0FBQyxVQUFVLEtBQUssU0FBUyxJQUFJLFFBQVEsQ0FBQyxVQUFVLElBQUksR0FBRyxJQUFJLFFBQVEsQ0FBQyxVQUFVLEdBQUcsR0FBRyxFQUFFLENBQUM7b0JBQ2xHLE1BQU0sV0FBVyxHQUFHLFFBQVEsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLElBQUksR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFBO29CQUMzRSxJQUFJLFdBQVcsRUFBRSxDQUFDO3dCQUNqQiw0QkFBWSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQ3pCLGNBQWMsQ0FBQyxXQUFXLEdBQUcsQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FDNUQsQ0FBQTtvQkFDRixDQUFDO29CQUNELElBQUksVUFBVSxHQUFHLENBQUMsQ0FBQTtvQkFDbEIsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFBO29CQUU1QixNQUFNLFdBQVcsR0FBRyxJQUFJLGtC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