-
-
Notifications
You must be signed in to change notification settings - Fork 4.2k
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
Pull Request: Refactor FastCGI Client into Separate Package (#4378) #6465
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Did a quick first pass. Thank you for working on this! With a few iterations I think we can merge something along these lines into the mainline.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry for my long delay on this.
The changes are looking good!
I have another thought now that I see this with fresh eyes -- let me know what you think.
logger *zap.Logger | ||
} | ||
|
||
func NewClient(conn net.Conn, logger *zap.Logger, stderr bool) client { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Being an exported function, this should probably return an exported type. Otherwise getting documentation on how to use it will be irritating.
If we don't want to export the client
type, maybe we can return an interface type instead, but honestly, given what NewClient()
is doing, I feel like we could just export this as the Client
type and I dunno if we even need NewClient()
anymore.
Hi Caddy team,
Looking at the list of issues about FastCGI, I noticed a "help wanted SOS" issue #4378 requesting the FastCGI client be moved into its own package (pretty logic). And as I was already familiar with this codebase (because when I contributed in the v2.7.3 release, I read the whole package), I've prepared a pull request to address this issue. I hope to help you!
The Problem
Currently, the FastCGI client code is intertwined with Caddy's FastCGI implementation, making it harder to maintain (and read!) and potentially reuse the client elsewhere. This refactor aims to improve the code's organization and clarity.
The Solution
writer.go
,record.go
,reader.go
,pool.go
, andheader.go
are now in the fastcgiclient subpackage. They were non exportable auxiliar FastCGI client files.fastcgi.go
file in the subpackage just for clean handling the initialization of the noopLogger, previously a single line of thefastcgi.go
in the previous implementation. (This is a noopLogger, so it can be safely initialized inside the client, because it just discard the output, but we can now easily refactor the logging in a future)Testing
The majority of changes are fast revisable code edits and movements, easily verifiable using Git (they're mainly rename trackings and single lines). It do not change any code logic (I was careful about that).
To thoroughly test the changes, I successfully ran a WordPress site using a Caddy server with this modification. All functionality, including file uploads, API access, and GET/POST requests, worked seamlessly.
Closing Remarks
Well, I hope this solve the 3 years issue #4378 and makes the FastCGI codebase cleaner and more maintainable.
I'd hope to be included in the contributor list for the next release :)
Best regards,