summaryrefslogtreecommitdiffstats
path: root/src/scanner-session/scannersession.vala
diff options
context:
space:
mode:
authorHolger Cremer <HolgerCremer@gmail.com>2015-06-11 20:47:03 +0200
committerHolger Cremer <HolgerCremer@gmail.com>2015-06-12 19:31:23 +0200
commit9d61f22844bdfcbe983976aaf5176d08e741a6de (patch)
tree8cb3f04507eda40c902337ee40dfc8c044007781 /src/scanner-session/scannersession.vala
parent609f72b68df7d8c5a029d5faf1867ef68a5ff6ef (diff)
downloadserial-barcode-scanner-9d61f22844bdfcbe983976aaf5176d08e741a6de.tar.bz2
a simple cli interface to send barcodes
Diffstat (limited to 'src/scanner-session/scannersession.vala')
-rw-r--r--src/scanner-session/scannersession.vala388
1 files changed, 196 insertions, 192 deletions
diff --git a/src/scanner-session/scannersession.vala b/src/scanner-session/scannersession.vala
index 9e87682..8d89593 100644
--- a/src/scanner-session/scannersession.vala
+++ b/src/scanner-session/scannersession.vala
@@ -15,196 +15,200 @@
[DBus (name = "io.mainframe.shopsystem.ScannerSession")]
public class ScannerSessionImplementation {
- private int user = 0;
- private string name = "Guest";
- private bool logged_in = false;
- private bool disabled = false;
- private string theme = "beep";
-
- private Database db;
- private AudioPlayer audio;
- private SerialDevice dev;
-
- public signal void msg(MessageType type, string message);
- public signal void popup(string title, string message);
-
- public ScannerSessionImplementation() {
- try {
- db = Bus.get_proxy_sync(BusType.SESSION, "io.mainframe.shopsystem.Database", "/io/mainframe/shopsystem/database");
- dev = Bus.get_proxy_sync(BusType.SESSION, "io.mainframe.shopsystem.SerialDevice", "/io/mainframe/shopsystem/device");
- audio = Bus.get_proxy_sync(BusType.SESSION, "io.mainframe.shopsystem.AudioPlayer", "/io/mainframe/shopsystem/audio");
-
- dev.received_barcode.connect(handle_barcode);
- } catch(IOError e) {
- error("IOError: %s\n", e.message);
- }
- }
-
- private void send_message(MessageType type, string format, ...) {
- var arguments = va_list();
- var message = format.vprintf(arguments);
-
- msg(type, message);
- }
-
- private void logout() {
- logged_in = false;
- }
-
- private bool login(int user) throws IOError {
- this.user = user;
- try {
- this.name = db.get_username(user);
- this.disabled = db.get_user_auth(user).disabled;
- } catch(DatabaseError e) {
- send_message(MessageType.ERROR, "Error (user=%d): %s", user, e.message);
- return false;
- }
- this.logged_in = true;
-
- try {
- this.theme = audio.get_random_user_theme();
- } catch(IOError e) {
- this.theme = "beep";
- }
-
- return true;
- }
-
- private void handle_barcode(string scannerdata) {
- try {
- stdout.printf("scannerdata: %s\n", scannerdata);
- if(interpret(scannerdata))
- dev.blink(1000);
- } catch(IOError e) {
- send_message(MessageType.ERROR, "IOError: %s", e.message);
- } catch(DatabaseError e) {
- send_message(MessageType.ERROR, "DatabaseError: %s", e.message);
- }
- }
-
- private bool interpret(string scannerdata) throws DatabaseError, IOError {
- if(scannerdata.has_prefix("USER ")) {
- string str_id = scannerdata.substring(5);
- int32 id = int.parse(str_id);
-
- /* check if scannerdata has valid format */
- if(scannerdata != "USER %d".printf(id)) {
- audio.play_system("error.ogg");
- send_message(MessageType.ERROR, "Invalid User ID: %s", scannerdata);
- return false;
- }
-
- if(logged_in) {
- send_message(MessageType.WARNING, "Last user forgot to logout");
- logout();
- }
-
- if(login(id)) {
- audio.play_user(theme, "login");
- send_message(MessageType.INFO, "Login: %s (%d)", name, user);
- return true;
- } else {
- audio.play_system("error.ogg");
- send_message(MessageType.ERROR, "Login failed (User ID = %d)", id);
- return false;
- }
- } else if(scannerdata == "GUEST") {
- if(logged_in) {
- send_message(MessageType.WARNING, "Last user forgot to logout");
- logout();
- }
-
- if(login(0)) {
- audio.play_user(theme, "login");
- send_message(MessageType.INFO, "Login: %s (%d)", name, user);
- return true;
- } else {
- audio.play_system("error.ogg");
- send_message(MessageType.ERROR, "Login failed (User ID = 0)");
- return false;
- }
- } else if(scannerdata == "UNDO") {
- if(!logged_in) {
- audio.play_system("error.ogg");
- send_message(MessageType.ERROR, "Can't undo if not logged in!");
- return false;
- } else {
- string product = db.undo(user);
-
- if(product != "") {
- audio.play_user(theme, "purchase");
- send_message(MessageType.INFO, "Removed purchase of %s", product);
- return true;
- } else {
- audio.play_user(theme, "error");
- send_message(MessageType.ERROR, "Couldn't undo last purchase!");
- return false;
- }
- }
- } else if(scannerdata == "LOGOUT") {
- if(logged_in) {
- audio.play_user(theme, "logout");
- send_message(MessageType.INFO, "Logout!");
- logout();
- return true;
- }
-
- return false;
- } else {
- uint64 id = 0;
- scannerdata.scanf("%llu", out id);
-
- /* check if scannerdata has valid format */
- if(scannerdata != "%llu".printf(id) && scannerdata != "%08llu".printf(id) && scannerdata != "%013llu".printf(id)) {
- audio.play_user(theme, "error");
- send_message(MessageType.ERROR, "invalid product: %s", scannerdata);
- return false;
- }
-
- string name = "unknown product";
-
- try {
- name = db.get_product_name(id);
- } catch(IOError e) {
- audio.play_user(theme, "error");
- send_message(MessageType.ERROR, "Internal Error!");
- return false;
- } catch(DatabaseError e) {
- if(e is DatabaseError.PRODUCT_NOT_FOUND) {
- audio.play_user(theme, "error");
- var msg = "Error: unknown product: %llu".printf(id);
- send_message(MessageType.ERROR, msg);
- popup("Attention", msg);
- } else {
- audio.play_user(theme, "error");
- send_message(MessageType.ERROR, "Error: %s", e.message);
- }
- return false;
- }
-
- if(!logged_in) {
- var mprice = db.get_product_price(1, id);
- var gprice = db.get_product_price(0, id);
- var msg = @"article info: $name (Member: $mprice €, Guest: $gprice €)";
- audio.play_system("error.ogg");
- send_message(MessageType.INFO, msg);
- send_message(MessageType.ERROR, "Login required for purchase!");
- popup("Attention", "%s\nLogin required for purchase!".printf(msg));
-
- return false;
- }
-
- if(db.buy(user, id)) {
- var price = db.get_product_price(user, id);
- audio.play_user(theme, "purchase");
- send_message(MessageType.INFO, @"article bought: $name ($price €)");
- return true;
- } else {
- audio.play_user(theme, "error");
- send_message(MessageType.ERROR, "purchase failed!");
- return false;
- }
- }
- }
+ private int user = 0;
+ private string name = "Guest";
+ private bool logged_in = false;
+ private bool disabled = false;
+ private string theme = "beep";
+
+ private Database db;
+ private AudioPlayer audio;
+ private SerialDevice dev;
+ private Cli cli;
+
+
+ public signal void msg(MessageType type, string message);
+ public signal void popup(string title, string message);
+
+ public ScannerSessionImplementation() {
+ try {
+ db = Bus.get_proxy_sync(BusType.SESSION, "io.mainframe.shopsystem.Database", "/io/mainframe/shopsystem/database");
+ dev = Bus.get_proxy_sync(BusType.SESSION, "io.mainframe.shopsystem.SerialDevice", "/io/mainframe/shopsystem/device");
+ cli = Bus.get_proxy_sync(BusType.SESSION, "io.mainframe.shopsystem.Cli", "/io/mainframe/shopsystem/cli");
+ audio = Bus.get_proxy_sync(BusType.SESSION, "io.mainframe.shopsystem.AudioPlayer", "/io/mainframe/shopsystem/audio");
+
+ dev.received_barcode.connect(handle_barcode);
+ cli.received_barcode.connect(handle_barcode);
+ } catch(IOError e) {
+ error("IOError: %s\n", e.message);
+ }
+ }
+
+ private void send_message(MessageType type, string format, ...) {
+ var arguments = va_list();
+ var message = format.vprintf(arguments);
+
+ msg(type, message);
+ }
+
+ private void logout() {
+ logged_in = false;
+ }
+
+ private bool login(int user) throws IOError {
+ this.user = user;
+ try {
+ this.name = db.get_username(user);
+ this.disabled = db.get_user_auth(user).disabled;
+ } catch(DatabaseError e) {
+ send_message(MessageType.ERROR, "Error (user=%d): %s", user, e.message);
+ return false;
+ }
+ this.logged_in = true;
+
+ try {
+ this.theme = audio.get_random_user_theme();
+ } catch(IOError e) {
+ this.theme = "beep";
+ }
+
+ return true;
+ }
+
+ private void handle_barcode(string scannerdata) {
+ try {
+ stdout.printf("scannerdata: %s\n", scannerdata);
+ if(interpret(scannerdata))
+ dev.blink(1000);
+ } catch(IOError e) {
+ send_message(MessageType.ERROR, "IOError: %s", e.message);
+ } catch(DatabaseError e) {
+ send_message(MessageType.ERROR, "DatabaseError: %s", e.message);
+ }
+ }
+
+ private bool interpret(string scannerdata) throws DatabaseError, IOError {
+ if(scannerdata.has_prefix("USER ")) {
+ string str_id = scannerdata.substring(5);
+ int32 id = int.parse(str_id);
+
+ /* check if scannerdata has valid format */
+ if(scannerdata != "USER %d".printf(id)) {
+ audio.play_system("error.ogg");
+ send_message(MessageType.ERROR, "Invalid User ID: %s", scannerdata);
+ return false;
+ }
+
+ if(logged_in) {
+ send_message(MessageType.WARNING, "Last user forgot to logout");
+ logout();
+ }
+
+ if(login(id)) {
+ audio.play_user(theme, "login");
+ send_message(MessageType.INFO, "Login: %s (%d)", name, user);
+ return true;
+ } else {
+ audio.play_system("error.ogg");
+ send_message(MessageType.ERROR, "Login failed (User ID = %d)", id);
+ return false;
+ }
+ } else if(scannerdata == "GUEST") {
+ if(logged_in) {
+ send_message(MessageType.WARNING, "Last user forgot to logout");
+ logout();
+ }
+
+ if(login(0)) {
+ audio.play_user(theme, "login");
+ send_message(MessageType.INFO, "Login: %s (%d)", name, user);
+ return true;
+ } else {
+ audio.play_system("error.ogg");
+ send_message(MessageType.ERROR, "Login failed (User ID = 0)");
+ return false;
+ }
+ } else if(scannerdata == "UNDO") {
+ if(!logged_in) {
+ audio.play_system("error.ogg");
+ send_message(MessageType.ERROR, "Can't undo if not logged in!");
+ return false;
+ } else {
+ string product = db.undo(user);
+
+ if(product != "") {
+ audio.play_user(theme, "purchase");
+ send_message(MessageType.INFO, "Removed purchase of %s", product);
+ return true;
+ } else {
+ audio.play_user(theme, "error");
+ send_message(MessageType.ERROR, "Couldn't undo last purchase!");
+ return false;
+ }
+ }
+ } else if(scannerdata == "LOGOUT") {
+ if(logged_in) {
+ audio.play_user(theme, "logout");
+ send_message(MessageType.INFO, "Logout!");
+ logout();
+ return true;
+ }
+
+ return false;
+ } else {
+ uint64 id = 0;
+ scannerdata.scanf("%llu", out id);
+
+ /* check if scannerdata has valid format */
+ if(scannerdata != "%llu".printf(id) && scannerdata != "%08llu".printf(id) && scannerdata != "%013llu".printf(id)) {
+ audio.play_user(theme, "error");
+ send_message(MessageType.ERROR, "invalid product: %s", scannerdata);
+ return false;
+ }
+
+ string name = "unknown product";
+
+ try {
+ name = db.get_product_name(id);
+ } catch(IOError e) {
+ audio.play_user(theme, "error");
+ send_message(MessageType.ERROR, "Internal Error!");
+ return false;
+ } catch(DatabaseError e) {
+ if(e is DatabaseError.PRODUCT_NOT_FOUND) {
+ audio.play_user(theme, "error");
+ var msg = "Error: unknown product: %llu".printf(id);
+ send_message(MessageType.ERROR, msg);
+ popup("Attention", msg);
+ } else {
+ audio.play_user(theme, "error");
+ send_message(MessageType.ERROR, "Error: %s", e.message);
+ }
+ return false;
+ }
+
+ if(!logged_in) {
+ var mprice = db.get_product_price(1, id);
+ var gprice = db.get_product_price(0, id);
+ var msg = @"article info: $name (Member: $mprice €, Guest: $gprice €)";
+ audio.play_system("error.ogg");
+ send_message(MessageType.INFO, msg);
+ send_message(MessageType.ERROR, "Login required for purchase!");
+ popup("Attention", "%s\nLogin required for purchase!".printf(msg));
+
+ return false;
+ }
+
+ if(db.buy(user, id)) {
+ var price = db.get_product_price(user, id);
+ audio.play_user(theme, "purchase");
+ send_message(MessageType.INFO, @"article bought: $name ($price €)");
+ return true;
+ } else {
+ audio.play_user(theme, "error");
+ send_message(MessageType.ERROR, "purchase failed!");
+ return false;
+ }
+ }
+ }
}