svn commit: samba r24371 - in branches/SAMBA_4_0/source/winbind: .

kai at samba.org kai at samba.org
Mon Aug 13 15:58:42 GMT 2007


Author: kai
Date: 2007-08-13 15:58:41 +0000 (Mon, 13 Aug 2007)
New Revision: 24371

WebSVN: http://websvn.samba.org/cgi-bin/viewcvs.cgi?view=rev&root=samba&rev=24371

Log:
Actually add the glue to make wbinfo -S and wbinfo -Y work

Modified:
   branches/SAMBA_4_0/source/winbind/wb_samba3_cmd.c
   branches/SAMBA_4_0/source/winbind/wb_samba3_protocol.c


Changeset:
Modified: branches/SAMBA_4_0/source/winbind/wb_samba3_cmd.c
===================================================================
--- branches/SAMBA_4_0/source/winbind/wb_samba3_cmd.c	2007-08-13 15:49:09 UTC (rev 24370)
+++ branches/SAMBA_4_0/source/winbind/wb_samba3_cmd.c	2007-08-13 15:58:41 UTC (rev 24371)
@@ -750,3 +750,79 @@
 	s3call->response.result = WINBINDD_OK;
 	return NT_STATUS_OK;
 }
+
+static void sid2uid_recv(struct composite_context *ctx);
+
+NTSTATUS wbsrv_samba3_sid2uid(struct wbsrv_samba3_call *s3call)
+{
+	struct composite_context *ctx;
+	struct wbsrv_service *service =
+		s3call->wbconn->listen_socket->service;
+	struct dom_sid *sid;
+
+	DEBUG(1, ("wbsrv_samba3_sid2uid called\n"));
+
+	sid = dom_sid_parse_talloc(s3call, s3call->request.data.sid);
+	NT_STATUS_HAVE_NO_MEMORY(sid);
+
+	ctx = wb_sid2uid_send(s3call, service, sid);
+	NT_STATUS_HAVE_NO_MEMORY(ctx);
+
+	ctx->async.fn = sid2uid_recv;
+	ctx->async.private_data = s3call;
+	s3call->flags |= WBSRV_CALL_FLAGS_REPLY_ASYNC;
+	return NT_STATUS_OK;
+
+}
+
+static void sid2uid_recv(struct composite_context *ctx)
+{
+	struct wbsrv_samba3_call *s3call =
+		talloc_get_type(ctx->async.private_data,
+				struct wbsrv_samba3_call);
+	NTSTATUS status;
+
+	DEBUG(1, ("sid2uid_recv called\n"));
+
+	status = wb_sid2uid_recv(ctx, &s3call->response.data.uid);
+
+	wbsrv_samba3_async_epilogue(status, s3call);
+}
+
+static void sid2gid_recv(struct composite_context *ctx);
+
+NTSTATUS wbsrv_samba3_sid2gid(struct wbsrv_samba3_call *s3call)
+{
+	struct composite_context *ctx;
+	struct wbsrv_service *service =
+		s3call->wbconn->listen_socket->service;
+	struct dom_sid *sid;
+
+	DEBUG(1, ("wbsrv_samba3_sid2gid called\n"));
+
+	sid = dom_sid_parse_talloc(s3call, s3call->request.data.sid);
+	NT_STATUS_HAVE_NO_MEMORY(sid);
+
+	ctx = wb_sid2gid_send(s3call, service, sid);
+	NT_STATUS_HAVE_NO_MEMORY(ctx);
+
+	ctx->async.fn = sid2gid_recv;
+	ctx->async.private_data = s3call;
+	s3call->flags |= WBSRV_CALL_FLAGS_REPLY_ASYNC;
+	return NT_STATUS_OK;
+
+}
+
+static void sid2gid_recv(struct composite_context *ctx)
+{
+	struct wbsrv_samba3_call *s3call =
+		talloc_get_type(ctx->async.private_data,
+				struct wbsrv_samba3_call);
+	NTSTATUS status;
+
+	DEBUG(1, ("sid2gid_recv called\n"));
+
+	status = wb_sid2gid_recv(ctx, &s3call->response.data.gid);
+
+	wbsrv_samba3_async_epilogue(status, s3call);
+}

Modified: branches/SAMBA_4_0/source/winbind/wb_samba3_protocol.c
===================================================================
--- branches/SAMBA_4_0/source/winbind/wb_samba3_protocol.c	2007-08-13 15:49:09 UTC (rev 24370)
+++ branches/SAMBA_4_0/source/winbind/wb_samba3_protocol.c	2007-08-13 15:58:41 UTC (rev 24371)
@@ -157,6 +157,14 @@
 	case WINBINDD_ENDGRENT:
 		return wbsrv_samba3_endgrent(s3call);
 
+	case WINBINDD_SID_TO_UID:
+	case WINBINDD_DUAL_SID2UID:
+		return wbsrv_samba3_sid2uid(s3call);
+
+	case WINBINDD_SID_TO_GID:
+	case WINBINDD_DUAL_SID2GID:
+		return wbsrv_samba3_sid2gid(s3call);
+
 		/* Unimplemented commands */
 
 	case WINBINDD_PAM_CHAUTHTOK:
@@ -165,8 +173,6 @@
 	case WINBINDD_LIST_USERS:
 	case WINBINDD_LIST_GROUPS:
 	case WINBINDD_LOOKUPRIDS:
-	case WINBINDD_SID_TO_UID:
-	case WINBINDD_SID_TO_GID:
 	case WINBINDD_SIDS_TO_XIDS:
 	case WINBINDD_UID_TO_SID:
 	case WINBINDD_GID_TO_SID:
@@ -182,8 +188,6 @@
 	case WINBINDD_WINS_BYNAME:
 	case WINBINDD_GETGRLST:
 	case WINBINDD_INIT_CONNECTION:
-	case WINBINDD_DUAL_SID2UID:
-	case WINBINDD_DUAL_SID2GID:
 	case WINBINDD_DUAL_SIDS2XIDS:
 	case WINBINDD_DUAL_UID2SID:
 	case WINBINDD_DUAL_GID2SID:



More information about the samba-cvs mailing list