4 * Copyright (C) 1993-2001 by Darren Reed.
6 * See the IPFILTER.LICENCE file for details on licencing.
9 static const char sccsid[] = "@(#)ip_fil.c 2.41 6/5/96 (C) 1993-2000 Darren Reed";
10 static const char rcsid[] = "@(#)$Id: ipsyncm.c,v 1.4.2.2 2005/01/08 14:31:46 darrenr Exp $";
12 #include <sys/types.h>
14 #include <sys/socket.h>
16 #include <netinet/in.h>
19 #include <arpa/inet.h>
29 #include "netinet/ip_compat.h"
30 #include "netinet/ip_fil.h"
31 #include "netinet/ip_nat.h"
32 #include "netinet/ip_state.h"
33 #include "netinet/ip_sync.h"
36 int main __P((int, char *[]));
40 void usage(const char *progname) {
41 fprintf(stderr, "Usage: %s <destination IP> <destination port>\n", progname);
44 static void handleterm(int sig)
50 /* should be large enough to hold header + any datatype */
51 #define BUFFERLEN 1400
57 struct sockaddr_in sin;
61 int nfd = -1, lfd = -1, n1, n2, n3, len;
67 progname = strrchr(argv[0], '/');
81 signal(SIGHUP, handleterm);
82 signal(SIGINT, handleterm);
83 signal(SIGTERM, handleterm);
86 openlog(progname, LOG_PID, LOG_SECURITY);
88 bzero((char *)&sin, sizeof(sin));
89 sin.sin_family = AF_INET;
90 sin.sin_addr.s_addr = inet_addr(argv[1]);
92 sin.sin_port = htons(atoi(argv[2]));
94 sin.sin_port = htons(43434);
103 lfd = open(IPSYNC_NAME, O_RDONLY);
105 syslog(LOG_ERR, "Opening %s :%m", IPSYNC_NAME);
109 nfd = socket(AF_INET, SOCK_DGRAM, 0);
111 syslog(LOG_ERR, "Socket :%m");
115 if (connect(nfd, (struct sockaddr *)&sin, sizeof(sin)) == -1) {
116 syslog(LOG_ERR, "Connect: %m");
120 syslog(LOG_INFO, "Established connection to %s",
121 inet_ntoa(sin.sin_addr));
126 n1 = read(lfd, buff+inbuf, BUFFERLEN-inbuf);
128 printf("header : %d bytes read (header = %d bytes)\n",
132 syslog(LOG_ERR, "Read error (header): %m");
137 /* XXX can this happen??? */
139 "Read error (header) : No data");
147 if (inbuf < sizeof(*sh)) {
148 continue; /* need more data */
151 sh = (synchdr_t *)buff;
152 len = ntohl(sh->sm_len);
153 magic = ntohl(sh->sm_magic);
155 if (magic != SYNHDRMAGIC) {
157 "Invalid header magic %x", magic);
163 printf("v:%d p:%d len:%d magic:%x", sh->sm_v,
164 sh->sm_p, len, magic);
166 if (sh->sm_cmd == SMC_CREATE)
167 printf(" cmd:CREATE");
168 else if (sh->sm_cmd == SMC_UPDATE)
169 printf(" cmd:UPDATE");
171 printf(" cmd:Unknown(%d)", sh->sm_cmd);
173 if (sh->sm_table == SMC_NAT)
174 printf(" table:NAT");
175 else if (sh->sm_table == SMC_STATE)
176 printf(" table:STATE");
178 printf(" table:Unknown(%d)", sh->sm_table);
180 printf(" num:%d\n", (u_32_t)ntohl(sh->sm_num));
183 if (inbuf < sizeof(*sh) + len) {
184 continue; /* need more data */
189 if (sh->sm_cmd == SMC_CREATE) {
190 sl = (synclogent_t *)buff;
192 } else if (sh->sm_cmd == SMC_UPDATE) {
193 su = (syncupdent_t *)buff;
194 if (sh->sm_p == IPPROTO_TCP) {
195 printf(" TCP Update: age %lu state %d/%d\n",
197 su->sup_tcp.stu_state[0],
198 su->sup_tcp.stu_state[1]);
201 printf("Unknown command\n");
205 n2 = sizeof(*sh) + len;
206 n3 = write(nfd, buff, n2);
208 syslog(LOG_ERR, "Write error: %m");
214 syslog(LOG_ERR, "Incomplete write (%d/%d)",
219 /* signal received? */
223 /* move buffer to the front,we might need to make
224 * this more efficient, by using a rolling pointer
225 * over the buffer and only copying it, when
226 * we are reaching the end
230 bcopy(buff+n2, buff, inbuf);
231 printf("More data in buffer\n");
249 syslog(LOG_ERR, "signal %d received, exiting...", terminate);