This commit is contained in:
J. Nick Koston 2023-06-05 18:40:36 -05:00
parent 92b9dc5669
commit 64d6b259f2
No known key found for this signature in database
3 changed files with 27 additions and 60 deletions

View File

@ -9,8 +9,6 @@ DEPENDENCIES = ["preferences"]
ratgdo_ns = cg.esphome_ns.namespace("ratgdo")
RATGDO = ratgdo_ns.class_("RATGDOComponent", cg.Component)
CONF_ROLLING_CODES = "rolling_codes"
CONF_OUTPUT_GDO = "output_gdo_pin"
DEFAULT_OUTPUT_GDO = 2 # D4 ed control terminal / GarageDoorOpener (UART1 TX) pin is D4 on D1 Mini
@ -38,7 +36,6 @@ DEFAULT_INPUT_RPM2 = 4 # D2 RPM2 rotary encoder input OR not used if using reed
CONFIG_SCHEMA = cv.Schema(
{
cv.GenerateID(): cv.declare_id(RATGDO),
cv.Optional(CONF_ROLLING_CODES, default=True): cv.boolean,
cv.Optional(CONF_OUTPUT_GDO, default=DEFAULT_OUTPUT_GDO): pins.internal_gpio_input_pin_schema,
cv.Optional(CONF_INPUT_GDO, default=DEFAULT_INPUT_GDO): pins.internal_gpio_input_pin_schema,
cv.Optional(CONF_TRIGGER_OPEN, default=DEFAULT_TRIGGER_OPEN): pins.internal_gpio_input_pin_schema,
@ -56,8 +53,6 @@ CONFIG_SCHEMA = cv.Schema(
async def to_code(config):
var = cg.new_Pvariable(config[CONF_ID])
await cg.register_component(var, config)
cg.add(var.set_rolling_codes(config[CONF_ROLLING_CODES]))
pin = await cg.gpio_pin_expression(config[CONF_OUTPUT_GDO])
cg.add(var.set_output_gdo_pin(pin))
pin = await cg.gpio_pin_expression(config[CONF_INPUT_GDO])

View File

@ -19,23 +19,6 @@ namespace esphome {
namespace ratgdo {
static const char* const TAG = "ratgdo";
/*** Static Codes ***/
static const unsigned char SYNC1[] = { 0x55, 0x01, 0x00, 0x61, 0x12, 0x49, 0x2c, 0x92, 0x5b, 0x24,
0x96, 0x86, 0x0b, 0x65, 0x96, 0xd9, 0x8f, 0x26, 0x4a };
static const unsigned char SYNC2[] = { 0x55, 0x01, 0x00, 0x08, 0x34, 0x93, 0x49, 0xb4, 0x92, 0x4d,
0x20, 0x26, 0x1b, 0x4d, 0xb4, 0xdb, 0xad, 0x76, 0x93 };
static const unsigned char SYNC3[] = { 0x55, 0x01, 0x00, 0x06, 0x1b, 0x2c, 0xbf, 0x4b, 0x6d, 0xb6,
0x4b, 0x18, 0x20, 0x92, 0x09, 0x20, 0xf2, 0x11, 0x2c };
static const unsigned char SYNC4[] = { 0x55, 0x01, 0x00, 0x95, 0x29, 0x36, 0x91, 0x29, 0x36, 0x9a,
0x69, 0x05, 0x2f, 0xbe, 0xdf, 0x6d, 0x16, 0xcb, 0xe7 };
static const unsigned char DOOR_CODE[] = { 0x55, 0x01, 0x00, 0x94, 0x3f, 0xef, 0xbc, 0xfb, 0x7f, 0xbe,
0xfc, 0xa6, 0x1a, 0x4d, 0xa6, 0xda, 0x8d, 0x36, 0xb3 };
static const unsigned char LIGHT_CODE[] = { 0x55, 0x01, 0x00, 0x94, 0x3f, 0xef, 0xbc, 0xfb, 0x7f, 0xbe,
0xff, 0xa6, 0x1a, 0x4d, 0xa6, 0xda, 0x8d, 0x76, 0xb1 };
static const int STARTUP_DELAY = 2000; // delay before enabling interrupts
/*************************** DRY CONTACT CONTROL OF LIGHT & DOOR
@ -460,18 +443,6 @@ namespace ratgdo {
this->pref_.save(&this->rollingCodeCounter);
}
void RATGDOComponent::sendSyncCodes()
{
transmit(SYNC1);
delay(65);
transmit(SYNC2);
delay(65);
transmit(SYNC3);
delay(65);
transmit(SYNC4);
delay(65);
}
void RATGDOComponent::openDoor()
{
if(this->doorStates[this->store_.doorState] == "open" || doorStates[this->store_.doorState] == "opening"){
@ -500,36 +471,40 @@ namespace ratgdo {
void RATGDOComponent::toggleDoor()
{
if (this->useRollingCodes_) {
getRollingCode("door1");
transmit(this->txRollingCode);
getRollingCode("door1");
transmit(this->txRollingCode);
delay(40);
delay(40);
getRollingCode("door2");
transmit(this->txRollingCode);
getRollingCode("door2");
transmit(this->txRollingCode);
this->pref_.save(&this->rollingCodeCounter);
} else {
sendSyncCodes();
ESP_LOGD(TAG, "door_code");
transmit(DOOR_CODE);
this->pref_.save(&this->rollingCodeCounter);
}
void RATGDOComponent::lightOn(){
if(his->lightStates[this->store_.lightState] == "on"){
ESP_LOGD(TAG, "already on");
}else{
toggleLight();
}
}
void RATGDOComponent::toggleLight()
{
if (this->useRollingCodes_) {
getRollingCode("light");
transmit(this->txRollingCode);
this->pref_.save(&this->rollingCodeCounter);
} else {
sendSyncCodes();
ESP_LOGD(TAG, "light_code");
transmit(LIGHT_CODE);
void RATGDOComponent::lightOff(){
if(his->lightStates[this->store_.lightState] == "off"){
ESP_LOGD(TAG, "already off");
}else{
toggleLight();
}
}
void RATGDOComponent::toggleLight(){
getRollingCode("light");
transmit(this->txRollingCode);
this->pref_.save(&this->rollingCodeCounter);
}
// Lock functions
void RATGDOComponent::lock(){
if(this->lockStates[this->store_.lockState] == "locked"){

View File

@ -97,10 +97,8 @@ namespace ratgdo {
/********************************** FUNCTION DECLARATION
* *****************************************/
void set_rolling_codes(bool useRollingCodes);
void transmit(const uint8_t*);
void sync();
void sendSyncCodes();
void obstructionLoop();
void sendObstructionStatus();
@ -133,7 +131,6 @@ namespace ratgdo {
protected:
ESPPreferenceObject pref_;
bool useRollingCodes_ { true };
RATGDOStore store_ {};
InternalGPIOPin* output_gdo_pin_;