svn commit: samba r4194 - in branches/SAMBA_4_0/source/rpc_server/lsa: .

tridge at samba.org tridge at samba.org
Tue Dec 14 05:20:39 GMT 2004


Author: tridge
Date: 2004-12-14 05:20:38 +0000 (Tue, 14 Dec 2004)
New Revision: 4194

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

Log:
added server side implementation of lsa_EnumPrivs



Modified:
   branches/SAMBA_4_0/source/rpc_server/lsa/dcesrv_lsa.c


Changeset:
Modified: branches/SAMBA_4_0/source/rpc_server/lsa/dcesrv_lsa.c
===================================================================
--- branches/SAMBA_4_0/source/rpc_server/lsa/dcesrv_lsa.c	2004-12-14 05:07:29 UTC (rev 4193)
+++ branches/SAMBA_4_0/source/rpc_server/lsa/dcesrv_lsa.c	2004-12-14 05:20:38 UTC (rev 4194)
@@ -98,7 +98,40 @@
 static NTSTATUS lsa_EnumPrivs(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
 			      struct lsa_EnumPrivs *r)
 {
-	DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
+	struct dcesrv_handle *h;
+	struct lsa_policy_state *state;
+	int i;
+	const char *privname;
+
+	DCESRV_PULL_HANDLE(h, r->in.handle, LSA_HANDLE_POLICY);
+
+	state = h->data;
+
+	i = *r->in.resume_handle;
+	if (i == 0) i = 1;
+
+	while ((privname = sec_privilege_name(i)) &&
+	       r->out.privs->count < r->in.max_count) {
+		struct lsa_PrivEntry *e;
+
+		r->out.privs->privs = talloc_realloc_p(r->out.privs,
+						       r->out.privs->privs, 
+						       struct lsa_PrivEntry, 
+						       r->out.privs->count+1);
+		if (r->out.privs->privs == NULL) {
+			return NT_STATUS_NO_MEMORY;
+		}
+		e = &r->out.privs->privs[r->out.privs->count];
+		e->luid_low = i;
+		e->luid_high = 0;
+		e->name.string = privname;
+		r->out.privs->count++;
+		i++;
+	}
+
+	*r->in.resume_handle = i;
+
+	return NT_STATUS_OK;
 }
 
 



More information about the samba-cvs mailing list