1
0
Fork 0

Update internal/api/api.go

main
jhot 2023-11-25 06:56:40 +00:00
parent 1cbc04c02b
commit b5b37a81ba
1 changed files with 8 additions and 6 deletions

View File

@ -152,33 +152,35 @@ func setEntityStateHandler(w http.ResponseWriter, r *http.Request) {
entityId := chi.URLParam(r, "entityId") entityId := chi.URLParam(r, "entityId")
service := chi.URLParam(r, "service") service := chi.URLParam(r, "service")
domain := r.URL.Query().Get("domain") domain := r.URL.Query().Get("domain")
l := logger.With("endpoint", "POST /api/state/{entityId}/{service}", "entityId", entityId, "service", service, "domain", domain)
var extras map[string]any var extras map[string]any
err := render.DecodeJSON(r.Body, &extras) err := render.DecodeJSON(r.Body, &extras)
if err != nil { if err != nil {
logger.Error("Error decoding JSON body", "error", err) l.Error("Error decoding JSON body", "error", err, "body", string(r.Body))
} }
var haErr error var haErr error
if err == nil && len(extras) > 0 { if err == nil && len(extras) > 0 {
if domain != "" { if domain != "" {
logger.Debug("Calling service manually", "service", service, "domain", domain, "entity", entityId, "extras", extras) l.Debug("Calling service manually", "extras", extras)
haErr = haClient.CallServiceManual(domain, entityId, service, extras) haErr = haClient.CallServiceManual(domain, entityId, service, extras)
} else { } else {
logger.Debug("Calling service", "service", service, "entity", entityId, "extras", extras) l.Debug("Calling service", "extras", extras)
haErr = haClient.CallService(entityId, service, extras) haErr = haClient.CallService(entityId, service, extras)
} }
} else { } else {
if domain != "" { if domain != "" {
logger.Debug("Calling service manually (without extras)", "service", service, "domain", domain, "entity", entityId) l.Debug("Calling service manually (without extras)")
haErr = haClient.CallServiceManual(domain, entityId, service) haErr = haClient.CallServiceManual(domain, entityId, service)
} else { } else {
logger.Debug("Calling service (without extras)", "service", service, "entity", entityId) l.Debug("Calling service (without extras)")
haErr = haClient.CallService(entityId, service) haErr = haClient.CallService(entityId, service)
} }
} }
if haErr != nil { if haErr != nil {
logger.Error("Error setting state", "error", haErr) l.Error("Error setting state", "error", haErr)
http.Error(w, fmt.Sprintf("error proxying request: %s", haErr.Error()), http.StatusInternalServerError) http.Error(w, fmt.Sprintf("error proxying request: %s", haErr.Error()), http.StatusInternalServerError)
return return
} }