<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>Home automation on BlocNotes</title>
    <link>https://notes.iopush.net/tags/home-automation/</link>
    <description>Recent content in Home automation on BlocNotes</description>
    <generator>Hugo -- gohugo.io</generator>
    <language>en-us</language>
    <lastBuildDate>Tue, 30 Sep 2025 00:00:00 +0000</lastBuildDate><atom:link href="https://notes.iopush.net/tags/home-automation/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Fix Home-Assistant statistics and energy erroneous values</title>
      <link>https://notes.iopush.net/blog/2025/09-hass-fix-statistics/</link>
      <pubDate>Tue, 30 Sep 2025 00:00:00 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2025/09-hass-fix-statistics/</guid>
      <description>&lt;h2 id=&#34;introduction&#34;&gt;Introduction&lt;/h2&gt;
&lt;p&gt;I have been experimenting with solar panels, &lt;a href=&#34;https://www.home-assistant.io/&#34;&gt;Home Assistant&lt;/a&gt; and my electricity meter lately. This French meter from the utility is called Linky. It provides a small power supply (130 mW) and a serial link hidden via amplitude modulation.&lt;br&gt;
To avoid using batteries, I built a prototype that harvests this power, demodulates the serial link, and feeds the data into an nRF52 development kit. It works well enough that I never bothered turning this messy setup into a proper PCB.&lt;/p&gt;
&lt;p&gt;However, every now and then—despite CRC checks—I get an erroneous reading that messes up the Home Assistant Energy panel. Here&amp;rsquo;s how to fix incorrect statistics in the Home Assistant database.&lt;/p&gt;
&lt;h4 id=&#34;preparation&#34;&gt;Preparation&lt;/h4&gt;
&lt;p&gt;Before editing the database, it is strongly recommended to stop Home Assistant to avoid concurrent access that could corrupt the database.&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;Connect to the system running Home Assistant&lt;/li&gt;
&lt;li&gt;Install SQLite3 if needed. For example, on Debian-based systems: &lt;code&gt;apt install sqlite3&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;Locate the &lt;code&gt;home-assistant_v2.db&lt;/code&gt; database file in Home-Assistant data folder and create a backup&lt;/li&gt;
&lt;/ol&gt;
&lt;h4 id=&#34;open-the-database-for-editing&#34;&gt;Open the database for editing&lt;/h4&gt;
&lt;p&gt;Open the database using SQLite and set a more readable output mode:&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-bash&#34; data-lang=&#34;bash&#34;&gt;$ sqlite3 home-assistant_v2.db
&lt;span style=&#34;color:#75715e&#34;&gt;# Then enter the commands&lt;/span&gt;
sqlite&amp;gt; .header on
sqlite&amp;gt; .mode column
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h4 id=&#34;find-the-data-id&#34;&gt;Find the data id&lt;/h4&gt;
&lt;p&gt;Identify Home Assitant&amp;rsquo;s internal identifier, it is called &lt;code&gt;metadata_id&lt;/code&gt;. Replace &lt;code&gt;easf02&lt;/code&gt; with Home-Assistant&amp;rsquo;s Entity ID you are looking for.&lt;br&gt;
Using &lt;code&gt;LIKE &#39;%PARTIAL_ENTITY_STRING%&lt;/code&gt; allows for easier search by matching any string containing &lt;code&gt;PARTIAL_ENTITY_STRING&lt;/code&gt;&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-SQL&#34; data-lang=&#34;SQL&#34;&gt;sqlite&lt;span style=&#34;color:#f92672&#34;&gt;&amp;gt;&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;SELECT&lt;/span&gt; id, statistic_id &lt;span style=&#34;color:#66d9ef&#34;&gt;FROM&lt;/span&gt; statistics_meta &lt;span style=&#34;color:#66d9ef&#34;&gt;WHERE&lt;/span&gt; statistic_id &lt;span style=&#34;color:#66d9ef&#34;&gt;LIKE&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;%easf01%&amp;#39;&lt;/span&gt;;
id  statistic_id            
&lt;span style=&#34;color:#75715e&#34;&gt;--  ------------------------
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;6&lt;/span&gt;   sensor.linky_easf01     
&lt;span style=&#34;color:#ae81ff&#34;&gt;15&lt;/span&gt;  sensor.linky_easf01_cost
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;In this case &lt;code&gt;id = 6&lt;/code&gt; is the one we want to fix, and &lt;code&gt;id = 15&lt;/code&gt; is the associated cost.&lt;/p&gt;
&lt;h4 id=&#34;search-for-erroneous-data&#34;&gt;Search for erroneous data&lt;/h4&gt;
&lt;p&gt;We let&amp;rsquo;s ask the database for any sudden jump in the data, e.g change greater than 10,000 Wh. Adjust &lt;code&gt;metadata_id = 6&lt;/code&gt; and the threshold (&lt;code&gt;&amp;gt; 10000&lt;/code&gt;) as needed.&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-SQL&#34; data-lang=&#34;SQL&#34;&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;WITH&lt;/span&gt; ordered_stats &lt;span style=&#34;color:#66d9ef&#34;&gt;AS&lt;/span&gt; (
  &lt;span style=&#34;color:#66d9ef&#34;&gt;SELECT&lt;/span&gt;
    id,
    created_ts,
    &lt;span style=&#34;color:#66d9ef&#34;&gt;sum&lt;/span&gt;,
    metadata_id,
    LAG(&lt;span style=&#34;color:#66d9ef&#34;&gt;sum&lt;/span&gt;) OVER (PARTITION &lt;span style=&#34;color:#66d9ef&#34;&gt;BY&lt;/span&gt; metadata_id &lt;span style=&#34;color:#66d9ef&#34;&gt;ORDER&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;BY&lt;/span&gt; created_ts) &lt;span style=&#34;color:#66d9ef&#34;&gt;AS&lt;/span&gt; previous_sum,
    LAG(created_ts) OVER (PARTITION &lt;span style=&#34;color:#66d9ef&#34;&gt;BY&lt;/span&gt; metadata_id &lt;span style=&#34;color:#66d9ef&#34;&gt;ORDER&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;BY&lt;/span&gt; created_ts) &lt;span style=&#34;color:#66d9ef&#34;&gt;AS&lt;/span&gt; previous_created_ts
  &lt;span style=&#34;color:#66d9ef&#34;&gt;FROM&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;statistics&lt;/span&gt;
  &lt;span style=&#34;color:#66d9ef&#34;&gt;WHERE&lt;/span&gt; metadata_id &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;6&lt;/span&gt;
)
&lt;span style=&#34;color:#66d9ef&#34;&gt;SELECT&lt;/span&gt;
  id,
  datetime(created_ts, &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;unixepoch&amp;#39;&lt;/span&gt;, &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;localtime&amp;#39;&lt;/span&gt;) &lt;span style=&#34;color:#66d9ef&#34;&gt;as&lt;/span&gt; date,
  &lt;span style=&#34;color:#66d9ef&#34;&gt;ABS&lt;/span&gt;(&lt;span style=&#34;color:#66d9ef&#34;&gt;sum&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt; previous_sum) &lt;span style=&#34;color:#66d9ef&#34;&gt;AS&lt;/span&gt; difference
&lt;span style=&#34;color:#66d9ef&#34;&gt;FROM&lt;/span&gt; ordered_stats
&lt;span style=&#34;color:#66d9ef&#34;&gt;WHERE&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;ABS&lt;/span&gt;(&lt;span style=&#34;color:#66d9ef&#34;&gt;sum&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt; previous_sum) &lt;span style=&#34;color:#f92672&#34;&gt;&amp;gt;&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;10000&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;ORDER&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;BY&lt;/span&gt; id &lt;span style=&#34;color:#66d9ef&#34;&gt;DESC&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;LIMIT&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;5&lt;/span&gt;;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;In a nutshell, this query:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;Selects statistics data for the entity and associates each value with the previous one.&lt;/li&gt;
&lt;li&gt;Displays the five most recent entries where the difference between consecutive values exceeds the threshold.&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;Example result:&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-SQL&#34; data-lang=&#34;SQL&#34;&gt;id      date                 difference
&lt;span style=&#34;color:#75715e&#34;&gt;------  -------------------  ----------
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;229351&lt;/span&gt;  &lt;span style=&#34;color:#ae81ff&#34;&gt;2025&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;08&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;18&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;14&lt;/span&gt;:&lt;span style=&#34;color:#ae81ff&#34;&gt;00&lt;/span&gt;:&lt;span style=&#34;color:#ae81ff&#34;&gt;10&lt;/span&gt;  &lt;span style=&#34;color:#ae81ff&#34;&gt;20676793&lt;/span&gt;.&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;
&lt;span style=&#34;color:#ae81ff&#34;&gt;38711&lt;/span&gt;   &lt;span style=&#34;color:#ae81ff&#34;&gt;2025&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;01&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;28&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;12&lt;/span&gt;:&lt;span style=&#34;color:#ae81ff&#34;&gt;00&lt;/span&gt;:&lt;span style=&#34;color:#ae81ff&#34;&gt;10&lt;/span&gt;  &lt;span style=&#34;color:#ae81ff&#34;&gt;20020401&lt;/span&gt;.&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Looks like we found the 20.6 MWh spike reported in the Energy panel :-)&lt;/p&gt;
&lt;h4 id=&#34;update-the-value&#34;&gt;Update the value&lt;/h4&gt;
&lt;p&gt;Since Home Assistant records cumulative sums, we need to subtract the erroneous difference from all entries starting from the anomaly. Use the following query:&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-SQL&#34; data-lang=&#34;SQL&#34;&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;UPDATE&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;statistics&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;SET&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;sum&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;sum&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;20676793&lt;/span&gt;.&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;WHERE&lt;/span&gt; metadata_id &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;6&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;and&lt;/span&gt; id &lt;span style=&#34;color:#f92672&#34;&gt;&amp;gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;229351&lt;/span&gt;;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Replace &lt;code&gt;20676793.0&lt;/code&gt; and &lt;code&gt;229351&lt;/code&gt; with your actual values.&lt;/p&gt;
&lt;p&gt;The &lt;code&gt;statistics_short_term&lt;/code&gt; sum should also be adjusted by the same value:&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-SQL&#34; data-lang=&#34;SQL&#34;&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;UPDATE&lt;/span&gt; statistics_short_term &lt;span style=&#34;color:#66d9ef&#34;&gt;SET&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;sum&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;sum&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;20676793&lt;/span&gt;.&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;WHERE&lt;/span&gt; metadata_id &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;6&lt;/span&gt;;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Once done, exit SQLite by pressing &lt;code&gt;Ctrl + D&lt;/code&gt;. The database is now fixed, and the energy panel displays accurate values!&lt;/p&gt;



    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2025/09-hass-fix-statistics/hass_panel_after.png&#34; alt=&#34;Fixed Home-Assistant energy panel&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Fixed Home-Assistant energy panel
        &lt;/div&gt;&lt;/p&gt;
    


</description>
    </item>
    
    <item>
      <title>Update iTead Sonoff Zigbee 3.0 USB Dongle Plus</title>
      <link>https://notes.iopush.net/blog/2021/12-itead-zigbee-dongle/</link>
      <pubDate>Sun, 12 Dec 2021 00:00:00 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2021/12-itead-zigbee-dongle/</guid>
      <description>&lt;p&gt;I recently bought a &lt;a href=&#34;https://itead.cc/product/sonoff-zigbee-3-0-usb-dongle-plus/&#34;&gt;Sonoff Zigbee 3.0 USB Dongle Plus&lt;/a&gt; from iTead to use it with Home Assistant.&lt;br&gt;
While it worked out of the box, the update itself was not complicated but you
have to find the right tools&amp;hellip;&lt;/p&gt;
&lt;h1 id=&#34;update-the-firmware&#34;&gt;Update the firmware&lt;/h1&gt;
&lt;p&gt;The nice Python script &lt;a href=&#34;https://github.com/JelmerT/cc2538-bsl/&#34;&gt;cc2538-bsl&lt;/a&gt; can be used, but the branch &lt;code&gt;feature/ITead_Sonoff_Zigbee-delay&lt;/code&gt; needs to be selected until the &lt;a href=&#34;https://github.com/JelmerT/cc2538-bsl/pull/114&#34;&gt;pull request&lt;/a&gt; is merged.&lt;/p&gt;
&lt;h2 id=&#34;install-cc2538-bsl&#34;&gt;Install cc2538-bsl&lt;/h2&gt;
&lt;pre&gt;&lt;code&gt;git clone https://github.com/JelmerT/cc2538-bsl.git
cd cc2538-bsl
git checkout feature/ITead_Sonoff_Zigbee-delay
python3 -m venv .venv
source .venv/bin/activate
pip install wheel
python setup.py install
pip install intelhex python-magic
&lt;/code&gt;&lt;/pre&gt;&lt;h2 id=&#34;flash-the-dongle&#34;&gt;Flash the dongle&lt;/h2&gt;
&lt;p&gt;Download the firmware from Koenkk&amp;rsquo;s &lt;a href=&#34;https://github.com/Koenkk/Z-Stack-firmware/blob/develop/coordinator/Z-Stack_3.x.0/bin/CC1352P2_CC2652P_launchpad_coordinator_20211207.zip&#34;&gt;Z-Stack&lt;/a&gt;:&lt;/p&gt;
&lt;p&gt;Then use the command&lt;/p&gt;
&lt;pre&gt;&lt;code&gt;python cc2538-bsl.py -e -v -w --bootloader-sonoff-usb ./CC1352P2_CC2652P_launchpad_coordinator_20211207.hex
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;Which should output:&lt;/p&gt;
&lt;pre&gt;&lt;code&gt;sonoff
Opening port /dev/ttyUSB0, baud 500000
Reading data from ./CC1352P2_CC2652P_launchpad_coordinator_20211207.hex
Firmware file: Intel Hex
Connecting to target...
CC1350 PG2.0 (7x7mm): 352KB Flash, 20KB SRAM, CCFG.BL_CONFIG at 0x00057FD8
Primary IEEE Address: 00:12:4B:00:25:6C:59:51
    Performing mass erase
Erasing all main bank flash sectors
    Erase done
Writing 360448 bytes starting at address 0x0000000
Write 104 bytes at 0x00057F980
    Write done                                
Verifying by comparing CRC32 calculations.
    Verified (match: 0x6dca550e)
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;After that you can use the nice &lt;a href=&#34;https://www.home-assistant.io/integrations/zha&#34;&gt;Zigbee Home Automation&lt;/a&gt; integration to easily setup the Zigbee dongle.&lt;/p&gt;</description>
    </item>
    
    <item>
      <title>Automate shutters with an ESP and Home Assistant</title>
      <link>https://notes.iopush.net/blog/2020/automate-shutters-with-an-esp-and-home-assistant/</link>
      <pubDate>Sun, 12 Jul 2020 18:50:41 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2020/automate-shutters-with-an-esp-and-home-assistant/</guid>
      <description>&lt;p&gt;I recently did a proof of concept on shutters automation by hacking the remote
control: the idea is to wire the ESP in parallel with the remote control
buttons.&lt;br&gt;
My remotes are Bubendorff 41677 but it should work with a lot of other remote
controls.&lt;/p&gt;
    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2020/automate-shutters-with-an-esp-and-home-assistant/remote-esp-photo.jpg&#34; alt=&#34;Wemos &amp;amp; the remote control&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Wemos &amp;amp; the remote control
        &lt;/div&gt;&lt;/p&gt;
    


&lt;p&gt;After poking with a multi-meter it appears that two test points are connected to
the right signals:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;TP103: Up&lt;/li&gt;
&lt;li&gt;TP102: Down&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;The signal is active low: there is a pull-up resistor and it must be grounded to
simulate the activation. A 680 Ohm resistor is used in series with each button
of the remote to prevent current overshoot and maybe reduce power consumption,
so I also used them:&lt;/p&gt;



    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2020/automate-shutters-with-an-esp-and-home-assistant/schematic.png&#34; alt=&#34;Schematic&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Schematic
        &lt;/div&gt;&lt;/p&gt;
    


&lt;p&gt;You might not see the resistors on the top picture as I only had SMD 0603 on
hand; look carefully :)&lt;/p&gt;
&lt;p&gt;On the first attempt, I used the great &lt;a href=&#34;https://esphome.io/&#34;&gt;ESPHome&lt;/a&gt; project to
simulate pressing the pushbuttons. I just created 3 virtual switches as a proof
of concept but for correct integration, a
&lt;a href=&#34;https://esphome.io/components/cover/template.html&#34;&gt;cover component&lt;/a&gt; can be
used.&lt;br&gt;
I split the configuration into two files: one generic and the other only
specifying the shutter name (room) and timings.&lt;/p&gt;
&lt;p&gt;Per device file, called &lt;code&gt;shutters-office.yaml&lt;/code&gt; in this example:&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-yaml&#34; data-lang=&#34;yaml&#34;&gt;&lt;span style=&#34;color:#f92672&#34;&gt;substitutions&lt;/span&gt;:
  &lt;span style=&#34;color:#75715e&#34;&gt;# Used for HASS identifier&lt;/span&gt;
  &lt;span style=&#34;color:#f92672&#34;&gt;name&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;office&lt;/span&gt;
  &lt;span style=&#34;color:#75715e&#34;&gt;# Used for friendly name&lt;/span&gt;
  &lt;span style=&#34;color:#f92672&#34;&gt;switch_name&lt;/span&gt;: &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;bureau&amp;#34;&lt;/span&gt;
  &lt;span style=&#34;color:#75715e&#34;&gt;# Time from fully closed to fully opened&lt;/span&gt;
  &lt;span style=&#34;color:#f92672&#34;&gt;full_time&lt;/span&gt;: &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;16s&amp;#34;&lt;/span&gt;
  &lt;span style=&#34;color:#75715e&#34;&gt;# Time from fully closed to slightly opened&lt;/span&gt;
  &lt;span style=&#34;color:#f92672&#34;&gt;partially_open_time&lt;/span&gt;: &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;5s&amp;#34;&lt;/span&gt;
  &lt;span style=&#34;color:#75715e&#34;&gt;# Time for the &amp;#34;button pressed&amp;#34; event&lt;/span&gt;
  &lt;span style=&#34;color:#f92672&#34;&gt;on_time&lt;/span&gt;: &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;150ms&amp;#34;&lt;/span&gt;

&lt;span style=&#34;color:#f92672&#34;&gt;&amp;lt;&amp;lt;&lt;/span&gt;: !&lt;span style=&#34;color:#ae81ff&#34;&gt;include shutters-common.yaml&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Then the generic file called &lt;code&gt;shutters-common.yaml&lt;/code&gt;:&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-yaml&#34; data-lang=&#34;yaml&#34;&gt;&lt;span style=&#34;color:#f92672&#34;&gt;esphome&lt;/span&gt;:
  &lt;span style=&#34;color:#f92672&#34;&gt;name&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;shutters_${name}&lt;/span&gt;
  &lt;span style=&#34;color:#f92672&#34;&gt;platform&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;ESP8266&lt;/span&gt;
  &lt;span style=&#34;color:#f92672&#34;&gt;board&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;d1_mini&lt;/span&gt;

&lt;span style=&#34;color:#f92672&#34;&gt;wifi&lt;/span&gt;:
  &lt;span style=&#34;color:#f92672&#34;&gt;ssid&lt;/span&gt;: &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;MY SSID&amp;#34;&lt;/span&gt;
  &lt;span style=&#34;color:#f92672&#34;&gt;password&lt;/span&gt;: &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;MY PASSWORD&amp;#34;&lt;/span&gt;

  &lt;span style=&#34;color:#75715e&#34;&gt;# Enable fallback hotspot (captive portal) in case wifi connection fails&lt;/span&gt;
  &lt;span style=&#34;color:#f92672&#34;&gt;ap&lt;/span&gt;:
    &lt;span style=&#34;color:#f92672&#34;&gt;ssid&lt;/span&gt;: &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;Shutter fallback hotspot&amp;#34;&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;password&lt;/span&gt;: &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;12345678ABCDEF&amp;#34;&lt;/span&gt;

&lt;span style=&#34;color:#f92672&#34;&gt;captive_portal&lt;/span&gt;:

&lt;span style=&#34;color:#75715e&#34;&gt;# Enable logging&lt;/span&gt;
&lt;span style=&#34;color:#f92672&#34;&gt;logger&lt;/span&gt;:

&lt;span style=&#34;color:#75715e&#34;&gt;# Enable Home Assistant API&lt;/span&gt;
&lt;span style=&#34;color:#f92672&#34;&gt;api&lt;/span&gt;:

&lt;span style=&#34;color:#f92672&#34;&gt;ota&lt;/span&gt;:

&lt;span style=&#34;color:#f92672&#34;&gt;switch&lt;/span&gt;:
  &lt;span style=&#34;color:#75715e&#34;&gt;# Define with GPIOs are used&lt;/span&gt;
  - &lt;span style=&#34;color:#f92672&#34;&gt;platform&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;gpio&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;id&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;up&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;pin&lt;/span&gt;:
      &lt;span style=&#34;color:#f92672&#34;&gt;number&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;12&lt;/span&gt;
      &lt;span style=&#34;color:#f92672&#34;&gt;inverted&lt;/span&gt;: &lt;span style=&#34;color:#66d9ef&#34;&gt;yes&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;restore_mode&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;ALWAYS_OFF&lt;/span&gt;
  - &lt;span style=&#34;color:#f92672&#34;&gt;platform&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;gpio&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;id&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;down&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;pin&lt;/span&gt;:
      &lt;span style=&#34;color:#f92672&#34;&gt;number&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;14&lt;/span&gt;
      &lt;span style=&#34;color:#f92672&#34;&gt;inverted&lt;/span&gt;: &lt;span style=&#34;color:#66d9ef&#34;&gt;yes&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;restore_mode&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;ALWAYS_OFF&lt;/span&gt;

  &lt;span style=&#34;color:#75715e&#34;&gt;# Define template simulating the push on the button&lt;/span&gt;
  - &lt;span style=&#34;color:#f92672&#34;&gt;platform&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;template&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;name&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;Shutter ${switch_name} open&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;turn_on_action&lt;/span&gt;:
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_on&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;up&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;delay&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;${on_time}&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_off&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;up&lt;/span&gt;

  - &lt;span style=&#34;color:#f92672&#34;&gt;platform&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;template&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;name&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;Shutter ${switch_name} close&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;turn_on_action&lt;/span&gt;:
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_on&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;down&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;delay&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;${on_time}&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_off&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;down&lt;/span&gt;

  &lt;span style=&#34;color:#75715e&#34;&gt;# Define template for slightly opening the shutter&lt;/span&gt;
  - &lt;span style=&#34;color:#f92672&#34;&gt;platform&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;template&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;name&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;Shutter ${switch_name} slightly open&lt;/span&gt;
    &lt;span style=&#34;color:#f92672&#34;&gt;turn_on_action&lt;/span&gt;:
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_on&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;down&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;delay&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;${on_time}&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_off&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;down&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;delay&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;${full_time}&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_on&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;up&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;delay&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;${on_time}&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_off&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;up&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;delay&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;${partially_open_time}&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_on&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;up&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;delay&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;${on_time}&lt;/span&gt;
      - &lt;span style=&#34;color:#f92672&#34;&gt;switch.turn_off&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;up&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;As there is no feedback information on the shutter state the &amp;ldquo;&lt;em&gt;slightly opened&lt;/em&gt;&amp;rdquo;
state is achieved by fully closing the shutter then opening it for a small
amount of time.&lt;br&gt;
Once the ESP8266 or ESP32 is flashed the only thing remaining is to add it to
&lt;a href=&#34;https://www.home-assistant.io/&#34;&gt;Home-Assistant&lt;/a&gt;, thanks to &lt;code&gt;Configuration&lt;/code&gt; =&amp;gt;
&lt;code&gt;Integrations&lt;/code&gt; =&amp;gt; &lt;code&gt;Set up a new integration&lt;/code&gt; =&amp;gt; Search for &lt;code&gt;ESPHome&lt;/code&gt; =&amp;gt; enter
the ESP IP address. Et voilà, you are good to go and create powerful automations
in Home-Assistant.&lt;/p&gt;
&lt;p&gt;On the next version, I used a more clever strategy to command shutters from 0 to
100%, and a LoRaWAN board to allow battery-powered operation - to be published
soon.&lt;/p&gt;</description>
    </item>
    
    <item>
      <title>How to monitor pellet stove&#39;s tank</title>
      <link>https://notes.iopush.net/blog/2019/how-to-monitor-pellet/</link>
      <pubDate>Tue, 26 Nov 2019 12:53:50 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2019/how-to-monitor-pellet/</guid>
      <description>&lt;p&gt;I have a great &lt;a href=&#34;https://www.rika.eu&#34;&gt;Rika&lt;/a&gt; pellet stove, but despite all the
embedded electronics, it is unable to warn me just before the pellets tank is
empty. As I already have my own low-power wireless devices and home automation
tools, I just added a distance sensor and designed some enclosures.&lt;/p&gt;
    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2019/how-to-monitor-pellet/stove.png&#34; alt=&#34;Pellet stove&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Pellet stove
        &lt;/div&gt;&lt;/p&gt;
    


&lt;h1 id=&#34;sensor-selection&#34;&gt;Sensor selection&lt;/h1&gt;
&lt;h2 id=&#34;ir-sensor&#34;&gt;IR sensor&lt;/h2&gt;
&lt;p&gt;Cheap usual
&lt;a href=&#34;https://global.sharp/products/device/lineup/data/pdf/datasheet/gp2y0a21yk_e.pdf&#34;&gt;Sharp sensor&lt;/a&gt;
needs to be at least 10 cm away from the pellets. It is a no go for this use
case as pellets are close to the lid when the tank is full&lt;/p&gt;
&lt;h2 id=&#34;ultrasonic-sensors&#34;&gt;Ultrasonic sensors&lt;/h2&gt;
&lt;p&gt;As common as the Sharp IR sensor, the
&lt;a href=&#34;https://www.mouser.com/datasheet/2/813/HCSR04-1022824.pdf&#34;&gt;HC-SR04&lt;/a&gt; was an
option but I discarded it for two reasons:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Dust generated by pellets: sensor difficult to clean&lt;/li&gt;
&lt;li&gt;Not working well with a power supply of 3.3 Vdc&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;stmicroelectronics-time-of-flight-sensor&#34;&gt;STMicroelectronics time of flight sensor&lt;/h2&gt;
&lt;p&gt;So I went with
&lt;a href=&#34;https://www.st.com/resource/en/datasheet/vl53l0x.pdf&#34;&gt;ST VL53L0X&lt;/a&gt;: range
adapted to my needs, low power, and it is easy to the clean sensor. Regarding
dust, I used it for several months without having to clean it but summer was
included, so let&amp;rsquo;s wait a full winter for feedback.&lt;/p&gt;
&lt;h1 id=&#34;hardware&#34;&gt;Hardware&lt;/h1&gt;
&lt;p&gt;I bought a cheap breakout board from eBay and plug the I2C lines into my
&lt;a href=&#34;https://notes.iopush.net/projects/noterf/&#34;&gt;NoteRF&lt;/a&gt; boards&lt;/p&gt;
&lt;h1 id=&#34;software&#34;&gt;Software&lt;/h1&gt;
&lt;p&gt;I just added the library from
&lt;a href=&#34;https://github.com/pololu/vl53l0x-arduino&#34;&gt;Pololu&lt;/a&gt; to my project then
translated the data in &lt;a href=&#34;https://nodered.org/&#34;&gt;Node-Red&lt;/a&gt;.&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-Javascript&#34; data-lang=&#34;Javascript&#34;&gt;&lt;span style=&#34;color:#75715e&#34;&gt;// VL53L0X
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;if&lt;/span&gt; ( &lt;span style=&#34;color:#a6e22e&#34;&gt;sensorType&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;==&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;7&lt;/span&gt; ) {
    &lt;span style=&#34;color:#a6e22e&#34;&gt;msg&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;topic&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;`data/sensor/noterf_distance_&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;${&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;sensorName&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;}&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;/state`&lt;/span&gt;;

	&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;distance&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;msg&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;payload&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;split&lt;/span&gt;( &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;|&amp;#34;&lt;/span&gt; )[&lt;span style=&#34;color:#ae81ff&#34;&gt;2&lt;/span&gt;];
	&lt;span style=&#34;color:#a6e22e&#34;&gt;distance_percent&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;100&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;distance&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;/&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;590&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;*&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;100&lt;/span&gt;;

	&lt;span style=&#34;color:#a6e22e&#34;&gt;msg&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;payload&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; {
	    &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;rssi&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;rssi&lt;/span&gt;,
	    &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;battery&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;battery&lt;/span&gt;,
	};

	&lt;span style=&#34;color:#75715e&#34;&gt;// Filter abnormal values
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;	&lt;span style=&#34;color:#66d9ef&#34;&gt;if&lt;/span&gt; ( ( &lt;span style=&#34;color:#a6e22e&#34;&gt;distance&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;&amp;gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt; ) &lt;span style=&#34;color:#f92672&#34;&gt;&amp;amp;&amp;amp;&lt;/span&gt; ( &lt;span style=&#34;color:#a6e22e&#34;&gt;distance&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;&amp;lt;&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;8000&lt;/span&gt; ) ) {
	    &lt;span style=&#34;color:#a6e22e&#34;&gt;msg&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;payload&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;distance&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;distance&lt;/span&gt;;
	    &lt;span style=&#34;color:#a6e22e&#34;&gt;msg&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;payload&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;distance_percent&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;distance_percent&lt;/span&gt;;
	}
}
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h1 id=&#34;home-assistant&#34;&gt;Home assistant&lt;/h1&gt;
&lt;p&gt;As for all other connected things in my house it reports to
&lt;a href=&#34;https://www.home-assistant.io/&#34;&gt;Home Assistant&lt;/a&gt;, which allows a nice interface,
that I rarely use thanks to the automation: I am notified on my phone (through
&lt;a href=&#34;https://www.pushbullet.com/&#34;&gt;pushbullet&lt;/a&gt;) when tank level or device battery
cross a threshold: the purpose of that device is achieved! Anyway, some fancy
displays can be setup in a few seconds:&lt;/p&gt;



    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2019/how-to-monitor-pellet/stove-percent.png&#34; alt=&#34;Tank status gauge - color changes according to the value&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Tank status gauge - color changes according to the value
        &lt;/div&gt;&lt;/p&gt;
    





    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2019/how-to-monitor-pellet/stove-distance.png&#34; alt=&#34;Tank status in millimeters - useless as percentage is more descriptive&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Tank status in millimeters - useless as percentage is more descriptive
        &lt;/div&gt;&lt;/p&gt;
    





    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2019/how-to-monitor-pellet/stove-icons.png&#34; alt=&#34;Icons &amp;#43; values - I have view with it for all my devices&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Icons &amp;#43; values - I have view with it for all my devices
        &lt;/div&gt;&lt;/p&gt;
    


&lt;p&gt;Device battery needs calibration :-)&lt;/p&gt;
&lt;h1 id=&#34;mechanics&#34;&gt;Mechanics&lt;/h1&gt;
&lt;p&gt;I designed with OnShape two 3D printed boxes for the sensor and the
electronics/battery, both are using magnets to stick in place The sensor is on
the tank lid, while electronics and batteries are outside, hidden on the back of
the stove.&lt;/p&gt;
&lt;p&gt;Design files:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;a href=&#34;https://cad.onshape.com/documents/45d755613314d24a302a4f9d/w/8c3fbb3859e3d10773ac6731/e/be84d8417991516e8ee8feaf&#34;&gt;Time of flight forGYUL53 breakout board&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href=&#34;https://cad.onshape.com/documents/d18d8afd3ce6d5f171c0023e/w/541ec7d59e81f47be7c5d1c0/e/212bd88d468242fcb15d3269&#34;&gt;NoteRF box&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;



    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2019/how-to-monitor-pellet/sensor-tof.jpg&#34; alt=&#34;Time of flight sensor - Hot glued into 3D printed box&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Time of flight sensor - Hot glued into 3D printed box
        &lt;/div&gt;&lt;/p&gt;
    





    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2019/how-to-monitor-pellet/sensor-enclosure.jpg&#34; alt=&#34;Enclosure for the electronics and the battery&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Enclosure for the electronics and the battery
        &lt;/div&gt;&lt;/p&gt;</description>
    </item>
    
    <item>
      <title>ESP32 / MQTT - BLE beacon tracker powered by microPython</title>
      <link>https://notes.iopush.net/blog/2017/mqtt-tracker/</link>
      <pubDate>Thu, 19 Oct 2017 13:47:55 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2017/mqtt-tracker/</guid>
      <description>&lt;p&gt;I am currently working with BLE beacons -only iBeacons for now- with Espressif&amp;rsquo;s
