#include #include #include "LMI_SSSDDomain.h" #include "utils.h" #include "sssd_domains.h" static const CMPIBroker* _cb = NULL; static void LMI_SSSDDomainInitialize(const CMPIContext *ctx) { lmi_init(PROVIDER_NAME, _cb, ctx, NULL); } static CMPIStatus LMI_SSSDDomainCleanup( CMPIInstanceMI* mi, const CMPIContext* cc, CMPIBoolean term) { CMReturn(CMPI_RC_OK); } static CMPIStatus LMI_SSSDDomainEnumInstanceNames( CMPIInstanceMI* mi, const CMPIContext* cc, const CMPIResult* cr, const CMPIObjectPath* cop) { return KDefaultEnumerateInstanceNames( _cb, mi, cc, cr, cop); } static CMPIStatus LMI_SSSDDomainEnumInstances( CMPIInstanceMI* mi, const CMPIContext* cc, const CMPIResult* cr, const CMPIObjectPath* cop, const char** properties) { LMI_SSSDDomain instance; const char *namespace = KNameSpace(cop); sss_dbus_ctx *dbus_ctx = NULL; sss_dbus_error error; char **paths = NULL; sssd_method_error mret; CMPIrc ret; int i; error = sss_dbus_init(&dbus_ctx); check_sss_dbus_error(error, ret, CMPI_RC_ERR_FAILED, done); error = sss_dbus_invoke_list(dbus_ctx, SSSD_DBUS_LIST_DOMAINS, &paths, DBUS_TYPE_INVALID); check_sss_dbus_error(error, ret, CMPI_RC_ERR_FAILED, done); for (i = 0; paths[i] != NULL; i++) { mret = sssd_domain_set_instance(dbus_ctx, paths[i], _cb, namespace, &instance); if (mret != SSSD_METHOD_ERROR_OK) { ret = CMPI_RC_ERR_FAILED; goto done; } KReturnInstance(cr, instance); } ret = CMPI_RC_OK; done: sss_dbus_free_string_array(dbus_ctx, &paths); sss_dbus_free(&dbus_ctx); CMReturn(ret); } static CMPIStatus LMI_SSSDDomainGetInstance( CMPIInstanceMI* mi, const CMPIContext* cc, const CMPIResult* cr, const CMPIObjectPath* cop, const char** properties) { LMI_SSSDDomain instance; LMI_SSSDDomainRef ref; const char *namespace = KNameSpace(cop); sss_dbus_ctx *dbus_ctx = NULL; sss_dbus_error error; const char *name = NULL; char *path = NULL; sssd_method_error mret; CMPIrc ret; LMI_SSSDDomainRef_InitFromObjectPath(&ref, _cb, cop); name = ref.Name.chars; error = sss_dbus_init(&dbus_ctx); check_sss_dbus_error(error, ret, CMPI_RC_ERR_FAILED, done); error = sss_dbus_invoke_find(dbus_ctx, SSSD_DBUS_FIND_DOMAIN, &path, DBUS_TYPE_STRING, &name, DBUS_TYPE_INVALID); check_sss_dbus_error(error, ret, CMPI_RC_ERR_FAILED, done); mret = sssd_domain_set_instance(dbus_ctx, path, _cb, namespace, &instance); if (mret != SSSD_METHOD_ERROR_OK) { ret = CMPI_RC_ERR_FAILED; goto done; } KReturnInstance(cr, instance); ret = CMPI_RC_OK; done: sss_dbus_free_string(dbus_ctx, &path); sss_dbus_free(&dbus_ctx); CMReturn(ret); } static CMPIStatus LMI_SSSDDomainCreateInstance( CMPIInstanceMI* mi, const CMPIContext* cc, const CMPIResult* cr, const CMPIObjectPath* cop, const CMPIInstance* ci) { CMReturn(CMPI_RC_ERR_NOT_SUPPORTED); } static CMPIStatus LMI_SSSDDomainModifyInstance( CMPIInstanceMI* mi, const CMPIContext* cc, const CMPIResult* cr, const CMPIObjectPath* cop, const CMPIInstance* ci, const char** properties) { CMReturn(CMPI_RC_ERR_NOT_SUPPORTED); } static CMPIStatus LMI_SSSDDomainDeleteInstance( CMPIInstanceMI* mi, const CMPIContext* cc, const CMPIResult* cr, const CMPIObjectPath* cop) { CMReturn(CMPI_RC_ERR_NOT_SUPPORTED); } static CMPIStatus LMI_SSSDDomainExecQuery( CMPIInstanceMI* mi, const CMPIContext* cc, const CMPIResult* cr, const CMPIObjectPath* cop, const char* lang, const char* query) { CMReturn(CMPI_RC_ERR_NOT_SUPPORTED); } CMInstanceMIStub( LMI_SSSDDomain, LMI_SSSDDomain, _cb, LMI_SSSDDomainInitialize(ctx)) static CMPIStatus LMI_SSSDDomainMethodCleanup( CMPIMethodMI* mi, const CMPIContext* cc, CMPIBoolean term) { CMReturn(CMPI_RC_OK); } static CMPIStatus LMI_SSSDDomainInvokeMethod( CMPIMethodMI* mi, const CMPIContext* cc, const CMPIResult* cr, const CMPIObjectPath* cop, const char* meth, const CMPIArgs* in, CMPIArgs* out) { return LMI_SSSDDomain_DispatchMethod( _cb, mi, cc, cr, cop, meth, in, out); } CMMethodMIStub( LMI_SSSDDomain, LMI_SSSDDomain, _cb, LMI_SSSDDomainInitialize(ctx)) KONKRET_REGISTRATION( "root/cimv2", "LMI_SSSDDomain", "LMI_SSSDDomain", "instance method")