Skip to content

Commit

Permalink
renames DTO struct (#354)
Browse files Browse the repository at this point in the history
A DTO (Data Transfer Object) is meant to either:
- Represent data received from the client in requests.
- Represent data sent to the client in responses.

A struct that is used for internal business logic is not normally named "DTO".
  • Loading branch information
GustavoSept authored Nov 14, 2024
1 parent 746da2d commit 98c4c20
Showing 1 changed file with 4 additions and 4 deletions.
8 changes: 4 additions & 4 deletions website/docs/guide/binding.md
Original file line number Diff line number Diff line change
Expand Up @@ -109,12 +109,12 @@ Consider what will happen if your bound struct has an Exported field `IsAdmin bo
In this example we define a `User` struct type with field tags to bind from `json`, `form`, or `query` request data:

```go
type User struct {
type UserDTO struct {
Name string `json:"name" form:"name" query:"name"`
Email string `json:"email" form:"email" query:"email"`
}

type UserDTO struct {
type User struct {
Name string
Email string
IsAdmin bool
Expand All @@ -125,13 +125,13 @@ And a handler at the POST `/users` route binds request data to the struct:

```go
e.POST("/users", func(c echo.Context) (err error) {
u := new(User)
u := new(UserDTO)
if err := c.Bind(u); err != nil {
return c.String(http.StatusBadRequest, "bad request")
}

// Load into separate struct for security
user := UserDTO{
user := User{
Name: u.Name,
Email: u.Email,
IsAdmin: false // avoids exposing field that should not be bound
Expand Down

0 comments on commit 98c4c20

Please sign in to comment.