2 * OpenVPN -- An application to securely tunnel IP networks
3 * over a single TCP/UDP port, with support for SSL/TLS-based
4 * session authentication and key exchange,
5 * packet encryption, packet authentication, and
8 * Copyright (C) 2002-2005 OpenVPN Solutions LLC <info@openvpn.net>
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License version 2
12 * as published by the Free Software Foundation.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program (see the file COPYING included with this
21 * distribution); if not, write to the Free Software Foundation, Inc.,
22 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
29 * Should we exit or restart due to ping (or other authenticated packet)
30 * not received in n seconds?
33 check_ping_restart (struct context
*c
)
35 void check_ping_restart_dowork (struct context
*c
);
36 if (c
->options
.ping_rec_timeout
37 && event_timeout_trigger (&c
->c2
.ping_rec_interval
,
39 (!c
->options
.ping_timer_remote
40 || addr_defined (&c
->c1
.link_socket_addr
.actual
))
42 check_ping_restart_dowork (c
);
46 * Should we ping the remote?
49 check_ping_send (struct context
*c
)
51 void check_ping_send_dowork (struct context
*c
);
52 if (c
->options
.ping_send_timeout
53 && event_timeout_trigger (&c
->c2
.ping_send_interval
,
55 !TO_LINK_DEF(c
) ? ETT_DEFAULT
: 1))
56 check_ping_send_dowork (c
);