2006-06-18 00:41:10 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2002, Adam Dunkels.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above
|
|
|
|
* copyright notice, this list of conditions and the following
|
|
|
|
* disclaimer in the documentation and/or other materials provided
|
|
|
|
* with the distribution.
|
|
|
|
* 3. The name of the author may not be used to endorse or promote
|
|
|
|
* products derived from this software without specific prior
|
|
|
|
* written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
|
|
|
|
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
|
|
|
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
|
|
|
|
* GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
|
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
|
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* This file is part of the Contiki OS.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2007-04-14 15:40:53 +02:00
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
2006-06-18 00:41:10 +02:00
|
|
|
|
|
|
|
#include "contiki.h"
|
2007-04-14 15:40:53 +02:00
|
|
|
#include "sys/log.h"
|
|
|
|
|
2006-06-18 00:41:10 +02:00
|
|
|
#include "http-strings.h"
|
2007-04-23 23:19:55 +02:00
|
|
|
#include "webserver-nogui.h"
|
2006-06-18 00:41:10 +02:00
|
|
|
#include "httpd.h"
|
|
|
|
|
|
|
|
PROCESS(webserver_nogui_process, "Web server");
|
2008-02-08 23:48:28 +01:00
|
|
|
|
|
|
|
AUTOSTART_PROCESSES(&webserver_nogui_process);
|
|
|
|
|
2006-06-18 00:41:10 +02:00
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
PROCESS_THREAD(webserver_nogui_process, ev, data)
|
|
|
|
{
|
|
|
|
PROCESS_BEGIN();
|
|
|
|
|
|
|
|
httpd_init();
|
|
|
|
|
|
|
|
while(1) {
|
|
|
|
PROCESS_WAIT_EVENT_UNTIL(ev == tcpip_event);
|
|
|
|
httpd_appcall(data);
|
|
|
|
}
|
|
|
|
|
|
|
|
PROCESS_END();
|
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
void
|
2007-04-23 23:19:55 +02:00
|
|
|
webserver_log_file(uip_ipaddr_t *requester, char *file)
|
2006-06-18 00:41:10 +02:00
|
|
|
{
|
2007-04-14 15:40:53 +02:00
|
|
|
#if LOG_CONF_ENABLED
|
|
|
|
/* Print out IP address of requesting host. */
|
2009-08-11 18:07:54 +02:00
|
|
|
|
2014-12-01 21:02:57 +01:00
|
|
|
#if NETSTACK_CONF_WITH_IPV6
|
2009-08-11 18:07:54 +02:00
|
|
|
char buf[48];
|
2009-08-12 20:23:37 +02:00
|
|
|
uint8_t j;
|
|
|
|
j=httpd_sprint_ip6((uip_ip6addr_t)*requester, buf);
|
|
|
|
buf[j]=':';buf[j+1]=' ';buf[j+2]=0;
|
2009-08-11 18:07:54 +02:00
|
|
|
#else
|
|
|
|
char buf[20];
|
2007-04-14 15:40:53 +02:00
|
|
|
sprintf(buf, "%d.%d.%d.%d: ", requester->u8[0], requester->u8[1],
|
2009-08-11 18:07:54 +02:00
|
|
|
requester->u8[2], requester->u8[3]);
|
2014-12-01 21:02:57 +01:00
|
|
|
#endif /* NETSTACK_CONF_WITH_IPV6 */
|
2009-08-11 18:07:54 +02:00
|
|
|
|
2007-04-14 15:40:53 +02:00
|
|
|
log_message(buf, file);
|
|
|
|
#endif /* LOG_CONF_ENABLED */
|
2006-06-18 00:41:10 +02:00
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
void
|
2007-04-23 23:19:55 +02:00
|
|
|
webserver_log(char *msg)
|
2006-06-18 00:41:10 +02:00
|
|
|
{
|
2007-04-14 15:40:53 +02:00
|
|
|
log_message(msg, "");
|
2006-06-18 00:41:10 +02:00
|
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|