Fixes found in smtp testing

git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@356 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
patacongo 2007-10-27 18:56:04 +00:00
parent f43ffa05aa
commit 00093c0a08
6 changed files with 80 additions and 51 deletions

View file

@ -45,6 +45,7 @@
#include <sys/ioctl.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <time.h>
@ -70,11 +71,29 @@
# include <net/uip/resolv.h>
#elif defined(CONFIG_EXAMPLE_UIP_WEBCLIENT)
# include <net/uip/webclient.h>
#else
# error "No network application specified"
#endif
/************************************************************
/****************************************************************************
* Private Data
****************************************************************************/
#if defined(CONFIG_EXAMPLE_UIP_SMTP)
static const char g_host_name[] = "localhost";
static const char g_recipient[] = "spudmonkey@racsa.co.cr";
static const char g_sender[] = "nuttx-testing@example.com";
static const char g_subject[] = "Testing SMTP from NuttX";
static const char g_msg_body[] = "Test message sent by NuttX\r\n";
#endif
/****************************************************************************
* Public Functions
****************************************************************************/
/****************************************************************************
* user_initialize
************************************************************/
****************************************************************************/
#ifndef CONFIG_HAVE_WEAKFUNCTIONS
void user_initialize(void)
@ -85,11 +104,11 @@ void user_initialize(void)
}
#endif
/************************************************************
/****************************************************************************
* user_start
************************************************************/
****************************************************************************/
int user_start(int argc, char *argv[])
int user_start(int argc, char *argv[])
{
struct in_addr addr;
#if defined(CONFIG_EXAMPLE_UIP_DHCPC) || defined(CONFIG_ARCH_SIM)
@ -154,9 +173,9 @@ void user_initialize(void)
handle = smtp_open();
if (handle)
{
smtp_configure("localhost", addr.s_addr);
smtp_send("adam@sics.se", NULL, "uip-testing@example.com",
"Testing SMTP from uIP", "Test message sent by uIP\r\n");
smtp_configure(handle, g_host_name, &addr.s_addr);
smtp_send(handle, g_recipient, NULL, g_sender, g_subject,
g_msg_body, strlen(g_msg_body));
smtp_close(handle);
}
#elif defined(CONFIG_EXAMPLE_UIP_WEBCLIENT)
@ -180,6 +199,7 @@ void uip_log(char *m)
printf("uIP log message: %s\n", m);
}
#if defined(CONFIG_EXAMPLE_UIP_WEBCLIENT)
void webclient_closed(void)
{
printf("Webclient: connection closed\n");
@ -204,3 +224,4 @@ void webclient_datahandler(char *data, uint16 len)
{
printf("Webclient: got %d bytes of data.\n", len);
}
#endif

View file

@ -57,8 +57,11 @@
****************************************************************************/
extern void *smtp_open(void);
extern void smtp_configure(void *handle, char *localhostname, void *smtpserver);
extern int smtp_send(void *handle, char *to, char *cc, char *from, char *subject, char *msg, int msglen);
extern void smtp_configure(void *handle, const char *localhostname,
const uip_ipaddr_t *paddr);
extern int smtp_send(void *handle, const char *to, const char *cc,
const char *from, const char *subject,
const char *msg, int msglen);
extern void smtp_close(void *handle);
#endif /* __SMTP_H__ */

View file

@ -258,8 +258,7 @@ int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen)
goto errout;
}
err = ENOSYS;
/*return OK;*/
return OK;
errout:
*get_errno_ptr() = err;

View file

