PowerShell/docs/check-power.md

95 lines
2.9 KiB
Markdown
Raw Permalink Normal View History

2024-11-08 12:38:20 +01:00
The *check-power.ps1* Script
===========================
2023-09-01 17:53:03 +02:00
This PowerShell script queries the power status and prints it.
Parameters
----------
```powershell
2024-11-08 12:35:11 +01:00
/home/markus/Repos/PowerShell/scripts/check-power.ps1 [<CommonParameters>]
2023-09-01 17:53:03 +02:00
[<CommonParameters>]
This script supports the common parameters: Verbose, Debug, ErrorAction, ErrorVariable, WarningAction,
WarningVariable, OutBuffer, PipelineVariable, and OutVariable.
```
Example
-------
```powershell
PS> ./check-power.ps1
2024-11-08 12:35:11 +01:00
⚠️ Battery 9% only with 54min remaining (power scheme is 'HP Optimized')
2023-09-01 17:53:03 +02:00
```
Notes
-----
Author: Markus Fleschutz | License: CC0
Related Links
-------------
https://github.com/fleschutz/PowerShell
Script Content
--------------
```powershell
<#
.SYNOPSIS
Checks the power status
.DESCRIPTION
This PowerShell script queries the power status and prints it.
.EXAMPLE
PS> ./check-power.ps1
2024-11-08 12:35:11 +01:00
⚠️ Battery 9% only with 54min remaining (power scheme is 'HP Optimized')
2023-09-01 17:53:03 +02:00
.LINK
https://github.com/fleschutz/PowerShell
.NOTES
Author: Markus Fleschutz | License: CC0
#>
try {
if ($IsLinux) {
2023-10-19 08:12:00 +02:00
$reply = "✅ AC powered" # TODO, just guessing :-)
2023-09-01 17:53:03 +02:00
} else {
Add-Type -Assembly System.Windows.Forms
2023-10-19 08:12:00 +02:00
$details = [System.Windows.Forms.SystemInformation]::PowerStatus
[int]$percent = 100 * $details.BatteryLifePercent
[int]$remaining = $details.BatteryLifeRemaining / 60
2024-11-08 12:35:11 +01:00
$powerScheme = (powercfg /getactivescheme)
$powerScheme = $powerScheme -Replace "^(.*) \(",""
$powerScheme = $powerScheme -Replace "\)$",""
2023-10-19 08:12:00 +02:00
if ($details.PowerLineStatus -eq "Online") {
if ($details.BatteryChargeStatus -eq "NoSystemBattery") {
$reply = "✅ AC powered"
} elseif ($percent -ge 95) {
2024-11-08 12:35:11 +01:00
$reply = "✅ Battery nearly full ($percent%, power scheme is '$powerScheme')"
2023-09-01 17:53:03 +02:00
} else {
2024-11-08 12:35:11 +01:00
$reply = "✅ Battery $percent% and charging (power scheme is '$powerScheme')"
2023-09-01 17:53:03 +02:00
}
} else { # must be offline
2023-10-19 08:12:00 +02:00
if (($remaining -eq 0) -and ($percent -ge 60)) {
2024-11-08 12:35:11 +01:00
$reply = "✅ Battery $percent% full (power scheme is '$powerScheme')"
2023-10-19 08:12:00 +02:00
} elseif ($remaining -eq 0) {
2024-11-08 12:35:11 +01:00
$reply = "✅ Battery at $percent% (power scheme is '$powerScheme')"
2023-10-19 08:12:00 +02:00
} elseif ($remaining -le 5) {
2024-11-08 12:35:11 +01:00
$reply = "⚠️ Battery $percent% ONLY $($remaining)min remaining (power scheme is '$powerScheme')"
2023-10-19 08:12:00 +02:00
} elseif ($remaining -le 30) {
2024-11-08 12:35:11 +01:00
$reply = "⚠️ Battery $percent% only $($remaining)min remaining (power scheme is '$powerScheme')"
2023-10-19 08:12:00 +02:00
} elseif ($percent -lt 10) {
2024-11-08 12:35:11 +01:00
$reply = "⚠️ Battery $percent% only with $($remaining)min remaining (power scheme is '$powerScheme') "
} elseif ($percent -ge 90) {
$reply = "✅ Battery $percent% full with $($remaining)min remaining (power scheme is '$powerScheme')"
2023-09-01 17:53:03 +02:00
} else {
2024-11-08 12:35:11 +01:00
$reply = "✅ Battery $percent% with $($remaining)min remaining (power scheme is '$powerScheme') "
2023-09-01 17:53:03 +02:00
}
}
}
2024-08-15 09:51:46 +02:00
Write-Host $reply
2023-09-01 17:53:03 +02:00
exit 0 # success
} catch {
"⚠️ Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"
exit 1
}
```
2024-11-20 11:52:20 +01:00
*(generated by convert-ps2md.ps1 as of 11/20/2024 11:51:51)*