PowerShellForFOD.psm1
# using module .\PowerShellForFOD\Class\PowerShellForFOD.Class1.psm1 # Above needs to remain the first line to import Classes # remove the comment when using classes #requires -Version 2 #Get public and private function definition files. $Public = @( Get-ChildItem -Path $PSScriptRoot\Public\*.ps1 -Recurse -ErrorAction SilentlyContinue ) $Private = @( Get-ChildItem -Path $PSScriptRoot\Private\*.ps1 -Recurse -ErrorAction SilentlyContinue ) #Dot source the files Foreach ($import in @($Public + $Private)) { Try { . $import.fullname } Catch { Write-Error -Message "Failed to import function $($import.fullname): $_" } } #Create / Read config $script:_PS4FODXmlpath = Get-FODConfigPath if(-not (Test-Path -Path $script:_PS4FODXmlpath -ErrorAction SilentlyContinue)) { Try { Write-Warning "Did not find config file $($script:_PS4FODXmlpath), attempting to create" [pscustomobject]@{ ApiUri = $null Token = $null Proxy = $null ForceVerbose = $False } | Export-Clixml -Path $($script:_PS4FODXmlpath) -Force -ErrorAction Stop } Catch { Write-Warning "Failed to create config file $($script:_PS4FODXmlpath): $_" } } #Initialize the config variable. Try { #Import the config $PS4FOD = $null $PS4FOD = Get-FODConfig -Source PS4FOD.xml -ErrorAction Stop } Catch { Write-Warning "Error importing PS4FOD config: $_" } # Create a hashtable for use with the "leaky bucket" rate-limiting algorithm. (Some of FOD's API calls will fail if you request them too quickly.) # https://en.wikipedia.org/wiki/Leaky_bucket $Script:APIRateBuckets = @{} [Net.ServicePointManager]::SecurityProtocol = [Net.ServicePointManager]::SecurityProtocol -bor [Net.SecurityProtocolType]::Tls12 Export-ModuleMember -Function $Public.Basename |