/*
- * tcp_sockets.c
+ * $Id$
*
- * TCP socket module for WebCit
+ * TCP client socket module for WebCit
*
- * $Id$
*/
+/*
+ * Uncomment this to log all communications with the Citadel server
+#define SERV_TRACE 1
+ */
#include <ctype.h>
#include <stdlib.h>
memset(&addr, 0, sizeof(addr));
addr.sun_family = AF_UNIX;
- safestrncpy(addr.sun_path, sockpath, sizeof addr.sun_path);
+ strncpy(addr.sun_path, sockpath, sizeof addr.sun_path);
s = socket(AF_UNIX, SOCK_STREAM, 0);
if (s < 0) {
if (connect(s, (struct sockaddr *) &addr, sizeof(addr)) < 0) {
lprintf(1, "Can't connect: %s\n",
strerror(errno));
+ close(s);
return(-1);
}
if (connect(s, (struct sockaddr *) &sin, sizeof(sin)) < 0) {
lprintf(1, "Can't connect to %s.%s: %s\n",
host, service, strerror(errno));
+ close(s);
return (-1);
}
alarm(0);
if (rlen < 1) {
lprintf(1, "Server connection broken: %s\n",
strerror(errno));
+ close(WC->serv_sock);
+ WC->serv_sock = (-1);
WC->connected = 0;
WC->logged_in = 0;
+ memset(buf, 0, bytes);
return;
}
len = len + rlen;
/*
* input string from pipe
*/
-void serv_gets(char *strbuf)
+void serv_getln(char *strbuf, int bufsize)
{
int ch, len;
char buf[2];
serv_read(&buf[0], 1);
ch = buf[0];
strbuf[len++] = ch;
- } while ((ch != 10) && (ch != 13) && (ch != 0) && (len < 255));
- strbuf[len - 1] = 0;
- /* lprintf(9, ">%s\n", strbuf); */
+ } while ((ch != 10) && (ch != 0) && (len < (bufsize-1)));
+ if (strbuf[len-1] == 10) strbuf[--len] = 0;
+ if (strbuf[len-1] == 13) strbuf[--len] = 0;
+#ifdef SERV_TRACE
+ lprintf(9, "%3d>%s\n", WC->serv_sock, strbuf);
+#endif
}
if (retval < 1) {
lprintf(1, "Server connection broken: %s\n",
strerror(errno));
+ close(WC->serv_sock);
+ WC->serv_sock = (-1);
WC->connected = 0;
WC->logged_in = 0;
return;
{
char buf[SIZ];
+#ifdef SERV_TRACE
+ lprintf(9, "%3d<%s\n", WC->serv_sock, string);
+#endif
sprintf(buf, "%s\n", string);
serv_write(buf, strlen(buf));
}
char buf[SIZ];
va_start(arg_ptr, format);
- vsprintf(buf, format, arg_ptr);
+ vsnprintf(buf, sizeof buf, format, arg_ptr);
va_end(arg_ptr);
strcat(buf, "\n");
serv_write(buf, strlen(buf));
- /* lprintf(9, "<%s", buf); */
+#ifdef SERV_TRACE
+ lprintf(9, "<%s", buf);
+#endif
}