&lt;code&gt;esp-idf&lt;/code&gt; libraries. The aim is to use the ESP32 as a gateway to published
detected beacons to an MQTT broker. It was surprisingly easy and I will write
something about that when the
&lt;a href=&#34;https://github.com/Oliv4945/ESP-Beacon-Tracker&#34;&gt;code&lt;/a&gt; will be more polished.&lt;/p&gt;
&lt;p&gt;Anyway, by curiosity and to speed up development, I wanted to try
microPython port to ESP32, and I did. Unfortunately, BLE support is not yet
reliable enough and a lot of advertisements were lost with 4 to 6 beacons. This
post is to keep track of my work and, hopefully, use in the future when
microPython port will be more reliable :-)&lt;/p&gt;
&lt;h2 id=&#34;micropython-compilation&#34;&gt;microPython compilation&lt;/h2&gt;
&lt;p&gt;While compiling microPython was really straightforward, I had one issue
afterward: I was unable to use the MQTT library, neither by calling it &lt;code&gt;mqtt&lt;/code&gt; or
&lt;code&gt;umqtt&lt;/code&gt;, nor by putting it manually in flash. I did not investigate why but I
found that adding it to the &amp;ldquo;frozen&amp;rdquo; scripts worked.&lt;/p&gt;
&lt;p&gt;The code used is from &lt;a href=&#34;https://pycom.io/&#34;&gt;Pycom&lt;/a&gt; with Wipy 2.0 as target. I used
&lt;a href=&#34;https://github.com/pycom/pycom-micropython-sigfox/tree/c1a862b7733d01c7dd78f16d0287b7033ef9ffd3&#34;&gt;this&lt;/a&gt;
commit against
&lt;a href=&#34;https://github.com/pycom/pycom-esp-idf/tree/13a08ac00cb51f892611af86e81f979c2330ae60&#34;&gt;this version&lt;/a&gt;
of esp-idf.&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Clone both repositories, update esp-idf&amp;rsquo;s submodules&lt;/li&gt;
&lt;li&gt;Set PATH to xtensa compilation tools. Be careful to use only
&lt;a href=&#34;https://dl.espressif.com/dl/xtensa-esp32-elf-linux64-1.22.0-61-gab8375a-5.2.0.tar.gz&#34;&gt;version 1.22.0-61&lt;/a&gt;
for the mentioned Pycom &amp;amp; esp-idf commits.&lt;/li&gt;
&lt;li&gt;Set &lt;code&gt;IDF_PATH&lt;/code&gt; to esp-idf directory&lt;/li&gt;
&lt;li&gt;Change directory to &lt;code&gt;pycom-micropython-sigfox&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;run
&lt;ul&gt;
&lt;li&gt;&lt;code&gt;cd mpy-cross &amp;amp;&amp;amp; make clean &amp;amp;&amp;amp; make&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;cd ../ESP32/frozen&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;wget https://raw.githubusercontent.com/micropython/micropython-lib/a09b3ec20a745cfd1bccb7bd9db513bfe36968db/umqtt.simple/umqtt/simple.py&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;cd ..&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;make BOARD=WIPY TARGET=boot&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;make BOARD=WIPY TARGET=app&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;make BOARD=WIPY flash&lt;/code&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;You can now connect to microPython REPL on your ESP32!&lt;/p&gt;
&lt;p&gt;##Python BLE tracker Following is a quick and dirty code I used to test it. It
does:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Connect to WiFi&lt;/li&gt;
&lt;li&gt;Connect to MQTT server&lt;/li&gt;
&lt;li&gt;Scan for BLE advertisements&lt;/li&gt;
&lt;li&gt;Send one MQTT message by discovered device&lt;/li&gt;
&lt;/ul&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-python&#34; data-lang=&#34;python&#34;&gt;&lt;span style=&#34;color:#f92672&#34;&gt;from&lt;/span&gt; network &lt;span style=&#34;color:#f92672&#34;&gt;import&lt;/span&gt; Bluetooth, WLAN
&lt;span style=&#34;color:#f92672&#34;&gt;from&lt;/span&gt; mqtt &lt;span style=&#34;color:#f92672&#34;&gt;import&lt;/span&gt; MQTTClient
&lt;span style=&#34;color:#f92672&#34;&gt;from&lt;/span&gt; binascii &lt;span style=&#34;color:#f92672&#34;&gt;import&lt;/span&gt; hexlify
&lt;span style=&#34;color:#f92672&#34;&gt;import&lt;/span&gt; machine
&lt;span style=&#34;color:#f92672&#34;&gt;import&lt;/span&gt; time
&lt;span style=&#34;color:#f92672&#34;&gt;import&lt;/span&gt; ujson


