source: titan/titan/httpd.h @ 25830

Last change on this file since 25830 was 25830, checked in by obi, 9 years ago

update screenshoot

File size: 18.6 KB
Line 
1#ifndef HTTPD_H
2#define HTTPD_H
3
4char* getmimetype(char* name, char* mime)
5{
6        char* dot;
7
8        if(mime != NULL) return mime;
9        if(name == NULL) return "text/html";
10
11        dot = strrchr( name, '.' );
12        if(dot == NULL || strcmp(dot, ".html") == 0 || strcmp(dot, ".htm") == 0)
13                return "text/html";
14        if(strcmp(dot, ".jpg") == 0 || strcmp( dot, ".jpeg" ) == 0)
15                return "image/jpeg";
16        if(strcmp(dot, ".gif") == 0)
17                return "image/gif";
18        if(strcmp(dot, ".png") == 0)
19                return "image/png";
20        if(strcmp(dot, ".css") == 0)
21                return "text/css";
22        if(strcmp(dot, ".au") == 0)
23                return "audio/basic";
24        if(strcmp(dot, ".wav") == 0)
25                return "audio/wav";
26        if(strcmp(dot, ".avi") == 0)
27                return "video/x-msvideo";
28        if(strcmp(dot, ".mov") == 0 || strcmp(dot, ".qt" ) == 0)
29                return "video/quicktime";
30        if(strcmp(dot, ".mpeg") == 0 || strcmp(dot, ".mpe" ) == 0)
31                return "video/mpeg";
32        if(strcmp(dot, ".ts") == 0)
33                return "video/MP2T";   
34        if(strcmp(dot, ".vrml") == 0 || strcmp(dot, ".wrl" ) == 0)
35                return "model/vrml";
36        if(strcmp(dot, ".midi") == 0 || strcmp(dot, ".mid" ) == 0)
37                return "audio/midi";
38        if(strcmp(dot, ".mp3") == 0)
39                return "audio/mpeg";
40        if(strcmp(dot, ".ogg") == 0)
41                return "application/ogg";
42        if(strcmp(dot, ".pac") == 0)
43                return "application/x-ns-proxy-autoconfig";
44
45        return "text/html";
46}
47
48char* createheader(off64_t len, char* filename, char* mime, char* ext, int code, int auth)
49{
50        char* header = NULL, *buf = NULL;
51        time_t now = time(NULL);
52
53        buf = malloc(100);
54        if(buf == NULL)
55        {
56                err("no mem");
57                return NULL;
58        }
59
60        if(auth == 1) code=401;
61        switch(code)
62        {
63                case 200:
64                        header = ostrcat(header, "HTTP/1.1 200 OK\r\n", 1, 0);
65                        break;
66                case 302:
67                        header = ostrcat(header, "HTTP/1.1 302 Found\r\n", 1, 0);
68                        break;
69                case 401:
70                        header = ostrcat(header, "HTTP/1.1 401 Unauthorized\r\n", 1, 0);
71                        break;
72                case 500:
73                        header = ostrcat(header, "HTTP/1.1 500 Internal Server Error\r\n", 1, 0);
74                        break;
75        }
76
77        snprintf(buf, 99, "Server: %s\r\n", PROGNAME);
78        header = ostrcat(header, buf, 1, 0);
79
80        if(auth == 1)
81        {
82                snprintf(buf, 99, "WWW-Authenticate: Basic realm=\"Contol Panel\"\r\n");
83                header = ostrcat(header, buf, 1, 0);
84        }
85
86        strftime(buf, 99, "Date: %a, %d %b %Y %H:%M:%S GMT\r\n", gmtime(&now));
87        header = ostrcat(header, buf, 1, 0);
88
89        header = ostrcat(header, "Content-Type: ", 1, 0);
90        header = ostrcat(header, getmimetype(filename, mime), 1, 0);
91        header = ostrcat(header, "\r\n", 1, 0);
92
93        if(auth == 1) len = 0;
94        snprintf(buf, 99, "Content-Length: %lld\r\n", len);
95        header = ostrcat(header, buf, 1, 0);
96
97        strftime(buf, 99, "Expires: %a, %d %b %Y %H:%M:%S GMT\r\n", gmtime(&now));
98        header = ostrcat(header, buf, 1, 0);
99
100        if(filename != NULL)
101        {
102                now = getfiletime(filename, 1);
103                strftime(buf, 99, "Last-Modified: %a, %d %b %Y %H:%M:%S GMT\r\n", gmtime(&now));
104                header = ostrcat(header, buf, 1, 0);
105        }
106
107        if(ext != NULL)
108        {
109                header = ostrcat(header, ext, 1, 0);
110                header = ostrcat(header, "\r\n", 1, 0);
111        }
112
113        header = ostrcat(header, "Connection: close\r\n", 1, 0);
114        header = ostrcat(header, "\r\n", 1, 0);
115
116        free(buf);
117        return header;
118}
119
120void senderror(int* connfd, char* title, char* text, int auth, int fmt)
121{
122        char* buf = NULL, *header = NULL;;
123
124        if(fmt == 0)
125        {
126                buf = ostrcat(buf, "<html><head><meta http-equiv=\"Content-Type\" content=\"text/html; charset=UTF-8\"><link rel=stylesheet type=text/css href=titan.css><title>Error ", 1, 0);
127                buf = ostrcat(buf, title, 1, 0);
128                buf = ostrcat(buf, "</title></head><body class=body><font class=error>Error - ", 1, 0);
129                buf = ostrcat(buf, text, 1, 0);
130                buf = ostrcat(buf, "</font></body></html>", 1, 0);
131        }
132        else
133        {
134                buf = ostrcat(buf, "Error: ", 1, 0);
135                buf = ostrcat(buf, text, 1, 0);
136        }
137
138        header = createheader(strlen(buf), NULL, NULL, NULL, 500, auth);
139
140        socksend(connfd, (unsigned char*)header, strlen(header), 5000 * 1000);
141        socksend(connfd, (unsigned char*)buf, strlen(buf), 5000 * 1000);
142
143        free(header);
144        free(buf);
145}
146
147void checkquery(int* connfd, char* query, int auth, int fmt)
148{
149        char* buf = NULL, *header = NULL, *param = NULL;
150        char* ext = NULL, *mime = NULL;
151        int buflen = 0, onlyheader = 0, code = 200;
152
153        //create param
154        param = strchr(query, '&');
155        if(param != NULL)
156                *param++ = '\0';
157
158        if(ostrcmp(query, "getbouquetepg") == 0)
159        {
160                m_lock(&status.waitrcmutex, 24);
161                buf = webgetbouquetepg(param, fmt);
162                m_unlock(&status.waitrcmutex, 24);
163        }
164        else if(ostrcmp(query, "getchannellock") == 0)
165        {
166                m_lock(&status.waitrcmutex, 24);
167                buf = webgetchannellock(param, fmt);
168                m_unlock(&status.waitrcmutex, 24);
169        }
170        else if(ostrcmp(query, "getsysteminfo") == 0)
171                buf = webgetsysteminfo(fmt);
172        else if(ostrcmp(query, "getrccodes") == 0)
173                buf = webgetrccodes(fmt);
174        else if(ostrcmp(query, "getmute") == 0)
175                buf = webgetmute(fmt);
176        else if(ostrcmp(query, "getvol") == 0)
177                buf = webgetvol(fmt);
178        else if(ostrcmp(query, "sendrc") == 0)
179                buf = websendrc(param, fmt);
180        else if(ostrcmp(query, "getrectimer") == 0)
181        {
182                m_lock(&status.waitrcmutex, 24);
183                buf = webgetrectimer(param, 0, fmt);
184                m_unlock(&status.waitrcmutex, 24);
185        }
186        else if(ostrcmp(query, "addrectimer") == 0)
187        {
188                m_lock(&status.waitrcmutex, 24);
189                buf = webaddrectimer(param, fmt);
190                m_unlock(&status.waitrcmutex, 24);
191        }
192        else if(ostrcmp(query, "delrectimer") == 0)
193        {
194                m_lock(&status.waitrcmutex, 24);
195                buf = webdelrectimer(param, fmt);
196                m_unlock(&status.waitrcmutex, 24);
197        }
198        else if(ostrcmp(query, "editrectimer") == 0)
199        {
200                m_lock(&status.waitrcmutex, 24);
201                buf = webeditrectimer(param, fmt);
202                m_unlock(&status.waitrcmutex, 24);
203        }
204        else if(ostrcmp(query, "rectimercheck") == 0)
205        {
206                m_lock(&status.waitrcmutex, 24);
207                buf = webrectimercheck(param, fmt);
208                m_unlock(&status.waitrcmutex, 24);
209        }
210        else if(ostrcmp(query, "rectimersend") == 0)
211        {
212                m_lock(&status.waitrcmutex, 24);
213                buf = webrectimersend(param, fmt);
214                m_unlock(&status.waitrcmutex, 24);
215        }
216        else if(ostrcmp(query, "getrectimerarchive") == 0)
217        {
218                m_lock(&status.waitrcmutex, 24);
219                buf = webgetrectimer(param, 1, fmt);
220                m_unlock(&status.waitrcmutex, 24);
221        }
222        else if(ostrcmp(query, "setvol") == 0)
223                buf = websetvol(param, fmt);
224        else if(ostrcmp(query, "setmute") == 0)
225                buf = websetmute(param, fmt);
226        else if(ostrcmp(query, "getbouquet") == 0)
227        {
228                m_lock(&status.waitrcmutex, 24);
229                buf = webgetbouquet(fmt);
230                m_unlock(&status.waitrcmutex, 24);
231        }
232        else if(ostrcmp(query, "getsat") == 0)
233        {
234                m_lock(&status.waitrcmutex, 24);
235                buf = webgetsat(fmt);
236                m_unlock(&status.waitrcmutex, 24);
237        }
238        else if(ostrcmp(query, "getprovider") == 0)
239        {
240                m_lock(&status.waitrcmutex, 24);
241                buf = webgetprovider(fmt);
242                m_unlock(&status.waitrcmutex, 24);
243        }
244        else if(ostrcmp(query, "getaz") == 0)
245                buf = webgetaz(fmt);
246        else if(ostrcmp(query, "getconfig") == 0)
247                buf = webgetconfig(fmt);
248        else if(ostrcmp(query, "getchannelpage") == 0)
249        {
250                m_lock(&status.waitrcmutex, 24);
251                buf = webgetchannelpage(param, fmt);
252                m_unlock(&status.waitrcmutex, 24);
253        }
254        else if(ostrcmp(query, "getallchannel") == 0)
255        {
256                m_lock(&status.waitrcmutex, 24);
257                buf = webgetchannel(0, 0, 1, fmt);
258                m_unlock(&status.waitrcmutex, 24);
259        }
260        else if(ostrcmp(query, "getbouquetchannel") == 0)
261        {
262                m_lock(&status.waitrcmutex, 24);
263                buf = webgetbouquetchannel(param, fmt);
264                m_unlock(&status.waitrcmutex, 24);
265        }
266        else if(ostrcmp(query, "getsatchannel") == 0 && param != NULL)
267        {
268                m_lock(&status.waitrcmutex, 24);
269                buf = webgetchannel(atoi(param), 1, 1, fmt);
270                m_unlock(&status.waitrcmutex, 24);
271        }
272        else if(ostrcmp(query, "getproviderchannel") == 0 && param != NULL)
273        {
274                m_lock(&status.waitrcmutex, 24);
275                buf = webgetchannel(atoi(param), 2, 1, fmt);
276                m_unlock(&status.waitrcmutex, 24);
277        }
278        else if(ostrcmp(query, "getazchannel") == 0 && param != NULL)
279        {
280                m_lock(&status.waitrcmutex, 24);
281                buf = webgetchannel(atoi(param), 3, 1, fmt);
282                m_unlock(&status.waitrcmutex, 24);
283        }
284        else if(ostrcmp(query, "switch") == 0)
285                buf = webswitch(param, fmt);
286        else if(ostrcmp(query, "getaktservice") == 0)
287        {
288                m_lock(&status.waitrcmutex, 24);
289                buf = webgetaktservice(fmt);
290                m_unlock(&status.waitrcmutex, 24);
291        }
292        else if(ostrcmp(query, "getservice") == 0)
293        {
294                m_lock(&status.waitrcmutex, 24);
295                buf = webgetservice(param, fmt);
296                m_unlock(&status.waitrcmutex, 24);
297        }
298        else if(ostrcmp(query, "getepg") == 0)
299        {
300                m_lock(&status.waitrcmutex, 24);
301                buf = webgetepg(param, fmt);
302                m_unlock(&status.waitrcmutex, 24);
303        }
304        else if(ostrcmp(query, "getmovieepg") == 0)
305        {
306                m_lock(&status.waitrcmutex, 24);
307                buf = webgetmovieepg(param, getconfig("rec_streampath", NULL), 1, fmt);
308                m_unlock(&status.waitrcmutex, 24);
309        }
310        else if(ostrcmp(query, "getsingleepg") == 0)
311        {
312                m_lock(&status.waitrcmutex, 24);
313                buf = webgetsingleepg(param, fmt);
314                m_unlock(&status.waitrcmutex, 24);
315        }
316        else if(ostrcmp(query, "getgmultiepg") == 0)
317        {
318                m_lock(&status.waitrcmutex, 24);
319                buf = webgetgmultiepg(param, fmt);
320                m_unlock(&status.waitrcmutex, 24);
321        }
322        else if(query != NULL && ostrstr(query, "getepgsearch") == query)
323        {
324                m_lock(&status.waitrcmutex, 24);
325                buf = webgetepgsearch(query, param, fmt);
326                m_unlock(&status.waitrcmutex, 24);
327        }
328        else if(ostrcmp(query, "getsignal") == 0)
329                buf = webgetsignal(fmt);
330        else if(ostrcmp(query, "getmoviefilelist") == 0)
331        {
332                if(fmt == 0)
333                        buf = webgetfilelist(param, "getmoviefilelist", "delmoviefile", getconfig("rec_streampath", NULL), "*.avi *.dat *.divx *.flv *.mkv *.m4v *.mp4 *.mov *.mpg *.mpeg *.mts *.m2ts *.trp *.ts *.vdr *.vob *.wmv *.rm", 31, fmt);
334                else
335                        buf = webgetfilelist(param, "getmoviefilelist", "delmoviefile", getconfig("rec_streampath", NULL), "*.avi *.dat *.divx *.flv *.mkv *.m4v *.mp4 *.mov *.mpg *.mpeg *.mts *.m2ts *.trp *.ts *.vdr *.vob *.wmv *.rm *.wav *.mp3", 31, fmt);
336       
337        }
338        else if(ostrcmp(query, "delmoviefile") == 0)
339        {
340                if(fmt == 0)
341                        buf = webdelfile(param, "getmoviefilelist", "delmoviefile", getconfig("rec_streampath", NULL), "*.avi *.dat *.divx *.flv *.mkv *.m4v *.mp4 *.mov *.mpg *.mpeg *.mts *.m2ts *.trp *.ts *.vdr *.vob *.wmv *.rm", 31, fmt);
342                else
343                        buf = webdelfile(param, "getmoviefilelist", "delmoviefile", getconfig("rec_streampath", NULL), "*.avi *.dat *.divx *.flv *.mkv *.m4v *.mp4 *.mov *.mpg *.mpeg *.mts *.m2ts *.trp *.ts *.vdr *.vob *.wmv *.rm *.wav *.mp3", 31, fmt);
344        }
345        else if(ostrcmp(query, "getm3u") == 0)
346        {
347                buf = webgetm3u(param, *connfd, fmt);
348                if(fmt == 0)
349                {
350                        ext = "Content-Disposition: attachment; filename=stream.m3u";
351                        mime = "audio/x-mpegurl";
352                }
353        }
354        else if(ostrcmp(query, "getvideo") == 0)
355                buf = webgetvideo(param, *connfd, fmt);
356        else if(ostrcmp(query, "videoplay") == 0 || ostrcmp(query, "videoplay=") == 0)
357                buf = webvideo(param, fmt);
358        else if(ostrcmp(query, "getdrawcount") == 0)
359                buf = webgetdrawcount(param, fmt);
360        else if(ostrcmp(query, "getshoot") == 0)
361        {
362                webgetshoot(param, fmt);
363                if(fmt == 0)
364                {
365                        ext = "Location: shoot.html";
366                        onlyheader = 1;
367                        code = 302;
368                }
369                else
370                        buf = ostrcat("shoot.html", NULL, 0, 0);
371        }
372        else if(query != NULL && ostrstr(query, "poweroff") == query)
373                oshutdown(1, 1);
374        else if(query != NULL && ostrstr(query, "restart") == query)
375                oshutdown(2, 1);
376        else if(query != NULL && ostrstr(query, "guirestart") == query)
377                oshutdown(3, 1);
378        else if(query != NULL && ostrstr(query, "standby") == query)
379        {
380                status.standby = 2;
381                addtimer(&screenstandby, START, 1000, 1, NULL, NULL, NULL);
382        }
383        else if(query != NULL && ostrstr(query, "boxstatus") == query)
384        {
385                if(status.standby > 0)
386                {
387                        if(fmt == 0)
388                                sendoktext(connfd, "standby", auth);
389                        else
390                                buf = ostrcat("standby", NULL, 0, 0);
391                }
392                else
393                {
394                        if(fmt == 0)
395                                sendoktext(connfd, "running", auth);
396                        else
397                                buf = ostrcat("running", NULL, 0, 0);
398                }
399        }
400        else if(query != NULL && ostrstr(query, "mutestatus") == query)
401        {
402                if(status.mute > 0)
403                {
404                        if(fmt == 0)
405                                sendoktext(connfd, "muteon", auth);
406                        else
407                                buf = ostrcat("muteon", NULL, 0, 0);
408                }
409                else
410                {
411                        if(fmt == 0)
412                                sendoktext(connfd, "muteoff", auth);
413                        else
414                                buf = ostrcat("muteoff", NULL, 0, 0);
415                }
416        }
417        else if(query != NULL && ostrstr(query, "message") == query)
418                buf = websendmessage(query, fmt);
419               
420        if(buf != NULL || onlyheader == 1)
421        {
422                if(buflen == 0 && onlyheader == 0) buflen = strlen(buf);
423
424                header = createheader(buflen, NULL, mime, ext, code, auth);
425                socksend(connfd, (unsigned char*)header, strlen(header), 5000 * 1000);
426                if(onlyheader == 0 && auth == 0)
427                        socksend(connfd, (unsigned char*)buf, buflen, 5000 * 1000);
428        }
429        else
430                senderror(connfd, "query", "Error in query string", auth, fmt);
431
432        free(header);
433        free(buf);
434}
435
436void gotdata(int* connfd)
437{
438        int ret = 0, filefd = -1, auth = 0;
439        unsigned char* buf = NULL;
440        char* tmpstr = NULL, *tmpstr1 = NULL, *filename = NULL, *fullfilename = NULL, *header = NULL, *query = NULL;
441
442        buf = malloc(MINMALLOC);
443        if(buf == NULL)
444        {
445                err("no mem");
446                sockclose(connfd);
447                return;
448        }
449        memset(buf, 0, MINMALLOC);
450
451        debug(250, "get client data");
452
453        //read one line
454        unsigned char* pbuf = buf;
455        while(pbuf - buf < MINMALLOC)
456        {
457                unsigned char c;
458
459                ret = sockreceive(connfd, &c, 1, 5000 * 1000);
460                if(ret != 0)
461                {
462                        debug(250, "no client data in buffer");
463                        break;
464                }
465
466                *pbuf = c;
467                if(buf != NULL && (ostrstr((char*)buf, "\n\n") != NULL || ostrstr((char*)buf, "\r\n\r\n") != NULL))
468                        break;
469                pbuf++;
470        }
471
472        if(buf != NULL)
473        {
474                tmpstr = ostrstr((char*)buf, "GET /");
475                tmpstr1 = ostrstr((char*)buf, "Authorization: Basic ");
476        }
477
478        //Auth Password
479        if(status.httpauth != NULL)
480        {
481                if(tmpstr1 != NULL)
482                {
483                        tmpstr1 += 21;
484                        char* tmpstr3 = malloc(255);
485                        if(tmpstr3 != NULL)
486                        {
487                                int l = b64dec(tmpstr3, tmpstr1);
488                                if(l < 255) tmpstr3[l] = '\0';
489                        }
490                        if(ostrncmp(tmpstr3, status.httpauth, strlen(status.httpauth)) != 0)
491                        {
492                                //not ok:
493                                tmpstr1 = NULL;
494                        }
495                        free(tmpstr3); tmpstr3 = NULL;
496                }
497       
498                if(tmpstr1 == NULL) auth = 1;
499        }
500
501        if(tmpstr != NULL)
502        {
503                tmpstr += 4;
504
505                filename = malloc(MINMALLOC);
506                if(filename == NULL)
507                {
508                        err("no mem");
509                        sockclose(connfd);
510                        free(buf); buf = NULL;
511                        tmpstr = NULL;
512                        return;
513                }
514                memset(filename, 0, MINMALLOC);
515
516                ret = sscanf(tmpstr, "%s", filename);
517                if(ret == 1)
518                {
519                        if(ostrstr(filename, "query?rectimersend") != NULL)
520                                stringreplacechar(filename, '+', ' ');
521                        if(ostrstr(filename, "query?rectimercheck") != NULL)
522                                stringreplacechar(filename, '+', ' ');
523                        htmldecode(filename, filename);
524                       
525                        if(ostrstr(filename, "xmessage") == filename + 1  || ostrstr(filename, "/cgi-bin/xmessage") == filename )
526                        {       
527                                xmessage(filename);
528                                sendoktext(connfd, "ok", 0);
529                                //senderror(connfd, "ok", "ok", 0, 0);
530                                free(buf); buf = NULL;
531                                free(filename); filename = NULL;
532                                tmpstr = NULL;
533                                return;
534                        }
535
536                        //create query
537                        query = strchr(filename, '?');
538                        if(query != NULL)
539                        {
540                                *query++ = '\0';
541                                debug(250, "httpd query=%s", query);
542                        }
543
544                        //queryraw
545                        if(ostrcmp(filename, "/queryraw") == 0 && query != NULL)
546                        {
547                                checkquery(connfd, query, auth, 1);
548                                free(buf); buf = NULL;
549                                free(filename); filename = NULL;
550                                tmpstr = NULL;
551                                return;
552                        }
553
554                        //query
555                        if(ostrcmp(filename, "/query") == 0 && query != NULL)
556                        {
557                                checkquery(connfd, query, auth, 0);
558                                free(buf); buf = NULL;
559                                free(filename); filename = NULL;
560                                tmpstr = NULL;
561                                return;
562                        }
563
564                        //create index.html
565                        if(filename[strlen(filename) - 1] == '/')
566                                filename = ostrcat(filename, "index.html", 1, 0);
567
568                        debug(250, "httpd filename=%s", filename);
569
570                        if(ostrstr(filename, "/movie/") != NULL)
571                                fullfilename = ostrcat(filename, NULL, 0, 0);
572                        else
573                                fullfilename = ostrcat(getconfig("httpdpath", NULL), filename, 0, 0);
574                        filefd = open(fullfilename, O_RDONLY | O_LARGEFILE);
575                        if(filefd < 0)
576                        {
577                                perr("open filename=%s", fullfilename);
578                                senderror(connfd, "Open File", "Can't open File", auth, 0);
579                                free(fullfilename); fullfilename = NULL;
580                                free(buf); buf = NULL;
581                                free(filename); filename = NULL;
582                                tmpstr = NULL;
583                                return;
584                        }
585                       
586                        debug(250, "sende OK response to client");
587                        char* rpath = realpath(fullfilename, NULL);
588                        header = createheader(getfilesize(rpath), fullfilename, NULL, NULL, 200, auth);
589                        free(rpath); rpath = NULL;
590                        free(fullfilename); fullfilename = NULL;
591                        ret = socksend(connfd, (unsigned char*)header, strlen(header), 5000 * 1000);
592                        free(header); header = NULL;
593
594                        if(ret != 0)
595                        {
596                                sockclose(connfd);
597                                free(buf); buf = NULL;
598                                free(filename); filename = NULL;
599                                tmpstr = NULL;
600                                return;
601                        }
602
603                        //TODO:
604                        int readret = 1;
605                        while(readret > 0 && auth == 0)
606                        {
607                                readret = dvbreadfd(filefd, buf, 0, MINMALLOC, 1000, 0);
608                                if(readret > 0)
609                                        socksend(connfd, buf, readret, 5000 * 1000);
610                        }
611                }
612        }
613
614        close(filefd);
615        free(buf); buf = NULL;
616        free(filename); filename = NULL;
617        tmpstr = NULL;
618}
619
620int newconn(int* streamfd, int* connfd)
621{
622        int i, fd = -1;
623
624        fd = sockaccept(streamfd, 1);
625        if(fd < 0) return -1;
626
627        for(i = 0; i < MAXHTTPDCONN; i++)
628        {
629                if(connfd[i] < 0)
630                {
631                        connfd[i] = fd;
632                        debug(250, "accept httpd connection fd=%d", fd);
633                        fd = -1;
634                        break;
635                }
636        }
637
638        if(fd != -1)
639        {
640                debug(250, "all connections in use");
641                sockclose(&fd);
642                return -1;
643        }
644
645        return 0;
646}
647
648void httpdthreadfunc(struct stimerthread* timernode)
649{
650        struct timeval timeout;
651        fd_set rfds;
652        int i, ret = 0, streamfd = -1, connfd[MAXHTTPDCONN], maxfd = -1;
653
654        if(timernode == NULL) return;
655        debug(250, "Starting httpd thread");
656
657        for(i = 0; i < MAXHTTPDCONN; i++)
658                connfd[i] = -1;
659
660        while(timernode->aktion != STOP)
661        {
662                if(streamfd < 0)
663                {
664                        sockportcreate(&streamfd, getconfigint("httpdport", NULL), MAXHTTPDCONN);
665                        if(streamfd < 0) break;
666                        maxfd = streamfd;
667
668                        //set nonblocking
669                        fcntl(streamfd, F_SETFL, fcntl(streamfd, F_GETFL) | O_NONBLOCK);
670                }
671
672                timeout.tv_sec = 1;
673                timeout.tv_usec = 0;
674
675                FD_ZERO(&rfds);
676                FD_SET(streamfd, &rfds);
677
678                for(i = 0; i < MAXHTTPDCONN; i++)
679                {
680                        if(connfd[i] > -1)
681                        {
682                                FD_SET(connfd[i], &rfds);
683                                if(connfd[i] > maxfd) maxfd = connfd[i];
684                        }
685                }
686
687                ret = TEMP_FAILURE_RETRY(select(maxfd + 1, &rfds , NULL, NULL, &timeout));
688
689                if(ret < 0)
690                {
691                        perr("httpd listen socket fd=%d", maxfd);
692                        sleep(1);
693                        continue;
694                }
695                if(ret == 0) continue; //timeout
696
697                if(FD_ISSET(streamfd, &rfds))
698                {
699                        ret = newconn(&streamfd, connfd);
700                        if(ret < 0) continue;
701                }
702
703                for(i = 0; i < MAXHTTPDCONN; i++)
704                {
705                        if(connfd[i] > -1 && FD_ISSET(connfd[i], &rfds))
706                                gotdata(&connfd[i]);
707                }
708        }
709
710        debug(250, "Stopping httpd thread");
711        sockclose(&streamfd);
712        for(i = 0; i < MAXHTTPDCONN; i++)
713                sockclose(&connfd[i]);
714
715        return;
716}
717
718void sendoktext(int* connfd, char* text, int auth)
719{
720        char* buf = NULL;
721        char* header = NULL;
722        buf = webcreatehead(buf, NULL, 1);
723        buf = ostrcat(buf, "<tr><td align=center valign=top><font class=biglabel><br><br>", 1, 0);
724        buf = ostrcat(buf, text, 1, 0);
725        buf = ostrcat(buf, "</font></td></tr>", 1, 0);
726        buf = webcreatetail(buf, 1);
727        int buflen = strlen(buf);
728        header = createheader(buflen, NULL, NULL, NULL, 200, auth);
729        socksend(connfd, (unsigned char*)header, strlen(header), 5000 * 1000);
730        if(auth == 0)
731                socksend(connfd, (unsigned char*)buf, buflen, 5000 * 1000);
732        free(buf); buf=NULL;
733        free(header); header=NULL;
734}
735
736#endif
Note: See TracBrowser for help on using the repository browser.