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

Support environment variable to hide broadcasted raw transactions. #30717

Open
tornadocontrib opened this issue Nov 2, 2024 · 6 comments
Open

Comments

@tornadocontrib
Copy link

Hello.

Since I have no kind of fetish or voyeurism of spying broadcasted raw transactions though local node it would be great if we have any kind of ENV variable or command line option to not list those on local console output.

I thought about disabling console logs but since I need info about peer connections or imported blocks it wouldn't be possible to hide the log about txid without hiding all those info.

I know that it would be best to run a local node but since nodes require decent connections have no choice but to host them on remote location.

But I don't want to store those info about broadcasted transactions since I am not a fed, biden or macron.

I mean, it would be like 2~3 additional lines to https://github.com/ethereum/go-ethereum/blob/master/internal/ethapi/api.go#L1570 which should hide those logs right?

@namiloh
Copy link

namiloh commented Nov 2, 2024

Hadn't considered it before, but yes, I agree that we should not log this by default.

However, it is extremely useful to see the address of a contract about to be created, particularly in dev-mode when debugging.

Open to suggestions for how to both provide nice UX and be a bit less leaky-to-logs. I think using envvars sound a bit too clunky.

@MariusVanDerWijden
Copy link
Member

I think you can try to do a debug.vmodule("internal/ethapi/api.go=0") to get rid of the Submitted transaction log

@tornadocontrib
Copy link
Author

@MariusVanDerWijden It would be hard to check if the logs are on or off programmatically ( Also integrating IPC connection are not easy ). Would it be possible to support it on config or command line options?

@holiman
Copy link
Contributor

holiman commented Nov 13, 2024

Would it be possible to support it on config or command line options?

Right, so @MariusVanDerWijden 's suggestion would work. Should be something like --log.vmodule=internal/ethapi/api.go=0 (0 is silent in legacy verbosity).

EDIT: This is wrong

@holiman
Copy link
Contributor

holiman commented Nov 13, 2024

Sorry, but that's not how it works. The vmodule pkg-specfic log filter works like this:

filtering a log record through the global, local and backtrace filters, finally emitting it if either allow it through.

So, if the global log level (INFO) allows it, then the message will be allowed through. The vmodule can thus only be used to increase the verbosity, not to filter it.

Tangentially, the vmodule is very difficult to use, now that we have a mishmash of legacy loglevels and slog loglevels. I think the vmodule loglevel is not quite correctly translated.

@holiman
Copy link
Contributor

holiman commented Dec 12, 2024

Coming back to this... Yeah, I'd be fine with having an envvar for this, personally.

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

No branches or pull requests

4 participants