diff options
author | Kai Blin <kai@samba.org> | 2007-08-13 16:20:26 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 15:01:47 -0500 |
commit | 677ccf3047dddbaf6b0323a68c00ac58ae20cde6 (patch) | |
tree | 6101b7eaff7bfe081793eca9fc590f924bd86668 /source4/winbind/wb_samba3_cmd.c | |
parent | e1c832521f636d186067bd13b235c5f18db1b0da (diff) | |
download | samba-677ccf3047dddbaf6b0323a68c00ac58ae20cde6.tar.gz samba-677ccf3047dddbaf6b0323a68c00ac58ae20cde6.tar.bz2 samba-677ccf3047dddbaf6b0323a68c00ac58ae20cde6.zip |
r24373: Implement backend for wbinfo -G (gid2sid)
(This used to be commit e928e56219c8911105b34e3a322bd70f7172382b)
Diffstat (limited to 'source4/winbind/wb_samba3_cmd.c')
-rw-r--r-- | source4/winbind/wb_samba3_cmd.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/source4/winbind/wb_samba3_cmd.c b/source4/winbind/wb_samba3_cmd.c index 76125c4032..03c5f7a1f9 100644 --- a/source4/winbind/wb_samba3_cmd.c +++ b/source4/winbind/wb_samba3_cmd.c @@ -875,3 +875,48 @@ static void uid2sid_recv(struct composite_context *ctx) wbsrv_samba3_async_epilogue(status, s3call); } +static void gid2sid_recv(struct composite_context *ctx); + +NTSTATUS wbsrv_samba3_gid2sid(struct wbsrv_samba3_call *s3call) +{ + struct composite_context *ctx; + struct wbsrv_service *service = + s3call->wbconn->listen_socket->service; + + DEBUG(5, ("wbsrv_samba3_gid2sid called\n")); + + ctx = wb_gid2sid_send(s3call, service, s3call->request.data.gid); + NT_STATUS_HAVE_NO_MEMORY(ctx); + + ctx->async.fn = gid2sid_recv; + ctx->async.private_data = s3call; + s3call->flags |= WBSRV_CALL_FLAGS_REPLY_ASYNC; + return NT_STATUS_OK; + +} + +static void gid2sid_recv(struct composite_context *ctx) +{ + struct wbsrv_samba3_call *s3call = + talloc_get_type(ctx->async.private_data, + struct wbsrv_samba3_call); + NTSTATUS status; + struct dom_sid *sid; + char *sid_str; + + DEBUG(5, ("gid2sid_recv called\n")); + + status = wb_gid2sid_recv(ctx, s3call, &sid); + if(NT_STATUS_IS_OK(status)) { + sid_str = dom_sid_string(s3call, sid); + + if (sid_str == NULL) + wbsrv_samba3_async_epilogue(NT_STATUS_NO_MEMORY,s3call); + + WBSRV_SAMBA3_SET_STRING(s3call->response.data.sid.sid, sid_str); + s3call->response.data.sid.type = SID_NAME_DOMAIN; + } + + wbsrv_samba3_async_epilogue(status, s3call); +} + |