diff options
author | Roman Rakus <rrakus@redhat.com> | 2012-09-21 13:06:24 +0200 |
---|---|---|
committer | Roman Rakus <rrakus@redhat.com> | 2012-09-21 13:06:24 +0200 |
commit | 1285ef838782a6399606fc5af96e288236edf8e2 (patch) | |
tree | 0edba1d4488e50e0409e559dedf59ba2f3219b7c /src/account | |
parent | 7faa01fbaed22c074afeab82c4de811f29d6e8d2 (diff) | |
download | openlmi-providers-1285ef838782a6399606fc5af96e288236edf8e2.tar.gz openlmi-providers-1285ef838782a6399606fc5af96e288236edf8e2.tar.xz openlmi-providers-1285ef838782a6399606fc5af96e288236edf8e2.zip |
account: DeleteInstance on LMI_Group
Signed-off-by: Roman Rakus <rrakus@redhat.com>
Diffstat (limited to 'src/account')
-rw-r--r-- | src/account/LMI_GroupProvider.c | 40 |
1 files changed, 39 insertions, 1 deletions
diff --git a/src/account/LMI_GroupProvider.c b/src/account/LMI_GroupProvider.c index 5de5318..3ffec5a 100644 --- a/src/account/LMI_GroupProvider.c +++ b/src/account/LMI_GroupProvider.c @@ -122,7 +122,45 @@ static CMPIStatus LMI_GroupDeleteInstance( const CMPIResult* cr, const CMPIObjectPath* cop) { - CMReturn(CMPI_RC_ERR_NOT_SUPPORTED); + LMI_Group lg; + const char *name = NULL; + struct lu_context *luc = NULL; + struct lu_error *error = NULL; + struct lu_ent *lue = NULL; + char errmsg[256]; + + LMI_Group_InitFromObjectPath(&lg, _cb, cop); + name = lg.Name.chars; + + luc = lu_start(NULL, 0, NULL, NULL, lu_prompt_console_quiet, NULL, &error); + if (!luc) + { + fprintf(stderr, "Error initializing: %s\n", lu_strerror(error)); + exit(1); + } + + lue = lu_ent_new(); + if (!lu_group_lookup_name(luc, name, lue, &error)) + { /* Group not found */ + snprintf(errmsg, 256, "Non existing group: %s\n", name); + lu_ent_free(lue); + lu_end(luc); + CMReturnWithChars(_cb, CMPI_RC_ERR_NOT_FOUND, errmsg); + } + + if (!lu_group_delete(luc, lue, &error)) + { + snprintf(errmsg, 256, "Group %s could not be deleted: %s\n", name, + lu_strerror(error)); + lu_ent_free(lue); + lu_end(luc); + CMReturnWithChars(_cb, CMPI_RC_ERR_FAILED, errmsg); + } + + lu_ent_free(lue); + lu_end(luc); + + CMReturn(CMPI_RC_OK); } static CMPIStatus LMI_GroupExecQuery( |