-
Compteur de contenus
1 329 -
Inscription
-
Dernière visite
-
Jours gagnés
30
Tout ce qui a été posté par Bloug
-
Bon j'avance ! et bien même Je me suis concentré sur le problème de Token qui change souvent, il faut s'identifier avec un POST qui retourne alors le bon Token et j'ai trouvé comment faire marcher mon POST grace à https://apitester.com/ en fait j'ai besoin du/des bon Headers sinon la requette merdouille et de bidouillé l'encodage du data local http = net.HTTPClient() http:request('https://www.airzonecloud.com/users/sign_in/', { success = function(response) if response.status == 201 then if response.data and response.data ~= "" then --fibaro:debug('Retour : '.. response.data) local jsonTable = json.decode(response.data) local k, v for k, v in pairs(jsonTable) do end fibaro:setGlobal("airzone_Token", jsonTable.user.authentication_token) -- Token envoyé dans une variable else fibaro:debug("Error : empty response data") end else fibaro:debug("Erreur : status=" .. tostring(response.status)) end end, error = function(err) fibaro:debug("Erreur : " .. err) end, options = { method = 'POST', headers = {["Content-Type"] = "application/json;charset=UTF-8",}, data = "{\"email\":\"******\",\"password\":\"********\"}" } }) Enfin j'arrive egalement a reproduire une commande ON ou OFF d'une Zone MAIS je suis obliger de m'identifier avant sur api test.com j'y arrive seulement grace à la fonction STEP en deux étapes : STEP1 : Identification via un POST STEP2 : Demande de modif de zone via un Post ( avec d'autre arguments en header ) le second POST est vers : https://www.airzonecloud.com/events/?user_email=******&user_token=****** avec le data : "{\"event\":{\"cgi\":\"modzona\",\"system_number\":\"1\",\"zone_number\":\"4\",\"option\":\"state\",\"value\":0,\"device_id\":\"5a37f4167765621039320000\"}}" Donc ma question Comment faire cela ? faut il reproduire l'ensemble du code en déut de mon post : comme dans ton tuto sous : -- Ici la suite du code, exécuté en synchrone, donc avant l'exécution du contenu de la fonction success() ou sous : -- Ici la suite du code, exécuté en asynchrone, donc après la fin de l'exécution du code appelant http:request() ou 3eme option un truc de fous d'informaticien ? MErci
-
ahh il y a une mise à jour de dispo ? je me suis jamais penché dessus car inexistante à l'achat
-
Oulalalalala du lourd !! J'installe immédiatement ! MERCI
- 488 réponses
-
- tuto multimã©dia
- onduleur
-
(et 3 en plus)
Étiqueté avec :
-
je vais continuer à chercher ! doucemanette Encore merci !
-
local fullurl = ( serveur .. myAuth_DID ) --============================================================================ -- Fonction Urlencode() function urlencode(str) if (str) then str = string.gsub (str, "\n", "\r\n") str = string.gsub (str, "([^%w ])", function (c) return string.format ("%%%02X", string.byte(c)) end) str = string.gsub (str, " ", "+") end return str end fibaro:debug('<font color="green"> fullurl : </font>' .. fullurl ) -- Appel HTTPS local http = net.HTTPClient() http:request(fullurl, { success = function(response) if response.status == 200 then le débug de la variable fullurl copié dans le navigateur fonctionne parfaitement c'est pas demain que je hack qq moi .....
-
je viens de de tout RE-vérifier, j'encode le mail , j'encode le token , je débug l'ensemble et le résultat copier dans le navigateur marche mais avec la HC2 .... 404 [DEBUG] 12:07:58: mail : *****%40*****%2E**[DEBUG] 12:07:58: token : ******%5F******[DEBUG] 12:07:58: auth : ?format=json&device_id=5a37f4167765621039320000&user_email=*****%40*****%2E**&user_token=******%5F***** y'a surement une sécurité c'est pas possible ..... des redirections ou autre...
-
@Lazer juste pour être sur .... si mon url : https://airzonecloud.com/zones/?format=json&device_id=5a37f4167765621039320000&user_email=*****&user_token=***** me retourne un json tout plein d'info quand je la pose dans un navigateur.... cette meme URL placé dans mon http:request n'est pas censé me retourner une erreur 404 ( not Found ) non ?
-
J'avance sur la 2eme solution ! avec deja un piège de la team AirZone ! suite à un coup de tel hier à la hotline le tech c'est connecté dessus et du coup le Token à changé .... donc j'arrive à règler le pb de l'dentification : {"error":"Il est nécessaire que vous soyez inscrit afin de pouvoir continuer."} ensuite mes deux coquilles : https://airzonecloud.com/zones/?format=json&system_id=5b139f1ef51445a30df80c6c?user_email=*****&user_token=**** déjà j'ai deux erreurs dans l'url : le ? je pense qu'il faut le remplacer par une & , et le system_id lui est pour le Groupe Nuit et non la "Zone" donc à remplacer par l’étiquette : id https://airzonecloud.com/zones/?format=json&device_id=5b139f1ef51445a30df80c6d&user_email=*****&user_token=***** quand je colle cela dans mon navigateur celui ci m'affiche : {"zones":[]} je pense donc arriver pas trop loin du bon endroit vu que la commande du PUT est : data = '{"zone":{"state":"1"}}' reste à comprendre pourquoi du coté de la HC2 j'ai une erreur 404 Edit : en fait non même avec : https://airzonecloud.com/zones/?format=json&user_email=*****&user_token=***** j'ai le meme retour ....
-
pour le urlencode() tu parle de "email:password" dans mon cas j'ai une "email" &user_token= "Token" c'est l'ensemble de la ligne que je dois encoder : email&user_token=Token car en encodant chacun de son coté , meme problème. , le token est genre : 3ICzvRojbmRZ-BjuNEOqy0vUQSudNYOMedHwTFt8 Pour la seconde : j'ai modifié avec : https://airzonecloud.com/zones/?format=json&system_id=5b139f1ef51445a30df80c6c?user_email=*****&user_token=**** qui me donne du 404 - mais dans le navigateur j'ai : {"error":"Il est nécessaire que vous soyez inscrit afin de pouvoir continuer."}
-
peut etre une autre piste , en trifouillant le sniffer j'ai trouvé une commande PUT qui change également l’état : PUT /zones/5b139f1ef51445a30df80c6c?user_email=*****&user_token=***** { "zone": { "state": "1" } } voici mon code : --================= IDENTIFICATION =========================================== local serveur = 'airzonecloud.com' local user_email = '*******' local user_token = '*******' local regist_Id = '*******' --============================================================================ local device_ID = '5a37f4167765621039320000' ----- ID du System ------ local espace_Jour = '5b139f1ef51445a30df80c6f' -- Jour local zone_Salon = '5b139f1ef51445a30df80c70' --------------- Salon 0 local espace_Nuit = '5b139f1ef51445a30df80c69' -- Nuit local zone_Parents = '5b139f1ef51445a30df80c6a' --------------- Parents 0 local zone_Sport = '5b139f1ef51445a30df80c6b' --------------- Sport 1 local zone_Alyssa = '5b139f1ef51445a30df80c6c' --------------- Alyssa 2 local zone_Bureau = '5b139f1ef51445a30df80c6d' --------------- Bureau 3 --============================================================================ local myAuthJour = ( '/?format=json&system_id=' .. espace_Jour .. '&user_email=' .. user_email .. '&user_token=' .. user_token ) local myAuthNuit = ( '/?format=json&system_id=' .. espace_Nuit .. '&user_email=' .. user_email .. '&user_token=' .. user_token ) local myAuth = ( '?user_email=' .. urlencode(tostring(user_email)) .. '&user_token=' .. user_token ) function urlencode(str) if (str) then str = string.gsub (str, "\n", "\r\n") str = string.gsub (str, "([^%w ])", function (c) return string.format ("%%%02X", string.byte(c)) end) str = string.gsub (str, " ", "+") end return str end --fibaro:debug("urlencode : " .. urlencode(tostring(user_email))) -- Appel HTTPS local http = net.HTTPClient() http:request('https://airzonecloud.com/zones/' .. zone_Bureau .. myAuth, { success = function(response) if response.status == 200 then if response.data and response.data ~= "" then fibaro:debug('Retour : '.. response.data) local jsonTable = json.decode(response.data) -- Parcours de la table JSON local k, v for k, v in pairs(jsonTable) do fibaro:debug("key = " .. k .. " - type(v) = " .. type(v)) end -- Ici la suite du code, exécuté en asynchrone, donc après la fin de l'exécution du code appelant http:request() -- ... else fibaro:debug("Error : empty response data") end else fibaro:debug("Erreur : status=" .. tostring(response.status)) end end, error = function(err) fibaro:debug("Erreur : " .. err) end, options = { method = 'PUT', data = '{"zone":{"state":"1"}}' } }) -- Ici la suite du code, exécuté en synchrone, donc avant l'exécution du contenu de la fonction success() -- ... malheureusement j'ai également une erreur mais..... différente : [DEBUG] 07:21:31: Erreur : Bad file descriptor peut être qu'ici le pb peut être contourné
-
merci beaucoup @Lazer pour ton temps ! j'a donc trouvé la fonction urlencode() que j'ai adapté pour l'authentification t local myAuth = ( '?user_email=' .. urlencode(tostring(user_email)) .. '&user_token=' .. user_token ) function urlencode(str) if (str) then str = string.gsub (str, "\n", "\r\n") str = string.gsub (str, "([^%w ])", function (c) return string.format ("%%%02X", string.byte(c)) end) str = string.gsub (str, " ", "+") end return str end fibaro:debug("urlencode : " .. urlencode(tostring(user_email))) [DEBUG] 06:47:41: Erreur : status=401 <---- mais toujours le meme pb . L'erreur 401 ( unauthorized )
-
Voici mon pb : Je souhaite utiliser des fonctions de mon system AirZone via la HC2 pour combiner des actions ( fenetre ouverte ==> push ==> extinction de la zone ou genre CO2 > xx =>> mode ventilation etc... ) L'API AirZone n'est pas publique mais dans le dernier Airzone m'informent qu'ils y bossent .... ( bientot 1ans ... ) Du coup je me suis amusé avec le sniffer Android : Packet Capture : où j'ai trouver des infos comme les requêtes GET sur mon Groupe Nuit composée de 4 Zones : https://airzonecloud.com/zones/?format=json&system_id=5b139f1ef51445a30df80c69&user_email=*****&user_token=***** ou mon Groupe Jour composée d'une seule Zone : https://airzonecloud.com/zones/?format=json&system_id=5b139f1ef51445a30df80c6f&user_email=*****&user_token=***** Voici voici un extrait du retour de la requête ( j'ai coupé pour pas la faire trop longue ) Zone NUIT : { "zones": [ { "id": "5b139f1ef51445a30df80c6c", "system_id": "5b139f1ef51445a30df80c69", "device_id": "5a37f4167765621039320000", "modes": "1111111011", "warning": "0", "name": "Alyssa", "system_number": "1", "zone_number": "3", "state": "0", "consign": "25.0", "temp": "25.8", "mode": "1", "velocity": null, "show_velocity": null, "sleep": "0", "lower_conf_limit": "18.0", "upper_conf_limit": "30.0", "master": null, "eco": "0", "prog_enabled": "0", "speed_prog_mode": null, "show_ventilation": "1", "updated_at": 1529765477, "setup_type": "0", "class": "Zone", "last_update": 1529765477, "next_schedule_number": "0", "led": null, "offset": null, "cold_offset": null, "heat_offset": null, "scene": null, "air_flow": null, "humidity": null, "coldConsign": "", "heatConsign": "", "auto": false, "temperature_unit": false, "config": { "id": "5b159daaf51445a30df8123c", "cold_values": null, "heat_values": null, "cold_angle": null, "heat_angle": null, "swing_horizontal": null, "swing_vertical": null, "antifreeze": "0", "vla": null, "zone_number": "3", "slave": null, "master": null, "basic_mode": null, "ambient_temp": null, "heat_type": null, "cold_type": null, "heat_type_config": null, "cold_type_config": null, "ventilation": null, "q_weight": null, "window": null, "presence": null, "spray_dew": null, "local_vent": null, "tact_fw": null, "firm_lm": null, "manufacturer": null, "led": null, "confort_cold_consign": null, "confort_heat_consign": null, "eco_cold_consign": null, "eco_heat_consign": null, "unocupied_cold_consign": null, "unocupied_heat_consign": null, "vacation_cold_consign": null, "vacation_heat_consign": null, "firm_ws": "3.10", "offset": null, "errors": "0", "zone_id": "5b139f1ef51445a30df80c6c", "automatic_weight": null, "autochange_differential": null, "offset_environment_cold": null, "offset_environment_heat": null ....................................................... } }, { "id": "5b139f1ef51445a30df80c6d", "system_id": "5b139f1ef51445a30df80c69", "device_id": "5a37f4167765621039320000", "modes": "1111111011", "warning": "0", "name": "Bureau", ....................................................... } }, { "id": "5b139f1ef51445a30df80c6a", "system_id": "5b139f1ef51445a30df80c69", "device_id": "5a37f4167765621039320000", "modes": "1111111011", "warning": "0", "name": "Parents", ....................................................... }, { "id": "5b139f1ef51445a30df80c6b", "system_id": "5b139f1ef51445a30df80c69", "device_id": "5a37f4167765621039320000", "modes": "1111111011", "warning": "0", "name": "Sport", } ] } j'ai donc accès avec le GET aux info importante grace au code : local http = net.HTTPClient() http:request('https://airzonecloud.com/zones/' .. myAuthNuit, { options = { method = 'GET' }, success = function(response) if response.status == 200 then if response.data and response.data ~= "" then local jsonTable = json.decode(response.data) -- Alyssa local nameAlyssa = jsonTable.zones[1].name local consAlyssa = jsonTable.zones[1].consign local tempAlyssa = jsonTable.zones[1].temp local modeAlyssa = jsonTable.zones[1].mode local etatAlyssa = jsonTable.zones[1].state local lupdAlyssa = jsonTable.zones[1].last_update -- Etat de la Zone Alyssa if etatAlyssa == "0" then etatAlyssa = " arret " elseif etatAlyssa == "1" then etatAlyssa = " marche " end -- Mode de travail Alyssa if modeAlyssa == "1" then modeAlyssa = " Refroidissement " elseif modeAlyssa == "3" then modeAlyssa = " Chauffage " elseif modeAlyssa == "5" then modeAlyssa = " Deshumidification " elseif modeAlyssa == "7" then modeAlyssa = " Ventilation " end -- Débug Alyssa fibaro:debug( 'Zone Nuit : ' .. nameAlyssa ) fibaro:debug( 'Consigne à :' .. consAlyssa .. '°C -- Température Actuelle : ' .. tempAlyssa .. '°C ' ) fibaro:debug( 'Mode de Fonctionnement :' .. modeAlyssa .. ' -- Etat Actuel : en' .. etatAlyssa ) fibaro:debug( '*************' ) --- Suite ci dessous --- else fibaro:debug("Error : empty response data") end else fibaro:debug("Error : status=" .. tostring(response.status)) end end, error = function(err) fibaro:debug("Error : " .. err) end }) Enfin analyser les modifications avec packet caputure sur la mise en marche et arrêt d'une zone j'ai le POST suivant : POST /events/?user_email=********&user_token=******** HTTP/1.1 Host: www.airzonecloud.com Connection: keep-alive Content-Length: 131 Accept: application/json, text/plain, */* Origin: file:// X-Requested-With: XMLHttpRequest User-Agent: Mozilla/5.0 (Linux; Android 8.0.0; SM-G950F Build/R16NW; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/67.0.3396.87 Mobile Safari/537.36 Content-Type: application/json;charset=UTF-8 Accept-Encoding: gzip, deflate Accept-Language: fr-FR,en-US;q=0.9 { "event": { "cgi": "modzona", "system_number": "1", "zone_number": "4", "option": "state", "value": 0, "device_id": "5a37f4167765621039320000" } } ou j'utilise donc ta scene : local myAuth = ( '?user_email=' .. user_email .. '&user_token=' .. user_token ) -- ====================== Z O N N E N U I T ===================== -- -- Appel HTTPS local http = net.HTTPClient() http:request('https://airzonecloud.com/events/' .. myAuth, { success = function(response) if response.status == 200 then if response.data and response.data ~= "" then fibaro:debug('Retour : '.. response.data) local jsonTable = json.decode(response.data) -- Parcours de la table JSON local k, v for k, v in pairs(jsonTable) do fibaro:debug("key = " .. k .. " - type(v) = " .. type(v)) end -- Ici la suite du code, exécuté en asynchrone, donc après la fin de l'exécution du code appelant http:request() -- ... else fibaro:debug("Error : empty response data") end else fibaro:debug("Erreur : status=" .. tostring(response.status)) end end, error = function(err) fibaro:debug("Erreur : " .. err) end, options = { method = 'POST', data = '{"event":{"cgi":"modzona","system_number":"1","zone_number":"4","option":"state","value":1,"device_id":"5a37f4167765621039320000"}}' } }) -- Ici la suite du code, exécuté en synchrone, donc avant l'exécution du contenu de la fonction success() -- ... mais j'ai une Erreur : 401 unauthorized [DEBUG] 09:29:05: Erreur : status=401 déjà pour le data je suis obligé de le réduire en une ligne et de le placer entre des ' ' ( Ôhhh passage, suis passé par le site : https://codebeautify.org/jsonviewer ) data = '{"event":{"cgi":"modzona","system_number":"1","zone_number":"4","option":"state","value":1,"device_id":"5a37f4167765621039320000"}}' sinon j'ai toujours des erreurs, même si je le pose sous la forme : data = { "event": { "cgi": "modzona", "system_number": "1", "zone_number": "4", "option": "state", "value": 1, "device_id": "5a37f4167765621039320000" } } Donc pour GET je passe par ici : http:request('https://airzonecloud.com/zones/' .. myAuthNuit, { et pour POST par là : http:request('https://airzonecloud.com/events/' .. myAuth, { mais rien dans le navigateur si je colle la ligne : https://airzonecloud/events/?user_email=******&user_token=***** d'où ma question de hier de faire un POST directement après le GET en utilisant le : jsonTable.zones[1].state = "1" sur la requette : https://airzonecloud.com/zones/ et non /events/... j'espère avoir été assez clair :S lol merci.
-
Bon après beaucoup de tests avec GET puis POST puis qu'avec POST et une erreur 401 j'ai ajouter des éléments dans le headers pour bloqué sur du 400 ... Comme le souligne le grand philosophe espagnol : Mas banda ! j'arrêter de polluer le topic ....
- 58 réponses
-
merci , je regarde immediatement !
- 58 réponses
-
oui
- 58 réponses
-
désolé, pour etre plus clair, je souhaite comprendre le fonctionnent, j'utilise pour récupérer des info un GET et un element de la table : local etatAlyssa = jsonTable.zones[1].state Si je souhaite modifier la valeur de l'élément et lui attribuer la valeur 1 ou 0 => state = 1 j'utilise donc la seconde parti de ton code avec POST et la valeur dans le myJson EX : local myJson = { "couleurs": { [1] = "bleu", [2] = "blanc", [3] = "rouge" }, "fruits": { [1] = "pomme", [2] = "banane" }, } donc pour mon cas je dois utiliser la même structure qu'avec GET ? ou il faut adapter comme dans ton ex avec les accolades : jsonTable.zones[1].state jsonTable.zones[1].state modif : {"zones":[{"state":"0"}]} ou peut etre qu'il n' a aucun rapport entre un GET et POST...
- 58 réponses
-
merci pour le tuto, Petite question , si je récupère une donné avec un GET : local etatAlyssa = jsonTable.zones[1].state pour la modifier dois je utiliser la meme structure que le GET ? local myJson = { jsonTable.zones[1].state = "1" } merci
- 58 réponses
-
Oh cool ! Merci beaucoup je vais prendre une aspirine avant
-
y'a pas de pb lol C'est la fameuse erreur entre la chaise et le clavier
-
loool impec je regarde cela merci.
-
@Lazer toc toc toc bon je me doute qu'avec Alexa mon sujet n’intéresse pas grand monde ( visiteur 1 ( moi)) lol mais puis je avoir ton analyse sur le message d'erreur? et vers quel coté chercher ? Est-ce une erreur du coté de la requette qui semble fausse du myjson ou de la 'method' ? merci
-
Alexa sur Amazon Echo (Plus, Dot, Spot, ...)
Bloug a répondu à un(e) sujet de yoim dans Les Assistants Vocaux
Et les cmd avec ha-bridge c'est quoi ? Alexa, demande à M. Bridge d'allumer..... ?- 501 réponses
-
Alexa sur Amazon Echo (Plus, Dot, Spot, ...)
Bloug a répondu à un(e) sujet de yoim dans Les Assistants Vocaux
Lol moi j'arrive à obtenir les infos de fibaro sur mobile mais quand je bascule sur un compte amazon fr je perds tout. Ayant un pb avec mon numéro de tel déjà associé je pense que mon pb est donc là.- 501 réponses
-
Alexa sur Amazon Echo (Plus, Dot, Spot, ...)
Bloug a répondu à un(e) sujet de yoim dans Les Assistants Vocaux
Cool Je test plus tard merci- 501 réponses
-
- 1
-
-
Alexa sur Amazon Echo (Plus, Dot, Spot, ...)
Bloug a répondu à un(e) sujet de yoim dans Les Assistants Vocaux
Idem- 501 réponses