Explorando APIs e monitorando gateways TTN (The Thing Network)
Antiga Versão - v0 (caso já conheça o contexto, sugiro saltar para Nova Versão)
A boa dica desta vez será um fluxo para monitorar falhas de gateways (Gateway Management). Na verdade, nada foi inventado, pois este trabalho foi inspirado e adaptado da comunidade TTN de Barcelona (https://tinkerman.cat/post/monitor-your-ttn-gateways-with-node-red). Mas afinal, o que é TTN? Por favor, acesse o link.
Mas em uma linha: TTN é um rede voltada para IoT que emprega a tecnologia LoRa&LoRaWAN para atender aos quesitos de conectividade à longa distância (5 km variável) e low power.
A ideia se baseia em utilizar algumas APIs, meio que perdidas no “limbo”, para checar o status (online ou offline) dos gateways numa determinada região e, melhor ainda, ser alertado por meio do envio de mensagem - aplicativo Telegram - quando houver alguma alteração de status.
Bem, faz-se necessário saber lidar um pouco com o Node-RED, descobrir o ID dos gateways-alvos de interesse e configurar apropriadamente o Node "telegram sender". Simplesmente, importe o código gw-management-v0.json (descontinuado e substituído pela nova versão no item abaixo) para o seu Node-RED e faça as adaptações necessárias para sua rede, checando cada etapa do fluxo com o Node "debug".
Bene, bene, bene ... o mundo sempre girando!
Houve na TTN uma significativa mudança, eu diria não só de versão da stack do servidor de rede LoRaWAN mas também conceitual sob vários aspectos. Uma destas mudanças impactou as antigas API correlatas ao status dos gateways, que foram utilizadas na descrição acima. Eis um trecho retirado da fala do próprio Johan Stokking:
I’m happy to announce that we have a new API for fetching gateway locations, online status and other info for The Things Stack Community Edition, Cloud, Open Source and Enterprise: Packet Broker Mapper API. Since we wanted to make gateway information available in one place, we built a new service for this in Packet Broker. With Packet Broker being the backbone for LoRaWAN traffic, making gateway information available in a central place allows for better insight in the entire ecosystem and discovery of (private) networks to exchange traffic with.
Backwards compatibility
This replaces two existing APIs: the https://www.thethingsnetwork.org/gateway-data endpoint and the NOC (part of V2). The former now uses the Packet Broker Mapper API as data source, so applications using the old API now receive up-to-date information (including our very own www.thethingsnetwork.org gateway map as we work on a redesign of the homepage). Please update your API clients to consume the new API, as we will be shutting down the "/gateway-data" endpoint by the end of 2021. The NOC is already gone.
Pois então, a ideia é recuperar a aplicação antiga (gerenciamento dos GW regionais) utilizando-se da nova API (Packet Broker Mapper) disponibilizada.
Exemplos de emprego da API:
- todos os gateways num raio de 50 Km de Caxias do Sul - RS: https://mapper.packetbroker.net/api/v2/gateways?distanceWithin[latitude]=-29.167778&distanceWithin[longitude]=-51.178889&distanceWithin[distance]=50000&netID=000013&tenantID=ttn;
- todos os gateways - globais - online e conectados a TTN V2 (rede em obsolescência): https://mapper.packetbroker.net/api/v2/gateways?online=true&netID=000013&tenantID=ttnv2; e
- consulta as características de um gateway individual "
id
=gw-gpstesouro": https://mapper.packetbroker.net/api/v2/gateways/netID=000013,tenantID=ttn,id=gw-gpstesouro.
Observações: (i) TTN utiliza
netID
000013 etenantID
(locatário): ttn (V3) and ttnv2 (V2); (ii) como novidade,rxRate
etxRate
são taxas médias de tráfego dos últimos 6 minutos e, também, houve a inclusão da timestampupdatedAt
; (iii) tenha paciência em aguardar as atualizações: o statusonline
=false (offline),rxRate
etxRate
podem demorar um pouco mais de 10 minutos eonline
=true leva cerca de 1 minuto para ser reportado pela API; (iv) na versão anterior o robô enviava a mensagem para uma conta pessoal, agora amplia o público ao direcionar a mensagem para um grupo Telegram; e (v) ainda estou pensando nisto (talvez a futura v1.1), parece viável implementar um indicativo de SLA (Acordo de Nível de Serviço) por gateway. Depende da adesão à ideia.
Agora sim ... eis o novo código gw-management-v1.json a ser importado para o Node-RED, para aqueles interessados em implementar na sua respectiva região.
- Sistemática de funcionamento: um robô por intermédio de API verifica constantemente o status (online ou offline) de alguns dos gateways elencados para serem monitorados, havendo alteração dispara uma mensagem utilizando o aplicativo Telegram; e
- ID dos gateways monitorados: gw-gpstesouro, samuelcamara, samuel, gwtrinopolo03, gwtrinopolo02, gwtrinopolo01, gtw-vortyce-2, gtw-vortyce-main, 5813d30c0370, farroupilha, gw-veranopolis e iffar-gw1.
😊 GOSTOU DA IDEIA? Pois então, caso queira observar uma solução já implementada e em produção, junte-se ao grupo TTN_Gateways_CXS no Telegram e seja notificado a cada mudança de estado dos gateways LoRaWAN que integram a rede TTN em Caxias do Sul - RS. Por favor, "a principio" interprete a quietude do robô como favorável, pois poucas mensagens emitidas quer dizer que a rede está estabilizada (sem alternância entre offline <-> online). Além disso ... na modelagem das API há um filtro temporal de transiente (evitar reportar flutuações); sendo mais claro, quero dizer que há uma latência de 11 minutos, caso o GW tenha se tornado "offline". Já a informação de "online" é reportada mais de imediato (1 min). 😊
- Modo básico e que todos conhecem: TTN Community;
- Mapa de Gateways oficial da TTN, já via Packet Brocker Mapper. Vale a pena observar no mapa a aglomeração de gateways na Europa; e
- Agora, caso deseje uma solução personalizada e beirando um designer profissional - com o requinte de um dashboard - não deixe de visitar o seguinte link. Olha que belezura! E já testei ... FUNCIONA BEM!
- Que tal fuçar no mundo Docker-Conteiner em três curtos parágrafos? É sério! Você não se arrependerá! 💪 Primeiro acesse o link: Play with Docker (PWD). Você precisa se cadastrar: fazer um LOGIN (e-mail e criar uma senha). Depois START.
- Clique em + ADD NEW INSTANCE. Agora a parte mais difícil, não tenha receio! 😱 Na linha de comando digite:
docker container run -d -p 1880:1880 gpstesouro/ttn_gateways_rs
<enter>. Espere até a tela preta parar de "pipocar", seu container está sendo recheado de "gostosuras". - Quase lá! Clique em 1880 (ou acione OPEN PORT e digite 1880 <OK>). Uma nova janela se apresentará. Simplesmente, feche algumas janelas popup de aviso e voilá! 🙏 Finja que não vê o Node-RED e só chame o dashboard (coloque ui após a primeira barra solitária da URL:
http://ip...play-with-docker.com/ui
<enter>) e divirta-se... GET
Eu não disse ... facinho! 😏 Você acabou de utilizar o recurso Docker através do site PWD, criou um container - rodando um aplicativo Node-RED - que se autodestruirá após 4 horas. PARABÉNS!