annotate nnchat.c @ 19:e80072e26178

Add login timestamps.
author Matti Hamalainen <ccr@tnsp.org>
date Tue, 25 Mar 2008 01:28:00 +0000
parents 50d8396e7417
children 29098addfa65
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
1 #ifdef __WIN32
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
2 #include <winsock2.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
3 #else
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
4 #include <sys/socket.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
5 #include <sys/types.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
6 #include <arpa/inet.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
7 #include <sys/time.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
8 #include <netdb.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
9 #endif
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
10
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
11 #include <unistd.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
12 #include <stdlib.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
13 #include <stdio.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
14 #include "th_args.h"
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
15 #include "th_string.h"
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
16 #include <string.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
17 #include <errno.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
18 #include <time.h>
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
19
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
20
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
21 #define SET_ALLOC_SIZE (128)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
22 #define SET_SELECT_USEC (100000)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
23
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
24
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
25 /* Options
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
26 */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
27 int optPort = 8005;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
28 int optUserColor = 0x408060;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
29 char *optServer = "www11.servemedata.com",
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
30 *optUserName = NULL,
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
31 *optUserName2 = NULL,
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
32 *optPassword = NULL,
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
33 *optLogFilename = NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
34
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
35 FILE *optLogFile = NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
36
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
37
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
38 /* Arguments
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
39 */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
40 optarg_t optList[] = {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
41 { 0, '?', "help", "Show this help", OPT_NONE },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
42 { 1, 'v', "verbose", "Be more verbose", OPT_NONE },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
43 { 2, 'p', "port", "Connect to port", OPT_ARGREQ },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
44 { 3, 's', "server", "Server to connect to", OPT_ARGREQ },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
45 { 4, 'C', "color", "Initial color in RGB hex 000000", OPT_ARGREQ },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
46 { 5, 'l', "logfile", "Log filename", OPT_ARGREQ },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
47 };
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
48
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
49 const int optListN = (sizeof(optList) / sizeof(optarg_t));
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
50
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
51
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
52 void argShowHelp()
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
53 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
54 th_args_help(stdout, optList, optListN, th_prog_name,
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
55 "[options] <username> <password>");
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
56 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
57
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
58
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
59 #ifdef __WIN32
1
351e96e01f4c Fix a warning.
Matti Hamalainen <ccr@tnsp.org>
parents: 0
diff changeset
60 /* Just a bogus stub
351e96e01f4c Fix a warning.
Matti Hamalainen <ccr@tnsp.org>
parents: 0
diff changeset
61 */
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
62 const char *hstrerror(int err)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
63 {
1
351e96e01f4c Fix a warning.
Matti Hamalainen <ccr@tnsp.org>
parents: 0
diff changeset
64 (void) err;
351e96e01f4c Fix a warning.
Matti Hamalainen <ccr@tnsp.org>
parents: 0
diff changeset
65
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
66 return "???";
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
67 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
68 #endif
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
69
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
70 BOOL argHandleOpt(const int optN, char *optArg, char *currArg)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
71 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
72 switch (optN) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
73 case 0:
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
74 argShowHelp();
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
75 exit(0);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
76 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
77
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
78 case 1:
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
79 th_verbosityLevel++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
80 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
81
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
82 case 2:
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
83 optPort = atoi(optArg);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
84 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
85
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
86 case 3:
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
87 optServer = optArg;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
88 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
89
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
90 case 4:
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
91 if (sscanf(optArg, "%06x", &optUserColor) != 1) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
92 THERR("Invalid color argument '%s', should be a RGB hex triplet '000000'.\n",
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
93 optArg);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
94 return FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
95 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
96 THMSG(1, "Using color #%06x\n", optUserColor);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
97 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
98
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
99 case 5:
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
100 optLogFilename = optArg;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
101 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
102
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
103 default:
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
104 THERR("Unknown option '%s'.\n", currArg);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
105 return FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
106 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
107
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
108 return TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
109 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
110
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
111
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
112 BOOL argHandleFile(char *currArg)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
113 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
114 if (!optUserName)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
115 optUserName = currArg;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
116 else if (!optPassword)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
117 optPassword = currArg;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
118 else {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
119 THERR("Username '%s' already specified on commandline!\n", optUserName);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
120 return FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
121 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
122
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
123 return TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
124 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
125
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
126
15
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
127 int openConnection(struct in_addr *addr, int port)
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
128 {
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
129 struct sockaddr_in tmpAddr;
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
130 int sock = -1;
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
131
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
132 tmpAddr.sin_family = AF_INET;
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
133 tmpAddr.sin_port = htons(port);
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
134 tmpAddr.sin_addr = *addr;
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
135
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
136 THMSG(1, "Connecting to %s:%d ...\n",
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
137 inet_ntoa(tmpAddr.sin_addr), port);
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
138
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
139 if ((sock = socket(PF_INET, SOCK_STREAM, 0)) == -1) {
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
140 THERR("Could not open socket: %s\n", strerror(errno));
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
141 return -2;
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
142 }
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
143
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
144 THMSG(2, "Using socket %d.\n", sock);
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
145
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
146 if (connect(sock, (struct sockaddr *) &tmpAddr, sizeof(tmpAddr)) == -1) {
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
147 THERR("Could not connect: %s\n", strerror(errno));
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
148 return -5;
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
149 }
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
150
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
151 return sock;
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
152 }
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
153
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
154
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
155 void closeConnection(int sock)
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
156 {
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
157 if (sock >= 0) {
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
158 #ifdef __WIN32
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
159 closesocket(sock);
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
160 #else
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
161 close(sock);
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
162 #endif
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
163 }
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
164 }
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
165
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
166
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
167 BOOL sendToSocket(int sock, char *buf, const size_t bufLen)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
168 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
169 size_t bufLeft = bufLen;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
170 char *bufPtr = buf;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
171
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
172 while (bufLeft > 0) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
173 ssize_t bufSent;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
174 bufSent = send(sock, bufPtr, bufLeft, 0);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
175 if (bufSent < 0) return FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
176 bufLeft -= bufSent;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
177 bufPtr += bufSent;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
178 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
179 return TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
180 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
181
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
182
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
183 void printMsg(char *fmt, ...)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
184 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
185 char tmpStr[64] = "";
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
186 va_list ap;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
187 time_t timeStamp;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
188 struct tm *tmpTime;;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
189
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
190 timeStamp = time(NULL);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
191 if ((tmpTime = localtime(&timeStamp)) != NULL) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
192 strftime(tmpStr, sizeof(tmpStr), "[%H:%M:%S] ", tmpTime);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
193 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
194
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
195 if (optLogFile) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
196 fputs(tmpStr, optLogFile);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
197 va_start(ap, fmt);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
198 vfprintf(optLogFile, fmt, ap);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
199 va_end(ap);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
200 fflush(optLogFile);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
201 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
202
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
203 fputs(tmpStr, stdout);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
204 va_start(ap, fmt);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
205 vfprintf(stdout, fmt, ap);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
206 va_end(ap);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
207 fflush(stdout);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
208 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
209
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
210
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
211 BOOL bufRealloc(char **buf, size_t *size, size_t add)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
212 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
213 return ((*buf = th_realloc(*buf, *size + add)) != NULL);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
214 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
215
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
216 #define PUSHCHAR(x) bufPushChar(&result, &resSize, &resPos, x)
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
217 BOOL bufPushChar(char **buf, size_t *size, size_t *pos, char ch)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
218 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
219 if (*pos >= *size && !bufRealloc(buf, size, SET_ALLOC_SIZE))
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
220 return FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
221
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
222 (*buf)[*pos] = ch;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
223 (*pos)++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
224 return TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
225 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
226
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
227 #define PUSHSTR(x) bufPushStr(&result, &resSize, &resPos, x)
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
228 BOOL bufPushStr(char **buf, size_t *size, size_t *pos, char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
229 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
230 size_t tmpLen;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
231
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
232 if (!str) return FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
233 tmpLen = strlen(str);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
234
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
235 if ((*pos + tmpLen) >= *size && !bufRealloc(buf, size, tmpLen + SET_ALLOC_SIZE))
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
236 return FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
237
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
238 strcpy(*buf + *pos, str);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
239 (*pos) += tmpLen;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
240 return TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
241 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
242
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
243
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
244 char *encodeStr1(char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
245 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
246 char *result, *s = str;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
247 size_t resSize, resPos = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
248
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
249 if (!str) return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
250
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
251 resSize = strlen(str) + SET_ALLOC_SIZE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
252 if ((result = th_malloc(resSize)) == NULL)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
253 return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
254
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
255 while (*s) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
256 switch (*s) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
257 case 32:
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
258 PUSHCHAR('+');
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
259 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
260
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
261 default:
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
262 if (th_isalnum(*s))
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
263 PUSHCHAR(*s);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
264 else {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
265 char tmpStr[4];
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
266 sprintf(tmpStr, "%2X", (unsigned char) *s);
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
267 PUSHCHAR('%');
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
268 PUSHSTR(tmpStr);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
269 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
270 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
271 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
272 s++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
273 }
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
274 PUSHCHAR(0);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
275
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
276 return result;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
277 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
278
15
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
279
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
280 int getxdigit(int c, int shift)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
281 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
282 int i;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
283
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
284 if (c >= 'A' && c <= 'F')
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
285 i = c - 'A' + 10;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
286 else if (c >= 'a' && c <= 'f')
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
287 i = c - 'a' + 10;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
288 else if (c >= '0' && c <= '9')
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
289 i = c - '0';
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
290 else
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
291 return -1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
292
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
293 return i << shift;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
294 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
295
15
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
296
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
297 char *decodeStr1(char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
298 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
299 char *result, *s = str;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
300 size_t resSize, resPos = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
301 int c;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
302
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
303 if (!str) return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
304
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
305 resSize = strlen(str) + SET_ALLOC_SIZE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
306 if ((result = th_malloc(resSize)) == NULL)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
307 return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
308
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
309 while (*s) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
310 switch (*s) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
311 case '+':
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
312 PUSHCHAR(' ');
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
313 s++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
314 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
315
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
316 case '%':
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
317 s++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
318 if (*s == '%')
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
319 PUSHCHAR('%');
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
320 else if ((c = getxdigit(*s, 4)) >= 0) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
321 int i = getxdigit(*(++s), 0);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
322 if (i >= 0) {
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
323 PUSHCHAR(c | i);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
324 } else {
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
325 PUSHCHAR('§');
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
326 PUSHCHAR(*s);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
327 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
328 } else {
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
329 PUSHCHAR('§');
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
330 PUSHCHAR(*s);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
331 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
332 s++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
333 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
334
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
335 default:
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
336 PUSHCHAR(*s);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
337 s++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
338 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
339 }
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
340 PUSHCHAR(0);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
341
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
342 return result;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
343 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
344
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
345
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
346 char *stripTags(char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
347 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
348 char *result, *s = str;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
349 size_t resSize, resPos = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
350
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
351 if (!str) return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
352
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
353 resSize = strlen(str) + SET_ALLOC_SIZE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
354 if ((result = th_malloc(resSize)) == NULL)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
355 return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
356
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
357 while (*s) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
358 if (*s == '<') {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
359 while (*s && *s != '>') s++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
360 if (*s == '>') s++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
361 } else
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
362 PUSHCHAR(*s++);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
363 }
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
364 PUSHCHAR(0);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
365
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
366 return result;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
367 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
368
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
369
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
370 typedef struct {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
371 char c;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
372 char *ent;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
373 } html_entity_t;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
374
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
375
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
376 html_entity_t HTMLEntities[] = {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
377 { '<', "&lt;" },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
378 { '>', "&gt;" },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
379 };
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
380
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
381 const int numHTMLEntities = (sizeof(HTMLEntities) / sizeof(html_entity_t));
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
382
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
383
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
384 char *encodeStr2(char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
385 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
386 char *result, *s = str;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
387 size_t resSize, resPos = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
388
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
389 if (!str) return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
390
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
391 resSize = strlen(str) + SET_ALLOC_SIZE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
392 if ((result = th_malloc(resSize)) == NULL)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
393 return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
394
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
395 while (*s) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
396 int i;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
397 BOOL found = FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
398 for (i = 0; i < numHTMLEntities; i++)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
399 if (HTMLEntities[i].c == *s) {
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
400 PUSHSTR(HTMLEntities[i].ent);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
401 found = TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
402 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
403 }
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
404 if (!found) PUSHCHAR(*s);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
405
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
406 s++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
407 }
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
408 PUSHCHAR(0);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
409
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
410 return result;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
411 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
412
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
413
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
414 char *decodeStr2(char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
415 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
416 char *result, *s = str;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
417 size_t resSize, resPos = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
418
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
419 if (!str) return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
420
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
421 resSize = strlen(str);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
422 if ((result = th_malloc(resSize)) == NULL)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
423 return NULL;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
424
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
425 while (*s) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
426 if (*s == '&') {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
427 int i;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
428 BOOL found = FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
429 for (i = 0; i < numHTMLEntities; i++) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
430 html_entity_t *ent = &HTMLEntities[i];
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
431 int len = strlen(ent->ent);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
432 if (!strncmp(s, ent->ent, len)) {
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
433 PUSHCHAR(ent->c);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
434 s += len;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
435 found = TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
436 break;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
437 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
438 }
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
439 if (!found) PUSHCHAR(*s++);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
440 } else
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
441 PUSHCHAR(*s++);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
442 }
12
Matti Hamalainen <ccr@tnsp.org>
parents: 10
diff changeset
443 PUSHCHAR(0);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
444
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
445 return result;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
446 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
447
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
448
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
449 BOOL sendUserMsg(int sock, char *user, char *fmt, ...)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
450 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
451 char tmpBuf[4096], tmpBuf2[4096+256];
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
452 int n;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
453 va_list ap;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
454
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
455 va_start(ap, fmt);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
456 n = vsnprintf(tmpBuf, sizeof(tmpBuf), fmt, ap);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
457 va_end(ap);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
458
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
459 if (n < 0) return FALSE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
460
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
461 snprintf(tmpBuf2, sizeof(tmpBuf2),
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
462 "<USER>%s</USER><MESSAGE>%s</MESSAGE>",
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
463 user, tmpBuf);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
464
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
465 return sendToSocket(sock, tmpBuf2, strlen(tmpBuf2) + 1);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
466 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
467
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
468
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
469 int handleUser(int sock, char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
470 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
471 const char *msg = "</USER><MESSAGE>";
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
472 char *p = str, *q, *s;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
473
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
474 (void) sock;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
475
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
476 s = strstr(str, msg);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
477 if (!s) return 1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
478 *s = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
479 s += strlen(msg);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
480
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
481 q = strstr(s, "</MESSAGE>");
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
482 if (!q) return 3;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
483 *q = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
484
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
485 s = decodeStr1(s);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
486 if (!s) return -1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
487
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
488 p = decodeStr1(p);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
489 if (!p) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
490 th_free(s);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
491 return -2;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
492 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
493
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
494 /* FIXME: decodeStr2() */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
495
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
496 if (*s == '/') {
19
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
497 char *t;
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
498 if (!strncmp(s, "/BPRV", 5)) {
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
499 t = stripTags(s + 2);
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
500 printMsg("%s\n", t);
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
501 } else {
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
502 t = stripTags(s + 1);
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
503 printMsg("* %s\n", t);
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
504 }
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
505 th_free(t);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
506 } else {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
507 char *t = stripTags(s);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
508 printMsg("<%s> %s\n", p, t);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
509 th_free(t);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
510 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
511
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
512 th_free(s);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
513 th_free(p);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
514 return 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
515 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
516
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
517
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
518 int handleLogin(int sock, char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
519 {
19
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
520 char tmpStr[256] = "";
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
521 time_t timeStamp;
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
522 struct tm *tmpTime;;
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
523
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
524 timeStamp = time(NULL);
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
525 if ((tmpTime = localtime(&timeStamp)) != NULL) {
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
526 strftime(tmpStr, sizeof(tmpStr), "%c", tmpTime);
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
527 }
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
528
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
529 if (!strncmp(str, "FAILURE", 7)) {
19
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
530 printMsg("Login failure - %s\n", tmpStr);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
531 return -2;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
532 } else if (!strncmp(str, "SUCCESS", 7)) {
19
e80072e26178 Add login timestamps.
Matti Hamalainen <ccr@tnsp.org>
parents: 15
diff changeset
533 printMsg("Login success - %s\n", tmpStr);
13
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
534 sendUserMsg(sock, optUserName2, "%%2FRequestUserList");
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
535 return 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
536 } else
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
537 return 1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
538 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
539
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
540
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
541 int handleAddUser(int sock, char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
542 {
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
543 char *p, *s = strstr(str, "</ADD_USER>");
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
544
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
545 (void) sock;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
546
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
547 if (!s) return 1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
548 *s = 0;
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
549
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
550 p = decodeStr1(str);
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
551 if (!p) return -1;
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
552
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
553 printMsg("! %s ADDED.\n", p);
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
554 th_free(p);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
555 return 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
556 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
557
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
558
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
559 int handleDeleteUser(int sock, char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
560 {
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
561 char *p, *s = strstr(str, "</DELETE_USER>");
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
562
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
563 (void) sock;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
564
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
565 if (!s) return 1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
566 *s = 0;
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
567
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
568 p = decodeStr1(str);
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
569 if (!p) return -1;
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
570
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
571 printMsg("! %s DELETED.\n", p);
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
572 th_free(p);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
573 return 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
574 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
575
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
576
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
577 int handleFoo(int sock, char *str)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
578 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
579 (void) sock; (void) str;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
580
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
581 return 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
582 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
583
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
584
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
585 typedef struct {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
586 char *cmd;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
587 int (*handler)(int, char *);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
588 } protocmd_t;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
589
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
590
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
591 protocmd_t protoCmds[] = {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
592 { "<USER>", handleUser },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
593 { "<LOGIN_", handleLogin },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
594 { "<DELETE_USER>", handleDeleteUser },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
595 { "<ADD_USER>", handleAddUser },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
596 { "<NUMCLIENTS>", handleFoo },
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
597 };
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
598
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
599 const int nprotoCmds = (sizeof(protoCmds) / sizeof(protocmd_t));
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
600
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
601
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
602 int handleProtocol(int sock, char *buf, size_t bufLen)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
603 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
604 int i;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
605
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
606 for (i = 0; i < nprotoCmds; i++) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
607 size_t cmdLen = strlen(protoCmds[i].cmd);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
608 if (cmdLen < bufLen && !strncmp(buf, protoCmds[i].cmd, cmdLen)) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
609 return protoCmds[i].handler(sock, buf + cmdLen);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
610 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
611 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
612
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
613 return 1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
614 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
615
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
616
15
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
617 int handleUserInput(int sock, char *buf, size_t bufLen)
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
618 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
619 char *tmpStr, *tmpStr2;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
620 BOOL result;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
621
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
622 /* Trim right */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
623 buf[--bufLen] = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
624 while (bufLen > 0 && (buf[bufLen] == '\n' || buf[bufLen] == '\r' || th_isspace(buf[bufLen])))
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
625 buf[bufLen--] = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
626
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
627 //fprintf(stderr, "'%s'\n", buf); fflush(stderr);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
628
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
629 /* Check command */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
630 if (*buf == 0) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
631 return 1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
632 } else if (*buf == '@') {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
633 /* Send 1-pass encoded 'RAW' */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
634 buf++;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
635 printf("RAW>%s\n", buf);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
636 fflush(stdout);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
637
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
638 tmpStr = encodeStr1(buf);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
639 if (!tmpStr) return -2;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
640
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
641 result = sendUserMsg(sock, optUserName2, "%s", tmpStr);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
642 th_free(tmpStr);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
643 if (result)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
644 return 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
645 else
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
646 return -1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
647 } else {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
648 /* Send double-encoded */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
649 printf("ENC>%s\n", buf);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
650 fflush(stdout);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
651
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
652 tmpStr = encodeStr2(buf);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
653 if (!tmpStr) return -2;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
654 tmpStr2 = encodeStr1(tmpStr);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
655 if (!tmpStr2) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
656 th_free(tmpStr);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
657 return -3;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
658 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
659
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
660 result = sendUserMsg(sock, optUserName2, "%s", tmpStr2);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
661 th_free(tmpStr);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
662 th_free(tmpStr2);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
663 if (result)
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
664 return 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
665 else
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
666 return -1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
667 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
668 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
669
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
670
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
671 int main(int argc, char *argv[])
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
672 {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
673 int tmpSocket;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
674 struct hostent *tmpHost;
13
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
675 BOOL exitProg = FALSE, colorSet = FALSE;
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
676 struct timeval tv;
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
677 fd_set sockfds;
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
678 fd_set inputfds;
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
679 char *tmpStr;
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
680
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
681 /* Initialize */
4
b9d792e88ab5 Creator info changed.
Matti Hamalainen <ccr@tnsp.org>
parents: 1
diff changeset
682 th_init("NNChat", "Newbie Nudes chat client", "0.3",
6
526ba3b578d7 Changed copyright etc. again.
Matti Hamalainen <ccr@tnsp.org>
parents: 4
diff changeset
683 "Written and designed by Anonymous Finnish Guy (C) 2008",
526ba3b578d7 Changed copyright etc. again.
Matti Hamalainen <ccr@tnsp.org>
parents: 4
diff changeset
684 "This software is freeware, use and distribute as you wish.");
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
685 th_verbosityLevel = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
686
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
687 /* Parse arguments */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
688 th_args_process(argc, argv, optList, optListN,
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
689 argHandleOpt, argHandleFile, FALSE);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
690
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
691 /* Check the mode and arguments */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
692 if (optUserName == NULL || optPassword == NULL) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
693 THERR("User/pass not specified, get some --help\n");
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
694 return -1;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
695 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
696
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
697 /* Open logfile */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
698 if (optLogFilename) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
699 THMSG(1, "Opening logfile '%s'\n", optLogFilename);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
700
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
701 if ((optLogFile = fopen(optLogFilename, "a")) == NULL) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
702 THERR("Could not open logfile for appending!\n");
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
703 return -9;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
704 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
705 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
706
10
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
707 #ifdef __WIN32
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
708 {
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
709 WSADATA wsaData;
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
710 if (WSAStartup(MAKEWORD(2, 0), &wsaData) != 0) {
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
711 THERR("WinSock API v2.0 not supported.\n");
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
712 return -20;
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
713 }
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
714 }
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
715 #endif
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
716
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
717 /* Okay ... */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
718 THMSG(1, "Trying to resolve host '%s' ...\n", optServer);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
719 tmpHost = gethostbyname(optServer);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
720 if (tmpHost == NULL) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
721 THERR("Could not resolve hostname: %s.\n",
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
722 hstrerror(h_errno));
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
723 return -3;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
724 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
725 THMSG(2, "True hostname: %s\n", tmpHost->h_name);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
726
13
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
727 /* To emulate the official client, we first make a fake connection ... */
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
728 if ((tmpSocket = openConnection((struct in_addr *) tmpHost->h_addr, optPort)) < 0) {
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
729 THERR("Fakeprobe connection setup failed!\n");
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
730 goto err_exit;
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
731 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
732
13
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
733 tmpStr = "<policy-file-request/>";
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
734 if (sendToSocket(tmpSocket, tmpStr, strlen(tmpStr) + 1) < 0) {
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
735 THERR("Failed to send fakeprobe.\n");
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
736 goto err_exit;
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
737 } else {
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
738 ssize_t gotBuf;
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
739 char tmpBuf[4096];
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
740 gotBuf = recv(tmpSocket, tmpBuf, sizeof(tmpBuf), 0);
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
741 tmpBuf[gotBuf-1] = 0;
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
742 THMSG(2, "Probe got: %s\n", tmpBuf);
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
743 closeConnection(tmpSocket);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
744 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
745
13
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
746 /* Okay, now do the proper connection ... */
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
747 if ((tmpSocket = openConnection((struct in_addr *) tmpHost->h_addr, optPort)) < 0) {
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
748 THERR("Main connection setup failed!\n");
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
749 goto err_exit;
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
750 }
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
751
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
752 THMSG(1, "Connected, logging in as '%s'.\n", optUserName);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
753 optUserName2 = encodeStr1(optUserName);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
754
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
755 sendUserMsg(tmpSocket, optUserName2, "%%2Flogin%%20%%2Dsite%%20NN%%20%%2Dpassword%%20%s", optPassword);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
756
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
757 FD_ZERO(&inputfds);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
758 FD_SET(0, &inputfds);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
759 FD_ZERO(&sockfds);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
760 FD_SET(tmpSocket, &sockfds);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
761
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
762 while (!exitProg) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
763 ssize_t gotBuf;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
764 int result;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
765 char tmpBuf[4096];
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
766 fd_set tmpfds;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
767
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
768 /* Check for incoming data from the server */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
769 tv.tv_sec = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
770 tv.tv_usec = SET_SELECT_USEC;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
771 tmpfds = sockfds;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
772 if ((result = select(tmpSocket+1, &tmpfds, NULL, NULL, &tv)) == -1) {
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
773 printMsg("Error occured in select(sockfds): %s\n", strerror(errno));
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
774 exitProg = TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
775 } else if (FD_ISSET(tmpSocket, &tmpfds)) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
776 gotBuf = recv(tmpSocket, tmpBuf, sizeof(tmpBuf), 0);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
777
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
778 if (gotBuf < 0) {
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
779 printMsg("Error in recv: %s\n", strerror(errno));
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
780 exitProg = TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
781 } else if (gotBuf == 0) {
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
782 printMsg("Server closed connection.\n");
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
783 exitProg = TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
784 } else {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
785 /* Handle protocol data */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
786 tmpBuf[gotBuf] = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
787 result = handleProtocol(tmpSocket, tmpBuf, gotBuf);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
788
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
789 if (result > 0) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
790 /* Couldn't handle the message for some reason */
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
791 printMsg("Could not handle: %s\n", tmpBuf);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
792 } else if (result < 0) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
793 /* Fatal error, quit */
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
794 printMsg("Fatal error with message: %s\n", tmpBuf);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
795 exitProg = TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
796 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
797 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
798 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
799
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
800 /* Check for user input */
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
801 tv.tv_sec = 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
802 tv.tv_usec = SET_SELECT_USEC;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
803 tmpfds = inputfds;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
804 if ((result = select(1, &tmpfds, NULL, NULL, &tv)) == -1) {
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
805 printMsg("Error occured in select(inputfds): %s\n", strerror(errno));
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
806 exitProg = TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
807 } else if (FD_ISSET(0, &tmpfds)) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
808 gotBuf = read(0, tmpBuf, sizeof(tmpBuf));
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
809
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
810 if (gotBuf < 0) {
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
811 printMsg("Error in reading stdio.\n");
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
812 exitProg = TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
813 } else {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
814 /* Call the user input handler */
15
50d8396e7417 Move things around a bit.
Matti Hamalainen <ccr@tnsp.org>
parents: 13
diff changeset
815 result = handleUserInput(tmpSocket, tmpBuf, gotBuf);
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
816 if (result < 0) {
9
a02659cc5bc8 Cleanup.
Matti Hamalainen <ccr@tnsp.org>
parents: 6
diff changeset
817 printMsg("Fatal error handling user input: %s\n",
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
818 tmpBuf);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
819 exitProg = TRUE;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
820 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
821 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
822 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
823
13
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
824 if (!colorSet) {
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
825 colorSet = TRUE;
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
826 sendUserMsg(tmpSocket, optUserName2, "%%2FSetFontColor%%20%%2Dcolor%%20%06X", optUserColor);
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
827 }
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
828
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
829 fflush(stdout);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
830 fflush(stderr);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
831 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
832
13
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
833 /* Shotdiwn */
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
834 err_exit:
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
835 th_free(optUserName2);
10
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
836
13
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
837 closeConnection(tmpSocket);
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
838
10
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
839 #ifdef __WIN32
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
840 WSACleanup();
53e127854dca WinSock support fixes.
Matti Hamalainen <ccr@tnsp.org>
parents: 9
diff changeset
841 #endif
13
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
842
86fe5f0d1a85 Cleanups; Added probing connection (requesting some policy crap) to emulate the official client.
Matti Hamalainen <ccr@tnsp.org>
parents: 12
diff changeset
843 THMSG(1, "Connection terminated.\n");
0
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
844
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
845 if (optLogFile) {
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
846 THMSG(1, "Closing logfile.\n");
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
847 fclose(optLogFile);
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
848 }
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
849
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
850
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
851 return 0;
728243125263 Import.
Matti Hamalainen <ccr@tnsp.org>
parents:
diff changeset
852 }