&lt;span style=&#34;color:#66d9ef&#34;&gt;def&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;hexlifyNone&lt;/span&gt;(object):
    &lt;span style=&#34;color:#66d9ef&#34;&gt;return&lt;/span&gt; None &lt;span style=&#34;color:#66d9ef&#34;&gt;if&lt;/span&gt; object &lt;span style=&#34;color:#f92672&#34;&gt;is&lt;/span&gt; None &lt;span style=&#34;color:#66d9ef&#34;&gt;else&lt;/span&gt; hexlify(object)


&lt;span style=&#34;color:#66d9ef&#34;&gt;def&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;scan&lt;/span&gt;():
    devices &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; {}
    &lt;span style=&#34;color:#66d9ef&#34;&gt;print&lt;/span&gt;(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;***   Starting   ***&amp;#34;&lt;/span&gt;)
    bt &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; Bluetooth()
    &lt;span style=&#34;color:#66d9ef&#34;&gt;print&lt;/span&gt;(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;Scan...&amp;#34;&lt;/span&gt;, end&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&amp;#34;&lt;/span&gt;)
    bt&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;start_scan(&lt;span style=&#34;color:#ae81ff&#34;&gt;10&lt;/span&gt;)
    time&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;sleep(&lt;span style=&#34;color:#ae81ff&#34;&gt;10&lt;/span&gt;)
    &lt;span style=&#34;color:#66d9ef&#34;&gt;print&lt;/span&gt;(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;OK&amp;#34;&lt;/span&gt;)
    advs &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; bt&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;get_advertisements()
    &lt;span style=&#34;color:#66d9ef&#34;&gt;print&lt;/span&gt;(advs)

    &lt;span style=&#34;color:#66d9ef&#34;&gt;for&lt;/span&gt; adv &lt;span style=&#34;color:#f92672&#34;&gt;in&lt;/span&gt; advs:
        devices[hexlify(adv&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;mac)] &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; {
            &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;Mac&amp;#34;&lt;/span&gt;: hexlify(adv&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;mac),
            &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;Rssi&amp;#34;&lt;/span&gt;: adv&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;rssi,
            &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;Data&amp;#34;&lt;/span&gt;: hexlifyNone(adv&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;data),
            &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;MfrData&amp;#34;&lt;/span&gt;: hexlifyNone(
                bt&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;resolve_adv_data(adv&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;data, Bluetooth&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;ADV_MANUFACTURER_DATA)
            ),
            &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;NameShort&amp;#34;&lt;/span&gt;: hexlifyNone(
                bt&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;resolve_adv_data(adv&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;data, Bluetooth&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;ADV_NAME_SHORT)
            ),
            &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;NameComplete&amp;#34;&lt;/span&gt;: hexlifyNone(
                bt&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;resolve_adv_data(adv&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;data, Bluetooth&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;ADV_NAME_CMPL)
            ),
            &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;Flag&amp;#34;&lt;/span&gt;: bt&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;resolve_adv_data(adv&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;data, Bluetooth&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;ADV_FLAG),
            &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;Appearance&amp;#34;&lt;/span&gt;: hexlifyNone(
                bt&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;resolve_adv_data(adv&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;data, Bluetooth&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;ADV_APPEARANCE)
            ),
        }
        &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&amp;#34;&amp;#34;
