| LibOFX | 
Main header file containing the LibOfx API. More...
Go to the source code of this file.
| Data Structures | |
| struct | LibofxFileFormatInfo | 
| struct | OfxStatusData | 
| An abstraction of an OFX STATUS element.  More... | |
| struct | OfxAccountData | 
| An abstraction of an account.  More... | |
| struct | OfxSecurityData | 
| An abstraction of a security, such as a stock, mutual fund, etc.  More... | |
| struct | OfxTransactionData | 
| An abstraction of a transaction in an account.  More... | |
| struct | OfxStatementData | 
| An abstraction of an account statement.  More... | |
| struct | OfxCurrency | 
| NOT YET SUPPORTED.  More... | |
| struct | OfxFiServiceInfo | 
| Information returned by the OFX Partner Server about a financial institution.  More... | |
| struct | OfxFiLogin | 
| Information sufficient to log into an financial institution.  More... | |
| struct | OfxPayment | 
| struct | OfxPayee | 
| Defines | |
| #define | LIBOFX_MAJOR_VERSION 0 | 
| #define | LIBOFX_MINOR_VERSION 9 | 
| #define | LIBOFX_MICRO_VERSION 8 | 
| #define | LIBOFX_BUILD_VERSION 0 | 
| #define | LIBOFX_VERSION_RELEASE_STRING "0.9.8" | 
| #define | true 1 | 
| #define | false 0 | 
| #define | OFX_ELEMENT_NAME_LENGTH 100 | 
| #define | OFX_SVRTID2_LENGTH (36 + 1) | 
| #define | OFX_CHECK_NUMBER_LENGTH (12 + 1) | 
| #define | OFX_REFERENCE_NUMBER_LENGTH (32 + 1) | 
| #define | OFX_FITID_LENGTH (255 + 1) | 
| #define | OFX_TOKEN2_LENGTH (36 + 1) | 
| #define | OFX_MEMO_LENGTH (255 + 1) | 
| #define | OFX_FIID_LENGTH (32 + 1) | 
| #define | OFX_MEMO2_LENGTH (390 + 1) | 
| #define | OFX_BALANCE_NAME_LENGTH (32 + 1) | 
| #define | OFX_BALANCE_DESCRIPTION_LENGTH (80 + 1) | 
| #define | OFX_CURRENCY_LENGTH (3 + 1) | 
| #define | OFX_BANKID_LENGTH (9 + 1) | 
| #define | OFX_BRANCHID_LENGTH (22 + 1) | 
| #define | OFX_ACCTID_LENGTH (22 + 1) | 
| #define | OFX_ACCTKEY_LENGTH (22 + 1) | 
| #define | OFX_BROKERID_LENGTH (22 + 1) | 
| #define | OFX_ACCOUNT_ID_LENGTH (OFX_BANKID_LENGTH + OFX_BRANCHID_LENGTH + OFX_ACCTID_LENGTH + 1) | 
| #define | OFX_ACCOUNT_NAME_LENGTH 255 | 
| #define | OFX_MARKETING_INFO_LENGTH (360 + 1) | 
| #define | OFX_TRANSACTION_NAME_LENGTH (96 + 1) | 
| #define | OFX_UNIQUE_ID_LENGTH (32 + 1) | 
| #define | OFX_UNIQUE_ID_TYPE_LENGTH (10 + 1) | 
| #define | OFX_SECNAME_LENGTH (32 + 1) | 
| #define | OFX_TICKER_LENGTH (32 + 1) | 
| #define | OFX_ORG_LENGTH (32 + 1) | 
| #define | OFX_FID_LENGTH (32 + 1) | 
| #define | OFX_USERID_LENGTH (32 + 1) | 
| #define | OFX_USERPASS_LENGTH (32 + 1) | 
| #define | OFX_URL_LENGTH (500 + 1) | 
| #define | OFX_APPID_LENGTH (32) | 
| #define | OFX_APPVER_LENGTH (32) | 
| #define | OFX_HEADERVERSION_LENGTH (32) | 
| Typedefs | |
| typedef void * | LibofxContextPtr | 
| typedef int(* | LibofxProcStatusCallback )(const struct OfxStatusData data, void *status_data) | 
| The callback function for the OfxStatusData stucture. | |
| typedef int(* | LibofxProcAccountCallback )(const struct OfxAccountData data, void *account_data) | 
| The callback function for the OfxAccountData stucture. | |
| typedef int(* | LibofxProcSecurityCallback )(const struct OfxSecurityData data, void *security_data) | 
| The callback function for the OfxSecurityData stucture. | |
| typedef int(* | LibofxProcTransactionCallback )(const struct OfxTransactionData data, void *transaction_data) | 
| The callback function for the OfxTransactionData stucture. | |
| typedef int(* | LibofxProcStatementCallback )(const struct OfxStatementData data, void *statement_data) | 
| The callback function for the OfxStatementData stucture. | |
| Enumerations | |
| enum | LibofxFileFormat { AUTODETECT, OFX, OFC, QIF, UNKNOWN, LAST, AUTODETECT, OFX, OFC, QIF, UNKNOWN, LAST } | 
| enum | TransactionType { OFX_CREDIT, OFX_DEBIT, OFX_INT, OFX_DIV, OFX_FEE, OFX_SRVCHG, OFX_DEP, OFX_ATM, OFX_POS, OFX_XFER, OFX_CHECK, OFX_PAYMENT, OFX_CASH, OFX_DIRECTDEP, OFX_DIRECTDEBIT, OFX_REPEATPMT, OFX_OTHER, OFX_CREDIT, OFX_DEBIT, OFX_INT, OFX_DIV, OFX_FEE, OFX_SRVCHG, OFX_DEP, OFX_ATM, OFX_POS, OFX_XFER, OFX_CHECK, OFX_PAYMENT, OFX_CASH, OFX_DIRECTDEP, OFX_DIRECTDEBIT, OFX_REPEATPMT, OFX_OTHER } | 
| enum | InvTransactionType { OFX_BUYDEBT, OFX_BUYMF, OFX_BUYOPT, OFX_BUYOTHER, OFX_BUYSTOCK, OFX_CLOSUREOPT, OFX_INCOME, OFX_INVEXPENSE, OFX_JRNLFUND, OFX_JRNLSEC, OFX_MARGININTEREST, OFX_REINVEST, OFX_RETOFCAP, OFX_SELLDEBT, OFX_SELLMF, OFX_SELLOPT, OFX_SELLOTHER, OFX_SELLSTOCK, OFX_SPLIT, OFX_TRANSFER, OFX_BUYDEBT, OFX_BUYMF, OFX_BUYOPT, OFX_BUYOTHER, OFX_BUYSTOCK, OFX_CLOSUREOPT, OFX_INCOME, OFX_INVEXPENSE, OFX_JRNLFUND, OFX_JRNLSEC, OFX_MARGININTEREST, OFX_REINVEST, OFX_RETOFCAP, OFX_SELLDEBT, OFX_SELLMF, OFX_SELLOPT, OFX_SELLOTHER, OFX_SELLSTOCK, OFX_SPLIT, OFX_TRANSFER } | 
| enum | FiIdCorrectionAction { DELETE, REPLACE, DELETE, REPLACE } | 
| Functions | |
| LibofxContextPtr | libofx_get_new_context () | 
| Initialise the library and return a new context. | |
| int | libofx_free_context (LibofxContextPtr) | 
| Free all ressources used by this context. | |
| void | libofx_set_dtd_dir (LibofxContextPtr libofx_context, const char *s) | 
| enum LibofxFileFormat | libofx_get_file_format_from_str (const struct LibofxFileFormatInfo format_list[], const char *file_type_string) | 
| libofx_get_file_type returns a proper enum from a file type string. | |
| const char * | libofx_get_file_format_description (const struct LibofxFileFormatInfo format_list[], enum LibofxFileFormat file_format) | 
| get_file_format_description returns a string description of a LibofxFileType. | |
| int | libofx_proc_file (LibofxContextPtr libofx_context, const char *p_filename, enum LibofxFileFormat ftype) | 
| libofx_proc_file is the entry point of the library. | |
| void | ofx_set_status_cb (LibofxContextPtr ctx, LibofxProcStatusCallback cb, void *user_data) | 
| void | ofx_set_account_cb (LibofxContextPtr ctx, LibofxProcAccountCallback cb, void *user_data) | 
| void | ofx_set_security_cb (LibofxContextPtr ctx, LibofxProcSecurityCallback cb, void *user_data) | 
| void | ofx_set_transaction_cb (LibofxContextPtr ctx, LibofxProcTransactionCallback cb, void *user_data) | 
| void | ofx_set_statement_cb (LibofxContextPtr ctx, LibofxProcStatementCallback cb, void *user_data) | 
| int | libofx_proc_buffer (LibofxContextPtr ctx, const char *s, unsigned int size) | 
| Variables | |
| struct LibofxFileFormatInfo | LibofxImportFormatList [] | 
| struct LibofxFileFormatInfo | LibofxExportFormatList [] | 
| int | ofx_PARSER_msg | 
| int | ofx_DEBUG_msg | 
| int | ofx_DEBUG1_msg | 
| int | ofx_DEBUG2_msg | 
| int | ofx_DEBUG3_msg | 
| int | ofx_DEBUG4_msg | 
| int | ofx_DEBUG5_msg | 
| int | ofx_STATUS_msg | 
| int | ofx_INFO_msg | 
| int | ofx_WARNING_msg | 
| int | ofx_ERROR_msg | 
| int | ofx_show_position | 
| Creating OFX Files | |
| #define | OFX_AMOUNT_LENGTH (32 + 1) | 
| #define | OFX_PAYACCT_LENGTH (32 + 1) | 
| #define | OFX_STATE_LENGTH (5 + 1) | 
| #define | OFX_POSTALCODE_LENGTH (11 + 1) | 
| #define | OFX_NAME_LENGTH (32 + 1) | 
| char * | libofx_request_statement (const struct OfxFiLogin *fi, const struct OfxAccountData *account, time_t date_from) | 
| Creates an OFX statement request in string form. | |
| char * | libofx_request_accountinfo (const struct OfxFiLogin *login) | 
| Creates an OFX account info (list) request in string form. | |
| char * | libofx_request_payment (const struct OfxFiLogin *login, const struct OfxAccountData *account, const struct OfxPayee *payee, const struct OfxPayment *payment) | 
| char * | libofx_request_payment_status (const struct OfxFiLogin *login, const char *transactionid) | 
Main header file containing the LibOfx API.
This file should be included for all applications who use this API. This header file will work with both C and C++ programs. The entire API is made of the following structures and functions.
All of the following ofx_proc_* functions are callbacks (Except ofx_proc_file which is the entry point). They must be implemented by your program, but can be left empty if not needed. They are called each time the associated structure is filled by the library.
Important note: The variables associated with every data element have a _valid companion. Always check that data_valid == true before using. Not only will you ensure that the data is meaningfull, but also that pointers are valid and strings point to a null terminated string. Elements listed as mandatory are for information purpose only, do not trust the bank not to send you non-conforming data...
Definition in file libofx-0.9.8/inc/libofx.h.
| typedef int(* LibofxProcAccountCallback)(const struct OfxAccountData data, void *account_data) | 
The callback function for the OfxAccountData stucture.
The ofx_proc_account_cb event is always generated first, to allow the application to create accounts or ask the user to match an existing account before the ofx_proc_statement and ofx_proc_transaction event are received. An OfxAccountData is passed to this event.
Note however that this OfxAccountData structure will also be available as part of OfxStatementData structure passed to ofx_proc_statement event, as well as a pointer to an arbitrary data structure.
Definition at line 342 of file libofx-0.9.8/inc/libofx.h.
| typedef int(* LibofxProcSecurityCallback)(const struct OfxSecurityData data, void *security_data) | 
The callback function for the OfxSecurityData stucture.
An ofx_proc_security_cb event is generated for any securities listed in the ofx file. It is generated after ofx_proc_statement but before ofx_proc_transaction. It is meant to be used to allow the client to create a new commodity or security (such as a new stock type). Please note however that this information is usually also available as part of each OfxtransactionData.
An OfxSecurityData structure is passed to this event, as well as a pointer to an arbitrary data structure.
Definition at line 413 of file libofx-0.9.8/inc/libofx.h.
| typedef int(* LibofxProcStatementCallback)(const struct OfxStatementData data, void *statement_data) | 
The callback function for the OfxStatementData stucture.
The ofx_proc_statement_cb event is sent after all ofx_proc_transaction events have been sent. An OfxStatementData is passed to this event, as well as a pointer to an arbitrary data structure.
Definition at line 703 of file libofx-0.9.8/inc/libofx.h.
| typedef int(* LibofxProcStatusCallback)(const struct OfxStatusData data, void *status_data) | 
The callback function for the OfxStatusData stucture.
An ofx_proc_status_cb event is sent everytime the server has generated a OFX STATUS element. As such, it could be received at any time(but not during other events). An OfxStatusData structure is passed to this event, as well as a pointer to an arbitrary data structure.
Definition at line 257 of file libofx-0.9.8/inc/libofx.h.
| typedef int(* LibofxProcTransactionCallback)(const struct OfxTransactionData data, void *transaction_data) | 
The callback function for the OfxTransactionData stucture.
An ofx_proc_transaction_cb event is generated for every transaction in the ofx response, after ofx_proc_statement (and possibly ofx_proc_security is generated. An OfxTransactionData structure is passed to this event, as well as a pointer to an arbitrary data structure.
Definition at line 625 of file libofx-0.9.8/inc/libofx.h.
| enum FiIdCorrectionAction | 
Definition at line 460 of file libofx-0.9.8/inc/libofx.h.
| enum InvTransactionType | 
Definition at line 436 of file libofx-0.9.8/inc/libofx.h.
| enum LibofxFileFormat | 
List of possible file formats
Definition at line 122 of file libofx-0.9.8/inc/libofx.h.
| enum TransactionType | 
Definition at line 415 of file libofx-0.9.8/inc/libofx.h.
| int libofx_free_context | ( | LibofxContextPtr | ) | 
Free all ressources used by this context.
Definition at line 158 of file context.cpp.
| const char* libofx_get_file_format_description | ( | const struct LibofxFileFormatInfo | format_list[], | 
| enum LibofxFileFormat | file_format | ||
| ) | 
get_file_format_description returns a string description of a LibofxFileType.
The file format list in which the format should be looked up, usually LibofxImportFormatList or LibofxExportFormatList
The file format which should match one of the formats in the list.
Definition at line 37 of file file_preproc.cpp.
| enum LibofxFileFormat libofx_get_file_format_from_str | ( | const struct LibofxFileFormatInfo | format_list[], | 
| const char * | file_type_string | ||
| ) | 
libofx_get_file_type returns a proper enum from a file type string.
The file format list in which the format string should be found, usually LibofxImportFormatList or LibofxExportFormatList
The string which contain the file format matching one of the format_name of the list.
Definition at line 54 of file file_preproc.cpp.
| LibofxContextPtr libofx_get_new_context | ( | ) | 
Initialise the library and return a new context.
Definition at line 153 of file context.cpp.
| int libofx_proc_buffer | ( | LibofxContextPtr | ctx, | 
| const char * | s, | ||
| unsigned int | size | ||
| ) | 
Parses the content of the given buffer.
| int libofx_proc_file | ( | LibofxContextPtr | libofx_context, | 
| const char * | p_filename, | ||
| enum LibofxFileFormat | ftype | ||
| ) | 
libofx_proc_file is the entry point of the library.
libofx_proc_file must be called by the client, with a list of 1 or more OFX files to be parsed in command line format.
Definition at line 67 of file file_preproc.cpp.
| char* libofx_request_accountinfo | ( | const struct OfxFiLogin * | login | ) | 
Creates an OFX account info (list) request in string form.
Creates a string which should be passed to an OFX server. This string is an OFX request suitable to retrieve a list of accounts from the fi 
| fi | Identifies the financial institution and the user logging in. | 
| char* libofx_request_statement | ( | const struct OfxFiLogin * | fi, | 
| const struct OfxAccountData * | account, | ||
| time_t | date_from | ||
| ) | 
Creates an OFX statement request in string form.
Creates a string which should be passed to an OFX server. This string is an OFX request suitable to retrieve a statement for the account from the fi 
| fi | Identifies the financial institution and the user logging in. | 
| account | Idenfities the account for which a statement is desired | 
| void ofx_set_account_cb | ( | LibofxContextPtr | ctx, | 
| LibofxProcAccountCallback | cb, | ||
| void * | user_data | ||
| ) | 
Set the account callback in the given context.
| ctx | context | 
| cb | callback function | 
| user_data | user data to be passed to the callback | 
Definition at line 186 of file context.cpp.
| void ofx_set_security_cb | ( | LibofxContextPtr | ctx, | 
| LibofxProcSecurityCallback | cb, | ||
| void * | user_data | ||
| ) | 
Set the security callback in the given context.
| ctx | context | 
| cb | callback function | 
| user_data | user data to be passed to the callback | 
Definition at line 195 of file context.cpp.
| void ofx_set_statement_cb | ( | LibofxContextPtr | ctx, | 
| LibofxProcStatementCallback | cb, | ||
| void * | user_data | ||
| ) | 
Set the statement callback in the given context.
| ctx | context | 
| cb | callback function | 
| user_data | user data to be passed to the callback | 
Definition at line 213 of file context.cpp.
| void ofx_set_status_cb | ( | LibofxContextPtr | ctx, | 
| LibofxProcStatusCallback | cb, | ||
| void * | user_data | ||
| ) | 
Set the status callback in the given context.
| ctx | context | 
| cb | callback function | 
| user_data | user data to be passed to the callback | 
Definition at line 178 of file context.cpp.
| void ofx_set_transaction_cb | ( | LibofxContextPtr | ctx, | 
| LibofxProcTransactionCallback | cb, | ||
| void * | user_data | ||
| ) | 
Set the transaction callback in the given context.
| ctx | context | 
| cb | callback function | 
| user_data | user data to be passed to the callback | 
Definition at line 204 of file context.cpp.
| struct LibofxFileFormatInfo LibofxExportFormatList[] | 
  {
    {QIF, "QIF", "QIF (Intuit Quicken Interchange Format) NOT IMPLEMENTED"},
    {LAST, "LAST", "Not a file format, meant as a loop breaking condition"}
  }
Definition at line 151 of file libofx-0.9.8/inc/libofx.h.
| struct LibofxFileFormatInfo LibofxImportFormatList[] | 
  {
    {AUTODETECT, "AUTODETECT", "AUTODETECT (File format will be automatically detected later)"},
    {OFX, "OFX", "OFX (Open Financial eXchange (OFX or QFX))"},
    {OFC, "OFC", "OFC (Microsoft Open Financial Connectivity)"},
    {QIF, "QIF", "QIF (Intuit Quicken Interchange Format) NOT IMPLEMENTED"},
    {LAST, "LAST", "Not a file format, meant as a loop breaking condition"}
  }
Definition at line 142 of file libofx-0.9.8/inc/libofx.h.
| int ofx_DEBUG1_msg | 
If set to true, debug level 1 messages will be printed to the console
Definition at line 32 of file messages.cpp.
| int ofx_DEBUG2_msg | 
If set to true, debug level 2 messages will be printed to the console
Definition at line 33 of file messages.cpp.
| int ofx_DEBUG3_msg | 
If set to true, debug level 3 messages will be printed to the console
Definition at line 34 of file messages.cpp.
| int ofx_DEBUG4_msg | 
If set to true, debug level 4 messages will be printed to the console
Definition at line 35 of file messages.cpp.
| int ofx_DEBUG5_msg | 
If set to true, debug level 5 messages will be printed to the console
Definition at line 36 of file messages.cpp.
| int ofx_DEBUG_msg | 
If set to true, general debug messages will be printed to the console
Definition at line 31 of file messages.cpp.
| int ofx_ERROR_msg | 
If set to true, error messages will be printed to the console
Definition at line 40 of file messages.cpp.
| int ofx_INFO_msg | 
If set to true, information messages will be printed to the console
Definition at line 38 of file messages.cpp.
| int ofx_PARSER_msg | 
If set to true, parser events will be printed to the console
Definition at line 30 of file messages.cpp.
If set to true, the line number will be shown after any error
Definition at line 41 of file messages.cpp.
| int ofx_STATUS_msg | 
If set to true, status messages will be printed to the console
Definition at line 37 of file messages.cpp.
| int ofx_WARNING_msg | 
If set to true, warning messages will be printed to the console
Definition at line 39 of file messages.cpp.