PoshSNMP.psm1
if ($psEdition -ne 'Core') { $dotNetTarget = 'net452' } else { $dotNetTarget = 'netstandard1.3' } $AssembliesToLoad = @() foreach ($dotNetTargetItem in $dotNetTarget) { $AssembliesToLoad += Get-ChildItem -Path "$PSScriptRoot\lib\$dotNetTargetItem" -Filter "*.dll" -ErrorAction SilentlyContinue | Select-Object -ExpandProperty FullName } if ($AssembliesToLoad) { #If we are in a build or a pester test, load assemblies from a temporary file so they don't lock the original file #This helps to prevent cleaning problems due to a powershell session locking the file because unloading a module doesn't unload assemblies if ($BuildTask -or $TestDrive -or $env:BUILD_BUILDID) { write-verbose "Detected Invoke-Build or Pester, loading assemblies from a temp location to avoid locking issues" $TempAssembliesToLoad = @() foreach ($AssemblyPathItem in $AssembliesToLoad) { $TempAssemblyPath = [System.IO.Path]::GetTempFileName() + ".dll" Copy-Item $AssemblyPathItem $TempAssemblyPath $TempAssembliesToLoad += [System.IO.FileInfo]$TempAssemblyPath } $AssembliesToLoad = $TempAssembliesToLoad } #Load the specified assemblies if not loaded already #Checks based on full path of assemblies, doesn't check for version or assembly target. $AssembliesToLoad | Foreach-Object { if ($_ -notin ([System.AppDomain]::CurrentDomain.GetAssemblies() | Where-Object Location | Select-Object -ExpandProperty Location)) { [Reflection.Assembly]::LoadFile($_) } } } #Dot source the files Foreach($FolderItem in 'Private','Public') { $ImportItemList = Get-ChildItem -Path $PSScriptRoot\$FolderItem\*.ps1 -ErrorAction SilentlyContinue Foreach($ImportItem in $ImportItemList) { Try { . $ImportItem } Catch { throw "Failed to import function $($importItem.fullname): $_" } } if ($FolderItem -eq 'Public') { Export-ModuleMember -Function ($ImportItemList.basename | Where-Object {$PSitem -match '^\w+-\w+$'}) } } #Import Settings files as global objects based on their filename foreach ($ModuleSettingsItem in $ModuleSettings) { New-Variable -Name "$($ModuleSettingsItem.basename)" -Scope Global -Value (convertfrom-json (Get-Content -raw $ModuleSettingsItem.fullname)) -Force } #Export the public functions. This requires them to match the standard Noun-Verb powershell cmdlet format as a safety mechanism |