&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;        print( &amp;#39;MAC: {}&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;\n\t&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;RSSI: {}&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;\n\t&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;Data: {}&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;\n\t&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;Name: {}&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;\n\t&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;MfrData: {}&amp;#39;.format(
&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;                hexlify( adv.mac ),
&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;                adv.rssi,
&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;                hexlify( adv.data ),
&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;                bt.resolve_adv_data( adv.data, Bluetooth.ADV_NAME_SHORT ),
&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;                hexlify( bt.resolve_adv_data( adv.data, Bluetooth.ADV_MANUFACTURER_DATA ) )
&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;                )
&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;              )
&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;        &amp;#34;&amp;#34;&amp;#34;&lt;/span&gt;
    &lt;span style=&#34;color:#66d9ef&#34;&gt;print&lt;/span&gt;(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;\n&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;***********&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;\n&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;Devices: &amp;#34;&lt;/span&gt;, devices)
    &lt;span style=&#34;color:#66d9ef&#34;&gt;for&lt;/span&gt; key, data &lt;span style=&#34;color:#f92672&#34;&gt;in&lt;/span&gt; devices&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;items():
        &lt;span style=&#34;color:#66d9ef&#34;&gt;print&lt;/span&gt;(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;\n&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;***********&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;\n&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&lt;/span&gt;, data)
        msgJson &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; ujson&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;dumps(data)
        client&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;publish(topic&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;/test&amp;#34;&lt;/span&gt;, msg&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;msgJson)

    &lt;span style=&#34;color:#66d9ef&#34;&gt;print&lt;/span&gt;(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;***   End   ***&amp;#34;&lt;/span&gt;)


&lt;span style=&#34;color:#66d9ef&#34;&gt;def&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;sub_cb&lt;/span&gt;(topic, msg):
    &lt;span style=&#34;color:#66d9ef&#34;&gt;print&lt;/span&gt;(msg)


wlan &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; WLAN(mode&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;WLAN&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;STA)
wlan&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;connect(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;SSID name&amp;#34;&lt;/span&gt;, auth&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;(WLAN&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;WPA2, &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;password&amp;#34;&lt;/span&gt;), timeout&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;5000&lt;/span&gt;)
&lt;span style=&#34;color:#66d9ef&#34;&gt;while&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;not&lt;/span&gt; wlan&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;isconnected():
    machine&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;idle()
&lt;span style=&#34;color:#66d9ef&#34;&gt;print&lt;/span&gt;(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;Connected to Wifi&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;\n&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&lt;/span&gt;)

client &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; MQTTClient(
    &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;device_id&amp;#34;&lt;/span&gt;,
    &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;MQTT broker address&amp;#34;&lt;/span&gt;,
    user&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;user if any&amp;#34;&lt;/span&gt;,
    password&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;password if any&amp;#34;&lt;/span&gt;,
    port&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;1883&lt;/span&gt;,
    ssl&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;True,
)
client&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;set_callback(sub_cb)
client&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;connect()
client&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;subscribe(topic&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;/test&amp;#34;&lt;/span&gt;)
client&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;publish(topic&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;/test&amp;#34;&lt;/span&gt;, msg&lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;Started&amp;#34;&lt;/span&gt;)
scan()

&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;</description>
    </item>
    
    <item>
      <title>NoteRF - Sensors schematic and layout</title>
      <link>https://notes.iopush.net/blog/2016/noterf-sensors-schematic-and-layout/</link>
      <pubDate>Tue, 09 Feb 2016 09:38:04 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2016/noterf-sensors-schematic-and-layout/</guid>
      <description>&lt;p&gt;I finaly published them: sources of my wireless sensors are available
&lt;a href=&#34;https://github.com/Oliv4945/NoteRF-Elec/tree/master/Hardware&#34;&gt;here&lt;/a&gt;.&lt;/p&gt;
&lt;p&gt;For the record it has:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;a href=&#34;http://www.atmel.com/devices/atmega328.aspx&#34;&gt;ATMega328&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href=&#34;http://www.hoperf.com/%20modules/rf_transceiver/RFM69HW.html&#34;&gt;RFM69&lt;/a&gt; wireless
chip&lt;/li&gt;
&lt;li&gt;All analog and digital ports&lt;/li&gt;
&lt;li&gt;3.3V regulator&lt;/li&gt;
&lt;li&gt;Battery tension can be sensed through A7&lt;/li&gt;
&lt;li&gt;Footprint for &lt;a href=&#34;http://datasheets.maximintegrated.com/en/ds/DS7505.pdf&#34;&gt;DS7505&lt;/a&gt;
temperature sensor&lt;/li&gt;
&lt;li&gt;FTDI and ISP connectors&lt;/li&gt;
&lt;/ul&gt;



    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2016/noterf-sensors-schematic-and-layout/NoteRF_0-3-sch.png&#34; alt=&#34;Schematic&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Schematic
        &lt;/div&gt;&lt;/p&gt;
    





    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2016/noterf-sensors-schematic-and-layout/NoteRF_0-3-board.png&#34; alt=&#34;Layout&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Layout
        &lt;/div&gt;&lt;/p&gt;</description>
    </item>
    
    <item>
      <title>Dashing - Job to get data from InfluxDB v0.8 database</title>
      <link>https://notes.iopush.net/blog/2015/dashing-job-to-get-data-from-influxdb-v0-8-database/</link>
      <pubDate>Tue, 14 Apr 2015 09:29:00 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2015/dashing-job-to-get-data-from-influxdb-v0-8-database/</guid>
      <description>&lt;p&gt;To use my dashboard, I wrote some &lt;a href=&#34;http://dashing.io/&#34;&gt;Dashing&lt;/a&gt; jobs to be able
to query some values from my &lt;a href=&#34;http://influxdb.com/&#34;&gt;InfluxDB&lt;/a&gt; database.&lt;/p&gt;
&lt;p&gt;There are thre versions:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;In Ruby&lt;/li&gt;
&lt;li&gt;In node.js (javascript) after my switch to Dashing-js&lt;/li&gt;
&lt;li&gt;A way to update a &amp;lsquo;list&amp;rsquo; widget&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;The third code also changes the background color of a list widget, to set it
regarding data values. I will share the widget&amp;rsquo;s code soon, I just need some
time to clean a bit the code&lt;/p&gt;
&lt;h3 id=&#34;1-ruby-code&#34;&gt;1. Ruby code&lt;/h3&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-ruby&#34; data-lang=&#34;ruby&#34;&gt;&lt;span style=&#34;color:#75715e&#34;&gt;# Insert required components&lt;/span&gt;
require &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;json&amp;#39;&lt;/span&gt;
require &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;net/http&amp;#39;&lt;/span&gt;

&lt;span style=&#34;color:#75715e&#34;&gt;# Parameter&lt;/span&gt;
serverAddr &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;http://localhost:8086&amp;#39;&lt;/span&gt;

&lt;span style=&#34;color:#75715e&#34;&gt;# :first_in sets how long it takes before the job is first run. In this case, it is run immediately&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;SCHEDULER&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;every &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;1m&amp;#39;&lt;/span&gt;, &lt;span style=&#34;color:#e6db74&#34;&gt;:first_in&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&amp;gt;&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;do&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;|&lt;/span&gt;job&lt;span style=&#34;color:#f92672&#34;&gt;|&lt;/span&gt;

  &lt;span style=&#34;color:#75715e&#34;&gt;# Url to get data&lt;/span&gt;
  url &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;URI&lt;/span&gt;( &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;#{&lt;/span&gt;serverAddr&lt;span style=&#34;color:#e6db74&#34;&gt;}&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;/db/db_name/series?u=xxxx&amp;amp;p=xxxx&amp;amp;q=SELECT%20*%20FROM%20%22/data/Conservatory/Humidity%22%20LIMIT%201&amp;#34;&lt;/span&gt; )
  &lt;span style=&#34;color:#75715e&#34;&gt;# Query server&lt;/span&gt;
  res &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;Net&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;::&lt;/span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;HTTP&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;get( url )
  &lt;span style=&#34;color:#75715e&#34;&gt;# Transforms JSON in object&lt;/span&gt;
  j &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;JSON&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;.&lt;/span&gt;parse(res)
  send_event(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;welcome&amp;#39;&lt;/span&gt;, { &lt;span style=&#34;color:#e6db74&#34;&gt;text&lt;/span&gt;: j&lt;span style=&#34;color:#f92672&#34;&gt;[&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;][&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;points&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;][&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;][&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;2&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;]&lt;/span&gt; })
  send_event(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;synergy&amp;#39;&lt;/span&gt;, { &lt;span style=&#34;color:#e6db74&#34;&gt;value&lt;/span&gt;: j&lt;span style=&#34;color:#f92672&#34;&gt;[&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;][&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;points&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;][&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;][&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;2&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;]&lt;/span&gt; })

&lt;span style=&#34;color:#66d9ef&#34;&gt;end&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h3 id=&#34;2-in-nodejs-easier-to-modify&#34;&gt;2. In node.js, easier to modify&lt;/h3&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-javascript&#34; data-lang=&#34;javascript&#34;&gt;&lt;span style=&#34;color:#75715e&#34;&gt;// Includes
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;request&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;require&lt;/span&gt;( &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;request&amp;#39;&lt;/span&gt; )

&lt;span style=&#34;color:#75715e&#34;&gt;// Configuration
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbAddress&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;localhost&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbPort&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;8086&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbName&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;XXXX&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbUser&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;XXXX&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbPwd&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;XXXX&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;refreshTime&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;60&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;*&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;1000&lt;/span&gt;    &lt;span style=&#34;color:#75715e&#34;&gt;// in ms
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;getData&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;parameterToRefresh&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;widgetId&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;unit&lt;/span&gt; ) {
  &lt;span style=&#34;color:#75715e&#34;&gt;// URL creation
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;  &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;urlToGet&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;http://&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;dbAddress&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;:&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;dbPort&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;/db/&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;dbName&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;/series?u=&amp;#39;&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbUser&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;&amp;amp;p=&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;dbPwd&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;&amp;amp;q=SELECT%20*%20FROM%20%22/data/&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;parameterToRefresh&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;%22%20LIMIT%201&amp;#39;&lt;/span&gt;
  &lt;span style=&#34;color:#75715e&#34;&gt;// Request
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;  &lt;span style=&#34;color:#a6e22e&#34;&gt;request&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;urlToGet&lt;/span&gt;, &lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt; (&lt;span style=&#34;color:#a6e22e&#34;&gt;error&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;response&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;body&lt;/span&gt;) {
    &lt;span style=&#34;color:#66d9ef&#34;&gt;if&lt;/span&gt; (&lt;span style=&#34;color:#f92672&#34;&gt;!&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;error&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;&amp;amp;&amp;amp;&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;response&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;statusCode&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;==&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;200&lt;/span&gt;) {
      &lt;span style=&#34;color:#75715e&#34;&gt;// No error, send the value to the dashboard
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;   	  &lt;span style=&#34;color:#a6e22e&#34;&gt;send_event&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;widgetId&lt;/span&gt;, { &lt;span style=&#34;color:#a6e22e&#34;&gt;value&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt; Math.&lt;span style=&#34;color:#a6e22e&#34;&gt;round&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;JSON&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;parse&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;body&lt;/span&gt;)[&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;points&amp;#39;&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;2&lt;/span&gt;]&lt;span style=&#34;color:#f92672&#34;&gt;*&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;100&lt;/span&gt;)&lt;span style=&#34;color:#f92672&#34;&gt;/&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;100&lt;/span&gt; })
    }
  })
}

&lt;span style=&#34;color:#a6e22e&#34;&gt;setInterval&lt;/span&gt;( &lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt;() { &lt;span style=&#34;color:#a6e22e&#34;&gt;getData&lt;/span&gt;( &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Outside/Pressure&amp;#39;&lt;/span&gt;, &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;outsideText&amp;#39;&lt;/span&gt;, &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39; mbara&amp;#39;&lt;/span&gt; ) }, &lt;span style=&#34;color:#a6e22e&#34;&gt;refreshTime&lt;/span&gt; )
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h3 id=&#34;3-and-a-way-to-fill-a-list-widget&#34;&gt;3. And a way to fill a &amp;lsquo;list&amp;rsquo; widget&lt;/h3&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4&#34;&gt;&lt;code class=&#34;language-javascript&#34; data-lang=&#34;javascript&#34;&gt;&lt;span style=&#34;color:#f92672&#34;&gt;&amp;lt;&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;pre&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;&amp;gt;&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;// Includes
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;http&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;require&lt;/span&gt;( &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;http&amp;#39;&lt;/span&gt; )
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#66d9ef&#34;&gt;async&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;require&lt;/span&gt;( &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;async&amp;#39;&lt;/span&gt; )
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;request&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;require&lt;/span&gt;( &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;request&amp;#39;&lt;/span&gt; )

&lt;span style=&#34;color:#75715e&#34;&gt;// Configuration
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbAddress&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;localhost&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbPort&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;8086&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbName&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;XXXX&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbUser&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;XXXX&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;dbPwd&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;XXXX&amp;#39;&lt;/span&gt;
&lt;span style=&#34;color:#75715e&#34;&gt;// itemsToQuery [ dataNameInInflux, NameToDisplayInWidget ]
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;itemsToQuery&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; [ [ &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Conservatory&amp;#39;&lt;/span&gt;,  &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;PLA&amp;#39;&lt;/span&gt; ],
                     [ &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;SensorTest_1&amp;#39;&lt;/span&gt;,  &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Citrus&amp;#39;&lt;/span&gt; ],
                     [ &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;LivingRoom&amp;#39;&lt;/span&gt;,    &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Salon&amp;#39;&lt;/span&gt; ],
                     [ &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Office&amp;#39;&lt;/span&gt;,        &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Bureau&amp;#39;&lt;/span&gt; ]
                    ]
&lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;refreshTime&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;60&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;*&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;1000&lt;/span&gt;    &lt;span style=&#34;color:#75715e&#34;&gt;// in ms
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;
&lt;span style=&#34;color:#75715e&#34;&gt;// Function to fetch data
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;getDataList&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;url&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;callback&lt;/span&gt;) {
  &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;data&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&amp;#34;&lt;/span&gt;

  &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;req&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;http&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;request&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;url&lt;/span&gt;, &lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;res&lt;/span&gt;) {
    &lt;span style=&#34;color:#a6e22e&#34;&gt;res&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;on&lt;/span&gt;(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;data&amp;#39;&lt;/span&gt;, &lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;chunk&lt;/span&gt;) {
        &lt;span style=&#34;color:#a6e22e&#34;&gt;data&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;chunk&lt;/span&gt;
    })
    &lt;span style=&#34;color:#a6e22e&#34;&gt;res&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;on&lt;/span&gt;(&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;end&amp;#39;&lt;/span&gt;, &lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;e&lt;/span&gt;) {
        &lt;span style=&#34;color:#a6e22e&#34;&gt;callback&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;e&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;data&lt;/span&gt;)
    })
  }).&lt;span style=&#34;color:#a6e22e&#34;&gt;end&lt;/span&gt;()
}

&lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;refreshDataList&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;parameterToRefresh&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;widgetId&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;unit&lt;/span&gt; ) {
  &lt;span style=&#34;color:#75715e&#34;&gt;// Variables declaration
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;  &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;urls&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; []
  &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;itemarray&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; []
  &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;average&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;

  &lt;span style=&#34;color:#75715e&#34;&gt;// Set url regarding unit
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;  &lt;span style=&#34;color:#66d9ef&#34;&gt;switch&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;unit&lt;/span&gt; ) {
    &lt;span style=&#34;color:#66d9ef&#34;&gt;case&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39; %&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;urlPrefix&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;data/&amp;#39;&lt;/span&gt;; &lt;span style=&#34;color:#a6e22e&#34;&gt;urlSuffix&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;/&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;parameterToRefresh&lt;/span&gt;; &lt;span style=&#34;color:#66d9ef&#34;&gt;break&lt;/span&gt;
    &lt;span style=&#34;color:#66d9ef&#34;&gt;case&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;°C&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;urlPrefix&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;data/&amp;#39;&lt;/span&gt;; &lt;span style=&#34;color:#a6e22e&#34;&gt;urlSuffix&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;/&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;parameterToRefresh&lt;/span&gt;; &lt;span style=&#34;color:#66d9ef&#34;&gt;break&lt;/span&gt;
    &lt;span style=&#34;color:#66d9ef&#34;&gt;default&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt;   &lt;span style=&#34;color:#a6e22e&#34;&gt;urlPrefix&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;parameterToRefresh&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;/&amp;#39;&lt;/span&gt;; &lt;span style=&#34;color:#a6e22e&#34;&gt;urlSuffix&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;&amp;#39;&lt;/span&gt;; &lt;span style=&#34;color:#66d9ef&#34;&gt;break&lt;/span&gt;
  }
  &lt;span style=&#34;color:#75715e&#34;&gt;// Table construction regarding the items ot query
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;  &lt;span style=&#34;color:#66d9ef&#34;&gt;for&lt;/span&gt;( &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;; &lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;&amp;lt;&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;itemsToQuery&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;length&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;-&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;1&lt;/span&gt;; &lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;++&lt;/span&gt; ) {
    &lt;span style=&#34;color:#a6e22e&#34;&gt;urls&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;push&lt;/span&gt;( &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;http://&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;dbAddress&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;:&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;dbPort&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;/db/&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;dbName&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;/series?u=&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;dbUser&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;&amp;amp;p=&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;dbPwd&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;&amp;amp;q=SELECT%20*%20FROM%20%22/&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;urlPrefix&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; encodeURIComponent(&lt;span style=&#34;color:#a6e22e&#34;&gt;itemsToQuery&lt;/span&gt;[&lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;])&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;urlSuffix&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;%22%20LIMIT%201&amp;#39;&lt;/span&gt;)
  }

  &lt;span style=&#34;color:#75715e&#34;&gt;// Asynchronous call to get the data
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;  &lt;span style=&#34;color:#66d9ef&#34;&gt;async&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;map&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;urls&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;getDataList&lt;/span&gt;, &lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;err&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;result&lt;/span&gt; ) {
    &lt;span style=&#34;color:#75715e&#34;&gt;// Parse results
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;    &lt;span style=&#34;color:#66d9ef&#34;&gt;for&lt;/span&gt;( &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;; &lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;&amp;lt;&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;result&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;length&lt;/span&gt;; &lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;++&lt;/span&gt; ) {
      &lt;span style=&#34;color:#a6e22e&#34;&gt;itemarray&lt;/span&gt;[&lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt;] &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; {&lt;span style=&#34;color:#a6e22e&#34;&gt;label&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;itemsToQuery&lt;/span&gt;[&lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;1&lt;/span&gt;], &lt;span style=&#34;color:#a6e22e&#34;&gt;value&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt; (&lt;span style=&#34;color:#a6e22e&#34;&gt;JSON&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;parse&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;result&lt;/span&gt;[&lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt;])[&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;points&amp;#39;&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;2&lt;/span&gt;] &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;unit&lt;/span&gt;)}
      &lt;span style=&#34;color:#a6e22e&#34;&gt;average&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;average&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;JSON&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;parse&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;result&lt;/span&gt;[&lt;span style=&#34;color:#a6e22e&#34;&gt;i&lt;/span&gt;])[&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;points&amp;#39;&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;2&lt;/span&gt;]
    }
    &lt;span style=&#34;color:#a6e22e&#34;&gt;average&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; Math.&lt;span style=&#34;color:#a6e22e&#34;&gt;round&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;average&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;/&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;result&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;length&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;*&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;100&lt;/span&gt; )&lt;span style=&#34;color:#f92672&#34;&gt;/&lt;/span&gt;&lt;span style=&#34;color:#ae81ff&#34;&gt;100&lt;/span&gt;

    &lt;span style=&#34;color:#75715e&#34;&gt;// Select color and &amp;#39;moreinfo&amp;#39; message regarding data type and average value
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;    &lt;span style=&#34;color:#66d9ef&#34;&gt;switch&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;unit&lt;/span&gt; ) {
      &lt;span style=&#34;color:#66d9ef&#34;&gt;case&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39; %&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt;
        &lt;span style=&#34;color:#a6e22e&#34;&gt;backGroundColor&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;humidityColor&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;average&lt;/span&gt; )
        &lt;span style=&#34;color:#a6e22e&#34;&gt;moreinfo&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Moyenne : &amp;#39;&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;average&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;unit&lt;/span&gt;; &lt;span style=&#34;color:#66d9ef&#34;&gt;break&lt;/span&gt;
      &lt;span style=&#34;color:#66d9ef&#34;&gt;case&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;°C&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt;
        &lt;span style=&#34;color:#a6e22e&#34;&gt;backGroundColor&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;insideTemperatureColor&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;average&lt;/span&gt; );
        &lt;span style=&#34;color:#a6e22e&#34;&gt;moreinfo&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Moyenne : &amp;#39;&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;average&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;unit&lt;/span&gt;; &lt;span style=&#34;color:#66d9ef&#34;&gt;break&lt;/span&gt;
      &lt;span style=&#34;color:#66d9ef&#34;&gt;case&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39; V&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt;
        &lt;span style=&#34;color:#a6e22e&#34;&gt;mini&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; Math.&lt;span style=&#34;color:#a6e22e&#34;&gt;min&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;apply&lt;/span&gt;(Math, &lt;span style=&#34;color:#a6e22e&#34;&gt;result&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;map&lt;/span&gt;(&lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;table&lt;/span&gt;) { &lt;span style=&#34;color:#66d9ef&#34;&gt;return&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;JSON&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;parse&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;table&lt;/span&gt;)[&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;points&amp;#39;&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;2&lt;/span&gt;] }))
        &lt;span style=&#34;color:#a6e22e&#34;&gt;backGroundColor&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;batteryLevelColor&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;mini&lt;/span&gt; )
        &lt;span style=&#34;color:#a6e22e&#34;&gt;moreinfo&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Minimum : &amp;#39;&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;mini&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;unit&lt;/span&gt;; &lt;span style=&#34;color:#66d9ef&#34;&gt;break&lt;/span&gt;
      &lt;span style=&#34;color:#66d9ef&#34;&gt;case&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39; dB&amp;#39;&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt;
        &lt;span style=&#34;color:#a6e22e&#34;&gt;mini&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; Math.&lt;span style=&#34;color:#a6e22e&#34;&gt;min&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;apply&lt;/span&gt;(Math, &lt;span style=&#34;color:#a6e22e&#34;&gt;result&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;map&lt;/span&gt;(&lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;table&lt;/span&gt;) { &lt;span style=&#34;color:#66d9ef&#34;&gt;return&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;JSON&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;parse&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;table&lt;/span&gt;)[&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;points&amp;#39;&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;0&lt;/span&gt;][&lt;span style=&#34;color:#ae81ff&#34;&gt;2&lt;/span&gt;] }))
        &lt;span style=&#34;color:#a6e22e&#34;&gt;backGroundColor&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;rssiColor&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;mini&lt;/span&gt; )
        &lt;span style=&#34;color:#a6e22e&#34;&gt;moreinfo&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Minimum : &amp;#39;&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;mini&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;+&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;unit&lt;/span&gt;; &lt;span style=&#34;color:#66d9ef&#34;&gt;break&lt;/span&gt;
      &lt;span style=&#34;color:#66d9ef&#34;&gt;default&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt;
        &lt;span style=&#34;color:#a6e22e&#34;&gt;backGroundColor&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;55555&amp;#39;&lt;/span&gt;
    }

    &lt;span style=&#34;color:#75715e&#34;&gt;// Prepare structure to send
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;    &lt;span style=&#34;color:#66d9ef&#34;&gt;var&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;datastruct&lt;/span&gt; &lt;span style=&#34;color:#f92672&#34;&gt;=&lt;/span&gt; {
      &lt;span style=&#34;color:#a6e22e&#34;&gt;items&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;itemarray&lt;/span&gt;,
      &lt;span style=&#34;color:#a6e22e&#34;&gt;backGroundColor&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;backGroundColor&lt;/span&gt;,
      &lt;span style=&#34;color:#a6e22e&#34;&gt;moreinfo&lt;/span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;:&lt;/span&gt;  &lt;span style=&#34;color:#a6e22e&#34;&gt;moreinfo&lt;/span&gt;
    }
    &lt;span style=&#34;color:#a6e22e&#34;&gt;send_event&lt;/span&gt;( &lt;span style=&#34;color:#a6e22e&#34;&gt;widgetId&lt;/span&gt;, &lt;span style=&#34;color:#a6e22e&#34;&gt;datastruct&lt;/span&gt; )
  })
}

