summaryrefslogtreecommitdiff
path: root/libexec/ftp-proxy/util.h
diff options
context:
space:
mode:
authorBob Beck <beck@cvs.openbsd.org>2001-08-19 04:11:13 +0000
committerBob Beck <beck@cvs.openbsd.org>2001-08-19 04:11:13 +0000
commit39a444a369d31d9b46d53363b2c4048743e38516 (patch)
treef4084ba7c88e380c0194129f6ecc17ea4927bf16 /libexec/ftp-proxy/util.h
parent2227a0f057f47fc26716273fd678ccec599a6b7b (diff)
transparent ftp proxy, based on Obtuse Systems juniper stuff with much
modernizing and cleanup. still needs looking at. Currently supports PORT PASV EPRT data connections with only a pf rdr to capture the control connection. (I.E. you don't need ip forwarding or other NAT stuff). Runs from inetd. Supports all passive (EPSV PASV) when using -n flag, where the proxy ignores passive mode data connections (and assumes nat will get them through). Todo yet: More audit IpV6 Handle EPSV in proxy (with an rdr added then removed) Option to Daemonize and bind only to the loopback More Content/Login filtering, etc. etc. and more bloat
Diffstat (limited to 'libexec/ftp-proxy/util.h')
-rw-r--r--libexec/ftp-proxy/util.h68
1 files changed, 68 insertions, 0 deletions
diff --git a/libexec/ftp-proxy/util.h b/libexec/ftp-proxy/util.h
new file mode 100644
index 00000000000..3e9e33ede98
--- /dev/null
+++ b/libexec/ftp-proxy/util.h
@@ -0,0 +1,68 @@
+/* $OpenBSD: util.h,v 1.1 2001/08/19 04:11:12 beck Exp $ */
+/*
+ * Copyright (c) 1996-2001
+ * Obtuse Systems Corporation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 4. Neither the name of the Obtuse Systems nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL OBTUSE SYSTEMS CORPORATION OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+ * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+ * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+struct proxy_channel {
+ int pc_to_fd, pc_from_fd;
+ int pc_alive;
+ int pc_nextbyte;
+ int pc_flags;
+ int pc_length;
+ int pc_size;
+ struct sockaddr_in pc_from_sa, pc_to_sa;
+ int (*pc_filter)( void ** databuf, int datalen);
+ char *pc_buffer;
+};
+
+struct csiob {
+ int fd;
+ int line_buffer_size, io_buffer_size, io_buffer_len, next_byte;
+ unsigned char *io_buffer, *line_buffer;
+ struct sockaddr_in sa, real_sa;
+ char *who;
+ char alive, got_eof, data_available;
+ int send_oob_flags;
+};
+
+extern int telnet_getline(struct csiob *iobp,
+ struct csiob *telnet_passthrough);
+
+extern int get_proxy_env(int fd, struct sockaddr_in *server_sa_ptr,
+ struct sockaddr_in *client_sa_ptr);
+
+extern int get_backchannel_socket(int type, int min_port, int max_port,
+ int start_port, int direction, struct sockaddr_in *sap);
+
+extern int xfer_data(const char *what_read, int from_fd, int to_fd,
+ struct in_addr from, struct in_addr to);
+
+extern char *ProgName;
+
+