mirror of
https://github.com/taigrr/tplinkController
synced 2025-01-18 04:43:13 -08:00
Support longer responses from device (needed for HS300)
This commit is contained in:
parent
94d4f10d87
commit
5d16c96ef0
16
comms.c
16
comms.c
@ -8,8 +8,6 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include "comms.h"
|
#include "comms.h"
|
||||||
|
|
||||||
#define RECV_BUF_SIZE 4096
|
|
||||||
|
|
||||||
bool hs100_encrypt(uint8_t *d, uint8_t *s, size_t len)
|
bool hs100_encrypt(uint8_t *d, uint8_t *s, size_t len)
|
||||||
{
|
{
|
||||||
if( d == NULL)
|
if( d == NULL)
|
||||||
@ -117,11 +115,15 @@ char *hs100_send(char *servaddr, char *msg)
|
|||||||
|
|
||||||
send(sock, s, s_len, 0);
|
send(sock, s, s_len, 0);
|
||||||
free(s);
|
free(s);
|
||||||
uint8_t recvbuf[RECV_BUF_SIZE];
|
uint32_t msglen;
|
||||||
size_t received_size = recv(sock, recvbuf, RECV_BUF_SIZE, 0);
|
size_t recvsize = recv (sock, &msglen, sizeof(msglen), MSG_PEEK);
|
||||||
close(sock);
|
if (recvsize != sizeof(msglen)) {
|
||||||
if (received_size == 0)
|
|
||||||
return NULL;
|
return NULL;
|
||||||
char *recvmsg = hs100_decode(recvbuf, received_size);
|
}
|
||||||
|
msglen = ntohl(msglen) + 4;
|
||||||
|
uint8_t *recvbuf = calloc(1, (size_t)msglen);
|
||||||
|
recvsize = recv(sock, recvbuf, msglen, MSG_WAITALL);
|
||||||
|
close(sock);
|
||||||
|
char *recvmsg = hs100_decode(recvbuf, msglen);
|
||||||
return recvmsg;
|
return recvmsg;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user