@ -406,7 +406,7 @@ static ssize_t recvfrom_result(int result, struct recvfrom_s *pstate)
* psock Pointer to the socket structure for the SOCK_DRAM socket
* buf Buffer to receive data
* len Length of buffer
* infrom INET ddress of source
* infrom INET ddress of source (may be NULL)
*
* Returned Value:
* On success, returns the number of characters sent. On error,
@ -489,7 +489,7 @@ static ssize_t udp_recvfrom(FAR struct socket *psock, FAR void *buf, size_t len,
* psock Pointer to the socket structure for the SOCK_DRAM socket
* buf Buffer to receive data
* len Length of buffer
* infrom INET ddress of source
* infrom INET ddress of source (may be NULL)
*
* Returned Value:
* On success, returns the number of characters sent. On error,
@ -575,7 +575,7 @@ static ssize_t tcp_recvfrom(FAR struct socket *psock, FAR void *buf, size_t len,
* buf Buffer to receive data
* len Length of buffer
* flags Receive flags
* from Address of source
* from Address of source (may be NULL)
* fromlen The length of the address structure
*
* Returned Value:
@ -624,7 +624,7 @@ ssize_t recvfrom(int sockfd, FAR void *buf, size_t len, int flags, FAR struct so
/* Verify that non-NULL pointers were passed */
if (!buf || !from || !fromlen)
if (!buf)
{
err = EINVAL;
goto errout;
@ -640,17 +640,20 @@ ssize_t recvfrom(int sockfd, FAR void *buf, size_t len, int flags, FAR struct so
goto errout;
}
/* Verify that a valid address has been provided */
/* If a 'from' address has been provided, verify that it is valid */
if (from)
{
#ifdef CONFIG_NET_IPv6
if (from->sa_family != AF_INET6 || *fromlen < sizeof(struct sockaddr_in6))
if (from->sa_family != AF_INET6 || *fromlen < sizeof(struct sockaddr_in6))
#else
if (from->sa_family != AF_INET || *fromlen < sizeof(struct sockaddr_in))
if (from->sa_family != AF_INET || *fromlen < sizeof(struct sockaddr_in))
#endif
{
err = EBADF;
goto errout;
}
{
err = EBADF;
goto errout;
}
}
/* Set the socket state to receiving */

View file

@ -75,21 +75,21 @@
struct smtp_state
{
uint8 state;
boolean connected;
sem_t sem;
uint8 state;
boolean connected;
sem_t sem;
uip_ipaddr_t smtpserver;
char *localhostname;
char *to;
char *cc;
char *from;
char *subject;
char *msg;
int msglen;
int sentlen;
int textlen;
int sendptr;
char buffer[SMTP_INPUT_BUFFER_SIZE];
const char *localhostname;
const char *to;
const char *cc;
const char *from;
const char *subject;
const char *msg;
int msglen;
int sentlen;
int textlen;
int sendptr;
char buffer[SMTP_INPUT_BUFFER_SIZE];
};
static inline int smtp_send_message(int sockfd, struct smtp_state *psmtp)
@ -242,33 +242,35 @@ static inline int smtp_send_message(int sockfd, struct smtp_state *psmtp)
/* Specificy an SMTP server and hostname.
*
* This function is used to configure the SMTP module with an SMTP
* server and the hostname of the host.
* This function is used to configure the SMTP module with an SMTP server and
* the hostname of the host.
*
* lhostname The hostname of the uIP host.
* lhostname - The hostname of the local, uIP host.
*
* server A pointer to a 4-byte array representing the IP
* address of the SMTP server to be configured.
* paddr - A pointer to the IP address of the SMTP server to be
* configured.
*/
void smtp_configure(void *handle, char *lhostname, void *server)
void smtp_configure(void *handle, const char *lhostname,
const uip_ipaddr_t *paddr)
{
struct smtp_state *psmtp = (struct smtp_state *)handle;
psmtp->localhostname = lhostname;
uip_ipaddr_copy(psmtp->smtpserver, server);
uip_ipaddr_copy(psmtp->smtpserver, paddr);
}
/* Send an e-mail.
*
* to The e-mail address of the receiver of the e-mail.
* cc The e-mail address of the CC: receivers of the e-mail.
* from The e-mail address of the sender of the e-mail.
* subject The subject of the e-mail.
* msg The actual e-mail message.
* msglen The length of the e-mail message.
* to - The e-mail address of the receiver of the e-mail.
* cc - The e-mail address of the CC: receivers of the e-mail.
* from - The e-mail address of the sender of the e-mail.
* subject - The subject of the e-mail.
* msg - The actual e-mail message.
* msglen - The length of the e-mail message.
*/
int smtp_send(void *handle, char *to, char *cc, char *from, char *subject, char *msg, int msglen)
int smtp_send(void *handle, const char *to, const char *cc, const char *from,
const char *subject, const char *msg, int msglen)
{
struct smtp_state *psmtp = (struct smtp_state *)handle;
struct sockaddr_in server;

View file

@ -289,6 +289,7 @@ static void handle_connection(struct httpd_state *pstate)
int httpd_listen(void)
{
#warning "this is all very broken at the moment"
return OK;
}
/****************************************************************************