s3:smbd: split smb_conf_updated into parent and child versions
authorStefan Metzmacher <metze@samba.org>
Wed, 14 Dec 2011 11:39:36 +0000 (12:39 +0100)
committerStefan Metzmacher <metze@samba.org>
Thu, 15 Dec 2011 10:03:00 +0000 (11:03 +0100)
metze

source3/smbd/process.c
source3/smbd/server.c

index e57faf197826a63face6f71ddd025a9a0308e57d..2b35680949b21531bdaa5e092e9ad07e967241c2 100644 (file)
@@ -925,6 +925,22 @@ void smbd_setup_sig_hup_handler(struct smbd_server_connection *sconn)
        }
 }
 
+static void smbd_conf_updated(struct messaging_context *msg,
+                             void *private_data,
+                             uint32_t msg_type,
+                             struct server_id server_id,
+                             DATA_BLOB *data)
+{
+       struct smbd_server_connection *sconn =
+               talloc_get_type_abort(private_data,
+               struct smbd_server_connection);
+
+       DEBUG(10,("smbd_conf_updated: Got message saying smb.conf was "
+                 "updated. Reloading.\n"));
+       change_to_root_user();
+       reload_services(sconn->msg_ctx, sconn->sock, False);
+}
+
 static NTSTATUS smbd_server_connection_loop_once(struct tevent_context *ev_ctx,
                                                 struct smbd_server_connection *conn)
 {
@@ -3254,6 +3270,11 @@ void smbd_process(struct tevent_context *ev_ctx,
        messaging_register(sconn->msg_ctx, sconn,
                           ID_CACHE_KILL, smbd_id_cache_kill);
 
+       messaging_deregister(sconn->msg_ctx,
+                            MSG_SMB_CONF_UPDATED, sconn->ev_ctx);
+       messaging_register(sconn->msg_ctx, sconn,
+                          MSG_SMB_CONF_UPDATED, smbd_conf_updated);
+
        /*
         * Use the default MSG_DEBUG handler to avoid rebroadcasting
         * MSGs to all child processes
index 7e1bddd23bf10422935b2ae77dc44384008db1d8..e58128ea58eae72a23c54612ffbbb206b065d45e 100644 (file)
@@ -87,23 +87,20 @@ extern int dcelogin_atmost_once;
  What to do when smb.conf is updated.
  ********************************************************************/
 
-static void smb_conf_updated(struct messaging_context *msg,
-                            void *private_data,
-                            uint32_t msg_type,
-                            struct server_id server_id,
-                            DATA_BLOB *data)
+static void smbd_parent_conf_updated(struct messaging_context *msg,
+                                    void *private_data,
+                                    uint32_t msg_type,
+                                    struct server_id server_id,
+                                    DATA_BLOB *data)
 {
        struct tevent_context *ev_ctx =
                talloc_get_type_abort(private_data, struct tevent_context);
-       struct smbd_server_connection *sconn = msg_ctx_to_sconn(msg);
 
-       DEBUG(10,("smb_conf_updated: Got message saying smb.conf was "
+       DEBUG(10,("smbd_parent_conf_updated: Got message saying smb.conf was "
                  "updated. Reloading.\n"));
        change_to_root_user();
-       reload_services(msg, sconn->sock, False);
-       if (am_parent) {
-               printing_subsystem_update(ev_ctx, msg, false);
-       }
+       reload_services(msg, -1, false);
+       printing_subsystem_update(ev_ctx, msg, false);
 }
 
 /*******************************************************************
@@ -801,7 +798,7 @@ static bool open_sockets_smbd(struct smbd_parent_context *parent,
 
        messaging_register(msg_ctx, NULL, MSG_SHUTDOWN, msg_exit_server);
        messaging_register(msg_ctx, ev_ctx, MSG_SMB_CONF_UPDATED,
-                          smb_conf_updated);
+                          smbd_parent_conf_updated);
        messaging_register(msg_ctx, NULL, MSG_SMB_STAT_CACHE_DELETE,
                           smb_stat_cache_delete);
        messaging_register(msg_ctx, NULL, MSG_DEBUG, smbd_msg_debug);