diff options
author | Rafal Szczesniak <mimir@samba.org> | 2005-10-02 19:59:24 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 13:39:17 -0500 |
commit | bc651bd7a49ce266a7e0b12d473abda788035fef (patch) | |
tree | 132f4fd3aa05140263b7bfbe906a076eb7c142e0 | |
parent | e264c8b6dd207862a618627ef288e3ca0a33fe0f (diff) | |
download | samba-bc651bd7a49ce266a7e0b12d473abda788035fef.tar.gz samba-bc651bd7a49ce266a7e0b12d473abda788035fef.tar.bz2 samba-bc651bd7a49ce266a7e0b12d473abda788035fef.zip |
r10679: Monitor messages should be issued from usermod functions.
Also a bit of formatting.
rafal
(This used to be commit 1fefca2c172085d6bc05bfac1c10e52066e42606)
-rw-r--r-- | source4/libnet/composite.h | 1 | ||||
-rw-r--r-- | source4/libnet/userman.c | 59 |
2 files changed, 52 insertions, 8 deletions
diff --git a/source4/libnet/composite.h b/source4/libnet/composite.h index 0500e19f5a..515db2a792 100644 --- a/source4/libnet/composite.h +++ b/source4/libnet/composite.h @@ -37,6 +37,7 @@ #define rpc_close_user (0x00000004) /* userinfo.h */ #define rpc_lookup_name (0x00000005) /* userman.h */ #define rpc_delete_user (0x00000006) /* userman.h */ +#define rpc_set_user (0x00000007) /* userman.h */ struct monitor_msg { uint32_t type; diff --git a/source4/libnet/userman.c b/source4/libnet/userman.c index 2a76b55ef1..cd632602ff 100644 --- a/source4/libnet/userman.c +++ b/source4/libnet/userman.c @@ -30,7 +30,7 @@ #include "libnet/userinfo.h" /* - * Composite user add function + * Composite USER ADD functionality */ static void useradd_handler(struct rpc_request*); @@ -45,6 +45,7 @@ struct useradd_state { struct samr_CreateUser createuser; struct policy_handle user_handle; uint32_t user_rid; + /* information about the progress */ void (*monitor_fn)(struct monitor_msg *); }; @@ -201,8 +202,9 @@ NTSTATUS libnet_rpc_useradd(struct dcerpc_pipe *pipe, } + /* - * Composite user delete function + * Composite USER DELETE functionality */ static void userdel_handler(struct rpc_request*); @@ -218,6 +220,7 @@ struct userdel_state { struct samr_LookupNames lookupname; struct samr_OpenUser openuser; struct samr_DeleteUser deleteuser; + /* information about the progress */ void (*monitor_fn)(struct monitor_msg *); }; @@ -315,7 +318,8 @@ static void userdel_handler(struct rpc_request *req) msg.type = rpc_lookup_name; msg_lookup = talloc(s, struct msg_rpc_lookup_name); - msg_lookup->rid = s->lookupname.out.rids.ids; + + msg_lookup->rid = s->lookupname.out.rids.ids; msg_lookup->count = s->lookupname.out.rids.count; msg.data = (void*)msg_lookup; msg.data_size = sizeof(*msg_lookup); @@ -326,7 +330,8 @@ static void userdel_handler(struct rpc_request *req) msg.type = rpc_open_user; msg_open = talloc(s, struct msg_rpc_open_user); - msg_open->rid = s->openuser.in.rid; + + msg_open->rid = s->openuser.in.rid; msg_open->access_mask = s->openuser.in.rid; msg.data = (void*)msg_open; msg.data_size = sizeof(*msg_open); @@ -375,9 +380,9 @@ struct composite_context *libnet_rpc_userdel_send(struct dcerpc_pipe *p, s = talloc_zero(c, struct userdel_state); if (s == NULL) goto failure; - c->state = COMPOSITE_STATE_IN_PROGRESS; - c->private_data= s; - c->event_ctx = dcerpc_event_context(p); + c->state = COMPOSITE_STATE_IN_PROGRESS; + c->private_data = s; + c->event_ctx = dcerpc_event_context(p); s->pipe = p; s->domain_handle = io->in.domain_handle; @@ -405,7 +410,7 @@ failure: /** -1 * Waits for and receives results of asynchronous userdel call + * Waits for and receives results of asynchronous userdel call * * @param c composite context returned by asynchronous userdel call * @param mem_ctx memory context of the call @@ -449,6 +454,10 @@ NTSTATUS libnet_rpc_userdel(struct dcerpc_pipe *pipe, } +/* + * USER MODIFY functionality + */ + static void usermod_handler(struct rpc_request*); enum usermod_stage { USERMOD_LOOKUP, USERMOD_OPEN, USERMOD_QUERY, USERMOD_MODIFY }; @@ -465,6 +474,9 @@ struct usermod_state { struct samr_OpenUser openuser; struct samr_SetUserInfo setuser; struct samr_QueryUserInfo queryuser; + + /* information about the progress */ + void (*monitor_fn)(struct monitor_msg *); }; @@ -691,22 +703,49 @@ static void usermod_handler(struct rpc_request *req) { struct composite_context *c = req->async.private; struct usermod_state *s = talloc_get_type(c->private_data, struct usermod_state); + struct monitor_msg msg; + struct msg_rpc_lookup_name *msg_lookup; + struct msg_rpc_open_user *msg_open; switch (s->stage) { case USERMOD_LOOKUP: c->status = usermod_lookup(c, s); + + msg.type = rpc_lookup_name; + msg_lookup = talloc(s, struct msg_rpc_lookup_name); + + msg_lookup->rid = s->lookupname.out.rids.ids; + msg_lookup->count = s->lookupname.out.rids.count; + msg.data = (void*)msg_lookup; + msg.data_size = sizeof(*msg_lookup); break; case USERMOD_OPEN: c->status = usermod_open(c, s); + + msg.type = rpc_open_user; + msg_open = talloc(s, struct msg_rpc_open_user); + + msg_open->rid = s->openuser.in.rid; + msg_open->access_mask = s->openuser.in.rid; + msg.data = (void*)msg_open; + msg.data_size = sizeof(*msg_open); break; case USERMOD_QUERY: c->status = usermod_query(c, s); + + msg.type = rpc_query_user; + msg.data = NULL; + msg.data_size = 0; break; case USERMOD_MODIFY: c->status = usermod_modify(c, s); + + msg.type = rpc_set_user; + msg.data = NULL; + msg.data_size = 0; break; } @@ -714,6 +753,10 @@ static void usermod_handler(struct rpc_request *req) c->state = COMPOSITE_STATE_ERROR; } + if (s->monitor_fn) { + s->monitor_fn(&msg); + } + if (c->state >= COMPOSITE_STATE_DONE && c->async.fn) { c->async.fn(c); |