2 * @file delete_child_sa_job.c
4 * @brief Implementation of delete_child_sa_job_t.
9 * Copyright (C) 2006 Martin Willi
10 * Hochschule fuer Technik Rapperswil
12 * This program is free software; you can redistribute it and/or modify it
13 * under the terms of the GNU General Public License as published by the
14 * Free Software Foundation; either version 2 of the License, or (at your
15 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
17 * This program is distributed in the hope that it will be useful, but
18 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
19 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
23 #include "delete_child_sa_job.h"
28 typedef struct private_delete_child_sa_job_t private_delete_child_sa_job_t
;
31 * Private data of an delete_child_sa_job_t object.
33 struct private_delete_child_sa_job_t
{
36 * Public delete_child_sa_job_t interface.
38 delete_child_sa_job_t
public;
41 * reqid of the CHILD_SA
46 * protocol of the CHILD_SA (ESP/AH)
48 protocol_id_t protocol
;
51 * inbound SPI of the CHILD_SA
57 * Implementation of job_t.get_type.
59 static job_type_t
get_type(private_delete_child_sa_job_t
*this)
61 return DELETE_CHILD_SA
;
65 * Implementation of job_t.execute.
67 static status_t
execute(private_delete_child_sa_job_t
*this)
71 ike_sa
= charon
->ike_sa_manager
->checkout_by_id(charon
->ike_sa_manager
,
75 DBG1(DBG_JOB
, "CHILD_SA with reqid %d not found for delete",
79 ike_sa
->delete_child_sa(ike_sa
, this->protocol
, this->spi
);
81 charon
->ike_sa_manager
->checkin(charon
->ike_sa_manager
, ike_sa
);
86 * Implementation of job_t.destroy.
88 static void destroy(private_delete_child_sa_job_t
*this)
96 delete_child_sa_job_t
*delete_child_sa_job_create(u_int32_t reqid
,
97 protocol_id_t protocol
,
100 private_delete_child_sa_job_t
*this = malloc_thing(private_delete_child_sa_job_t
);
102 /* interface functions */
103 this->public.job_interface
.get_type
= (job_type_t (*) (job_t
*)) get_type
;
104 this->public.job_interface
.execute
= (status_t (*) (job_t
*)) execute
;
105 this->public.job_interface
.destroy
= (void (*)(job_t
*)) destroy
;
107 /* private variables */
109 this->protocol
= protocol
;
112 return &(this->public);