@oaklean/windows-sensorinterface
Version:
A library that provides a binary that utilizes the LibreHardwareMonitor library to capture energy measurements on Windows
95 lines • 7.53 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 (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__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 profiler_core_1 = require("@oaklean/profiler-core");
const ZipHelper_1 = require("./ZipHelper");
const config_1 = require("../constants/config");
class InstallHelper {
static makeRequest(url) {
return new Promise((resolve, reject) => {
https_1.default
.get(url, (response) => {
if (response.statusCode !== undefined && response.statusCode >= 200 && response.statusCode < 300) {
const chunks = [];
response.on('data', (chunk) => chunks.push(chunk));
response.on('end', () => {
resolve(Buffer.concat(chunks));
});
}
else if (response.statusCode !== undefined &&
response.statusCode >= 300 &&
response.statusCode < 400 &&
response.headers.location) {
// Follow redirects
InstallHelper.makeRequest(response.headers.location).then(resolve, reject);
}
else {
reject(new Error(`npm responded with status code ${response.statusCode} when downloading the package!`));
}
})
.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));
ZipHelper_1.ZipHelper.extractSpecificDirectory(tarballDownloadBuffer, new profiler_core_1.UnifiedPath('./'), (0, config_1.getPlatformSpecificBinaryDirectoryPath)(platform));
});
}
static isPlatformSpecificPackageInstalled(platform) {
return fs.existsSync((0, config_1.getPlatformSpecificBinaryPath)(platform).toPlatformString());
}
static installPlatformSpecificPackage(platform) {
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.log('Platform specific package not found. Will manually download binary.');
InstallHelper.downloadPlatformSpecificBinary(platform);
}
}
}
exports.InstallHelper = InstallHelper;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5zdGFsbEhlbHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9oZWxwZXIvSW5zdGFsbEhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHVDQUF3QjtBQUN4QixrREFBeUI7QUFFekIsMERBQWtFO0FBRWxFLDJDQUF1QztBQUV2QyxnREFNNEI7QUFJNUIsTUFBYSxhQUFhO0lBQ3pCLE1BQU0sQ0FBQyxXQUFXLENBQUMsR0FBVztRQUM3QixPQUFPLElBQUksT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFO1lBQ3RDLGVBQUs7aUJBQ0gsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLFFBQVEsRUFBRSxFQUFFO2dCQUN0QixJQUFJLFFBQVEsQ0FBQyxVQUFVLEtBQUssU0FBUyxJQUFJLFFBQVEsQ0FBQyxVQUFVLElBQUksR0FBRyxJQUFJLFFBQVEsQ0FBQyxVQUFVLEdBQUcsR0FBRyxFQUFFLENBQUM7b0JBQ2xHLE1BQU0sTUFBTSxHQUFVLEVBQUUsQ0FBQTtvQkFDeEIsUUFBUSxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQTtvQkFDbEQsUUFBUSxDQUFDLEVBQUUsQ0FBQyxLQUFLLEVBQUUsR0FBRyxFQUFFO3dCQUN2QixPQUFPLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFBO29CQUMvQixDQUFDLENBQUMsQ0FBQTtnQkFDSCxDQUFDO3FCQUFNLElBQ04sUUFBUSxDQUFDLFVBQVUsS0FBSyxTQUFTO29CQUNqQyxRQUFRLENBQUMsVUFBVSxJQUFJLEdBQUc7b0JBQzFCLFFBQVEsQ0FBQyxVQUFVLEdBQUcsR0FBRztvQkFDekIsUUFBUSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQ3hCLENBQUM7b0JBQ0YsbUJBQW1CO29CQUNuQixhQUFhLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQTtnQkFDM0UsQ0FBQztxQkFBTSxDQUFDO29CQUNQLE1BQU0sQ0FDTCxJQUFJLEtBQUssQ0FDUixrQ0FBa0MsUUFBUSxDQUFDLFVBQVUsZ0NBQWdDLENBQ3JGLENBQ0QsQ0FBQTtnQkFDRixDQUFDO1lBQ0YsQ0FBQyxDQUFDO2lCQUNELEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxLQUFLLEVBQUUsRUFBRTtnQkFDdEIsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ2QsQ0FBQyxDQUFDLENBQUE7UUFDSixDQUFDLENBQUMsQ0FBQTtJQUNILENBQUM7SUFFRCxNQUFNLENBQU8sOEJBQThCLENBQUMsUUFBNEI7O1lBQ3ZFLGdFQUFnRTtZQUNoRSxNQUFNLHFCQUFxQixHQUFHLE1BQU0sYUFBYSxDQUFDLFdBQVcsQ0FBQyxJQUFBLHdDQUErQixFQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUE7WUFFeEcscUJBQVMsQ0FBQyx3QkFBd0IsQ0FDakMscUJBQXFCLEVBQ3JCLElBQUksMkJBQVcsQ0FBQyxJQUFJLENBQUMsRUFDckIsSUFBQSwrQ0FBc0MsRUFBQyxRQUFRLENBQUMsQ0FDaEQsQ0FBQTtRQUNGLENBQUM7S0FBQTtJQUVELE1BQU0sQ0FBQyxrQ0FBa0MsQ0FBQyxRQUE0QjtRQUNyRSxPQUFPLEVBQUUsQ0FBQyxVQUFVLENBQUMsSUFBQSxzQ0FBNkIsRUFBQyxRQUFRLENBQUMsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLENBQUE7SUFDakYsQ0FBQztJQUVELE1BQU0sQ0FBQyw4QkFBOEIsQ0FBQyxRQUE0QjtRQUNqRSxNQUFNLDJCQUEyQixHQUFHLElBQUEsdUNBQThCLEVBQUMsUUFBUSxDQUFDLENBQUE7UUFFNUUsSUFBSSxDQUFDLDJCQUEyQixFQUFFLENBQUM7WUFDbEMsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFBO1FBQzNDLENBQUM7UUFFRCxtRkFBbUY7UUFDbkYsSUFBSSxDQUFDLGFBQWEsQ0FBQyxrQ0FBa0MsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1lBQ2pFLDRCQUFZLENBQUMsR0FBRyxDQUFDLHFFQUFxRSxDQUFDLENBQUE7WUFDdkYsYUFBYSxDQUFDLDhCQUE4QixDQUFDLFFBQVEsQ0FBQyxDQUFBO1FBQ3ZELENBQUM7SUFDRixDQUFDO0NBQ0Q7QUE3REQsc0NBNkRDIn0=