mirror of
https://github.com/aclindsa/ofxgo.git
synced 2024-11-14 09:10:05 -05:00
Aaron Lindsay
1d8ba5c19a
This allows encoding/xml to properly comparison against nil to see if they should be marshalled if the 'xml' tag contains ",omitempty" and for users to test against nil to see if a field was present in the parsed OFX. This commit also fixes up cmd/ofx to use the new pointers.
86 lines
3.4 KiB
Go
86 lines
3.4 KiB
Go
package ofxgo
|
|
|
|
import (
|
|
"errors"
|
|
"github.com/aclindsa/go/src/encoding/xml"
|
|
)
|
|
|
|
type CCStatementRequest struct {
|
|
XMLName xml.Name `xml:"CCSTMTTRNRQ"`
|
|
TrnUID UID `xml:"TRNUID"`
|
|
CCAcctFrom CCAcct `xml:"CCSTMTRQ>CCACCTFROM"`
|
|
DtStart *Date `xml:"CCSTMTRQ>INCTRAN>DTSTART,omitempty"`
|
|
DtEnd *Date `xml:"CCSTMTRQ>INCTRAN>DTEND,omitempty"`
|
|
Include Boolean `xml:"CCSTMTRQ>INCTRAN>INCLUDE"` // Include transactions (instead of just balance)
|
|
IncludePending Boolean `xml:"CCSTMTRQ>INCLUDEPENDING,omitempty"` // Include pending transactions
|
|
IncTranImg Boolean `xml:"CCSTMTRQ>INCTRANIMG,omitempty"` // Include transaction images
|
|
}
|
|
|
|
func (r *CCStatementRequest) Name() string {
|
|
return "CCSTMTTRNRQ"
|
|
}
|
|
|
|
func (r *CCStatementRequest) Valid() (bool, error) {
|
|
if ok, err := r.TrnUID.Valid(); !ok {
|
|
return false, err
|
|
}
|
|
return true, nil
|
|
}
|
|
|
|
type CCStatementResponse struct {
|
|
XMLName xml.Name `xml:"CCSTMTTRNRS"`
|
|
TrnUID UID `xml:"TRNUID"`
|
|
CurDef String `xml:"CCSTMTRS>CURDEF"`
|
|
CCAcctFrom CCAcct `xml:"CCSTMTRS>CCACCTFROM"`
|
|
BankTranList *TransactionList `xml:"CCSTMTRS>BANKTRANLIST,omitempty"`
|
|
//BANKTRANLISTP
|
|
BalAmt Amount `xml:"CCSTMTRS>LEDGERBAL>BALAMT"`
|
|
DtAsOf Date `xml:"CCSTMTRS>LEDGERBAL>DTASOF"`
|
|
AvailBalAmt Amount `xml:"CCSTMTRS>AVAILBAL>BALAMT,omitempty"`
|
|
AvailDtAsOf *Date `xml:"CCSTMTRS>AVAILBAL>DTASOF,omitempty"`
|
|
CashAdvBalAmt Amount `xml:"CCSTMTRS>CASHADVBALAMT,omitempty"` // Only for CREDITLINE accounts, available balance for cash advances
|
|
IntRatePurch Amount `xml:"CCSTMTRS>INTRATEPURCH,omitempty"` // Current interest rate for purchases
|
|
IntRateCash Amount `xml:"CCSTMTRS>INTRATECASH,omitempty"` // Current interest rate for cash advances
|
|
IntRateXfer Amount `xml:"CCSTMTRS>INTRATEXFER,omitempty"` // Current interest rate for cash advances
|
|
RewardName String `xml:"CCSTMTRS>REWARDINFO>NAME,omitempty"` // Name of the reward program referred to by the next two elements
|
|
RewardBal Amount `xml:"CCSTMTRS>REWARDINFO>REWARDBAL,omitempty"` // Current balance of the reward program
|
|
RewardEarned Amount `xml:"CCSTMTRS>REWARDINFO>REWARDEARNED,omitempty"` // Reward amount earned YTD
|
|
BalList []Balance `xml:"CCSTMTRS>BALLIST>BAL,omitempty"`
|
|
MktgInfo String `xml:"CCSTMTRS>MKTGINFO,omitempty"` // Marketing information
|
|
}
|
|
|
|
func (sr CCStatementResponse) Name() string {
|
|
return "CCSTMTTRNRS"
|
|
}
|
|
|
|
func (sr CCStatementResponse) Valid() (bool, error) {
|
|
//TODO implement
|
|
return true, nil
|
|
}
|
|
|
|
func decodeCCMessageSet(d *xml.Decoder, start xml.StartElement) ([]Message, error) {
|
|
var msgs []Message
|
|
for {
|
|
tok, err := nextNonWhitespaceToken(d)
|
|
if err != nil {
|
|
return nil, err
|
|
} else if end, ok := tok.(xml.EndElement); ok && end.Name.Local == start.Name.Local {
|
|
// If we found the end of our starting element, we're done parsing
|
|
return msgs, nil
|
|
} else if startElement, ok := tok.(xml.StartElement); ok {
|
|
switch startElement.Name.Local {
|
|
case "CCSTMTTRNRS":
|
|
var info CCStatementResponse
|
|
if err := d.DecodeElement(&info, &startElement); err != nil {
|
|
return nil, err
|
|
}
|
|
msgs = append(msgs, Message(info))
|
|
default:
|
|
return nil, errors.New("Unsupported banking response tag: " + startElement.Name.Local)
|
|
}
|
|
} else {
|
|
return nil, errors.New("Didn't find an opening element")
|
|
}
|
|
}
|
|
}
|