MPI/API/EvtMifireNFC
De uTech Tecnologia
(Diferença entre revisões)
(→Buitl-in Respose) |
(→Buitl-in Respose) |
||
(3 edições intermediárias de um usuário não apresentadas) | |||
Linha 58: | Linha 58: | ||
! align="center" colspan="2" | Parâmetros enviados para o Porteiro | ! align="center" colspan="2" | Parâmetros enviados para o Porteiro | ||
|- | |- | ||
− | | align="left"| request || Comando a ser enviado. | + | | align="left"| request || Comando a ser enviado. Comandos aceitos: '''relay''' ou '''play'''. |
|- | |- | ||
| align="left"| interface || '''Para relay''': Define qual relê será habilitado ou desligado | | align="left"| interface || '''Para relay''': Define qual relê será habilitado ou desligado | ||
Linha 150: | Linha 150: | ||
<source lang="php"> | <source lang="php"> | ||
<?php | <?php | ||
− | |||
− | |||
− | |||
$vars = $_REQUEST; | $vars = $_REQUEST; | ||
Linha 162: | Linha 159: | ||
$event = $vars['request']; | $event = $vars['request']; | ||
else { | else { | ||
− | |||
exit(1); | exit(1); | ||
} | } | ||
− | printf("Evento: %s<BR>\n", $vars['request']); | + | # Dados recebido no evevento do porteiro |
− | printf("=> Card: %s<BR>\n", $vars['card']); | + | #printf("Evento: %s<BR>\n", $vars['request']); |
− | printf("=> State: %s<BR>\n", $vars['state']); | + | #printf("=> Card: %s<BR>\n", $vars['card']); |
− | printf("=> Time: %s<BR>\n", $vars['time']); | + | #printf("=> State: %s<BR>\n", $vars['state']); |
− | printf("=> Key: %s<BR>\n", $vars['key']); | + | #printf("=> Time: %s<BR>\n", $vars['time']); |
+ | #printf("=> Key: %s<BR>\n", $vars['key']); | ||
− | |||
− | |||
− | + | ## Verifricvar se o cartão tem acesso e responder com o comando de liberacao. | |
− | + | ## | |
− | + | ||
− | + | ||
− | + | $data = array ( | |
− | + | 0 => array ('request' => 'relay', | |
− | + | 'interface' => '1', | |
+ | 'state' => 'on'), | ||
− | + | 1 => array ('request' => 'play', | |
− | + | 'message' => 'access_allowed'), | |
+ | ); | ||
− | + | header('Content-type: application/json'); | |
+ | echo json_encode( $data ); | ||
?> | ?> | ||
+ | |||
</source> | </source> | ||
|} | |} | ||
− | |||
− | |||
− | |||
− | |||
<br/> | <br/> | ||
[[MPI/API#Eventos|'''Voltar''']] | [[MPI/API#Eventos|'''Voltar''']] | ||
----- | ----- |
Edição atual tal como 22h08min de 29 de julho de 2019
Tabela de conteúdo |
O Evento Mifire/NFC é enviado do porteiro para a aplicação, informando evento de cartão mifire / NFC.
[editar] Evento
Parâmetros enviados pelo Porteiro | |
---|---|
request | card |
card | Identificação do cartão Mifire/NFC |
state | Status do cartão/Evento
|
key | Chave primária do usuário. |
interface | Identificação da interface acessada/acionada.
|
time | Data/Hora do evento no formato ddmmYYYYHHMMSS onde:
|
[editar] Exemplo
http://ip:porta/url/?request=card&card=EAD2353236FAC&interface=1&state=blocked&key=2ed1698bcf&time=10122018183000 |
---|
Resposta: A aplicação deve responder:
- 401 => Erro de Autenticação.
- 200 => OK.
[editar] Buitl-in Respose
No próprio evento, é possível executar outros comandos, inserindo no corpo da resposta (no caso 200 OK) enviado pela aplicação, um array com os dados do comando a ser executado. Os parâmetros aceiros são descritos abaixo:
Parâmetros enviados para o Porteiro | |
---|---|
request | Comando a ser enviado. Comandos aceitos: relay ou play. |
interface | Para relay: Define qual relê será habilitado ou desligado
|
state | Para relay: Define o estado do relê:
|
message | Para play: Define a mensagem a reproduzir. Ver mensagens na documentação do comando PlayMessage |
Exemplo - acionando o relê para abertura da interface 1:
HTTP/1.1 200 OK Content-Type: application/json Content-Length: 167 { "request" :"relay", "interface": "1", "state" :"on" } |
---|
Exemplo - acionando o relê para abertura da interface 1 e reproduzindo a mensagem de acesso liberado:
HTTP/1.1 200 OK Content-Type: application/json Content-Length: 167 [ { "request" :"relay", "interface": "1", "state" :"on" }, { "request" :"play", "message" :"access_allowed" } ] |
---|
[editar] PHP
[editar] Evento Simples
<?php $vars = $_REQUEST; if(!isset($vars)) exit(0); if(isset($vars['request']) && strcmp($vars['request'],"card") == 0) $event = $vars['request']; else { echo "Evento invalido!\n"; exit(1); } printf("Evento: %s<BR>\n", $vars['request']); printf("=> Card: %s<BR>\n", $vars['card']); printf("=> State: %s<BR>\n", $vars['state']); printf("=> Time: %s<BR>\n", $vars['time']); printf("=> Key: %s<BR>\n", $vars['key']); ?> |
[editar] Evento com Resposta Built-in
<?php $vars = $_REQUEST; if(!isset($vars)) exit(0); if(isset($vars['request']) && strcmp($vars['request'],"card") == 0) $event = $vars['request']; else { exit(1); } # Dados recebido no evevento do porteiro #printf("Evento: %s<BR>\n", $vars['request']); #printf("=> Card: %s<BR>\n", $vars['card']); #printf("=> State: %s<BR>\n", $vars['state']); #printf("=> Time: %s<BR>\n", $vars['time']); #printf("=> Key: %s<BR>\n", $vars['key']); ## Verifricvar se o cartão tem acesso e responder com o comando de liberacao. ## $data = array ( 0 => array ('request' => 'relay', 'interface' => '1', 'state' => 'on'), 1 => array ('request' => 'play', 'message' => 'access_allowed'), ); header('Content-type: application/json'); echo json_encode( $data ); ?> |