PyIntelbras é um módulo Python para trabalhar com a API Intelbras V3.35.
Obs: Caso o link da documentação esteja offline, a mesma também está disponível no diretório docs do repositório.
- Testado com a API
V3.35
de umiNVD 9116 PE FT
.
Instale PyIntelbras usando pip:
$ pip install pyintelbras
Agora é possível importar e usar o PyIntelbras da seguinte forma:
from pyintelbras import IntelbrasAPI
api = IntelbrasAPI("http://device-server.example.com")
api.login("api-user", "api-pass")
response = api.configManager(action='getConfig', name='ChannelTitle')
O PyIntelbras utiliza a biblioteca requests para HTTP. Todos os paths existentes na API da Intelbras podem ser utilizados como métodos e seus respectivos parâmetros também podem ser passados como parâmetros das funções.
from pyintelbras import IntelbrasAPI
api = IntelbrasAPI("http://device-server.example.com")
api.login("api-user", "api-pass")
response = api.configManager(action='getConfig', name='ChannelTitle')
O exemplo acima irá realizar uma requisição GET
para o endereço:
http://device-server.example.com/cgi-bin/configManager.cgi?action=getConfig&name=ChannelTitle
.
Note que tanto o prefixo cgi-bin
quanto o sufixo .cgi
, exigidos pela API, são automaticamente adicionados.
É possível definir o tipo de requisição, sendo permitidos apenas 2 verbos HTTP.
Por padrão e caso seja omitido, a requisição será do tipo GET
.
from pyintelbras import IntelbrasAPI
api = IntelbrasAPI("http://device-server.example.com")
api.login("api-user", "api-pass")
# Mesmo efeito para ambas as requisições
response = api.configManager(action='getConfig', name='ChannelTitle')
response = api.configManager.get(action='getConfig', name='ChannelTitle')
from pyintelbras import IntelbrasAPI
api = IntelbrasAPI("http://device-server.example.com")
api.login("api-user", "api-pass")
response = api.api.LogicDeviceManager.getCameraState.post(body={ 'uniqueChannels': [-1] })
O exemplo acima irá realizar uma requisição POST
para o endereço:
http://device-server.example.com/cgi-bin/api/LogicDeviceManager/getCameraState.cgi
.
E enviar o conteúdo da variável body
como corpo da requisição.
A API da Intelbrás é case sensitive, ou seja, faz diferenciação entre maiúsculas e minúsculas. Por conta disto, a URL de requisição é montada exatamente conforme os métodos e parâmetros são passados.
Sendo assim, a requisição abaixo deverá retornar o código de status HTTP 200
:
api.configManager(action='getConfig', name='ChannelTitle')
Enquanto isso, a requisição abaixo retornará o código de status HTTP 400
:
api.configmanager(action='getConfig', name='ChannelTitle')
Note a diferença da grafia da letra M. Isso irá ocorrer pelo fato de não existir a rota:
.../cgi-bin/configmanager.cgi/...
e sim:
.../cgi-bin/configManager.cgi/...
.
Os componente de consulta (query parameters), utilizados como parâmetros das funções, devem ser tratados adequadamente quando possuírem sintaxe inválida no python. Basicamente isso será necessário quando houver
.
ou []
nos parâmetros. O seguinte exemplo:
...
response = api.mediaFileFind(action='findFile', condition.Channel=1)
Retornará o erro:
Cell In[1], line 1
response = api.mediaFileFind(action='findFile', condition.Channel=1)
^
SyntaxError: expression cannot contain assignment, perhaps you meant "=="?
A forma correta de lidar neste caso é utilizando a descompactação de listas de argumentos.
...
params = {
'action': 'findFile',
'condition.Channel': 1
}
response = api.mediaFileFind(**params)
Se for necessário debugar algum problema com as requisições para a API da Intelbras, é possível habilitar a saída de logs. O pyintelbras
utiliza o sistema de logging do Python, mas por padrão, ele registra para Null. É possível alterar esse comportamento. Segue um exemplo:
import sys
import logging
from pyintelbras import IntelbrasAPI
stream = logging.StreamHandler(sys.stdout)
stream.setLevel(logging.DEBUG)
log = logging.getLogger('pyintelbras')
log.addHandler(stream)
log.setLevel(logging.DEBUG)
api = IntelbrasAPI("http://device-server.example.com")
api.login("api-user", "api-pass")
response = api.configManager(action='getConfig', name='ChannelTitle')
Outros exemplos de uso da API estão disponíveis no diretório examples do repositório.