Addded Monitor to monitor a pc's status like online and login status.
This commit is contained in:
parent
e60cd96bc6
commit
2b0c9ed93c
|
|
@ -52,9 +52,11 @@ function Get-PCBatchInvoke {
|
|||
|
||||
#Adapter
|
||||
$adapter = ($win32_networkadapterconfiguration | Where-Object {$_.IpEnabled -Match "True"} | Select-Object -Expand Description)
|
||||
<#
|
||||
if($adapter -is [array]){
|
||||
$adapter = $adapter[0]
|
||||
}
|
||||
#>
|
||||
|
||||
#UserName
|
||||
$Username = $PCInfo.CSUserName
|
||||
|
|
|
|||
|
|
@ -1,15 +1,38 @@
|
|||
function Invoke-Monitor {
|
||||
function Invoke-PCMonitor {
|
||||
param(
|
||||
[string[]] $comps
|
||||
)
|
||||
# Ask to notify
|
||||
$notify = $(Read-Host "Notify with pop-up window? (y/N)") -match "^[yY]"
|
||||
if ($notify) {
|
||||
Add-Type -AssemblyName PresentationFramework
|
||||
}
|
||||
$sleepTime = $(Read-Host "Checkin interval in seconds (Default: 300 [5 min])")
|
||||
if (-not ($sleepTime)) { $sleepTime = 300 }
|
||||
$dogs = @()
|
||||
# Initialize computer sessions
|
||||
|
||||
foreach ($comp in $comps) {
|
||||
$dog = [WatchDog]::new($comp)
|
||||
$null = $dog.Update()
|
||||
$dogs += $dog
|
||||
}
|
||||
while ($true) {
|
||||
foreach ($dog in $dogs) {
|
||||
$msg = $dog.ReportChange()
|
||||
if ($msg) {
|
||||
if ($notify) {
|
||||
$null = [System.Windows.MessageBox]::Show($msg)
|
||||
}
|
||||
Write-Host "$msg"
|
||||
}
|
||||
}
|
||||
Start-Sleep $sleepTime
|
||||
}
|
||||
}
|
||||
|
||||
class WatchDog {
|
||||
[string]$Hostname
|
||||
[PSSession]$Session
|
||||
[System.Management.Automation.Runspaces.PSSession]$Session
|
||||
[string]$LastUser
|
||||
WatchDog() { $this.Init(@{})}
|
||||
WatchDog([hashtable]$Properties) { $this.Init($Properties)}
|
||||
|
|
@ -19,12 +42,25 @@ class WatchDog {
|
|||
$this.$prop = $Properties.$prop
|
||||
}
|
||||
}
|
||||
[string] ToString() {
|
||||
return `
|
||||
"Hostname: $($this.Hostname) `n" +
|
||||
"Status: $(if ($this.Session) { 'Online' } else { 'Offline' }) `n" +
|
||||
"User: $($this.LastUser) `n"
|
||||
}
|
||||
[WatchDog] Copy() {
|
||||
$props = @{}
|
||||
foreach ($prop in $this.PSObject.Properties) {
|
||||
$props.$($prop.Name) = $prop.Value
|
||||
}
|
||||
return [WatchDog]$props
|
||||
}
|
||||
# Returns true if a value was updated
|
||||
[bool] Update() {
|
||||
$old = $this
|
||||
if ((Test-Connection -ComputerName $this.Hostnmae -Count 1)) {
|
||||
$old = $this.Copy()
|
||||
if (-not (Test-Connection -ComputerName $this.Hostname -Count 1)) {
|
||||
$this.Session = $null
|
||||
return -not ($old.Session)
|
||||
return ($old.Session)
|
||||
}
|
||||
if (-not ($this.Session)) {
|
||||
$this.Session = New-PSSession -ComputerName $this.Hostname -SessionOption (New-PSSessionOption -NoMachineProfile)
|
||||
|
|
@ -43,4 +79,28 @@ class WatchDog {
|
|||
}
|
||||
return (($this.Session -ne $old.Session) -or ($this.LastUser -ne $old.LastUser))
|
||||
}
|
||||
}
|
||||
# Returns a message describing any changes
|
||||
[string] ReportChange() {
|
||||
$old = $this.Copy()
|
||||
if (-not ($this.Update())) { return $null }
|
||||
$date = Get-Date -Format "[MM/dd/yy HH:MM:ss]"
|
||||
if ($old.Session -ne $this.Session) {
|
||||
if ($old.Session -and $this.Session) {
|
||||
return "$date $($this.Hostname) | Session re-established"
|
||||
} elseif ($this.Session) {
|
||||
return "$date $($this.Hostname) | Online"
|
||||
} else {
|
||||
return "$date $($this.Hostname) | Offline"
|
||||
}
|
||||
} elseif ($old.LastUser -ne $this.LastUser) {
|
||||
if ($old.LastUser -and $this.LastUser) {
|
||||
return "$date $($this.Hostname) | $($old.LastUser) logged off and $($this.LastUser) logged on"
|
||||
} elseif ($old.LastUser) {
|
||||
return "$date $($this.Hostname) | $($old.LastUser) logged off"
|
||||
} else {
|
||||
return "$date $($this.Hostname) | $($this.LastUser) logged on"
|
||||
}
|
||||
}
|
||||
return $null
|
||||
}
|
||||
}
|
||||
|
|
@ -112,7 +112,6 @@
|
|||
$SourceRoot = "\\$Computer\c$\Users\$User"
|
||||
$BackupDestination = "\\SHSCMGSRMC\ProfileBackup"
|
||||
$Destination = "\\SHSCMGSRMC\ProfileBackup\$DestinationFileName"
|
||||
$CopiedUserDesktop = Join-Path -Path $Destination -ChildPath "Desktop"
|
||||
|
||||
#region BACKUP
|
||||
if($ConfirmUser -eq 'y'){
|
||||
|
|
@ -155,6 +154,7 @@
|
|||
Write-Warning "Invalid input please restart script"
|
||||
return
|
||||
}
|
||||
|
||||
#Creates a log file
|
||||
New-Item -Path $Destination\backuplog.txt -Force | Write-Verbose
|
||||
$log = Join-Path -Path $Destination -ChildPath backuplog.txt
|
||||
|
|
@ -171,6 +171,7 @@
|
|||
#Cleans up Citrix Shortcuts
|
||||
|
||||
Write-Host "Removing Citrix Shortcuts from backup"
|
||||
$CopiedUserDesktop = Join-Path -Path $Destination -ChildPath "Desktop"
|
||||
$Shortcuts = Get-ChildItem -Path $CopiedUserDesktop -Filter *.lnk
|
||||
|
||||
foreach($Shortcut in $Shortcuts){
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@
|
|||
|
||||
#region Module Import Block
|
||||
|
||||
$ErrorActionPreference = 'SilentlyContinue'
|
||||
#$ErrorActionPreference = 'SilentlyContinue'
|
||||
#DevStage can take either Dev or Prod as values
|
||||
$devStage = 'Dev'
|
||||
#Locations for dev build and prod build
|
||||
|
|
@ -544,6 +544,7 @@ Function Get-PC {
|
|||
if ($adTest) {
|
||||
Write-Warning "$comp is either disabled or off the domain"
|
||||
}
|
||||
Write-Progress -Activity "Looking up computer in AD" -Completed
|
||||
}
|
||||
|
||||
#Direct SCCM Queries
|
||||
|
|
|
|||
Loading…
Reference in a new issue