public inbox for network@lists.ipfire.org
 help / color / mirror / Atom feed
From: Michael Tremer <michael.tremer@ipfire.org>
To: network@lists.ipfire.org
Subject: Re: [PATCH 1/3] Add new function: device_get_by_assigned_ip_address()
Date: Sat, 24 Feb 2018 11:50:16 +0000	[thread overview]
Message-ID: <1519473016.5664.7.camel@ipfire.org> (raw)
In-Reply-To: <1519383935-3556-1-git-send-email-jonatan.schlag@ipfire.org>

[-- Attachment #1: Type: text/plain, Size: 1719 bytes --]

Hello,

what happens when the same IP address is assigned to multiple interfaces?

That should not be because it doesn't make much sense, but people configure
stupid things and we should make sure that that doesn't crash other parts of
networking.

-Michael

On Fri, 2018-02-23 at 11:05 +0000, Jonatan Schlag via network wrote:
> This function is used to get a device from an IP address
> which is assigned to the device.
> This function needs to be introduced
> to set the routes for IPsec correctly.
> 
> Signed-off-by: Jonatan Schlag <jonatan.schlag(a)ipfire.org>
> ---
>  src/functions/functions.device | 27 +++++++++++++++++++++++++++
>  1 file changed, 27 insertions(+)
> 
> diff --git a/src/functions/functions.device b/src/functions/functions.device
> index cb4911f..2de1ad9 100644
> --- a/src/functions/functions.device
> +++ b/src/functions/functions.device
> @@ -1058,3 +1058,30 @@ device_queue_set_smp_affinity() {
>  
>  	__processor_id_to_bitmap ${processor} > ${path}
>  }
> +
> +# Tries to find a device which has the given IP address assigned
> +device_get_by_assigned_ip_address() {
> +	local ip=${1}
> +
> +	assert isset ip
> +
> +	local device
> +
> +	# Read the first line of ip addr show to
> +	read -r device <<< $(ip addr show to "${ip}")
> +
> +	# If we did not found a device we return with ${EXIT_ERROR}
> +	if ! isset device; then
> +		return ${EXIT_ERROR}
> +	fi
> +
> +	# We get something like:
> +	# 3: upl0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state
> UP group default qlen 1000
> +	# and we want upl0 so we take the second word and removing the :
> +	device=(${device})
> +	device=${device[1]}
> +	device=${device%:}
> +
> +	print "${device}"
> +	return ${EXIT_OK}
> +}

      parent reply	other threads:[~2018-02-24 11:50 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-02-23 11:05 Jonatan Schlag
2018-02-23 11:05 ` [PATCH 2/3] Add new function ip_get__assigned_addresses_from_net() Jonatan Schlag
2018-02-24 11:53   ` Michael Tremer
2018-02-23 11:05 ` [PATCH 3/3] IPsec: Log the content of all PLUTO variables in debug mode Jonatan Schlag
2018-02-24 11:54   ` Michael Tremer
2018-02-24 11:50 ` Michael Tremer [this message]

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=1519473016.5664.7.camel@ipfire.org \
    --to=michael.tremer@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