
Meteosource è un fornitore globale di dati meteorologici che offre condizioni attuali, previsioni e dati storici tramite API REST. Il template TapHome si connette al piano gratuito dell’API Meteosource tramite HTTPS e legge le condizioni meteo attuali e le previsioni giornaliere per una posizione GPS configurata.
Il template fornisce 8 dispositivi in sola lettura che coprono tipo meteo, velocità e direzione del vento, temperatura attuale, temperature giornaliere minima/massima e precipitazioni (attuali e giornaliere). Il modulo interroga l’API ogni 5 minuti e memorizza l’intera risposta JSON nella cache — i singoli sensori leggono poi dalla cache a intervalli più brevi. Il piano gratuito consente 400 chiamate al giorno e il template ne utilizza circa 288 al giorno, ampiamente entro il limite.
Configurazione
Ottenere la chiave API
- Registra un account gratuito su meteosource.com/client/sign-up
- Dopo la registrazione, la chiave API è disponibile nel dashboard dell’account
- Copia la chiave — sarà necessaria durante l’importazione del template in TapHome
Il piano gratuito fornisce 400 chiamate API al giorno con un limite di 10 richieste al minuto. Il template TapHome interroga ogni 5 minuti (288 chiamate/giorno), lasciando un margine confortevole. Il piano gratuito richiede una menzione e un backlink a Meteosource per uso commerciale.
Parametri di importazione
Durante l’importazione del template in TapHome, sono richiesti tre parametri:
| Parametro | Descrizione | Esempio |
|---|---|---|
latitude | Latitudine della posizione in gradi decimali | 48.1778 |
longitude | Longitudine della posizione in gradi decimali | 17.1426 |
apiKey | Chiave API Meteosource dal dashboard dell’account | abc123def456... |
Per trovare le coordinate di una posizione, fai clic destro su Google Maps e seleziona le coordinate dal menu contestuale.
Variabili del modulo
Dopo l’importazione del template, una variabile può essere regolata nelle impostazioni del modulo:
| Variabile | Descrizione | Predefinito |
|---|---|---|
tz | Fuso orario in formato tzinfo | Europe/Prague |
Il fuso orario determina come vengono interpretati i timestamp nella risposta dell’API. Gli utenti al di fuori del fuso orario CET/CEST dovrebbero modificare questo valore per adattarlo alla propria posizione (es. America/New_York, Asia/Tokyo, UTC).
Endpoint API
Il modulo si connette a www.meteosource.com tramite HTTPS (porta 443) e chiama:
| |
Il template utilizza il sistema di unità ca (canadese): Celsius per la temperatura, km/h per la velocità del vento, mm per le precipitazioni e hPa per la pressione.
Funzionalità dei dispositivi
Tipo meteo
Il dispositivo Weather Type è uno switch multi-valore che mappa il campo Meteosource icon_num (valori 1–36) su 7 categorie meteo TapHome:
| Valore switch | Categoria | Icone Meteosource (giorno) | Icone Meteosource (notte) |
|---|---|---|---|
| 0 | Sereno / Soleggiato | 2, 3, 4, 5 | 26, 27, 28 |
| 1 | Nuvoloso / Coperto | 6, 7, 8 | 29, 30, 31 |
| 2 | Pioggia | 11, 12, 13, 25 | 32, 34, 35, 36 |
| 3 | Pioggerella / Pioggia leggera | 10 | – |
| 4 | Temporale | 14, 15 | 33 |
| 5 | Neve / Gelata | 16–24 | – |
| 6 | Nebbia | 9 | – |
Se il numero dell’icona è 1 o non riconosciuto, lo switch si imposta sul valore predefinito 1 (Nuvoloso). Il tipo meteo viene interrogato ogni 30 minuti.
Temperatura
Tre dispositivi di temperatura forniscono dati attuali e previsionali:
- Temperature — temperatura dell’aria attuale a 2 m di altezza in Celsius. Utilizza un tipo di dispositivo sensore di temperatura dedicato con segnalazione errori se la risposta dell’API non è disponibile
- Temperature Max — temperatura massima prevista per oggi in Celsius, letta dalla sezione previsioni giornaliere (
daily.data[0]) - Temperature Min — temperatura minima prevista per oggi in Celsius, letta dalla sezione previsioni giornaliere (
daily.data[0])
Vento
- Wind Speed — velocità del vento attuale a 10 m di altezza in km/h (utilizzando il sistema di unità
ca). Segnala un errore se la risposta memorizzata non è disponibile - Wind Direction — direzione del vento in gradi (0–360, dove 0/360 = Nord, 90 = Est, 180 = Sud, 270 = Ovest). Questo è il dispositivo interrogato più frequentemente con intervalli di 15 secondi, che legge dalla risposta memorizzata
Precipitazioni
- Precipitation (1-hour) — quantità di precipitazioni attuale in mm. Segnala un errore se la risposta memorizzata non è disponibile
- Precipitation (Daily) — precipitazioni giornaliere totali previste per oggi in mm, lette dalla sezione previsioni giornaliere
Funzionalità aggiuntive
L’API Meteosource fornisce anche temperatura percepita, raffiche di vento, copertura nuvolosa, pressione atmosferica, umidità, visibilità, indice UV, punto di rugiada, windchill, tipo di precipitazione e un riepilogo meteo testuale per le condizioni attuali. Un endpoint per la qualità dell’aria con PM10, PM2.5, NO2, CO, O3 e AQI è disponibile separatamente. Questi possono essere aggiunti in un futuro aggiornamento del template.
Risoluzione problemi
Tutti i dispositivi mostrano NaN o nessun dato
- Verifica che il TapHome Core abbia accesso a internet — il template richiede connettività HTTPS in uscita verso
www.meteosource.com - Controlla che la chiave API sia valida e non sia stata rigenerata
- Conferma che i valori di latitudine e longitudine siano coordinate decimali corrette
- Le nuove chiavi API potrebbero richiedere alcuni minuti per l’attivazione dopo la registrazione
Letture obsolete o ritardate
Il modulo interroga l’API Meteosource ogni 5 minuti e memorizza la risposta in una variabile cache. I singoli sensori leggono da questa cache a intervalli più brevi (da 15 secondi a 1 minuto). Se la chiamata API fallisce, tutti i sensori continuano a restituire gli ultimi valori memorizzati fino alla successiva interrogazione riuscita.
L’API Meteosource è un servizio cloud che richiede una connessione internet attiva sul TapHome Core. Durante interruzioni di internet o indisponibilità dell’API, il template non riceverà dati meteo aggiornati. Il fuso orario predefinito è
Europe/Prague— gli utenti in altre regioni devono modificare la variabile del modulotzper ottenere timestamp locali corretti.
