Skip to content
  • MySensors
  • OpenHardware.io
  • Categories
  • Recent
  • Tags
  • Popular
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Brand Logo
  1. Home
  2. Troubleshooting
  3. Relay shows up in mysensors.json but not in gui [homeassistant]

Relay shows up in mysensors.json but not in gui [homeassistant]

Scheduled Pinned Locked Moved Troubleshooting
18 Posts 4 Posters 1.2k Views 4 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • M Offline
    M Offline
    mcchots
    wrote on last edited by
    #2

    Are you using a relatively recent build of Home Assistant?

    Check in the Unused Entities section for your sensor. I think home assistant no longer adds discovered devices to the front-end by default.

    1 Reply Last reply
    0
    • M Offline
      M Offline
      mrhutchinsonmn
      wrote on last edited by
      #3

      Version 0.94.4

      Thank you for the recommendation. I learned to look there through trial-and-error but the relay does not show up.

      However, everything works as expected (4 relays show up in Unused Entities) when I use the following sketch:

      Copy to clipboard
      // Override Setting for Manual Node ID to 2
      #define MY_NODE_ID 2
      
      // Enable debug prints to serial monitor
      #define MY_DEBUG 
      
      // Enable and select radio type attached
      #define MY_RADIO_NRF24
      
      // Enable repeater functionality for this node
      #define MY_REPEATER_FEATURE
      
      #include <SPI.h>
      #include <MySensors.h>
      
      #define RELAY_1  3          // Arduino Digital I/O pin number for first relay (second on pin+1 etc)
      #define NUMBER_OF_RELAYS 4  // Total number of attached relays: 4
      
      // Opto Relay Module I was using Active Low - Low (0):ON, High (1): OFF
      #define RELAY_ON 0          // GPIO value to write to turn on attached relay
      #define RELAY_OFF 1         // GPIO value to write to turn off attached relay
      
      bool initialValueSent = false;
      
      //Init MyMessage for Each Child ID
      MyMessage msg1(1, V_LIGHT);
      MyMessage msg2(2, V_LIGHT);
      MyMessage msg3(3, V_LIGHT);
      MyMessage msg4(4, V_LIGHT);
      
      void before() { 
        for (int sensor=1, pin=RELAY_1; sensor<=NUMBER_OF_RELAYS;sensor++, pin++) {
          // Then set relay pins in output mode
          pinMode(pin, OUTPUT);   
          // Set relay to last known state (using eeprom storage) 
          digitalWrite(pin, loadState(sensor)?RELAY_ON:RELAY_OFF);
        }
      }
      
      void setup() {
        
      }
      
      void presentation()  
      {   
        // Send the sketch version information to the gateway and Controller
        sendSketchInfo("Relay", "1.0");
      
        for (int sensor=1, pin=RELAY_1; sensor<=NUMBER_OF_RELAYS;sensor++, pin++) {
          // Register all sensors to gw (they will be created as child devices)
          present(sensor, S_LIGHT);
        }
      }
      
      
      void loop() 
      {
        if (!initialValueSent) {
          Serial.println("Sending initial value");
          send(msg1.set(loadState(1)?RELAY_OFF:RELAY_ON),true);
          wait(1000);
          send(msg2.set(loadState(2)?RELAY_OFF:RELAY_ON),true);
          wait(1000);
          send(msg3.set(loadState(3)?RELAY_OFF:RELAY_ON),true);
          wait(1000);
          send(msg4.set(loadState(4)?RELAY_OFF:RELAY_ON),true);
          wait(1000);
          Serial.println("Sending initial value: Completed");
          wait(5000);
        }
      }
      
      void receive(const MyMessage &message) {
        Serial.println("=============== Receive Start =======================");
        if (message.isAck()) {
           Serial.println(">>>>> ACK <<<<<");
           Serial.println("This is an ack from gateway");
           Serial.println("<<<<<< ACK >>>>>>");
        }
        // We only expect one type of message from controller. But we better check anyway.
        if (message.type==V_LIGHT) {
          Serial.println(">>>>> V_LIGHT <<<<<");
          if (!initialValueSent) {
            Serial.println("Receiving initial value from controller");
            initialValueSent = true;
          }
           // Update relay state to HA
           digitalWrite(message.sensor-1+RELAY_1, message.getBool()?RELAY_ON:RELAY_OFF);
           switch (message.sensor) {
              case 1:
                Serial.print("Incoming change for sensor 1");
                send(msg1.set(message.getBool()?RELAY_OFF:RELAY_ON));
                break;
              case 2:
                Serial.print("Incoming change for sensor 2");
                send(msg2.set(message.getBool()?RELAY_OFF:RELAY_ON));
                break;
              case 3:
                Serial.print("Incoming change for sensor 3");
                send(msg3.set(message.getBool()?RELAY_OFF:RELAY_ON));
                break;
              case 4:
                Serial.print("Incoming change for sensor 4");
                send(msg4.set(message.getBool()?RELAY_OFF:RELAY_ON));
                break;                    
              default: 
                Serial.println("Default Case: Receiving Other Sensor Child ID");
              break;
           }
           // Store state in Arduino eeprom
           saveState(message.sensor, message.getBool());
           Serial.print("Saved State for sensor: ");
           Serial.print( message.sensor);
           Serial.print(", New status: ");
           Serial.println(message.getBool());
           Serial.println("<<<<<< V_LIGHT >>>>>>");
         } 
         Serial.println("=============== Receive END =======================");
      }```
      1 Reply Last reply
      1
      • B Offline
        B Offline
        bereska
        wrote on last edited by
        #4

        i have the same very problem adding a water mater pulse sensor with the following sketch from mysensors.org

        /*
         * The MySensors Arduino library handles the wireless radio link and protocol
         * between your home built sensors/actuators and HA controller of choice.
         * The sensors forms a self healing radio network with optional repeaters. Each
         * repeater and gateway builds a routing tables in EEPROM which keeps track of the
         * network topology allowing messages to be routed to nodes.
         *
         * Created by Henrik Ekblad <henrik.ekblad@mysensors.org>
         * Copyright (C) 2013-2018 Sensnology AB
         * Full contributor list: https://github.com/mysensors/MySensors/graphs/contributors
         *
         * Documentation: http://www.mysensors.org
         * Support Forum: http://forum.mysensors.org
         *
         * This program is free software; you can redistribute it and/or
         * modify it under the terms of the GNU General Public License
         * version 2 as published by the Free Software Foundation.
         *
         *******************************
         *
         * REVISION HISTORY
         * Version 1.0 - Henrik Ekblad
         * Version 1.1 - GizMoCuz
         *
         * DESCRIPTION
         * Use this sensor to measure volume and flow of your house water meter.
         * You need to set the correct pulsefactor of your meter (pulses per m3).
         * The sensor starts by fetching current volume reading from gateway (VAR 1).
         * Reports both volume and flow back to gateway.
         *
         * Unfortunately millis() won't increment when the Arduino is in
         * sleepmode. So we cannot make this sensor sleep if we also want
         * to calculate/report flow.
         * http://www.mysensors.org/build/pulse_water
         */
        
        // Enable debug prints to serial monitor
        #define MY_DEBUG
        
        // Enable and select radio type attached
        #define MY_RADIO_RF24
        #define MY_NODE_ID 6
        //#define MY_RADIO_NRF5_ESB
        //#define MY_RADIO_RFM69
        //#define MY_RADIO_RFM95
        
        #include <MySensors.h>
        
        #define DIGITAL_INPUT_SENSOR 3                  // The digital input you attached your sensor.  (Only 2 and 3 generates interrupt!)
        
        #define PULSE_FACTOR 1000                       // Number of blinks per m3 of your meter (One rotation/liter)
        
        #define SLEEP_MODE false                        // flowvalue can only be reported when sleep mode is false.
        
        #define MAX_FLOW 40                             // Max flow (l/min) value to report. This filters outliers.
        
        #define CHILD_ID 1                              // Id of the sensor child
        
        uint32_t SEND_FREQUENCY =
            30000;           // Minimum time between send (in milliseconds). We don't want to spam the gateway.
        
        MyMessage flowMsg(CHILD_ID,V_FLOW);
        MyMessage volumeMsg(CHILD_ID,V_VOLUME);
        MyMessage lastCounterMsg(CHILD_ID,V_VAR1);
        
        double ppl = ((double)PULSE_FACTOR)/1000;        // Pulses per liter
        
        volatile uint32_t pulseCount = 0;
        volatile uint32_t lastBlink = 0;
        volatile double flow = 0;
        bool pcReceived = false;
        uint32_t oldPulseCount = 0;
        uint32_t newBlink = 0;
        double oldflow = 0;
        double volume =0;
        double oldvolume =0;
        uint32_t lastSend =0;
        uint32_t lastPulse =0;
        
        void setup()
        {
          // initialize our digital pins internal pullup resistor so one pulse switches from high to low (less distortion)
          pinMode(DIGITAL_INPUT_SENSOR, INPUT_PULLUP);
        
          pulseCount = oldPulseCount = 0;
        
          // Fetch last known pulse count value from gw
          request(CHILD_ID, V_VAR1);
        
          lastSend = lastPulse = millis();
        
          attachInterrupt(digitalPinToInterrupt(DIGITAL_INPUT_SENSOR), onPulse, FALLING);
        }
        
        void presentation()
        {
          // Send the sketch version information to the gateway and Controller
          sendSketchInfo("Water Meter", "1.1");
        
          // Register this device as Water flow sensor
          present(CHILD_ID, S_WATER);
        }
        
        void loop()
        {
          uint32_t currentTime = millis();
        
          // Only send values at a maximum frequency or woken up from sleep
          if (SLEEP_MODE || (currentTime - lastSend > SEND_FREQUENCY)) {
            lastSend=currentTime;
        
            if (!pcReceived) {
              //Last Pulsecount not yet received from controller, request it again
              request(CHILD_ID, V_VAR1);
              return;
            }
        
            if (!SLEEP_MODE && flow != oldflow) {
              oldflow = flow;
        
              Serial.print("l/min:");
              Serial.println(flow);
        
              // Check that we don't get unreasonable large flow value.
              // could happen when long wraps or false interrupt triggered
              if (flow<((uint32_t)MAX_FLOW)) {
                send(flowMsg.set(flow, 2));                   // Send flow value to gw
              }
            }
        
            // No Pulse count received in 2min
            if(currentTime - lastPulse > 120000) {
              flow = 0;
            }
        
            // Pulse count has changed
            if ((pulseCount != oldPulseCount)||(!SLEEP_MODE)) {
              oldPulseCount = pulseCount;
        
              Serial.print("pulsecount:");
              Serial.println(pulseCount);
        
              send(lastCounterMsg.set(pulseCount));                  // Send  pulsecount value to gw in VAR1
        
              double volume = ((double)pulseCount/((double)PULSE_FACTOR));
              if ((volume != oldvolume)||(!SLEEP_MODE)) {
                oldvolume = volume;
        
                Serial.print("volume:");
                Serial.println(volume, 3);
        
                send(volumeMsg.set(volume, 3));               // Send volume value to gw
              }
            }
          }
          if (SLEEP_MODE) {
            sleep(SEND_FREQUENCY);
          }
        }
        
        void receive(const MyMessage &message)
        {
          if (message.type==V_VAR1) {
            uint32_t gwPulseCount=message.getULong();
            pulseCount += gwPulseCount;
            flow=oldflow=0;
            Serial.print("Received last pulse count from gw:");
            Serial.println(pulseCount);
            pcReceived = true;
          }
        }
        
        void onPulse()
        {
          if (!SLEEP_MODE) {
            uint32_t newBlink = micros();
            uint32_t interval = newBlink-lastBlink;
        
            if (interval!=0) {
              lastPulse = millis();
              if (interval<500000L) {
                // Sometimes we get interrupt on RISING,  500000 = 0.5 second debounce ( max 120 l/min)
                return;
              }
              flow = (60000000.0 /interval) / ppl;
            }
            lastBlink = newBlink;
          }
          pulseCount++;
        }
        

        Node 6 as Water Meter shows up in mysensors.json and homeassistant logs but fails to appear in GUI.
        Thank you for your help

        1 Reply Last reply
        0
        • M Offline
          M Offline
          mcchots
          wrote on last edited by mcchots
          #5

          From my limited use with sensors other then temperature, sometimes items don't appear in the GUI on Home Assistant until they send some data.

          Also check in the States section of Developer Tools at what data HA has acquired from your sensor.

          Beyond that, you might have to ask on the Home Assistant forums.

          B 1 Reply Last reply
          0
          • M mcchots

            From my limited use with sensors other then temperature, sometimes items don't appear in the GUI on Home Assistant until they send some data.

            Also check in the States section of Developer Tools at what data HA has acquired from your sensor.

            Beyond that, you might have to ask on the Home Assistant forums.

            B Offline
            B Offline
            bereska
            wrote on last edited by
            #6

            @mcchots thank you, that's what I thought, too. Let me rig it up on my water meter and see if starts sending any data

            1 Reply Last reply
            0
            • J Offline
              J Offline
              Jens Jensen
              wrote on last edited by Jens Jensen
              #7

              So I too was having this issue and pulling my hair out trying to understand what was wrong.
              The homeassistant/mysensor doc page says you have to send intial values, but the important nuanced point is that ALL possible value types must have an initial value sent for a given sensor type.

              In my example, I could not figure out why my motion sensor (S_MOTION) was not registering in HA UI - I was sending an initial (V_TRIPPED) state.

              However, S_MOTION sensors can have both V_TRIPPED and V_ARMED.
              ref: https://www.mysensors.org/download/serial_api_20#presentation
              Once I sent an initial value for V_ARMED, it started working - whew!

              So check carefully that you are sending some initial value for EVERY possible value type of your sensor type.

              B 1 Reply Last reply
              0
              • J Jens Jensen

                So I too was having this issue and pulling my hair out trying to understand what was wrong.
                The homeassistant/mysensor doc page says you have to send intial values, but the important nuanced point is that ALL possible value types must have an initial value sent for a given sensor type.

                In my example, I could not figure out why my motion sensor (S_MOTION) was not registering in HA UI - I was sending an initial (V_TRIPPED) state.

                However, S_MOTION sensors can have both V_TRIPPED and V_ARMED.
                ref: https://www.mysensors.org/download/serial_api_20#presentation
                Once I sent an initial value for V_ARMED, it started working - whew!

                So check carefully that you are sending some initial value for EVERY possible value type of your sensor type.

                B Offline
                B Offline
                bereska
                wrote on last edited by
                #8

                @jens-jensen thank you for your input
                could you have a look at my sketch above and point me in the right direction on what needs to be changed/added?
                I see this part which looks good to me:

                MyMessage flowMsg(CHILD_ID,V_FLOW);
                MyMessage volumeMsg(CHILD_ID,V_VOLUME);
                MyMessage lastCounterMsg(CHILD_ID,V_VAR1);```
                thanks
                J 1 Reply Last reply
                0
                • B bereska

                  @jens-jensen thank you for your input
                  could you have a look at my sketch above and point me in the right direction on what needs to be changed/added?
                  I see this part which looks good to me:

                  MyMessage flowMsg(CHILD_ID,V_FLOW);
                  MyMessage volumeMsg(CHILD_ID,V_VOLUME);
                  MyMessage lastCounterMsg(CHILD_ID,V_VAR1);```
                  thanks
                  J Offline
                  J Offline
                  Jens Jensen
                  wrote on last edited by Jens Jensen
                  #9

                  @bereska
                  looks mostly correct, althought I would take a look at the example here to use their technique for ensuring you send initial values for V_FLOW and V_VOLUME.
                  ref: https://www.home-assistant.io/components/mysensors/

                  From your sketch, it seems possible that either may not be sent right away, e.g. if volume or flow is not changing, etc.

                  Also, where in HA UI are you looking? I had to add my sensor to one of my lovelace cards. Still getting the hang of the new UI (but definitely better than it was before). I also saw it in developer, states under current entities

                  B 1 Reply Last reply
                  0
                  • J Jens Jensen

                    @bereska
                    looks mostly correct, althought I would take a look at the example here to use their technique for ensuring you send initial values for V_FLOW and V_VOLUME.
                    ref: https://www.home-assistant.io/components/mysensors/

                    From your sketch, it seems possible that either may not be sent right away, e.g. if volume or flow is not changing, etc.

                    Also, where in HA UI are you looking? I had to add my sensor to one of my lovelace cards. Still getting the hang of the new UI (but definitely better than it was before). I also saw it in developer, states under current entities

                    B Offline
                    B Offline
                    bereska
                    wrote on last edited by
                    #10

                    @jens-jensen thank you, like you said the sketch looks ok. Yet this only sensor fails to appear in HA, neither on dashboard nor in states or unused entities. The only thing I have noticed though is that this sketch is missing this part:

                    Bounce debouncer = Bounce();
                    bool state = false;
                    bool initialValueSent = false;
                    

                    maybe that's the key to this problem?

                    B 1 Reply Last reply
                    0
                    • B bereska

                      @jens-jensen thank you, like you said the sketch looks ok. Yet this only sensor fails to appear in HA, neither on dashboard nor in states or unused entities. The only thing I have noticed though is that this sketch is missing this part:

                      Bounce debouncer = Bounce();
                      bool state = false;
                      bool initialValueSent = false;
                      

                      maybe that's the key to this problem?

                      B Offline
                      B Offline
                      bereska
                      wrote on last edited by
                      #11

                      this is HA log:

                      2019-07-04 23:24:05 DEBUG (MainThread) [homeassistant.components.mqtt] Received message on mygateway1-out/6/255/3/0/11: b'Water Meter',
                      2019-07-04 23:24:05 DEBUG (MainThread) [mysensors.gateway_mqtt] Receiving 6;255;3;0;11;Water Meter,
                      2019-07-04 23:24:23 DEBUG (MainThread) [homeassistant.components.mqtt] Received message on mygateway1-out/6/255/3/0/11: b'Water Meter',
                      2019-07-04 23:24:23 DEBUG (MainThread) [mysensors.gateway_mqtt] Receiving 6;255;3;0;11;Water Meter

                      1 Reply Last reply
                      0
                      • J Offline
                        J Offline
                        Jens Jensen
                        wrote on last edited by
                        #12

                        Looking at your HA log, do you see that both V_FLOW and V_VOLUME values are sent after some time?

                        With the sketch, their idea is that you use initialValueSent to send initial values (for all types) only once (at first boot) in loop section.

                        B 1 Reply Last reply
                        0
                        • J Jens Jensen

                          Looking at your HA log, do you see that both V_FLOW and V_VOLUME values are sent after some time?

                          With the sketch, their idea is that you use initialValueSent to send initial values (for all types) only once (at first boot) in loop section.

                          B Offline
                          B Offline
                          bereska
                          wrote on last edited by
                          #13

                          @jens-jensen said in Relay shows up in mysensors.json but not in gui [homeassistant]:

                          V_FLOW and V_VOLUME values are sent after some time

                          no, V_FLOW and V_VOLUME values are NOT sent after some time
                          how to i modify the sketch to make it happen?

                          J 1 Reply Last reply
                          0
                          • B bereska

                            @jens-jensen said in Relay shows up in mysensors.json but not in gui [homeassistant]:

                            V_FLOW and V_VOLUME values are sent after some time

                            no, V_FLOW and V_VOLUME values are NOT sent after some time
                            how to i modify the sketch to make it happen?

                            J Offline
                            J Offline
                            Jens Jensen
                            wrote on last edited by
                            #14

                            @bereska
                            look at how the reference sketch in the homeassistant mysensors page works.
                            I starts with a bool initialValueSent set to false.
                            It checks for this in loop, and if not already set to true, it will send initial values, then set initialValueSent = false, so that it never runs again (until sensor is restarted).

                            Also regarding your sketch logic, should it periodically send values of all sensors (like at least once per hour, per day, etc)? You may want to look at that as well.

                            1 Reply Last reply
                            0
                            • J Offline
                              J Offline
                              Jens Jensen
                              wrote on last edited by
                              #15

                              ok, I think i have also may have found a bug in the HA mysensors implementation, i.e. if you name your sketch with some reserved names, it never registers in HA.

                              I.e.
                              sendSketchInfo("motion_sensor", "1.0"); won't work in HA
                              but sendSketchInfo("motion_sensor_foo", "1.0"); shows up :(
                              I didn't see any mention of this in https://www.home-assistant.io/components/mysensors/
                              Maybe it's a bug (should mysensors ha component rename it or prefix with some namespace, etc; or should this be documented in guide - and then what are the reserved names which we cannot name sketches to?)

                              1 Reply Last reply
                              0
                              • J Offline
                                J Offline
                                Jens Jensen
                                wrote on last edited by
                                #16

                                nm, I seems like it eventually sends the sketch name

                                B 1 Reply Last reply
                                0
                                • J Jens Jensen

                                  nm, I seems like it eventually sends the sketch name

                                  B Offline
                                  B Offline
                                  bereska
                                  wrote on last edited by
                                  #17

                                  @jens-jensen it does send and register the name, no problem.

                                  1 Reply Last reply
                                  0
                                  • B Offline
                                    B Offline
                                    bereska
                                    wrote on last edited by
                                    #18

                                    i can't get this sensor to show up in HA. Any ideas anyone?

                                    1 Reply Last reply
                                    0
                                    Reply
                                    • Reply as topic
                                    Log in to reply
                                    • Oldest to Newest
                                    • Newest to Oldest
                                    • Most Votes


                                    9

                                    Online

                                    11.7k

                                    Users

                                    11.2k

                                    Topics

                                    113.0k

                                    Posts


                                    Copyright 2019 TBD   |   Forum Guidelines   |   Privacy Policy   |   Terms of Service
                                    • Login

                                    • Don't have an account? Register

                                    • Login or register to search.
                                    • First post
                                      Last post
                                    0
                                    • MySensors
                                    • OpenHardware.io
                                    • Categories
                                    • Recent
                                    • Tags
                                    • Popular