rekey_ike_sa_job.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /*
  2. * Copyright (C) 2006 Martin Willi
  3. * HSR Hochschule fuer Technik Rapperswil
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of the GNU General Public License as published by the
  7. * Free Software Foundation; either version 2 of the License, or (at your
  8. * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
  9. *
  10. * This program is distributed in the hope that it will be useful, but
  11. * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
  12. * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
  13. * for more details.
  14. */
  15. /**
  16. * @defgroup rekey_ike_sa_job rekey_ike_sa_job
  17. * @{ @ingroup cjobs
  18. */
  19. #ifndef REKEY_IKE_SA_JOB_H_
  20. #define REKEY_IKE_SA_JOB_H_
  21. typedef struct rekey_ike_sa_job_t rekey_ike_sa_job_t;
  22. #include <library.h>
  23. #include <sa/ike_sa_id.h>
  24. #include <processing/jobs/job.h>
  25. /**
  26. * Class representing an REKEY_IKE_SA Job.
  27. *
  28. * This job initiates the rekeying of an IKE_SA.
  29. */
  30. struct rekey_ike_sa_job_t {
  31. /**
  32. * The job_t interface.
  33. */
  34. job_t job_interface;
  35. };
  36. /**
  37. * Creates a job of type REKEY_IKE_SA.
  38. *
  39. * @param ike_sa_id ID of the IKE_SA to rekey
  40. * @param reauth TRUE to reauthenticate peer, FALSE for rekeying only
  41. * @return rekey_ike_sa_job_t object
  42. */
  43. rekey_ike_sa_job_t *rekey_ike_sa_job_create(ike_sa_id_t *ike_sa_id, bool reauth);
  44. #endif /** REKEY_IKE_SA_JOB_H_ @}*/