From: Stefan Metzmacher Date: Sat, 17 May 2008 00:40:37 +0000 (+0200) Subject: rpc_server: use the transport session_info if available X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=76dd521bcf53a245bd1412968e9b921e5c2f10c9;p=thirdparty%2Fsamba.git rpc_server: use the transport session_info if available metze --- diff --git a/source/rpc_server/service_rpc.c b/source/rpc_server/service_rpc.c index 00f0d261ca5..b68cec4c7db 100644 --- a/source/rpc_server/service_rpc.c +++ b/source/rpc_server/service_rpc.c @@ -104,20 +104,24 @@ static void dcesrv_sock_accept(struct stream_connection *srv_conn) struct dcesrv_socket_context *dcesrv_sock = talloc_get_type(srv_conn->private, struct dcesrv_socket_context); struct dcesrv_connection *dcesrv_conn = NULL; - struct auth_session_info *session_info = NULL; - status = auth_anonymous_session_info(srv_conn, srv_conn->event.ctx, dcesrv_sock->dcesrv_ctx->lp_ctx, &session_info); - if (!NT_STATUS_IS_OK(status)) { - DEBUG(0,("dcesrv_sock_accept: auth_anonymous_session_info failed: %s\n", - nt_errstr(status))); - stream_terminate_connection(srv_conn, nt_errstr(status)); - return; + if (!srv_conn->session_info) { + status = auth_anonymous_session_info(srv_conn, + srv_conn->event.ctx, + srv_conn->lp_ctx, + &srv_conn->session_info); + if (!NT_STATUS_IS_OK(status)) { + DEBUG(0,("dcesrv_sock_accept: auth_anonymous_session_info failed: %s\n", + nt_errstr(status))); + stream_terminate_connection(srv_conn, nt_errstr(status)); + return; + } } status = dcesrv_endpoint_connect(dcesrv_sock->dcesrv_ctx, srv_conn, dcesrv_sock->endpoint, - session_info, + srv_conn->session_info, srv_conn->event.ctx, srv_conn->msg_ctx, srv_conn->server_id,