@@ -2441,6 +2441,30 @@
ifconfig_constraint_network, ifconfig_constraint_netmask);
}
+ /* set our client's VPN endpoint for status reporting purposes */
+ mi->reporting_addr = mi->context.c2.push_ifconfig_local;
+ mi->reporting_addr_ipv6 = mi->context.c2.push_ifconfig_ipv6_local;
+
+ /* set context-level authentication flag */
+ mi->context.c2.tls_multi->multi_state = CAS_CONNECT_DONE;
+
+ /* authentication complete, calculate dynamic client specific options */
+ if (!multi_client_set_protocol_options(&mi->context))
+ {
+ mi->context.c2.tls_multi->multi_state = CAS_FAILED;
+ }
+ /* only continue if setting protocol options worked */
+ else if (!multi_client_setup_dco_initial(m, mi, &gc))
+ {
+ mi->context.c2.tls_multi->multi_state = CAS_FAILED;
+ }
+ /* Generate data channel keys only if setting protocol options
+ * and DCO initial setup has not failed */
+ else if (!multi_client_generate_tls_keys(&mi->context))
+ {
+ mi->context.c2.tls_multi->multi_state = CAS_FAILED;
+ }
+
/*
* For routed tunnels, set up internal route to endpoint
* plus add all iroute routes.
@@ -2488,30 +2512,6 @@
multi_instance_string(mi, false, &gc));
}
- /* set our client's VPN endpoint for status reporting purposes */
- mi->reporting_addr = mi->context.c2.push_ifconfig_local;
- mi->reporting_addr_ipv6 = mi->context.c2.push_ifconfig_ipv6_local;
-
- /* set context-level authentication flag */
- mi->context.c2.tls_multi->multi_state = CAS_CONNECT_DONE;
-
- /* authentication complete, calculate dynamic client specific options */
- if (!multi_client_set_protocol_options(&mi->context))
- {
- mi->context.c2.tls_multi->multi_state = CAS_FAILED;
- }
- /* only continue if setting protocol options worked */
- else if (!multi_client_setup_dco_initial(m, mi, &gc))
- {
- mi->context.c2.tls_multi->multi_state = CAS_FAILED;
- }
- /* Generate data channel keys only if setting protocol options
- * and DCO initial setup has not failed */
- else if (!multi_client_generate_tls_keys(&mi->context))
- {
- mi->context.c2.tls_multi->multi_state = CAS_FAILED;
- }
-
/* send push reply if ready */
if (mi->context.c2.push_request_received)
{
Attention is currently required from: flichtenheld, plaisthos. Hello plaisthos, flichtenheld, I'd like you to do a code review. Please visit http://gerrit.openvpn.net/c/openvpn/+/856?usp=email to review the following change. Change subject: multi.c: add iroutes after dco peer is added ...................................................................... multi.c: add iroutes after dco peer is added This doesn't matter for Linux and FreeBSD but matters for dco-win, where iroute subnet is mapped to a peer context, which means that peer has to be created before iroute is added. Change-Id: I1cac0f036504c87205a3c97589a94a662cf79b99 Signed-off-by: Lev Stipakov <lev@openvpn.net> --- M src/openvpn/multi.c 1 file changed, 24 insertions(+), 24 deletions(-) git pull ssh://gerrit.openvpn.net:29418/openvpn refs/changes/56/856/1