/* * OpenVPN -- An application to securely tunnel IP networks * over a single TCP/UDP port, with support for SSL/TLS-based * session authentication and key exchange, * packet encryption, packet authentication, and * packet compression. * * Copyright (C) 2002-2009 OpenVPN Technologies, Inc. <sales@openvpn.net> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program (see the file COPYING included with this * distribution); if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef INIT_H #define INIT_H #include "openvpn.h" /* * Baseline maximum number of events * to wait for. */ #define BASE_N_EVENTS 4 void context_clear (struct context *c); void context_clear_1 (struct context *c); void context_clear_2 (struct context *c); void context_init_1 (struct context *c); void context_clear_all_except_first_time (struct context *c); bool init_static (void); void uninit_static (void); #define IVM_LEVEL_1 (1<<0) #define IVM_LEVEL_2 (1<<1) void init_verb_mute (struct context *c, unsigned int flags); void init_options_dev (struct options *options); bool print_openssl_info (const struct options *options); bool do_genkey (const struct options *options); bool do_persist_tuntap (const struct options *options); void pre_setup (const struct options *options); void init_instance_handle_signals (struct context *c, const struct env_set *env, const unsigned int flags); void init_instance (struct context *c, const struct env_set *env, const unsigned int flags); void do_route (const struct options *options, struct route_list *route_list, const struct tuntap *tt, const struct plugin_list *plugins, struct env_set *es); void close_instance (struct context *c); bool do_test_crypto (const struct options *o); void context_gc_free (struct context *c); void do_up (struct context *c, bool pulled_options, unsigned int option_types_found); unsigned int pull_permission_mask (const struct context *c); const char *format_common_name (struct context *c, struct gc_arena *gc); void reset_coarse_timers (struct context *c); void do_deferred_options (struct context *c, const unsigned int found); void inherit_context_child (struct context *dest, const struct context *src); void inherit_context_top (struct context *dest, const struct context *src); #define CC_GC_FREE (1<<0) #define CC_USR1_TO_HUP (1<<1) #define CC_HARD_USR1_TO_HUP (1<<2) #define CC_NO_CLOSE (1<<3) void close_context (struct context *c, int sig, unsigned int flags); struct context_buffers *init_context_buffers (const struct frame *frame); void free_context_buffers (struct context_buffers *b); #define ISC_ERRORS (1<<0) #define ISC_SERVER (1<<1) void initialization_sequence_completed (struct context *c, const unsigned int flags); #ifdef ENABLE_MANAGEMENT void init_management (struct context *c); bool open_management (struct context *c); void close_management (void); void management_show_net_callback (void *arg, const int msglevel); #endif void init_management_callback_p2p (struct context *c); void uninit_management_callback (void); #ifdef ENABLE_PLUGIN void init_plugins (struct context *c); void open_plugins (struct context *c, const bool import_options, int init_point); #endif #endif