about-system 0.0.22 → 0.0.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/about-system-cli.js +1 -1
- package/dist/index.js +1 -1
- package/dist/{system-info-api-Bc0iSNdN.js → system-info-api-DAF2cjeE.js} +2 -2
- package/dist/system-info-api-DAF2cjeE.js.map +1 -0
- package/dist/system-info-api.js +1 -1
- package/package.json +1 -1
- package/src/info/process.ts +1 -1
- package/dist/system-info-api-Bc0iSNdN.js.map +0 -1
package/dist/about-system-cli.js
CHANGED
|
@@ -3,7 +3,7 @@ import p from "os";
|
|
|
3
3
|
import i from "fs";
|
|
4
4
|
import u from "path";
|
|
5
5
|
import { fileURLToPath as x } from "url";
|
|
6
|
-
import { g as $, a as C, b as y, C as S, S as I, c as g, D as w } from "./system-info-api-
|
|
6
|
+
import { g as $, a as C, b as y, C as S, S as I, c as g, D as w } from "./system-info-api-DAF2cjeE.js";
|
|
7
7
|
const L = x(import.meta.url), d = p.platform() === "win32";
|
|
8
8
|
function b(e, s, o) {
|
|
9
9
|
if (!s || s.trim() === "") return "";
|
package/dist/index.js
CHANGED
|
@@ -484,7 +484,7 @@ function K(e) {
|
|
|
484
484
|
const c = l("ps -eo pcpu,comm --sort=-%cpu --no-headers").split(`
|
|
485
485
|
`);
|
|
486
486
|
if (c.length > 0) {
|
|
487
|
-
const s = c[0].trim().replace(/\s+/, " ").split(" "), r = s[0].replace(/\.\d+/, "%"), o = s[1].split("/").pop(), i = `${r} ${o}`;
|
|
487
|
+
const s = c[0].trim().replace(/\s+/, " ").split(" "), r = s[0].replace(/\.\d+/, "%"), o = s[1].split("/").pop(), i = `${r}% ${o}`;
|
|
488
488
|
return a(e.cache, "top_process", i), i;
|
|
489
489
|
}
|
|
490
490
|
} catch {
|
|
@@ -834,4 +834,4 @@ export {
|
|
|
834
834
|
de as l,
|
|
835
835
|
ye as s
|
|
836
836
|
};
|
|
837
|
-
//# sourceMappingURL=system-info-api-
|
|
837
|
+
//# sourceMappingURL=system-info-api-DAF2cjeE.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"system-info-api-DAF2cjeE.js","sources":["../__vite-browser-external","../src/info/settings.ts","../src/utils/platform.ts","../src/utils/command.ts","../src/cache/cache-config.ts","../src/cache/cache.ts","../src/info/platform.ts","../src/info/hardware.ts","../src/info/memory.ts","../src/info/process.ts","../src/info/network.ts","../src/info/system-status.ts","../src/info/software.ts","../src/system-info-api.ts"],"sourcesContent":["export default {}","/**\n * Settings configuration and management\n * @module info/settings\n */\n\nimport path from \"path\";\nimport os from \"os\";\nimport fs from \"fs\";\nimport process from \"process\";\n\n// Settings file paths\nexport const SETTINGS_FILE = path.join(\n os.homedir(),\n \".config\",\n \"systeminfo-settings.json\"\n);\nexport const CACHE_FILE = path.join(os.tmpdir(), \"systeminfo-cache.json\");\n\n// Color codes\nexport const colors = {\n reset: \"\\x1b[0m\",\n red: \"\\x1b[38;5;196m\",\n orange: \"\\x1b[38;5;208m\",\n yellow: \"\\x1b[38;5;226m\",\n green: \"\\x1b[38;5;46m\",\n blue: \"\\x1b[38;5;39m\",\n cyan: \"\\x1b[38;5;51m\",\n purple: \"\\x1b[38;5;171m\",\n magenta: \"\\x1b[38;5;213m\",\n gray: \"\\x1b[38;5;250m\",\n lightblue: \"\\x1b[38;5;220m\",\n};\n\n// Default settings\nexport const DEFAULT_SETTINGS = {\n display_order: [\n [\"user\", \"hostname\", \"os\", \"device\", \"kernel\", \"cpu\", \"gpu\"],\n [\n \"disk_used\",\n \"ram_used\",\n \"top_process\",\n \"uptime\",\n \"temperature\",\n \"battery\",\n \"load_average\",\n ],\n [\"ip\", \"iplocal\", \"city\", \"domain\", \"isp\"],\n [\"shell\", \"pacman\", \"services_running\", \"containers\"],\n ],\n colors: {\n user: \"red\",\n hostname: \"orange\",\n disk_used: \"purple\",\n ram_used: \"yellow\",\n top_process: \"magenta\",\n uptime: \"cyan\",\n ip: \"green\",\n iplocal: \"yellow\",\n city: \"green\",\n domain: \"gray\",\n isp: \"lightblue\",\n os: \"gray\",\n cpu: \"orange\",\n gpu: \"yellow\",\n device: \"yellow\",\n kernel: \"green\",\n shell: \"orange\",\n pacman: \"multicolor\",\n ports: \"multicolor\",\n containers: \"green\",\n memory_available: \"blue\",\n swap_used: \"purple\",\n load_average: \"red\",\n users_logged_in: \"cyan\",\n network_interfaces: \"yellow\",\n mount_points: \"gray\",\n services_running: \"green\",\n temperature: \"red\",\n battery: \"green\",\n screen_resolution: \"blue\",\n },\n emojis: {\n user: \"👤 \",\n hostname: \"🏠 \",\n ip: \"🌎 \",\n iplocal: \"🌐 \",\n city: \"📍 \",\n domain: \"🔗 \",\n isp: \"👮 \",\n os: \"⚡ \",\n cpu: \"📈 \",\n gpu: \"🎮 \",\n device: \"💻 \",\n kernel: \"🔧 \",\n shell: \"🐚 \",\n pacman: \"🚀 \",\n disk_used: \"📁 \",\n ram_used: \"💾 \",\n top_process: \"🔝 \",\n uptime: \"⏱️ \",\n ports: \"🔌 \",\n containers: \"📦 \",\n memory_available: \"🧠 \",\n swap_used: \"🔄 \",\n load_average: \"⚖️ \",\n users_logged_in: \"👥 \",\n network_interfaces: \"🌐 \",\n mount_points: \"📂 \",\n services_running: \"⚙️ \",\n temperature: \"🌡️ \",\n battery_charging: \"🔌 \",\n battery: \"🔋 \",\n screen_resolution: \"🖥️ \",\n },\n labels: {\n user: \"User\",\n hostname: \"Host\",\n ip: \"IP\",\n iplocal: \"Local IP\",\n city: \"City\",\n domain: \"Domain\",\n isp: \"ISP\",\n os: \"OS\",\n cpu: \"CPU\",\n gpu: \"GPU\",\n device: \"Device\",\n kernel: \"Kernel\",\n shell: \"Shell\",\n pacman: \"Packages\",\n disk_used: \"Disk\",\n ram_used: \"RAM\",\n top_process: \"Top\",\n uptime: \"Uptime\",\n ports: \"Ports\",\n containers: \"Containers\",\n memory_available: \"Memory\",\n swap_used: \"Swap\",\n load_average: \"Load\",\n users_logged_in: \"Users\",\n network_interfaces: \"Network\",\n mount_points: \"Mounts\",\n services_running: \"Services\",\n temperature: \"Temp\",\n battery_charging: \"Battery\",\n battery: \"Battery\",\n screen_resolution: \"Resolution\",\n },\n display: {\n show_emojis: true,\n single_line: false,\n line_wrap_length: process?.stdout?.columns || 100,\n },\n network: {\n show_offline_message: true,\n },\n advanced: {\n debug: false,\n },\n};\n\nexport interface Settings {\n display_order: string[][];\n colors: Record<string, string>;\n emojis: Record<string, string>;\n labels: Record<string, string>;\n display: {\n show_emojis: boolean;\n single_line: boolean;\n line_wrap_length: number;\n };\n network: {\n show_offline_message: boolean;\n };\n advanced: {\n debug: boolean;\n };\n}\n\n/**\n * Loads settings from the configuration file\n * @returns Settings object (defaults merged with user settings)\n */\nexport function loadSettings(): Settings {\n try {\n if (fs.existsSync(SETTINGS_FILE)) {\n const settings = JSON.parse(fs.readFileSync(SETTINGS_FILE, \"utf8\"));\n return { ...DEFAULT_SETTINGS, ...settings };\n }\n } catch {}\n return DEFAULT_SETTINGS;\n}\n\n/**\n * Saves settings to the configuration file\n * @param settings - The settings object to save\n * @returns True if successful, false otherwise\n */\nexport function saveSettings(settings: Settings): boolean {\n try {\n const configDir = path.dirname(SETTINGS_FILE);\n if (!fs.existsSync(configDir)) {\n fs.mkdirSync(configDir, { recursive: true });\n }\n fs.writeFileSync(SETTINGS_FILE, JSON.stringify(settings, null, 2));\n return true;\n } catch {\n return false;\n }\n}\n","/**\n * Platform detection utilities\n * @module platform\n */\n\nimport os from \"os\";\n\n/**\n * Platform detection constants\n */\nexport const IS_WINDOWS = os.platform() === \"win32\";\nexport const IS_MAC = os.platform() === \"darwin\";\nexport const IS_LINUX = os.platform() === \"linux\";\n","/**\n * Command execution utilities\n * @module command\n */\n\nimport { execSync } from \"child_process\";\nimport { IS_WINDOWS } from \"./platform\";\n\n/**\n * Executes a shell command safely with timeout\n * @param {string} command - Command to execute\n * @param {object} options - Additional options for execSync\n * @returns {string} Command output or empty string on error\n */\nexport function execCommand(command: string, options = {}): string {\n try {\n const cmd = IS_WINDOWS ? `cmd /c ${command}` : command;\n return execSync(cmd, {\n encoding: \"utf8\",\n timeout: 10000,\n stdio: [\"pipe\", \"pipe\", \"ignore\"],\n ...options,\n })\n .toString()\n .trim();\n } catch (error) {\n return \"\";\n }\n}\n\n/**\n * Checks if a command exists in the system PATH\n * @param {string} command - Command name to check\n * @returns {boolean} True if command exists\n */\nexport function commandExists(command: string): boolean {\n try {\n if (IS_WINDOWS) {\n execSync(`where ${command}`, { stdio: \"ignore\" });\n } else {\n execSync(`which ${command}`, { stdio: \"ignore\" });\n }\n return true;\n } catch {\n return false;\n }\n}\n","/**\n * Cache configuration and constants\n * @module cache-config\n */\n\nimport os from \"os\";\nimport path from \"path\";\n\n/**\n * Cache file location in system's temporary directory\n * @constant\n */\nexport const CACHE_FILE = path.join(os.tmpdir(), \"systeminfo-cache.json\");\n\n/**\n * Cache duration configuration for different system information types\n * Values are in milliseconds\n *\n * @constant\n * @property {number} ip - IP information cache (5 minutes)\n * @property {number} cpu - CPU information cache (24 hours)\n * @property {number} gpu - GPU information cache (24 hours)\n * @property {number} os - OS information cache (24 hours)\n * @property {number} device - Device information cache (24 hours)\n * @property {number} kernel - Kernel information cache (1 hour)\n * @property {number} pacman - Package managers cache (10 minutes)\n * @property {number} ports - Open ports cache (5 minutes)\n * @property {number} containers - Docker containers cache (5 minutes)\n * @property {number} top_process - Top process cache (5 seconds)\n * @property {number} disk_used - Disk usage cache (1 minute)\n * @property {number} ram_used - RAM usage cache (10 seconds)\n * @property {number} services_running - Services cache (5 minutes)\n * @property {number} temperature - Temperature cache (30 seconds)\n * @property {number} battery - Battery status cache (1 minute)\n * @property {number} network_interfaces - Network interfaces cache (5 minutes)\n * @property {number} mount_points - Mount points cache (10 minutes)\n */\nexport const CACHE_DURATION = {\n ip: 5 * 60 * 1000,\n cpu: 24 * 60 * 60 * 1000,\n gpu: 24 * 60 * 60 * 1000,\n os: 24 * 60 * 60 * 1000,\n device: 24 * 60 * 60 * 1000,\n kernel: 60 * 60 * 1000,\n pacman: 10 * 60 * 1000,\n ports: 5 * 60 * 1000,\n containers: 5 * 60 * 1000,\n top_process: 5 * 1000,\n disk_used: 60 * 1000,\n ram_used: 10 * 1000,\n services_running: 5 * 60 * 1000,\n temperature: 30 * 1000,\n battery: 60 * 1000,\n network_interfaces: 5 * 60 * 1000,\n mount_points: 10 * 60 * 1000,\n};\n\n/**\n * Default IPInfo.io API token for geolocation\n * @constant\n */\nexport const DEFAULT_IPINFO_TOKEN = \"da2d6cc4baa5d1\";\n\n/**\n * Default network request timeout in milliseconds\n * @constant\n */\nexport const DEFAULT_NETWORK_TIMEOUT = 5000;\n","/**\n * Cache management utilities\n * @module cache\n */\n\nimport fs from \"fs\";\nimport { CACHE_FILE, CACHE_DURATION } from \"./cache-config\";\n\n/**\n * Represents a cached value with timestamp\n * @interface CacheEntry\n */\nexport interface CacheEntry {\n /** The cached value */\n value: any;\n /** Unix timestamp when the value was cached */\n timestamp: number;\n}\n\n/**\n * Cache storage structure\n * @interface Cache\n */\nexport interface Cache {\n [key: string]: CacheEntry;\n}\n\n/**\n * Loads cache from disk\n * @returns {Cache} Cached data or empty object if cache doesn't exist or is corrupted\n */\nexport function loadCache(): Cache {\n try {\n if (fs.existsSync(CACHE_FILE)) {\n return JSON.parse(fs.readFileSync(CACHE_FILE, \"utf8\"));\n }\n } catch (error) {\n // Corrupted cache - return empty object\n }\n return {};\n}\n\n/**\n * Saves cache to disk\n * @param {Cache} cache - Cache object to save\n */\nexport function saveCache(cache: Cache): void {\n try {\n fs.writeFileSync(CACHE_FILE, JSON.stringify(cache, null, 2));\n } catch (error) {\n // Silently fail if can't write cache\n }\n}\n\n/**\n * Checks if a cache entry is still valid based on configured duration\n * @param {CacheEntry} cacheEntry - The cache entry to validate\n * @param {string} key - The key name to determine cache duration\n * @returns {boolean} True if cache is still valid\n */\nexport function isCacheValid(cacheEntry: CacheEntry, key: string): boolean {\n if (!cacheEntry || !cacheEntry.timestamp) return false;\n const age = Date.now() - cacheEntry.timestamp;\n const maxAge = CACHE_DURATION[key as keyof typeof CACHE_DURATION] || 60000;\n return age < maxAge;\n}\n\n/**\n * Retrieves a value from cache if valid\n * @param {Cache} cache - Cache object\n * @param {string} key - Key to retrieve\n * @returns {any} Cached value or null if not found/expired\n */\nexport function getCachedValue(cache: Cache, key: string): any {\n if (!cache[key]) return null;\n const cacheEntry = cache[key];\n if (!isCacheValid(cacheEntry, key)) {\n delete cache[key];\n return null;\n }\n return cacheEntry.value;\n}\n\n/**\n * Stores a value in cache with current timestamp\n * @param {Cache} cache - Cache object\n * @param {string} key - Key to store under\n * @param {any} value - Value to cache\n */\nexport function setCachedValue(cache: Cache, key: string, value: any): void {\n cache[key] = {\n value,\n timestamp: Date.now(),\n };\n}\n","/**\n * Platform-related system information functions\n * @module info/platform\n */\n\nimport os from \"os\";\nimport fs from \"fs\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_WINDOWS, IS_MAC, IS_LINUX } from \"../utils/platform\";\nimport { execCommand, commandExists } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets the current username\n * @returns Current system username\n */\nexport function user(): string {\n return os.userInfo().username;\n}\n\n/**\n * Gets the system hostname\n * @returns Computer hostname/network name\n */\nexport function hostname(): string {\n return os.hostname();\n}\n\n/**\n * Gets operating system name and version\n * Platform-specific detection for Windows, macOS, and Linux\n * @param context - Info context with cache\n * @returns OS name and version string\n * @example \"Windows 11 Pro\", \"macOS Ventura 13.2.1\", \"Ubuntu 22.04.3 LTS\"\n */\nexport function os_info(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"os\");\n if (cached) return cached;\n\n const platform = os.platform();\n const release = os.release();\n let osName = \"\";\n\n if (IS_WINDOWS) {\n try {\n const version = execCommand(\"ver\");\n const match = version.match(/Microsoft Windows \\[Version ([^\\]]+)\\]/);\n osName = match ? `Windows ${match[1]}` : `Windows ${release}`;\n } catch {\n osName = `Windows ${release}`;\n }\n } else if (IS_MAC) {\n osName = `macOS ${release}`;\n } else if (IS_LINUX) {\n try {\n const osRelease = fs.readFileSync(\"/etc/os-release\", \"utf8\");\n const nameMatch = osRelease.match(/^NAME=\"([^\"]+)\"/m);\n const versionMatch = osRelease.match(/^VERSION_ID=\"([^\"]+)\"/m);\n osName = nameMatch ? nameMatch[1] : \"Linux\";\n if (versionMatch) osName += ` ${versionMatch[1]}`;\n } catch {\n osName = `Linux ${release}`;\n }\n } else {\n osName = `${platform} ${release}`;\n }\n\n setCachedValue(context.cache, \"os\", osName);\n return osName;\n}\n\n/**\n * Gets kernel version string\n * Returns the operating system kernel version from os.release()\n * @param context - Info context with cache\n * @returns Kernel version string\n * @example \"5.15.0-56-generic\", \"6.11.11-valve12-1-neptune\"\n */\nexport function kernel(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"kernel\");\n if (cached) return cached;\n\n const kernel = os.release();\n setCachedValue(context.cache, \"kernel\", kernel);\n return kernel;\n}\n\n/**\n * Gets device or computer model name\n * Uses WMI on Windows, DMI on Linux, getprop on Android\n * @param context - Info context with cache\n * @returns Device model name or empty string\n * @example \"Dell OptiPlex 7090\", \"MacBook Pro 16-inch\", \"Valve Steam Deck\"\n */\nexport function device(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"device\");\n if (cached !== null) return cached;\n\n if (IS_WINDOWS) {\n try {\n const wmic = execCommand(\"wmic csproduct get name /format:list\");\n const nameMatch = wmic.match(/Name=(.+)/);\n if (nameMatch) {\n const device = nameMatch[1].trim();\n if (device && device !== \"\") {\n setCachedValue(context.cache, \"device\", device);\n return device;\n }\n }\n } catch {}\n\n try {\n const ps = execCommand(\n 'powershell.exe -Command \"Get-WmiObject -Class Win32_ComputerSystem | Select-Object -ExpandProperty Model\"'\n );\n if (ps.trim()) {\n const device = ps.trim();\n setCachedValue(context.cache, \"device\", device);\n return device;\n }\n } catch {}\n } else if (IS_LINUX) {\n try {\n if (commandExists(\"getprop\")) {\n const device = execCommand(\"getprop ro.product.model\");\n if (device) {\n setCachedValue(context.cache, \"device\", device);\n return device;\n }\n }\n\n const dmiPath = \"/sys/devices/virtual/dmi/id/product_name\";\n if (fs.existsSync(dmiPath)) {\n const device = fs.readFileSync(dmiPath, \"utf8\").trim();\n if (device) {\n setCachedValue(context.cache, \"device\", device);\n return device;\n }\n }\n } catch {}\n }\n\n setCachedValue(context.cache, \"device\", \"\");\n return \"\";\n}\n","/**\n * Hardware-related system information functions\n * @module info/hardware\n */\n\nimport os from \"os\";\nimport fs from \"fs\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_WINDOWS, IS_LINUX } from \"../utils/platform\";\nimport { execCommand } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets CPU model name and specifications\n * Uses platform-specific commands (wmic/lscpu/cpuinfo)\n * Automatically strips \"with Radeon Graphics\" and similar suffixes\n * @param context - Info context with cache\n * @returns CPU model string or empty string\n * @example \"Intel Core i7-12700K\", \"AMD Ryzen 9 5900HX\", \"Apple M2 Pro\"\n */\nexport function cpu(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"cpu\");\n if (cached) return cached;\n\n let cpuName = \"\";\n\n if (IS_WINDOWS) {\n try {\n const wmic = execCommand(\"wmic cpu get name /format:list\");\n const nameMatch = wmic.match(/Name=(.+)/);\n if (nameMatch) {\n cpuName = nameMatch[1].trim();\n }\n } catch {}\n\n if (!cpuName) {\n try {\n const ps = execCommand(\n 'powershell.exe -Command \"Get-WmiObject -Class Win32_Processor | Select-Object -ExpandProperty Name\"'\n );\n if (ps.trim()) {\n cpuName = ps.trim();\n }\n } catch {}\n }\n } else if (IS_LINUX) {\n try {\n const lscpu = execCommand(\"lscpu\");\n const modelMatch = lscpu.match(/Model name:\\s*([^\\n,]+)/);\n if (modelMatch) {\n cpuName = modelMatch[1].trim();\n }\n } catch {}\n\n if (!cpuName) {\n try {\n const cpuInfo = fs.readFileSync(\"/proc/cpuinfo\", \"utf8\");\n const modelMatch = cpuInfo.match(/model name\\s*:\\s*([^\\n]+)/);\n const hardwareMatch = cpuInfo.match(/Hardware\\s*:\\s*([^\\n]+)/);\n\n if (modelMatch) {\n cpuName = modelMatch[1].trim();\n } else if (hardwareMatch) {\n cpuName = hardwareMatch[1].trim();\n }\n } catch {}\n }\n } else {\n const cpus = os.cpus();\n if (cpus.length > 0) {\n cpuName = cpus[0].model.trim().replace(/[\\r\\n]+/g, \" \");\n }\n }\n\n if (!cpuName) {\n setCachedValue(context.cache, \"cpu\", \"\");\n return \"\";\n }\n\n cpuName = cpuName.trim().replace(/with .*/, \"\");\n\n setCachedValue(context.cache, \"cpu\", cpuName);\n return cpuName;\n}\n\n/**\n * Gets graphics card model name\n * Extracts GPU info from lspci (Linux) or WMI (Windows)\n * Filters out basic/generic display adapters\n * @param context - Info context with cache\n * @returns GPU model string or empty string\n * @example \"NVIDIA GeForce RTX 4070\", \"AMD Radeon RX 6800 XT\"\n */\nexport function gpu(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"gpu\");\n if (cached !== null) return cached;\n\n if (IS_WINDOWS) {\n try {\n const wmic = execCommand(\n \"wmic path win32_VideoController get name /format:list\"\n );\n const nameMatch = wmic.match(/Name=(.+)/);\n if (nameMatch) {\n const gpu = nameMatch[1].trim();\n if (gpu && gpu !== \"\" && !gpu.includes(\"Microsoft Basic\")) {\n setCachedValue(context.cache, \"gpu\", gpu);\n return gpu;\n }\n }\n } catch {}\n\n try {\n const ps = execCommand(\n \"powershell.exe -Command \\\"Get-WmiObject -Class Win32_VideoController | Where-Object {$_.Name -notlike '*Microsoft Basic*'} | Select-Object -First 1 -ExpandProperty Name\\\"\"\n );\n if (ps.trim()) {\n const gpu = ps.trim();\n setCachedValue(context.cache, \"gpu\", gpu);\n return gpu;\n }\n } catch {}\n } else if (IS_LINUX) {\n try {\n const lspci = execCommand(\"lspci\");\n const gpuMatch = lspci.match(\n /VGA.*?(RTX|GeForce|AMD|Intel|NVIDIA)[^\\n]*/i\n );\n if (gpuMatch) {\n let gpu = gpuMatch[0];\n\n const bracketMatch = gpu.match(/\\[([^\\]]+)\\]/);\n if (bracketMatch) {\n gpu = bracketMatch[1];\n } else {\n gpu = gpu\n .replace(/^.*VGA[^:]*:\\s*/, \"\")\n .replace(/\\s*\\(.*\\)$/, \"\")\n .trim();\n }\n\n if (gpu) {\n setCachedValue(context.cache, \"gpu\", gpu);\n return gpu;\n }\n }\n } catch {}\n }\n\n setCachedValue(context.cache, \"gpu\", \"\");\n return \"\";\n}\n\n/**\n * Gets screen resolution from X11 display\n * Uses xrandr command (Linux with X11/Xorg only)\n * @returns Resolution in WIDTHxHEIGHT format or empty string\n * @example \"1920x1080\", \"2560x1440\", \"3840x2160\"\n */\nexport function screen_resolution(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n if (process.env.DISPLAY) {\n const xrandr = execCommand(\"xrandr\");\n const resolutionMatch = xrandr.match(/(\\d+x\\d+)\\+\\d+\\+\\d+/);\n if (resolutionMatch) {\n return resolutionMatch[1];\n }\n }\n } catch {}\n return \"\";\n}\n","/**\n * Memory and disk-related system information functions\n * @module info/memory\n */\n\nimport os from \"os\";\nimport fs from \"fs\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets memory usage in gigabytes\n * Reads from /proc/meminfo on Linux, falls back to os.totalmem()\n * @param context - Info context with cache\n * @returns Memory usage as \"used/total GB\"\n * @example \"12/32GB\", \"6/16GB\"\n */\nexport function ram_used(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"ram_used\");\n if (cached) return cached;\n\n if (IS_LINUX) {\n try {\n const meminfo = fs.readFileSync(\"/proc/meminfo\", \"utf8\");\n const totalMatch = meminfo.match(/MemTotal:\\s+(\\d+) kB/);\n const freeMatch = meminfo.match(/MemFree:\\s+(\\d+) kB/);\n\n if (totalMatch && freeMatch) {\n const totalMB = Math.round(parseInt(totalMatch[1]) / 1024);\n const freeMB = Math.round(parseInt(freeMatch[1]) / 1024);\n const usedMB = totalMB - freeMB;\n\n const totalGB = Math.round(totalMB / 1024);\n const usedGB = Math.round(usedMB / 1024);\n\n const result = `${usedGB}/${totalGB}GB`;\n setCachedValue(context.cache, \"ram_used\", result);\n return result;\n }\n } catch {}\n }\n\n const totalMem = os.totalmem();\n const freeMem = os.freemem();\n const usedMem = totalMem - freeMem;\n\n const totalGB = Math.round(totalMem / (1024 * 1024 * 1024));\n const usedGB = Math.round(usedMem / (1024 * 1024 * 1024));\n\n const result = `${usedGB}/${totalGB}GB`;\n setCachedValue(context.cache, \"ram_used\", result);\n return result;\n}\n\n/**\n * Gets available memory in gigabytes\n * Reads MemAvailable from /proc/meminfo (Linux only)\n * @returns Available memory with \"GB available\" suffix or empty string\n * @example \"12GB available\", \"4GB available\"\n */\nexport function memory_available(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const meminfo = fs.readFileSync(\"/proc/meminfo\", \"utf8\");\n const availableMatch = meminfo.match(/MemAvailable:\\s+(\\d+) kB/);\n if (availableMatch) {\n const availableGB = Math.round(parseInt(availableMatch[1]) / 1024 / 1024);\n return `${availableGB}GB available`;\n }\n } catch {}\n return \"\";\n}\n\n/**\n * Gets swap memory usage\n * Calculates swap usage from /proc/meminfo (Linux only)\n * @returns Swap usage as \"percentage (size MB) swap\" or empty string\n * @example \"15% (512MB) swap\", \"0% (0MB) swap\"\n */\nexport function swap_used(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const meminfo = fs.readFileSync(\"/proc/meminfo\", \"utf8\");\n const swapTotalMatch = meminfo.match(/SwapTotal:\\s+(\\d+) kB/);\n const swapFreeMatch = meminfo.match(/SwapFree:\\s+(\\d+) kB/);\n\n if (swapTotalMatch && swapFreeMatch) {\n const swapTotal = parseInt(swapTotalMatch[1]);\n const swapFree = parseInt(swapFreeMatch[1]);\n const swapUsed = swapTotal - swapFree;\n\n if (swapTotal > 0) {\n const swapUsedPercent = Math.round((swapUsed / swapTotal) * 100);\n const swapUsedMB = Math.round(swapUsed / 1024);\n return `${swapUsedPercent}% (${swapUsedMB}MB) swap`;\n }\n }\n } catch {}\n return \"\";\n}\n\n/**\n * Gets root filesystem disk usage percentage\n * Uses df command on Linux/Android\n * @param context - Info context with cache\n * @returns Percentage string or empty string\n * @example \"45%\", \"78%\"\n */\nexport function disk_used(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"disk_used\");\n if (cached !== null) return cached;\n\n if (IS_LINUX) {\n try {\n const df = execCommand(\"df -h\");\n let diskUsage = \"\";\n\n if (df.includes(\"/storage/emulated\")) {\n const match = df.match(/\\s+(\\d+%)\\s+\\/storage\\/emulated/);\n diskUsage = match ? match[1] : \"\";\n } else {\n const lines = df.split(\"\\n\");\n for (const line of lines) {\n if (line.trim().endsWith(\" /\")) {\n const parts = line.trim().split(/\\s+/);\n const percentIndex = parts.findIndex((part) => part.includes(\"%\"));\n if (percentIndex !== -1) {\n diskUsage = parts[percentIndex];\n break;\n }\n }\n }\n\n if (!diskUsage) {\n const rootMatch = df.match(/(\\d+%)\\s+\\/\\s*$/m);\n diskUsage = rootMatch ? rootMatch[1] : \"\";\n }\n }\n\n setCachedValue(context.cache, \"disk_used\", diskUsage);\n return diskUsage;\n } catch {}\n }\n\n setCachedValue(context.cache, \"disk_used\", \"\");\n return \"\";\n}\n\n/**\n * Gets system load averages\n * Reads 1, 5, and 15 minute load averages from /proc/loadavg (Linux only)\n * @returns Space-separated load averages (1m 5m 15m) or empty string\n * @example \"0.52 0.58 0.59\", \"2.10 1.95 1.88\"\n */\nexport function load_average(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const loadavg = fs.readFileSync(\"/proc/loadavg\", \"utf8\");\n const loads = loadavg.split(\" \").slice(0, 3);\n return loads.join(\" \");\n } catch {}\n return \"\";\n}\n\n/**\n * Gets mounted filesystem information\n * Lists non-system mount points with usage from df (Linux only)\n * Excludes /, /dev, /proc, and /sys mounts\n * @param context - Info context with cache\n * @returns Space-separated mount points with usage or empty string\n * @example \"/home(45%) /mnt/data(78%)\", \"/media/usb(12%)\"\n */\nexport function mount_points(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"mount_points\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"mount_points\", \"\");\n return \"\";\n }\n\n try {\n const df = execCommand(\"df -h\");\n const lines = df.split(\"\\n\").slice(1);\n const mountPoints: string[] = [];\n\n lines.forEach((line) => {\n const parts = line.trim().split(/\\s+/);\n if (parts.length >= 6) {\n const mountPoint = parts[5];\n const usage = parts[4];\n if (\n !mountPoint.startsWith(\"/dev\") &&\n !mountPoint.startsWith(\"/proc\") &&\n !mountPoint.startsWith(\"/sys\") &&\n mountPoint !== \"/\"\n ) {\n mountPoints.push(`${mountPoint}(${usage})`);\n }\n }\n });\n\n const result = mountPoints.slice(0, 3).join(\" \");\n setCachedValue(context.cache, \"mount_points\", result);\n return result;\n } catch {}\n\n setCachedValue(context.cache, \"mount_points\", \"\");\n return \"\";\n}\n","/**\n * Process-related system information functions\n * @module info/process\n */\n\nimport os from \"os\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets the highest CPU-consuming process\n * Uses ps command to find top process by CPU usage (Linux only)\n * @param context - Info context with cache\n * @returns Process info as \"percentage processname\" or empty string\n * @example \"8% firefox\", \"15% chrome\", \"3% systemd\"\n */\nexport function top_process(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"top_process\");\n if (cached !== null) return cached;\n\n if (IS_LINUX) {\n try {\n const ps = execCommand(\"ps -eo pcpu,comm --sort=-%cpu --no-headers\");\n const lines = ps.split(\"\\n\");\n if (lines.length > 0) {\n const topProcess = lines[0].trim().replace(/\\s+/, \" \").split(\" \");\n const cpu = topProcess[0].replace(/\\.\\d+/, \"%\");\n const process = topProcess[1].split(\"/\").pop();\n const result = `${cpu}% ${process}`;\n setCachedValue(context.cache, \"top_process\", result);\n return result;\n }\n } catch {}\n }\n\n setCachedValue(context.cache, \"top_process\", \"\");\n return \"\";\n}\n\n/**\n * Gets system uptime since last boot\n * @returns Uptime formatted as \"Xd Yh Zm\"\n * @example \"2d 14h 23m\", \"0d 3h 45m\"\n */\nexport function uptime(): string {\n const uptimeSeconds = os.uptime();\n const days = Math.floor(uptimeSeconds / 86400);\n const hours = Math.floor((uptimeSeconds % 86400) / 3600);\n const minutes = Math.floor((uptimeSeconds % 3600) / 60);\n return `${days}d ${hours}h ${minutes}m`;\n}\n\n/**\n * Gets number of logged in users\n * Uses who command to count active user sessions (Linux only)\n * @returns User count with \"users\" suffix or empty string\n * @example \"3 users\", \"1 users\"\n */\nexport function users_logged_in(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const who = execCommand(\"who\");\n const users = who.split(\"\\n\").filter((line) => line.trim()).length;\n if (users > 0) {\n return `${users} users`;\n }\n } catch {}\n return \"\";\n}\n","/**\n * Network-related system information functions\n * @module info/network\n */\n\nimport os from \"os\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets public IP address from ipinfo.io\n * @param context - Info context with cache and IP info\n * @returns Public IPv4 address or empty string\n * @example \"203.0.113.42\"\n */\nexport async function ip(context: InfoContext): Promise<string> {\n const cached = getCachedValue(context.cache, \"ip\");\n if (cached) return cached;\n\n if (!context.ipInfo) {\n setCachedValue(context.cache, \"ip\", \"\");\n return \"\";\n }\n const ip = context.ipInfo.ip || \"\";\n setCachedValue(context.cache, \"ip\", ip);\n return ip;\n}\n\n/**\n * Gets local/private IP address(es)\n * Tries ifconfig and ip commands on Linux, falls back to Node.js API\n * @returns Space-separated local IP addresses (RFC 1918 ranges)\n * @example \"192.168.1.100\" or \"10.0.0.50 192.168.1.100\"\n */\nexport function iplocal(): string {\n if (IS_LINUX) {\n try {\n const ifconfig = execCommand(\"ifconfig 2>/dev/null\");\n const wlanMatch = ifconfig.match(\n /wlan0[\\s\\S]*?inet (\\d+\\.\\d+\\.\\d+\\.\\d+)/\n );\n if (wlanMatch) {\n return wlanMatch[1];\n }\n } catch {}\n\n try {\n const ipAddr = execCommand(\"ip addr show 2>/dev/null\");\n const addresses: string[] = [];\n const matches = ipAddr.matchAll(/inet (\\d+\\.\\d+\\.\\d+\\.\\d+)\\/\\d+/g);\n for (const match of matches) {\n if (!match[1].startsWith(\"127.\")) {\n addresses.push(match[1]);\n }\n }\n if (addresses.length > 0) {\n return addresses.join(\" \");\n }\n } catch {}\n }\n\n const interfaces = os.networkInterfaces();\n const addresses: string[] = [];\n\n for (const name of Object.keys(interfaces)) {\n for (const device of interfaces[name] || []) {\n if (device.family === \"IPv4\" && !device.internal) {\n addresses.push(device.address);\n }\n }\n }\n\n return addresses.join(\" \");\n}\n\n/**\n * Gets geographic city based on public IP\n * @param context - Info context with IP geolocation data\n * @returns City name or empty string\n * @example \"San Francisco\", \"New York\", \"London\"\n */\nexport async function city(context: InfoContext): Promise<string> {\n const cached = getCachedValue(context.cache, \"city\");\n if (cached !== null) return cached;\n\n if (!context.ipInfo || !context.ipInfo.city) {\n setCachedValue(context.cache, \"city\", \"\");\n return \"\";\n }\n const city = context.ipInfo.city;\n setCachedValue(context.cache, \"city\", city);\n return city;\n}\n\n/**\n * Gets reverse DNS hostname with HTTP prefix\n * @param context - Info context with IP info\n * @returns Domain with http:// prefix or empty string\n * @example \"http://example.com\", \"http://host-203-0-113-42.example.net\"\n */\nexport async function domain(context: InfoContext): Promise<string> {\n const cached = getCachedValue(context.cache, \"domain\");\n if (cached !== null) return cached;\n\n if (!context.ipInfo || !context.ipInfo.hostname) {\n setCachedValue(context.cache, \"domain\", \"\");\n return \"\";\n }\n const domain = `http://${context.ipInfo.hostname}`;\n setCachedValue(context.cache, \"domain\", domain);\n return domain;\n}\n\n/**\n * Gets Internet Service Provider name\n * Strips AS number prefix from organization string\n * @param context - Info context with IP info\n * @returns ISP name or empty string\n * @example \"Comcast Cable\", \"Verizon Business\", \"Cloudflare Inc\"\n */\nexport async function isp(context: InfoContext): Promise<string> {\n const cached = getCachedValue(context.cache, \"isp\");\n if (cached !== null) return cached;\n\n if (!context.ipInfo || !context.ipInfo.org) {\n setCachedValue(context.cache, \"isp\", \"\");\n return \"\";\n }\n const isp = context.ipInfo.org.split(\" \").slice(1).join(\" \");\n setCachedValue(context.cache, \"isp\", isp);\n return isp;\n}\n\n/**\n * Gets active network interface names\n * Lists non-loopback interfaces with IPv4 addresses (Linux only)\n * @param context - Info context with cache\n * @returns Space-separated interface names or empty string\n * @example \"eth0 wlan0\", \"enp0s3\"\n */\nexport function network_interfaces(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"network_interfaces\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"network_interfaces\", \"\");\n return \"\";\n }\n\n try {\n const interfaces = os.networkInterfaces();\n const activeInterfaces: string[] = [];\n\n for (const [name, addrs] of Object.entries(interfaces)) {\n if (name !== \"lo\") {\n const ipv4Addr = addrs?.find(\n (addr) => addr.family === \"IPv4\" && !addr.internal\n );\n if (ipv4Addr) {\n activeInterfaces.push(name);\n }\n }\n }\n\n const result = activeInterfaces.join(\" \");\n setCachedValue(context.cache, \"network_interfaces\", result);\n return result;\n } catch {}\n\n setCachedValue(context.cache, \"network_interfaces\", \"\");\n return \"\";\n}\n/**\n * Gets open TCP ports with service names\n * Uses lsof to find listening TCP ports (Linux only)\n * @param context - Info context with cache\n * @returns Space-separated port+process pairs or empty string\n * @example \"80http 443http 22ssh\", \"3000node 5432post\"\n */\nexport function ports(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"ports\");\n if (cached !== null) return cached;\n\n if (IS_LINUX) {\n try {\n const lsof = execCommand(\"lsof -nP -iTCP -sTCP:LISTEN\");\n const lines = lsof.split(\"\\n\").slice(1);\n const ports = new Set<string>();\n\n lines.forEach((line) => {\n const parts = line.split(/\\s+/);\n if (parts.length >= 9) {\n const address = parts[8];\n const portMatch = address.match(/:(\\d+)$/);\n if (portMatch) {\n const port = portMatch[1];\n const process = parts[0].substring(0, 4);\n ports.add(`${port}${process}`);\n }\n }\n });\n\n const result = Array.from(ports).join(\" \");\n setCachedValue(context.cache, \"ports\", result);\n return result;\n } catch {}\n }\n\n setCachedValue(context.cache, \"ports\", \"\");\n return \"\";\n}\n","/**\n * System status and health information functions\n * @module info/system-status\n */\n\nimport fs from \"fs\";\nimport os from \"os\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand, commandExists } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets system load averages\n * Reads 1, 5, and 15 minute load averages from /proc/loadavg (Linux only)\n * @returns Space-separated load averages (1m 5m 15m) or empty string\n * @example \"0.52 0.58 0.59\", \"2.10 1.95 1.88\"\n */\nexport function load_average(context: InfoContext): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const loadavg = fs.readFileSync(\"/proc/loadavg\", \"utf8\");\n const loads = loadavg.split(\" \").slice(0, 3);\n return loads.join(\" \");\n } catch {}\n return \"\";\n}\n\n/**\n * Gets battery charge level and charging status\n * Reads from /sys/class/power_supply/BAT0 (Linux laptops only)\n * @param context - Info context with cache\n * @returns Battery percentage with optional + for charging, or empty string\n * @example \"85%\", \"42%+\", \"100%\"\n */\nexport function battery(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"battery\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"battery\", \"\");\n return \"\";\n }\n\n try {\n const batteryPath = \"/sys/class/power_supply/BAT0\";\n const capacityPath = `${batteryPath}/capacity`;\n const statusPath = `${batteryPath}/status`;\n\n if (fs.existsSync(capacityPath)) {\n const capacity = fs.readFileSync(capacityPath, \"utf8\").trim();\n const status = fs.existsSync(statusPath)\n ? fs.readFileSync(statusPath, \"utf8\").trim()\n : \"Unknown\";\n\n const batteryPercent = parseInt(capacity);\n const isCharging = status === \"Charging\";\n const result = `${batteryPercent}%${isCharging ? \"+\" : \"\"}`;\n setCachedValue(context.cache, \"battery\", result);\n return result;\n }\n } catch {}\n\n setCachedValue(context.cache, \"battery\", \"\");\n return \"\";\n}\n\n/**\n * Gets system temperature in Celsius\n * Reads from thermal zone or hwmon sensors (Linux only)\n * @param context - Info context with cache\n * @returns Temperature with °C suffix or empty string\n * @example \"45°C\", \"62°C\"\n */\nexport function temperature(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"temperature\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"temperature\", \"\");\n return \"\";\n }\n\n try {\n const tempSources = [\n \"/sys/class/thermal/thermal_zone0/temp\",\n \"/sys/class/hwmon/hwmon0/temp1_input\",\n \"/sys/class/hwmon/hwmon1/temp1_input\",\n ];\n\n for (const source of tempSources) {\n if (fs.existsSync(source)) {\n const temp = fs.readFileSync(source, \"utf8\").trim();\n const tempC = Math.round(parseInt(temp) / 1000);\n\n if (tempC > 0 && tempC < 150) {\n const result = `${tempC}°C`;\n setCachedValue(context.cache, \"temperature\", result);\n return result;\n }\n }\n }\n } catch {}\n\n setCachedValue(context.cache, \"temperature\", \"\");\n return \"\";\n}\n\n/**\n * Gets count of running system services\n * Uses systemctl or service command (Linux only)\n * @param context - Info context with cache\n * @returns Service count with \"services\" suffix or empty string\n * @example \"125 services\", \"89 services\"\n */\nexport function services_running(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"services_running\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"services_running\", \"\");\n return \"\";\n }\n\n try {\n let serviceCount = 0;\n\n if (commandExists(\"systemctl\")) {\n const services = execCommand(\n \"systemctl list-units --type=service --state=running --no-pager\"\n );\n serviceCount = services\n .split(\"\\n\")\n .filter((line) => line.includes(\".service\")).length;\n } else if (commandExists(\"service\")) {\n const services = execCommand(\"service --status-all\");\n serviceCount = services\n .split(\"\\n\")\n .filter((line) => line.includes(\"+\")).length;\n }\n\n if (serviceCount > 0) {\n const result = `${serviceCount} services`;\n setCachedValue(context.cache, \"services_running\", result);\n return result;\n }\n } catch {}\n\n setCachedValue(context.cache, \"services_running\", \"\");\n return \"\";\n}\n","/**\n * Software and package-related system information functions\n * @module info/software\n */\n\nimport process from \"process\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand, commandExists } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets the current shell name\n * Uses ps command to find parent process shell (Linux/Unix only)\n * @returns Shell name or empty string on Windows\n * @example \"bash\", \"zsh\", \"fish\", \"nu\"\n */\nexport function shell(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"shell\");\n if (cached !== null) return cached;\n\n if (IS_LINUX) {\n try {\n const ppid = process.ppid;\n const shellName = execCommand(`ps -p ${ppid} -o comm=`).split(\"/\").pop();\n if (shellName) {\n setCachedValue(context.cache, \"shell\", shellName);\n return shellName;\n }\n } catch {}\n }\n\n setCachedValue(context.cache, \"shell\", \"\");\n return \"\";\n}\n\n/**\n * Gets available package managers and development tools\n * Checks for package managers (apt, yum, npm, etc.) and editors (nvim, hx)\n * @param context - Info context with cache\n * @returns Space-separated list of available commands\n * @example \"apt npm docker nvim\", \"yay pacman bun hx\"\n */\nexport function packages(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"packages\");\n if (cached !== null) return cached;\n\n const commands = [\n \"apt\",\n \"npm\",\n \"uv\",\n \"docker\",\n \"hx\",\n \"nvim\",\n \"bun\",\n \"yay\",\n \"pacman\",\n \"yum\",\n \"dnf\",\n \"zypper\",\n \"emerge\",\n \"apk\",\n \"snap\",\n \"flatpak\",\n ];\n const available = commands.filter((cmd) => commandExists(cmd));\n\n const result = available.join(\" \");\n setCachedValue(context.cache, \"packages\", result);\n return result;\n}\n\n/**\n * Gets versions of common software tools\n * @param context - Info context with cache\n * @returns Formatted string of tool versions\n * @example \"node:20.1.0 git:2.34.1\"\n */\nexport function common_versions(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"common_versions\");\n if (cached !== null) return cached;\n\n const tools = [\n {\n cmd: \"node\",\n args: \"--version\",\n clean: (v: string) => v.replace(/^v/, \"\"),\n },\n {\n cmd: \"git\",\n args: \"--version\",\n clean: (v: string) => v.replace(\"git version \", \"\"),\n },\n {\n cmd: \"docker\",\n args: \"--version\",\n clean: (v: string) => v.replace(/Docker version ([^,]+),.*/, \"$1\"),\n },\n {\n cmd: \"python3\",\n args: \"--version\",\n clean: (v: string) => v.replace(\"Python \", \"\"),\n },\n {\n cmd: \"go\",\n args: \"version\",\n clean: (v: string) => v.replace(\"go version go\", \"\").split(\" \")[0],\n },\n {\n cmd: \"rustc\",\n args: \"--version\",\n clean: (v: string) => v.replace(\"rustc \", \"\").split(\" \")[0],\n },\n ];\n\n const versions: string[] = [];\n\n for (const tool of tools) {\n if (commandExists(tool.cmd)) {\n try {\n const output = execCommand(`${tool.cmd} ${tool.args}`);\n const version = tool.clean(output).trim();\n if (version) {\n versions.push(`${tool.cmd}:${version}`);\n }\n } catch {}\n }\n }\n\n const result = versions.join(\" \");\n setCachedValue(context.cache, \"common_versions\", result);\n return result;\n}\n/**\n * Gets running Docker container names\n * Lists active Docker containers with their names\n * @param context - Info context with cache\n * @returns Space-separated container names or empty string\n * @example \"nginx redis postgres\", \"web-app db-server\"\n */\nexport function containers(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"containers\");\n if (cached !== null) return cached;\n\n if (!commandExists(\"docker\")) {\n setCachedValue(context.cache, \"containers\", \"\");\n return \"\";\n }\n\n try {\n const containerCount = execCommand(\"docker ps -q\")\n .split(\"\\n\")\n .filter((line) => line.trim()).length;\n if (containerCount === 0) {\n setCachedValue(context.cache, \"containers\", \"\");\n return \"\";\n }\n\n const containers = execCommand(\n 'docker ps --format \"{{.Names}}\\t{{.Ports}}\"'\n );\n const lines = containers.split(\"\\n\").filter((line) => line.trim());\n\n const containerInfo: string[] = [];\n\n lines.forEach((line) => {\n const [name, ports] = line.split(\"\\t\");\n if (name) {\n containerInfo.push(name);\n\n if (ports) {\n const portMatches = ports.match(/->(\\d+(-\\d+)?)\\//g);\n if (portMatches) {\n const uniquePorts = [\n ...new Set(\n portMatches.map((p) => p.replace(/->\\d+(-\\d+)?\\//, \"\"))\n ),\n ];\n containerInfo.push(...uniquePorts);\n }\n }\n }\n });\n\n const result = containerInfo.join(\" \");\n setCachedValue(context.cache, \"containers\", result);\n return result;\n } catch {}\n\n setCachedValue(context.cache, \"containers\", \"\");\n return \"\";\n}\n","/**\n * @fileoverview System Information API\n *\n * A comprehensive cross-platform system information collection API.\n * Provides clean JSON data without formatting, suitable for programmatic use.\n *\n * @module system-info-api\n * @author vtempest\n * @license rights.institute/prosper\n */\n\nimport os from \"os\";\nimport fs from \"fs\";\nimport https from \"https\";\nimport path from \"path\";\nimport type { SystemInfo, SystemInfoOptions } from \"./systeminfo-types\";\nimport { CACHE_FILE } from \"./info/settings\"; // Using CACHE_FILE from settings to ensure consistency\n\n// Import info functions from modules\nimport { user, hostname, os_info, kernel, device } from \"./info/platform\";\nimport { cpu, gpu, screen_resolution } from \"./info/hardware\";\nimport {\n disk_used,\n ram_used,\n memory_available,\n swap_used,\n mount_points,\n} from \"./info/memory\";\nimport { top_process, uptime, users_logged_in } from \"./info/process\";\nimport {\n ip,\n iplocal,\n city,\n domain,\n isp,\n network_interfaces,\n ports,\n} from \"./info/network\";\nimport {\n services_running,\n temperature,\n battery,\n load_average,\n} from \"./info/system-status\";\nimport { shell, packages, containers } from \"./info/software\";\n\n/**\n * Cache duration configuration for different system information types\n * Values are in milliseconds\n */\nconst CACHE_DURATION = {\n ip: 5 * 60 * 1000,\n cpu: 24 * 60 * 60 * 1000,\n gpu: 24 * 60 * 60 * 1000,\n os: 24 * 60 * 60 * 1000,\n device: 24 * 60 * 60 * 1000,\n kernel: 60 * 60 * 1000,\n pacman: 10 * 60 * 1000,\n ports: 5 * 60 * 1000,\n containers: 5 * 60 * 1000,\n top_process: 5 * 1000,\n disk_used: 60 * 1000,\n ram_used: 10 * 1000,\n services_running: 5 * 60 * 1000,\n temperature: 30 * 1000,\n battery: 60 * 1000,\n network_interfaces: 5 * 60 * 1000,\n mount_points: 10 * 60 * 1000,\n};\n\n/**\n * Platform detection constants\n */\nconst IS_WINDOWS = os.platform() === \"win32\";\nconst IS_MAC = os.platform() === \"darwin\";\nconst IS_LINUX = os.platform() === \"linux\";\n\n/**\n * Default IPInfo.io API token for geolocation\n */\nconst DEFAULT_IPINFO_TOKEN = \"da2d6cc4baa5d1\";\n\n/**\n * Default network request timeout in milliseconds\n */\nconst DEFAULT_NETWORK_TIMEOUT = 5000;\n\n/**\n * Represents a cached value with timestamp\n */\ninterface CacheEntry {\n value: any;\n timestamp: number;\n}\n\n/**\n * Cache storage structure\n */\ninterface Cache {\n [key: string]: CacheEntry;\n}\n\n/**\n * IP information from ipinfo.io API\n */\ninterface IPInfo {\n ip?: string;\n city?: string;\n hostname?: string;\n org?: string;\n}\n\n/**\n * Context object passed to info collection functions\n */\ninterface InfoContext {\n cache: Cache;\n ipInfo?: IPInfo;\n}\n\n/**\n * Loads cache from disk\n */\nfunction loadCache(): Cache {\n try {\n if (fs.existsSync(CACHE_FILE)) {\n return JSON.parse(fs.readFileSync(CACHE_FILE, \"utf8\"));\n }\n } catch (error) {\n // Corrupted cache - return empty object\n }\n return {};\n}\n\n/**\n * Saves cache to disk\n */\nfunction saveCache(cache: Cache): void {\n try {\n const cacheDir = path.dirname(CACHE_FILE);\n if (!fs.existsSync(cacheDir)) {\n fs.mkdirSync(cacheDir, { recursive: true });\n }\n fs.writeFileSync(CACHE_FILE, JSON.stringify(cache, null, 2));\n } catch (error) {\n // Silently fail if can't write cache\n }\n}\n\n/**\n * Fetches IP geolocation information from ipinfo.io API\n */\nasync function fetchIPInfo(\n token: string = DEFAULT_IPINFO_TOKEN,\n timeout: number = DEFAULT_NETWORK_TIMEOUT\n): Promise<IPInfo> {\n return new Promise((resolve) => {\n const url = `https://ipinfo.io/json${token ? `?token=${token}` : \"\"}`;\n\n const req = https.get(url, (res) => {\n let data = \"\";\n res.on(\"data\", (chunk) => (data += chunk));\n res.on(\"end\", () => {\n try {\n resolve(JSON.parse(data));\n } catch {\n resolve({});\n }\n });\n });\n\n req.on(\"error\", () => resolve({}));\n req.setTimeout(timeout, () => {\n req.destroy();\n resolve({});\n });\n });\n}\n\n/**\n * System information collection functions map\n */\nexport const infoFunctions = {\n user,\n hostname,\n ip,\n iplocal,\n city,\n domain,\n isp,\n os: os_info, // Mapped from os_info\n cpu,\n gpu,\n disk_used,\n ram_used,\n top_process,\n uptime,\n device,\n kernel,\n shell,\n pacman: packages, // Mapped from packages\n ports,\n containers,\n memory_available,\n swap_used,\n load_average,\n users_logged_in,\n network_interfaces,\n mount_points,\n services_running,\n temperature,\n battery,\n screen_resolution,\n};\n\n/**\n * Get all system information as a clean JSON object\n */\nexport async function getSystemInfo(\n options: SystemInfoOptions = {}\n): Promise<SystemInfo> {\n const cache = loadCache();\n const context: InfoContext = { cache };\n\n // Check if we need IP info\n // Some functions need IP info, so we fetch it once if needed by any function\n // For now we always try to fetch it if not cached, as ip/city/etc depend on it\n // Optimization: check if we actually need to run those functions based on options if provided\n // But current implementation fetches it always if missing from cache\n\n const cachedIPInfo = cache[\"ipInfo\"]?.value;\n if (cachedIPInfo) {\n context.ipInfo = cachedIPInfo;\n } else {\n context.ipInfo = await fetchIPInfo();\n // Cache IP info itself\n cache[\"ipInfo\"] = {\n value: context.ipInfo,\n timestamp: Date.now(),\n };\n }\n\n // Collect all system information\n const info: Partial<SystemInfo> = {\n timestamp: new Date().toISOString(),\n platform: IS_WINDOWS\n ? \"windows\"\n : IS_MAC\n ? \"macos\"\n : IS_LINUX\n ? \"linux\"\n : \"unknown\",\n };\n\n // Call all info functions\n for (const [key, fn] of Object.entries(infoFunctions)) {\n try {\n // most functions are sync but some are async (ip related)\n const value = await fn(context);\n info[key as keyof SystemInfo] = value as any;\n } catch (error) {\n info[key as keyof SystemInfo] = \"\" as any;\n }\n }\n\n saveCache(cache);\n\n return info as SystemInfo;\n}\n\nexport { loadCache, saveCache };\n"],"names":["process$1","SETTINGS_FILE","path","os","CACHE_FILE","colors","DEFAULT_SETTINGS","process","loadSettings","fs","settings","saveSettings","configDir","IS_WINDOWS","IS_MAC","IS_LINUX","execCommand","command","options","cmd","execSync","commandExists","CACHE_DURATION","isCacheValid","cacheEntry","key","age","maxAge","getCachedValue","cache","setCachedValue","value","user","hostname","os_info","context","cached","platform","release","osName","match","osRelease","nameMatch","versionMatch","kernel","device","ps","dmiPath","cpu","cpuName","modelMatch","cpuInfo","hardwareMatch","cpus","gpu","gpuMatch","bracketMatch","screen_resolution","resolutionMatch","ram_used","meminfo","totalMatch","freeMatch","totalMB","freeMB","usedMB","totalGB","result","totalMem","freeMem","usedMem","memory_available","availableMatch","swap_used","swapTotalMatch","swapFreeMatch","swapTotal","swapFree","swapUsed","swapUsedPercent","swapUsedMB","disk_used","df","diskUsage","lines","line","parts","percentIndex","part","rootMatch","mount_points","mountPoints","mountPoint","usage","top_process","topProcess","uptime","uptimeSeconds","days","hours","minutes","users_logged_in","users","ip","iplocal","wlanMatch","ipAddr","addresses","matches","interfaces","name","city","domain","isp","network_interfaces","activeInterfaces","addrs","addr","ports","portMatch","port","load_average","battery","batteryPath","capacityPath","statusPath","capacity","status","temperature","tempSources","source","temp","tempC","services_running","serviceCount","shell","ppid","shellName","packages","containers","containerInfo","portMatches","uniquePorts","p","DEFAULT_IPINFO_TOKEN","DEFAULT_NETWORK_TIMEOUT","loadCache","saveCache","cacheDir","fetchIPInfo","token","timeout","resolve","url","req","https","res","data","chunk","infoFunctions","getSystemInfo","cachedIPInfo","info","fn"],"mappings":"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"}
|
package/dist/system-info-api.js
CHANGED
|
@@ -2,7 +2,7 @@ import "os";
|
|
|
2
2
|
import "fs";
|
|
3
3
|
import "https";
|
|
4
4
|
import "path";
|
|
5
|
-
import { g as m, i as r, l as p, s as n } from "./system-info-api-
|
|
5
|
+
import { g as m, i as r, l as p, s as n } from "./system-info-api-DAF2cjeE.js";
|
|
6
6
|
export {
|
|
7
7
|
m as getSystemInfo,
|
|
8
8
|
r as infoFunctions,
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "about-system",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.23",
|
|
4
4
|
"description": "A Node.js script to display key system information with emojis. Cross-platform support for Windows, macOS, and Linux with customizable output and caching.",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
package/src/info/process.ts
CHANGED
|
@@ -28,7 +28,7 @@ export function top_process(context: InfoContext): string {
|
|
|
28
28
|
const topProcess = lines[0].trim().replace(/\s+/, " ").split(" ");
|
|
29
29
|
const cpu = topProcess[0].replace(/\.\d+/, "%");
|
|
30
30
|
const process = topProcess[1].split("/").pop();
|
|
31
|
-
const result = `${cpu} ${process}`;
|
|
31
|
+
const result = `${cpu}% ${process}`;
|
|
32
32
|
setCachedValue(context.cache, "top_process", result);
|
|
33
33
|
return result;
|
|
34
34
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"system-info-api-Bc0iSNdN.js","sources":["../__vite-browser-external","../src/info/settings.ts","../src/utils/platform.ts","../src/utils/command.ts","../src/cache/cache-config.ts","../src/cache/cache.ts","../src/info/platform.ts","../src/info/hardware.ts","../src/info/memory.ts","../src/info/process.ts","../src/info/network.ts","../src/info/system-status.ts","../src/info/software.ts","../src/system-info-api.ts"],"sourcesContent":["export default {}","/**\n * Settings configuration and management\n * @module info/settings\n */\n\nimport path from \"path\";\nimport os from \"os\";\nimport fs from \"fs\";\nimport process from \"process\";\n\n// Settings file paths\nexport const SETTINGS_FILE = path.join(\n os.homedir(),\n \".config\",\n \"systeminfo-settings.json\"\n);\nexport const CACHE_FILE = path.join(os.tmpdir(), \"systeminfo-cache.json\");\n\n// Color codes\nexport const colors = {\n reset: \"\\x1b[0m\",\n red: \"\\x1b[38;5;196m\",\n orange: \"\\x1b[38;5;208m\",\n yellow: \"\\x1b[38;5;226m\",\n green: \"\\x1b[38;5;46m\",\n blue: \"\\x1b[38;5;39m\",\n cyan: \"\\x1b[38;5;51m\",\n purple: \"\\x1b[38;5;171m\",\n magenta: \"\\x1b[38;5;213m\",\n gray: \"\\x1b[38;5;250m\",\n lightblue: \"\\x1b[38;5;220m\",\n};\n\n// Default settings\nexport const DEFAULT_SETTINGS = {\n display_order: [\n [\"user\", \"hostname\", \"os\", \"device\", \"kernel\", \"cpu\", \"gpu\"],\n [\n \"disk_used\",\n \"ram_used\",\n \"top_process\",\n \"uptime\",\n \"temperature\",\n \"battery\",\n \"load_average\",\n ],\n [\"ip\", \"iplocal\", \"city\", \"domain\", \"isp\"],\n [\"shell\", \"pacman\", \"services_running\", \"containers\"],\n ],\n colors: {\n user: \"red\",\n hostname: \"orange\",\n disk_used: \"purple\",\n ram_used: \"yellow\",\n top_process: \"magenta\",\n uptime: \"cyan\",\n ip: \"green\",\n iplocal: \"yellow\",\n city: \"green\",\n domain: \"gray\",\n isp: \"lightblue\",\n os: \"gray\",\n cpu: \"orange\",\n gpu: \"yellow\",\n device: \"yellow\",\n kernel: \"green\",\n shell: \"orange\",\n pacman: \"multicolor\",\n ports: \"multicolor\",\n containers: \"green\",\n memory_available: \"blue\",\n swap_used: \"purple\",\n load_average: \"red\",\n users_logged_in: \"cyan\",\n network_interfaces: \"yellow\",\n mount_points: \"gray\",\n services_running: \"green\",\n temperature: \"red\",\n battery: \"green\",\n screen_resolution: \"blue\",\n },\n emojis: {\n user: \"👤 \",\n hostname: \"🏠 \",\n ip: \"🌎 \",\n iplocal: \"🌐 \",\n city: \"📍 \",\n domain: \"🔗 \",\n isp: \"👮 \",\n os: \"⚡ \",\n cpu: \"📈 \",\n gpu: \"🎮 \",\n device: \"💻 \",\n kernel: \"🔧 \",\n shell: \"🐚 \",\n pacman: \"🚀 \",\n disk_used: \"📁 \",\n ram_used: \"💾 \",\n top_process: \"🔝 \",\n uptime: \"⏱️ \",\n ports: \"🔌 \",\n containers: \"📦 \",\n memory_available: \"🧠 \",\n swap_used: \"🔄 \",\n load_average: \"⚖️ \",\n users_logged_in: \"👥 \",\n network_interfaces: \"🌐 \",\n mount_points: \"📂 \",\n services_running: \"⚙️ \",\n temperature: \"🌡️ \",\n battery_charging: \"🔌 \",\n battery: \"🔋 \",\n screen_resolution: \"🖥️ \",\n },\n labels: {\n user: \"User\",\n hostname: \"Host\",\n ip: \"IP\",\n iplocal: \"Local IP\",\n city: \"City\",\n domain: \"Domain\",\n isp: \"ISP\",\n os: \"OS\",\n cpu: \"CPU\",\n gpu: \"GPU\",\n device: \"Device\",\n kernel: \"Kernel\",\n shell: \"Shell\",\n pacman: \"Packages\",\n disk_used: \"Disk\",\n ram_used: \"RAM\",\n top_process: \"Top\",\n uptime: \"Uptime\",\n ports: \"Ports\",\n containers: \"Containers\",\n memory_available: \"Memory\",\n swap_used: \"Swap\",\n load_average: \"Load\",\n users_logged_in: \"Users\",\n network_interfaces: \"Network\",\n mount_points: \"Mounts\",\n services_running: \"Services\",\n temperature: \"Temp\",\n battery_charging: \"Battery\",\n battery: \"Battery\",\n screen_resolution: \"Resolution\",\n },\n display: {\n show_emojis: true,\n single_line: false,\n line_wrap_length: process?.stdout?.columns || 100,\n },\n network: {\n show_offline_message: true,\n },\n advanced: {\n debug: false,\n },\n};\n\nexport interface Settings {\n display_order: string[][];\n colors: Record<string, string>;\n emojis: Record<string, string>;\n labels: Record<string, string>;\n display: {\n show_emojis: boolean;\n single_line: boolean;\n line_wrap_length: number;\n };\n network: {\n show_offline_message: boolean;\n };\n advanced: {\n debug: boolean;\n };\n}\n\n/**\n * Loads settings from the configuration file\n * @returns Settings object (defaults merged with user settings)\n */\nexport function loadSettings(): Settings {\n try {\n if (fs.existsSync(SETTINGS_FILE)) {\n const settings = JSON.parse(fs.readFileSync(SETTINGS_FILE, \"utf8\"));\n return { ...DEFAULT_SETTINGS, ...settings };\n }\n } catch {}\n return DEFAULT_SETTINGS;\n}\n\n/**\n * Saves settings to the configuration file\n * @param settings - The settings object to save\n * @returns True if successful, false otherwise\n */\nexport function saveSettings(settings: Settings): boolean {\n try {\n const configDir = path.dirname(SETTINGS_FILE);\n if (!fs.existsSync(configDir)) {\n fs.mkdirSync(configDir, { recursive: true });\n }\n fs.writeFileSync(SETTINGS_FILE, JSON.stringify(settings, null, 2));\n return true;\n } catch {\n return false;\n }\n}\n","/**\n * Platform detection utilities\n * @module platform\n */\n\nimport os from \"os\";\n\n/**\n * Platform detection constants\n */\nexport const IS_WINDOWS = os.platform() === \"win32\";\nexport const IS_MAC = os.platform() === \"darwin\";\nexport const IS_LINUX = os.platform() === \"linux\";\n","/**\n * Command execution utilities\n * @module command\n */\n\nimport { execSync } from \"child_process\";\nimport { IS_WINDOWS } from \"./platform\";\n\n/**\n * Executes a shell command safely with timeout\n * @param {string} command - Command to execute\n * @param {object} options - Additional options for execSync\n * @returns {string} Command output or empty string on error\n */\nexport function execCommand(command: string, options = {}): string {\n try {\n const cmd = IS_WINDOWS ? `cmd /c ${command}` : command;\n return execSync(cmd, {\n encoding: \"utf8\",\n timeout: 10000,\n stdio: [\"pipe\", \"pipe\", \"ignore\"],\n ...options,\n })\n .toString()\n .trim();\n } catch (error) {\n return \"\";\n }\n}\n\n/**\n * Checks if a command exists in the system PATH\n * @param {string} command - Command name to check\n * @returns {boolean} True if command exists\n */\nexport function commandExists(command: string): boolean {\n try {\n if (IS_WINDOWS) {\n execSync(`where ${command}`, { stdio: \"ignore\" });\n } else {\n execSync(`which ${command}`, { stdio: \"ignore\" });\n }\n return true;\n } catch {\n return false;\n }\n}\n","/**\n * Cache configuration and constants\n * @module cache-config\n */\n\nimport os from \"os\";\nimport path from \"path\";\n\n/**\n * Cache file location in system's temporary directory\n * @constant\n */\nexport const CACHE_FILE = path.join(os.tmpdir(), \"systeminfo-cache.json\");\n\n/**\n * Cache duration configuration for different system information types\n * Values are in milliseconds\n *\n * @constant\n * @property {number} ip - IP information cache (5 minutes)\n * @property {number} cpu - CPU information cache (24 hours)\n * @property {number} gpu - GPU information cache (24 hours)\n * @property {number} os - OS information cache (24 hours)\n * @property {number} device - Device information cache (24 hours)\n * @property {number} kernel - Kernel information cache (1 hour)\n * @property {number} pacman - Package managers cache (10 minutes)\n * @property {number} ports - Open ports cache (5 minutes)\n * @property {number} containers - Docker containers cache (5 minutes)\n * @property {number} top_process - Top process cache (5 seconds)\n * @property {number} disk_used - Disk usage cache (1 minute)\n * @property {number} ram_used - RAM usage cache (10 seconds)\n * @property {number} services_running - Services cache (5 minutes)\n * @property {number} temperature - Temperature cache (30 seconds)\n * @property {number} battery - Battery status cache (1 minute)\n * @property {number} network_interfaces - Network interfaces cache (5 minutes)\n * @property {number} mount_points - Mount points cache (10 minutes)\n */\nexport const CACHE_DURATION = {\n ip: 5 * 60 * 1000,\n cpu: 24 * 60 * 60 * 1000,\n gpu: 24 * 60 * 60 * 1000,\n os: 24 * 60 * 60 * 1000,\n device: 24 * 60 * 60 * 1000,\n kernel: 60 * 60 * 1000,\n pacman: 10 * 60 * 1000,\n ports: 5 * 60 * 1000,\n containers: 5 * 60 * 1000,\n top_process: 5 * 1000,\n disk_used: 60 * 1000,\n ram_used: 10 * 1000,\n services_running: 5 * 60 * 1000,\n temperature: 30 * 1000,\n battery: 60 * 1000,\n network_interfaces: 5 * 60 * 1000,\n mount_points: 10 * 60 * 1000,\n};\n\n/**\n * Default IPInfo.io API token for geolocation\n * @constant\n */\nexport const DEFAULT_IPINFO_TOKEN = \"da2d6cc4baa5d1\";\n\n/**\n * Default network request timeout in milliseconds\n * @constant\n */\nexport const DEFAULT_NETWORK_TIMEOUT = 5000;\n","/**\n * Cache management utilities\n * @module cache\n */\n\nimport fs from \"fs\";\nimport { CACHE_FILE, CACHE_DURATION } from \"./cache-config\";\n\n/**\n * Represents a cached value with timestamp\n * @interface CacheEntry\n */\nexport interface CacheEntry {\n /** The cached value */\n value: any;\n /** Unix timestamp when the value was cached */\n timestamp: number;\n}\n\n/**\n * Cache storage structure\n * @interface Cache\n */\nexport interface Cache {\n [key: string]: CacheEntry;\n}\n\n/**\n * Loads cache from disk\n * @returns {Cache} Cached data or empty object if cache doesn't exist or is corrupted\n */\nexport function loadCache(): Cache {\n try {\n if (fs.existsSync(CACHE_FILE)) {\n return JSON.parse(fs.readFileSync(CACHE_FILE, \"utf8\"));\n }\n } catch (error) {\n // Corrupted cache - return empty object\n }\n return {};\n}\n\n/**\n * Saves cache to disk\n * @param {Cache} cache - Cache object to save\n */\nexport function saveCache(cache: Cache): void {\n try {\n fs.writeFileSync(CACHE_FILE, JSON.stringify(cache, null, 2));\n } catch (error) {\n // Silently fail if can't write cache\n }\n}\n\n/**\n * Checks if a cache entry is still valid based on configured duration\n * @param {CacheEntry} cacheEntry - The cache entry to validate\n * @param {string} key - The key name to determine cache duration\n * @returns {boolean} True if cache is still valid\n */\nexport function isCacheValid(cacheEntry: CacheEntry, key: string): boolean {\n if (!cacheEntry || !cacheEntry.timestamp) return false;\n const age = Date.now() - cacheEntry.timestamp;\n const maxAge = CACHE_DURATION[key as keyof typeof CACHE_DURATION] || 60000;\n return age < maxAge;\n}\n\n/**\n * Retrieves a value from cache if valid\n * @param {Cache} cache - Cache object\n * @param {string} key - Key to retrieve\n * @returns {any} Cached value or null if not found/expired\n */\nexport function getCachedValue(cache: Cache, key: string): any {\n if (!cache[key]) return null;\n const cacheEntry = cache[key];\n if (!isCacheValid(cacheEntry, key)) {\n delete cache[key];\n return null;\n }\n return cacheEntry.value;\n}\n\n/**\n * Stores a value in cache with current timestamp\n * @param {Cache} cache - Cache object\n * @param {string} key - Key to store under\n * @param {any} value - Value to cache\n */\nexport function setCachedValue(cache: Cache, key: string, value: any): void {\n cache[key] = {\n value,\n timestamp: Date.now(),\n };\n}\n","/**\n * Platform-related system information functions\n * @module info/platform\n */\n\nimport os from \"os\";\nimport fs from \"fs\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_WINDOWS, IS_MAC, IS_LINUX } from \"../utils/platform\";\nimport { execCommand, commandExists } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets the current username\n * @returns Current system username\n */\nexport function user(): string {\n return os.userInfo().username;\n}\n\n/**\n * Gets the system hostname\n * @returns Computer hostname/network name\n */\nexport function hostname(): string {\n return os.hostname();\n}\n\n/**\n * Gets operating system name and version\n * Platform-specific detection for Windows, macOS, and Linux\n * @param context - Info context with cache\n * @returns OS name and version string\n * @example \"Windows 11 Pro\", \"macOS Ventura 13.2.1\", \"Ubuntu 22.04.3 LTS\"\n */\nexport function os_info(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"os\");\n if (cached) return cached;\n\n const platform = os.platform();\n const release = os.release();\n let osName = \"\";\n\n if (IS_WINDOWS) {\n try {\n const version = execCommand(\"ver\");\n const match = version.match(/Microsoft Windows \\[Version ([^\\]]+)\\]/);\n osName = match ? `Windows ${match[1]}` : `Windows ${release}`;\n } catch {\n osName = `Windows ${release}`;\n }\n } else if (IS_MAC) {\n osName = `macOS ${release}`;\n } else if (IS_LINUX) {\n try {\n const osRelease = fs.readFileSync(\"/etc/os-release\", \"utf8\");\n const nameMatch = osRelease.match(/^NAME=\"([^\"]+)\"/m);\n const versionMatch = osRelease.match(/^VERSION_ID=\"([^\"]+)\"/m);\n osName = nameMatch ? nameMatch[1] : \"Linux\";\n if (versionMatch) osName += ` ${versionMatch[1]}`;\n } catch {\n osName = `Linux ${release}`;\n }\n } else {\n osName = `${platform} ${release}`;\n }\n\n setCachedValue(context.cache, \"os\", osName);\n return osName;\n}\n\n/**\n * Gets kernel version string\n * Returns the operating system kernel version from os.release()\n * @param context - Info context with cache\n * @returns Kernel version string\n * @example \"5.15.0-56-generic\", \"6.11.11-valve12-1-neptune\"\n */\nexport function kernel(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"kernel\");\n if (cached) return cached;\n\n const kernel = os.release();\n setCachedValue(context.cache, \"kernel\", kernel);\n return kernel;\n}\n\n/**\n * Gets device or computer model name\n * Uses WMI on Windows, DMI on Linux, getprop on Android\n * @param context - Info context with cache\n * @returns Device model name or empty string\n * @example \"Dell OptiPlex 7090\", \"MacBook Pro 16-inch\", \"Valve Steam Deck\"\n */\nexport function device(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"device\");\n if (cached !== null) return cached;\n\n if (IS_WINDOWS) {\n try {\n const wmic = execCommand(\"wmic csproduct get name /format:list\");\n const nameMatch = wmic.match(/Name=(.+)/);\n if (nameMatch) {\n const device = nameMatch[1].trim();\n if (device && device !== \"\") {\n setCachedValue(context.cache, \"device\", device);\n return device;\n }\n }\n } catch {}\n\n try {\n const ps = execCommand(\n 'powershell.exe -Command \"Get-WmiObject -Class Win32_ComputerSystem | Select-Object -ExpandProperty Model\"'\n );\n if (ps.trim()) {\n const device = ps.trim();\n setCachedValue(context.cache, \"device\", device);\n return device;\n }\n } catch {}\n } else if (IS_LINUX) {\n try {\n if (commandExists(\"getprop\")) {\n const device = execCommand(\"getprop ro.product.model\");\n if (device) {\n setCachedValue(context.cache, \"device\", device);\n return device;\n }\n }\n\n const dmiPath = \"/sys/devices/virtual/dmi/id/product_name\";\n if (fs.existsSync(dmiPath)) {\n const device = fs.readFileSync(dmiPath, \"utf8\").trim();\n if (device) {\n setCachedValue(context.cache, \"device\", device);\n return device;\n }\n }\n } catch {}\n }\n\n setCachedValue(context.cache, \"device\", \"\");\n return \"\";\n}\n","/**\n * Hardware-related system information functions\n * @module info/hardware\n */\n\nimport os from \"os\";\nimport fs from \"fs\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_WINDOWS, IS_LINUX } from \"../utils/platform\";\nimport { execCommand } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets CPU model name and specifications\n * Uses platform-specific commands (wmic/lscpu/cpuinfo)\n * Automatically strips \"with Radeon Graphics\" and similar suffixes\n * @param context - Info context with cache\n * @returns CPU model string or empty string\n * @example \"Intel Core i7-12700K\", \"AMD Ryzen 9 5900HX\", \"Apple M2 Pro\"\n */\nexport function cpu(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"cpu\");\n if (cached) return cached;\n\n let cpuName = \"\";\n\n if (IS_WINDOWS) {\n try {\n const wmic = execCommand(\"wmic cpu get name /format:list\");\n const nameMatch = wmic.match(/Name=(.+)/);\n if (nameMatch) {\n cpuName = nameMatch[1].trim();\n }\n } catch {}\n\n if (!cpuName) {\n try {\n const ps = execCommand(\n 'powershell.exe -Command \"Get-WmiObject -Class Win32_Processor | Select-Object -ExpandProperty Name\"'\n );\n if (ps.trim()) {\n cpuName = ps.trim();\n }\n } catch {}\n }\n } else if (IS_LINUX) {\n try {\n const lscpu = execCommand(\"lscpu\");\n const modelMatch = lscpu.match(/Model name:\\s*([^\\n,]+)/);\n if (modelMatch) {\n cpuName = modelMatch[1].trim();\n }\n } catch {}\n\n if (!cpuName) {\n try {\n const cpuInfo = fs.readFileSync(\"/proc/cpuinfo\", \"utf8\");\n const modelMatch = cpuInfo.match(/model name\\s*:\\s*([^\\n]+)/);\n const hardwareMatch = cpuInfo.match(/Hardware\\s*:\\s*([^\\n]+)/);\n\n if (modelMatch) {\n cpuName = modelMatch[1].trim();\n } else if (hardwareMatch) {\n cpuName = hardwareMatch[1].trim();\n }\n } catch {}\n }\n } else {\n const cpus = os.cpus();\n if (cpus.length > 0) {\n cpuName = cpus[0].model.trim().replace(/[\\r\\n]+/g, \" \");\n }\n }\n\n if (!cpuName) {\n setCachedValue(context.cache, \"cpu\", \"\");\n return \"\";\n }\n\n cpuName = cpuName.trim().replace(/with .*/, \"\");\n\n setCachedValue(context.cache, \"cpu\", cpuName);\n return cpuName;\n}\n\n/**\n * Gets graphics card model name\n * Extracts GPU info from lspci (Linux) or WMI (Windows)\n * Filters out basic/generic display adapters\n * @param context - Info context with cache\n * @returns GPU model string or empty string\n * @example \"NVIDIA GeForce RTX 4070\", \"AMD Radeon RX 6800 XT\"\n */\nexport function gpu(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"gpu\");\n if (cached !== null) return cached;\n\n if (IS_WINDOWS) {\n try {\n const wmic = execCommand(\n \"wmic path win32_VideoController get name /format:list\"\n );\n const nameMatch = wmic.match(/Name=(.+)/);\n if (nameMatch) {\n const gpu = nameMatch[1].trim();\n if (gpu && gpu !== \"\" && !gpu.includes(\"Microsoft Basic\")) {\n setCachedValue(context.cache, \"gpu\", gpu);\n return gpu;\n }\n }\n } catch {}\n\n try {\n const ps = execCommand(\n \"powershell.exe -Command \\\"Get-WmiObject -Class Win32_VideoController | Where-Object {$_.Name -notlike '*Microsoft Basic*'} | Select-Object -First 1 -ExpandProperty Name\\\"\"\n );\n if (ps.trim()) {\n const gpu = ps.trim();\n setCachedValue(context.cache, \"gpu\", gpu);\n return gpu;\n }\n } catch {}\n } else if (IS_LINUX) {\n try {\n const lspci = execCommand(\"lspci\");\n const gpuMatch = lspci.match(\n /VGA.*?(RTX|GeForce|AMD|Intel|NVIDIA)[^\\n]*/i\n );\n if (gpuMatch) {\n let gpu = gpuMatch[0];\n\n const bracketMatch = gpu.match(/\\[([^\\]]+)\\]/);\n if (bracketMatch) {\n gpu = bracketMatch[1];\n } else {\n gpu = gpu\n .replace(/^.*VGA[^:]*:\\s*/, \"\")\n .replace(/\\s*\\(.*\\)$/, \"\")\n .trim();\n }\n\n if (gpu) {\n setCachedValue(context.cache, \"gpu\", gpu);\n return gpu;\n }\n }\n } catch {}\n }\n\n setCachedValue(context.cache, \"gpu\", \"\");\n return \"\";\n}\n\n/**\n * Gets screen resolution from X11 display\n * Uses xrandr command (Linux with X11/Xorg only)\n * @returns Resolution in WIDTHxHEIGHT format or empty string\n * @example \"1920x1080\", \"2560x1440\", \"3840x2160\"\n */\nexport function screen_resolution(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n if (process.env.DISPLAY) {\n const xrandr = execCommand(\"xrandr\");\n const resolutionMatch = xrandr.match(/(\\d+x\\d+)\\+\\d+\\+\\d+/);\n if (resolutionMatch) {\n return resolutionMatch[1];\n }\n }\n } catch {}\n return \"\";\n}\n","/**\n * Memory and disk-related system information functions\n * @module info/memory\n */\n\nimport os from \"os\";\nimport fs from \"fs\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets memory usage in gigabytes\n * Reads from /proc/meminfo on Linux, falls back to os.totalmem()\n * @param context - Info context with cache\n * @returns Memory usage as \"used/total GB\"\n * @example \"12/32GB\", \"6/16GB\"\n */\nexport function ram_used(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"ram_used\");\n if (cached) return cached;\n\n if (IS_LINUX) {\n try {\n const meminfo = fs.readFileSync(\"/proc/meminfo\", \"utf8\");\n const totalMatch = meminfo.match(/MemTotal:\\s+(\\d+) kB/);\n const freeMatch = meminfo.match(/MemFree:\\s+(\\d+) kB/);\n\n if (totalMatch && freeMatch) {\n const totalMB = Math.round(parseInt(totalMatch[1]) / 1024);\n const freeMB = Math.round(parseInt(freeMatch[1]) / 1024);\n const usedMB = totalMB - freeMB;\n\n const totalGB = Math.round(totalMB / 1024);\n const usedGB = Math.round(usedMB / 1024);\n\n const result = `${usedGB}/${totalGB}GB`;\n setCachedValue(context.cache, \"ram_used\", result);\n return result;\n }\n } catch {}\n }\n\n const totalMem = os.totalmem();\n const freeMem = os.freemem();\n const usedMem = totalMem - freeMem;\n\n const totalGB = Math.round(totalMem / (1024 * 1024 * 1024));\n const usedGB = Math.round(usedMem / (1024 * 1024 * 1024));\n\n const result = `${usedGB}/${totalGB}GB`;\n setCachedValue(context.cache, \"ram_used\", result);\n return result;\n}\n\n/**\n * Gets available memory in gigabytes\n * Reads MemAvailable from /proc/meminfo (Linux only)\n * @returns Available memory with \"GB available\" suffix or empty string\n * @example \"12GB available\", \"4GB available\"\n */\nexport function memory_available(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const meminfo = fs.readFileSync(\"/proc/meminfo\", \"utf8\");\n const availableMatch = meminfo.match(/MemAvailable:\\s+(\\d+) kB/);\n if (availableMatch) {\n const availableGB = Math.round(parseInt(availableMatch[1]) / 1024 / 1024);\n return `${availableGB}GB available`;\n }\n } catch {}\n return \"\";\n}\n\n/**\n * Gets swap memory usage\n * Calculates swap usage from /proc/meminfo (Linux only)\n * @returns Swap usage as \"percentage (size MB) swap\" or empty string\n * @example \"15% (512MB) swap\", \"0% (0MB) swap\"\n */\nexport function swap_used(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const meminfo = fs.readFileSync(\"/proc/meminfo\", \"utf8\");\n const swapTotalMatch = meminfo.match(/SwapTotal:\\s+(\\d+) kB/);\n const swapFreeMatch = meminfo.match(/SwapFree:\\s+(\\d+) kB/);\n\n if (swapTotalMatch && swapFreeMatch) {\n const swapTotal = parseInt(swapTotalMatch[1]);\n const swapFree = parseInt(swapFreeMatch[1]);\n const swapUsed = swapTotal - swapFree;\n\n if (swapTotal > 0) {\n const swapUsedPercent = Math.round((swapUsed / swapTotal) * 100);\n const swapUsedMB = Math.round(swapUsed / 1024);\n return `${swapUsedPercent}% (${swapUsedMB}MB) swap`;\n }\n }\n } catch {}\n return \"\";\n}\n\n/**\n * Gets root filesystem disk usage percentage\n * Uses df command on Linux/Android\n * @param context - Info context with cache\n * @returns Percentage string or empty string\n * @example \"45%\", \"78%\"\n */\nexport function disk_used(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"disk_used\");\n if (cached !== null) return cached;\n\n if (IS_LINUX) {\n try {\n const df = execCommand(\"df -h\");\n let diskUsage = \"\";\n\n if (df.includes(\"/storage/emulated\")) {\n const match = df.match(/\\s+(\\d+%)\\s+\\/storage\\/emulated/);\n diskUsage = match ? match[1] : \"\";\n } else {\n const lines = df.split(\"\\n\");\n for (const line of lines) {\n if (line.trim().endsWith(\" /\")) {\n const parts = line.trim().split(/\\s+/);\n const percentIndex = parts.findIndex((part) => part.includes(\"%\"));\n if (percentIndex !== -1) {\n diskUsage = parts[percentIndex];\n break;\n }\n }\n }\n\n if (!diskUsage) {\n const rootMatch = df.match(/(\\d+%)\\s+\\/\\s*$/m);\n diskUsage = rootMatch ? rootMatch[1] : \"\";\n }\n }\n\n setCachedValue(context.cache, \"disk_used\", diskUsage);\n return diskUsage;\n } catch {}\n }\n\n setCachedValue(context.cache, \"disk_used\", \"\");\n return \"\";\n}\n\n/**\n * Gets system load averages\n * Reads 1, 5, and 15 minute load averages from /proc/loadavg (Linux only)\n * @returns Space-separated load averages (1m 5m 15m) or empty string\n * @example \"0.52 0.58 0.59\", \"2.10 1.95 1.88\"\n */\nexport function load_average(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const loadavg = fs.readFileSync(\"/proc/loadavg\", \"utf8\");\n const loads = loadavg.split(\" \").slice(0, 3);\n return loads.join(\" \");\n } catch {}\n return \"\";\n}\n\n/**\n * Gets mounted filesystem information\n * Lists non-system mount points with usage from df (Linux only)\n * Excludes /, /dev, /proc, and /sys mounts\n * @param context - Info context with cache\n * @returns Space-separated mount points with usage or empty string\n * @example \"/home(45%) /mnt/data(78%)\", \"/media/usb(12%)\"\n */\nexport function mount_points(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"mount_points\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"mount_points\", \"\");\n return \"\";\n }\n\n try {\n const df = execCommand(\"df -h\");\n const lines = df.split(\"\\n\").slice(1);\n const mountPoints: string[] = [];\n\n lines.forEach((line) => {\n const parts = line.trim().split(/\\s+/);\n if (parts.length >= 6) {\n const mountPoint = parts[5];\n const usage = parts[4];\n if (\n !mountPoint.startsWith(\"/dev\") &&\n !mountPoint.startsWith(\"/proc\") &&\n !mountPoint.startsWith(\"/sys\") &&\n mountPoint !== \"/\"\n ) {\n mountPoints.push(`${mountPoint}(${usage})`);\n }\n }\n });\n\n const result = mountPoints.slice(0, 3).join(\" \");\n setCachedValue(context.cache, \"mount_points\", result);\n return result;\n } catch {}\n\n setCachedValue(context.cache, \"mount_points\", \"\");\n return \"\";\n}\n","/**\n * Process-related system information functions\n * @module info/process\n */\n\nimport os from \"os\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets the highest CPU-consuming process\n * Uses ps command to find top process by CPU usage (Linux only)\n * @param context - Info context with cache\n * @returns Process info as \"percentage processname\" or empty string\n * @example \"8% firefox\", \"15% chrome\", \"3% systemd\"\n */\nexport function top_process(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"top_process\");\n if (cached !== null) return cached;\n\n if (IS_LINUX) {\n try {\n const ps = execCommand(\"ps -eo pcpu,comm --sort=-%cpu --no-headers\");\n const lines = ps.split(\"\\n\");\n if (lines.length > 0) {\n const topProcess = lines[0].trim().replace(/\\s+/, \" \").split(\" \");\n const cpu = topProcess[0].replace(/\\.\\d+/, \"%\");\n const process = topProcess[1].split(\"/\").pop();\n const result = `${cpu} ${process}`;\n setCachedValue(context.cache, \"top_process\", result);\n return result;\n }\n } catch {}\n }\n\n setCachedValue(context.cache, \"top_process\", \"\");\n return \"\";\n}\n\n/**\n * Gets system uptime since last boot\n * @returns Uptime formatted as \"Xd Yh Zm\"\n * @example \"2d 14h 23m\", \"0d 3h 45m\"\n */\nexport function uptime(): string {\n const uptimeSeconds = os.uptime();\n const days = Math.floor(uptimeSeconds / 86400);\n const hours = Math.floor((uptimeSeconds % 86400) / 3600);\n const minutes = Math.floor((uptimeSeconds % 3600) / 60);\n return `${days}d ${hours}h ${minutes}m`;\n}\n\n/**\n * Gets number of logged in users\n * Uses who command to count active user sessions (Linux only)\n * @returns User count with \"users\" suffix or empty string\n * @example \"3 users\", \"1 users\"\n */\nexport function users_logged_in(): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const who = execCommand(\"who\");\n const users = who.split(\"\\n\").filter((line) => line.trim()).length;\n if (users > 0) {\n return `${users} users`;\n }\n } catch {}\n return \"\";\n}\n","/**\n * Network-related system information functions\n * @module info/network\n */\n\nimport os from \"os\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets public IP address from ipinfo.io\n * @param context - Info context with cache and IP info\n * @returns Public IPv4 address or empty string\n * @example \"203.0.113.42\"\n */\nexport async function ip(context: InfoContext): Promise<string> {\n const cached = getCachedValue(context.cache, \"ip\");\n if (cached) return cached;\n\n if (!context.ipInfo) {\n setCachedValue(context.cache, \"ip\", \"\");\n return \"\";\n }\n const ip = context.ipInfo.ip || \"\";\n setCachedValue(context.cache, \"ip\", ip);\n return ip;\n}\n\n/**\n * Gets local/private IP address(es)\n * Tries ifconfig and ip commands on Linux, falls back to Node.js API\n * @returns Space-separated local IP addresses (RFC 1918 ranges)\n * @example \"192.168.1.100\" or \"10.0.0.50 192.168.1.100\"\n */\nexport function iplocal(): string {\n if (IS_LINUX) {\n try {\n const ifconfig = execCommand(\"ifconfig 2>/dev/null\");\n const wlanMatch = ifconfig.match(\n /wlan0[\\s\\S]*?inet (\\d+\\.\\d+\\.\\d+\\.\\d+)/\n );\n if (wlanMatch) {\n return wlanMatch[1];\n }\n } catch {}\n\n try {\n const ipAddr = execCommand(\"ip addr show 2>/dev/null\");\n const addresses: string[] = [];\n const matches = ipAddr.matchAll(/inet (\\d+\\.\\d+\\.\\d+\\.\\d+)\\/\\d+/g);\n for (const match of matches) {\n if (!match[1].startsWith(\"127.\")) {\n addresses.push(match[1]);\n }\n }\n if (addresses.length > 0) {\n return addresses.join(\" \");\n }\n } catch {}\n }\n\n const interfaces = os.networkInterfaces();\n const addresses: string[] = [];\n\n for (const name of Object.keys(interfaces)) {\n for (const device of interfaces[name] || []) {\n if (device.family === \"IPv4\" && !device.internal) {\n addresses.push(device.address);\n }\n }\n }\n\n return addresses.join(\" \");\n}\n\n/**\n * Gets geographic city based on public IP\n * @param context - Info context with IP geolocation data\n * @returns City name or empty string\n * @example \"San Francisco\", \"New York\", \"London\"\n */\nexport async function city(context: InfoContext): Promise<string> {\n const cached = getCachedValue(context.cache, \"city\");\n if (cached !== null) return cached;\n\n if (!context.ipInfo || !context.ipInfo.city) {\n setCachedValue(context.cache, \"city\", \"\");\n return \"\";\n }\n const city = context.ipInfo.city;\n setCachedValue(context.cache, \"city\", city);\n return city;\n}\n\n/**\n * Gets reverse DNS hostname with HTTP prefix\n * @param context - Info context with IP info\n * @returns Domain with http:// prefix or empty string\n * @example \"http://example.com\", \"http://host-203-0-113-42.example.net\"\n */\nexport async function domain(context: InfoContext): Promise<string> {\n const cached = getCachedValue(context.cache, \"domain\");\n if (cached !== null) return cached;\n\n if (!context.ipInfo || !context.ipInfo.hostname) {\n setCachedValue(context.cache, \"domain\", \"\");\n return \"\";\n }\n const domain = `http://${context.ipInfo.hostname}`;\n setCachedValue(context.cache, \"domain\", domain);\n return domain;\n}\n\n/**\n * Gets Internet Service Provider name\n * Strips AS number prefix from organization string\n * @param context - Info context with IP info\n * @returns ISP name or empty string\n * @example \"Comcast Cable\", \"Verizon Business\", \"Cloudflare Inc\"\n */\nexport async function isp(context: InfoContext): Promise<string> {\n const cached = getCachedValue(context.cache, \"isp\");\n if (cached !== null) return cached;\n\n if (!context.ipInfo || !context.ipInfo.org) {\n setCachedValue(context.cache, \"isp\", \"\");\n return \"\";\n }\n const isp = context.ipInfo.org.split(\" \").slice(1).join(\" \");\n setCachedValue(context.cache, \"isp\", isp);\n return isp;\n}\n\n/**\n * Gets active network interface names\n * Lists non-loopback interfaces with IPv4 addresses (Linux only)\n * @param context - Info context with cache\n * @returns Space-separated interface names or empty string\n * @example \"eth0 wlan0\", \"enp0s3\"\n */\nexport function network_interfaces(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"network_interfaces\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"network_interfaces\", \"\");\n return \"\";\n }\n\n try {\n const interfaces = os.networkInterfaces();\n const activeInterfaces: string[] = [];\n\n for (const [name, addrs] of Object.entries(interfaces)) {\n if (name !== \"lo\") {\n const ipv4Addr = addrs?.find(\n (addr) => addr.family === \"IPv4\" && !addr.internal\n );\n if (ipv4Addr) {\n activeInterfaces.push(name);\n }\n }\n }\n\n const result = activeInterfaces.join(\" \");\n setCachedValue(context.cache, \"network_interfaces\", result);\n return result;\n } catch {}\n\n setCachedValue(context.cache, \"network_interfaces\", \"\");\n return \"\";\n}\n/**\n * Gets open TCP ports with service names\n * Uses lsof to find listening TCP ports (Linux only)\n * @param context - Info context with cache\n * @returns Space-separated port+process pairs or empty string\n * @example \"80http 443http 22ssh\", \"3000node 5432post\"\n */\nexport function ports(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"ports\");\n if (cached !== null) return cached;\n\n if (IS_LINUX) {\n try {\n const lsof = execCommand(\"lsof -nP -iTCP -sTCP:LISTEN\");\n const lines = lsof.split(\"\\n\").slice(1);\n const ports = new Set<string>();\n\n lines.forEach((line) => {\n const parts = line.split(/\\s+/);\n if (parts.length >= 9) {\n const address = parts[8];\n const portMatch = address.match(/:(\\d+)$/);\n if (portMatch) {\n const port = portMatch[1];\n const process = parts[0].substring(0, 4);\n ports.add(`${port}${process}`);\n }\n }\n });\n\n const result = Array.from(ports).join(\" \");\n setCachedValue(context.cache, \"ports\", result);\n return result;\n } catch {}\n }\n\n setCachedValue(context.cache, \"ports\", \"\");\n return \"\";\n}\n","/**\n * System status and health information functions\n * @module info/system-status\n */\n\nimport fs from \"fs\";\nimport os from \"os\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand, commandExists } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets system load averages\n * Reads 1, 5, and 15 minute load averages from /proc/loadavg (Linux only)\n * @returns Space-separated load averages (1m 5m 15m) or empty string\n * @example \"0.52 0.58 0.59\", \"2.10 1.95 1.88\"\n */\nexport function load_average(context: InfoContext): string {\n if (!IS_LINUX) return \"\";\n\n try {\n const loadavg = fs.readFileSync(\"/proc/loadavg\", \"utf8\");\n const loads = loadavg.split(\" \").slice(0, 3);\n return loads.join(\" \");\n } catch {}\n return \"\";\n}\n\n/**\n * Gets battery charge level and charging status\n * Reads from /sys/class/power_supply/BAT0 (Linux laptops only)\n * @param context - Info context with cache\n * @returns Battery percentage with optional + for charging, or empty string\n * @example \"85%\", \"42%+\", \"100%\"\n */\nexport function battery(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"battery\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"battery\", \"\");\n return \"\";\n }\n\n try {\n const batteryPath = \"/sys/class/power_supply/BAT0\";\n const capacityPath = `${batteryPath}/capacity`;\n const statusPath = `${batteryPath}/status`;\n\n if (fs.existsSync(capacityPath)) {\n const capacity = fs.readFileSync(capacityPath, \"utf8\").trim();\n const status = fs.existsSync(statusPath)\n ? fs.readFileSync(statusPath, \"utf8\").trim()\n : \"Unknown\";\n\n const batteryPercent = parseInt(capacity);\n const isCharging = status === \"Charging\";\n const result = `${batteryPercent}%${isCharging ? \"+\" : \"\"}`;\n setCachedValue(context.cache, \"battery\", result);\n return result;\n }\n } catch {}\n\n setCachedValue(context.cache, \"battery\", \"\");\n return \"\";\n}\n\n/**\n * Gets system temperature in Celsius\n * Reads from thermal zone or hwmon sensors (Linux only)\n * @param context - Info context with cache\n * @returns Temperature with °C suffix or empty string\n * @example \"45°C\", \"62°C\"\n */\nexport function temperature(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"temperature\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"temperature\", \"\");\n return \"\";\n }\n\n try {\n const tempSources = [\n \"/sys/class/thermal/thermal_zone0/temp\",\n \"/sys/class/hwmon/hwmon0/temp1_input\",\n \"/sys/class/hwmon/hwmon1/temp1_input\",\n ];\n\n for (const source of tempSources) {\n if (fs.existsSync(source)) {\n const temp = fs.readFileSync(source, \"utf8\").trim();\n const tempC = Math.round(parseInt(temp) / 1000);\n\n if (tempC > 0 && tempC < 150) {\n const result = `${tempC}°C`;\n setCachedValue(context.cache, \"temperature\", result);\n return result;\n }\n }\n }\n } catch {}\n\n setCachedValue(context.cache, \"temperature\", \"\");\n return \"\";\n}\n\n/**\n * Gets count of running system services\n * Uses systemctl or service command (Linux only)\n * @param context - Info context with cache\n * @returns Service count with \"services\" suffix or empty string\n * @example \"125 services\", \"89 services\"\n */\nexport function services_running(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"services_running\");\n if (cached !== null) return cached;\n\n if (!IS_LINUX) {\n setCachedValue(context.cache, \"services_running\", \"\");\n return \"\";\n }\n\n try {\n let serviceCount = 0;\n\n if (commandExists(\"systemctl\")) {\n const services = execCommand(\n \"systemctl list-units --type=service --state=running --no-pager\"\n );\n serviceCount = services\n .split(\"\\n\")\n .filter((line) => line.includes(\".service\")).length;\n } else if (commandExists(\"service\")) {\n const services = execCommand(\"service --status-all\");\n serviceCount = services\n .split(\"\\n\")\n .filter((line) => line.includes(\"+\")).length;\n }\n\n if (serviceCount > 0) {\n const result = `${serviceCount} services`;\n setCachedValue(context.cache, \"services_running\", result);\n return result;\n }\n } catch {}\n\n setCachedValue(context.cache, \"services_running\", \"\");\n return \"\";\n}\n","/**\n * Software and package-related system information functions\n * @module info/software\n */\n\nimport process from \"process\";\nimport type { InfoContext } from \"../types/internal-types\";\nimport { IS_LINUX } from \"../utils/platform\";\nimport { execCommand, commandExists } from \"../utils/command\";\nimport { getCachedValue, setCachedValue } from \"../cache/cache\";\n\n/**\n * Gets the current shell name\n * Uses ps command to find parent process shell (Linux/Unix only)\n * @returns Shell name or empty string on Windows\n * @example \"bash\", \"zsh\", \"fish\", \"nu\"\n */\nexport function shell(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"shell\");\n if (cached !== null) return cached;\n\n if (IS_LINUX) {\n try {\n const ppid = process.ppid;\n const shellName = execCommand(`ps -p ${ppid} -o comm=`).split(\"/\").pop();\n if (shellName) {\n setCachedValue(context.cache, \"shell\", shellName);\n return shellName;\n }\n } catch {}\n }\n\n setCachedValue(context.cache, \"shell\", \"\");\n return \"\";\n}\n\n/**\n * Gets available package managers and development tools\n * Checks for package managers (apt, yum, npm, etc.) and editors (nvim, hx)\n * @param context - Info context with cache\n * @returns Space-separated list of available commands\n * @example \"apt npm docker nvim\", \"yay pacman bun hx\"\n */\nexport function packages(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"packages\");\n if (cached !== null) return cached;\n\n const commands = [\n \"apt\",\n \"npm\",\n \"uv\",\n \"docker\",\n \"hx\",\n \"nvim\",\n \"bun\",\n \"yay\",\n \"pacman\",\n \"yum\",\n \"dnf\",\n \"zypper\",\n \"emerge\",\n \"apk\",\n \"snap\",\n \"flatpak\",\n ];\n const available = commands.filter((cmd) => commandExists(cmd));\n\n const result = available.join(\" \");\n setCachedValue(context.cache, \"packages\", result);\n return result;\n}\n\n/**\n * Gets versions of common software tools\n * @param context - Info context with cache\n * @returns Formatted string of tool versions\n * @example \"node:20.1.0 git:2.34.1\"\n */\nexport function common_versions(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"common_versions\");\n if (cached !== null) return cached;\n\n const tools = [\n {\n cmd: \"node\",\n args: \"--version\",\n clean: (v: string) => v.replace(/^v/, \"\"),\n },\n {\n cmd: \"git\",\n args: \"--version\",\n clean: (v: string) => v.replace(\"git version \", \"\"),\n },\n {\n cmd: \"docker\",\n args: \"--version\",\n clean: (v: string) => v.replace(/Docker version ([^,]+),.*/, \"$1\"),\n },\n {\n cmd: \"python3\",\n args: \"--version\",\n clean: (v: string) => v.replace(\"Python \", \"\"),\n },\n {\n cmd: \"go\",\n args: \"version\",\n clean: (v: string) => v.replace(\"go version go\", \"\").split(\" \")[0],\n },\n {\n cmd: \"rustc\",\n args: \"--version\",\n clean: (v: string) => v.replace(\"rustc \", \"\").split(\" \")[0],\n },\n ];\n\n const versions: string[] = [];\n\n for (const tool of tools) {\n if (commandExists(tool.cmd)) {\n try {\n const output = execCommand(`${tool.cmd} ${tool.args}`);\n const version = tool.clean(output).trim();\n if (version) {\n versions.push(`${tool.cmd}:${version}`);\n }\n } catch {}\n }\n }\n\n const result = versions.join(\" \");\n setCachedValue(context.cache, \"common_versions\", result);\n return result;\n}\n/**\n * Gets running Docker container names\n * Lists active Docker containers with their names\n * @param context - Info context with cache\n * @returns Space-separated container names or empty string\n * @example \"nginx redis postgres\", \"web-app db-server\"\n */\nexport function containers(context: InfoContext): string {\n const cached = getCachedValue(context.cache, \"containers\");\n if (cached !== null) return cached;\n\n if (!commandExists(\"docker\")) {\n setCachedValue(context.cache, \"containers\", \"\");\n return \"\";\n }\n\n try {\n const containerCount = execCommand(\"docker ps -q\")\n .split(\"\\n\")\n .filter((line) => line.trim()).length;\n if (containerCount === 0) {\n setCachedValue(context.cache, \"containers\", \"\");\n return \"\";\n }\n\n const containers = execCommand(\n 'docker ps --format \"{{.Names}}\\t{{.Ports}}\"'\n );\n const lines = containers.split(\"\\n\").filter((line) => line.trim());\n\n const containerInfo: string[] = [];\n\n lines.forEach((line) => {\n const [name, ports] = line.split(\"\\t\");\n if (name) {\n containerInfo.push(name);\n\n if (ports) {\n const portMatches = ports.match(/->(\\d+(-\\d+)?)\\//g);\n if (portMatches) {\n const uniquePorts = [\n ...new Set(\n portMatches.map((p) => p.replace(/->\\d+(-\\d+)?\\//, \"\"))\n ),\n ];\n containerInfo.push(...uniquePorts);\n }\n }\n }\n });\n\n const result = containerInfo.join(\" \");\n setCachedValue(context.cache, \"containers\", result);\n return result;\n } catch {}\n\n setCachedValue(context.cache, \"containers\", \"\");\n return \"\";\n}\n","/**\n * @fileoverview System Information API\n *\n * A comprehensive cross-platform system information collection API.\n * Provides clean JSON data without formatting, suitable for programmatic use.\n *\n * @module system-info-api\n * @author vtempest\n * @license rights.institute/prosper\n */\n\nimport os from \"os\";\nimport fs from \"fs\";\nimport https from \"https\";\nimport path from \"path\";\nimport type { SystemInfo, SystemInfoOptions } from \"./systeminfo-types\";\nimport { CACHE_FILE } from \"./info/settings\"; // Using CACHE_FILE from settings to ensure consistency\n\n// Import info functions from modules\nimport { user, hostname, os_info, kernel, device } from \"./info/platform\";\nimport { cpu, gpu, screen_resolution } from \"./info/hardware\";\nimport {\n disk_used,\n ram_used,\n memory_available,\n swap_used,\n mount_points,\n} from \"./info/memory\";\nimport { top_process, uptime, users_logged_in } from \"./info/process\";\nimport {\n ip,\n iplocal,\n city,\n domain,\n isp,\n network_interfaces,\n ports,\n} from \"./info/network\";\nimport {\n services_running,\n temperature,\n battery,\n load_average,\n} from \"./info/system-status\";\nimport { shell, packages, containers } from \"./info/software\";\n\n/**\n * Cache duration configuration for different system information types\n * Values are in milliseconds\n */\nconst CACHE_DURATION = {\n ip: 5 * 60 * 1000,\n cpu: 24 * 60 * 60 * 1000,\n gpu: 24 * 60 * 60 * 1000,\n os: 24 * 60 * 60 * 1000,\n device: 24 * 60 * 60 * 1000,\n kernel: 60 * 60 * 1000,\n pacman: 10 * 60 * 1000,\n ports: 5 * 60 * 1000,\n containers: 5 * 60 * 1000,\n top_process: 5 * 1000,\n disk_used: 60 * 1000,\n ram_used: 10 * 1000,\n services_running: 5 * 60 * 1000,\n temperature: 30 * 1000,\n battery: 60 * 1000,\n network_interfaces: 5 * 60 * 1000,\n mount_points: 10 * 60 * 1000,\n};\n\n/**\n * Platform detection constants\n */\nconst IS_WINDOWS = os.platform() === \"win32\";\nconst IS_MAC = os.platform() === \"darwin\";\nconst IS_LINUX = os.platform() === \"linux\";\n\n/**\n * Default IPInfo.io API token for geolocation\n */\nconst DEFAULT_IPINFO_TOKEN = \"da2d6cc4baa5d1\";\n\n/**\n * Default network request timeout in milliseconds\n */\nconst DEFAULT_NETWORK_TIMEOUT = 5000;\n\n/**\n * Represents a cached value with timestamp\n */\ninterface CacheEntry {\n value: any;\n timestamp: number;\n}\n\n/**\n * Cache storage structure\n */\ninterface Cache {\n [key: string]: CacheEntry;\n}\n\n/**\n * IP information from ipinfo.io API\n */\ninterface IPInfo {\n ip?: string;\n city?: string;\n hostname?: string;\n org?: string;\n}\n\n/**\n * Context object passed to info collection functions\n */\ninterface InfoContext {\n cache: Cache;\n ipInfo?: IPInfo;\n}\n\n/**\n * Loads cache from disk\n */\nfunction loadCache(): Cache {\n try {\n if (fs.existsSync(CACHE_FILE)) {\n return JSON.parse(fs.readFileSync(CACHE_FILE, \"utf8\"));\n }\n } catch (error) {\n // Corrupted cache - return empty object\n }\n return {};\n}\n\n/**\n * Saves cache to disk\n */\nfunction saveCache(cache: Cache): void {\n try {\n const cacheDir = path.dirname(CACHE_FILE);\n if (!fs.existsSync(cacheDir)) {\n fs.mkdirSync(cacheDir, { recursive: true });\n }\n fs.writeFileSync(CACHE_FILE, JSON.stringify(cache, null, 2));\n } catch (error) {\n // Silently fail if can't write cache\n }\n}\n\n/**\n * Fetches IP geolocation information from ipinfo.io API\n */\nasync function fetchIPInfo(\n token: string = DEFAULT_IPINFO_TOKEN,\n timeout: number = DEFAULT_NETWORK_TIMEOUT\n): Promise<IPInfo> {\n return new Promise((resolve) => {\n const url = `https://ipinfo.io/json${token ? `?token=${token}` : \"\"}`;\n\n const req = https.get(url, (res) => {\n let data = \"\";\n res.on(\"data\", (chunk) => (data += chunk));\n res.on(\"end\", () => {\n try {\n resolve(JSON.parse(data));\n } catch {\n resolve({});\n }\n });\n });\n\n req.on(\"error\", () => resolve({}));\n req.setTimeout(timeout, () => {\n req.destroy();\n resolve({});\n });\n });\n}\n\n/**\n * System information collection functions map\n */\nexport const infoFunctions = {\n user,\n hostname,\n ip,\n iplocal,\n city,\n domain,\n isp,\n os: os_info, // Mapped from os_info\n cpu,\n gpu,\n disk_used,\n ram_used,\n top_process,\n uptime,\n device,\n kernel,\n shell,\n pacman: packages, // Mapped from packages\n ports,\n containers,\n memory_available,\n swap_used,\n load_average,\n users_logged_in,\n network_interfaces,\n mount_points,\n services_running,\n temperature,\n battery,\n screen_resolution,\n};\n\n/**\n * Get all system information as a clean JSON object\n */\nexport async function getSystemInfo(\n options: SystemInfoOptions = {}\n): Promise<SystemInfo> {\n const cache = loadCache();\n const context: InfoContext = { cache };\n\n // Check if we need IP info\n // Some functions need IP info, so we fetch it once if needed by any function\n // For now we always try to fetch it if not cached, as ip/city/etc depend on it\n // Optimization: check if we actually need to run those functions based on options if provided\n // But current implementation fetches it always if missing from cache\n\n const cachedIPInfo = cache[\"ipInfo\"]?.value;\n if (cachedIPInfo) {\n context.ipInfo = cachedIPInfo;\n } else {\n context.ipInfo = await fetchIPInfo();\n // Cache IP info itself\n cache[\"ipInfo\"] = {\n value: context.ipInfo,\n timestamp: Date.now(),\n };\n }\n\n // Collect all system information\n const info: Partial<SystemInfo> = {\n timestamp: new Date().toISOString(),\n platform: IS_WINDOWS\n ? \"windows\"\n : IS_MAC\n ? \"macos\"\n : IS_LINUX\n ? \"linux\"\n : \"unknown\",\n };\n\n // Call all info functions\n for (const [key, fn] of Object.entries(infoFunctions)) {\n try {\n // most functions are sync but some are async (ip related)\n const value = await fn(context);\n info[key as keyof SystemInfo] = value as any;\n } catch (error) {\n info[key as keyof SystemInfo] = \"\" as any;\n }\n }\n\n saveCache(cache);\n\n return info as SystemInfo;\n}\n\nexport { loadCache, saveCache };\n"],"names":["process$1","SETTINGS_FILE","path","os","CACHE_FILE","colors","DEFAULT_SETTINGS","process","loadSettings","fs","settings","saveSettings","configDir","IS_WINDOWS","IS_MAC","IS_LINUX","execCommand","command","options","cmd","execSync","commandExists","CACHE_DURATION","isCacheValid","cacheEntry","key","age","maxAge","getCachedValue","cache","setCachedValue","value","user","hostname","os_info","context","cached","platform","release","osName","match","osRelease","nameMatch","versionMatch","kernel","device","ps","dmiPath","cpu","cpuName","modelMatch","cpuInfo","hardwareMatch","cpus","gpu","gpuMatch","bracketMatch","screen_resolution","resolutionMatch","ram_used","meminfo","totalMatch","freeMatch","totalMB","freeMB","usedMB","totalGB","result","totalMem","freeMem","usedMem","memory_available","availableMatch","swap_used","swapTotalMatch","swapFreeMatch","swapTotal","swapFree","swapUsed","swapUsedPercent","swapUsedMB","disk_used","df","diskUsage","lines","line","parts","percentIndex","part","rootMatch","mount_points","mountPoints","mountPoint","usage","top_process","topProcess","uptime","uptimeSeconds","days","hours","minutes","users_logged_in","users","ip","iplocal","wlanMatch","ipAddr","addresses","matches","interfaces","name","city","domain","isp","network_interfaces","activeInterfaces","addrs","addr","ports","portMatch","port","load_average","battery","batteryPath","capacityPath","statusPath","capacity","status","temperature","tempSources","source","temp","tempC","services_running","serviceCount","shell","ppid","shellName","packages","containers","containerInfo","portMatches","uniquePorts","p","DEFAULT_IPINFO_TOKEN","DEFAULT_NETWORK_TIMEOUT","loadCache","saveCache","cacheDir","fetchIPInfo","token","timeout","resolve","url","req","https","res","data","chunk","infoFunctions","getSystemInfo","cachedIPInfo","info","fn"],"mappings":"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"}
|