Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
slapos.package
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Guillaume Hervier
slapos.package
Commits
8e0927f9
Commit
8e0927f9
authored
May 02, 2013
by
Jondy Zhao
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Patch openvpn for cygwin
parent
873ba777
Changes
14
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
269 additions
and
71 deletions
+269
-71
windows/openvpn/src/openvpn/console.c
windows/openvpn/src/openvpn/console.c
+2
-2
windows/openvpn/src/openvpn/error.c
windows/openvpn/src/openvpn/error.c
+1
-1
windows/openvpn/src/openvpn/forward.c
windows/openvpn/src/openvpn/forward.c
+60
-5
windows/openvpn/src/openvpn/misc.c
windows/openvpn/src/openvpn/misc.c
+18
-14
windows/openvpn/src/openvpn/openvpn.c
windows/openvpn/src/openvpn/openvpn.c
+3
-3
windows/openvpn/src/openvpn/options.c
windows/openvpn/src/openvpn/options.c
+26
-26
windows/openvpn/src/openvpn/platform.c
windows/openvpn/src/openvpn/platform.c
+9
-9
windows/openvpn/src/openvpn/platform.h
windows/openvpn/src/openvpn/platform.h
+1
-1
windows/openvpn/src/openvpn/socket.h
windows/openvpn/src/openvpn/socket.h
+2
-0
windows/openvpn/src/openvpn/syshead.h
windows/openvpn/src/openvpn/syshead.h
+5
-3
windows/openvpn/src/openvpn/tun.c
windows/openvpn/src/openvpn/tun.c
+5
-1
windows/openvpn/src/openvpn/tun.h
windows/openvpn/src/openvpn/tun.h
+6
-0
windows/openvpn/src/openvpn/win32.c
windows/openvpn/src/openvpn/win32.c
+123
-6
windows/openvpn/src/openvpn/win32.h
windows/openvpn/src/openvpn/win32.h
+8
-0
No files found.
windows/openvpn/src/openvpn/console.c
View file @
8e0927f9
...
@@ -34,7 +34,7 @@
...
@@ -34,7 +34,7 @@
#include "buffer.h"
#include "buffer.h"
#include "misc.h"
#include "misc.h"
#if
def WIN32
#if
defined (WIN32) && !defined (CYGWIN)
#include "win32.h"
#include "win32.h"
...
@@ -201,7 +201,7 @@ get_console_input (const char *prompt, const bool echo, char *input, const int c
...
@@ -201,7 +201,7 @@ get_console_input (const char *prompt, const bool echo, char *input, const int c
return
get_console_input_systemd
(
prompt
,
echo
,
input
,
capacity
);
return
get_console_input_systemd
(
prompt
,
echo
,
input
,
capacity
);
#endif
#endif
#if defined(WIN32)
#if defined(WIN32)
&& !defined(CYGWIN)
return
get_console_input_win32
(
prompt
,
echo
,
input
,
capacity
);
return
get_console_input_win32
(
prompt
,
echo
,
input
,
capacity
);
#elif defined(HAVE_GETPASS)
#elif defined(HAVE_GETPASS)
if
(
echo
)
if
(
echo
)
...
...
windows/openvpn/src/openvpn/error.c
View file @
8e0927f9
...
@@ -470,7 +470,7 @@ get_orig_stderr (void)
...
@@ -470,7 +470,7 @@ get_orig_stderr (void)
void
void
redirect_stdout_stderr
(
const
char
*
file
,
bool
append
)
redirect_stdout_stderr
(
const
char
*
file
,
bool
append
)
{
{
#if defined(WIN32)
#if defined(WIN32)
&& !defined(CYGWIN)
if
(
!
std_redir
)
if
(
!
std_redir
)
{
{
struct
gc_arena
gc
=
gc_new
();
struct
gc_arena
gc
=
gc_new
();
...
...
windows/openvpn/src/openvpn/forward.c
View file @
8e0927f9
...
@@ -571,7 +571,7 @@ check_coarse_timers_dowork (struct context *c)
...
@@ -571,7 +571,7 @@ check_coarse_timers_dowork (struct context *c)
c
->
c2
.
timeval
.
tv_sec
=
BIG_TIMEOUT
;
c
->
c2
.
timeval
.
tv_sec
=
BIG_TIMEOUT
;
c
->
c2
.
timeval
.
tv_usec
=
0
;
c
->
c2
.
timeval
.
tv_usec
=
0
;
process_coarse_timers
(
c
);
process_coarse_timers
(
c
);
c
->
c2
.
coarse_timer_wakeup
=
now
+
c
->
c2
.
timeval
.
tv_sec
;
c
->
c2
.
coarse_timer_wakeup
=
now
+
c
->
c2
.
timeval
.
tv_sec
;
dmsg
(
D_INTERVAL
,
"TIMER: coarse timer wakeup %d seconds"
,
(
int
)
c
->
c2
.
timeval
.
tv_sec
);
dmsg
(
D_INTERVAL
,
"TIMER: coarse timer wakeup %d seconds"
,
(
int
)
c
->
c2
.
timeval
.
tv_sec
);
...
@@ -762,7 +762,7 @@ process_incoming_link (struct context *c)
...
@@ -762,7 +762,7 @@ process_incoming_link (struct context *c)
}
}
else
else
c
->
c2
.
original_recv_size
=
0
;
c
->
c2
.
original_recv_size
=
0
;
#ifdef ENABLE_DEBUG
#ifdef ENABLE_DEBUG
/* take action to corrupt packet if we are in gremlin test mode */
/* take action to corrupt packet if we are in gremlin test mode */
if
(
c
->
options
.
gremlin
)
{
if
(
c
->
options
.
gremlin
)
{
...
@@ -949,7 +949,7 @@ read_incoming_tun (struct context *c)
...
@@ -949,7 +949,7 @@ read_incoming_tun (struct context *c)
register_signal
(
c
,
SIGTERM
,
"tun-stop"
);
register_signal
(
c
,
SIGTERM
,
"tun-stop"
);
msg
(
M_INFO
,
"TUN/TAP interface has been stopped, exiting"
);
msg
(
M_INFO
,
"TUN/TAP interface has been stopped, exiting"
);
perf_pop
();
perf_pop
();
return
;
return
;
}
}
/* Check the status return from read() */
/* Check the status return from read() */
...
@@ -1040,7 +1040,7 @@ process_ip_header (struct context *c, unsigned int flags, struct buffer *buf)
...
@@ -1040,7 +1040,7 @@ process_ip_header (struct context *c, unsigned int flags, struct buffer *buf)
if
(
flags
&
PIPV4_PASSTOS
)
if
(
flags
&
PIPV4_PASSTOS
)
link_socket_extract_tos
(
c
->
c2
.
link_socket
,
&
ipbuf
);
link_socket_extract_tos
(
c
->
c2
.
link_socket
,
&
ipbuf
);
#endif
#endif
/* possibly alter the TCP MSS */
/* possibly alter the TCP MSS */
if
(
flags
&
PIP_MSSFIX
)
if
(
flags
&
PIP_MSSFIX
)
mss_fixup_ipv4
(
&
ipbuf
,
MTU_TO_MSS
(
TUN_MTU_SIZE_DYNAMIC
(
&
c
->
c2
.
frame
)));
mss_fixup_ipv4
(
&
ipbuf
,
MTU_TO_MSS
(
TUN_MTU_SIZE_DYNAMIC
(
&
c
->
c2
.
frame
)));
...
@@ -1254,6 +1254,10 @@ process_outgoing_tun (struct context *c)
...
@@ -1254,6 +1254,10 @@ process_outgoing_tun (struct context *c)
size
=
write_tun
(
c
->
c1
.
tuntap
,
BPTR
(
&
c
->
c2
.
to_tun
),
BLEN
(
&
c
->
c2
.
to_tun
));
size
=
write_tun
(
c
->
c1
.
tuntap
,
BPTR
(
&
c
->
c2
.
to_tun
),
BLEN
(
&
c
->
c2
.
to_tun
));
#endif
#endif
#if defined(CYGWIN)
/* do_multicast_ipv6_packets(c, &c->c2.to_tun); */
#endif
if
(
size
>
0
)
if
(
size
>
0
)
c
->
c2
.
tun_write_bytes
+=
size
;
c
->
c2
.
tun_write_bytes
+=
size
;
check_status
(
size
,
"write to TUN/TAP"
,
NULL
,
c
->
c1
.
tuntap
);
check_status
(
size
,
"write to TUN/TAP"
,
NULL
,
c
->
c1
.
tuntap
);
...
@@ -1395,7 +1399,7 @@ io_wait_dowork (struct context *c, const unsigned int flags)
...
@@ -1395,7 +1399,7 @@ io_wait_dowork (struct context *c, const unsigned int flags)
/* set traffic shaping delay in microseconds */
/* set traffic shaping delay in microseconds */
if
(
c
->
options
.
shaper
)
if
(
c
->
options
.
shaper
)
delay
=
max_int
(
delay
,
shaper_delay
(
&
c
->
c2
.
shaper
));
delay
=
max_int
(
delay
,
shaper_delay
(
&
c
->
c2
.
shaper
));
if
(
delay
<
1000
)
if
(
delay
<
1000
)
{
{
socket
|=
EVENT_WRITE
;
socket
|=
EVENT_WRITE
;
...
@@ -1555,3 +1559,54 @@ process_io (struct context *c)
...
@@ -1555,3 +1559,54 @@ process_io (struct context *c)
process_incoming_tun
(
c
);
process_incoming_tun
(
c
);
}
}
}
}
#if defined(CYGWIN)
/*
* IPv6/ICMPv6 Multicast Packet:
*
* We'll filter all the ipmpv6 multicast packets, and rewrite to all
* the other netword devices. Openvpn writes these packets only to its
* own tun/tap device. So other netword devices in this node could
* receive the multicase message.
*
*/
static
void
do_multicast_ipv6_packets
(
struct
context
*
c
,
struct
buffer
*
buf
)
{
int
offset
;
TUNNEL_TYPE
tunnel_type
;
unsigned
char
*
p
=
buf
;
const
struct
openvpn_ipv6hdr
*
pip6
;
struct
buffer
newbuf
;
int
i
;
tunnel_type
=
TUNNEL_TYPE
(
c
->
c1
.
tuntap
);
if
(
!
is_ipv6
(
tunnel_type
,
buf
))
return
;
offset
=
tunnel_type
==
DEV_TYPE_TUN
?
0
:
sizeof
(
struct
openvpn_ethhdr
);
pip6
=
(
struct
openvpn_ipv6hdr
*
)
(
BPTR
(
buf
)
+
offset
);
/* do we have the full IPv6 packet?
* "payload_len" does not include IPv6 header (+40 bytes)
*/
if
(
BLEN
(
buf
)
!=
(
int
)
ntohs
(
pip6
->
payload_len
)
+
40
)
return
;
/* follow header chain until we reach final header, then check for TCP
*
* An IPv6 packet could, theoretically, have a chain of multiple headers
* before the final header (TCP, UDP, ...), so we'd need to walk that
* chain (see RFC 2460 and RFC 6564 for details).
*
* In practice, "most typically used" extention headers (AH, routing,
* fragment, mobility) are very unlikely to be seen inside an OpenVPN
* tun, so for now, we only handle the case of "single next header = TCP"
*/
if
(
pip6
->
nexthdr
!=
58
)
/* IP_PROTO_ICMPV6 */
return
;
/* Check it's multicast message */
}
#endif
/* CYGWIN */
windows/openvpn/src/openvpn/misc.c
View file @
8e0927f9
...
@@ -147,7 +147,7 @@ write_pid (const struct pid_state *state)
...
@@ -147,7 +147,7 @@ write_pid (const struct pid_state *state)
{
{
if
(
state
->
filename
&&
state
->
fp
)
if
(
state
->
filename
&&
state
->
fp
)
{
{
unsigned
int
pid
=
platform_getpid
();
unsigned
int
pid
=
platform_getpid
();
fprintf
(
state
->
fp
,
"%u
\n
"
,
pid
);
fprintf
(
state
->
fp
,
"%u
\n
"
,
pid
);
if
(
fclose
(
state
->
fp
))
if
(
fclose
(
state
->
fp
))
msg
(
M_ERR
,
"Close error on pid file %s"
,
state
->
filename
);
msg
(
M_ERR
,
"Close error on pid file %s"
,
state
->
filename
);
...
@@ -562,7 +562,7 @@ env_set_del_nolock (struct env_set *es, const char *str)
...
@@ -562,7 +562,7 @@ env_set_del_nolock (struct env_set *es, const char *str)
static
void
static
void
env_set_add_nolock
(
struct
env_set
*
es
,
const
char
*
str
)
env_set_add_nolock
(
struct
env_set
*
es
,
const
char
*
str
)
{
{
remove_env_item
(
str
,
es
->
gc
==
NULL
,
&
es
->
list
);
remove_env_item
(
str
,
es
->
gc
==
NULL
,
&
es
->
list
);
add_env_item
((
char
*
)
str
,
true
,
&
es
->
list
,
es
->
gc
);
add_env_item
((
char
*
)
str
,
true
,
&
es
->
list
,
es
->
gc
);
}
}
...
@@ -1036,7 +1036,11 @@ absolute_pathname (const char *pathname)
...
@@ -1036,7 +1036,11 @@ absolute_pathname (const char *pathname)
{
{
const
int
c
=
pathname
[
0
];
const
int
c
=
pathname
[
0
];
#ifdef WIN32
#ifdef WIN32
#if defined(CYGWIN)
return
c
==
'/'
||
(
isalpha
(
c
)
&&
pathname
[
1
]
==
':'
&&
pathname
[
2
]
==
'/'
);
#else
return
c
==
'\\'
||
(
isalpha
(
c
)
&&
pathname
[
1
]
==
':'
&&
pathname
[
2
]
==
'\\'
);
return
c
==
'\\'
||
(
isalpha
(
c
)
&&
pathname
[
1
]
==
':'
&&
pathname
[
2
]
==
'\\'
);
#endif
#else
#else
return
c
==
'/'
;
return
c
==
'/'
;
#endif
#endif
...
@@ -1100,14 +1104,14 @@ get_user_pass_cr (struct user_pass *up,
...
@@ -1100,14 +1104,14 @@ get_user_pass_cr (struct user_pass *up,
struct
buffer
user_prompt
=
alloc_buf_gc
(
128
,
&
gc
);
struct
buffer
user_prompt
=
alloc_buf_gc
(
128
,
&
gc
);
buf_printf
(
&
user_prompt
,
"NEED-OK|%s|%s:"
,
prefix
,
up
->
username
);
buf_printf
(
&
user_prompt
,
"NEED-OK|%s|%s:"
,
prefix
,
up
->
username
);
if
(
!
get_console_input
(
BSTR
(
&
user_prompt
),
true
,
up
->
password
,
USER_PASS_LEN
))
if
(
!
get_console_input
(
BSTR
(
&
user_prompt
),
true
,
up
->
password
,
USER_PASS_LEN
))
msg
(
M_FATAL
,
"ERROR: could not read %s ok-confirmation from stdin"
,
prefix
);
msg
(
M_FATAL
,
"ERROR: could not read %s ok-confirmation from stdin"
,
prefix
);
if
(
!
strlen
(
up
->
password
))
if
(
!
strlen
(
up
->
password
))
strcpy
(
up
->
password
,
"ok"
);
strcpy
(
up
->
password
,
"ok"
);
}
}
/*
/*
* Get username/password from standard input?
* Get username/password from standard input?
*/
*/
...
@@ -1183,7 +1187,7 @@ get_user_pass_cr (struct user_pass *up,
...
@@ -1183,7 +1187,7 @@ get_user_pass_cr (struct user_pass *up,
* Get username/password from a file.
* Get username/password from a file.
*/
*/
FILE
*
fp
;
FILE
*
fp
;
#ifndef ENABLE_PASSWORD_SAVE
#ifndef ENABLE_PASSWORD_SAVE
/*
/*
* Unless ENABLE_PASSWORD_SAVE is defined, don't allow sensitive passwords
* Unless ENABLE_PASSWORD_SAVE is defined, don't allow sensitive passwords
...
@@ -1214,12 +1218,12 @@ get_user_pass_cr (struct user_pass *up,
...
@@ -1214,12 +1218,12 @@ get_user_pass_cr (struct user_pass *up,
prefix
,
prefix
,
auth_file
);
auth_file
);
}
}
fclose
(
fp
);
fclose
(
fp
);
chomp
(
up
->
username
);
chomp
(
up
->
username
);
chomp
(
up
->
password
);
chomp
(
up
->
password
);
if
(
!
(
flags
&
GET_USER_PASS_PASSWORD_ONLY
)
&&
strlen
(
up
->
username
)
==
0
)
if
(
!
(
flags
&
GET_USER_PASS_PASSWORD_ONLY
)
&&
strlen
(
up
->
username
)
==
0
)
msg
(
M_FATAL
,
"ERROR: username from %s authfile '%s' is empty"
,
prefix
,
auth_file
);
msg
(
M_FATAL
,
"ERROR: username from %s authfile '%s' is empty"
,
prefix
,
auth_file
);
}
}
...
@@ -1277,7 +1281,7 @@ get_auth_challenge (const char *auth_challenge, struct gc_arena *gc)
...
@@ -1277,7 +1281,7 @@ get_auth_challenge (const char *auth_challenge, struct gc_arena *gc)
else
if
(
c
==
'R'
)
else
if
(
c
==
'R'
)
ac
->
flags
|=
CR_RESPONSE
;
ac
->
flags
|=
CR_RESPONSE
;
}
}
/* parse state ID */
/* parse state ID */
if
(
!
buf_parse
(
&
b
,
':'
,
work
,
len
))
if
(
!
buf_parse
(
&
b
,
':'
,
work
,
len
))
return
NULL
;
return
NULL
;
...
@@ -1491,7 +1495,7 @@ make_inline_array (const char *str, struct gc_arena *gc)
...
@@ -1491,7 +1495,7 @@ make_inline_array (const char *str, struct gc_arena *gc)
ASSERT
(
i
<
len
);
ASSERT
(
i
<
len
);
ret
[
i
]
=
string_alloc
(
skip_leading_whitespace
(
line
),
gc
);
ret
[
i
]
=
string_alloc
(
skip_leading_whitespace
(
line
),
gc
);
++
i
;
++
i
;
}
}
ASSERT
(
i
<=
len
);
ASSERT
(
i
<=
len
);
ret
[
i
]
=
NULL
;
ret
[
i
]
=
NULL
;
return
(
const
char
**
)
ret
;
return
(
const
char
**
)
ret
;
...
@@ -1826,7 +1830,7 @@ argv_printf_arglist (struct argv *a, const char *format, const unsigned int flag
...
@@ -1826,7 +1830,7 @@ argv_printf_arglist (struct argv *a, const char *format, const unsigned int flag
argv_reset
(
a
);
argv_reset
(
a
);
argv_extend
(
a
,
1
);
/* ensure trailing NULL */
argv_extend
(
a
,
1
);
/* ensure trailing NULL */
while
((
term
=
argv_term
(
&
f
))
!=
NULL
)
while
((
term
=
argv_term
(
&
f
))
!=
NULL
)
{
{
if
(
term
[
0
]
==
'%'
)
if
(
term
[
0
]
==
'%'
)
{
{
...
@@ -1950,7 +1954,7 @@ argv_test (void)
...
@@ -1950,7 +1954,7 @@ argv_test (void)
msg
(
M_INFO
,
"ARGV-S: %s"
,
argv_system_str
(
&
a
));
msg
(
M_INFO
,
"ARGV-S: %s"
,
argv_system_str
(
&
a
));
/*openvpn_execve_check (&a, NULL, 0, "command failed");*/
/*openvpn_execve_check (&a, NULL, 0, "command failed");*/
argv_printf
(
&
a
,
"%sc %s %s"
,
"c:
\\\\
src
\\\\
test files
\\\\
batargs.bat"
,
"foo"
,
"bar"
);
argv_printf
(
&
a
,
"%sc %s %s"
,
"c:
\\\\
src
\\\\
test files
\\\\
batargs.bat"
,
"foo"
,
"bar"
);
argv_msg_prefix
(
M_INFO
,
&
a
,
"ARGV"
);
argv_msg_prefix
(
M_INFO
,
&
a
,
"ARGV"
);
msg
(
M_INFO
,
"ARGV-S: %s"
,
argv_system_str
(
&
a
));
msg
(
M_INFO
,
"ARGV-S: %s"
,
argv_system_str
(
&
a
));
/*openvpn_execve_check (&a, NULL, 0, "command failed");*/
/*openvpn_execve_check (&a, NULL, 0, "command failed");*/
...
@@ -2001,7 +2005,7 @@ argv_test (void)
...
@@ -2001,7 +2005,7 @@ argv_test (void)
const char *f = line;
const char *f = line;
int i = 0;
int i = 0;
while ((term = argv_term (&f)) != NULL)
while ((term = argv_term (&f)) != NULL)
{
{
printf ("[%d] '%s'\n", i, term);
printf ("[%d] '%s'\n", i, term);
++i;
++i;
...
...
windows/openvpn/src/openvpn/openvpn.c
View file @
8e0927f9
...
@@ -49,7 +49,6 @@ process_signal_p2p (struct context *c)
...
@@ -49,7 +49,6 @@ process_signal_p2p (struct context *c)
}
}
/**************************************************************************/
/**************************************************************************/
/**
/**
* Main event loop for OpenVPN in client mode, where only one VPN tunnel
* Main event loop for OpenVPN in client mode, where only one VPN tunnel
...
@@ -138,7 +137,7 @@ openvpn_main (int argc, char *argv[])
...
@@ -138,7 +137,7 @@ openvpn_main (int argc, char *argv[])
return
1
;
return
1
;
#endif
#endif
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
SetConsoleOutputCP
(
CP_UTF8
);
SetConsoleOutputCP
(
CP_UTF8
);
#endif
#endif
...
@@ -291,7 +290,8 @@ openvpn_main (int argc, char *argv[])
...
@@ -291,7 +290,8 @@ openvpn_main (int argc, char *argv[])
return
0
;
/* NOTREACHED */
return
0
;
/* NOTREACHED */
}
}
#ifdef WIN32
#if defined(WIN32) && !defined (CYGWIN)
int
int
wmain
(
int
argc
,
wchar_t
*
wargv
[])
{
wmain
(
int
argc
,
wchar_t
*
wargv
[])
{
char
**
argv
;
char
**
argv
;
...
...
windows/openvpn/src/openvpn/options.c
View file @
8e0927f9
...
@@ -739,7 +739,7 @@ static const char usage_message[] =
...
@@ -739,7 +739,7 @@ static const char usage_message[] =
#ifdef ENABLE_PKCS11
#ifdef ENABLE_PKCS11
"
\n
"
"
\n
"
"PKCS#11 standalone options:
\n
"
"PKCS#11 standalone options:
\n
"
"--show-pkcs11-ids provider [cert_private] : Show PKCS#11 available ids.
\n
"
"--show-pkcs11-ids provider [cert_private] : Show PKCS#11 available ids.
\n
"
" --verb option can be added *BEFORE* this.
\n
"
" --verb option can be added *BEFORE* this.
\n
"
#endif
/* ENABLE_PKCS11 */
#endif
/* ENABLE_PKCS11 */
"
\n
"
"
\n
"
...
@@ -859,7 +859,7 @@ init_options (struct options *o, const bool init_gc)
...
@@ -859,7 +859,7 @@ init_options (struct options *o, const bool init_gc)
/* tmp is only used in P2MP server context */
/* tmp is only used in P2MP server context */
#if P2MP_SERVER
#if P2MP_SERVER
/* Set default --tmp-dir */
/* Set default --tmp-dir */
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
/* On Windows, find temp dir via enviroment variables */
/* On Windows, find temp dir via enviroment variables */
o
->
tmp_dir
=
win_get_tempdir
();
o
->
tmp_dir
=
win_get_tempdir
();
#else
#else
...
@@ -1404,7 +1404,7 @@ show_settings (const struct options *o)
...
@@ -1404,7 +1404,7 @@ show_settings (const struct options *o)
msg
(
D_SHOW_PARMS
,
"Current Parameter Settings:"
);
msg
(
D_SHOW_PARMS
,
"Current Parameter Settings:"
);
SHOW_STR
(
config
);
SHOW_STR
(
config
);
SHOW_INT
(
mode
);
SHOW_INT
(
mode
);
#ifdef ENABLE_FEATURE_TUN_PERSIST
#ifdef ENABLE_FEATURE_TUN_PERSIST
...
@@ -1526,7 +1526,7 @@ show_settings (const struct options *o)
...
@@ -1526,7 +1526,7 @@ show_settings (const struct options *o)
SHOW_BOOL
(
allow_pull_fqdn
);
SHOW_BOOL
(
allow_pull_fqdn
);
if
(
o
->
routes
)
if
(
o
->
routes
)
print_route_options
(
o
->
routes
,
D_SHOW_PARMS
);
print_route_options
(
o
->
routes
,
D_SHOW_PARMS
);
#ifdef ENABLE_CLIENT_NAT
#ifdef ENABLE_CLIENT_NAT
if
(
o
->
client_nat
)
if
(
o
->
client_nat
)
print_client_nat_list
(
o
->
client_nat
,
D_SHOW_PARMS
);
print_client_nat_list
(
o
->
client_nat
,
D_SHOW_PARMS
);
...
@@ -1859,7 +1859,7 @@ options_postprocess_verify_ce (const struct options *options, const struct conne
...
@@ -1859,7 +1859,7 @@ options_postprocess_verify_ce (const struct options *options, const struct conne
if
(
options
->
lladdr
&&
dev
!=
DEV_TYPE_TAP
)
if
(
options
->
lladdr
&&
dev
!=
DEV_TYPE_TAP
)
msg
(
M_USAGE
,
"--lladdr can only be used in --dev tap mode"
);
msg
(
M_USAGE
,
"--lladdr can only be used in --dev tap mode"
);
/*
/*
* Sanity check on TCP mode options
* Sanity check on TCP mode options
*/
*/
...
@@ -1898,7 +1898,7 @@ options_postprocess_verify_ce (const struct options *options, const struct conne
...
@@ -1898,7 +1898,7 @@ options_postprocess_verify_ce (const struct options *options, const struct conne
&&
string_defined_equal
(
ce
->
local
,
ce
->
remote
)
&&
string_defined_equal
(
ce
->
local
,
ce
->
remote
)
&&
ce
->
local_port
==
ce
->
remote_port
)
&&
ce
->
local_port
==
ce
->
remote_port
)
msg
(
M_USAGE
,
"--remote and --local addresses are the same"
);
msg
(
M_USAGE
,
"--remote and --local addresses are the same"
);
if
(
string_defined_equal
(
ce
->
remote
,
options
->
ifconfig_local
)
if
(
string_defined_equal
(
ce
->
remote
,
options
->
ifconfig_local
)
||
string_defined_equal
(
ce
->
remote
,
options
->
ifconfig_remote_netmask
))
||
string_defined_equal
(
ce
->
remote
,
options
->
ifconfig_remote_netmask
))
msg
(
M_USAGE
,
"--local and --remote addresses must be distinct from --ifconfig addresses"
);
msg
(
M_USAGE
,
"--local and --remote addresses must be distinct from --ifconfig addresses"
);
...
@@ -1969,7 +1969,7 @@ options_postprocess_verify_ce (const struct options *options, const struct conne
...
@@ -1969,7 +1969,7 @@ options_postprocess_verify_ce (const struct options *options, const struct conne
msg
(
M_USAGE
,
"--explicit-exit-notify can only be used with --proto udp"
);
msg
(
M_USAGE
,
"--explicit-exit-notify can only be used with --proto udp"
);
#endif
#endif
if
(
!
ce
->
remote
&&
(
ce
->
proto
==
PROTO_TCPv4_CLIENT
if
(
!
ce
->
remote
&&
(
ce
->
proto
==
PROTO_TCPv4_CLIENT
||
ce
->
proto
==
PROTO_TCPv6_CLIENT
))
||
ce
->
proto
==
PROTO_TCPv6_CLIENT
))
msg
(
M_USAGE
,
"--remote MUST be used in TCP Client mode"
);
msg
(
M_USAGE
,
"--remote MUST be used in TCP Client mode"
);
...
@@ -2008,7 +2008,7 @@ options_postprocess_verify_ce (const struct options *options, const struct conne
...
@@ -2008,7 +2008,7 @@ options_postprocess_verify_ce (const struct options *options, const struct conne
msg
(
M_USAGE
,
"--mode server currently only supports "
msg
(
M_USAGE
,
"--mode server currently only supports "
"--proto udp or --proto tcp-server or proto tcp6-server"
);
"--proto udp or --proto tcp-server or proto tcp6-server"
);
#if PORT_SHARE
#if PORT_SHARE
if
((
options
->
port_share_host
||
options
->
port_share_port
)
&&
if
((
options
->
port_share_host
||
options
->
port_share_port
)
&&
(
ce
->
proto
!=
PROTO_TCPv4_SERVER
&&
ce
->
proto
!=
PROTO_TCPv6_SERVER
))
(
ce
->
proto
!=
PROTO_TCPv4_SERVER
&&
ce
->
proto
!=
PROTO_TCPv6_SERVER
))
msg
(
M_USAGE
,
"--port-share only works in TCP server mode "
msg
(
M_USAGE
,
"--port-share only works in TCP server mode "
"(--proto tcp-server or tcp6-server)"
);
"(--proto tcp-server or tcp6-server)"
);
...
@@ -2390,7 +2390,7 @@ options_postprocess_mutate_ce (struct options *o, struct connection_entry *ce)
...
@@ -2390,7 +2390,7 @@ options_postprocess_mutate_ce (struct options *o, struct connection_entry *ce)
o
->
ce
.
mssfix
=
ce
->
fragment
;
o
->
ce
.
mssfix
=
ce
->
fragment
;
#else
#else
msg
(
M_USAGE
,
"--mssfix must specify a parameter"
);
msg
(
M_USAGE
,
"--mssfix must specify a parameter"
);
#endif
#endif
}
}
/*
/*
...
@@ -2452,7 +2452,7 @@ options_postprocess_mutate_invariant (struct options *options)
...
@@ -2452,7 +2452,7 @@ options_postprocess_mutate_invariant (struct options *options)
*/
*/
options
->
tuntap_options
.
tap_sleep
=
10
;
options
->
tuntap_options
.
tap_sleep
=
10
;
if
(
options
->
route_delay_defined
&&
options
->
route_delay
)
if
(
options
->
route_delay_defined
&&
options
->
route_delay
)
options
->
tuntap_options
.
tap_sleep
=
options
->
route_delay
;
options
->
tuntap_options
.
tap_sleep
=
options
->
route_delay
;
options
->
route_delay_defined
=
false
;
options
->
route_delay_defined
=
false
;
#endif
#endif
}
}
...
@@ -2529,7 +2529,7 @@ options_postprocess_mutate (struct options *o)
...
@@ -2529,7 +2529,7 @@ options_postprocess_mutate (struct options *o)
#endif
#endif
}
}
else
else
options_postprocess_mutate_ce
(
o
,
&
o
->
ce
);
options_postprocess_mutate_ce
(
o
,
&
o
->
ce
);
#if P2MP
#if P2MP
/*
/*
...
@@ -3085,7 +3085,7 @@ options_warning_extract_parm1 (const char *option_string,
...
@@ -3085,7 +3085,7 @@ options_warning_extract_parm1 (const char *option_string,
struct
buffer
b
=
string_alloc_buf
(
option_string
,
&
gc
);
struct
buffer
b
=
string_alloc_buf
(
option_string
,
&
gc
);
char
*
p
=
gc_malloc
(
OPTION_PARM_SIZE
,
false
,
&
gc
);
char
*
p
=
gc_malloc
(
OPTION_PARM_SIZE
,
false
,
&
gc
);
const
char
*
ret
;
const
char
*
ret
;
buf_parse
(
&
b
,
' '
,
p
,
OPTION_PARM_SIZE
);
buf_parse
(
&
b
,
' '
,
p
,
OPTION_PARM_SIZE
);
ret
=
string_alloc
(
p
,
gc_ret
);
ret
=
string_alloc
(
p
,
gc_ret
);
gc_free
(
&
gc
);
gc_free
(
&
gc
);
...
@@ -3122,7 +3122,7 @@ options_warning_safe_scan2 (const int msglevel,
...
@@ -3122,7 +3122,7 @@ options_warning_safe_scan2 (const int msglevel,
if
(
strlen
(
p2
))
if
(
strlen
(
p2
))
{
{
const
char
*
p2_prefix
=
options_warning_extract_parm1
(
p2
,
&
gc
);
const
char
*
p2_prefix
=
options_warning_extract_parm1
(
p2
,
&
gc
);
if
(
!
strcmp
(
p1
,
p2
))
if
(
!
strcmp
(
p1
,
p2
))
goto
done
;
goto
done
;
if
(
!
strcmp
(
p1_prefix
,
p2_prefix
))
if
(
!
strcmp
(
p1_prefix
,
p2_prefix
))
...
@@ -3133,17 +3133,17 @@ options_warning_safe_scan2 (const int msglevel,
...
@@ -3133,17 +3133,17 @@ options_warning_safe_scan2 (const int msglevel,
b1_name
,
b1_name
,
safe_print
(
p1
,
&
gc
),
safe_print
(
p1
,
&
gc
),
b2_name
,
b2_name
,
safe_print
(
p2
,
&
gc
));
safe_print
(
p2
,
&
gc
));
goto
done
;
goto
done
;
}
}
}
}
}
}
msg
(
msglevel
,
"WARNING: '%s' is present in %s config but missing in %s config, %s='%s'"
,
msg
(
msglevel
,
"WARNING: '%s' is present in %s config but missing in %s config, %s='%s'"
,
safe_print
(
p1_prefix
,
&
gc
),
safe_print
(
p1_prefix
,
&
gc
),
b1_name
,
b1_name
,
b2_name
,
b2_name
,
b1_name
,
b1_name
,
safe_print
(
p1
,
&
gc
));
safe_print
(
p1
,
&
gc
));
done:
done:
...
@@ -3402,7 +3402,7 @@ usage (void)
...
@@ -3402,7 +3402,7 @@ usage (void)
fflush
(
fp
);
fflush
(
fp
);
#endif
/* ENABLE_SMALL */
#endif
/* ENABLE_SMALL */
openvpn_exit
(
OPENVPN_EXIT_STATUS_USAGE
);
/* exit point */
openvpn_exit
(
OPENVPN_EXIT_STATUS_USAGE
);
/* exit point */
}
}
...
@@ -4789,7 +4789,7 @@ add_option (struct options *options,
...
@@ -4789,7 +4789,7 @@ add_option (struct options *options,
if
(
streq
(
p
[
j
],
"TCP_NODELAY"
))
if
(
streq
(
p
[
j
],
"TCP_NODELAY"
))
options
->
sockflags
|=
SF_TCP_NODELAY
;
options
->
sockflags
|=
SF_TCP_NODELAY
;
else
else
msg
(
msglevel
,
"unknown socket flag: %s"
,
p
[
j
]);
msg
(
msglevel
,
"unknown socket flag: %s"
,
p
[
j
]);
}
}
}
}
else
if
(
streq
(
p
[
0
],
"txqueuelen"
)
&&
p
[
1
])
else
if
(
streq
(
p
[
0
],
"txqueuelen"
)
&&
p
[
1
])
...
@@ -4931,9 +4931,9 @@ add_option (struct options *options,
...
@@ -4931,9 +4931,9 @@ add_option (struct options *options,
msg
(
msglevel
,
"Bad http-proxy port number: %s"
,
p
[
2
]);
msg
(
msglevel
,
"Bad http-proxy port number: %s"
,
p
[
2
]);
goto
err
;
goto
err
;
}
}
ho
=
init_http_proxy_options_once
(
&
options
->
ce
.
http_proxy_options
,
&
options
->
gc
);
ho
=
init_http_proxy_options_once
(
&
options
->
ce
.
http_proxy_options
,
&
options
->
gc
);
ho
->
server
=
p
[
1
];
ho
->
server
=
p
[
1
];
ho
->
port
=
port
;
ho
->
port
=
port
;
}
}
...
@@ -5763,7 +5763,7 @@ add_option (struct options *options,
...
@@ -5763,7 +5763,7 @@ add_option (struct options *options,
else
else
{
{
if
(
!
options
->
ifconfig_ipv6_local
||
if
(
!
options
->
ifconfig_ipv6_local
||
!
get_ipv6_addr
(
options
->
ifconfig_ipv6_local
,
&
remote
,
!
get_ipv6_addr
(
options
->
ifconfig_ipv6_local
,
&
remote
,
NULL
,
NULL
,
msglevel
)
)
NULL
,
NULL
,
msglevel
)
)
{
{
msg
(
msglevel
,
"second argument to --ifconfig-ipv6-push missing and no global --ifconfig-ipv6 address set"
);
msg
(
msglevel
,
"second argument to --ifconfig-ipv6-push missing and no global --ifconfig-ipv6 address set"
);
...
@@ -5930,7 +5930,7 @@ add_option (struct options *options,
...
@@ -5930,7 +5930,7 @@ add_option (struct options *options,
}
}
}
}
to
->
ip_win32_type
=
index
;
to
->
ip_win32_type
=
index
;
to
->
ip_win32_defined
=
true
;
to
->
ip_win32_defined
=
true
;
}
}
else
if
(
streq
(
p
[
0
],
"dhcp-option"
)
&&
p
[
1
])
else
if
(
streq
(
p
[
0
],
"dhcp-option"
)
&&
p
[
1
])
{
{
...
@@ -6331,7 +6331,7 @@ add_option (struct options *options,
...
@@ -6331,7 +6331,7 @@ add_option (struct options *options,
}
}
else
else
options
->
engine
=
"auto"
;
options
->
engine
=
"auto"
;
}
}
#endif
/* ENABLE_CRYPTO_POLARSSL */
#endif
/* ENABLE_CRYPTO_POLARSSL */
#ifdef HAVE_EVP_CIPHER_CTX_SET_KEY_LENGTH
#ifdef HAVE_EVP_CIPHER_CTX_SET_KEY_LENGTH
else
if
(
streq
(
p
[
0
],
"keysize"
)
&&
p
[
1
])
else
if
(
streq
(
p
[
0
],
"keysize"
)
&&
p
[
1
])
...
@@ -6454,7 +6454,7 @@ add_option (struct options *options,
...
@@ -6454,7 +6454,7 @@ add_option (struct options *options,
options
->
key_pass_file
=
p
[
1
];
options
->
key_pass_file
=
p
[
1
];
}
}
else
else
options
->
key_pass_file
=
"stdin"
;
options
->
key_pass_file
=
"stdin"
;
}
}
else
if
(
streq
(
p
[
0
],
"auth-nocache"
))
else
if
(
streq
(
p
[
0
],
"auth-nocache"
))
{
{
...
@@ -6664,7 +6664,7 @@ add_option (struct options *options,
...
@@ -6664,7 +6664,7 @@ add_option (struct options *options,
else
if
(
streq
(
p
[
0
],
"pkcs11-providers"
)
&&
p
[
1
])
else
if
(
streq
(
p
[
0
],
"pkcs11-providers"
)
&&
p
[
1
])
{
{
int
j
;
int
j
;
VERIFY_PERMISSION
(
OPT_P_GENERAL
);
VERIFY_PERMISSION
(
OPT_P_GENERAL
);
for
(
j
=
1
;
j
<
MAX_PARMS
&&
p
[
j
]
!=
NULL
;
++
j
)
for
(
j
=
1
;
j
<
MAX_PARMS
&&
p
[
j
]
!=
NULL
;
++
j
)
...
@@ -6682,7 +6682,7 @@ add_option (struct options *options,
...
@@ -6682,7 +6682,7 @@ add_option (struct options *options,
else
if
(
streq
(
p
[
0
],
"pkcs11-private-mode"
)
&&
p
[
1
])
else
if
(
streq
(
p
[
0
],
"pkcs11-private-mode"
)
&&
p
[
1
])
{
{
int
j
;
int
j
;
VERIFY_PERMISSION
(
OPT_P_GENERAL
);
VERIFY_PERMISSION
(
OPT_P_GENERAL
);
for
(
j
=
1
;
j
<
MAX_PARMS
&&
p
[
j
]
!=
NULL
;
++
j
)
for
(
j
=
1
;
j
<
MAX_PARMS
&&
p
[
j
]
!=
NULL
;
++
j
)
...
...
windows/openvpn/src/openvpn/platform.c
View file @
8e0927f9
...
@@ -158,7 +158,7 @@ platform_nice (int niceval)
...
@@ -158,7 +158,7 @@ platform_nice (int niceval)
unsigned
int
unsigned
int
platform_getpid
()
platform_getpid
()
{
{
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
return
(
unsigned
int
)
GetCurrentProcessId
();
return
(
unsigned
int
)
GetCurrentProcessId
();
#else
#else
#ifdef HAVE_GETPID
#ifdef HAVE_GETPID
...
@@ -190,7 +190,7 @@ int
...
@@ -190,7 +190,7 @@ int
platform_chdir
(
const
char
*
dir
)
platform_chdir
(
const
char
*
dir
)
{
{
#ifdef HAVE_CHDIR
#ifdef HAVE_CHDIR
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
int
res
;
int
res
;
struct
gc_arena
gc
=
gc_new
();
struct
gc_arena
gc
=
gc_new
();
res
=
_wchdir
(
wide_string
(
dir
,
&
gc
));
res
=
_wchdir
(
wide_string
(
dir
,
&
gc
));
...
@@ -210,7 +210,7 @@ platform_chdir (const char* dir)
...
@@ -210,7 +210,7 @@ platform_chdir (const char* dir)
bool
bool
platform_system_ok
(
int
stat
)
platform_system_ok
(
int
stat
)
{
{
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
return
stat
==
0
;
return
stat
==
0
;
#else
#else
return
stat
!=
-
1
&&
WIFEXITED
(
stat
)
&&
WEXITSTATUS
(
stat
)
==
0
;
return
stat
!=
-
1
&&
WIFEXITED
(
stat
)
&&
WEXITSTATUS
(
stat
)
==
0
;
...
@@ -220,7 +220,7 @@ platform_system_ok (int stat)
...
@@ -220,7 +220,7 @@ platform_system_ok (int stat)
int
int
platform_access
(
const
char
*
path
,
int
mode
)
platform_access
(
const
char
*
path
,
int
mode
)
{
{
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
struct
gc_arena
gc
=
gc_new
();
struct
gc_arena
gc
=
gc_new
();
int
ret
=
_waccess
(
wide_string
(
path
,
&
gc
),
mode
&
~
X_OK
);
int
ret
=
_waccess
(
wide_string
(
path
,
&
gc
),
mode
&
~
X_OK
);
gc_free
(
&
gc
);
gc_free
(
&
gc
);
...
@@ -263,7 +263,7 @@ platform_sleep_until_signal (void)
...
@@ -263,7 +263,7 @@ platform_sleep_until_signal (void)
bool
bool
platform_unlink
(
const
char
*
filename
)
platform_unlink
(
const
char
*
filename
)
{
{
#if defined(WIN32)
#if defined(WIN32)
& !defined(CYGWIN)
struct
gc_arena
gc
=
gc_new
();
struct
gc_arena
gc
=
gc_new
();
BOOL
ret
=
DeleteFileW
(
wide_string
(
filename
,
&
gc
));
BOOL
ret
=
DeleteFileW
(
wide_string
(
filename
,
&
gc
));
gc_free
(
&
gc
);
gc_free
(
&
gc
);
...
@@ -278,7 +278,7 @@ platform_unlink (const char *filename)
...
@@ -278,7 +278,7 @@ platform_unlink (const char *filename)
int
platform_putenv
(
char
*
string
)
int
platform_putenv
(
char
*
string
)
{
{
int
status
;
int
status
;
#if defined(WIN32)
#if defined(WIN32)
&& !defined(CYGWIN)
struct
gc_arena
gc
=
gc_new
();
struct
gc_arena
gc
=
gc_new
();
char
*
s
=
string_alloc
(
string
,
&
gc
);
char
*
s
=
string_alloc
(
string
,
&
gc
);
char
*
value
=
strchr
(
s
,
'='
);
char
*
value
=
strchr
(
s
,
'='
);
...
@@ -306,7 +306,7 @@ int platform_putenv(char *string)
...
@@ -306,7 +306,7 @@ int platform_putenv(char *string)
FILE
*
FILE
*
platform_fopen
(
const
char
*
path
,
const
char
*
mode
)
platform_fopen
(
const
char
*
path
,
const
char
*
mode
)
{
{
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
struct
gc_arena
gc
=
gc_new
();
struct
gc_arena
gc
=
gc_new
();
FILE
*
f
=
_wfopen
(
wide_string
(
path
,
&
gc
),
wide_string
(
mode
,
&
gc
));
FILE
*
f
=
_wfopen
(
wide_string
(
path
,
&
gc
),
wide_string
(
mode
,
&
gc
));
gc_free
(
&
gc
);
gc_free
(
&
gc
);
...
@@ -319,7 +319,7 @@ platform_fopen (const char *path, const char *mode)
...
@@ -319,7 +319,7 @@ platform_fopen (const char *path, const char *mode)
int
int
platform_open
(
const
char
*
path
,
int
flags
,
int
mode
)
platform_open
(
const
char
*
path
,
int
flags
,
int
mode
)
{
{
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
struct
gc_arena
gc
=
gc_new
();
struct
gc_arena
gc
=
gc_new
();
int
fd
=
_wopen
(
wide_string
(
path
,
&
gc
),
flags
,
mode
);
int
fd
=
_wopen
(
wide_string
(
path
,
&
gc
),
flags
,
mode
);
gc_free
(
&
gc
);
gc_free
(
&
gc
);
...
@@ -332,7 +332,7 @@ platform_open (const char *path, int flags, int mode)
...
@@ -332,7 +332,7 @@ platform_open (const char *path, int flags, int mode)
int
int
platform_stat
(
const
char
*
path
,
platform_stat_t
*
buf
)
platform_stat
(
const
char
*
path
,
platform_stat_t
*
buf
)
{
{
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
struct
gc_arena
gc
=
gc_new
();
struct
gc_arena
gc
=
gc_new
();
int
res
=
_wstat
(
wide_string
(
path
,
&
gc
),
buf
);
int
res
=
_wstat
(
wide_string
(
path
,
&
gc
),
buf
);
gc_free
(
&
gc
);
gc_free
(
&
gc
);
...
...
windows/openvpn/src/openvpn/platform.h
View file @
8e0927f9
...
@@ -130,7 +130,7 @@ int platform_putenv (char *string);
...
@@ -130,7 +130,7 @@ int platform_putenv (char *string);
FILE
*
platform_fopen
(
const
char
*
path
,
const
char
*
mode
);
FILE
*
platform_fopen
(
const
char
*
path
,
const
char
*
mode
);
int
platform_open
(
const
char
*
path
,
int
flags
,
int
mode
);
int
platform_open
(
const
char
*
path
,
int
flags
,
int
mode
);
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
typedef
struct
_stat
platform_stat_t
;
typedef
struct
_stat
platform_stat_t
;
#else
#else
typedef
struct
stat
platform_stat_t
;
typedef
struct
stat
platform_stat_t
;
...
...
windows/openvpn/src/openvpn/socket.h
View file @
8e0927f9
...
@@ -239,6 +239,8 @@ struct link_socket
...
@@ -239,6 +239,8 @@ struct link_socket
/* used to get/set TOS. */
/* used to get/set TOS. */
#if defined(TARGET_LINUX)
#if defined(TARGET_LINUX)
uint8_t
ptos
;
uint8_t
ptos
;
#elif defined(CYGWIN)
char
ptos
;
#else
/* all the BSDs, Solaris, MacOS use plain "int" -> see "man ip" there */
#else
/* all the BSDs, Solaris, MacOS use plain "int" -> see "man ip" there */
int
ptos
;
int
ptos
;
#endif
#endif
...
...
windows/openvpn/src/openvpn/syshead.h
View file @
8e0927f9
...
@@ -38,12 +38,14 @@
...
@@ -38,12 +38,14 @@
#endif
#endif
#ifdef WIN32
#ifdef WIN32
#include <windows.h>
#include <winsock2.h>
#include <winsock2.h>
#include <windows.h>
#ifndef CYGWIN
#define sleep(x) Sleep((x)*1000)
#define sleep(x) Sleep((x)*1000)
#define random rand
#define random rand
#define srandom srand
#define srandom srand
#endif
#endif
#endif
#if defined(__APPLE__)
#if defined(__APPLE__)
#if __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ >= 1070
#if __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ >= 1070
...
@@ -448,7 +450,7 @@
...
@@ -448,7 +450,7 @@
/*
/*
* Directory separation char
* Directory separation char
*/
*/
#if
def WIN32
#if
defined(WIN32) && !defined(CYGWIN)
#define OS_SPECIFIC_DIRSEP '\\'
#define OS_SPECIFIC_DIRSEP '\\'
#else
#else
#define OS_SPECIFIC_DIRSEP '/'
#define OS_SPECIFIC_DIRSEP '/'
...
@@ -615,7 +617,7 @@ socket_defined (const socket_descriptor_t sd)
...
@@ -615,7 +617,7 @@ socket_defined (const socket_descriptor_t sd)
* Do we have CryptoAPI capability?
* Do we have CryptoAPI capability?
*/
*/
#if defined(WIN32) && defined(ENABLE_CRYPTO) && defined(ENABLE_SSL) && defined(ENABLE_CRYPTO_OPENSSL)
#if defined(WIN32) && defined(ENABLE_CRYPTO) && defined(ENABLE_SSL) && defined(ENABLE_CRYPTO_OPENSSL)
#define ENABLE_CRYPTOAPI
/* #define ENABLE_CRYPTOAPI */
#endif
#endif
/*
/*
...
...
windows/openvpn/src/openvpn/tun.c
View file @
8e0927f9
...
@@ -3650,7 +3650,11 @@ get_adapter_index_method_1 (const char *guid)
...
@@ -3650,7 +3650,11 @@ get_adapter_index_method_1 (const char *guid)
DWORD
index
;
DWORD
index
;
ULONG
aindex
;
ULONG
aindex
;
wchar_t
wbuf
[
256
];
wchar_t
wbuf
[
256
];
#if defined(CYGWIN)
swprintf
(
wbuf
,
SIZE
(
wbuf
),
L"
\\
DEVICE
\\
TCPIP_%S"
,
guid
);
#else
_snwprintf
(
wbuf
,
SIZE
(
wbuf
),
L"
\\
DEVICE
\\
TCPIP_%S"
,
guid
);
_snwprintf
(
wbuf
,
SIZE
(
wbuf
),
L"
\\
DEVICE
\\
TCPIP_%S"
,
guid
);
#endif
wbuf
[
SIZE
(
wbuf
)
-
1
]
=
0
;
wbuf
[
SIZE
(
wbuf
)
-
1
]
=
0
;
if
(
GetAdapterIndex
(
wbuf
,
&
aindex
)
!=
NO_ERROR
)
if
(
GetAdapterIndex
(
wbuf
,
&
aindex
)
!=
NO_ERROR
)
index
=
TUN_ADAPTER_INDEX_INVALID
;
index
=
TUN_ADAPTER_INDEX_INVALID
;
...
@@ -4480,10 +4484,10 @@ fork_dhcp_action (struct tuntap *tt)
...
@@ -4480,10 +4484,10 @@ fork_dhcp_action (struct tuntap *tt)
buf_printf
(
&
cmd
,
"openvpn --verb %d --tap-sleep %d"
,
verb
,
pre_sleep
);
buf_printf
(
&
cmd
,
"openvpn --verb %d --tap-sleep %d"
,
verb
,
pre_sleep
);
if
(
tt
->
options
.
dhcp_pre_release
)
if
(
tt
->
options
.
dhcp_pre_release
)
buf_printf
(
&
cmd
,
" --dhcp-pre-release"
);
buf_printf
(
&
cmd
,
" --dhcp-pre-release"
);
if
(
tt
->
options
.
dhcp_renew
)
if
(
tt
->
options
.
dhcp_renew
)
buf_printf
(
&
cmd
,
" --dhcp-renew"
);
buf_printf
(
&
cmd
,
" --dhcp-renew"
);
buf_printf
(
&
cmd
,
" --dhcp-internal %u"
,
(
unsigned
int
)
tt
->
adapter_index
);
buf_printf
(
&
cmd
,
" --dhcp-internal %u"
,
(
unsigned
int
)
tt
->
adapter_index
);
fork_to_self
(
BSTR
(
&
cmd
));
fork_to_self
(
BSTR
(
&
cmd
));
gc_free
(
&
gc
);
gc_free
(
&
gc
);
}
}
...
...
windows/openvpn/src/openvpn/tun.h
View file @
8e0927f9
...
@@ -27,9 +27,15 @@
...
@@ -27,9 +27,15 @@
#ifdef WIN32
#ifdef WIN32
#include <winioctl.h>
#include <winioctl.h>
#ifdef CYGWIN
#include "tap-windows.h"
#else
#include <tap-windows.h>
#include <tap-windows.h>
#endif
#endif
#endif
#include "buffer.h"
#include "buffer.h"
#include "error.h"
#include "error.h"
#include "mtu.h"
#include "mtu.h"
...
...
windows/openvpn/src/openvpn/win32.c
View file @
8e0927f9
...
@@ -209,7 +209,7 @@ init_net_event_win32 (struct rw_handle *event, long network_events, socket_descr
...
@@ -209,7 +209,7 @@ init_net_event_win32 (struct rw_handle *event, long network_events, socket_descr
if
(
event
->
read
==
NULL
)
if
(
event
->
read
==
NULL
)
msg
(
M_ERR
,
"Error: init_net_event_win32: CreateEvent (read) failed"
);
msg
(
M_ERR
,
"Error: init_net_event_win32: CreateEvent (read) failed"
);
}
}
/* setup network events to change read event state */
/* setup network events to change read event state */
if
(
WSAEventSelect
(
sd
,
event
->
read
,
network_events
)
!=
0
)
if
(
WSAEventSelect
(
sd
,
event
->
read
,
network_events
)
!=
0
)
msg
(
M_FATAL
|
M_ERRNO
,
"Error: init_net_event_win32: WSAEventSelect call failed"
);
msg
(
M_FATAL
|
M_ERRNO
,
"Error: init_net_event_win32: WSAEventSelect call failed"
);
...
@@ -218,7 +218,7 @@ init_net_event_win32 (struct rw_handle *event, long network_events, socket_descr
...
@@ -218,7 +218,7 @@ init_net_event_win32 (struct rw_handle *event, long network_events, socket_descr
long
long
reset_net_event_win32
(
struct
rw_handle
*
event
,
socket_descriptor_t
sd
)
reset_net_event_win32
(
struct
rw_handle
*
event
,
socket_descriptor_t
sd
)
{
{
WSANETWORKEVENTS
wne
;
WSANETWORKEVENTS
wne
;
if
(
WSAEnumNetworkEvents
(
sd
,
event
->
read
,
&
wne
)
!=
0
)
if
(
WSAEnumNetworkEvents
(
sd
,
event
->
read
,
&
wne
)
!=
0
)
{
{
msg
(
M_FATAL
|
M_ERRNO
,
"Error: reset_net_event_win32: WSAEnumNetworkEvents call failed"
);
msg
(
M_FATAL
|
M_ERRNO
,
"Error: reset_net_event_win32: WSAEnumNetworkEvents call failed"
);
...
@@ -359,7 +359,7 @@ win32_signal_open (struct win32_signal *ws,
...
@@ -359,7 +359,7 @@ win32_signal_open (struct win32_signal *ws,
&
~
(
ENABLE_WINDOW_INPUT
&
~
(
ENABLE_WINDOW_INPUT
|
ENABLE_PROCESSED_INPUT
|
ENABLE_PROCESSED_INPUT
|
ENABLE_LINE_INPUT
|
ENABLE_LINE_INPUT
|
ENABLE_ECHO_INPUT
|
ENABLE_ECHO_INPUT
|
ENABLE_MOUSE_INPUT
);
|
ENABLE_MOUSE_INPUT
);
if
(
new_console_mode
!=
ws
->
console_mode_save
)
if
(
new_console_mode
!=
ws
->
console_mode_save
)
...
@@ -685,7 +685,7 @@ netcmd_semaphore_lock (void)
...
@@ -685,7 +685,7 @@ netcmd_semaphore_lock (void)
{
{
const
int
timeout_seconds
=
600
;
const
int
timeout_seconds
=
600
;
if
(
!
semaphore_lock
(
&
netcmd_semaphore
,
timeout_seconds
*
1000
))
if
(
!
semaphore_lock
(
&
netcmd_semaphore
,
timeout_seconds
*
1000
))
msg
(
M_FATAL
,
"Cannot lock net command semaphore"
);
msg
(
M_FATAL
,
"Cannot lock net command semaphore"
);
}
}
void
void
...
@@ -764,7 +764,6 @@ static char *
...
@@ -764,7 +764,6 @@ static char *
env_block
(
const
struct
env_set
*
es
)
env_block
(
const
struct
env_set
*
es
)
{
{
char
*
force_path
=
"PATH=C:
\\
Windows
\\
System32;C:
\\
WINDOWS;C:
\\
WINDOWS
\\
System32
\\
Wbem"
;
char
*
force_path
=
"PATH=C:
\\
Windows
\\
System32;C:
\\
WINDOWS;C:
\\
WINDOWS
\\
System32
\\
Wbem"
;
if
(
es
)
if
(
es
)
{
{
struct
env_item
*
e
;
struct
env_item
*
e
;
...
@@ -772,7 +771,7 @@ env_block (const struct env_set *es)
...
@@ -772,7 +771,7 @@ env_block (const struct env_set *es)
char
*
p
;
char
*
p
;
size_t
nchars
=
1
;
size_t
nchars
=
1
;
bool
path_seen
=
false
;
bool
path_seen
=
false
;
for
(
e
=
es
->
list
;
e
!=
NULL
;
e
=
e
->
next
)
for
(
e
=
es
->
list
;
e
!=
NULL
;
e
=
e
->
next
)
nchars
+=
strlen
(
e
->
string
)
+
1
;
nchars
+=
strlen
(
e
->
string
)
+
1
;
...
@@ -849,6 +848,116 @@ wide_cmd_line (const struct argv *a, struct gc_arena *gc)
...
@@ -849,6 +848,116 @@ wide_cmd_line (const struct argv *a, struct gc_arena *gc)
return
wide_string
(
BSTR
(
&
buf
),
gc
);
return
wide_string
(
BSTR
(
&
buf
),
gc
);
}
}
#if defined(CYGWIN)
/*
* Run execve() inside a fork(). Designed to replicate the semantics of system() but
* in a safer way that doesn't require the invocation of a shell or the risks
* assocated with formatting and parsing a command line.
*/
const
char
**
make_env_array_p
(
const
struct
env_set
*
es
,
const
bool
check_allowed
,
struct
gc_arena
*
gc
)
{
char
**
ret
=
NULL
;
struct
env_item
*
e
=
NULL
;
int
i
=
0
,
n
=
0
;
bool
path_seen
=
false
;
/* figure length of es */
if
(
es
)
{
for
(
e
=
es
->
list
;
e
!=
NULL
;
e
=
e
->
next
)
++
n
;
}
/* alloc return array */
ALLOC_ARRAY_CLEAR_GC
(
ret
,
char
*
,
n
+
2
,
gc
);
/* fill return array */
if
(
es
)
{
i
=
0
;
for
(
e
=
es
->
list
;
e
!=
NULL
;
e
=
e
->
next
)
{
if
(
!
check_allowed
||
env_allowed
(
e
->
string
))
{
ASSERT
(
i
<
n
);
ret
[
i
++
]
=
e
->
string
;
if
(
strncmp
(
e
->
string
,
"PATH="
,
5
)
==
0
)
path_seen
=
true
;
}
}
}
/* PATH */
char
*
p
=
NULL
;
if
(
!
path_seen
)
{
char
*
s
=
getenv
(
"PATH"
);
n
=
strlen
(
s
);
ALLOC_ARRAY_CLEAR_GC
(
p
,
char
,
n
+
6
,
gc
);
memcpy
(
p
,
"PATH="
,
5
);
memcpy
(
p
+
5
,
s
,
n
);
*
(
p
+
n
+
5
)
=
0
;
}
ret
[
i
++
]
=
p
;
ret
[
i
]
=
NULL
;
return
(
const
char
**
)
ret
;
}
int
openvpn_execve
(
const
struct
argv
*
a
,
const
struct
env_set
*
es
,
const
unsigned
int
flags
)
{
struct
gc_arena
gc
=
gc_new
();
int
ret
=
-
1
;
static
bool
warn_shown
=
false
;
if
(
a
&&
a
->
argv
[
0
])
{
#if defined(ENABLE_FEATURE_EXECVE)
if
(
openvpn_execve_allowed
(
flags
))
{
const
char
*
cmd
=
a
->
argv
[
0
];
char
*
const
*
argv
=
a
->
argv
;
char
*
const
*
envp
=
(
char
*
const
*
)
make_env_array_p
(
es
,
true
,
&
gc
);
pid_t
pid
;
pid
=
fork
();
if
(
pid
==
(
pid_t
)
0
)
/* child side */
{
/* Miss PATH */
execve
(
cmd
,
argv
,
envp
);
exit
(
127
);
}
else
if
(
pid
<
(
pid_t
)
0
)
/* fork failed */
msg
(
M_ERR
,
"openvpn_execve: unable to fork"
);
else
/* parent side */
{
if
(
waitpid
(
pid
,
&
ret
,
0
)
!=
pid
)
ret
=
-
1
;
}
}
else
if
(
!
warn_shown
&&
(
script_security
<
SSEC_SCRIPTS
))
{
msg
(
M_WARN
,
SCRIPT_SECURITY_WARNING
);
warn_shown
=
true
;
}
#else
msg
(
M_WARN
,
"openvpn_execve: execve function not available"
);
#endif
}
else
{
msg
(
M_FATAL
,
"openvpn_execve: called with empty argv"
);
}
gc_free
(
&
gc
);
return
ret
;
}
#else
/*
/*
* Attempt to simulate fork/execve on Windows
* Attempt to simulate fork/execve on Windows
*/
*/
...
@@ -909,6 +1018,7 @@ openvpn_execve (const struct argv *a, const struct env_set *es, const unsigned i
...
@@ -909,6 +1018,7 @@ openvpn_execve (const struct argv *a, const struct env_set *es, const unsigned i
}
}
return
ret
;
return
ret
;
}
}
#endif
/* CYGWIN */
WCHAR
*
WCHAR
*
wide_string
(
const
char
*
utf8
,
struct
gc_arena
*
gc
)
wide_string
(
const
char
*
utf8
,
struct
gc_arena
*
gc
)
...
@@ -986,6 +1096,12 @@ set_win_sys_path_via_env (struct env_set *es)
...
@@ -986,6 +1096,12 @@ set_win_sys_path_via_env (struct env_set *es)
msg
(
M_ERR
,
"Cannot find environmental variable %s"
,
SYS_PATH_ENV_VAR_NAME
);
msg
(
M_ERR
,
"Cannot find environmental variable %s"
,
SYS_PATH_ENV_VAR_NAME
);
if
(
status
>
sizeof
(
buf
)
-
1
)
if
(
status
>
sizeof
(
buf
)
-
1
)
msg
(
M_FATAL
,
"String overflow attempting to read environmental variable %s"
,
SYS_PATH_ENV_VAR_NAME
);
msg
(
M_FATAL
,
"String overflow attempting to read environmental variable %s"
,
SYS_PATH_ENV_VAR_NAME
);
#if defined(CYGWIN)
while
(
status
)
{
if
(
buf
[
status
]
==
'\\'
)
buf
[
status
]
=
'/'
;
status
--
;
}
#endif
set_win_sys_path
(
buf
,
es
);
set_win_sys_path
(
buf
,
es
);
}
}
...
@@ -1008,4 +1124,5 @@ win_get_tempdir()
...
@@ -1008,4 +1124,5 @@ win_get_tempdir()
}
}
return
tmpdir
;
return
tmpdir
;
}
}
#endif
#endif
windows/openvpn/src/openvpn/win32.h
View file @
8e0927f9
...
@@ -28,12 +28,20 @@
...
@@ -28,12 +28,20 @@
#include "mtu.h"
#include "mtu.h"
#if !defined(CYGWIN)
/* location of executables */
/* location of executables */
#define SYS_PATH_ENV_VAR_NAME "SystemRoot"
/* environmental variable name that normally contains the system path */
#define SYS_PATH_ENV_VAR_NAME "SystemRoot"
/* environmental variable name that normally contains the system path */
#define NETSH_PATH_SUFFIX "\\system32\\netsh.exe"
#define NETSH_PATH_SUFFIX "\\system32\\netsh.exe"
#define WIN_ROUTE_PATH_SUFFIX "\\system32\\route.exe"
#define WIN_ROUTE_PATH_SUFFIX "\\system32\\route.exe"
#define WIN_IPCONFIG_PATH_SUFFIX "\\system32\\ipconfig.exe"
#define WIN_IPCONFIG_PATH_SUFFIX "\\system32\\ipconfig.exe"
#define WIN_NET_PATH_SUFFIX "\\system32\\net.exe"
#define WIN_NET_PATH_SUFFIX "\\system32\\net.exe"
#else
#define SYS_PATH_ENV_VAR_NAME "SYSTEMROOT"
#define NETSH_PATH_SUFFIX "/System32/netsh.exe"
#define WIN_ROUTE_PATH_SUFFIX "/System32/route.exe"
#define WIN_IPCONFIG_PATH_SUFFIX "/System32/ipconfig.exe"
#define WIN_NET_PATH_SUFFIX "net.exe"
#endif
/*
/*
* Win32-specific OpenVPN code, targetted at the mingw
* Win32-specific OpenVPN code, targetted at the mingw
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment