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

cln-plugin: Save "configuration" from "init" method #5279

Merged
merged 4 commits into from
Jun 22, 2022
Merged

cln-plugin: Save "configuration" from "init" method #5279

merged 4 commits into from
Jun 22, 2022

Conversation

justinmoon
Copy link
Contributor

@justinmoon justinmoon commented May 20, 2022

cln-plugin throws away the "configuration" field from the "init" message.

@justinmoon
Copy link
Contributor Author

justinmoon commented May 20, 2022

Added a unittest as separate commit to make sure the "init" message (used this example) can be parsed. Not sure if this is helpful or not.

@justinmoon justinmoon marked this pull request as ready for review May 20, 2022 23:48
@justinmoon justinmoon requested a review from cdecker as a code owner May 20, 2022 23:48
pub struct Configuration {
#[serde(rename = "lightning-dir")]
pub lightning_dir: String,
}
Copy link
Contributor Author

Choose a reason for hiding this comment

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

If we keep this struct, what else should go in it?

Copy link
Contributor

Choose a reason for hiding this comment

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

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.

overall LGTM, just take a decision if we want use an HasMap or a Struct for the configuration

plugins/src/lib.rs Show resolved Hide resolved
@cdecker
Copy link
Member

cdecker commented May 21, 2022

overall LGTM, just take a decision if we want use an HasMap or a Struct for the configuration

As you mentioned above making these things we have control over as strongly typed as possible would be a good idea. So I'd vote in favor of the Configuration struct 👍

@justinmoon
Copy link
Contributor Author

Added the rest of the fields to Configuration mostly copying from rust-clightning-rpc as suggested by @vincenzopalazzo. I prefer the strongly typed struct too.

@vincenzopalazzo
Copy link
Contributor

It is missing the Changelog in the body commit, maybe Changelog-Added: cln_plugin: take into consideration the cln configuration from init msg can be a good description?

@justinmoon
Copy link
Contributor Author

Added changelog entry @vincenzopalazzo

@rustyrussell
Copy link
Contributor

BTW I've invited you to project as a reader. This should mean CI runs for you...

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.

Only a small comment, and LGTM.

With the next commit, we will see with the CI will be happy!

plugins/src/messages.rs Outdated Show resolved Hide resolved
Represents the "configuration" part of the "init" message during
plugin initialization.

Changelog-Added: cln_plugin: persist cln configuration from init msg
@justinmoon
Copy link
Contributor Author

justinmoon commented Jun 21, 2022

The tests seem to be failing because this match is failing with my Configuration struct. But AFAIKT my unittest does exactly the same match and it works.

In my unittest I'm using exactly this JSON and it passes. Why is it failing in the python test in CI?

It does seem that the example JSON in the link above is different from what the CI test is sending. For example, the always_use_proxy value, for example, is missing in CI.

These are only populated if a proxy was specified, see
lightningd/plugin.c:1855, so we were getting upset when we expected
them and they weren't set.
@cdecker
Copy link
Member

cdecker commented Jun 22, 2022

ACK 9e912f8

@cdecker cdecker merged commit e6442d7 into ElementsProject:master Jun 22, 2022
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.

4 participants