/* * Copyright (C) 2010 Martin Willi * Copyright (C) 2010 revosec AG * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2 of the License, or (at your * option) any later version. See . * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. */ #include "callback_cred.h" typedef struct private_callback_cred_t private_callback_cred_t; /** * Private data of an callback_cred_t object. */ struct private_callback_cred_t { /** * Public callback_cred_t interface. */ callback_cred_t public; /** * Callback of this set, for all types, and generic */ union { void *generic; callback_cred_shared_cb_t shared; } cb; /** * Data to pass to callback */ void *data; }; /** * Shared key enumerator on callbacks */ typedef struct { /* implements enumerator_t */ enumerator_t public; /* backref to this */ private_callback_cred_t *this; /* type if requested key */ shared_key_type_t type; /* own identity to match */ identification_t *me; /* other identity to match */ identification_t *other; /* current shared key */ shared_key_t *current; } shared_enumerator_t; METHOD(enumerator_t, shared_enumerate, bool, shared_enumerator_t *this, va_list args) { shared_key_t **out; id_match_t *match_me, *match_other; VA_ARGS_VGET(args, out, match_me, match_other); DESTROY_IF(this->current); this->current = this->this->cb.shared(this->this->data, this->type, this->me, this->other, match_me, match_other); if (this->current) { *out = this->current; return TRUE; } return FALSE; } METHOD(enumerator_t, shared_destroy, void, shared_enumerator_t *this) { DESTROY_IF(this->current); free(this); } METHOD(credential_set_t, create_shared_enumerator, enumerator_t*, private_callback_cred_t *this, shared_key_type_t type, identification_t *me, identification_t *other) { shared_enumerator_t *enumerator; INIT(enumerator, .public = { .enumerate = enumerator_enumerate_default, .venumerate = _shared_enumerate, .destroy = _shared_destroy, }, .this = this, .type = type, .me = me, .other = other, ); return &enumerator->public; } METHOD(callback_cred_t, destroy, void, private_callback_cred_t *this) { free(this); } /** * Create a generic callback credential set */ static private_callback_cred_t* create_generic(void *cb, void *data) { private_callback_cred_t *this; INIT(this, .public = { .set = { .create_shared_enumerator = (void*)return_null, .create_private_enumerator = (void*)return_null, .create_cert_enumerator = (void*)return_null, .create_cdp_enumerator = (void*)return_null, .cache_cert = (void*)nop, }, .destroy = _destroy, }, .cb.generic = cb, .data = data, ); return this; } /** * See header */ callback_cred_t *callback_cred_create_shared(callback_cred_shared_cb_t cb, void *data) { private_callback_cred_t *this = create_generic(cb, data); this->public.set.create_shared_enumerator = _create_shared_enumerator; return &this->public; }