1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-27 14:04:05 +03:00

r4195: added IDL, test suite and server side code for lsa_LookupPrivValue

(This used to be commit 7bddd4740332017bb5f4bddcc9ba0234d05378bd)
This commit is contained in:
Andrew Tridgell 2004-12-14 05:32:51 +00:00 committed by Gerald (Jerry) Carter
parent 9927ffd600
commit 02f7d260a2
3 changed files with 60 additions and 18 deletions

View File

@ -35,10 +35,14 @@
unistr_noterm *string; unistr_noterm *string;
} lsa_String; } lsa_String;
typedef struct {
uint32 low;
uint32 high;
} lsa_LUID;
typedef struct { typedef struct {
lsa_String name; lsa_String name;
uint32 luid_low; lsa_LUID luid;
uint32 luid_high;
} lsa_PrivEntry; } lsa_PrivEntry;
typedef struct { typedef struct {
@ -358,11 +362,6 @@
/****************************************/ /****************************************/
/* Function: 0x12 */ /* Function: 0x12 */
typedef struct {
uint32 low;
uint32 high;
} lsa_LUID;
typedef struct { typedef struct {
lsa_LUID luid; lsa_LUID luid;
uint32 attribute; uint32 attribute;
@ -540,7 +539,11 @@
); );
/* Function: 0x1f */ /* Function: 0x1f */
NTSTATUS lsa_LookupPrivValue(); NTSTATUS lsa_LookupPrivValue(
[in,ref] policy_handle *handle,
[in,ref] lsa_String *name,
[out,ref] lsa_LUID *luid
);
/* Function: 0x20 */ /* Function: 0x20 */

View File

@ -122,8 +122,8 @@ static NTSTATUS lsa_EnumPrivs(struct dcesrv_call_state *dce_call, TALLOC_CTX *me
return NT_STATUS_NO_MEMORY; return NT_STATUS_NO_MEMORY;
} }
e = &r->out.privs->privs[r->out.privs->count]; e = &r->out.privs->privs[r->out.privs->count];
e->luid_low = i; e->luid.low = i;
e->luid_high = 0; e->luid.high = 0;
e->name.string = privname; e->name.string = privname;
r->out.privs->count++; r->out.privs->count++;
i++; i++;
@ -821,17 +821,35 @@ static NTSTATUS lsa_QuerySecret(struct dcesrv_call_state *dce_call, TALLOC_CTX *
/* /*
lsa_LookupPrivValue lsa_LookupPrivValue
*/ */
static NTSTATUS lsa_LookupPrivValue(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, static NTSTATUS lsa_LookupPrivValue(struct dcesrv_call_state *dce_call,
TALLOC_CTX *mem_ctx,
struct lsa_LookupPrivValue *r) struct lsa_LookupPrivValue *r)
{ {
DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); struct dcesrv_handle *h;
struct lsa_policy_state *state;
int id;
DCESRV_PULL_HANDLE(h, r->in.handle, LSA_HANDLE_POLICY);
state = h->data;
id = sec_privilege_id(r->in.name->string);
if (id == -1) {
return NT_STATUS_NO_SUCH_PRIVILEGE;
}
r->out.luid->low = id;
r->out.luid->high = 0;
return NT_STATUS_OK;
} }
/* /*
lsa_LookupPrivName lsa_LookupPrivName
*/ */
static NTSTATUS lsa_LookupPrivName(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, static NTSTATUS lsa_LookupPrivName(struct dcesrv_call_state *dce_call,
TALLOC_CTX *mem_ctx,
struct lsa_LookupPrivName *r) struct lsa_LookupPrivName *r)
{ {
DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR); DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);

View File

@ -283,7 +283,7 @@ static BOOL test_many_LookupSids(struct dcerpc_pipe *p,
names.count = 0; names.count = 0;
names.names = NULL; names.names = NULL;
sids.num_sids = 1000; sids.num_sids = 100;
sids.sids = talloc_array_p(mem_ctx, struct lsa_SidPtr, sids.num_sids); sids.sids = talloc_array_p(mem_ctx, struct lsa_SidPtr, sids.num_sids);
@ -317,6 +317,26 @@ static BOOL test_many_LookupSids(struct dcerpc_pipe *p,
return True; return True;
} }
static BOOL test_LookupPrivValue(struct dcerpc_pipe *p,
TALLOC_CTX *mem_ctx,
struct policy_handle *handle,
struct lsa_String *name)
{
NTSTATUS status;
struct lsa_LookupPrivValue r;
r.in.handle = handle;
r.in.name = name;
status = dcerpc_lsa_LookupPrivValue(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("\nLookupPrivValue failed - %s\n", nt_errstr(status));
return False;
}
return True;
}
static BOOL test_LookupPrivName(struct dcerpc_pipe *p, static BOOL test_LookupPrivName(struct dcerpc_pipe *p,
TALLOC_CTX *mem_ctx, TALLOC_CTX *mem_ctx,
struct policy_handle *handle, struct policy_handle *handle,
@ -805,7 +825,7 @@ static BOOL test_EnumPrivs(struct dcerpc_pipe *p,
r.in.handle = handle; r.in.handle = handle;
r.in.resume_handle = &resume_handle; r.in.resume_handle = &resume_handle;
r.in.max_count = 1000; r.in.max_count = 100;
r.out.resume_handle = &resume_handle; r.out.resume_handle = &resume_handle;
r.out.privs = &privs1; r.out.privs = &privs1;
@ -818,6 +838,7 @@ static BOOL test_EnumPrivs(struct dcerpc_pipe *p,
for (i = 0; i< privs1.count; i++) { for (i = 0; i< privs1.count; i++) {
test_LookupPrivDisplayName(p, mem_ctx, handle, &privs1.privs[i].name); test_LookupPrivDisplayName(p, mem_ctx, handle, &privs1.privs[i].name);
test_LookupPrivValue(p, mem_ctx, handle, &privs1.privs[i].name);
if (!test_EnumAccountsWithUserRight(p, mem_ctx, handle, &privs1.privs[i].name)) { if (!test_EnumAccountsWithUserRight(p, mem_ctx, handle, &privs1.privs[i].name)) {
ret = False; ret = False;
} }
@ -842,7 +863,7 @@ static BOOL test_EnumTrustDom(struct dcerpc_pipe *p,
r.in.handle = handle; r.in.handle = handle;
r.in.resume_handle = &resume_handle; r.in.resume_handle = &resume_handle;
r.in.num_entries = 1000; r.in.num_entries = 100;
r.out.domains = &domains; r.out.domains = &domains;
r.out.resume_handle = &resume_handle; r.out.resume_handle = &resume_handle;