+ if( !(Bank_GetFlags(User) & USER_FLAG_DOORGROUP) )
+ {
+ #if DEBUG
+ printf("Door_CanDispense: User %i not in door\n", User);
+ #endif
+ return 1;
+ }
+
+ door_serial_handle = InitSerial(gsDoor_SerialPort, 1200);
+ if(door_serial_handle < 0) {
+ fprintf(stderr, "Unable to open door serial '%s'\n", gsDoor_SerialPort);
+ perror("Opening door port");
+ return -1;
+ }
+
+ {
+ struct termios info;
+ tcgetattr(door_serial_handle, &info);
+// info.c_iflag &= ~IGNCR; // Ignore \r
+ info.c_cflag &= ~CLOCAL;
+ tcsetattr(door_serial_handle, TCSANOW, &info);
+ }
+
+ writes(door_serial_handle, "\r\r");
+ sleep(1);
+
+ if( writes(door_serial_handle, "ATH1\r") ) {
+ fprintf(stderr, "Unable to open door (sending ATH1)\n");
+ perror("Sending ATH1");
+ return -1;
+ }
+
+ // Wait before re-locking
+ sleep(DOOR_UNLOCKED_DELAY);
+
+ if( writes(door_serial_handle, "ATH0\r") ) {
+ fprintf(stderr, "Oh, hell! Door not re-locking, big error (sending ATH0 failed)\n");
+ perror("Sending ATH0");
+ return -1;
+ }
+
+ close(door_serial_handle);