1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-24 02:04:21 +03:00
Stefan Metzmacher ae38cfe6da s3:rpc_server: let get_servers() callback of rpc_worker_main() return NTSTATUS
This means the rpc_worker_main() logic is the only layer that
needs to call exit() and its able to do some cleanup before.

Signed-off-by: Stefan Metzmacher <metze@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
2023-10-17 19:20:38 +00:00

92 lines
2.4 KiB
C

/*
* Unix SMB/CIFS implementation.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, see <http://www.gnu.org/licenses/>.
*/
#include "includes.h"
#include "rpc_worker.h"
#include "lib/global_contexts.h"
#include "librpc/gen_ndr/ndr_spoolss.h"
#include "librpc/gen_ndr/ndr_spoolss_scompat.h"
#include "source3/locking/share_mode_lock.h"
#include "source3/printing/queue_process.h"
#include "source3/include/messages.h"
#include "source3/include/secrets.h"
#include "source3/smbd/proto.h"
static size_t spoolss_interfaces(
const struct ndr_interface_table ***pifaces,
void *private_data)
{
static const struct ndr_interface_table *ifaces[] = {
&ndr_table_spoolss,
};
*pifaces = ifaces;
return ARRAY_SIZE(ifaces);
}
static NTSTATUS spoolss_servers(
struct dcesrv_context *dce_ctx,
const struct dcesrv_endpoint_server ***_ep_servers,
size_t *_num_ep_servers,
void *private_data)
{
static const struct dcesrv_endpoint_server *ep_servers[1] = { NULL };
struct messaging_context *msg_ctx = global_messaging_context();
struct tevent_context *ev_ctx = messaging_tevent_context(msg_ctx);
bool ok;
ep_servers[0] = spoolss_get_ep_server();
ok = secrets_init();
if (!ok) {
DBG_ERR("secrets_init() failed\n");
return NT_STATUS_INTERNAL_ERROR;
}
ok = locking_init();
if (!ok) {
DBG_ERR("locking_init() failed\n");
return NT_STATUS_INTERNAL_ERROR;
}
lp_load_with_shares(get_dyn_CONFIGFILE());
ok = printing_subsystem_init(ev_ctx, msg_ctx, dce_ctx);
if (!ok) {
DBG_ERR("printing_subsystem_init() failed\n");
return NT_STATUS_INTERNAL_ERROR;
}
mangle_reset_cache();
*_ep_servers = ep_servers;
*_num_ep_servers = ARRAY_SIZE(ep_servers);
return NT_STATUS_OK;
}
int main(int argc, const char *argv[])
{
return rpc_worker_main(
argc,
argv,
"rpcd_spoolss",
5,
60,
spoolss_interfaces,
spoolss_servers,
NULL);
}