source: titan/titan/httpd.h @ 27899

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

[webif] add settings adjust read screen

File size: 18.7 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, "adjust") == 0)
223        {
224                buf = webadjust(param, fmt);
225        }
226        else if(ostrcmp(query, "setvol") == 0)
227                buf = websetvol(param, fmt);
228        else if(ostrcmp(query, "setmute") == 0)
229                buf = websetmute(param, fmt);
230        else if(ostrcmp(query, "getbouquet") == 0)
231        {
232                m_lock(&status.waitrcmutex, 24);
233                buf = webgetbouquet(fmt);
234                m_unlock(&status.waitrcmutex, 24);
235        }
236        else if(ostrcmp(query, "getsat") == 0)
237        {
238                m_lock(&status.waitrcmutex, 24);
239                buf = webgetsat(fmt);
240                m_unlock(&status.waitrcmutex, 24);
241        }
242        else if(ostrcmp(query, "getprovider") == 0)
243        {
244                m_lock(&status.waitrcmutex, 24);
245                buf = webgetprovider(fmt);
246                m_unlock(&status.waitrcmutex, 24);
247        }
248        else if(ostrcmp(query, "getaz") == 0)
249                buf = webgetaz(fmt);
250        else if(ostrcmp(query, "getconfig") == 0)
251                buf = webgetconfig(fmt);
252        else if(ostrcmp(query, "getchannelpage") == 0)
253        {
254                m_lock(&status.waitrcmutex, 24);
255                buf = webgetchannelpage(param, fmt);
256                m_unlock(&status.waitrcmutex, 24);
257        }
258        else if(ostrcmp(query, "getallchannel") == 0)
259        {
260                m_lock(&status.waitrcmutex, 24);
261                buf = webgetchannel(0, 0, 1, fmt);
262                m_unlock(&status.waitrcmutex, 24);
263        }
264        else if(ostrcmp(query, "getbouquetchannel") == 0)
265        {
266                m_lock(&status.waitrcmutex, 24);
267                buf = webgetbouquetchannel(param, fmt);
268                m_unlock(&status.waitrcmutex, 24);
269        }
270        else if(ostrcmp(query, "getsatchannel") == 0 && param != NULL)
271        {
272                m_lock(&status.waitrcmutex, 24);
273                buf = webgetchannel(atoi(param), 1, 1, fmt);
274                m_unlock(&status.waitrcmutex, 24);
275        }
276        else if(ostrcmp(query, "getproviderchannel") == 0 && param != NULL)
277        {
278                m_lock(&status.waitrcmutex, 24);
279                buf = webgetchannel(atoi(param), 2, 1, fmt);
280                m_unlock(&status.waitrcmutex, 24);
281        }
282        else if(ostrcmp(query, "getazchannel") == 0 && param != NULL)
283        {
284                m_lock(&status.waitrcmutex, 24);
285                buf = webgetchannel(atoi(param), 3, 1, fmt);
286                m_unlock(&status.waitrcmutex, 24);
287        }
288        else if(ostrcmp(query, "switch") == 0)
289                buf = webswitch(param, fmt);
290        else if(ostrcmp(query, "getaktservice") == 0)
291        {
292                m_lock(&status.waitrcmutex, 24);
293                buf = webgetaktservice(fmt);
294                m_unlock(&status.waitrcmutex, 24);
295        }
296        else if(ostrcmp(query, "getservice") == 0)
297        {
298                m_lock(&status.waitrcmutex, 24);
299                buf = webgetservice(param, fmt);
300                m_unlock(&status.waitrcmutex, 24);
301        }
302        else if(ostrcmp(query, "getepg") == 0)
303        {
304                m_lock(&status.waitrcmutex, 24);
305                buf = webgetepg(param, fmt);
306                m_unlock(&status.waitrcmutex, 24);
307        }
308        else if(ostrcmp(query, "getmovieepg") == 0)
309        {
310                m_lock(&status.waitrcmutex, 24);
311                buf = webgetmovieepg(param, getconfig("rec_streampath", NULL), 1, fmt);
312                m_unlock(&status.waitrcmutex, 24);
313        }
314        else if(ostrcmp(query, "getsingleepg") == 0)
315        {
316                m_lock(&status.waitrcmutex, 24);
317                buf = webgetsingleepg(param, fmt);
318                m_unlock(&status.waitrcmutex, 24);
319        }
320        else if(ostrcmp(query, "getgmultiepg") == 0)
321        {
322                m_lock(&status.waitrcmutex, 24);
323                buf = webgetgmultiepg(param, fmt);
324                m_unlock(&status.waitrcmutex, 24);
325        }
326        else if(query != NULL && ostrstr(query, "getepgsearch") == query)
327        {
328                m_lock(&status.waitrcmutex, 24);
329                buf = webgetepgsearch(query, param, fmt);
330                m_unlock(&status.waitrcmutex, 24);
331        }
332        else if(ostrcmp(query, "getsignal") == 0)
333                buf = webgetsignal(fmt);
334        else if(ostrcmp(query, "getmoviefilelist") == 0)
335        {
336                if(fmt == 0)
337                        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);
338                else
339                        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);
340       
341        }
342        else if(ostrcmp(query, "delmoviefile") == 0)
343        {
344                if(fmt == 0)
345                        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);
346                else
347                        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);
348        }
349        else if(ostrcmp(query, "getm3u") == 0)
350        {
351                buf = webgetm3u(param, *connfd, fmt);
352                if(fmt == 0)
353                {
354                        ext = "Content-Disposition: attachment; filename=stream.m3u";
355                        mime = "audio/x-mpegurl";
356                }
357        }
358        else if(ostrcmp(query, "getvideo") == 0)
359                buf = webgetvideo(param, *connfd, fmt);
360        else if(ostrcmp(query, "videoplay") == 0 || ostrcmp(query, "videoplay=") == 0)
361                buf = webvideo(param, fmt);
362        else if(ostrcmp(query, "getdrawcount") == 0)
363                buf = webgetdrawcount(param, fmt);
364        else if(ostrcmp(query, "getshoot") == 0)
365        {
366                webgetshoot(param, fmt);
367                if(fmt == 0)
368                {
369                        ext = "Location: shoot.html";
370                        onlyheader = 1;
371                        code = 302;
372                }
373                else
374                        buf = ostrcat("shoot.html", NULL, 0, 0);
375        }
376        else if(query != NULL && ostrstr(query, "poweroff") == query)
377                oshutdown(1, 1);
378        else if(query != NULL && ostrstr(query, "restart") == query)
379                oshutdown(2, 1);
380        else if(query != NULL && ostrstr(query, "guirestart") == query)
381                oshutdown(3, 1);
382        else if(query != NULL && ostrstr(query, "standby") == query)
383        {
384                status.standby = 2;
385                addtimer(&screenstandby, START, 1000, 1, NULL, NULL, NULL);
386        }
387        else if(query != NULL && ostrstr(query, "boxstatus") == query)
388        {
389                if(status.standby > 0)
390                {
391                        if(fmt == 0)
392                                sendoktext(connfd, "standby", auth);
393                        else
394                                buf = ostrcat("standby", NULL, 0, 0);
395                }
396                else
397                {
398                        if(fmt == 0)
399                                sendoktext(connfd, "running", auth);
400                        else
401                                buf = ostrcat("running", NULL, 0, 0);
402                }
403        }
404        else if(query != NULL && ostrstr(query, "mutestatus") == query)
405        {
406                if(status.mute > 0)
407                {
408                        if(fmt == 0)
409                                sendoktext(connfd, "muteon", auth);
410                        else
411                                buf = ostrcat("muteon", NULL, 0, 0);
412                }
413                else
414                {
415                        if(fmt == 0)
416                                sendoktext(connfd, "muteoff", auth);
417                        else
418                                buf = ostrcat("muteoff", NULL, 0, 0);
419                }
420        }
421        else if(query != NULL && ostrstr(query, "message") == query)
422                buf = websendmessage(query, fmt);
423               
424        if(buf != NULL || onlyheader == 1)
425        {
426                if(buflen == 0 && onlyheader == 0) buflen = strlen(buf);
427
428                header = createheader(buflen, NULL, mime, ext, code, auth);
429                socksend(connfd, (unsigned char*)header, strlen(header), 5000 * 1000);
430                if(onlyheader == 0 && auth == 0)
431                        socksend(connfd, (unsigned char*)buf, buflen, 5000 * 1000);
432        }
433        else
434                senderror(connfd, "query", "Error in query string", auth, fmt);
435
436        free(header);
437        free(buf);
438}
439
440void gotdata(int* connfd)
441{
442        int ret = 0, filefd = -1, auth = 0;
443        unsigned char* buf = NULL;
444        char* tmpstr = NULL, *tmpstr1 = NULL, *filename = NULL, *fullfilename = NULL, *header = NULL, *query = NULL;
445
446        buf = malloc(MINMALLOC);
447        if(buf == NULL)
448        {
449                err("no mem");
450                sockclose(connfd);
451                return;
452        }
453        memset(buf, 0, MINMALLOC);
454
455        debug(250, "get client data");
456
457        //read one line
458        unsigned char* pbuf = buf;
459        while(pbuf - buf < MINMALLOC)
460        {
461                unsigned char c;
462
463                ret = sockreceive(connfd, &c, 1, 5000 * 1000);
464                if(ret != 0)
465                {
466                        debug(250, "no client data in buffer");
467                        break;
468                }
469
470                *pbuf = c;
471                if(buf != NULL && (ostrstr((char*)buf, "\n\n") != NULL || ostrstr((char*)buf, "\r\n\r\n") != NULL))
472                        break;
473                pbuf++;
474        }
475
476        if(buf != NULL)
477        {
478                tmpstr = ostrstr((char*)buf, "GET /");
479                tmpstr1 = ostrstr((char*)buf, "Authorization: Basic ");
480        }
481
482        //Auth Password
483        if(status.httpauth != NULL)
484        {
485                if(tmpstr1 != NULL)
486                {
487                        tmpstr1 += 21;
488                        char* tmpstr3 = malloc(255);
489                        if(tmpstr3 != NULL)
490                        {
491                                int l = b64dec(tmpstr3, tmpstr1);
492                                if(l < 255) tmpstr3[l] = '\0';
493                        }
494                        if(ostrncmp(tmpstr3, status.httpauth, strlen(status.httpauth)) != 0)
495                        {
496                                //not ok:
497                                tmpstr1 = NULL;
498                        }
499                        free(tmpstr3); tmpstr3 = NULL;
500                }
501       
502                if(tmpstr1 == NULL) auth = 1;
503        }
504
505        if(tmpstr != NULL)
506        {
507                tmpstr += 4;
508
509                filename = malloc(MINMALLOC);
510                if(filename == NULL)
511                {
512                        err("no mem");
513                        sockclose(connfd);
514                        free(buf); buf = NULL;
515                        tmpstr = NULL;
516                        return;
517                }
518                memset(filename, 0, MINMALLOC);
519
520                ret = sscanf(tmpstr, "%s", filename);
521                if(ret == 1)
522                {
523                        if(ostrstr(filename, "query?rectimersend") != NULL)
524                                stringreplacechar(filename, '+', ' ');
525                        if(ostrstr(filename, "query?rectimercheck") != NULL)
526                                stringreplacechar(filename, '+', ' ');
527                        htmldecode(filename, filename);
528                       
529                        if(ostrstr(filename, "xmessage") == filename + 1  || ostrstr(filename, "/cgi-bin/xmessage") == filename )
530                        {       
531                                xmessage(filename);
532                                sendoktext(connfd, "ok", 0);
533                                //senderror(connfd, "ok", "ok", 0, 0);
534                                free(buf); buf = NULL;
535                                free(filename); filename = NULL;
536                                tmpstr = NULL;
537                                return;
538                        }
539
540                        //create query
541                        query = strchr(filename, '?');
542                        if(query != NULL)
543                        {
544                                *query++ = '\0';
545                                debug(250, "httpd query=%s", query);
546                        }
547
548                        //queryraw
549                        if(ostrcmp(filename, "/queryraw") == 0 && query != NULL)
550                        {
551                                checkquery(connfd, query, auth, 1);
552                                free(buf); buf = NULL;
553                                free(filename); filename = NULL;
554                                tmpstr = NULL;
555                                return;
556                        }
557
558                        //query
559                        if(ostrcmp(filename, "/query") == 0 && query != NULL)
560                        {
561                                checkquery(connfd, query, auth, 0);
562                                free(buf); buf = NULL;
563                                free(filename); filename = NULL;
564                                tmpstr = NULL;
565                                return;
566                        }
567
568                        //create index.html
569                        if(filename[strlen(filename) - 1] == '/')
570                                filename = ostrcat(filename, "index.html", 1, 0);
571
572                        debug(250, "httpd filename=%s", filename);
573
574                        if(ostrstr(filename, "/movie/") != NULL)
575                                fullfilename = ostrcat(filename, NULL, 0, 0);
576                        else
577                                fullfilename = ostrcat(getconfig("httpdpath", NULL), filename, 0, 0);
578                        filefd = open(fullfilename, O_RDONLY | O_LARGEFILE);
579                        if(filefd < 0)
580                        {
581                                perr("open filename=%s", fullfilename);
582                                senderror(connfd, "Open File", "Can't open File", auth, 0);
583                                free(fullfilename); fullfilename = NULL;
584                                free(buf); buf = NULL;
585                                free(filename); filename = NULL;
586                                tmpstr = NULL;
587                                return;
588                        }
589                       
590                        debug(250, "sende OK response to client");
591                        char* rpath = realpath(fullfilename, NULL);
592                        header = createheader(getfilesize(rpath), fullfilename, NULL, NULL, 200, auth);
593                        free(rpath); rpath = NULL;
594                        free(fullfilename); fullfilename = NULL;
595                        ret = socksend(connfd, (unsigned char*)header, strlen(header), 5000 * 1000);
596                        free(header); header = NULL;
597
598                        if(ret != 0)
599                        {
600                                sockclose(connfd);
601                                free(buf); buf = NULL;
602                                free(filename); filename = NULL;
603                                tmpstr = NULL;
604                                return;
605                        }
606
607                        //TODO:
608                        int readret = 1;
609                        while(readret > 0 && auth == 0)
610                        {
611                                readret = dvbreadfd(filefd, buf, 0, MINMALLOC, 1000, 0);
612                                if(readret > 0)
613                                        socksend(connfd, buf, readret, 5000 * 1000);
614                        }
615                }
616        }
617
618        close(filefd);
619        free(buf); buf = NULL;
620        free(filename); filename = NULL;
621        tmpstr = NULL;
622}
623
624int newconn(int* streamfd, int* connfd)
625{
626        int i, fd = -1;
627
628        fd = sockaccept(streamfd, 1);
629        if(fd < 0) return -1;
630
631        for(i = 0; i < MAXHTTPDCONN; i++)
632        {
633                if(connfd[i] < 0)
634                {
635                        connfd[i] = fd;
636                        debug(250, "accept httpd connection fd=%d", fd);
637                        fd = -1;
638                        break;
639                }
640        }
641
642        if(fd != -1)
643        {
644                debug(250, "all connections in use");
645                sockclose(&fd);
646                return -1;
647        }
648
649        return 0;
650}
651
652void httpdthreadfunc(struct stimerthread* timernode)
653{
654        struct timeval timeout;
655        fd_set rfds;
656        int i, ret = 0, streamfd = -1, connfd[MAXHTTPDCONN], maxfd = -1;
657
658        if(timernode == NULL) return;
659        debug(250, "Starting httpd thread");
660
661        for(i = 0; i < MAXHTTPDCONN; i++)
662                connfd[i] = -1;
663
664        while(timernode->aktion != STOP)
665        {
666                if(streamfd < 0)
667                {
668                        sockportcreate(&streamfd, getconfigint("httpdport", NULL), MAXHTTPDCONN);
669                        if(streamfd < 0) break;
670                        maxfd = streamfd;
671
672                        //set nonblocking
673                        fcntl(streamfd, F_SETFL, fcntl(streamfd, F_GETFL) | O_NONBLOCK);
674                }
675
676                timeout.tv_sec = 1;
677                timeout.tv_usec = 0;
678
679                FD_ZERO(&rfds);
680                FD_SET(streamfd, &rfds);
681
682                for(i = 0; i < MAXHTTPDCONN; i++)
683                {
684                        if(connfd[i] > -1)
685                        {
686                                FD_SET(connfd[i], &rfds);
687                                if(connfd[i] > maxfd) maxfd = connfd[i];
688                        }
689                }
690
691                ret = TEMP_FAILURE_RETRY(select(maxfd + 1, &rfds , NULL, NULL, &timeout));
692
693                if(ret < 0)
694                {
695                        perr("httpd listen socket fd=%d", maxfd);
696                        sleep(1);
697                        continue;
698                }
699                if(ret == 0) continue; //timeout
700
701                if(FD_ISSET(streamfd, &rfds))
702                {
703                        ret = newconn(&streamfd, connfd);
704                        if(ret < 0) continue;
705                }
706
707                for(i = 0; i < MAXHTTPDCONN; i++)
708                {
709                        if(connfd[i] > -1 && FD_ISSET(connfd[i], &rfds))
710                                gotdata(&connfd[i]);
711                }
712        }
713
714        debug(250, "Stopping httpd thread");
715        sockclose(&streamfd);
716        for(i = 0; i < MAXHTTPDCONN; i++)
717                sockclose(&connfd[i]);
718
719        return;
720}
721
722void sendoktext(int* connfd, char* text, int auth)
723{
724        char* buf = NULL;
725        char* header = NULL;
726        buf = webcreatehead(buf, NULL, 1);
727        buf = ostrcat(buf, "<tr><td align=center valign=top><font class=biglabel><br><br>", 1, 0);
728        buf = ostrcat(buf, text, 1, 0);
729        buf = ostrcat(buf, "</font></td></tr>", 1, 0);
730        buf = webcreatetail(buf, 1);
731        int buflen = strlen(buf);
732        header = createheader(buflen, NULL, NULL, NULL, 200, auth);
733        socksend(connfd, (unsigned char*)header, strlen(header), 5000 * 1000);
734        if(auth == 0)
735                socksend(connfd, (unsigned char*)buf, buflen, 5000 * 1000);
736        free(buf); buf=NULL;
737        free(header); header=NULL;
738}
739
740#endif
Note: See TracBrowser for help on using the repository browser.