From 9eebe991f5af73333540539e61920f65fdf6a2ba Mon Sep 17 00:00:00 2001 From: jagheterfredrik Date: Mon, 25 Dec 2023 21:52:35 +0100 Subject: [PATCH] add workaround for copper sb locking --- app/wallbox/wallbox.go | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/app/wallbox/wallbox.go b/app/wallbox/wallbox.go index 6cd04d3..5bbe3b9 100644 --- a/app/wallbox/wallbox.go +++ b/app/wallbox/wallbox.go @@ -40,6 +40,7 @@ type Wallbox struct { redisClient *redis.Client sqlClient *sqlx.DB Data DataCache + ChargerType string `db:"charger_type"` } func New() *Wallbox { @@ -51,6 +52,9 @@ func New() *Wallbox { panic(err) } + query := "select SUBSTRING_INDEX(part_number, '-', 1) AS charger_type from charger_info;" + w.sqlClient.Get(&w, query) + w.redisClient = redis.NewClient(&redis.Options{ Addr: "localhost:6379", Password: "", @@ -144,7 +148,9 @@ func (w *Wallbox) SetLocked(lock int) { if lock == w.Data.SQL.Lock { return } - if lock == 1 { + if w.ChargerType == "CPB1" { + w.sqlClient.MustExec("UPDATE `wallbox_config` SET `lock`=?", lock) + } else if lock == 1 { sendToPosixQueue("WALLBOX_MYWALLBOX_WALLBOX_LOGIN", "EVENT_REQUEST_LOCK") } else { userId := w.UserId()