#
#Clean up on New Run or on application Exit
<#
if($MainLoopEvent){
Unregister-Event $MainLoopEvent -Force
Stop-Job $MainLoopEvent
}
if($CrashEvent){
Unregister-Event $CrashEvent -Force
Stop-Job $CrashEvent
}
#>
# Store all the start up variables so you can clean up when the script finishes.
New-Variable -force -name startupVariables -value ( Get-Variable | ForEach-Object { $_.Name } )
Function Clean-Memory
{
Get-Variable |
Where-Object { $startupVariables -notcontains $_.Name } |
ForEach-Object
{
try
{
Remove-Variable -Name "$($_.Name)" -Force -Scope "global" -ErrorAction SilentlyContinue -WarningAction SilentlyContinue
}
catch { }
}
}
### Clean up Memory Script
function ReleaseObj ($ref) {
[System.Runtime.InteropServices.Marshal]::ReleaseComObject([System.__ComObject]$ref) | out-null
[System.GC]::Collect()
[System.GC]::WaitForPendingFinalizers()
}
### Clean up Memory + ShutDown Script
function FinalizeEvent ($ref){
Unregister-Event $ref
ReleaseRef $ref
Stop-Job $ref
}
#
#
#Dummy Data
$SearchPath="$env:USERPROFILE\Desktop"
$SubDir=$false
$MainLoopAction ={
Get-NewSource
Update-DataObj
Update-AppUi
#Send-Notice
}
$CrashNotice ={
Send-Notice
}
$CrashEvent = Set-WatchEvent (Make-Watcher <#CrashFodler#> "*.") -Action $CrashNotice
#
# "*.*" = All, "*." Directory
Function Make-Watcher($searchPath="$env:USERPROFILE\Desktop",$Filter="*.*", $subDir=$false) {
$watcher = New-Object System.IO.FileSystemWatcher
$watcher.Path = $searchPath
$watcher.Filter = $Filter
$watcher.IncludeSubdirectories = $subDir
$watcher.EnableRaisingEvents = $true
return $watcher
}
#
Function Set-WatchEvent($Object=$null,$Event="Created",$Action) {
# Deleted, Renamed, Changed, Created; $changed = Register-ObjectEvent $watcher "Changed" -Action { write-host "Changed: $($eventArgs.FullPath)" }
if($Object -ne $null){
$created = Register-ObjectEvent $Object $Event -Action $Action # Watcher/Event & Action Code Source: https://superuser.com/questions/888442/powershell-folder-monitor-batch-execution
#$action = {Invoke-Item "D:\BATCH FILES\XXXXX.bat" -filter = "XXXXX.pdf"}
#while ($true) {sleep 5} #Only works if external job
return $created
}
}
#Test Functionality
$MainLoopEvent = Set-WatchEvent (Make-Watcher) -Action $MainLoopAction
#
#
# Get system info
# $sys | Get-Member -MemberType Property | ForEach{ "{0} = `t{1}" -f $_.name, $sys.($_.name) }
Function Send-Notice ($title="TestTracker Report",$msg="You have a waiting Action. Please Approve the Action.",$bttn='ok',$icon='Exclamation') {
# Icon Info key Source: MSDN Icon Table: https://msdn.microsoft.com/en-us/library/system.windows.forms.messageboxicon(v=vs.110).aspx
# TODO: Change frame, change icon to custom, change color; background, header, text
#$wshell = New-Object -ComObject Wscript.Shell ##$wshell.Popup("Operation Completed",0,"Done",0x1)
[System.Windows.Forms.MessageBox]::Show($msg,$title,$bttn,$icon)
}
Function Get-NewSource {
Write-Host (`
"`n### `$newSource = Get-Content -Raw -Path `"`$env:USERPROFILE\Desktop\...`"",
"`$newJson = ConvertFrom-Json `$newSource",
"return `$newJson")
}
Function Get-Log {
#Pull Profile
Write-Host "`n### DataObj = NewSourceData"
}
Function Update-DataObj {
Write-Host "`n### DataObj = NewSourceData"
}
Function Update-AppUi {
Write-Host "`n### AppUI = UpdatedDataObj"
}
function Get-SystemInfo ($ComputerName=$env:ComputerName,$header = 'Hostname','OSName','OSVersion','OSManufacturer','OSConfig','Buildtype', 'RegisteredOwner','RegisteredOrganization','ProductID','InstallDate', 'StartTime','Manufacturer','Model','Type','Processor','BIOSVersion', 'WindowsFolder' ,'SystemFolder','StartDevice','Culture', 'UICulture', 'TimeZone','PhysicalMemory', 'AvailablePhysicalMemory' , 'MaxVirtualMemory', 'AvailableVirtualMemory','UsedVirtualMemory','PagingFile','Domain' ,'LogonServer','Hotfix','NetworkAdapter')
{
#param($ComputerName = $env:ComputerName)
$a = systeminfo.exe /FO CSV /S $ComputerName |
Select-Object -Skip 1 |
ConvertFrom-CSV -Header $header
return $a
#Flags:
#/s Computer #Specifies the name or IP address of a remote computer (do not use backslashes). The default is the local computer.
#/u Domain\User #Runs the command with the account permissions of the user specified by User or Domain\User. The default is the permissions of the current logged on user on the computer issuing the command.
#/p Password #Specifies the password of the user account that is specified in the /u parameter.
#/fo {Table|List|CSV} # Specifies the format to use for the output. Valid values are TABLE, LIST, and CSV. The default format for output is LIST.
#/nh #Suppresses column headers in the output. Valid when the /fo parameter is set to TABLE or CSV.
# Code Source https://gallery.technet.microsoft.com/scriptcenter/PowerShell-System-571521d1
}
function Get-Dxdiag {
# Drop output in temp dir
$logFile = $env:TEMP + "\dxDiagLog.xml"
# Piping to Out-Null forces it to wait for dxdiag to complete before continuing. Otherwise
# it tries to load the file before it actuallygets written
dxdiag.exe /whql:off /dontskip /x $logFile | Out-Null
[xml]$dxDiagLog = Get-Content $logFile
#$dxDiagLog.DxDiag.DirectSound.SoundDevices.SoundDevice | ft Description, DriverProvider
# CODE SOURCE: https://stackoverflow.com/questions/37122010/can-i-access-dxdiag-from-powershell-console
return $dxDiagLog
}
function Get-SystemData {
$S = Get-SystemInfo
$D = Get-Dxdiag
$Sys = @{}
#Gather relevant SystemInformation
$Sys.add("Date",Get-Date)
$Sys.add("Computer Name",$env:COMPUTERNAME)
$Sys.add("OS",$S.OSVersion)
$Sys.add("Language",$S.Culture)
$Sys.add("System Manufacturer",$S.Manufacturer)# $S.OSManufacturer
$Sys.add("System Model",$S.Model)
$Sys.add("Bios",$S.BIOSVersion)
$Sys.add("Processor",$D.DxDiag.SystemInformation.Processor)# $S.Processor
$Sys.add("Memory",$D.DxDiag.SystemInformation.AvaliableOSMem)
$Sys.add("Page File",$S.PagingFile)
$Sys.add("DirectX Version",$D.DxDiag.SystemInformation.DirectXVersion)
$Sys.add("Display Res",$D.DxDiag.DisplayDevices.DisplayDevice[1].CurrentMode)
$Sys.add("MonitorName",$D.DxDiag.DisplayDevices.DisplayDevice[1].MonitorName)
$Sys.add("MonitorId",$D.DxDiag.DisplayDevices.DisplayDevice[1].MonitorId)
$Sys.add("NativeMode",$D.DxDiag.DisplayDevices.DisplayDevice[1].NativeMode)
$Sys.add($S)
$Sys.add($D)
return $Sys
}
#
#
Function Set-AutoSession ($Check=$True) {
if(Check){ Write-Host "`n### Auto is ON." }
else{ Write-Host "`n### Auto is Off." }
}
Function StartSession {
Write-Host "`n### Session Started!"
}
Function StopSession {
Write-Host "`n### Session Stopped!"
}
Function Write-Token ($token=$null,$document=$null) {
Write-Host "`n### `$token written to `$(`$document[0]) at line `$(`$document[1])."
}
Function Refresh-Token ($token=$null) {
Write-Host "`n### `$token refreshed."
}
Function Copy-TokenToClipBoard ($token=$null) {
<#
Copy-TokenToClipBoard copies a passed token to the Windows Clipboard.
Syntax; [$token = int,string]
#>
#Not Functional yet.
#Set-Clipboard -Value $token
Write-Host "`n### `$token copied to clipboard."
}
Function Set-DirectoryPath ($dir="") {
Write-Host "`n### Path set to `$dir"
}
Function Set-Preferences ($AppPreferences) {
Write-Host "`n### Preference saved!"
$AppPreferences | Out-file $outFile
}
#
No comments:
Post a Comment
Conduct: Be nice and don't advertise or plug without adding value to the conversation.