u_int64_t jitter_packets;
};
+/**
+ * Helper macro to easily set all three values of a specified limit (time,
+ * bytes, packets).
+ */
+#define LIFETIME_CFG_SET(l, limit, life, rekey, jitter) do { \
+ (l)->life_##limit = (life); \
+ (l)->rekey_##limit = (rekey); \
+ (l)->jitter_##limit = (jitter); \
+} while(0)
+
/**
* Create a new lifetime_cfg_t object.
*/
u_int64_t rekey, u_int64_t jitter)
{
lifetime_cfg_t *this = lifetime_cfg_create();
- this->life_time = life;
- this->rekey_time = rekey;
- this->jitter_time = jitter;
+ LIFETIME_CFG_SET(this, time, life, rekey, jitter);
return this;
}
msg->add_conn.rekey.ipsec_lifetime,
msg->add_conn.rekey.ipsec_lifetime - msg->add_conn.rekey.margin,
msg->add_conn.rekey.margin * msg->add_conn.rekey.fuzz / 100);
+ LIFETIME_CFG_SET(lifetime, bytes,
+ msg->add_conn.rekey.life_bytes,
+ msg->add_conn.rekey.life_bytes - msg->add_conn.rekey.margin_bytes,
+ msg->add_conn.rekey.margin_bytes * msg->add_conn.rekey.fuzz / 100);
+ LIFETIME_CFG_SET(lifetime, packets,
+ msg->add_conn.rekey.life_packets,
+ msg->add_conn.rekey.life_packets - msg->add_conn.rekey.margin_packets,
+ msg->add_conn.rekey.margin_packets * msg->add_conn.rekey.fuzz / 100);
child_cfg = child_cfg_create(
msg->add_conn.name, lifetime,
msg.add_conn.rekey.ipsec_lifetime = conn->sa_ipsec_life_seconds;
msg.add_conn.rekey.ike_lifetime = conn->sa_ike_life_seconds;
msg.add_conn.rekey.margin = conn->sa_rekey_margin;
+ msg.add_conn.rekey.life_bytes = conn->sa_ipsec_life_bytes;
+ msg.add_conn.rekey.margin_bytes = conn->sa_ipsec_margin_bytes;
+ msg.add_conn.rekey.life_packets = conn->sa_ipsec_life_packets;
+ msg.add_conn.rekey.margin_packets = conn->sa_ipsec_margin_packets;
msg.add_conn.rekey.tries = conn->sa_keying_tries;
msg.add_conn.rekey.fuzz = conn->sa_rekey_fuzz;
}
time_t ipsec_lifetime;
time_t ike_lifetime;
time_t margin;
+ u_int64_t life_bytes;
+ u_int64_t margin_bytes;
+ u_int64_t life_packets;
+ u_int64_t margin_packets;
unsigned long tries;
unsigned long fuzz;
} rekey;