Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix CLN service startup failure by trimming trailing spaces in config parameters #7251

Merged
merged 2 commits into from
Aug 10, 2024

Conversation

maxrantil
Copy link
Collaborator

@maxrantil maxrantil commented Apr 22, 2024

fixes #7132

I would really appreciate some friendly feedback on this, as it is my first PR to the project and I might have misunderstood or missed important details.

I did find a similar function strip_trailing_whitespace in plugins/bcli.c, but from what I understand, having void trim_trailing_spaces(char *str); in ccan would still be beneficial, right?

Copy link
Contributor

@vincenzopalazzo vincenzopalazzo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for this, looks good to me

I was wondering if it is possible move this trim function inside tal string https://github.com/rustyrussell/ccan/blob/master/ccan/tal/str/str.h

@maxrantil
Copy link
Collaborator Author

I was wondering if it is possible move this trim function inside tal string https://github.com/rustyrussell/ccan/blob/master/ccan/tal/str/str.h

Do you mean to also change the function to use tal for allocating memory for the lines then? I thought it was not necessary since they were already allocated, but I can of course fix that if it is desirable. @vincenzopalazzo

@vincenzopalazzo
Copy link
Contributor

Do you mean to also change the function to use tal for allocating memory for the lines then?

No I mean to have like tal_strtrim or strtrim (not in tal), at the end of the day your code is implementing a subset of functionality to trim an origin string.

@maxrantil
Copy link
Collaborator Author

maxrantil commented Apr 24, 2024

Pardon me, but I don't fully understand what you mean. Could you elaborate on your suggestion? To my understanding, the tal functions you are linking to, @vincenzopalazzo , relate to string functions involving memory allocation. If I were to implement tal_strtrim(), from my experience, those implementations remove spaces from the beginning and end and allocate a new string. Is that what you are aiming for here? The current placement of the function trim_trailing_spaces() in ccan/ccan/str/str.c made sense to me because it manipulates an already allocated string.
Like I said at the beginning, I am new here and would appreciate a more thorough explanation if you have time for that.

Copy link
Collaborator

@endothermicdev endothermicdev left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice PR! It's a neat solution to the problem. I agree with Vincenzo - so long as a ccan library is being modified, it would be nice to go ahead and trim the leading whitespace too and resize the buffer (which would make this a tal/str operation). It's not a significant difference in this case, but it could be more useful for the library. I'm okay with either approach.

@maxrantil
Copy link
Collaborator Author

Thanks for the comment @endothermicdev, I'll start doing a strtrim function in tal tomorrow if you both think that is more useful then 👍

@maxrantil maxrantil force-pushed the max/config-trim-spaces branch from a1f61f0 to 73363f8 Compare May 16, 2024 09:30
@maxrantil
Copy link
Collaborator Author

@vincenzopalazzo & @endothermicdev , I've now changed to using tal_strtrim, is this what you had in mind?

@maxrantil maxrantil force-pushed the max/config-trim-spaces branch 4 times, most recently from e0cbfa2 to 3c829f0 Compare May 23, 2024 10:44
@maxrantil
Copy link
Collaborator Author

maxrantil commented May 23, 2024

@endothermicdev I am having some issues with tests on my local machine using tal_resize like this.
Is there anything in the way I am using it now, that you can see, is not working like it should? I get some out of memory errors from within the tal_resize() on my machine but the tests seems to run fine here in github-actions...
I am working on writing a test for it that I will push with the PR.

@maxrantil maxrantil force-pushed the max/config-trim-spaces branch from 3c829f0 to 22314d3 Compare May 23, 2024 14:38
@maxrantil
Copy link
Collaborator Author

maxrantil commented May 23, 2024

The local test I have tried is to add a space after a config varible in the startup_regtest.sh file and then sourced it and start_ln 2.

@maxrantil maxrantil force-pushed the max/config-trim-spaces branch 4 times, most recently from c8b062d to 9504f5d Compare May 27, 2024 08:34
@maxrantil
Copy link
Collaborator Author

If someone could have a look at the pytest and tell me if something is wrong in it, that would be appreciated.

@rustyrussell
Copy link
Contributor

Hi @maxrantil sorry this has been so long before I review!

The concept is great, the implementation needs some work though.

There are a few config options where we don't want to trim whitespace. In particular, log-prefix, and alias but you could also argue for things that take paths, such log-file, lightning-dir, pid-file ,conf etc. But I'm happy to just stick with log-prefix and alias.

  1. This implies that we should add a new flag, OPT_KEEP_WHITESPACE in common/configvar.h, and trim cv->optarg in common/configvar.c before calling return ot->cb_arg(cv->optarg, ot->u.arg); unless (ot->type & OPT_KEEP_WHITESPACE).
  2. Add this flag to those options which need to preserve whitespace.
  3. Trimming whitespace is trivial, you should simply do it by replacing the final space with a NUL terminator:
while (strlen(s) != 0 && cisspace(s[strlen(s)-1])
    s[strlen(s)-1] = '\0';
  1. We should note in doc/lightningd-config.5.md: "Because it's a common error, we automatically trim whitespace from the end of most configuration options. Exceptions are noted below". And then note it in alias and log-prefix, and any others you do it to.

Thanks!

@rustyrussell rustyrussell self-assigned this Jul 10, 2024
@rustyrussell rustyrussell added this to the v24.08 milestone Jul 10, 2024
@maxrantil
Copy link
Collaborator Author

Hi @rustyrussell ,
Thanks for the feedback! I didn't notice the review until now but I will get into it asap.

@maxrantil maxrantil force-pushed the max/config-trim-spaces branch 6 times, most recently from 0cd4f10 to bb11af4 Compare August 7, 2024 22:29
@maxrantil maxrantil force-pushed the max/config-trim-spaces branch 8 times, most recently from 8205779 to 7ef7407 Compare August 8, 2024 08:47
@maxrantil
Copy link
Collaborator Author

@rustyrussell or @endothermicdev , do you find it acceptable to manipulate a const char * with memmove() like I do in the trimming func??

@rustyrussell
Copy link
Contributor

Given how close we are to rc1, I simply added a commit with various cleanups. Thanks for this work!

maxrantil and others added 2 commits August 9, 2024 10:54
1) We can't simply cast away const to manipulate a string, the compiler can assume
   we don't.  The type must be made non-const.
2) cisspace() is nicer to use than isspace() (no cast required!)
3) Simply place a NUL terminator instead of using memmove to set it.
4) Use cast_const to add const to char **, where necessary.
5) Add Changelog line, for CHANGELOG.md

Changelog-Fixed: Config: whitespace at the end of (most) options is now ignored, not complained about.
Signed-off-by: Rusty Russell <[email protected]>
@maxrantil maxrantil force-pushed the max/config-trim-spaces branch from 3bc3f0b to 2a234b2 Compare August 9, 2024 08:54
@maxrantil
Copy link
Collaborator Author

That's fine @rustyrussell ! I learned some new things from studying your changes.

I'm not sure how to fix the error in the test that is failing now, tho.

@rustyrussell rustyrussell merged commit 62f531a into ElementsProject:master Aug 10, 2024
33 of 37 checks passed
@rustyrussell
Copy link
Contributor

THose issues were from master, fortunately!

@maxrantil
Copy link
Collaborator Author

Is there any chance of getting the sphinx bounty of 100k sats for this? 😊 I can't get Sphinx Chat to work with Core lightning on my umbrel node. Is there another way to get the payout if i am eligible for it?

@BitcoinJiuJitsu
Copy link

DM sent to @max54302324

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Minor issue/question: Trailing spaces in Config file parameter make CLN fail to start
5 participants