diff options
Diffstat (limited to 'source3/smbd')
-rw-r--r-- | source3/smbd/proto.h | 4 | ||||
-rw-r--r-- | source3/smbd/server.c | 2 | ||||
-rw-r--r-- | source3/smbd/server_reload.c | 21 |
3 files changed, 19 insertions, 8 deletions
diff --git a/source3/smbd/proto.h b/source3/smbd/proto.h index d271d7f043..8edd69507c 100644 --- a/source3/smbd/proto.h +++ b/source3/smbd/proto.h @@ -964,8 +964,8 @@ void init_sec_ctx(void); struct event_context *smbd_event_context(void); struct messaging_context *smbd_messaging_context(void); struct memcache *smbd_memcache(void); -void reload_printers(struct tevent_context *ev, - struct messaging_context *msg_ctx); +void delete_and_reload_printers(struct tevent_context *ev, + struct messaging_context *msg_ctx); bool reload_services(struct messaging_context *msg_ctx, int smb_sock, bool test); void exit_server(const char *const explanation); diff --git a/source3/smbd/server.c b/source3/smbd/server.c index 26e3c86edf..ecda47c644 100644 --- a/source3/smbd/server.c +++ b/source3/smbd/server.c @@ -88,7 +88,7 @@ static void smb_pcap_updated(struct messaging_context *msg, DEBUG(10,("Got message saying pcap was updated. Reloading.\n")); change_to_root_user(); - reload_printers(ev_ctx, msg); + delete_and_reload_printers(ev_ctx, msg); } /******************************************************************* diff --git a/source3/smbd/server_reload.c b/source3/smbd/server_reload.c index 6639c4a8f6..0c2ea2c5b1 100644 --- a/source3/smbd/server_reload.c +++ b/source3/smbd/server_reload.c @@ -31,11 +31,22 @@ #include "messages.h" #include "lib/param/loadparm.h" -/**************************************************************************** - purge stale printers and reload from pre-populated pcap cache -**************************************************************************/ -void reload_printers(struct tevent_context *ev, - struct messaging_context *msg_ctx) +/** + * @brief Purge stale printers and reload from pre-populated pcap cache. + * + * This function should normally only be called as a callback on a successful + * pcap_cache_reload() or after a MSG_PRINTER_CAP message is received. + * + * This function can cause DELETION of printers and drivers from our registry, + * so calling it on a failed pcap reload may REMOVE permanently all printers + * and drivers. + * + * @param[in] ev The event context. + * + * @param[in] msg_ctx The messaging context. + */ +void delete_and_reload_printers(struct tevent_context *ev, + struct messaging_context *msg_ctx) { struct auth_session_info *session_info = NULL; struct spoolss_PrinterInfo2 *pinfo2 = NULL; |