/* * Copyright (C) 2013-2014 Red Hat, Inc. All rights reserved. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * * Authors: Roman Rakus */ #include #include "LMI_AccountInstanceCreationIndication.h" #include "ind_manager.h" #include "indication_common.h" #include "macros.h" #include "account_globals.h" #include "openlmi.h" static const CMPIBroker* _cb = NULL; static IMManager *im = NULL; static IMError im_err = IM_ERR_OK; static AccountIndication ai; static bool creation_watcher(void **data) { return watcher(&ai, data); } static void LMI_AccountInstanceCreationIndicationInitialize(const CMPIContext *ctx) { lmi_init(provider_name, _cb, ctx, provider_config_defaults); im = im_create_manager(NULL, NULL, true, creation_watcher, IM_IND_CREATION, _cb, &im_err); im_register_filter_classes(im, &account_allowed_classes[0], &im_err); } static CMPIStatus LMI_AccountInstanceCreationIndicationIndicationCleanup( CMPIIndicationMI* mi, const CMPIContext* cc, CMPIBoolean term) { if (!im_destroy_manager(im, cc, &im_err)) CMReturn(CMPI_RC_ERR_FAILED); CMReturn(CMPI_RC_OK); } static CMPIStatus LMI_AccountInstanceCreationIndicationAuthorizeFilter( CMPIIndicationMI* mi, const CMPIContext* cc, const CMPISelectExp* se, const char* ns, const CMPIObjectPath* op, const char* user) { if (!im_verify_filter(im, se, cc, &im_err) ) { CMReturn(CMPI_RC_ERR_INVALID_QUERY); } CMReturn(CMPI_RC_OK); } static CMPIStatus LMI_AccountInstanceCreationIndicationMustPoll( CMPIIndicationMI* mi, const CMPIContext* cc, const CMPISelectExp* se, const char* ns, const CMPIObjectPath* op) { CMReturn(CMPI_RC_ERR_NOT_SUPPORTED); } static CMPIStatus LMI_AccountInstanceCreationIndicationActivateFilter( CMPIIndicationMI* mi, const CMPIContext* cc, const CMPISelectExp* se, const char* ns, const CMPIObjectPath* op, CMPIBoolean firstActivation) { if (!im_verify_filter(im, se, cc, &im_err)) { CMReturn(CMPI_RC_ERR_INVALID_QUERY); } if (!im_add_filter(im, (CMPISelectExp*)se, cc, &im_err)) { CMReturn(CMPI_RC_ERR_FAILED); } CMReturn(CMPI_RC_OK); } static CMPIStatus LMI_AccountInstanceCreationIndicationDeActivateFilter( CMPIIndicationMI* mi, const CMPIContext* cc, const CMPISelectExp* se, const char* ns, const CMPIObjectPath* op, CMPIBoolean lastActivation) { if (!im_remove_filter(im, se, cc, &im_err)) { CMReturn(CMPI_RC_ERR_FAILED); } CMReturn(CMPI_RC_OK); } static CMPIStatus LMI_AccountInstanceCreationIndicationEnableIndications( CMPIIndicationMI* mi, const CMPIContext* cc) { if (!watcher_init(&ai)) CMReturn(CMPI_RC_ERR_FAILED); if (!im_start_ind(im, cc, &im_err)) { watcher_destroy(&ai); CMReturn(CMPI_RC_ERR_FAILED); } CMReturn(CMPI_RC_OK); } static CMPIStatus LMI_AccountInstanceCreationIndicationDisableIndications( CMPIIndicationMI* mi, const CMPIContext* cc) { if (!im_stop_ind(im, cc, &im_err)) { CMReturn(CMPI_RC_ERR_FAILED); } watcher_destroy(&ai); CMReturn(CMPI_RC_OK); } CMIndicationMIStub( LMI_AccountInstanceCreationIndication, LMI_AccountInstanceCreationIndication, _cb, LMI_AccountInstanceCreationIndicationInitialize(ctx)) KONKRET_REGISTRATION( "root/cimv2", "LMI_AccountInstanceCreationIndication", "LMI_AccountInstanceCreationIndication", "indication")