2023-10-30 15:03:50 +00:00
|
|
|
#include "main.h"
|
|
|
|
|
|
|
|
volatile uint64_t cardData = 0;
|
|
|
|
volatile bool newDataAvailable = false;
|
|
|
|
unsigned long lastDataTime = 0;
|
|
|
|
const unsigned long displayDelay = 1000; // Delay in milliseconds after which the data is displayed
|
|
|
|
unsigned int bitCount = 0; // Variable to keep track of the bit count
|
|
|
|
unsigned int maxReaderWaitTime = 9000; // Variable to timeout reader after too long of no data.
|
|
|
|
|
2023-10-30 15:38:56 +00:00
|
|
|
void commandLockDoor() {
|
|
|
|
// Add code to lock the door here (e.g., activate a relay, if applicable)
|
2023-10-30 18:30:30 +00:00
|
|
|
;
|
|
|
|
if (!settings.DoorDisabled()) {
|
|
|
|
lockDoor();
|
2023-10-30 18:33:24 +00:00
|
|
|
Serial.println("DOOR_LOCK_STATUS=" + stateDoor() );
|
2023-10-30 18:30:30 +00:00
|
|
|
} else {
|
|
|
|
Serial.println("LOG_MSG=Door Disabled Ignoring Command");
|
|
|
|
}
|
2023-10-30 15:38:56 +00:00
|
|
|
}
|
2023-10-30 15:03:50 +00:00
|
|
|
|
2023-10-30 15:38:56 +00:00
|
|
|
void commandUnlockDoor() {
|
|
|
|
// Add code to unlock the door here (e.g., deactivate a relay, if applicable)
|
2023-10-30 18:30:30 +00:00
|
|
|
if (!settings.DoorDisabled()) {
|
|
|
|
unlockDoor(false);
|
2023-10-30 18:33:24 +00:00
|
|
|
Serial.println("DOOR_LOCK_STATUS=" + stateDoor());
|
2023-10-30 18:30:30 +00:00
|
|
|
delay(RELAY_DELAY);
|
|
|
|
lockDoor();
|
2023-10-30 18:33:24 +00:00
|
|
|
Serial.println("DOOR_LOCK_STATUS=" + stateDoor());
|
2023-10-30 18:30:30 +00:00
|
|
|
} else {
|
|
|
|
Serial.println("LOG_MSG=Door Disabled Ignoring Command");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void commandToggleDoor() {
|
|
|
|
// Add code to lock the door here (e.g., activate a relay, if applicable)
|
|
|
|
;
|
|
|
|
if (!settings.DoorDisabled()) {
|
|
|
|
toggleDoor();
|
2023-10-30 18:33:24 +00:00
|
|
|
Serial.println("DOOR_LOCK_STATUS=" + stateDoor() );
|
2023-10-30 18:30:30 +00:00
|
|
|
} else {
|
|
|
|
Serial.println("LOG_MSG=Door Disabled Ignoring Command");
|
|
|
|
}
|
|
|
|
|
2023-10-30 18:33:24 +00:00
|
|
|
}
|
2023-10-30 18:30:30 +00:00
|
|
|
|
|
|
|
void commandLockStateDoor() {
|
|
|
|
// Add code to get door state
|
|
|
|
Serial.println("DOOR_LOCK_STATUS=" + stateDoor());
|
|
|
|
}
|
|
|
|
|
|
|
|
void commandDisableDoor() {
|
|
|
|
// Add code to get door state
|
|
|
|
settings.setDisableDoor(1);
|
|
|
|
unlockDoor(1);
|
2023-10-30 18:40:06 +00:00
|
|
|
Serial.println("DOOR_DISABLED_STATUS=" + String(settings.DoorDisabled() ? "Disabled" : "Enabled"));
|
2023-10-30 18:30:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void commandEnableDoor() {
|
|
|
|
// Add code to get door state
|
|
|
|
settings.setDisableDoor(0);
|
|
|
|
lockDoor();
|
2023-10-30 18:40:06 +00:00
|
|
|
Serial.println("DOOR_DISABLED_STATUS=" + String(settings.DoorDisabled() ? "Disabled" : "Enabled"));
|
2023-10-30 15:38:56 +00:00
|
|
|
}
|
2023-10-30 15:03:50 +00:00
|
|
|
|
2023-10-30 18:30:30 +00:00
|
|
|
void commandDisabledState() {
|
|
|
|
// Add code to get door state
|
|
|
|
settings.setDisableDoor(0);
|
|
|
|
unlockDoor(true);
|
2023-10-30 18:40:06 +00:00
|
|
|
Serial.println("DOOR_DISABLED_STATUS=" + String(settings.DoorDisabled() ? "Disabled" : "Enabled"));
|
2023-10-30 18:30:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-10-30 15:03:50 +00:00
|
|
|
void handleInterrupt(int bitValue) {
|
|
|
|
static unsigned long lastInterruptTime = 0;
|
|
|
|
unsigned long interruptTime = micros();
|
|
|
|
|
|
|
|
if (interruptTime - lastInterruptTime > 200) {
|
|
|
|
cardData <<= 1;
|
|
|
|
cardData |= bitValue;
|
|
|
|
newDataAvailable = true;
|
|
|
|
bitCount++; // Increment the bit count
|
|
|
|
}
|
|
|
|
|
|
|
|
lastInterruptTime = interruptTime;
|
|
|
|
lastDataTime = millis(); // Update the time of last received data
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleData0Interrupt() {
|
|
|
|
handleInterrupt(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleData1Interrupt() {
|
|
|
|
handleInterrupt(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void setup() {
|
|
|
|
|
|
|
|
Serial.begin(9600);
|
2023-10-30 18:30:30 +00:00
|
|
|
settings.loadFromEEPROM();
|
|
|
|
|
2023-10-30 15:03:50 +00:00
|
|
|
pinMode(DATA0_PIN, INPUT_PULLUP);
|
|
|
|
pinMode(DATA1_PIN, INPUT_PULLUP);
|
|
|
|
|
|
|
|
#ifdef LEDCTL_PIN
|
|
|
|
pinMode(LEDCTL_PIN, OUTPUT);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef RELAY1
|
|
|
|
pinMode(RELAY1_PIN, OUTPUT);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
attachInterrupt(digitalPinToInterrupt(DATA0_PIN), handleData0Interrupt, FALLING);
|
|
|
|
attachInterrupt(digitalPinToInterrupt(DATA1_PIN), handleData1Interrupt, FALLING);
|
|
|
|
|
|
|
|
#ifdef RELAY1
|
2023-10-30 18:30:30 +00:00
|
|
|
if (!settings.DoorDisabled()) {
|
|
|
|
Serial.println("LOG_MSG=Door Enabled");
|
|
|
|
Serial.println("LOG_MSG=Locking Door");
|
|
|
|
lockDoor();
|
|
|
|
} else {
|
|
|
|
Serial.println("LOG_MSG=Door Disabled");
|
|
|
|
Serial.println("LOG_MSG=Unlocking Door");
|
|
|
|
unlockDoor(true);
|
|
|
|
}
|
|
|
|
|
2023-10-30 15:03:50 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef RELAY2
|
|
|
|
pinMode(RELAY2_PIN, OUTPUT);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef BUZZER
|
|
|
|
pinMode(ALARM_PIN, OUTPUT);
|
|
|
|
digitalWrite(ALARM_PIN, HIGH); // Do not set to low or it will constantly beep.
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void loop() {
|
2023-10-30 15:20:21 +00:00
|
|
|
// Check if new data is available
|
2023-10-30 15:03:50 +00:00
|
|
|
|
|
|
|
if (newDataAvailable) {
|
|
|
|
newDataAvailable = false;
|
|
|
|
lastDataTime = millis(); // Reset the time of last received data
|
|
|
|
}
|
|
|
|
|
|
|
|
if (millis() - lastDataTime >= displayDelay && cardData != 0) {
|
|
|
|
|
|
|
|
|
|
|
|
uint64_t facilityID = (cardData >> 17) & 0xFFFF;
|
|
|
|
uint64_t cardID = (cardData >> 1) & 0xFFFF;
|
|
|
|
|
2023-10-30 15:20:21 +00:00
|
|
|
#ifdef DEBUG
|
2023-10-30 18:30:30 +00:00
|
|
|
Serial.print("DEBUG_MSG=Facility ID (Decimal): ");
|
2023-10-30 15:03:50 +00:00
|
|
|
Serial.println(facilityID);
|
2023-10-30 18:30:30 +00:00
|
|
|
Serial.print("DEBUG_MSG=Facility ID (Binary): ");
|
2023-10-30 15:03:50 +00:00
|
|
|
Serial.println(facilityID, BIN);
|
|
|
|
|
2023-10-30 18:30:30 +00:00
|
|
|
Serial.print("DEBUG_MSG=Card ID (Decimal): ");
|
2023-10-30 15:03:50 +00:00
|
|
|
Serial.println(cardID);
|
2023-10-30 18:30:30 +00:00
|
|
|
Serial.print("DEBUG_MSG=Card ID (Binary): ");
|
2023-10-30 15:03:50 +00:00
|
|
|
Serial.println(cardID, BIN);
|
|
|
|
|
2023-10-30 18:30:30 +00:00
|
|
|
Serial.print("DEBUG_MSG=Card Data (Binary): ");
|
2023-10-30 15:03:50 +00:00
|
|
|
Serial.println(cardData, BIN);
|
2023-10-30 18:30:30 +00:00
|
|
|
Serial.print("DEBUG_MSG=Total Bits Received: ");
|
2023-10-30 15:03:50 +00:00
|
|
|
Serial.println(bitCount);
|
2023-10-30 15:20:21 +00:00
|
|
|
#endif
|
2023-10-30 15:03:50 +00:00
|
|
|
|
|
|
|
String fullCardID = String(facilityID)+":"+String(cardID);
|
2023-10-30 18:30:30 +00:00
|
|
|
Serial.println("FULL_CARD_ID=" + fullCardID);
|
|
|
|
|
|
|
|
Serial.println(settings.DoorDisabled() ? "DOOR_DISABLED_STATUS=1" : "DOOR_DISABLED_STATUS=0");
|
2023-10-30 15:03:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
cardData = 0; // Reset the card data
|
|
|
|
lastDataTime = millis(); // Reset the time of last received data
|
|
|
|
bitCount = 0; // Reset the bit count
|
|
|
|
|
|
|
|
}
|
|
|
|
else if (millis() - lastDataTime >= maxReaderWaitTime) {
|
|
|
|
cardData = 0; // Reset the card data
|
|
|
|
lastDataTime = millis(); // Reset the time of last received data
|
|
|
|
bitCount = 0; // Reset the bit count
|
|
|
|
|
|
|
|
}
|
2023-10-30 15:38:56 +00:00
|
|
|
|
|
|
|
// Check for commands from the serial interface
|
|
|
|
if (Serial.available() > 0) {
|
|
|
|
String command = Serial.readString();
|
|
|
|
command.trim();
|
|
|
|
|
|
|
|
if (command.equals("unlock")) {
|
|
|
|
commandUnlockDoor();
|
|
|
|
} else if (command.equals("lock")) {
|
|
|
|
commandLockDoor();
|
2023-10-30 18:30:30 +00:00
|
|
|
} else if (command.equals("toggle")) {
|
|
|
|
commandToggleDoor();
|
|
|
|
} else if (command.equals("lock_status")) {
|
|
|
|
commandLockStateDoor();
|
|
|
|
} else if (command.equals("enable")) {
|
|
|
|
commandEnableDoor();
|
|
|
|
} else if (command.equals("disable")) {
|
|
|
|
commandDisableDoor();
|
|
|
|
}else if (command.equals("disabled_status")) {
|
|
|
|
commandDisabledState();
|
2023-10-30 15:38:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-10-30 15:03:50 +00:00
|
|
|
}
|