main.c
4.77 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
/*
* Test on serial device
*/
////
// Include files
////
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <termios.h>
#include <string.h>
#include <libwebsockets.h>
#include "serial.h"
#define MAX_FRAME_SIZE 1024
#define WAIT_DELAY 50
#define SERIAL_DEVICE "/dev/ttyUSB0" //utiliser USB0 pour le shield Xbee branché en USB
/*****************************************************************************/
/**********************PARTIE WEBSOCKETS + COM SERIE**************************/
/*****************************************************************************/
//Fonction qui retourne un tableau de char, chaque char correspondant à une donnée d'un capteur
char * getDataFromSensors(char *request,int sizeOfRequest,int sd)
{
int i;
//la réponse est récupérée sous un type charactère non signé. Il est possible de la stocker dans un charactère signé, mais la valeur affichée par un printf sera différente
unsigned char *reponse = NULL;
reponse = malloc(4*sizeof(unsigned char));
//On envoie le GET au FPGA pour récupérer les données
for(i = 0; i < sizeOfRequest;i++)
{
if(write(sd,(void*)&request[i],sizeof(char))!=1)
{
perror("main.write"); exit(-1);
}
}
printf("\nReponse : ");
//NE PAS OUBLIER DE LIBERER LA MEMOIRE EN DEHORS DE LA FONCTION
for(i=0;i < 4;i++)
{ //on lit ce que nous envoie l'arduino à la suite de la requete GET
if(read(sd,(void*)&reponse[i],sizeof(unsigned char))!=1)
{
perror("main.read"); exit(-1);
}
}
printf("\nTemperature (C) : %d",reponse[1]);
printf("\nPression (hPa) : %d",reponse[0]+845);
printf("\nHumidite (pourcents) : %d",reponse[2]);
printf("\nLuminosité : %d\n",reponse[3]);
return reponse;
}
static int callback_http(struct libwebsocket_context *this, struct libwebsocket *wsi, enum libwebsocket_callback_reasons reason, void *user,void *in,size_t len)
{
return 0;
}
static int callback_my(struct libwebsocket_context * this, struct libwebsocket *wsi, enum libwebsocket_callback_reasons reason, void *user,void *in,size_t len)
{
static char *requete = NULL;
static char *reponse = NULL;
//Initialisation com Serie
int sd=serialOpen(SERIAL_DEVICE,SERIAL_BOTH);
serialConfig(sd,B9600);
switch(reason)
{
case LWS_CALLBACK_ESTABLISHED:
printf("connection established\n");
requete=NULL;
// Declenchement d'un prochain envoi au navigateur
libwebsocket_callback_on_writable(this,wsi);
break;
case LWS_CALLBACK_RECEIVE:
// Ici sont traites les messages envoyes par le navigateur
printf("received data: %s\n",(char *)in);
requete=malloc(len+LWS_SEND_BUFFER_PRE_PADDING+LWS_SEND_BUFFER_POST_PADDING);
if(requete==NULL)
{
perror("callback_my.malloc"); exit(EXIT_FAILURE);
}
memcpy(requete,in,len);
// Declenchement d'un prochain envoi au navigateur
libwebsocket_callback_on_writable(this,wsi);
break;
case LWS_CALLBACK_SERVER_WRITEABLE:
// Ici sont envoyes les messages au navigateur
//Si la requete a pour valeur GET, on envoie les donnée au site
if(requete!= NULL)
{
if(requete[0] == 'G' && requete[1] == 'E' && requete[2] == 'T')
{
reponse = getDataFromSensors(requete,3,sd);
int length = 4;
unsigned char *buf = malloc(LWS_SEND_BUFFER_PRE_PADDING + length + LWS_SEND_BUFFER_POST_PADDING);
memcpy (buf + LWS_SEND_BUFFER_PRE_PADDING, reponse, length );
libwebsocket_write(wsi, buf + LWS_SEND_BUFFER_PRE_PADDING, length, LWS_WRITE_BINARY); //LWS_WRITE_TEXT
free(reponse);
free(requete);
requete = NULL;
reponse = NULL;
}
}
break;
default:
break;
}
serialClose(sd);
return 0;
}
static struct libwebsocket_protocols protocols[] = {
{
"http-only", // name
callback_http, // callback
0, // data size
0 // maximum frame size
},
{"myprotocol",callback_my,0,MAX_FRAME_SIZE},
{NULL,NULL,0,0}
};
/*****************************************************************/
/**********************MAIN***************************************/
/*****************************************************************/
int main(void){
char j;
int i;
unsigned long count = 0;
//Initialisation WebSockets
int port=9000;
struct lws_context_creation_info info;
memset(&info,0,sizeof info);
info.port=port;
info.protocols=protocols;
info.gid=-1;
info.uid=-1;
struct libwebsocket_context *context=libwebsocket_create_context(&info);
if(context==NULL)
{
fprintf(stderr, "libwebsocket init failed\n");
return -1;
}
printf("starting server...\n");
//boucle infinie du main
while(1)
{
libwebsocket_service(context,WAIT_DELAY);
}
libwebsocket_context_destroy(context);
return 0;
}
//********************************************************************************//