MoneyMoney kann mit Extensions erweitert werden, um Umsätze aus anderen Anwendungen zu importieren. Diese Extensions sind kurze Lua-Skripte, die einfach zu erstellen, zu modifizieren und auszuwechseln sind. Bisher nicht unterstützte Dateiformate lassen sich durch neu geschriebene Skripte nachrüsten. Die Lua-Skripte werden in einer virtuellen Maschine ausgeführt und kommunizieren über eine dokumentierte API mit MoneyMoney. Das vorliegende Dokument spezifiziert diese API. Die Wahl der Skriptsprache fiel auf Lua, da sie relativ leicht zu erlernen ist und sich gut mit C/C++/Objective-C kombinieren lässt. Für unsere Extensions reicht es vollkommen aus, die ersten fünf Kapitel von »Programming in Lua« gelesen zu haben. Die meisten innerhalb einer Extension aufgerufenen Funktionen sind nämlich gar nicht Bestandteil von Lua, sondern existieren ausschließlich in MoneyMoney. Das Verzeichnis, in dem eigene Extensions abgelegt werden, kann über Menü Jede Änderung an Dateien in diesem Verzeichnis wirkt sich unmittelbar auf MoneyMoney aus, d.h. es ist nicht nötig, MoneyMoney neu zu starten. Fehlermeldungen werden im Protokoll-Fenster von MoneyMoney angezeigt. Das Protokoll-Fenster lässt sich mit der Menüfunktion »Fenster« → »Protokollfenster« erreichen. Ein Skript weist sich als Import-Extension aus, indem es am Beginn des Skripts einen Aufruf der Art enthält. Bei den benannten Parameter der Funktion Die Parameter der Funktion Die Variablen Die Ausgabe der Standard-Funktion Die Standard-Funktion Das Skript selbst muss UTF-8-kodiert sein und es werden auch alle Strings als UTF-8-Strings zwischen dem Skript und MoneyMoney übergeben, außer es steht in der API-Beschreibung, dass es sich um Binärdaten handelt. MoneyMoney treibt die Ausführung des Skripts, was bedeutet, dass jedes Skript eine bestimmte Funktion als Einsprungspunkt zur Verfügung stellen muss. MoneyMoney ruft zum Umsatzimport folgende Funktion des Skripts auf: Es wird das einfache I/O-Modell von Lua verwendet: Das Skript braucht die Daten bloß mit Diese Funktion liest die Umsätze aus der Datei: Parameter: Table Mögliche Rückgabewerte: Folgende Vorlage kann als Ausgangspunkt für eigene Import-Extensions dienen. Die Informationen eines Konto werden in einer Lua-Tabelle gespeichert. Folgende Felder sind definiert: Die Daten eines Umsatzes werden in einer Lua-Tabelle gespeichert. Die Felder orientieren sich an SWIFT MT-940/MT-942: Erzeugt ein neues Objekt mit Informationen zu einer Bank. Um den richtigen Nummernkreis zu wählen, wird die globale Variable Parameter: String Beispiel: Die Informationen zu einer Bank werden in einer Lua-Tabelle gespeichert. Derzeit gibt es nur ein einziges belegtes Feld: Mit dieser Funktion kann ein Text übersetzt werden. Diese Funktion ist primär für die mit MoneyMoney ausgelieferten Extensions gedacht. Sie ist ein Wrapper für die Cocoa-Funktion Parameter: String Rückgabewert: String Lokalisiert eine Zeitangabe. Da die von Lua unterstützten POSIX Locales innerhalb von macOS-Apps nicht zur Verfügung stehen, baut diese Funktion auf der Cocoa-Klasse Parameter: Rückgabewert: String Lokalisiert eine Zahl. Da die von Lua unterstützten POSIX Locales innerhalb von macOS-Apps nicht zur Verfügung stehen, baut diese Funktion auf der Cocoa-Klasse Parameter: Rückgabewert: String Lokalisiert einen Währungsbetrag. Parameter: Rückgabewert: String Konvertiert einen Text von UTF-8 zu einem anderen Zeichensatz. Parameter: Rückgabewert: Binary Konvertiert einen Text von einem anderen Zeichensatz zu UTF-8. Parameter: Rückgabewert: String MoneyMoney Import API Für Entwickler, Stand 31.10.2022
Einführung
Vom Skript zur Extension
Installation
Hilfe
→ Zeige Datenbank im Finder
im Finder geöffnet werden:~/Library/Containers/com.moneymoney-app.retail/Data/Library/Application Support/MoneyMoney/Extensions
Registrierung einer Extension
Importer{version = 1.05,
format = "Comma-separated values",
fileExtension = "csv",
description = "Import transactions from CSV file"}
Importer
handelt es sich um:
version
: Versionsnummer der Extensionformat
(optional): Bezeichnung des Dateiformats, wie sie in der Formatauswahl des Datei-Öffnen-Dialogs angezeigt wirdfileExtension
(optional): Dateinamenserweiterungdescription
(optional): Beschreibung der ExtensionLua-Laufzeitumgebung
Importer
sind später im Skript als globale Variablen version
, format
, fileExtension
, und description
zugänglich. Zusätzlich ist auch noch die globale Variable extensionName
mit dem Namen der Extension definiert.MM.productName
und MM.productVersion
enthalten Informationen zur Anwendung, also MoneyMoney.print
wird im Protokoll-Fenster von MoneyMoney angezeigt.error
bricht die Ausführung des Skripts ab.Aufbau einer Import-Extension
Einsprungspunkte
ReadTransactions
(Umsätze lesen)assert(io.read(...))
von der Standardeingabe (stdin
) zu lesen. Das Öffnen und Schließen der Datei übernimmt MoneyMoney.Umsätze lesen
function ReadTransactions (account)
account
: Das Konto, in das die Umsätze importiert werden; Die Strukur ist im Abschnitt »Datenstruktur eines Kontos« beschrieben.
Vorlage
Importer{version=1.00, format="Tab-separated values", fileExtension="tsv"}
local function strToDate (str)
-- Helper function for converting localized date strings to timestamps.
local d, m, y = string.match(str, "(%d%d).(%d%d).(%d%d%d%d)")
return os.time{year=y, month=m, day=d}
end
function ReadTransactions (account)
-- Read transactions from a file with the format "date<TAB>amount<TAB>purpose".
local transactions = {}
for line in assert(io.lines()) do
local values = {}
for value in string.gmatch(line, "[^\t]+") do
table.insert(values, value)
end
if #values >= 3 then
local transaction = {
bookingDate = strToDate(values[1]),
amount = tonumber(values[2]),
purpose = values[3]
}
table.insert(transactions, transaction)
end
end
return transactions
end
Die API von MoneyMoney
Datenstruktur eines Kontos
name
: Bezeichnung des Kontosowner
: Name des KontoinhabersaccountNumber
: KontonummersubAccount
: UnterkontomerkmalbankCode
: Bankleitzahlcurrency
: Kontowährungiban
: IBANbic
: BICtype
: Kontoart; Mögliche Werte sind AccountTypeGiro
(Girokonto), AccountTypeSavings
(Sparkonto), AccountTypeFixedTermDeposit
(Festgeldanlage), AccountTypeLoan
(Darlehenskonto), AccountTypeCreditCard
(Kreditkarte), AccountTypeCash
(Bargeld), AccountTypeOther
(Sonstige).Datenstruktur eines Umsatzes
name
: Name des Auftraggebers/ZahlungsempfängersaccountNumber
: Kontonummer oder IBAN des Auftraggebers/ZahlungsempfängersbankCode
: Bankzeitzahl oder BIC des Auftraggebers/Zahlungsempfängersamount
: Betragcurrency
: WährungbookingDate
: Buchungstag; Die Angabe erfolgt in Form eines POSIX-Zeitstempels.valueDate
: Wertstellungsdatum; Die Angabe erfolgt in Form eines POSIX-Zeitstempels.purpose
: Verwendungszweck; Mehrere Zeilen können durch Zeilenumbrüche ("\n"
) getrennt werden.transactionCode
: GeschäftsvorfallcodetextKeyExtension
: TextschlüsselergänzungpurposeCode
: SEPA-VerwendungsschlüsselbookingKey
: SWIFT-BuchungsschlüsselbookingText
: UmsatzartprimanotaNumber
: Primanota-NummerbatchReference
: SammlerreferenzendToEndReference
: SEPA-Ende-zu-Ende-ReferenzmandateReference
: SEPA-MandatsreferenzcreditorId
: SEPA-Gläubiger-IDreturnReason
: Rückgabegrundbooked
: Gebuchter oder vorgemerkter Umsatzcategory
: Kategoriennamecomment
: Notiz
Objekt für Bankinformationen
bankInfo = BankInfo(bankCode)
country
herangezogen.bankCode
: Bankleitzahlprint(BankInfo("80007777").name)
Datenstruktur für Bankinformationen
name
: Name der Bank
Sonstige Funktionen
str = MM.localizeText(str)
NSLocalizedString
und liefert natürlich nur dann eine Übersetzung, wenn der Text in MoneyMoney hinterlegt worden ist.str
: Englischer Textstr
: Übersetzter Textstr = MM.localizeDate([format, ]date)
NSDateFormatter
auf.
format
(optional): Ausgabeformat; Die Angabe erfolgt wie bei der Cocoa-Klasse NSDateFormatter
nach dem Unicode Technical Standard #35.date
: Datum; Die Angabe erfolgt in Form eines POSIX-Zeitstempels. str
: Datum im lokalisierten Formatstr = MM.localizeNumber([format, ]num)
NSNumberFormatter
auf.
format
(optional): Ausgabeformat; Die Angabe erfolgt wie bei der Cocoa-Klasse NSNumberFormatter
nach dem Unicode Technical Standard #35.num
: Zahlstr
: Zahl im lokalisierten Formatstr = MM.localizeAmount([format, ]amount[, currency])
format
(optional): Ausgabeformat; Die Angabe erfolgt wie bei der Cocoa-Klasse NSNumberFormatter
nach dem Unicode Technical Standard #35.amount
: Betragcurrency
(optional): Währung; Ohne diesen Parameter wird nur der Betrag ohne Währungsangabe zurückgegeben.str
: Währungsbetrag im lokalisierten Formatdata = MM.toEncoding(charset, str[, bom])
charset
: Zeichensatz; Die Angabe erfolgt wie bei HTTP nach IANA.str
: Text in UTF-8bom
(optional): Wenn dieser Parameter mit true
belegt ist, wird der Rückgabewert um eine Byte Order Mark (BOM) ergänzt, sofern sie für den angegeben Zeichensatz existiert.data
: Text im angegebenen Zeichensatzstr = MM.fromEncoding(charset, data)
charset
: Zeichensatz; Die Angabe erfolgt wie bei HTTP nach IANA.data
: Text im angegebenen Zeichensatzstr
: Text in UTF-8