This commit is contained in:
Graham Christensen 2024-04-19 10:41:36 -04:00
parent bbfc06896f
commit c4f84c57ff
6 changed files with 167 additions and 168 deletions

311
dist/index.js generated vendored
View file

@ -44767,173 +44767,162 @@ module.exports = Keyv;
/***/ }), /***/ }),
/***/ 8811: /***/ 7540:
/***/ ((module, __unused_webpack_exports, __nccwpck_require__) => { /***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
var __webpack_unused_export__;
/*!
const fs = __nccwpck_require__(7147) * linux-release-info
const os = __nccwpck_require__(2037) * Get Linux release info (distribution name, version, arch, release, etc.)
* from '/etc/os-release' or '/usr/lib/os-release' files and from native os
/** * module. On Windows and Darwin platforms it only returns common node os module
* Get OS release info from the node os module and augment that with information * info (platform, hostname, release, and arch)
* from '/etc/os-release', '/usr/lib/os-release', or '/etc/alpine-release'. The
* information in that file is distribution-dependent. If not Linux return only
* the node os module info.
* *
* @returns info {object} via Promise | callback | return value * Licensed under MIT
* * Copyright (c) 2018-2020 [Samuel Carreira]
* the file property in the info object will be filled in with one of:
* - undefined, if not Linux
* - the file path (above) used
* - an Error instance if no file could be read
*/ */
function linuxOsInfo (opts) { __webpack_unused_export__ = ({ value: true });
let outputData = { const fs = __nccwpck_require__(7147);
const os = __nccwpck_require__(2037);
const util_1 = __nccwpck_require__(3837);
const readFileAsync = util_1.promisify(fs.readFile);
const linuxReleaseInfoOptionsDefaults = {
mode: 'async',
custom_file: null,
debug: false
};
/**
* Get OS release info from 'os-release' file and from native os module
* on Windows or Darwin it only returns common os module info
* (uses native fs module)
* @returns {object} info from the current os
*/
function releaseInfo(options) {
options = { ...linuxReleaseInfoOptionsDefaults, ...options };
const searchOsreleaseFileList = osreleaseFileList(options.custom_file);
async function readAsyncOsreleaseFile(searchOsreleaseFileList, options) {
let fileData = null;
for (let os_release_file of searchOsreleaseFileList) {
try {
if (options.debug) {
console.log(`Trying to read '${os_release_file}'...`);
}
fileData = await readFileAsync(os_release_file, 'binary');
if (options.debug) {
console.log('Read data:\n' + fileData);
}
break;
}
catch (error) {
if (options.debug) {
console.error(error);
}
}
}
if (fileData === null) {
throw new Error('Cannot read os-release file!');
//return getOsInfo();
}
return formatFileData(getOsInfo(), fileData);
}
function readSyncOsreleaseFile(searchOsreleaseFileList, options) {
let fileData = null;
for (let os_release_file of searchOsreleaseFileList) {
try {
if (options.debug) {
console.log(`Trying to read '${os_release_file}'...`);
}
fileData = fs.readFileSync(os_release_file, 'binary');
if (options.debug) {
console.log('Read data:\n' + fileData);
}
break;
}
catch (error) {
if (options.debug) {
console.error(error);
}
}
}
if (fileData === null) {
throw new Error('Cannot read os-release file!');
//return getOsInfo();
}
return formatFileData(getOsInfo(), fileData);
}
if (os.type() !== 'Linux') {
if (options.mode === 'sync') {
return getOsInfo();
}
else {
return Promise.resolve(getOsInfo());
}
}
if (options.mode === 'sync') {
return readSyncOsreleaseFile(searchOsreleaseFileList, options);
}
else {
return Promise.resolve(readAsyncOsreleaseFile(searchOsreleaseFileList, options));
}
}
exports.o = releaseInfo;
/**
* Format file data: convert data to object keys/values
*
* @param {object} sourceData Source object to be appended
* @param {string} srcParseData Input file data to be parsed
* @returns {object} Formated object
*/
function formatFileData(sourceData, srcParseData) {
const lines = srcParseData.split('\n');
// @ts-ignore
lines.forEach(element => {
const linedata = element.split('=');
if (linedata.length === 2) {
linedata[1] = linedata[1].replace(/["'\r]/gi, ''); // remove quotes and return character
Object.defineProperty(sourceData, linedata[0].toLowerCase(), {
value: linedata[1],
writable: true,
enumerable: true,
configurable: true
});
}
});
return sourceData;
}
/**
* Export a list of os-release files
*
* @param {string} customFile optional custom complete filepath
* @returns {array} list of os-release files
*/
function osreleaseFileList(customFile) {
const DEFAULT_OS_RELEASE_FILES = ['/etc/os-release', '/usr/lib/os-release'];
if (!customFile) {
return DEFAULT_OS_RELEASE_FILES;
}
else {
return Array(customFile);
}
}
/**
* Get OS Basic Info
* (uses node 'os' native module)
*
* @returns {object} os basic info
*/
function getOsInfo() {
const osInfo = {
type: os.type(), type: os.type(),
platform: os.platform(), platform: os.platform(),
hostname: os.hostname(), hostname: os.hostname(),
arch: os.arch(), arch: os.arch(),
release: os.release(), release: os.release()
file: undefined, };
return osInfo;
} }
//# sourceMappingURL=index.js.map
let mode = 'promise'
opts = opts || {}
const list = Array.isArray(opts.list) ? opts.list : defaultList
if (typeof opts.mode === 'function') {
mode = 'callback'
} else if (opts.mode === 'sync') {
mode = 'sync'
}
if (os.type() !== 'Linux') {
if (mode === 'promise') {
return Promise.resolve(outputData)
} else if (mode === 'callback') {
return opts.mode(null, outputData)
} else {
return outputData
}
}
if (mode === 'sync') {
return synchronousRead()
} else {
// return a Promise that can be ignored if caller expects a callback
return new Promise(asynchronousRead)
}
// loop through the file list synchronously
function synchronousRead () {
for (let i = 0; i < list.length; i++) {
let data
try {
data = fs.readFileSync(list[i].path, 'utf8')
list[i].parser(data, outputData)
outputData.file = list[i].path
return outputData
} catch (e) {
// accumulate errors?
}
}
outputData.file = new Error('linux-os-info - no file found')
return outputData
}
// loop through the file list on completion of async reads
function asynchronousRead (resolve, reject) {
let i = 0
function tryRead () {
if (i >= list.length) {
const e = new Error('linux-os-info - no file found')
outputData.file = e
mode === 'promise' ? resolve(outputData) : opts.mode(null, outputData)
} else {
// try to read the file.
let file = list[i].path
fs.readFile(file, 'utf8', (err, data) => {
if (err) {
i += 1
tryRead()
} else {
list[i].parser(data, outputData)
outputData.file = file
mode === 'promise' ? resolve(outputData) : opts.mode(null, outputData)
}
})
}
}
tryRead()
}
}
//
// the default list of files to try to read and their parsers.
// in theory this can be replaced, especially for testing purposes.
// but it's not documented at this time unless one is reading this.
//
const defaultList = [
{path: '/etc/os-release', parser: etcOsRelease},
{path: '/usr/lib/os-release', parser: usrLibOsRelease},
{path: '/etc/alpine-release', parser: etcAlpineRelease}
]
//
// helper functions to parse file data
//
function etcOsRelease(data, outputData) {
addOsReleaseToOutputData(data, outputData)
}
function usrLibOsRelease(data, outputData) {
addOsReleaseToOutputData(data, outputData)
}
// the alpine-release file only contains the version string
// so fill in the basics based on that.
function etcAlpineRelease(data, outputData) {
outputData.name = 'Alpine'
outputData.id = 'alpine'
outputData.version = data
outputData.version_id = data
}
function addOsReleaseToOutputData(data, outputData) {
const lines = data.split('\n')
lines.forEach(line => {
let index = line.indexOf('=')
// only look at lines with at least a one character key
if (index >= 1) {
// lowercase key and remove quotes on value
let key = line.slice(0, index).toLowerCase()
let value = line.slice(index + 1).replace(/"/g, '')
Object.defineProperty(outputData, key, {
value: value,
writable: true,
enumerable: true,
configurable: true
})
}
});
}
module.exports = linuxOsInfo
//
// a tiny bit of testing
//
if (false) {}
/***/ }), /***/ }),
@ -95299,8 +95288,8 @@ function mungeDiagnosticEndpoint(inputUrl) {
var external_os_ = __nccwpck_require__(2037); var external_os_ = __nccwpck_require__(2037);
// EXTERNAL MODULE: ./node_modules/.pnpm/@actions+exec@1.1.1/node_modules/@actions/exec/lib/exec.js // EXTERNAL MODULE: ./node_modules/.pnpm/@actions+exec@1.1.1/node_modules/@actions/exec/lib/exec.js
var exec = __nccwpck_require__(7775); var exec = __nccwpck_require__(7775);
// EXTERNAL MODULE: ./node_modules/.pnpm/linux-os-info@2.0.0/node_modules/linux-os-info/index.js // EXTERNAL MODULE: ./node_modules/.pnpm/linux-release-info@3.0.0/node_modules/linux-release-info/dist/index.js
var linux_os_info = __nccwpck_require__(8811); var linux_release_info_dist = __nccwpck_require__(7540);
;// CONCATENATED MODULE: ./dist/platform.js ;// CONCATENATED MODULE: ./dist/platform.js
// MIT, lifted from https://github.com/actions/toolkit/blob/5a736647a123ecf8582376bdaee833fbae5b3847/packages/core/src/platform.ts // MIT, lifted from https://github.com/actions/toolkit/blob/5a736647a123ecf8582376bdaee833fbae5b3847/packages/core/src/platform.ts
// since it isn't in @actions/core 1.10.1 which is their current release as 2024-04-19 // since it isn't in @actions/core 1.10.1 which is their current release as 2024-04-19
@ -95331,7 +95320,7 @@ const getMacOsInfo = async () => {
}; };
}; };
const getLinuxInfo = async () => { const getLinuxInfo = async () => {
const data = await linux_os_info({ mode: "async" }); const data = (0,linux_release_info_dist/* releaseInfo */.o)({ mode: "sync" });
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log(data); console.log(data);
const { stdout } = await exec.getExecOutput("lsb_release", ["-i", "-r", "-s"], { const { stdout } = await exec.getExecOutput("lsb_release", ["-i", "-r", "-s"], {

4
dist/platform.js generated vendored
View file

@ -2,7 +2,7 @@
// since it isn't in @actions/core 1.10.1 which is their current release as 2024-04-19 // since it isn't in @actions/core 1.10.1 which is their current release as 2024-04-19
import os from "os"; import os from "os";
import * as exec from "@actions/exec"; import * as exec from "@actions/exec";
import osInfo from "linux-os-info"; import { releaseInfo } from "linux-release-info";
const getWindowsInfo = async () => { const getWindowsInfo = async () => {
const { stdout: version } = await exec.getExecOutput('powershell -command "(Get-CimInstance -ClassName Win32_OperatingSystem).Version"', undefined, { const { stdout: version } = await exec.getExecOutput('powershell -command "(Get-CimInstance -ClassName Win32_OperatingSystem).Version"', undefined, {
silent: true, silent: true,
@ -27,7 +27,7 @@ const getMacOsInfo = async () => {
}; };
}; };
const getLinuxInfo = async () => { const getLinuxInfo = async () => {
const data = await osInfo({ mode: "async" }); const data = releaseInfo({ mode: "sync" });
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log(data); console.log(data);
const { stdout } = await exec.getExecOutput("lsb_release", ["-i", "-r", "-s"], { const { stdout } = await exec.getExecOutput("lsb_release", ["-i", "-r", "-s"], {

View file

@ -31,7 +31,7 @@
"detsys-ts": "github:DeterminateSystems/detsys-ts", "detsys-ts": "github:DeterminateSystems/detsys-ts",
"fetch-retry": "^5.0.6", "fetch-retry": "^5.0.6",
"got": "^14.2.1", "got": "^14.2.1",
"linux-os-info": "^2.0.0", "linux-release-info": "^3.0.0",
"string-argv": "^0.3.2", "string-argv": "^0.3.2",
"tail": "^2.2.6" "tail": "^2.2.6"
}, },

View file

@ -29,6 +29,9 @@ dependencies:
linux-os-info: linux-os-info:
specifier: ^2.0.0 specifier: ^2.0.0
version: 2.0.0 version: 2.0.0
linux-release-info:
specifier: ^3.0.0
version: 3.0.0
string-argv: string-argv:
specifier: ^0.3.2 specifier: ^0.3.2
version: 0.3.2 version: 0.3.2
@ -3352,6 +3355,14 @@ packages:
} }
dev: false dev: false
/linux-release-info@3.0.0:
resolution:
{
integrity: sha512-qVARfxfp2uOM8XTlb+ZkzqVqvNDd6djySW7JL0ec+cnpB/SKZO2O/NJc9XR699fE7Wg1ERWN6aKcPm5Ejioj3A==,
}
engines: { node: ">=8.0" }
dev: false
/locate-path@6.0.0: /locate-path@6.0.0:
resolution: resolution:
{ {

View file

@ -1 +0,0 @@
declare module "linux-os-info";

View file

@ -3,7 +3,7 @@
import os from "os"; import os from "os";
import * as exec from "@actions/exec"; import * as exec from "@actions/exec";
import osInfo from "linux-os-info"; import { releaseInfo } from "linux-release-info";
const getWindowsInfo = async (): Promise<{ name: string; version: string }> => { const getWindowsInfo = async (): Promise<{ name: string; version: string }> => {
const { stdout: version } = await exec.getExecOutput( const { stdout: version } = await exec.getExecOutput(
@ -49,7 +49,7 @@ const getLinuxInfo = async (): Promise<{
name: string; name: string;
version: string; version: string;
}> => { }> => {
const data = await osInfo({ mode: "async" }); const data = releaseInfo({ mode: "sync" });
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log(data); console.log(data);