package gnucash import ( "github.com/mayswind/ezbookkeeping/pkg/converters/datatable" "github.com/mayswind/ezbookkeeping/pkg/core" "github.com/mayswind/ezbookkeeping/pkg/models" "github.com/mayswind/ezbookkeeping/pkg/utils" ) var gnucashTransactionTypeNameMapping = map[models.TransactionType]string{ models.TRANSACTION_TYPE_MODIFY_BALANCE: utils.IntToString(int(models.TRANSACTION_TYPE_MODIFY_BALANCE)), models.TRANSACTION_TYPE_INCOME: utils.IntToString(int(models.TRANSACTION_TYPE_INCOME)), models.TRANSACTION_TYPE_EXPENSE: utils.IntToString(int(models.TRANSACTION_TYPE_EXPENSE)), models.TRANSACTION_TYPE_TRANSFER: utils.IntToString(int(models.TRANSACTION_TYPE_TRANSFER)), } // gnucashTransactionDataImporter defines the structure of gnucash importer for transaction data type gnucashTransactionDataImporter struct { } // Initialize a gnucash transaction data importer singleton instance var ( GnuCashTransactionDataImporter = &gnucashTransactionDataImporter{} ) // ParseImportedData returns the imported data by parsing the gnucash transaction data func (c *gnucashTransactionDataImporter) ParseImportedData(ctx core.Context, user *models.User, data []byte, defaultTimezoneOffset int16, accountMap map[string]*models.Account, expenseCategoryMap map[string]*models.TransactionCategory, incomeCategoryMap map[string]*models.TransactionCategory, transferCategoryMap map[string]*models.TransactionCategory, tagMap map[string]*models.TransactionTag) (models.ImportedTransactionSlice, []*models.Account, []*models.TransactionCategory, []*models.TransactionCategory, []*models.TransactionCategory, []*models.TransactionTag, error) { gnucashDataReader, err := createNewGnuCashDatabaseReader(data) if err != nil { return nil, nil, nil, nil, nil, nil, err } gnucashData, err := gnucashDataReader.read(ctx) if err != nil { return nil, nil, nil, nil, nil, nil, err } transactionDataTable, err := createNewGnuCashTransactionDataTable(gnucashData) if err != nil { return nil, nil, nil, nil, nil, nil, err } dataTableImporter := datatable.CreateNewSimpleImporter(gnucashTransactionTypeNameMapping) return dataTableImporter.ParseImportedData(ctx, user, transactionDataTable, defaultTimezoneOffset, accountMap, expenseCategoryMap, incomeCategoryMap, transferCategoryMap, tagMap) }