}
/**
+ * Implementation of ike_sa_t.set_dpd_delay.
+ */
+static void set_dpd_delay(private_ike_sa_t *this, u_int32_t delay)
+{
+ this->dpd_delay = delay;
+}
+
+/**
* Implementation of ike_sa_t.get_my_host.
*/
static host_t *get_my_host(private_ike_sa_t *this)
this->public.enable_natt = (void(*)(ike_sa_t*, bool)) enable_natt;
this->public.is_natt_enabled = (bool(*)(ike_sa_t*)) is_natt_enabled;
this->public.set_lifetimes = (void(*)(ike_sa_t*,u_int32_t,u_int32_t))set_lifetimes;
+ this->public.set_dpd_delay = (void(*)(ike_sa_t*,u_int32_t))set_dpd_delay;
this->public.rekey = (status_t(*)(ike_sa_t*))rekey;
this->public.get_rekeying_transaction = (void*(*)(ike_sa_t*))get_rekeying_transaction;
this->public.set_rekeying_transaction = (void(*)(ike_sa_t*,void*))set_rekeying_transaction;
void (*enable_natt) (ike_sa_t *this, bool local);
/**
+ * @brief Set the delay before starting a DPD check in case of inactivity.
+ *
+ * @param this calling object
+ * @param delay dpd delay in seconds
+ */
+ void (*set_dpd_delay) (ike_sa_t *this, u_int32_t delay);
+
+ /**
* @brief Sends a DPD request to the peer.
*
* To check if a peer is still alive, periodic
{
this->ike_sa->set_name(this->ike_sa, name);
}
+ this->ike_sa->set_dpd_delay(this->ike_sa,
+ this->connection->get_dpd_delay(this->connection));
/* Precompute NAT-D hashes for incoming NAT notify comparison */
ike_sa_id = request->get_ike_sa_id(request);