From: Jonatan Schlag <jonatan.schlag@ipfire.org>
To: network@lists.ipfire.org
Subject: [PATCH] ipsec-pool: do not delete a pool when this pool is used by a connection
Date: Thu, 24 Aug 2017 12:12:15 +0200 [thread overview]
Message-ID: <1503569535-5228-1-git-send-email-jonatan.schlag@ipfire.org> (raw)
[-- Attachment #1: Type: text/plain, Size: 1422 bytes --]
Fixes: #11448
Signed-off-by: Jonatan Schlag <jonatan.schlag(a)ipfire.org>
---
src/functions/functions.ipsec-pool | 26 ++++++++++++++++++++++++++
1 file changed, 26 insertions(+)
diff --git a/src/functions/functions.ipsec-pool b/src/functions/functions.ipsec-pool
index e5da518..f7d73f6 100644
--- a/src/functions/functions.ipsec-pool
+++ b/src/functions/functions.ipsec-pool
@@ -219,6 +219,27 @@ ipsec_pool_new() {
fi
}
+ipsec_pool_is_in_use() {
+ [ $# -eq 1 ]
+ local pool="${1}"
+
+ for connection in $(ipsec_list_connections); do
+ local POOLS
+
+ if ! ipsec_connection_read_config "${connection}" "POOLS"; then
+ log WARNING "Could not read configuration"
+ continue
+ fi
+
+ if list_match "${pool}" ${POOLS}; then
+ return ${EXIT_TRUE}
+ break
+ fi
+ done
+
+ return ${EXIT_FALSE}
+}
+
# Function that deletes based on the passed parameters
# one ore more vpn ipsec pools
ipsec_pool_destroy() {
@@ -229,6 +250,11 @@ ipsec_pool_destroy() {
continue
fi
+ if ipsec_pool_is_in_use "${pool}"; then
+ log ERROR "The VPN IPsec pool is in use an can thats why not deleted"
+ return ${EXIT_ERROR}
+ fi
+
if [ -f "${NETWORK_IPSEC_SWANCTL_POOLS_DIR}/${pool}.conf" ]; then
if ! file_delete "${NETWORK_IPSEC_SWANCTL_POOLS_DIR}/${pool}.conf"; then
# We going on here to delete at least the configuration directory
--
2.6.3
reply other threads:[~2017-08-24 10:12 UTC|newest]
Thread overview: [no followups] expand[flat|nested] mbox.gz Atom feed
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1503569535-5228-1-git-send-email-jonatan.schlag@ipfire.org \
--to=jonatan.schlag@ipfire.org \
--cc=network@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox