diff options
author | Rafal Szczesniak <mimir@samba.org> | 2005-07-23 10:27:45 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 13:29:58 -0500 |
commit | 64f31e424b3db792a1edb909195eb592a9460aaf (patch) | |
tree | f100ed66a70a9da9fce8c6718f4635d88c5d0669 /source4/libnet | |
parent | 23924170cc1db85fecf21e0bfebf4d7b4ac42c25 (diff) | |
download | samba-64f31e424b3db792a1edb909195eb592a9460aaf.tar.gz samba-64f31e424b3db792a1edb909195eb592a9460aaf.tar.bz2 samba-64f31e424b3db792a1edb909195eb592a9460aaf.zip |
r8721: Further work on libnet_rpc_usermod function. Now it can change
both account name and full name.
rafal
(This used to be commit 1a779f8643c43677c62fed6ec4bfb54b08647f5b)
Diffstat (limited to 'source4/libnet')
-rw-r--r-- | source4/libnet/composite.h | 5 | ||||
-rw-r--r-- | source4/libnet/userman.c | 34 |
2 files changed, 35 insertions, 4 deletions
diff --git a/source4/libnet/composite.h b/source4/libnet/composite.h index 62ad46ee81..70e70d04ee 100644 --- a/source4/libnet/composite.h +++ b/source4/libnet/composite.h @@ -59,12 +59,15 @@ struct libnet_rpc_userdel { }; +#define USERMOD_FIELD_ACCOUNT_NAME ( 0x00000001 ) +#define USERMOD_FIELD_FULL_NAME ( 0x00000002 ) + struct libnet_rpc_usermod { struct { struct policy_handle domain_handle; const char *username; - struct usermod { + struct usermod_change { uint32_t fields; /* bitmask field */ const char *account_name; diff --git a/source4/libnet/userman.c b/source4/libnet/userman.c index 4d021506bb..37b3d1e723 100644 --- a/source4/libnet/userman.c +++ b/source4/libnet/userman.c @@ -428,6 +428,7 @@ struct usermod_state { struct rpc_request *req; struct policy_handle domain_handle; struct policy_handle user_handle; + struct usermod_change change; union samr_UserInfo info; struct samr_LookupNames lookupname; struct samr_OpenUser openuser; @@ -471,21 +472,47 @@ static NTSTATUS usermod_open(struct composite_context *c, struct usermod_state *s) { union samr_UserInfo *i = &s->info; + uint16_t level; c->status = dcerpc_ndr_request_recv(s->req); NT_STATUS_NOT_OK_RETURN(c->status); s->setuser.in.user_handle = &s->user_handle; - /* TODO: decide about the level of UserInfo */ - s->setuser.in.level = 1; + /* Prepare UserInfo level and data based on bitmask field */ + if (s->change.fields) { + if (s->change.fields & USERMOD_FIELD_ACCOUNT_NAME) { + level = 7; + i->info7.account_name.length = 2*strlen_m(s->change.account_name); + i->info7.account_name.size = 2*strlen_m(s->change.account_name); + i->info7.account_name.string = s->change.account_name; + + s->change.fields ^= USERMOD_FIELD_ACCOUNT_NAME; + + } else if (s->change.fields & USERMOD_FIELD_FULL_NAME) { + level = 8; + i->info8.full_name.length = 2*strlen_m(s->change.full_name); + i->info8.full_name.size = 2*strlen_m(s->change.full_name); + i->info8.full_name.string = s->change.full_name; + + s->change.fields ^= USERMOD_FIELD_FULL_NAME; + } + } + + s->setuser.in.level = level; s->setuser.in.info = i; s->req = dcerpc_samr_SetUserInfo_send(s->pipe, c, &s->setuser); s->req->async.callback = usermod_handler; s->req->async.private = c; - s->stage = USERMOD_MODIFY; + + /* Get back here again unless all fields have been set */ + if (s->change.fields) { + s->stage = USERMOD_OPEN; + } else { + s->stage = USERMOD_MODIFY; + } return NT_STATUS_OK; } @@ -554,6 +581,7 @@ struct composite_context *libnet_rpc_usermod_send(struct dcerpc_pipe *p, s->pipe = p; s->domain_handle = io->in.domain_handle; + s->change = io->in.change; s->lookupname.in.domain_handle = &io->in.domain_handle; s->lookupname.in.num_names = 1; |