Skip to content

Commit 3b01785

Browse files
authoredDec 4, 2024··
Changelog for 4.13.0 (#2712)
1 parent fe26277 commit 3b01785

File tree

2 files changed

+33
-1
lines changed

2 files changed

+33
-1
lines changed
 

‎CHANGELOG.md

+32
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,37 @@
11
# Changelog
22

3+
## v4.13.0 - 2024-12-04
4+
5+
**BREAKING CHANGE** JWT Middleware Removed from Core use [labstack/echo-jwt](https://github.com/labstack/echo-jwt) instead
6+
7+
The JWT middleware has been **removed from Echo core** due to another security vulnerability, [CVE-2024-51744](https://nvd.nist.gov/vuln/detail/CVE-2024-51744). For more details, refer to issue [#2699](https://github.com/labstack/echo/issues/2699). A drop-in replacement is available in the [labstack/echo-jwt](https://github.com/labstack/echo-jwt) repository.
8+
9+
**Important**: Direct assignments like `token := c.Get("user").(*jwt.Token)` will now cause a panic due to an invalid cast. Update your code accordingly. Replace the current imports from `"github.com/golang-jwt/jwt"` in your handlers to the new middleware version using `"github.com/golang-jwt/jwt/v5"`.
10+
11+
12+
Background:
13+
14+
The version of `golang-jwt/jwt` (v3.2.2) previously used in Echo core has been in an unmaintained state for some time. This is not the first vulnerability affecting this library; earlier issues were addressed in [PR #1946](https://github.com/labstack/echo/pull/1946).
15+
JWT middleware was marked as deprecated in Echo core as of [v4.10.0](https://github.com/labstack/echo/releases/tag/v4.10.0) on 2022-12-27. If you did not notice that, consider leveraging tools like [Staticcheck](https://staticcheck.dev/) to catch such deprecations earlier in you dev/CI flow. For bonus points - check out [gosec](https://github.com/securego/gosec).
16+
17+
We sincerely apologize for any inconvenience caused by this change. While we strive to maintain backward compatibility within Echo core, recurring security issues with third-party dependencies have forced this decision.
18+
19+
**Enhancements**
20+
21+
* remove jwt middleware by @stevenwhitehead in https://github.com/labstack/echo/pull/2701
22+
* optimization: struct alignment by @behnambm in https://github.com/labstack/echo/pull/2636
23+
* bind: Maintain backwards compatibility for map[string]interface{} binding by @thesaltree in https://github.com/labstack/echo/pull/2656
24+
* Add Go 1.23 to CI by @aldas in https://github.com/labstack/echo/pull/2675
25+
* improve `MultipartForm` test by @martinyonatann in https://github.com/labstack/echo/pull/2682
26+
* `bind` : add support of multipart multi files by @martinyonatann in https://github.com/labstack/echo/pull/2684
27+
* Add TemplateRenderer struct to ease creating renderers for `html/template` and `text/template` packages. by @aldas in https://github.com/labstack/echo/pull/2690
28+
* Refactor TestBasicAuth to utilize table-driven test format by @ErikOlson in https://github.com/labstack/echo/pull/2688
29+
* Remove broken header by @aldas in https://github.com/labstack/echo/pull/2705
30+
* fix(bind body): content-length can be -1 by @phamvinhdat in https://github.com/labstack/echo/pull/2710
31+
* CORS middleware should compile allowOrigin regexp at creation by @aldas in https://github.com/labstack/echo/pull/2709
32+
* Shorten Github issue template and add test example by @aldas in https://github.com/labstack/echo/pull/2711
33+
34+
335
## v4.12.0 - 2024-04-15
436

537
**Security**

‎echo.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -259,7 +259,7 @@ const (
259259

260260
const (
261261
// Version of Echo
262-
Version = "4.12.0"
262+
Version = "4.13.0"
263263
website = "https://echo.labstack.com"
264264
// http://patorjk.com/software/taag/#p=display&f=Small%20Slant&t=Echo
265265
banner = `

0 commit comments

Comments
 (0)
Please sign in to comment.