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

🔥 feat: Add support for AutoTLS / ACME #3201

Merged
merged 23 commits into from
Dec 10, 2024
Merged

Conversation

wangjq4214
Copy link
Member

@wangjq4214 wangjq4214 commented Nov 12, 2024

Description

Reduce the boilerplate of setting up AutoTLS / ACME by adding built-in support into Fiber. Whether this impl is good?

Fixes #3155

Changes introduced

  • Documentation Update: Detail the updates made to the documentation and links to the changed files.
  • Changelog/What's New: Include a summary of the additions for the upcoming release notes.

Type of change

Please delete options that are not relevant.

  • New feature (non-breaking change which adds functionality)
  • Documentation update (changes to documentation)

Copy link
Contributor

coderabbitai bot commented Nov 12, 2024

Warning

Rate limit exceeded

@gaby has exceeded the limit for the number of commits or files that can be reviewed per hour. Please wait 6 minutes and 33 seconds before requesting another review.

⌛ How to resolve this issue?

After the wait time has elapsed, a review can be triggered using the @coderabbitai review command as a PR comment. Alternatively, push new commits to this PR.

We recommend that you space out your commits to avoid hitting the rate limit.

🚦 How do rate limits work?

CodeRabbit enforces hourly rate limits for each developer per organization.

Our paid plans have higher rate limits than the trial, open-source and free plans. In all cases, we re-allow further reviews after a brief timeout.

Please see our FAQ for further information.

📥 Commits

Reviewing files that changed from the base of the PR and between 13f7aeb and dc11469.

📒 Files selected for processing (2)
  • docs/api/fiber.md (2 hunks)
  • docs/whats_new.md (34 hunks)

Walkthrough

The pull request introduces enhancements to the Fiber framework by adding support for automatic TLS certificate management through the AutoCertManager field in the ListenConfig struct. This field allows for the integration of the ACME protocol, facilitating automatic certificate management with providers like Let's Encrypt. Additionally, the documentation has been updated to reflect these changes, including new configuration options and methods for creating Fiber applications.

Changes

File Change Summary
listen.go Added AutoCertManager *autocert.Manager to ListenConfig. Updated Listen method to configure TLS settings based on AutoCertManager.
docs/api/fiber.md Updated documentation to include new New method for app creation and expanded ListenConfig options, including AutoCertManager.
docs/whats_new.md Documented significant updates for version 3, including removal of older Go version support and new customizable features.

Assessment against linked issues

