From: Jonatan Schlag <jonatan.schlag@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: [PATCH 2/5] functions.network: Add network_zone_exists
Date: Mon, 25 Mar 2024 08:46:23 +0100 [thread overview]
Message-ID: <2350d396d241a39e6dc1acd142d952bf@ipfire.org> (raw)
In-Reply-To: <124D11E4-5BDC-4D89-9CA5-5F42FE8E6369@ipfire.org>
[-- Attachment #1: Type: text/plain, Size: 12017 bytes --]
Am 2024-03-18 17:27, schrieb Michael Tremer:
> Hello,
>
>> On 16 Mar 2024, at 09:35, Jonatan Schlag <jonatan.schlag(a)ipfire.org>
>> wrote:
>>
>> Hi Michael,
>>
>> Am 2024-03-12 11:32, schrieb Michael Tremer:
>>> Hello Jonatan,
>>>> On 8 Mar 2024, at 11:14, Jonatan Schlag <jonatan.schlag(a)ipfire.org>
>>>> wrote:
>>>> Hi,
>>>> Tl;dr:
>>>> It is not sensible to duplicate code in bash and the setup command.
>>>> There should be one source for checking a network config. The
>>>> minimal
>>>> should be done in Bash. If C is the right language to go is another
>>>> question.
>>> I believe that you will have to duplicate a couple of things quite a
>>> bit. We use three different languages to implement the network
>>> configuration scripts, the management utility and the web UI. That
>>> means: Bash, C, and Perl.
>>> If we were going really bug there could be some benefit in writing a
>>> single C library with the logic and exposing that to Perl and Bash,
>>> but that would be a lot more work that we are willing to invest into
>>> this project right now.
>>
>> Would you still be OK, if I write some port for examples as loadable
>> for bash? Or do you want everything in Bash?
>
> Which parts would that be? I cannot think of anything that would be
> better implemented in something else.
>
> Let me know what you have in mind and we will discuss.
>
Reusing the function here
https://git.ipfire.org/?p=ipfire-2.x.git;a=blob;f=src/libsmooth/varval.c;hb=08b7500b267a54aa634fb34b67b4dfc0934ae2be#l46
and creating a bash loadable so that I can do
readkeyvalues FILE ARRAY_NAME
and subsequently, access the data like
echo ${ARRY_NAME["GREEN_DEV"]}
So we stay bug compatible and reusing code which we use already in
several other places.
>>>> After thought about this whole situation a little bit more, I came
>>>> to
>>>> the conclusion that we need a better solution here. So what are the
>>>> problems with this patch and the current situation:
>>> Better solution to what? I am not entirely sure where you are going
>>> with all of this.
>>
>> For reading and checking our network configuration.
>
> Reading it is not a problem as we have a script for that.
We currently do an eval on the file. I would not call this a script. Or
am I missing something.
>
> Checking? I think you need to be a little bit more clear.
>
Check for correct IP addresses and so on. I would like to avoid that the
setup utility lets you save an IP address with the bash script fails on.
So, the best way to do this: using the same function to check the
network config.
>>>> * We need to check for a correct network configuration before we
>>>> start
>>>> it and when a user edits it. The editing is done via /usr/sbin/setup
>>>> which is a C program from 2001. The startup is done via a shell
>>>> script. It is a bad idea, as we learned from ipfire-3.x, to have a
>>>> duplicated code in two languages. So it is a bad idea two write
>>>> shell
>>>> functions to check for a valid network config and C functions. There
>>>> needs to be one way to check for a valid network config.
>>> setup is probably slightly older than 2001 :)
>>> As mentioned above, I don’t think this will hurt us too bad here
>>> because the complexity of the network stack in IPFire 2 is
>>> substantially smaller than IPFire 3. You will also only copy a very
>>> small subnet of the functionality which mainly is reading and writing
>>> the configuration. That is all. Depending on how you are splitting
>>> it, this could be less than a hand full of functions. That sounds
>>> very acceptable to me.
>>>> *Nearly everything can be programmed in Bash, but maybe not
>>>> everything
>>>> should. It may be the better approach to do only the network startup
>>>> with as minimal code as possible in Bash (calling ip from something
>>>> else with something like system() is a bad idea.) Checking and
>>>> parsing
>>>> a config file is perhaps better to be done in other languages. After
>>>> we
>>>> parsed a config file and checked the content for validity, we could,
>>>> for example, export the necessary information as environment
>>>> variables.
>>>> Basically, we do the same thing here, as eval "parses" the config
>>>> and
>>>> export variables:
>>>> https://git.ipfire.org/?p=ipfire-2.x.git;a=blob;f=src/initscripts/networking/any;h=dc4796e914536dae03b70390e9447b3bb2bf127b;hb=refs/heads/next#l24
>>> Apart from copying variables back and forth this should not be the
>>> worst bit of code we have here.
>>
>> No, it is not. My point was, more, that I need to redefine which
>> CONFIG_TYPE is what. I would like to avoid that.
>
> I think there is no way to avoid that.
>
> I believe that there would be a huge benefit from checking the entire
> code base for this. We would be able to open a couple of extra doors
> for the future this way.
Checking the entire code base for what?
>
>>> Bash is a great language for these things. Can it be done better?
>>> Yes, but you are not seriously considering to do a full rewrite of
>>> everything in C, are you?
>>
>> Not a full rewrite. But If I can program a function in C or in Bash
>> and maybe reuse some Code of the installer in C, I would like to use
>> C.
>>
>>>> * Bash has somehow limited tooling, for example for testing. There
>>>> are
>>>> other languages like python and pytest, so we have to write less
>>>> code.
>>>> It is pointless to write a testing framework for ourselves in Bash.
>>> To test a bash function, you need a bash script. There is nothing
>>> else required.
>>
>> Short: No. This is not the way of testing I know and thought about. I
>> need at least covering reports. There seem to be some alternatives
>> around here: https://github.com/bats-core/bats-core . Still C has more
>> of these tools like https://gcc.gnu.org/onlinedocs/gcc/Gcov.html
>> because more people use it in bigger project where these tools are
>> needed.
>>
>>>> *This patch duplicates code which is somehow also found here:
>>>> https://git.ipfire.org/?p=ipfire-2.x.git;a=blob;f=src/setup/networking.c;h=9dd5205e5a1cb60c4a0bb003ec2a8348848822f9;hb=refs/heads/next#l37
>>> This is not a duplicate. This is the only place where the network
>>> card assignment happens.
>>
>> Still, the same code is in bot my bash function and in the c function.
>>
>>>> So what do I propose. This is a rough sketch, not a detailed plan:
>>>> There should be a program which I can call from bash, which:
>>> *script
>>
>> Do you, insist on script?
>>
>>>> * checks for the validity of the network config
>>>> * exports all variables which are valid.
>>>> The same config check should be used in the program which users use
>>>> to
>>>> edit the network settings and in the web interface to change the
>>>> zone
>>>> settings. The language for this program should not be Bash. What
>>>> language should be used largely depends on preferences. I can
>>>> program
>>>> in C, but I try to avoid it when there is no reason, like
>>>> performance.
>>>> A program in an interpreter language with enough tests, which are
>>>> easy
>>>> to write when you only need to mock a config file, is equally
>>>> stable.
>>>> But before this discussion starts, I would like to gather some
>>>> opinions
>>>> on the general thoughts a wrote down, here.
>>> You want to write shell scripts here. Nothing else, because you will
>>> run into new headaches:
>>> * You have a lot of shell scripts that execute the boot process, run
>>> daemons and what not. You don’t want to touch those, so you will have
>>> to be compatible.
>>
>> The plan was not to rewrite everything in c. Maybe having something
>> like
>> https://git.savannah.gnu.org/cgit/bash.git/tree/examples/loadables/csv.c
>> to load the file and check it for error. The rest would still be Bash.
>
> You would have to write a parser that is entirely bug-compatible with
> what we are using now. You don’t want to change even the smallest bit
> of the format because you won’t have a unique way across the entire
> distribution.
I already have a parser for this format here
https://git.ipfire.org/?p=ipfire-2.x.git;a=blob;f=src/libsmooth/varval.c;hb=08b7500b267a54aa634fb34b67b4dfc0934ae2be#l46
>
> If you want to write network code in C send patches for this:
> https://git.ipfire.org/?p=network.git;a=summary
No, I am not keen on writing C. It appears to be not avoidable here, but
I still don't like it here. But back then C was the way to go. It is not
now any more.
>
>>> * You will have to rewrite all sorts of callback scripts for DHCP and
>>> PPP. You don’t want to do that.
>> No, I would rather not do that.
>>
>>> * Shell can be written quickly.
>>> * You already have some functionality there which is working
>>> perfectly fine. Why would you want to rewrite something that already
>>> works so well?
>>
>>> * I believe that the IPFire 3 code shows that you can write large
>>> projects in shell. They work well and shell would cover everything we
>>> need in IPFire 2.
>>
>> I would say after my experience, it proves the opposite. Small parts
>> can be perfectly written in shell. Dealing with config files there
>> validity and everything else is better done in another language.
>
> Yes, but not when 100% of the code is already there and it is written
> in Bash. You will have to write everything again instead of improving
> the 2% that are bothering you right now.
>
I must say this sentence still confuses me. On the one hand, I try to
rewrite small parts, and you answer with the whole script needs a
rewrite. Here you seem to more at the line of rewrite as few as
possible.
Jonatan
>>> In order to get to some sort of milestone, I believe that we need to
>>> work with what we have and incrementally improve it. If you want to
>>> work on a total rewrite, please look at IPFire 3 and not IPFire 2.
>>
>> That's why I only send 5 patches. Would not say this is a total
>> rewrite. Even with C I would create a loadable for zone_exists and the
>> rest would be the same. I would only use the same C Code.
>>
>> Jonatan
>>
>>> -Michael
>>>> Greetings
>>>> Jonatan
>>>> Am Samstag, dem 02.03.2024 um 12:09 +0100 schrieb Jonatan Schlag:
>>>>> As our Network is quite static a case does the trick
>>>>> Signed-off-by: Jonatan Schlag <jonatan.schlag(a)ipfire.org>
>>>>> ---
>>>>> src/initscripts/networking/functions.network | 22
>>>>> ++++++++++++++++++++
>>>>> 1 file changed, 22 insertions(+)
>>>>> diff --git a/src/initscripts/networking/functions.network
>>>>> b/src/initscripts/networking/functions.network
>>>>> index dedbb6f7f..ad0d3f36a 100644
>>>>> --- a/src/initscripts/networking/functions.network
>>>>> +++ b/src/initscripts/networking/functions.network
>>>>> @@ -289,3 +289,25 @@ qmi_assign_address() {
>>>>> # Change the MAC address
>>>>> ip link set "${intf}" address "${address}"
>>>>> }
>>>>> +
>>>>> +network_zone_exists(){
>>>>> + local zone="${1}"
>>>>> +
>>>>> + case "${zone}" in
>>>>> + "blue")
>>>>> + [ "${CONFIG_TYPE}" = "3" ] || [
>>>>> "${CONFIG_TYPE}" = "4" ]
>>>>> + ;;
>>>>> + "green")
>>>>> + [ -n "${GREEN_DEV}" ] && [ -v "GREEN_DEV" ]
>>>>> + ;;
>>>>> + "orange")
>>>>> + [ "${CONFIG_TYPE}" = "2" ] || [
>>>>> "${CONFIG_TYPE}" = "4" ]
>>>>> + ;;
>>>>> + "red")
>>>>> + return ${EXIT_TRUE}
>>>>> + ;;
>>>>> + *)
>>>>> + return ${EXIT_FALSE}
>>>>> + ;;
>>>>> + esac
>>>>> +}
next prev parent reply other threads:[~2024-03-25 7:46 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-03-02 11:09 [PATCH 1/5] functions.network: Add proper Exit Codes Jonatan Schlag
2024-03-02 11:09 ` [PATCH 2/5] functions.network: Add network_zone_exists Jonatan Schlag
2024-03-08 11:14 ` Jonatan Schlag
2024-03-12 10:32 ` Michael Tremer
2024-03-16 9:35 ` Jonatan Schlag
2024-03-18 16:27 ` Michael Tremer
2024-03-25 7:46 ` Jonatan Schlag [this message]
2024-03-25 10:55 ` Michael Tremer
2024-03-12 9:59 ` Michael Tremer
2024-03-16 9:43 ` Jonatan Schlag
2024-03-18 16:32 ` Michael Tremer
2024-03-25 7:55 ` Jonatan Schlag
2024-03-25 11:01 ` Michael Tremer
2024-03-02 11:09 ` [PATCH 3/5] network initscript: Use network_zone_exists Jonatan Schlag
2024-03-11 17:02 ` Michael Tremer
2024-03-16 9:46 ` Jonatan Schlag
2024-03-16 11:25 ` Michael Tremer
2024-03-02 11:09 ` [PATCH 4/5] network initscript: Avoid an infinite loop Jonatan Schlag
2024-03-02 11:09 ` [PATCH 5/5] network initscript: drop unused variable Jonatan Schlag
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=2350d396d241a39e6dc1acd142d952bf@ipfire.org \
--to=jonatan.schlag@ipfire.org \
--cc=development@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