Freie Software für Freie Unternehmen
Transcription
Freie Software für Freie Unternehmen
Version 0.9 Jochen Stärk ([email protected]) Copyright © 2009 Jochen Stärk. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.1 or any later version published by the Free Software Foundation. Dieses Paper stellt osFaktura und Gnuaccounting, zwei Java-FakturaProgramme mit Buchhaltungsfunktionen vor. Freie Software für Freie Unternehmen: Zwei Buchhaltungsalternativen Faktura und Buchhaltung Es gibt mit Gnucash bereits ein größeres (1) Buchhaltungsprogramm mit vergleichsweise vielen Funktionen, allerdings konzentriert sich Gnucash auf die Buchführung und Bilanzierung, die Faktura, das heißt die Belegerstellung, ist relativ kompliziert und integriert sich nicht gut in Geschäftsprozesse2. Der Markt von „echten“, Buchhaltungs- oder Fakturalösungen für Linux ist mit gerade mal acht Programmen jedoch sehr überschaubar. Als „echte“ Programme gelten dabei alle nicht webbasierten Anwendungen die nativ unter Linux oder Java arbeiten 3. 1 65 registrierte Ohloh-Nutzer am 14.06.2009, http://www.ohloh.net/p/gnucash 2 Es fehlt ein visueller Designer für Rechnungen, druckbare Rechnungen können nicht ohne Rechnungsbuchung erstellt werden, Rechnungsbuchungen können nicht ohne Aufträge erstellt werden und Aufträge können zum Beispiel nicht ohne Auswahl der Verbuchungskonten für die Posten erstellt werden 3 siehe Nicht-webbasierter Linux-Buchhaltungsanwendungen ,S. 13 My itch Every good work of software starts by scratching a developer's personal itch. Eric Steven Raymond, The Cathedral and the Bazaar Für meine damalige Faktura musste ich jedesmal VMWare und Windows starten um eine Rechnung zu schreiben. Meine Faktura sollte also 1. unter Linux funktionieren. 2. eine echte Anwendung sein, da Webanwendungen zum Beispiel schlechter mit Drucker- Chipkarten- oder Scanneransteuerung zusammen arbeiten. 3. Belege erstellen können. Idealerweise sollten entsprechende Vorlagen leicht, das heißt ohne Skriptsprache (=What-you-see-is-what-you-get) gestaltet werden können. 4. eine Übergabe der Daten an eine Buchhaltung ermöglichen oder selbst Buchhaltungsaufgaben erfüllen. Diese Buchhaltung musste mir mindestens ermöglichen, meine monatlichen Umsatzsteuervoranmeldung durchzuführen und möglicherweise meine Bilanz vorbereiten. 5. benutzerfreundlich sein. Compiere warb angeblich mit: Im Gegensatz zu anderen Lösungen sind sie hier schon nach vier Stunden in der Lage Rechnungen einzugeben. Compiere Website1 Die Zielsetzung für Gnuaccounting ist, binnen vier Minuten eine Rechnung erstellen zu können. 6. Idealerweise und aus hauptsächlich ideologischen Gründen wäre sie Freie Software. Dies kann, vor allem auch in der Anfangsphase eines Projekts, auch aus betriebswirtschaftlichen Gründen sinnvoll sein, weil die NichtHaftung der GPL ein sehr frühes Release ermöglicht und keine Ressourcen, zum Beispiel zum Warten und Weiterentwickeln der Software, bindet. 1 http://www.linux-magazin.de/Heft-Abo/Ausgaben/2002/07/Freiheit-fuer-Buerohengste/ (offset)/2 OsFaktura Internet: http://www.osfaktura.de/ Download: http://www.osfaktura.de/files/beta/osfaktura.zip Unabhängig von Gnuaccounting aber in nicht einmal 30km Entfernung hat Jan Hans Novak in eine technisch sehr ähnliche, Open-Source Java Fakturasoftware geschrieben. Sie soll sein eigenes, produktiv eingesetztes kommerzielles Produkt, Refas, ablösen. Testsystem Das Testsystem besteht aus einem Kubuntu 9.04. Zusätzlich installiert wurde Sun Java 1.6 und der MySQL-Server. MySQL wurde mit mysql_secure_install gesichert. osfaktura wurde extrahiert und in das Verzeichnis /opt/osfaktura verschoben. Für das Scanmodul wurde /tmp auf /temp gesymlinked. Die Datenbank „osf“ wurde angelegt und entsprechend den Anweisungen in /opt/osfaktura/install/mini-howto.txt befüllt: „mysq l mysq l> c r e a t e da t a b a s e os f ; mysq l>g r a n t a l l p r i v i l e g e s on os f . * t o ' o s f a k t u r a ' @ ' l o c a l h o s t ' i d e n t i f i e d by '<gehe im> ' ; mysq l> f l u s h p r i v i l e g e s mysq l>e x i t mysq l -u os f a k t u r a -p </op t/o s f a k t u r a / i n s t a l l / o s f a k t u r a . s q l “ . Schritte 1. Start des Partnermoduls mit ./osfaktura.sh 1 osFaktura befindet sich noch in Entwicklung und es gibt leider noch keinen Hauptbildschirm, von dem sich die Module starten ließen. Die Standard-Zugangsdaten sind Benutzer „User1“ mit leerem Passwort. 2. Suchen nach Partner Als Platzhalter kann „*“ verwendet werden. Das Programm wird zu diesem Zeitpunkt allerdings nur Jans Firma, Repkom, finden. 3. Programm beenden 4. Demodaten erzeugen mit ./osfaktura.sh 4 5. Die Suche nach Partner (./osfaktura.sh 1) zeigt jetzt wesentlich mehr Daten: Illustration 1: Abb. 1: osFaktura Kontaktliste 6. Doppelklickt man einen Partner, sieht man die Details: Einige Funktionen sind angedeutet, die über die von Gnuaccounting weit herausgehen, zum Beispiel Umsatzliste (Partner|Umsatz) oder Artikelaufstellung (Partner|Artikel). Memo (Partner|Memo) und Intervallauftrag (Partner|Intervallauftrag) sind ebenfalls interessant, Intervallauftrag gefällt mir genau genommen so gut, dass ich ihn mir für Gnuaccounting eventuell klauen werde. Während Scans (Button rfScan) in Gnuaccounting zwar ebenfalls möglich sind, ist die offensichtliche Telefonintegration (Button RfTelco) einzigartig. 7. Die Artikelverwaltung (./osfaktura.sh 3) zeigt wesentlich mehr Attribute Abb. 1: OsFaktua Kontaktliste als wir später in Gnuaccounting sehen werden, unter anderem fünf Preise und ein Einkaufspreisattribut das eine Spannenberechnung erlaubt. Abb. 2: OsFaktura Kontaktdetails Auch hier ist osFaktura ambitionierter als der derzeitige Stand von Gnuaccounting und unterstützt unter anderem Lagerhaltung und Stücklistenartikel. 8. Das Kassenbuch (./osfaktura.sh 5) ist das derzeit einzige Buchhaltungsfeature von osFaktura und ermöglicht die Eingabe von Einund Ausgangsrechnungen inklusive Belegscans. Abb. 3: OsFaktura Kassenbuch 9. Das Faktura-Modul leidet in der derzeit verfügbaren Version leider unter einer Regression und lässt sich nicht starten. Gnuaccounting Internet: http://www.gnuaccounting.de/ Download: http://sourceforge.net/project/showfiles.php? group_id=130483&package_id=143018 Testsystem Das Testsystem besteht aus einem Kubuntu 9.04. Zusätzlich installiert wurde Sun Java 1.6, die (optionalen) Treiber des Chipkartenlesers und die ebenfalls optionale Winston-Freeware zur elektronischen Steueranmeldung (www.felfri.de/winston). Winston wurde einmalig gestartet, mit den Steuerdaten eingerichtet und durch Anklicken der Checkbox „Ausgangskorb benutzen“ zur Anlage eines Ausgangskorbs-Verzeichnisses angeregt. Bei anderen Linux-Systemen ist unter Umständen zusätzlich eine Installation des „OpenOffice-OfficeBeans“-Pakets notwendig. Unter Gnome funktioniert die Texteingabe in das in Gnuaccounting eingebettete OpenOffice.org derzeit nicht. Workaround: Vorlagen für die Rechnungen im externen OpenOffice.org gestalten und nach ~/.gnuaccounting/0000/AN-template1.odt, ERtemplate1.odt, GS-template1.odt, PD-template1.odt, RE-template1.odt und STtemplate1.odt kopieren. Schritte: Faktura 1. Gnuaccounting wird entpackt und per ./gnuaccounting.sh gestartet Abb. 4: Gnuaccounting Hauptfenster 2. In „Verwaltung|Konfiguration“ werden die Programmeinstellungen, in „Verwaltung|Einstellungen“ die Mandanteneinstellungen vorgenommen. Wichtige Programmeinstellungen für diese Demonstration sind das Winston-Ausgabeverzeichnis (~/.Winston/Ausgang/, siehe Abschnitt 'Testsystem') sowie der Chipkartentreiber. Wichtige Mandanteneinstellungen sind in diesem Zusammenhang Steuernummer, Bundesland, Finanzamt, Bankleitzahl, Kontonummer und Kontoinhaber. 3. Der Knopf „Neuer Vorgang“ im Hauptfenster erstellt Rechnungen, Gutschriften, Privatentnahmebescheinigungen, Stornierungen oder Angebote. Dazu wählt man im ersten Schritt Datum, Empfänger und Belegart: Abb. 5: Gnuaccounting Transaktionsdetailauswahl 4. im zweiten Schritt fügt man der Rechnung Positionen an, hier 123 „Beispielprodukt“ Abb. 6: Gnuaccounting Posteneingabe 5. im dritten Schritt wird eine Vorschau auf das fertige Dokument generiert. Theoretisch ist diese Vorschau noch beschreibbar, das heißt im Dokument kann noch editiert werden Abb. 7: Gnuaccounting Rechnungsvorschau im eingebetteten OpenOffice.org 6. im letzten Schritt wird das Dokument automatisch als .odt und .pdf gespeichert und auf Wunsch gedruckt und/oder gemailt. Zum E-Mailen wäre in der Kontakteverwaltung eine Empfänger-Email-Addresse und in der Programmkonfiguration Zugangsdaten zu einem E-Mail-Server nötig. In den Programmeinstellungen könnte man zusätzlich noch einen GPGPfad angeben um die Rechnungen digital signiert vorab zu verschicken. Da es sich jedoch nicht um rechtsgültige digitale Unterschriften im Sinne des Gesetzes handelt kann diese Mail eine Papierrechnung nicht ganz ersetzen. Schritte: Buchhaltung 1. Es gibt zwei Wege die Rechnung zu verbuchen. Erstens: Der „offen“ Knopf beinhaltet alle noch zu erledigenden Aufgaben. Neben einiger einmaligen Installations-Aufgaben wie der Vorlagenanpassung enthält er jetzt auch die eben gestellte Rechnung. Abb. 8: Gnuaccounting To-Do Fenster Der Link „Zahlungseingang“ führt zur Detailverbuchung: Abb. 9: Gnuaccounting Detailverbuchungsfenster Ist in der Kundenverwaltung „Lastschrift“ als Zahlungsmethode ausgewähltkann man auf diesem Bildschirm mit der Checkbox „Überweisung/Lastschrift Ausführen“ eine HBCI-Lastschrift einreichen. Bei einer Gutschrift veranlasst dieselbe Checkbox eine Überweisung statt einer Lastschrift. 2. Zweitens kann man Rechnungen verbuchen indem man über den „Importieren“ Link im Buchhaltungsfenster die Möglichkeit nutzt, ganze Kontoauszüge in die Buchhaltung zu übernehmen. Da die Kontoauszüge notwendigerweise die Hälfte des entsprechenden Buchhaltungskontos „Bank“ in der doppelten Buchführung darstellen fehlt nur die Auswahl des Gegenkontos, des Umsatzsteuersatzes und der Belegnummer. Zum Import per HBCI wählt man einfach einen Zeitraum und klickt auf „Import“. Für eigene Versuche ohne HBCI wird im GnuaccountingUnterverzeichnis „samples“ eine geeignete Moneyplex XML-Datei mitgeliefert. Abb. 10: Gnuaccounting Kontoauszugsimport 3. Im nächsten Fenster wählt man die Gegenkonten und den Umsatzsteuersatz aus und gibt in „Reference“ die Rechnungsnummer ein oder wählt sie aus. Da die Umsatzsteuerschuld für Leistungen im Mai, die erst im Juni bezahlt werden, schon im Mai anfällt, kann das Leistungserbringungsdatum manuell in der ersten Spalte angepasst werden oder automatisch durch Auswahl der entsprechenden Belegnummer für den Benutzer transparent übernommen werden. Abb. 11: Gnuaccounting Eingangsliste 4. Jede vollständige Buchung wird dann per Drag&Drop in einen Korb im Ablagebereich, „Buchen“, „Mehr“ oder „Löschen“ befördert. STRG+Klick ermöglicht hierbei das Auswählen mehrerer Buchungen. Während „Löschen“ die Buchung ins digitale Nirvana befördert, erlaubt die Ablage in „Mehr“die Anzeige in der bereits bekannten Detailverbuchungsansicht, die zum Beispiel zum Verbuchen von Rechnungen mit mehreren Vorsteuersätzen herangezogen werden muss. Der „Buchen“ Korb überträgt die Einträge ohne weitere Umwege in die Buchhaltung. 5. Wir möchten eine elektronische Umsatzsteuervoranmeldung durchführen und klicken hierzu im Hauptfenstermenü auf „Export der USt.Anmeldung“. 6. Nach Auswahl des Monats und Klick auf „Exportieren“ können wir Winston („winston“) starten. 7. Dort befindet sich die Umsatzsteueranmeldung in „Formular| Ausgangskorb“. Bitte markieren Sie die entsprechende Anmeldung. 8. Durch „Anmeldung übertragen“ wird diese ans Finanzamt übertragen und ausgedruckt. Es bietet sich jedoch eine vorherige Kontrolle, zum Beispiel durch Klick des „Bearbeiten“ Knopfes an. 9. Die so gewonnenen Daten können unter weiterhin per „Schnittstellen| Export als Tabellenkalkulation“ dem Steuerberater als Bilanzgrundlage zur Verfügung gestellt werden. Abb. 12: Gnuaccounting Buchhaltungsdatenexport in das eingebettete OpenOffice.Org Calc Ausblick OsFaktura Die Fertigstellung einer einsatzfähigen Version die möglicherweise ebenfalls OpenOffice einbetten könnte hat einen hohen Stellenwert, krankt aber an wenigen Ressourcen. Möglicherweise könnte man mittel- bis langfristig eine Schnittstelle zu Gnuaccounting ergänzen um Gnuaccounting für die Buchhaltung und osFaktura für die Faktura eines Unternehmens nutzen zu können. Gnuaccounting Nachdem die Version 0.7.1 die Umstellung auf Hibernate begonnen hat soll diese fortgesetzt werden und bisherige Methoden (native HSQLDB- und MySQLUnterstützung) idealerweise ablösen. In den nächsten fünf bis zehn Jahren könnte sich das Programm eventuell in Richtung Eclipse Rich Client Plattform und in Richtung Anwendungsserverintegration bewegen. Fazit Gnuaccounting erfüllt seine Aufgabe als Faktura und Buchhaltung für mein Kleinstunternehmen. Interessant ist die Frage, warum sich bislang keine Community gebildet hat, ob und wann sich diese möglicherweise bilden wird und ob das geringe Feedback (2 Mails) trotz offensichtlichem Interesses (>7500 Downloads) so niedrig ist. Während osFaktura zwar derzeit noch mehr und bessere Fakturafunktionen (Intervallauftrag, Lagerhaltung) verspricht, ist sie aufgrund des frühen Entwicklungsstands leider noch nicht einsatzbereit. Gnuaccounting hat weniger Faktura-Features zugunsten von mehr Buchhaltung und ist, zumindest die Faktura betreffend, bereits relativ stabil. Bei beiden Programme ist die Nutzung der Buchführungsfeatures optional. So kann die Einführung durchaus schrittweise (zuerst Faktura, dann Buchhaltung) erfolgen. Anhang Marktbetrachtung Nicht-webbasierter Linux-Buchhaltungsanwendungen Basierend auf http://gnuaccounting.wiki.sourceforge.net/Competitors • • • • • • • • Lin-Habu gnucash kraft Compiere Adempiere syntax mp Postbooks Gnuaccounting Facts&Features • Java (Win32/Lin32/Lin64) • Import von Starmoney und Moneyplex Kontoauszügen • Import von TaskCoach und KTimetracker Stundenlisten • OpenOffice.org-Einbettung zur einfachen Vorlagengestaltung • HSQLDB-Einbettung, MySQL fähig • Scannerunterstützung, ADF • Nutzung des SKR03-Kontenrahmens • nativ Englischsprachig, deutsche Übersetzung vorhanden • HBCI-Fähig (Kontostandabruf, Gutschrift, Lastschrift) • Winston-Export (Winston=Windows+Linux elektronische UStVoranmeldung) • Scanneranbindung für ein rudimentäres Dokumentenmanagement • Version 0.7.1 • >7500 Downloads in >4 Jahren (0.0.9 am 25.03.2005) • 2 User • 3 Developer Osfaktura-Gnuaccounting Vergleichsmatrix OsFaktura Gnuaccounting Human-Sprache Deutsch Englisch,Deutsch Programmiersprache Java Java Version Downloadgröße 0.7.1 12MB Alter (Vorgängerprodukt) 22MB 4 Jahre (kein Vorgänger) Web-Seite osfaktura.de gnuaccounting.de Author Jan Hans Novak Jochen Stärk Firma Repkom usegroup Codezeilen 33300 18000 Downloads 7500+ Lizenz GPLv2+ GPLv2+ Beta geschlossen offen GUI Swing SWT Datenbank MySQL HSQLDB, MySQL Persistenz OJB Hibernate Scannen+ADF Ja Ja HBCI Nein Ja OpenOffice Geplant Ja Kontenrahmen - SKR03 Ust-Voranmeldung Nein Winston-Export Eigenformat - OBDX Telefonintegration Ja Nein E-Mail Integration Ja nur RE senden GPG-Signaturen Nein Ja Import von Refas KTimeTracker, Taskcoach, Moneyplex, Starmoney Lagerhaltung Ja Nein Anzahl Entwickler 1 2 Anzahl Anwender 0 2 Lines of Code osFaktura 296 unique files. 1393 files ignored. http://cloc.sourceforge.net v 1.08 T=4.0 s (67.0 files/s, 15597.5 lines/s) ------------------------------------------------------------------------------Language files blank comment code scale 3rd gen. equiv ------------------------------------------------------------------------------Java 243 8248 8500 XML 10 211 485 SQL 3 248 12 DTD 1 179 637 Bourne Shell 8 37 DOS Batch 3 8 33366 x 1.36 = 8785 x 1.90 = 45377.76 16691.50 1353 x 2.29 = 3098.37 216 x 1.90 = 410.40 84 x 3.81 = 320.04 5 4 12 x 0.63 = 7.56 ------------------------------------------------------------------------------SUM: 268 8931 9643 43816 x 1.50 = 65905.63 ------------------------------------------------------------------------------- Gnuaccounting 148 unique files. 484 files ignored. http://cloc.sourceforge.net v 1.08 T=2.0 s (63.5 files/s, 14612.0 lines/s) ------------------------------------------------------------------------------Language files blank comment code scale 3rd gen. equiv ------------------------------------------------------------------------------Java 119 Bourne Shell 3967 3 372 XML 3 13 XSD 1 0 DOS Batch 1 2926 309 1 25276.96 2118 x 3.81 = 8069.58 840 x 1.90 = 0 0 18586 x 1.36 = 88 x 1.90 = 0 1596.00 167.20 4 x 0.63 = 2.52 ------------------------------------------------------------------------------SUM: 127 4352 3236 21636 x 1.62 = ------------------------------------------------------------------------------- 35112.26