Objective Addressed Explanation
Add built-in support for AutoTLS / ACME (#[3155])

Possibly related PRs

Suggested reviewers

  • sixcolors
  • ReneWerner87
  • efectn

🐇 In the meadow, where the bunnies play,
A new feature hops in, brightening the day.
With AutoCertManager, TLS is a breeze,
Let’s Encrypt's magic, bringing us ease.
So gather 'round, let’s cheer and delight,
For Fiber’s new changes, oh what a sight! 🌟


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@efectn
Copy link
Member

efectn commented Nov 12, 2024

Can we add several test-cases using https://letsencrypt.org/tr/docs/staging-environment/?

@wangjq4214
Copy link
Member Author

Can we add several test-cases using https://letsencrypt.org/tr/docs/staging-environment/?

Of course, do you think this change will meet the demand?

@gaby gaby changed the title feat: add a simple support for app.Listen 🔥 feat: Add support for AutoTLS / ACME Nov 12, 2024
@gaby gaby added the v3 label Nov 12, 2024
@gaby gaby added this to the v3 milestone Nov 12, 2024
listen.go Outdated Show resolved Hide resolved
listen.go Show resolved Hide resolved
@efectn
Copy link
Member

efectn commented Nov 12, 2024

Can we add several test-cases using https://letsencrypt.org/tr/docs/staging-environment/?

Of course, do you think this change will meet the demand?

I think it can. Otherwise it might be challenging to test the functionality.

listen_test.go Outdated Show resolved Hide resolved
listen_test.go Outdated Show resolved Hide resolved
listen.go Outdated Show resolved Hide resolved
listen_test.go Outdated Show resolved Hide resolved
can't passed and not chack the file yet
@ReneWerner87
Copy link
Member

  • add markdown for the added config
  • add markdown for an example in the markdown file
  • mention the new feature in the what´s new markdown

@grivera64
Copy link
Member

After the PR is merged, I think we could also update gofiber/recipes under the autocert recipe to use this feature.

listen.go Show resolved Hide resolved
listen_test.go Outdated Show resolved Hide resolved
listen_test.go Outdated Show resolved Hide resolved
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (1)
docs/api/fiber.md (1)

170-187: Enhance the AutoTLS documentation.

While the example is good, it could be improved by:

  1. Adding error handling for the certificate manager setup
  2. Including staging environment configuration for testing
  3. Documenting common pitfalls and requirements (e.g., port 80 must be available for ACME HTTP challenge)

Here's a suggested enhancement to the documentation:

 #### TLS AutoCert support (ACME / Let's Encrypt)

 Provides automatic access to certificates management from Let's Encrypt and any other ACME-based providers.
+
+:::note
+Requirements:
+- Port 80 must be available for the ACME HTTP challenge
+- Domain must be publicly accessible
+- Write permissions for the certificate cache directory
+:::

 ```go title="Examples"
+// For testing, use Let's Encrypt staging environment
+staging := autocert.Manager{
+    Prompt: autocert.AcceptTOS,
+    HostPolicy: autocert.HostWhitelist("example.com"),
+    Cache: autocert.DirCache("./certs"),
+    Client: &acme.Client{
+        DirectoryURL: "https://acme-staging-v02.api.letsencrypt.org/directory",
+    },
+}
+
 // Certificate manager
 certManager := &autocert.Manager{
     Prompt: autocert.AcceptTOS,
     // Replace with your domain name
     HostPolicy: autocert.HostWhitelist("example.com"),
     // Folder to store the certificates
     Cache: autocert.DirCache("./certs"),
 }
+
+// Handle certificate manager errors
+go func() {
+    log.Fatal(certManager.HTTPHandler(nil))
+}()

 app.Listen(":444", fiber.ListenConfig{
     AutoCertManager: certManager,
-}))
+})

</blockquote></details>

</blockquote></details>

<details>
<summary>📜 Review details</summary>

**Configuration used: CodeRabbit UI**
**Review profile: CHILL**

<details>
<summary>📥 Commits</summary>

Reviewing files that changed from the base of the PR and between 2996935703b4e6f25bbfe174491d9de850c95955 and b594117e6a8f6e3fd748fcbdfe0e222e6f876801.

</details>

<details>
<summary>📒 Files selected for processing (2)</summary>

* `docs/api/fiber.md` (2 hunks)
* `listen.go` (3 hunks)

</details>

<details>
<summary>🔇 Additional comments (4)</summary>

<details>
<summary>listen.go (3)</summary>

`26-26`: **LGTM!**

The import of the `autocert` package is required for the new AutoTLS functionality.

---

`74-78`: **LGTM!**

The `AutoCertManager` field is well-documented and properly typed. The JSON tag is correctly set.

---

`194-199`: **Consider adding support for custom TLS versions.**

The TLS configuration is correct, but the hardcoded `tls.VersionTLS12` might be too restrictive for some users. Consider making this configurable.



```shell
#!/bin/bash
# Description: Check if there are any existing TLS version configurations in the codebase

# Search for TLS version configurations
rg -A 2 'MinVersion.*=.*tls\.Version'

Note: I see this has been discussed in past review comments and issue #3239 has been created to track this enhancement.

docs/api/fiber.md (1)

117-117: LGTM!

The new OnShutdownSuccess and AutoCertManager fields are properly documented with clear descriptions and default values.

Also applies to: 119-119

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (1)
docs/whats_new.md (1)

923-923: Fix grammatical error in documentation.

Change "It should not be invoke concurrently" to "It should not be invoked concurrently".

🧰 Tools
🪛 LanguageTool

[grammar] ~923-~923: Consider using either the past participle “invoked” or the present participle “invoking” here.
Context: ...y in development mode. It should not be invoke concurrently. ### 🧠 Context Fiber v3...

(BEEN_PART_AGREEMENT)

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between b594117 and 90bd4cc.

📒 Files selected for processing (1)
  • docs/whats_new.md (33 hunks)
🧰 Additional context used
🪛 LanguageTool
docs/whats_new.md

[grammar] ~923-~923: Consider using either the past participle “invoked” or the present participle “invoking” here.
Context: ...y in development mode. It should not be invoke concurrently. ### 🧠 Context Fiber v3...

(BEEN_PART_AGREEMENT)

🔇 Additional comments (3)
docs/whats_new.md (3)

178-193: LGTM! Well-structured route chaining example.

The code example effectively demonstrates the new route chaining API with proper error handling and JSON responses.


212-213: LGTM! Clear middleware registration example.

The code example correctly demonstrates middleware registration for multiple prefixes.


464-477: LGTM! Well-documented generic functions examples.

The code examples for Convert, Params, Query, and GetReqHeader functions are clear, correct, and demonstrate proper error handling.

Also applies to: 543-554, 575-586, 608-619

@gaby
Copy link
Member

gaby commented Dec 8, 2024

I need to run the tests locally, something is crashing when we hit the staging server

@gaby
Copy link
Member

gaby commented Dec 8, 2024

Can we add several test-cases using letsencrypt.org/tr/docs/staging-environment?

After testing multiple times, locally and in CI. That staging server is for testing with a domain you own. When running with example.com it will try to hit that server on port 80 which will fail and we get a timeout.

Even the official google package doesn't have a test for this. We can't add one either.

Copy link

codecov bot commented Dec 9, 2024

Codecov Report

Attention: Patch coverage is 14.28571% with 6 lines in your changes missing coverage. Please review.

Project coverage is 82.81%. Comparing base (70a06c5) to head (dc11469).
Report is 1 commits behind head on main.

Files with missing lines Patch % Lines
listen.go 14.28% 5 Missing and 1 partial ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #3201      +/-   ##
==========================================
- Coverage   82.84%   82.81%   -0.03%     
==========================================
  Files         115      115              
  Lines       11295    11302       +7     
==========================================
+ Hits         9357     9360       +3     
- Misses       1539     1543       +4     
  Partials      399      399              
Flag Coverage Δ
unittests 82.81% <14.28%> (-0.03%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Copy link
Member

@gaby gaby left a comment

Choose a reason for hiding this comment

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

👍 LGTM. We are unable to add unit-tests since testing ACME requires either running Pebble or having a real domain.

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (1)
listen.go (1)

74-78: Enhance field documentation with usage examples

While the documentation explains the purpose, it would be more helpful to include:

  1. A basic usage example
  2. Required configuration for Let's Encrypt
  3. Common pitfalls to avoid

Consider expanding the documentation like this:

 // AutoCertManager manages TLS certificates automatically using the ACME protocol,
 // Enables integration with Let's Encrypt or other ACME-compatible providers.
+//
+// Example usage with Let's Encrypt:
+//  manager := &autocert.Manager{
+//    Prompt:     autocert.AcceptTOS,
+//    HostPolicy: autocert.HostWhitelist("example.com"),
+//    Cache:      autocert.DirCache("certs"),
+//  }
+//  app.Listen(":443", fiber.ListenConfig{
+//    AutoCertManager: manager,
+//  })
 //
 // Default: nil
 AutoCertManager *autocert.Manager `json:"auto_cert_manager"`
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 90bd4cc and c3b07e9.

📒 Files selected for processing (1)
  • listen.go (3 hunks)
🧰 Additional context used
🪛 GitHub Check: codecov/patch
listen.go

[warning] 195-199: listen.go#L195-L199
Added lines #L195 - L199 were not covered by tests

🔇 Additional comments (3)
listen.go (3)

26-26: LGTM: Import of autocert package

The import of the standard Go ACME/autocert package is appropriate for implementing AutoTLS support.


194-199: Verify TLS configuration customization

The TLS configuration for AutoTLS should be customizable through the TLSConfigFunc. While the base configuration is correct, users might need to:

  1. Adjust security parameters
  2. Add custom protocols
  3. Configure cipher suites
🧰 Tools
🪛 GitHub Check: codecov/patch

[warning] 195-199: listen.go#L195-L199
Added lines #L195 - L199 were not covered by tests


194-199: ⚠️ Potential issue

Add test coverage for AutoTLS configuration

The AutoTLS configuration block lacks test coverage. Consider adding tests using Let's Encrypt's staging environment to verify:

  1. Certificate acquisition
  2. TLS configuration
  3. Protocol negotiation
🧰 Tools
🪛 GitHub Check: codecov/patch

[warning] 195-199: listen.go#L195-L199
Added lines #L195 - L199 were not covered by tests

Copy link
Member

@ReneWerner87 ReneWerner87 left a comment

Choose a reason for hiding this comment

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

LGTM, but pls add something about this new cool feature in the "whats new" markdown

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 2

🧹 Outside diff range and nitpick comments (5)
docs/whats_new.md (5)

197-212: Fix indentation in the route chaining example.

The indentation of the chained methods is inconsistent with Go's standard formatting.

Apply this formatting:

 app.Route("/api").Route("/user/:id?")
-    .Get(func(c fiber.Ctx) error {
-        // Get user
-        return c.JSON(fiber.Map{"message": "Get user", "id": c.Params("id")})
-    })
-    .Post(func(c fiber.Ctx) error {
-        // Create user
-        return c.JSON(fiber.Map{"message": "User created"})
-    })
+   .Get(func(c fiber.Ctx) error {
+       // Get user
+       return c.JSON(fiber.Map{"message": "Get user", "id": c.Params("id")})
+   })
+   .Post(func(c fiber.Ctx) error {
+       // Create user
+       return c.JSON(fiber.Map{"message": "User created"})
+   })

264-271: Add error handling to the test configuration example.

The example should demonstrate proper error handling.

Add error handling:

 req := httptest.NewRequest(MethodGet, "/", nil)
 testConfig := fiber.TestConfig{
     Timeout:       0,
     FailOnTimeout: false,
 }

 // Test the handler using the request and testConfig
-resp, err := app.Test(req, testConfig)
+resp, err := app.Test(req, testConfig)
+if err != nil {
+    // Handle error
+    log.Fatal(err)
+}
+defer resp.Body.Close()

483-496: Enhance generic functions examples with error handling and type constraints.

The examples could be improved to show best practices.

Here's an improved version of the Convert example:

 app.Get("/convert", func(c fiber.Ctx) error {
-    value, err := Convert[string](c.Query("value"), strconv.Atoi, 0)
+    // Add type constraint
+    value, err := Convert[int, constraints.Integer](
+        c.Query("value"),
+        strconv.Atoi,
+        0,
+    )
     if err != nil {
-        return c.Status(fiber.StatusBadRequest).SendString(err.Error())
+        return c.Status(fiber.StatusBadRequest).JSON(fiber.Map{
+            "error": "Invalid value: " + err.Error(),
+        })
     }
-    return c.JSON(value)
+    return c.JSON(fiber.Map{"value": value})
 })

Also applies to: 562-571, 594-603, 627-638


Line range hint 922-942: Enhance RebuildTree documentation with production usage warnings.

The documentation should emphasize the risks of using this feature in production.

Add these warnings:

 Note: Use this method with caution. It is **not** thread-safe and can be very performance-intensive. Therefore, it should be used sparingly and primarily in development mode. It should not be invoke concurrently.
+
+**⚠️ Production Warning:**
+- This method rebuilds the entire route tree, which can be CPU-intensive
+- Avoid using this in production during high-traffic periods
+- Consider implementing a maintenance window for route updates
+- Use feature flags or environment-based conditions to control when rebuilding is allowed

942-942: Fix grammar in the RebuildTree note.

The word "invoke" should be "invoked" in this context.

-It should not be invoke concurrently.
+It should not be invoked concurrently.
🧰 Tools
🪛 LanguageTool

[grammar] ~942-~942: Consider using either the past participle “invoked” or the present participle “invoking” here.
Context: ...y in development mode. It should not be invoke concurrently. ### 🧠 Context Fiber v3...

(BEEN_PART_AGREEMENT)

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between c3b07e9 and 13f7aeb.

⛔ Files ignored due to path filters (2)
  • go.mod is excluded by !**/*.mod
  • go.sum is excluded by !**/*.sum, !**/*.sum
📒 Files selected for processing (1)
  • docs/whats_new.md (34 hunks)
🧰 Additional context used
🪛 LanguageTool
docs/whats_new.md

[grammar] ~942-~942: Consider using either the past participle “invoked” or the present participle “invoking” here.
Context: ...y in development mode. It should not be invoke concurrently. ### 🧠 Context Fiber v3...

(BEEN_PART_AGREEMENT)

🔇 Additional comments (1)
docs/whats_new.md (1)

231-232: LGTM!

The middleware registration example clearly demonstrates the new syntax for registering multiple prefixes and subapps.

Also applies to: 238-238

docs/whats_new.md Outdated Show resolved Hide resolved
docs/whats_new.md Show resolved Hide resolved
gaby and others added 3 commits December 9, 2024 10:22
Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

📝 [Proposal]: Add support for AutoTLS / ACME
5 participants