&lt;span style=&#34;color:#75715e&#34;&gt;// Set job call every refreshTime
&lt;/span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;&lt;/span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;setInterval&lt;/span&gt;( &lt;span style=&#34;color:#66d9ef&#34;&gt;function&lt;/span&gt;() { &lt;span style=&#34;color:#a6e22e&#34;&gt;refreshDataList&lt;/span&gt;( &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;Humidity&amp;#39;&lt;/span&gt;, &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39;humidityList&amp;#39;&lt;/span&gt;, &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#39; %&amp;#39;&lt;/span&gt; ) }, &lt;span style=&#34;color:#a6e22e&#34;&gt;refreshTime&lt;/span&gt; )
&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;</description>
    </item>
    
    <item>
      <title>From Dashing.io to Dashing-js</title>
      <link>https://notes.iopush.net/blog/2015/from-dashing-io-to-dashing-js/</link>
      <pubDate>Fri, 10 Apr 2015 09:15:00 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2015/from-dashing-io-to-dashing-js/</guid>
      <description>&lt;p&gt;I recently discovered &lt;a href=&#34;http://dashing.io/&#34;&gt;Dashing.io&lt;/a&gt;, which is an easy to use
dashboard, which seems to fit my needs :&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Easy to install&lt;/li&gt;
&lt;li&gt;Useful widgets available, easy to add new ones&lt;/li&gt;
&lt;li&gt;Generation of templates for dashboards, jobs, widgets&lt;/li&gt;
&lt;li&gt;Great design (subjective), some friends find it too close to Windows 8, but I
don&amp;rsquo;t use it, so&amp;hellip;&lt;/li&gt;
&lt;li&gt;New data can be pushed via internal jobs or external API, by calling an URL&lt;/li&gt;
&lt;li&gt;Tile based interface with drag&amp;amp;drop re-arranging (based on Gridster)&lt;/li&gt;
&lt;li&gt;Auto-adaptation to smartphone/tablets (Responsive)&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;From my point of view, the major drawback is that it uses Ruby language. I have
nothing about it, I just did not want to add another &amp;lsquo;technology&amp;rsquo; to this
project, which uses already lots of things. So I tried it, and then discovered
&lt;a href=&#34;https://github.com/fabiocaseri/dashing-js&#34;&gt;Dashing-js&lt;/a&gt;: a Node.js port.&lt;/p&gt;



    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2015/from-dashing-io-to-dashing-js/dashboard.png&#34; alt=&#34;Dashing dashboard&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Dashing dashboard
        &lt;/div&gt;&lt;/p&gt;
    


&lt;p&gt;The port is not as well documented as the Ruby version, so I will share my
experience:&lt;/p&gt;
&lt;h3 id=&#34;run-on-a-sub-directory-helpful-for-reverse-proxy&#34;&gt;Run on a sub-directory (helpful for reverse proxy)&lt;/h3&gt;
&lt;p&gt;The easiest way to add it on &lt;code&gt;/dashing&lt;/code&gt; is:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;In file &lt;code&gt;node_modules/dashing-js/lib/dashing.js&lt;/code&gt;&lt;br&gt;
Add &lt;code&gt;app.use(&#39;/dashing&#39;, app.router);&lt;/code&gt; (L75) inside
&lt;code&gt;app.configure(function() { }&lt;/code&gt; block&lt;/li&gt;
&lt;li&gt;In file &lt;code&gt;assets/javascripts/application.coffee&lt;/code&gt;&lt;br&gt;
Add &lt;code&gt;Batman.config.viewPrefix = &#39;dashing/views&#39;&lt;/code&gt; after
&lt;code&gt;#= require_tree ../../widgets&lt;/code&gt;,&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;stop-a-dashboard-launch-as-daemon&#34;&gt;Stop a dashboard launch as daemon&lt;/h3&gt;
&lt;p&gt;If you start your dashboard in background with &lt;code&gt;dashing-js start&lt;/code&gt;,
&lt;code&gt;dashing-js stop&lt;/code&gt; will not work, you must use &lt;code&gt;kill PID&lt;/code&gt; command. I hope to have
some time to explore the code and correct the bug/implement it soon.&lt;/p&gt;
&lt;h3 id=&#34;set-default-dashboard&#34;&gt;Set default dashboard&lt;/h3&gt;
&lt;p&gt;Edit the file &lt;code&gt;server.js&lt;/code&gt;, then line
&lt;code&gt;dashing.default_dashboard = &#39;subPathIfNeeded/sample&#39;;&lt;/code&gt;.&lt;/p&gt;
&lt;h3 id=&#34;save-the-current-tile-layout&#34;&gt;Save the current tile layout&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;Drag the tiles&lt;/li&gt;
&lt;li&gt;Click on the &amp;lsquo;Save this layout&amp;rsquo; button&lt;/li&gt;
&lt;li&gt;Copy the code&lt;/li&gt;
&lt;li&gt;Paste it in &lt;code&gt;dashboard/yourDashboard.jade&lt;/code&gt; respecting the following example
indentation, and the &lt;code&gt;.&lt;/code&gt; (dot) after &lt;code&gt;script(type=&amp;quot;text/javascript&amp;quot;).&lt;/code&gt; Done !&lt;/li&gt;
&lt;/ul&gt;
&lt;pre&gt;&lt;code&gt;extends layout

block title
  | Dashboard&#39;s title

block content
  div.gridster
    ul
      li(data-row=&#39;1&#39;, data-col=&#39;1&#39;, data-sizex=&#39;4&#39;, data-sizey=&#39;2&#39;)
        div(data-id=&#39;welcome&#39;, data-view=&#39;Text&#39;, data-title=&#39;Hello&#39;, data-text=&#39;This is your shiny new dashboard.&#39;, data-moreinfo=&#39;Protip: You can drag the widgets around!&#39;)
    center
      div(style=&#39;font-size: 12px&#39;) Try this: curl -d &#39;{ &amp;quot;auth_token&amp;quot;: &amp;quot;YOUR_AUTH_TOKEN&amp;quot;, &amp;quot;text&amp;quot;: &amp;quot;Hey, Look what I can do!&amp;quot; }&#39; -H &amp;quot;Content-Type: application/json&amp;quot; http://#{request.header(&#39;host&#39;)}/widgets/we$


  script(type=&amp;quot;text/javascript&amp;quot;).
    $(function() { Dashing.gridsterLayout(&#39;[{&amp;quot;col&amp;quot;:1,&amp;quot;row&amp;quot;:1,&amp;quot;size_x&amp;quot;:4,&amp;quot;size_y&amp;quot;:2} [...] }]&#39;) })
&lt;/code&gt;&lt;/pre&gt;</description>
    </item>
    
    <item>
      <title>NoteRF - Add a new sensor - Soil moisture sensor</title>
      <link>https://notes.iopush.net/blog/2015/noterf-add-a-new-sensor-moisture-sensor/</link>
      <pubDate>Fri, 20 Mar 2015 08:29:00 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2015/noterf-add-a-new-sensor-moisture-sensor/</guid>
      <description>&lt;p&gt;As I like to have plants at home but always forgot to water them, I bought a
cheap resistive soil moisture sensor. Actually, it is just two strips of copper
wired as a voltage divider with a 10k resistor, the IC is used as a comparator
to have a &amp;ldquo;digital&amp;rdquo; output, with a threshold set by the trimpot.&lt;/p&gt;
    
    
        
        
        
        
    

    
    
    

    
    







  


    

    
        &lt;p&gt;&lt;span class=&#34;image center&#34;&gt;
            &lt;img src=&#34;https://notes.iopush.net/blog/2015/noterf-add-a-new-sensor-moisture-sensor/IMG_20150318_223823-225x300.jpg&#34; alt=&#34;Soil moisture sensor&#34;&gt;
        &lt;/span&gt;&lt;/p&gt;
        &lt;p&gt;&lt;div class=&#34;align-center&#34; style=&#34;font-weight: bold;&#34;&gt;
            Soil moisture sensor
        &lt;/div&gt;&lt;/p&gt;
    


&lt;p&gt;The sensor can draw up to 35 mA, so I wired the power line to an output of the
microcontroller. Be careful that on the ATMega328, it is 40 mA max by pin with a
sum of 200 mA for all pins. It might be good to use a FET transistor if too much
power is drawn.&lt;/p&gt;
&lt;p&gt;Adding it to my home &lt;a href=&#34;https://notes.iopush.net/projects/noterf/&#34;&gt;automation system&lt;/a&gt; is
quite straightforward:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Add a new sensor type in config.h&lt;/li&gt;
&lt;li&gt;Add some code to set the I/O in &lt;code&gt;setup()&lt;/code&gt; function&lt;/li&gt;
&lt;li&gt;Add some code to read the sensor in &lt;code&gt;loop()&lt;/code&gt; function&lt;/li&gt;
&lt;li&gt;Send it over the air :)&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;My citrus is complaining if it needs some water! For the record, I found that I
need to water the plant if the value is more than 200 out of 255. This value
must be changed regarding soil composition and its salt saturation.&lt;/p&gt;
&lt;p&gt;Even if it works, I already see some improvements:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;I read an analog value, so there is no need for the comparator: try a 100% DIY
way with some copper + resistor&lt;/li&gt;
&lt;li&gt;Standalone watering system: use the comparator + RC or a 555 timer to open a
solenoid valve under a bottle of water&lt;/li&gt;
&lt;li&gt;For vegetables in the garden, link it to the water pump of my water well&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Copper strips might get some oxidation over time, which will change its
resistance, it might be better to use
&lt;a href=&#34;http://en.wikipedia.org/wiki/Capacitance_probe&#34;&gt;capacitance sensor&lt;/a&gt; instead.&lt;/p&gt;</description>
    </item>
    
    <item>
      <title>NoteRF - Why create a new set of things ?</title>
      <link>https://notes.iopush.net/blog/2015/noterf-why-create-a-new-set-of-things/</link>
      <pubDate>Wed, 18 Mar 2015 08:20:00 +0000</pubDate>
      
      <guid>https://notes.iopush.net/blog/2015/noterf-why-create-a-new-set-of-things/</guid>
      <description>&lt;h1 id=&#34;hardware&#34;&gt;Hardware&lt;/h1&gt;
&lt;p&gt;I had a discussion with a friend of mine on &lt;em&gt;Why the hell are you designing a
new PCB instead of buying one&lt;/em&gt; ? He is right: there is a lot of great cheap
boars like &lt;a href=&#34;http://lowpowerlab.com/moteino/&#34;&gt;Moteino&lt;/a&gt;,
&lt;a href=&#34;http://www.anarduino.com/miniwireless/&#34;&gt;Anarduino&lt;/a&gt;,
&lt;a href=&#34;http://www.anarduino.com/miniwireless/&#34;&gt;Jeenode&lt;/a&gt;&amp;hellip; But on the other side:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;I like to learn.&lt;/li&gt;
&lt;li&gt;Some of them are expensive compared to a full DIY solution.&lt;/li&gt;
&lt;li&gt;It is not so difficult: it is just an ATmega, an RF chip, an optional voltage
regulator and some passives selected to optimize power consumption.&lt;/li&gt;
&lt;li&gt;Adapted to my needs (RFM69hw, dedicated footprint for some sensors, form
factor, regulator, connectors&amp;hellip;).&lt;/li&gt;
&lt;li&gt;I am not reinventing the wheel, so I will use
&lt;a href=&#34;https://github.com/LowPowerLab/RFM69&#34;&gt;libraries&lt;/a&gt; from these boards.&lt;/li&gt;
&lt;li&gt;Regarding firmware they have done a great job, but I did not found it
flexible enough or too complicated for my needs.&lt;/li&gt;
&lt;/ol&gt;
&lt;h1 id=&#34;software--ihm&#34;&gt;Software &amp;amp; IHM&lt;/h1&gt;
&lt;p&gt;A lot of big softwares, hhis time too, I see the pros and cons:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Jeedom
&lt;ul&gt;
&lt;li&gt;Good GUI design, looks pretty&lt;/li&gt;
&lt;li&gt;Only use of MySQL, not really adapted for storing sensors data on a small
embedded Linux card&lt;/li&gt;
&lt;li&gt;Open-source but commercial aspects are really intrusive&lt;/li&gt;
&lt;li&gt;Not so easy to add a module&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;Domoticz
&lt;ul&gt;
&lt;li&gt;Seems more open and lightweight than Jeedom&lt;/li&gt;
&lt;li&gt;Bad GUI design&lt;/li&gt;
&lt;li&gt;Seems to be based on SQLite, lightweight but some old test on a Gumstix gave
me issues after a few months&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;li&gt;OpenHAB
&lt;ul&gt;
&lt;li&gt;Created to be linked to any modules or database&lt;/li&gt;
&lt;li&gt;Not lightweight, might be related to the use of Java&lt;/li&gt;
&lt;li&gt;Bad GUI design for version 1, the v2 seems great.&lt;/li&gt;
&lt;li&gt;The v2 will be too late for me&lt;/li&gt;
&lt;/ul&gt;
&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Also, I discovered &lt;a href=&#34;http://nodered.org/&#34;&gt;Node-Red&lt;/a&gt; which is really easy to use
and created &amp;ldquo;&lt;em&gt;for wiring together hardware devices, APIs and online services in
new and interesting ways&lt;/em&gt;&amp;rdquo;, exactly what I am doing. The main drawback is that
everything is asynchronous.&lt;/p&gt;
&lt;h1 id=&#34;database&#34;&gt;Database&lt;/h1&gt;
&lt;p&gt;On the database side I wanted to try time-series databases which are made to
collects metrics, and NoSQL.&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;a href=&#34;http://www.mongodb.org/&#34;&gt;MongoDB&lt;/a&gt; with or without cube layer: I heard good
things but never tried.&lt;/li&gt;
&lt;li&gt;&lt;a href=&#34;http://graphite.wikidot.com/&#34;&gt;Graphite&lt;/a&gt;: I tried on a Raspberry Pi, it works
but it is a complete solution: too big for me, a lot of dependencies and
components&lt;/li&gt;
&lt;li&gt;&lt;a href=&#34;http://influxdb.com/&#34;&gt;InfluxDB&lt;/a&gt;: I like the approach, the v0.9 add &amp;lsquo;tags&amp;rsquo;
which are good for my application, perform well on the rPi. Maybe a too
unstable but I will give a try :)&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;On the GUI side, I did not found what I want yet, so I am testing
&lt;a href=&#34;http://grafana.org/&#34;&gt;Grafana&lt;/a&gt; to display data and might use some links inside
to start actions until I find something great. I might also do it myself, but I
am far away from being a designer so it can be really ugly&amp;hellip;&lt;/p&gt;
</description>
    </item>
    
  </channel>
</rss>
