35d884be7d4fba0241df4dbe2301e45537a2cc18
[strongswan.git] / src / charon / processing / jobs / delete_child_sa_job.h
1 /*
2 * Copyright (C) 2006 Martin Willi
3 * 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 * $Id$
16 */
17
18 /**
19 * @defgroup delete_child_sa_job delete_child_sa_job
20 * @{ @ingroup jobs
21 */
22
23 #ifndef DELETE_CHILD_SA_JOB_H_
24 #define DELETE_CHILD_SA_JOB_H_
25
26 typedef struct delete_child_sa_job_t delete_child_sa_job_t;
27
28 #include <library.h>
29 #include <sa/ike_sa_id.h>
30 #include <processing/jobs/job.h>
31 #include <config/proposal.h>
32
33
34 /**
35 * Class representing an DELETE_CHILD_SA Job.
36 *
37 * This job initiates the delete of a CHILD SA.
38 */
39 struct delete_child_sa_job_t {
40 /**
41 * The job_t interface.
42 */
43 job_t job_interface;
44 };
45
46 /**
47 * Creates a job of type DELETE_CHILD_SA.
48 *
49 * The CHILD_SA is identified by its reqid, protocol (AH/ESP) and its
50 * inbound SPI.
51 *
52 * @param reqid reqid of the CHILD_SA, as used in kernel
53 * @param protocol protocol of the CHILD_SA
54 * @param spi security parameter index of the CHILD_SA
55 * @return delete_child_sa_job_t object
56 */
57 delete_child_sa_job_t *delete_child_sa_job_create(u_int32_t reqid,
58 protocol_id_t protocol,
59 u_int32_t spi);
60
61 #endif /* DELETE_CHILD_SA_JOB_H_ @} */