Acesse seus dados do Sense.
Adicione esta linha ao GemFile do seu aplicativo:
gem 'unofficial_sense_api'E depois execute:
$ bundle
Ou instale você mesmo como:
$ gem install unofficial_sense_api
Obtendo dados em tempo real (inicia um websocket para wss://clientrt.sense.com/monitors/#{api.first_monitor_id}/realtimefeed )
require 'sense_api'
require 'pp'
api = SenseApi . new ( "USERNAME" , "PASSWORD" )
count = 0
api . realtime do | json |
pp json
# Be sure to return :exit to terminate the connection and shut down EventMachine!
count += 1
count > 5 ? :exit : nil
end Use fetch para extrair pontos de extremidade de descanso de sua escolha. Nenhum ainda foi adicionado a esta jóia.
require 'sense_api'
api = SenseApi . new ( "USERNAME" , "PASSWORD" )
timeline = api . fetch ( "https://api.sense.com/apiservice/api/v1/users/ #{ api . user_id } /timeline?n_item=30" )
trends = api . fetch ( "https://api.sense.com/apiservice/api/v1/app/history/trends?monitor_id= #{ api . first_monitor_id } &scale=WEEK&start=2017-10-23T04:00:00.000Z" )
devices = api . fetch ( "https://api.sense.com/apiservice/api/v1/app/monitors/ #{ api . first_monitor_id } /devices?include_merged=true" )
first_device_id = devices . first [ "id" ]
first_device_details = api . fetch ( "https://api.sense.com/apiservice/api/v1/app/monitors/ #{ api . first_monitor_id } /devices/ #{ first_device_id } " )
first_device_hostory = api . fetch ( "https://api.sense.com/apiservice/api/v1/app/history/usage?monitor_id= #{ api . first_monitor_id } &granularity=MINUTE&start=2017-10-21T11:00:00.000Z&frames=5400&device_id= #{ first_device_id } " )Aqui estão os terminais que conhecemos até agora:
"https://api.sense.com/apiservice/api/v1/users/#{api.user_id}/timeline?n_item=30""https://api.sense.com/apiservice/api/v1/app/history/trends?monitor_id=#{api.first_monitor_id}&scale=WEEK&start=2017-10-23T04:00:00.000Z"SECOND "https://api.sense.com/apiservice/api/v1/app/history/usage?monitor_id=#{api.first_monitor_id}&granularity=SECOND&start=2017-10-25T03:54:00.000Z&frames=5400" granularity MINUTEDispositivos de lista:
"https://api.sense.com/apiservice/api/v1/app/monitors/#{api.first_monitor_id}/devices?include_merged=true" Você pode adicionar um device_id à solicitação de histórico:
"https://api.sense.com/apiservice/api/v1/app/history/usage?monitor_id=#{api.first_monitor_id}&granularity=MINUTE&start=2017-10-21T11:00:00.000Z&frames=5400&device_id=SOME_DEVICE_ID"E obtenha os dados para dispositivos:
"https://api.sense.com/apiservice/api/v1/app/monitors/#{api.first_monitor_id}/devices/always_on""https://api.sense.com/apiservice/api/v1/app/monitors/#{api.first_monitor_id}/devices/unknown""https://api.sense.com/apiservice/api/v1/app/monitors/#{api.first_monitor_id}/devices/SOME_DEVICE_ID"Se desejar, você pode pular Ruby completamente e conversar com a API Sense com Curl:
curl -k --data "[email protected]" --data "password=URL_ENCODED_PASSWORD" -H "Sense-Client-Version: 1.17.1-20c25f9" -H "X-Sense-Protocol: 3" -H "User-Agent: okhttp/3.8.0" "https://api.sense.com/apiservice/api/v1/authenticate"
A resposta terá um access_token , bem como uma matriz user_id e monitors que você pode usar para acessar as APIs do Sense. Por exemplo:
curl -k -H "Authorization: bearer ACCESS_TOKEN" -H "Sense-Client-Version: 1.17.1-20c25f9" -H "X-Sense-Protocol: 3" -H "User-Agent: okhttp/3.8.0" "https://api.sense.com/apiservice/api/v1/app/history/usage?monitor_id=A_MONITOR_ID&granularity=SECOND&start=2017-10-24T05:36:00.000Z&frames=5400"
Você pode executar bin/console para um prompt interativo que permitirá experimentar.
Para instalar esta gema na sua máquina local, execute bundle exec rake install . Para lançar uma nova versão, atualize o número da versão no version.rb e, em seguida, execute bundle exec rake release , que criará uma tag git para a versão, push git cometa e tags e pressionará o arquivo .gem para rubygems.org.
A GEM está disponível como código aberto nos termos da licença do MIT.