/* private Events */ +Silvester
[stratum0-wiki.git] / Schatzkarte.mw
1 {{Projekt|verantwortlich=[[Schatzmeister]]|status=aktiv|beschreibung=Eine Übersicht über die Buchführung des Schatzmeisters für den Verein.}}
2
3 ==Ziel dieser Seite==
4 Ziel dieser Seite ist die Dokumentation der Struktur der Buchführung für den Verein. Die Dokumentation soll dabei zum Einen einen Überblick über die Aktivitäten im Hintergrund geben und zum Anderen als Anleitung für zukünftige Schatzmeister und Kassenprüfer gelten.
5
6 Diese Seite soll aber keine Einführung in JVerein sein. Das ist auf deren [http://www.jverein.de/wiki/index.php?title=Hauptseite Webseite] aktueller.
7
8 ==Arbeitsumgebung==
9 ===JVerein===
10 Als Buchhaltung kommt JVerein zum Einsatz. Prinzipiell unterstützt JVerein den Einsatz eines SQL-Servers im Netzwerk als Backend. Um allerdings Änderungen an der Datenbank ebenfals Versionieren zu können, setzen wir JVerein mit einer lokalen Datenbank ein.
11
12 ===Versionverwaltung===
13 Alle finanz-relevanten Daten liegen in einem git. In dem Repository werden dabei rücksicktslos auch Binärdateien eingecheckt. Es gibt ein zentral gehostetes Repository, über das die Arbeitskopien synchron gehalten werden.
14
15 Das Repo hat folgende Struktur:
16 ./s0v-finanz
17 |- .jameica Arbeitsverzeichnis von JVerein.
18 |- 2012 Buchführung und Belege für 2011 und 2012.
19 |- Buchfuehrung2012.ods Buchführung des Vereins bis Ende 2012. Dient nur noch als Referenz.
20 Die Daten wurden ins JVerein übernommen.
21 |- Belege Verzeichnis mit digitalen Kopien der Buchungsbelege
22 |- 2013
23 |- Belege Verzeichnis mit digitalen Kopien der Buchungsbelege
24 |- Jahresbericht Verzeichnis mit dem Jahresbericht des Schatzmeisters
25 |- Prüfung Verzeichnis mit Unterlagen zur Kassenprüfung
26 |- Auswertungen Auswertungen der Datenbank, z.B. Mitgliedskontenauszüge
27 |- Vorlagen Vorlagen rund um das Schatzmeistern
28
29 Die Struktur des Ordners 2013 wiederholt sich für alle weiteren Jahre.
30
31 ===Erweiterte Toollandschaft===
32 Um das Jverein als zentrales Tool sind im Laufe der Zeit weitere Tools als Helfer entstanden:
33 * [https://gitli.stratum0.org/stratum0/jverein-regressionstests jverein-regressionstests]
34 ** Test-suite, die in einem Post-Commit Hook des Git-Hosts durchgeführt wird.
35 ** Mit den Tests sollen regelmäßig bei den Kassenprüfung auftretende Fehler vor der Kassenprüfung gefunden werden.
36 * [https://gitli.stratum0.org/stratum0/H2SqlServer H2SqlServer]
37 ** Stellt eine Socket-Schnittstelle auf die H2SQL-Datenbank JVereins zur Verfügung. Wird von weiteren Tools genutzt, um Änderungen und Auswertungen an der Datenbank durchführen zu können.
38 ** Es gibt eine Client-Library für Python, die direkt mit diesem Server sprechen kann.
39 * [https://gitli.stratum0.org/stratum0/jverein-zuwendungsbescheinigung jverein-zuweundungsbescheinigung]
40 ** Erstellt aus Mitgliedskontoauszügen automatisiert Zuwendungsbescheinigungen für Mitgliedsbeiträge als PDF.
41 ** Enthält auch ein Latex-Template für die Zuwendungsbescheinigungen.
42 * [https://gitli.stratum0.org/stratum0/finanz-helper finanz-helper]
43 ** Sammlung von mehreren kleinen Tools.
44 ** Erstellen von Buchungsbelegen für folgende Fälle:
45 *** Bar-Einzahlung in ein internes Konto
46 *** Umbuchung zwischen internen Konten
47 ** Senden aller Mitgliedskontoauszüge aus einem Ordner an das jeweilige Mitglied
48 * [https://gitli.stratum0.org/stratum0/jverein-beitragshelfer jverein-beitragshelfer]
49 ** Tool zum automatisierten Zuordnen von eingegangenen Buchungen zu den entsprechenden Mitgliedern.
50 * DEPRECATED [https://gitli.stratum0.org/stratum0/jverein-guthabenstat jverein-guthabenstat]
51 ** Tool zum Erstellen einer tageweisen Guthabenstatistik über alle Konten.
52 ** Der Export kann anschließend z.B. im Finanzbericht eingesetzt werden.
53 ** Sollte irgendwann einmal durch einen ReWrite ersetzt werden.
54 * DEPRECATED [https://gitli.stratum0.org/stratum0/jverein-member-reports jverein-member-reports]
55 ** Tool zum Erstellen der Mitgliedskontoauszüge
56 ** Sollte irgendwann einmal durch einen ReWrite ersetzt werden.
57 * DEPRECATED [https://gitli.stratum0.org/stratum0/jverein-finance-report jverein-finance-report]
58 ** Tool zum Erstellen von Finanz-Statistiken über den Verein.
59 ** Sollte irgendwann einmal durch einen ReWrite ersetzt werden.
60
61 ==Operatives==
62 ===Konten im JVerein===
63 Für den Verein werden im JVerein mehrere Konten mit unterschiedlichen Aufgaben abgebildet. Ein Konto kann dabei z.B. sein: Das Girokonto, die Barkasse, etc. Jedes Konto kann dabei in Unterkonten gegliedert sein.
64
65 Es gilt dabei folgendes:
66 * Ein (Haupt-) Konto ist dabei jeweils die Kasse bzw. das Konto in dem das Geld wirklich liegt. Hauptkonten haben als Kontonummer eine Zahl.
67 * Interne (Haupt-) Konten haben immer eine dreistellige Nummer. Externe (z.B. das Giro) haben wahrscheinlich eine längere.
68 * Unterkonten sind eine Segmentierung eines Hauptkontos. Dabei wird eine Menge Geld in einem Haupt-Konto für einen speziellen Zweck reserviert.
69 * Unterkonten werden durch Anhängen des Suffix "-$N" gebildet. Dabei ist $N der fortlaufende Index der Unterkonten des Hauptkontos.
70 * Die Summe der Beträge in einem Haupt- und seiner Unterkonten entspricht der Menge an Geld die tatsächlich in dieser Ablage vorhanden ist.
71 * Jedes Konto trägt am Anfang seines Namens einen Buchstaben als Kennung. Dieser Buchstabe wird bei der Bildung der Belegnummer verwendet.
72
73 Bei Erstellung des Artikels vorhandene Konten:
74 100 (B) Barkasse Stratum0
75 100-1 (D) 3D-Drucker Filamentspenden
76 100-2 (P) Pfand für Physische Schlüssel
77 100-3 (F) Spenden for Plotter-Material
78 100-4 (S) Spenden für Material Stickmaschine
79 101 (V) Erstattungskasse Verbrauchsmaterial
80 102 (M) Matekasse
81 200024917 (G) Girokonto des Vereins
82 200*-1 (R) Rückstellungen Giro
83
84 Wird Geld zwischen Konten verschoben, muss im JVerein eine Umbuchung zwischen den Konten stattfinden. Dies gilt auch, wenn eine Umbuchung zwischen Haupt- und Unterkonto stattfindet, z.B. wenn Geld aus einem Konto mit Zweckbindung in das zugehörige Hauptkonto verschoben wird.
85
86 ====Konto: Barkasse====
87 Konto, dass nicht zweckgebundenes Geld enthält.
88
89 ====Konto: 3D-Drucker Filamentspenden====
90 Konto mit zweckgebundenem Geld aus der 3D-Druck Spendenbox
91
92 ====Konto: Pfand für Physische Schlüssel ====
93 Konto mit für ausgegebene Schlüssel eingenommenes Pfand. Geld ist nicht für operatives Geschäft verfügbar, da es bei Rückgabe des Schlüssels ebenfalls zurückgegeben werden muss.
94 Für die Dokumentation der Schlüsselübergabe gibt es ein Template in:
95 ./s0v-dokumente/vorlagen/Schluesselquittung.odt
96
97 ====Konto: Spenden for Plotter-Material====
98 Konto mit zweckgebundenem Geld aus der Plotter Spendenbox.
99
100 ====Konto: Spenden für Material Stickmaschine====
101 Konto mit zweckgebundenem Geld aus der Stickmaschinen Spendenbox.
102
103 ====Konto: Erstattungskasse Verbrauchsmaterial====
104 Kasse, die im Space steht und es Mitgliedern erlaubt sich Verbrauchsmaterial direkt und ohne Antrag an den Vorstand selber zu erstatten. Dies soll Mitglieder motivieren notwendiges Verbrauchsmaterial selbständig zu beschaffen und das Geld dafür unbürokratisch zurück zu bekommen.
105 Die Kasse wird i.d.R. mit 20 bis 50€ "aufgeladen", wenn die Einlage zu gering geworden ist.
106
107 In dieser Kasse ist durch die Mitglieder ein Kassenbuch zu führen, dass alle Geldbewegungen abbildet.
108
109 ====Konto: Matekasse====
110 Kasse des Space-Kiosk für Getränke und Süßkram.
111
112 In dieser Kasse ist durch die Mitglieder ein Kassenbuch zu führen, dass alle Geldbewegungen abbildet.
113
114 ====Konto: Girokonto====
115 Girokonto. Konto, dass nicht zweckgebundenes Geld enthält.
116
117 ====Konto: Rückstellungen Giro====
118 Auf diesem Konto sind Gelder für zu erwartende Sonderausgaben besonders allokiert.
119
120
121 {{Todo| Virtuelle Konten}}
122 ===Buchungsklassen und Buchungsarten===
123 Die Buchungsklassen und Buchungsarten dienen der Gruppierung der Gewinn-und-Verlust-Rechnung des Vereins.
124
125 Buchungsarten werden in Buchungsklassen gruppiert. Innerhalb Buchungsklassen selber werden danach auch wieder Ein- und Ausgaben gruppiert.
126
127 Die Buchungsklassen haben dabei folgende Struktur:
128 * 1000er-Klassen: Einnahmen des Vereins
129 * 2000er-Klassen: Ausgaben des Vereins
130 * 3000er-Klassen: Umbuchungen zwischen Vereinskonten
131
132 Innerhalb dieser Klassen können somit einzelne Buchungsklassen für bestimmte Zwecke definiert werden:
133
134 1000 Einnahmen
135 |- 1001 Mitgliedsbeitrage
136 |- 1002 Spenden
137 2000 Ausgaben
138 |- 2001 Verein
139 |- 2002 Space
140 3000 Umbuchungen
141 |- 3000 Umbuchungen
142
143 Die Strukturierung in Buchungsklassen und Buchungsarten sollte so feingliedrig gewählt werden, dass sie übersichtlich Darstellt, welche (finanziellen) Aktivitäten im Verein stattgefunden haben. Diese Struktur wird sowohl für den Finanz-Jahresbericht, als auch für die Steuererklärung gegenüber dem Finanazamt herangezogen.
144
145 ===Mitgliedsbeitrag===
146 JVerein führt für jedes Mitglied ein Mitgliedskonto. Auf diesem werden die fälligen Beiträge (SOLL-Buchungen) (anhand der Beitragsklassen bzw. der Abrechnungsläufe, sowie besonders angelegter Fälligkeiten) und die gezahlten Mitgliedsbeiträge (IST-Buchungen) gegenüber gestellt.
147
148 Ein Mitgliedskonto ist im JVerein allerdings kein echtes Konto mit Buchungsvorfällen, sondern eine Liste von SOLL-Buchungen. An jede SOLL-Buchung kann anschließend genau eine IST-Buchung angehangen werden. JVerein geht also, davon aus, jedes Mitglied jede Fälligkeit mit genau einer Buchung begleicht - was natürlich im Stratum 0 nicht der Fall ist. Das führt an manchen Stellen zu interessantem Verhalten der Software.
149
150 Im Stratum 0 ist Mitgliedsbeitrag monatlich fällig. Daher wird für jeden Monat ein Abrechnungslauf durchgeführt und somit SOLL-Buchungen auf allen Mitgliedskonten erzeugt.
151
152 Mitgliedsbeiträge gehen dem Verein nur durch Überweisungsgutschriften, sowie Bar-Einzahlungen zu. Lastschrift wird nicht angeboten.
153
154 ==== Beitragsklassen ====
155 Im JVerein können Beitragsklassen als Presets für den fälligen Mitgliedsbeitrag je Abrechnungszeitraum angelegt werden. Hierfür sind typischerweise Vollzahler und ermäßigte Zahler definiert.
156 Diese Presets können allerdings für jedes Mitglied individuell überschrieben werden.
157
158 Zahlt ein Mitglied einen durch ein Preset abgedeckten Mitgliedsbeitrag, so sollte auch dieses Preset verwendet werden.
159
160 Zahlt ein Mitglied einen anderen Beitrag, so kann ein individueller Beitrag das Preset überschreiben. Individuelle Beiträge sind z.B. für Mitglieder mit individuellem Beitrag und Fördermitglieder üblich.
161
162
163 ==== Abrechnungslauf durchführen ====
164 Beim durchführen eines Abrechnungslauf sind folgende Schritte zu beachten:
165 * Als Stichtag für die Abrechung sollte der letzte des Monats angegeben werden. Somit werden auch Mitglieder erfasst, die im Laufe des Monats eingetreten sind (und für die auch Mitgliedsbeitrag für einen ganzen Monat fällig wird).
166 * JVerein möchte umbedingt angegebene SEPA-Fälligkeiten haben. Da kann man den vorgeschlagenen Wert akzeptieren.
167 * Abrechnungsziel ist "Alle".
168 * Freitext der Abrechnung ist "Mitgliedsbeitrag MM.YYYY".
169 * Nach einem Klick auf den "Make it so"-Button muss man die von JVerein generierten XML-Dateien speichern. Diese werden im Weiteren nicht benötigt - ohne diesen Schritt führt JVerien die Abrechnung allerdings nicht durch.
170
171 ==== Zuordnung der monatlichen IST-Buchungen ====
172 Um das Zuordnen der monatlich eingehenden Mitgliedsbeiträge auf die Mitgliedskonten zu erleichtern gibt es das Tool [https://gitli.stratum0.org/stratum0/jverein-beitragshelfer jverein-beitragshelfer]. Um dieses Tool einzusezten sind folgende Schritte notwendig:
173 * Durchführen des Abrechnungslauf.
174 * Import der neuen Buchungen vom Giro-Konto ins Hibiscus und ins JVerein.
175 * JVerein schließen.
176 * jverein-beitragshelfer:allocate.py ausführen.
177 ** Dieses Tool benötigt den H2SqlServer. Um es möglichst einfach zu Starten wird das Script ./s0v-finanz/allocate.sh eingesetzt.
178 ** Dieses Tool verwendet in ./s0v-finanz/allow.csv abgelegte Muster zur Zuordnung der Buchungen zu den Mitgliedern. Diese Datei ist ist Teil des Repos.
179 ** Das Tool ordnet möglichst viele Buchungen anhand der Muster zu.
180 * JVerein öffnen und verbleibende Buchungen von Hand zuordnen.
181
182
183 ===Buchungen===
184 {{Todo|Buchungsbegriff}}
185 {{Todo|Dokumentation einer Buchung (notwendige und optionale Angaben, Belegnummer, UB-Nummer)}}
186 {{Todo|Umbuchen zwischen Konten}}
187 [[Kategorie:Dokumentation]][[Kategorie:Verein]]
This page took 0.062435 seconds and 5 git commands to generate.