Kassomat: Unterschied zwischen den Versionen

aus Metalab Wiki, dem offenen Zentrum für meta-disziplinäre Magier und technisch-kreative Enthusiasten.
Zur Navigation springenZur Suche springen
(Bild hinzugefügt, Videos entfernt, da nicht mehr verfügbar)
 
(148 dazwischenliegende Versionen von 11 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
== WTF ==
[[Datei:Kassomat 2022.jpg|mini|rechts|Kassomat]]
Eine selbstgebaute Kassa mit Touchinterface, die (parallel??/ersatz??) zur offenen Kassa im Einsatz sein soll, die verhindern soll dass nicht einfach so mehrere Geldscheine aus der Kassa verschwinden. Zusaetzlich eroeffnen sich angenehme Funktionalitaet wie zB: iButton Credits, automatische Buchhaltung, Lazzzor Jobs erfassen, Barcode Scanner,.. whatnot.


== Kontakt ==
{{Projekt
[[User:Vierlex]] fuehlt sich verantwortlich.
|image=KASSOMAT.png
Mailingliste gibt es auch! kassomat@lists.metalab.at
|involved=[[User:anlumo]] [[User:m68k]] [[User:ripper]] [[User:phaer]] [[User:hetti]]
|startdate=XX.10.2012
|status=in progress
|wtf=box which changes banknotes into coins
}}


== was bisher geschah... ==
== Kassomat ==
* '''18.11.12''' erstes offizielles Orga Treffen eigentlich nur zum Thema Gehaeuse. Es ist schwerer als gedacht eine kostenguenstige und professionelle Lösung zu finden (zu dem das Budget sich verschmälert hat, siehe unten). Weitere Recherche nach geeignetem Material oder bereits fertigen Boxen nötig.
* <strike>'''WICHTIG''' erstes Organisations treffen in Planung! am '''18.11'''</strike>
* '''14.11.12 (nachtrag)''' ersteigerter NV200 ist NICHT erweiterbar mit einem Smartpayout Modul, daher muss alles neu angeschaft werden. dadurch erhöhen sich die Kosten auf 850€ OHNE Gehaeuse!
* '''7.11.12''' erstes UI Brainstorming. gar nicht so einfach.
* '''5.11.12''' you can has http://piratepad.net/CUBI9uXphb (fuer Planung und Organisation) and https://github.com/vierlex/kassomat


* '''1.11.12''' [[User:Vierlex]] schaut sich die low-level API [http://www.innovative-technology.co.uk//images/pdocuments/sspdoc/GA138%202_0_0.pdf PDF] der Geraete an. NV200 (ohne Smart Payout Modul) um 160€ ersteigert. Hat auch um C Libraries bei [http://www.innovative-technology.co.uk inovative technology] angefragt
payoutd controls the hardware and feeds events into redis queues where other tools may pick them up.
Changeomatic listens to events in those redis queues and allows users to change banknotes into coins.
The protocol is documented in the [https://github.com/metalab-kassomat/kassomat-payout/blob/master/docs/overview.md payoutd repository]. People who are interested in implementing a more advanced POS system are very welcome to do so! :)
There is now an [https://github.com/metalab-kassomat umbrella organization] on github which contains all the sub-projects listed below.


== ..und was grad ur wichtig is: ==
'''''Please note:''' From 6/2021 on the manufacturer of Smart Hopper (coin unit) and NV200 (banknotes) will no longer provide new currency or firmware updates. No spare parts, too.'' [https://metalab.at/wiki/Datei:Innovative_Technology_Ltd_-_Obsolete_Products_Notification.pdf cf. PDF]
'''GEHÄUSE!'''<br>
Derzeit gibt es keinen konkreten Plan zum Gehäuse. Ein bisschen weiter unten findet man die 3 Hardwareteile die man unter ein Dach bringen muss. Ob Metall, Holz, Acryl oder Beton,.. Wenn jemand eine KOSTENGÜNSTIGE Idee hat, wie und aus welchem Material so ein Gehäuse gestalten kann, immer nur her damit. Rahmenbedingungen:
* unter 100€
* möglichst schwer.
* Komponenten (ausser Laptop) sollten gut zugänglich sein. Komponeten muss man selten aber doch auch auseinander nehmen können.(Maße Datenblatt kommt noch)
* soll nicht leicht/leise aufbrechbar sein.
* Platz der Komponenten (wenn nebeneinander gestellt+Laptop-Motherboard oben drauf): ~ 24x40x29 cm


== Hardware ==
== Kassomat/VM ==
*  NV200 (<strike>hat [[User:Vierlex]] auf ebay um '''160€''' ersteigert! </strike>neu: '''450€''') + Smart Payout Modul (neu: '''200€''')
** [http://www.coinoperatorshop.com/Banknoten-pruefen-zaehlen-ausgeben/Banknotenleser/Leser/NV200-mit-Smart-Payout.html zum Shop] Diese Machinerie verwaltet Banknoten, hier wird ein zusaetzliches Modul benoetigt umd
*  Smart Hopper ('''190€''')
** [http://www.coinoperatorshop.com/Muenzen-zaehlen-pruefen-ausgeben/Muenzauszahlung/Hopper/Smart-Hopper/Smart-Hopper.htm zum Shop] Kann Muenzen pruefen und retour geben. Auf ebay daweil nciht gesichtet.
* <strike>Raspberry Pi ('''35€''') + Touchscreen ('''0€''') ODER</strike> Touchscreen Laptop ('''0€''')
** als Rechenpower und Interface. Auf der Mailingliste will [[User:overflo]] einen Touchscreen spenden, sowie noch jemand einen Laptop mit Touchscreen.
* GEHAEUSE! ('''?€''')
** eine Stahlbox? kein Plan daweil<br />''Einen "Elektronischen Safe" gibts schon [http://www.conrad.de/ce/de/product/777733/Elektronischer-Safe-mit-LCD ab etwa 50 Euro]. Eine beliebig gewählte [http://www.conrad.de/ce/de/product/777734/Dokumenten-Safe-mit-elektronischem-Schloss/0801076&ref=list größere Variante für 109,-]<br /> Ein solcher Preis ist im Selbstbau schwer zu erreichen - und das Ding schließt dann auch richtig.'' --[[Benutzer:Pk|Pk]] 13:09, 5. Nov. 2012 (CET)
'''* Gesamt (zur Zeit): 850€ + ?€ (Gehaeuse)'''


<gallery>
Instead of installing a lot of packages and requirements you could opt to use [https://www.virtualbox.org VirtualBox] and [https://www.vagrantup.com Vagrant]. The [https://github.com/metalab-kassomat/kassomat-vm kassomat-vm] repository contains all the necessary files to get a fully provisioned virtual machine (it is even possible to plug the actual hardware into your host and use it from inside the vm).
File:Meta_kassa_Smartpayout.jpg|[http://www.coinoperatorshop.com/Banknoten-pruefen-zaehlen-ausgeben/Banknotenleser/Leser/NV200-mit-Smart-Payout.html NV200+Smart Payout]
File:Meta_kassa_Smarthopper.jpg|[http://www.coinoperatorshop.com/Muenzen-zaehlen-pruefen-ausgeben/Muenzauszahlung/Hopper/Smart-Hopper/Smart-Hopper.htm Smart Hopper]
File:Meta_kassa_M912V.jpg|Touchscreen Laptop [http://en.wikipedia.org/wiki/Gigabyte_M912 Gigabyte M12V]
</gallery>


== Was gibts zu tun? (und wer machts) ==
== Components ==
* Gehaeuse? Aus was und wie bauen? Was soll es koennen? Tuer noetig?
** [[User:Zwax]]
* Welche Linux Distro auf dem Laptop?
* Wie verbindet man Geldcheckhardware mit Laptop?
** [[User:Vierlex]]
* API von Herstellerfirma checken (haben fuer Linux/C++ auch was)
** [[User:Vierlex]]
* Welche Fehlerfaelle gibt es bei der Hardware?
* Wie lauft der Bezahlvorgang ab?
* Wie schaut die UIX aus?
** [[User:anlumo]]
* Wie soll die Datenbank ausschauen?
* Datenbank Backup Moeglichkeit?
* Frontend implementieren
** [[User:redplanet]], [[User:Vierlex]]
* Backened implementieren
** [[User:redplanet]], [[User:Vierlex]]


== wann fertig? ==
* '''Changeomatic'''
** [https://github.com/metalab-kassomat/kassomat-changeomatic Source]
** Written in Java, can be built (and run) with [https://maven.apache.org/ Maven]
*** build: <code>mvn install</code>
*** run: <code>mvn exec:java -Dexec.mainClass="at.metalab.changeomatic.ChangeomaticMain"</code>
** UI: Graphical Swing Frontend
** libs
*** [http://redisson.org/ Redisson] (Redis client)
*** [https://github.com/FasterXML/jackson Jackson] (JSON library)


Wenn es von Core das OK gibt dann schaetze ich ([[User:Vierlex]]) wuerde das ganze ca 4 Monate dauern bis ein funktionierender Prototyp fertig ist. Dieser ist noch nicht fuer den regelmaessigen Betrieb gedacht, erst nach exzessivem Testen. '''ca. Mitte Februar '13'''


== und was kann der dann? ==
* '''Maintenance Mode Application'''
** [https://github.com/metalab-kassomat/kassomat-scripts Source]
** Written in Python
*** set the coin levels: <code>./kassomat-set-coin-levels.py</code>
*** count the coins (n.b. '''this will dump all coins through the bottom opening!'''): <code>./kassomat-count-coins.py</code>
** UI: Console interface
** libs
*** [https://pypi.python.org/pypi/redis redis]


Der erste Prototyp inkludiert ein Touchinterface mit man ein Getraenk auswaehlen kann. Man kann mit Muenzen oder mit Geldscheinen zahlen und bekommt entsprechend wieder Muenzen und/oder Scheine als Retourgeld zurueck.


Zusaetzlich soll es eine grundlegende Dokumentation (geschriebener Code dokumentiert, wie ist er zu erweitern ) und Wartungsmanual (wie entleere ich das Ding, was tun wenns spinnt) geben.
* '''Payout'''
** [https://github.com/metalab-kassomat/kassomat-payout Source]
** Written in C, can be built with make
** Linux daemon
** [https://github.com/metalab-kassomat/kassomat-payout/blob/master/docs/overview.md JSON API] (accessible via Redis)
** UI: none
** libs
*** [https://github.com/redis/hiredis hiredis] (Redis client)
*** [http://libevent.org libevent2] (Event Dispatching)
*** [http://www.digip.org/jansson/ libjansson] (JSON library)
*** [https://sourceforge.net/projects/libuuid/ libuuid]
*** ITL example code (aka "vendor hardware library")


== zukunftsmusik ==


zeug was man noch tun kann.
* '''Payout Simulator''' ''for development without the real hardware''
** [https://github.com/metalab-kassomat/kassomat-payout-simulator Source]
** Written in Java, can be built (and run) with [https://maven.apache.org/ Maven]
*** build: <code>mvn install</code>
*** run: <code>mvn exec:java -Dexec.mainClass="at.metalab.payoutsim.PayoutSimMain"</code>
** UI: Graphical Swing Frontend
** libs
*** [http://redisson.org/ Redisson] (Redis client)
*** [https://github.com/FasterXML/jackson Jackson] (JSON library)


* Strichcodeerkennung ueber die Webcam.
 
* Logging der verschiedenen Einnahmen (fuer Buchhaltung interessant und Statistiken: Mate-konsum um welche Uhrzeiten am meisten verkauft?)
* '''[http://redis.io/ Redis]'''
* Lazzzor Jobs bezahlen
** message broker between the different components (Changeomatic, Payout and the Maintenance Mode Application)
* iButton mit Credits
** not used as a datastore!
* Vinyldrucker Jobs bezahlen
 
* Druckerauftraege bezahlen
[[Datei:kassomat-overview.png|500px|thumb|left|Overview of the various components]]
* Custom Bezahlauftrag (wieviel/wofuer)


[[Kategorie:Projekte]]
[[Kategorie:Projekte]]

Aktuelle Version vom 20. Mai 2022, 22:00 Uhr

Kassomat



Kassomat
KASSOMAT.png
Gestartet: XX.10.2012
Involvierte: User:anlumo User:m68k User:ripper User:phaer User:hetti
Status: in progress
Beschreibung: box which changes banknotes into coins
Shutdownprozedur:
Zuletzt aktualisiert: 2022-05-20


Kassomat

payoutd controls the hardware and feeds events into redis queues where other tools may pick them up. Changeomatic listens to events in those redis queues and allows users to change banknotes into coins. The protocol is documented in the payoutd repository. People who are interested in implementing a more advanced POS system are very welcome to do so! :) There is now an umbrella organization on github which contains all the sub-projects listed below.

Please note: From 6/2021 on the manufacturer of Smart Hopper (coin unit) and NV200 (banknotes) will no longer provide new currency or firmware updates. No spare parts, too. cf. PDF

Kassomat/VM

Instead of installing a lot of packages and requirements you could opt to use VirtualBox and Vagrant. The kassomat-vm repository contains all the necessary files to get a fully provisioned virtual machine (it is even possible to plug the actual hardware into your host and use it from inside the vm).

Components

  • Changeomatic
    • Source
    • Written in Java, can be built (and run) with Maven
      • build: mvn install
      • run: mvn exec:java -Dexec.mainClass="at.metalab.changeomatic.ChangeomaticMain"
    • UI: Graphical Swing Frontend
    • libs


  • Maintenance Mode Application
    • Source
    • Written in Python
      • set the coin levels: ./kassomat-set-coin-levels.py
      • count the coins (n.b. this will dump all coins through the bottom opening!): ./kassomat-count-coins.py
    • UI: Console interface
    • libs


  • Payout
    • Source
    • Written in C, can be built with make
    • Linux daemon
    • JSON API (accessible via Redis)
    • UI: none
    • libs


  • Payout Simulator for development without the real hardware
    • Source
    • Written in Java, can be built (and run) with Maven
      • build: mvn install
      • run: mvn exec:java -Dexec.mainClass="at.metalab.payoutsim.PayoutSimMain"
    • UI: Graphical Swing Frontend
    • libs


  • Redis
    • message broker between the different components (Changeomatic, Payout and the Maintenance Mode Application)
    • not used as a datastore!
Overview of the various components