@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
JavaScript
;
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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