This is the Shop System of Oldenburg's Hackspace Mainframe. The software has been developed as a credit based system for members of the hackspace. The system depends on a cheap serial barcode scanner, which is used to establish user sessions (by scanning CODE39 based user codes) and buying products (by scanning their EAN). The members receive an invoice at the end of the month, which is also send to the hackspace's treasurer for further processing. Since the user barcodes do not contain any advanced authentication mechanism, security is established by sending daily mails in addition to the monthly invoice mail. The daily mail (which is only sent if something has been bought) lists all products bought by the member on this day and the current total sum for the month. The system provides the following features: * time shifted daily mails (08:00-07:59 of the following day), so that there is a lower chance of purchases from one visit being split over two mails. * native rendering of PDF invoices using Cairo (fast & lightweight) * invoice mails are sent using text/plain and text/html * support for sending a database backup to a mail address * curses based user interface * basic audio support The system administration is done using a simple web interface, which provides support for the following tasks: * adding information about new products * restocking products * changing selling prices of products * updating the user database by importing a userlist.csv (regularly generated by our treasurer) The system consists of multiple daemons written in Vala, which communicate with each other using DBus. Build Dependencies: * apt install build-essential valac libesmtp-dev libgpgme11-dev libncursesw5-dev libncurses5-dev libgee-0.8-dev libgmime-2.6-dev libarchive-dev libgstreamer1.0-dev libgtk2.0-dev librsvg2-dev libsoup2.4-dev libsqlite3-dev libpango1.0-dev libssl-dev dbus-x11 policykit-1 Additional runtime dependencies: * apt install fonts-lmodern gstreamer1.0-alsa gstreamer1.0-plugins-base Suggested runtime dependencies: * apt install sqlite3 == Installation == You can install to different location or use a different username, but you need to modify a few things. === Git Setup === * adduser "shop" with homedir in /home/shop * clone git repository into /home/shop/serial-barcode-scanner === Build and Install the Software === * meson build --prefix /usr * cd build * ninja * ninja install === Systemd === * cd systemd * sudo make install === Configuration === * mv example.cfg ktt-shopsystem.cfg * edit ktt-shopsystem.cfg === Database === * Create initial account with super user permissions `busctl --system call io.mainframe.shopsystem.Database /io/mainframe/shopsystem/database io.mainframe.shopsystem.Database UserReplace "(issssssssxbbsas)" "" "" "" "" "" "" "" "" "" 0 0 0 "" 0` `busctl --system call io.mainframe.shopsystem.Database /io/mainframe/shopsystem/database io.mainframe.shopsystem.Database SetUserPassword "is" "" ""` `busctl --system call io.mainframe.shopsystem.Database /io/mainframe/shopsystem/database io.mainframe.shopsystem.Database SetUserAuth "(ibbbb)" "" 1 1 1 1` * Demo Data `busctl --system call io.mainframe.shopsystem.Database /io/mainframe/shopsystem/database io.mainframe.shopsystem.Database AddCategory "s" "Getränke"` `busctl --system call io.mainframe.shopsystem.Database /io/mainframe/shopsystem/database io.mainframe.shopsystem.Database AddSupplier "ssssss" "Demo Lieferant" "12345" "Musterstadt" "Musterstr. 5" "+49 1234 56789" "https://www.example.org"` It's also possible to directly access the database. While there are some triggers to keep the database in a sensible state, please be careful with direct database transactions. For accessing the database in write mode, you need to kill the shopsystem database process first. It will be restarted by any process, that needs the database DBus API. * `pkill -15 shop-database` * `sqlite3 /path/to/shopsystem.db` === Display on / off via MQTT === You can control display power via MQTT by configuring the MQTT settings (i.e. BROKER, TOPIC) in the config file. == Customize Your Shop == Edit the Logo in the logo.txt File. A helpful tool you will found here [http://patorjk.com/software/taag/](http://patorjk.com/software/taag/)