diff options
author | Jeremy Allison <jra@samba.org> | 2002-03-30 00:45:26 +0000 |
---|---|---|
committer | Jeremy Allison <jra@samba.org> | 2002-03-30 00:45:26 +0000 |
commit | f029bd348c8c16a8774c3fb4f7f1d76470c7688f (patch) | |
tree | 9a4ca765b052853af263826f78afe2ec538f18ea | |
parent | d72d0972bd7e6699ddf39afc71de4ea838cb0816 (diff) | |
download | samba-f029bd348c8c16a8774c3fb4f7f1d76470c7688f.tar.gz samba-f029bd348c8c16a8774c3fb4f7f1d76470c7688f.tar.xz samba-f029bd348c8c16a8774c3fb4f7f1d76470c7688f.zip |
Hack to share pipe handles between lsa and samr pipes as NT4.x usrmgr
insists on re-using an lsa handle opened on a pipe then closed - this
keeps them around so long as a samr pipe is also open.
Jeremy.
-rw-r--r-- | source/rpc_server/srv_lsa_hnd.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/source/rpc_server/srv_lsa_hnd.c b/source/rpc_server/srv_lsa_hnd.c index 0e06a041778..84c3c5a9598 100644 --- a/source/rpc_server/srv_lsa_hnd.c +++ b/source/rpc_server/srv_lsa_hnd.c @@ -28,6 +28,16 @@ #endif /**************************************************************************** + Hack as handles need to be persisant over lsa pipe closes so long as a samr + pipe is open. JRA. +****************************************************************************/ + +static BOOL is_samr_lsa_pipe(const char *pipe_name) +{ + return (strstr(pipe_name, "samr") || strstr(pipe_name, "lsa")); +} + +/**************************************************************************** Initialise a policy handle list on a pipe. Handle list is shared between all pipes of the same name. ****************************************************************************/ @@ -38,7 +48,8 @@ BOOL init_pipe_handle_list(pipes_struct *p, char *pipe_name) struct handle_list *hl = NULL; for (plist = get_first_internal_pipe(); plist; plist = get_next_internal_pipe(plist)) { - if (strequal( plist->name, pipe_name)) { + if (strequal( plist->name, pipe_name) || + (is_samr_lsa_pipe(plist->name) && is_samr_lsa_pipe(pipe_name))) { if (!plist->pipe_handles) { pstring msg; slprintf(msg, sizeof(msg)-1, "init_pipe_handles: NULL pipe_handle pointer in pipe %s", |