Read the statement by Michael Teeuw here.
ESP8266 + DHT22 + Thingspeak in magic mirror
-
Alright so I read it partially and as I understand it you have to do it in a few steps:
First you have to create a channel and configure it(don’t forget to set it to public). Important: don’t set it to public as this is not secure! Use the api key you have from the channel instead! You can use the api key by adding&api_key=YOUR_KEY
at the end of the url you would use when the channel is public!The REST module accepts only single values from the URL. So you cannot get the whole feed at once. What you will have to do instead is retrieve only one field as text. How to do that can be found here under
Get Last Entry in a Field Feed
and thenText
.
So having configured a channel, having the right URL for the field you want with the api key in it (you can test if it’s correct by going to the URL yourself and you should see only a single value) the last thing for you to do is configure the module.
How to do that can be found it the module’s README.md. Don’t forget to configureoutput
aswell, else you won’t see anything on screen. Hope this is what you are looking for, if it still doesn’t work or you have any other questions don’t hesitate to ask/let me know! -
@tosti007 Thank you so much for your help! I was so close. everything you describe i did except for making it public.:D The url gives the correct value. What i dont get it is why are there so many links and why dont all links have a description above it? Should i only use celsius and humidity? Could you also explain what mapping means?
{ format: '%.1f', url: 'https://www.dirk-melchers.de/echo.php?text=22.54', }, { format: '%d%%', url: 'https://www.dirk-melchers.de/echo.php?text=59.1', }, { format: '%s', mapping: 'temperature', url: 'https://www.dirk-melchers.de/echo.php?text=2', }, { format: '%d', url: 'https://www.dirk-melchers.de/echo.php?text=62.1', }, { format: 'Lights %s', mapping: 'on_off', url: 'https://www.dirk-melchers.de/echo.php?text=true', }
The urls i replace with my urls: https://api.thingspeak.com/channels/12345/fields/12345/last.txt
Like this one for the humidity.
With configure output you mean: if i have multiple fields i have to change that number. In my case, just for beginning:[Livingroom','@1','@2'],
Too bad im at work and cant configure my raspberry. But this feels like it should work. :)
Note from admin: please use Markup when posting code.
-
@tosti007 I got it all working! thank you for pointing me in the right direction!! :D
-
Thank you so much for your help!
You’re welcome :D
What i dont get it is why are there so many links and why dont all links have a description above it?
There are so many links because you have to retrieve every field by itself. They don’t have a description because just defining a field to retrieve doesn’t display it yet, this is done in the output section.
Should i only use celsius and humidity?
You can use anything you want.
Could you also explain what mapping means?
Using mapping is a way to translate one value into another. For example you retrieve the state of your lamps and it returns a boolean. Just displaying
true
orfalse
doesn’t look so nice.on
oroff
would be better and make more sense in a human way. So you could use a mapping to translate that. For the example above the mapping would be:mappings: { on_off: { true: 'on', false: 'off', }, },
The urls i replace with my urls: https://api.thingspeak.com/channels/xxxxx/fields/2/last.txt
Don’t forget to make an url for each field.
With configure output you mean: if i have multiple fields i have to change that number.
No,
output
configures the way you display your sections (after mapping and formatting) on your mirror.
So for example you have defined 3 urls in thesections
value. The first url is the state of your lamps (with a mapping), the second is the humidity in your living room and the third the temperature in your living room. And you want to display it like:Lamps on Livingroom 21 degrees 52%
Then your output would look like:
output: [ ['Lamps','@1'], // use number 1 here because you defined that first in sections ['Livingroom','@3','@2'] // you defined temperature as third, but we want to display it first,?so we use @3 first and @2 second ],
Does this explain everything? :)
-
@Gelomidor ah great! You’re welcome and enjoy it :D
-
@Gelomidor I just realised I made a mistake! Setti your channel to public isn’t secure (anyone would be able to check the states of your lamps ect). Instead you should add the api key to the url by using the same url you would use when it’s public and adding
&api_key=YOUR_KEY
at the end of the url. Please do update this! (also remove the channel id in the url you usef above in post 6) -
@tosti007 Why Thingspeak and not FHEM?