From 11f1c9adcaeb4077c4fdab120eb6197795a2a872 Mon Sep 17 00:00:00 2001 From: Matthias Schiffer Date: Fri, 8 Mar 2013 20:25:17 +0100 Subject: Allow disabling previously enabled peers --- src/fastd.c | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) (limited to 'src/fastd.c') diff --git a/src/fastd.c b/src/fastd.c index fec0838..59a99ab 100644 --- a/src/fastd.c +++ b/src/fastd.c @@ -616,15 +616,24 @@ static void delete_peer_groups(fastd_context_t *ctx) { static void init_peers(fastd_context_t *ctx) { fastd_peer_config_t *peer_conf; for (peer_conf = ctx->conf->peers; peer_conf; peer_conf = peer_conf->next) { - if (peer_conf->enabled) - continue; + bool was_enabled = peer_conf->enabled; peer_conf->enabled = true; ctx->conf->protocol->peer_configure(ctx, peer_conf); - if (peer_conf->enabled) + if (peer_conf->enabled && !was_enabled) fastd_peer_add(ctx, peer_conf); } + + fastd_peer_t *peer, *next; + for (peer = ctx->peers; peer; peer = next) { + next = peer->next; + + if (!peer->config->enabled) { + pr_info(ctx, "previously enabled peer %P disabled, deleting.", peer); + fastd_peer_delete(ctx, peer); + } + } } static void delete_peers(fastd_context_t *ctx) { -- cgit v1.2.3