Get-IbTrade.psm1

<#
 .Synopsis
  Displays flex query results from Interactive Brokers.
 
 .Description
  Displays flex query V3 results from Interactive Brokers.
 
 .Parameter Query
  Flex query ID of Interactive Brokers.
 
 .Parameter Token
  Your flex web service token in Interactive Brokers.
 
 .Example
   # Display flex query result, token is store in $Env:ibtoken.
   Get-IbTrade -Query <Flex Query ID>
 
 .Example
   # Display flex query result, specific token parameter.
   Get-IbTrade -Query <Flex Query ID> -Token <Token>
 
 .LINK
   Online version: https://www.interactivebrokers.com/en/software/am/am/reports/flex_web_service_version_3.htm
#>




function Get-IbTrade {
[CmdletBinding( )]
param(
    $Query,
    [Parameter(Mandatory)]$Token = $env:ibtoken
    )

## Determine the first day of the start and end months.
$ib_token = $token
$ib_version = 3
$init_url = "https://gdcdyn.interactivebrokers.com/Universal/servlet/FlexStatementService.SendRequest"
$getdata_url = "https://gdcdyn.interactivebrokers.com/Universal/servlet/FlexStatementService.GetStatement"

#Authenticate to server
$Body = @{
    t = $ib_token
    q = $query
    v = $ib_version
}
$response = Invoke-WebRequest $init_url -Body $Body -Method 'POST'
[xml]$ib_ref = $response.Content

# Display IB Response Code
# $ib_ref.FlexStatementResponse.ReferenceCode

#Retrieve statement data
$Body = @{
    q = $ib_ref.FlexStatementResponse.ReferenceCode
    t = $ib_token
    v = $ib_version
}
$response = Invoke-WebRequest $getdata_url -Body $Body -Method 'POST'
[xml]$xml = $response.Content


#TCF
if ($xml.FlexQueryResponse.type -eq "TCF"){
$result = $xml.FlexQueryResponse.FlexStatements.FlexStatement.TradeConfirms.TradeConfirm
}



#AF
if ($xml.FlexQueryResponse.type -eq "AF"){
$result = $xml.FlexQueryResponse.FlexStatements.FlexStatement.ChangeInDividendAccruals.ChangeInDividendAccrual
}


#Print result
return $result

}
Export-ModuleMember -Function Get-IbTrade