189 lines
8.1 KiB
Go
189 lines
8.1 KiB
Go
package ofx
|
|
|
|
import (
|
|
"encoding/xml"
|
|
|
|
"github.com/mayswind/ezbookkeeping/pkg/models"
|
|
)
|
|
|
|
// oFXDeclarationVersion represents the declaration version of open financial exchange (ofx) file
|
|
type oFXDeclarationVersion string
|
|
|
|
const (
|
|
ofxVersion1 oFXDeclarationVersion = "100"
|
|
ofxVersion2 oFXDeclarationVersion = "200"
|
|
)
|
|
|
|
const ofxDefaultTimezoneOffset = "+00:00"
|
|
|
|
// ofxAccountType represents account type in open financial exchange (ofx) file
|
|
type ofxAccountType string
|
|
|
|
// OFX account types
|
|
const (
|
|
ofxCheckingAccount ofxAccountType = "CHECKING"
|
|
ofxSavingsAccount ofxAccountType = "SAVINGS"
|
|
ofxMoneyMarketAccount ofxAccountType = "MONEYMRKT"
|
|
ofxLineOfCreditAccount ofxAccountType = "CREDITLINE"
|
|
ofxCertificateOfDepositAccount ofxAccountType = "CD"
|
|
)
|
|
|
|
// ofxTransactionType represents transaction type in open financial exchange (ofx) file
|
|
type ofxTransactionType string
|
|
|
|
// OFX transaction types
|
|
const (
|
|
ofxGenericCreditTransaction ofxTransactionType = "CREDIT"
|
|
ofxGenericDebitTransaction ofxTransactionType = "DEBIT"
|
|
ofxInterestTransaction ofxTransactionType = "INT"
|
|
ofxDividendTransaction ofxTransactionType = "DIV"
|
|
ofxFIFeeTransaction ofxTransactionType = "FEE"
|
|
ofxServiceChargeTransaction ofxTransactionType = "SRVCHG"
|
|
ofxDepositTransaction ofxTransactionType = "DEP"
|
|
ofxATMTransaction ofxTransactionType = "ATM"
|
|
ofxPOSTransaction ofxTransactionType = "POS"
|
|
ofxTransferTransaction ofxTransactionType = "XFER"
|
|
ofxCheckTransaction ofxTransactionType = "CHECK"
|
|
ofxElectronicPaymentTransaction ofxTransactionType = "PAYMENT"
|
|
ofxCashWithdrawalTransaction ofxTransactionType = "CASH"
|
|
ofxDirectDepositTransaction ofxTransactionType = "DIRECTDEP"
|
|
ofxMerchantInitiatedDebitTransaction ofxTransactionType = "DIRECTDEBIT"
|
|
ofxRepeatingPaymentTransaction ofxTransactionType = "REPEATPMT"
|
|
ofxHoldTransaction ofxTransactionType = "HOLD"
|
|
ofxOtherTransaction ofxTransactionType = "OTHER"
|
|
)
|
|
|
|
var ofxTransactionTypeMapping = map[ofxTransactionType]models.TransactionType{
|
|
ofxGenericCreditTransaction: models.TRANSACTION_TYPE_EXPENSE,
|
|
ofxGenericDebitTransaction: models.TRANSACTION_TYPE_EXPENSE,
|
|
ofxDividendTransaction: models.TRANSACTION_TYPE_INCOME,
|
|
ofxFIFeeTransaction: models.TRANSACTION_TYPE_EXPENSE,
|
|
ofxServiceChargeTransaction: models.TRANSACTION_TYPE_EXPENSE,
|
|
ofxDepositTransaction: models.TRANSACTION_TYPE_INCOME,
|
|
ofxTransferTransaction: models.TRANSACTION_TYPE_TRANSFER,
|
|
ofxCheckTransaction: models.TRANSACTION_TYPE_EXPENSE,
|
|
ofxElectronicPaymentTransaction: models.TRANSACTION_TYPE_EXPENSE,
|
|
ofxCashWithdrawalTransaction: models.TRANSACTION_TYPE_EXPENSE,
|
|
ofxDirectDepositTransaction: models.TRANSACTION_TYPE_INCOME,
|
|
ofxMerchantInitiatedDebitTransaction: models.TRANSACTION_TYPE_EXPENSE,
|
|
ofxRepeatingPaymentTransaction: models.TRANSACTION_TYPE_EXPENSE,
|
|
}
|
|
|
|
// ofxFile represents the struct of open financial exchange (ofx) file
|
|
type ofxFile struct {
|
|
XMLName xml.Name `xml:"OFX"`
|
|
FileHeader *ofxFileHeader
|
|
BankMessageResponseV1 *ofxBankMessageResponseV1 `xml:"BANKMSGSRSV1"`
|
|
CreditCardMessageResponseV1 *ofxCreditCardMessageResponseV1 `xml:"CREDITCARDMSGSRSV1"`
|
|
}
|
|
|
|
// ofxFileHeader represents the struct of open financial exchange (ofx) file header
|
|
type ofxFileHeader struct {
|
|
OFXDeclarationVersion oFXDeclarationVersion
|
|
OFXDataVersion string
|
|
Security string
|
|
OldFileUid string
|
|
NewFileUid string
|
|
}
|
|
|
|
// ofxBankMessageResponseV1 represents the struct of open financial exchange (ofx) bank message response v1
|
|
type ofxBankMessageResponseV1 struct {
|
|
StatementTransactionResponse *ofxBankStatementTransactionResponse `xml:"STMTTRNRS"`
|
|
}
|
|
|
|
// ofxCreditCardMessageResponseV1 represents the struct of open financial exchange (ofx) credit card message response v1
|
|
type ofxCreditCardMessageResponseV1 struct {
|
|
StatementTransactionResponse *ofxCreditCardStatementTransactionResponse `xml:"CCSTMTTRNRS"`
|
|
}
|
|
|
|
// ofxBankStatementTransactionResponse represents the struct of open financial exchange (ofx) bank statement transaction response
|
|
type ofxBankStatementTransactionResponse struct {
|
|
StatementResponse *ofxBankStatementResponse `xml:"STMTRS"`
|
|
}
|
|
|
|
// ofxCreditCardStatementTransactionResponse represents the struct of open financial exchange (ofx) credit card statement transaction response
|
|
type ofxCreditCardStatementTransactionResponse struct {
|
|
StatementResponse *ofxCreditCardStatementResponse `xml:"CCSTMTRS"`
|
|
}
|
|
|
|
// ofxBankStatementResponse represents the struct of open financial exchange (ofx) bank statement response
|
|
type ofxBankStatementResponse struct {
|
|
DefaultCurrency string `xml:"CURDEF"`
|
|
AccountFrom *ofxBankAccount `xml:"BANKACCTFROM"`
|
|
TransactionList *ofxBankTransactionList `xml:"BANKTRANLIST"`
|
|
}
|
|
|
|
// ofxCreditCardStatementResponse represents the struct of open financial exchange (ofx) credit card statement response
|
|
type ofxCreditCardStatementResponse struct {
|
|
DefaultCurrency string `xml:"CURDEF"`
|
|
AccountFrom *ofxCreditCardAccount `xml:"CCACCTFROM"`
|
|
TransactionList *ofxCreditCardTransactionList `xml:"BANKTRANLIST"`
|
|
}
|
|
|
|
// ofxBankAccount represents the struct of open financial exchange (ofx) bank account
|
|
type ofxBankAccount struct {
|
|
BankId string `xml:"BANKID"`
|
|
BranchId string `xml:"BRANCHID"`
|
|
AccountId string `xml:"ACCTID"`
|
|
AccountType ofxAccountType `xml:"ACCTTYPE"`
|
|
AccountKey string `xml:"ACCTKEY"`
|
|
}
|
|
|
|
// ofxCreditCardAccount represents the struct of open financial exchange (ofx) credit card account
|
|
type ofxCreditCardAccount struct {
|
|
AccountId string `xml:"ACCTID"`
|
|
AccountKey string `xml:"ACCTKEY"`
|
|
}
|
|
|
|
// ofxBankTransactionList represents the struct of open financial exchange (ofx) bank transaction list
|
|
type ofxBankTransactionList struct {
|
|
StartDate string `xml:"DTSTART"`
|
|
EndDate string `xml:"DTEND"`
|
|
StatementTransactions []*ofxBankStatementTransaction `xml:"STMTTRN"`
|
|
}
|
|
|
|
// ofxCreditCardTransactionList represents the struct of open financial exchange (ofx) credit card transaction list
|
|
type ofxCreditCardTransactionList struct {
|
|
StartDate string `xml:"DTSTART"`
|
|
EndDate string `xml:"DTEND"`
|
|
StatementTransactions []*ofxCreditCardStatementTransaction `xml:"STMTTRN"`
|
|
}
|
|
|
|
// ofxBaseStatementTransaction represents the struct of open financial exchange (ofx) base statement transaction
|
|
type ofxBaseStatementTransaction struct {
|
|
TransactionId string `xml:"FITID"`
|
|
TransactionType ofxTransactionType `xml:"TRNTYPE"`
|
|
PostedDate string `xml:"DTPOSTED"`
|
|
Amount string `xml:"TRNAMT"`
|
|
Name string `xml:"NAME"`
|
|
Payee *ofxPayee `xml:"PAYEE"`
|
|
Memo string `xml:"MEMO"`
|
|
Currency string `xml:"CURRENCY"`
|
|
OriginalCurrency string `xml:"ORIGCURRENCY"`
|
|
}
|
|
|
|
// ofxBankStatementTransaction represents the struct of open financial exchange (ofx) bank statement transaction
|
|
type ofxBankStatementTransaction struct {
|
|
ofxBaseStatementTransaction
|
|
AccountTo *ofxBankAccount `xml:"BANKACCTTO"`
|
|
}
|
|
|
|
// ofxCreditCardStatementTransaction represents the struct of open financial exchange (ofx) credit card statement transaction
|
|
type ofxCreditCardStatementTransaction struct {
|
|
ofxBaseStatementTransaction
|
|
AccountTo *ofxCreditCardAccount `xml:"CCACCTTO"`
|
|
}
|
|
|
|
// ofxPayee represents the struct of open financial exchange (ofx) payee info
|
|
type ofxPayee struct {
|
|
Name string `xml:"NAME"`
|
|
Address1 string `xml:"ADDR1"`
|
|
Address2 string `xml:"ADDR2"`
|
|
Address3 string `xml:"ADDR3"`
|
|
City string `xml:"CITY"`
|
|
State string `xml:"STATE"`
|
|
PostalCode string `xml:"POSTALCODE"`
|
|
Country string `xml:"COUNTRY"`
|
|
Phone string `xml:"PHONE"`
|
|
}
|