4 * The secure anycast tunneling protocol (satp) defines a protocol used
5 * for communication between any combination of unicast and anycast
6 * tunnel endpoints. It has less protocol overhead than IPSec in Tunnel
7 * mode and allows tunneling of every ETHER TYPE protocol (e.g.
8 * ethernet, ip, arp ...). satp directly includes cryptography and
9 * message authentication based on the methodes used by SRTP. It is
10 * intended to deliver a generic, scaleable and secure solution for
11 * tunneling and relaying of packets of any protocol.
14 * Copyright (C) 2007-2008 Othmar Gsenger, Erwin Nindl,
15 * Christian Pointner <satp@wirdorange.org>
17 * This file is part of Anytun.
19 * Anytun is free software: you can redistribute it and/or modify
20 * it under the terms of the GNU General Public License version 3 as
21 * published by the Free Software Foundation.
23 * Anytun is distributed in the hope that it will be useful,
24 * but WITHOUT ANY WARRANTY; without even the implied warranty of
25 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
26 * GNU General Public License for more details.
28 * You should have received a copy of the GNU General Public License
29 * along with anytun. If not, see <http://www.gnu.org/licenses/>.
32 #ifndef _ANY_CTR_OPTIONS_H_
33 #define _ANY_CTR_OPTIONS_H_
35 #include "datatypes.h"
37 #include "threadUtils.hpp"
43 static Options
& instance();
45 bool parse(int argc
, char* argv
[]);
49 std::string
getProgname();
50 Options
& setProgname(std::string p
);
52 Options
& setDaemonize(bool d
);
54 Options
& setChroot(bool b
);
55 std::string
getUsername();
56 Options
& setUsername(std::string u
);
57 std::string
getChrootDir();
58 Options
& setChrootDir(std::string c
);
59 std::string
getPidFile();
60 Options
& setPidFile(std::string p
);
61 std::string
getFileName();
62 Options
& setFileName(std::string f
);
63 std::string
getBindToAddr();
64 Options
& setBindToAddr(std::string b
);
65 uint16_t getBindToPort();
66 Options
& setBindToPort(uint16_t b
);
72 Options(const Options
&l
);
73 void operator=(const Options
&l
);
76 static Mutex instMutex
;
77 class instanceCleaner
{
78 public: ~instanceCleaner() {
79 if(Options::inst
!= 0)
83 friend class instanceCleaner
;
87 std::string bind_to_addr_
;
88 uint16_t bind_to_port_
;
89 std::string progname_
;
92 std::string username_
;
93 std::string chroot_dir_
;
94 std::string pid_file_
;
95 std::string file_name_
;