Compare commits

..

15 Commits

Author SHA1 Message Date
4b5d681efe Update 2025-11-08 14:54:22 +01:00
c502499aa4 Update 2025-11-08 14:37:46 +01:00
82653025be Fixes 2025-11-08 13:55:34 +01:00
d7bcb71acf Added Quantity field to RemoveFromBasket DTO 2025-11-08 02:20:12 +01:00
6055673a34 Added DTO for RemoveFromBasket action 2025-11-08 02:16:17 +01:00
957e0aa13a Refactored time.Duration to time.Time type 2025-11-08 01:04:05 +01:00
3e340d68d0 Added AddProductToBasket HTTP DTO 2025-11-08 00:42:31 +01:00
f6c6bb07fd go.mod update 2025-11-07 23:20:29 +01:00
606c6ec6f8 Basket update 2025-11-07 16:24:54 +01:00
7d9c66ae26 Update 2025-10-24 13:27:38 +02:00
3b1ff1b649 Update 2025-10-23 19:16:25 +02:00
01963ddd35 Updated Product Entity 2025-10-23 18:53:13 +02:00
e4042cd76d Updated Product Entity 2025-10-23 18:51:16 +02:00
7a20709424 Updated Product Entity 2025-10-23 18:48:29 +02:00
dd3ed73013 Updated catalog DTOs 2025-10-23 18:47:01 +02:00
12 changed files with 113 additions and 114 deletions

View File

@@ -7,23 +7,44 @@ type GetBasketRequestDTO struct {
} }
type GetBasketResponseDTO struct { type GetBasketResponseDTO struct {
ID string `json:"id"` ID string `json:"id"`
State string `json:"state"` State string `json:"state"`
CreatedAt time.Duration `json:"created_at"` CreatedAt time.Time `json:"created_at"`
UpdatedAt time.Duration `json:"updated_at,omitempty"` UpdatedAt *time.Time `json:"updated_at,omitempty"`
} }
type GetBasketItemsRequestDTO struct { type GetBasketItemsRequestDTO struct {
BasketID string `json:"basket_id"`
} }
type GetBasketItemsResponseDTO struct { type GetBasketItemsResponseDTO struct {
ID string `json:"id"` ID string `json:"id"`
BasketID string `json:"basket_id"` BasketID string `json:"basket_id"`
ProductID int `json:"product_id"` ProductID string `json:"product_id"`
Quantity int `json:"quantity"` Quantity int `json:"quantity"`
Price float64 `json:"price"` Price float64 `json:"price"`
CreatedAt time.Duration `json:"created_at"` CreatedAt time.Time `json:"created_at"`
UpdatedAt time.Duration `json:"updated_at,omitempty"` UpdatedAt *time.Time `json:"updated_at,omitempty"`
}
type AddProductToBasketRequestDTO struct {
BasketID string `json:"basket_id"`
ProductID string `json:"product_id"`
Quantity int `json:"quantity"`
}
type AddProductToBasketResponseDTO struct {
BasketID string `json:"basket_id"`
}
type RemoveFromBasketRequestDTO struct {
BasketID string `json:"basket_id"`
ProductID string `json:"product_id"`
Quantity int `json:"quantity"`
}
type RemoveFromBasketResponseDTO struct {
BasketID string `json:"basket_id"`
} }
type BasketCheckoutRequestDTO struct { type BasketCheckoutRequestDTO struct {

View File

@@ -1,22 +1,20 @@
package basket package basket
import ( import "time"
"github.com/jackc/pgtype"
)
type BasketEntity struct { type Basket struct {
ID string `db:"id" json:"id"` ID string `db:"id" json:"id"`
State string `db:"state" json:"state"` State string `db:"state" json:"state"`
CreatedAt pgtype.Timestamp `db:"created_at" json:"created_at"` CreatedAt time.Time `db:"created_at" json:"created_at"`
UpdatedAt pgtype.Timestamp `db:"updated_at" json:"updated_at,omitempty"` UpdatedAt *time.Time `db:"updated_at" json:"updated_at,omitempty"`
} }
type BasketItemEntity struct { type BasketItem struct {
ID string `db:"id" json:"id"` ID string `db:"id" json:"id"`
BasketID string `db:"basket_id" json:"basket_id"` BasketID string `db:"basket_id" json:"basket_id"`
ProductID int `db:"product_id" json:"product_id"` ProductID string `db:"product_id" json:"product_id"`
Quantity int `db:"quantity" json:"quantity"` Quantity int `db:"quantity" json:"quantity"`
Price float64 `db:"price" json:"price"` Price float64 `db:"price" json:"price"`
CreatedAt pgtype.Timestamp `db:"created_at" json:"created_at"` CreatedAt time.Time `db:"created_at" json:"created_at"`
UpdatedAt pgtype.Timestamp `db:"updated_at" json:"updated_at,omitempty"` UpdatedAt *time.Time `db:"updated_at" json:"updated_at,omitempty"`
} }

View File

@@ -5,16 +5,16 @@ import (
) )
type Basket struct { type Basket struct {
State string `db:"state" json:"state"` State string `db:"state" json:"state"`
CreatedAt time.Time `db:"created_at" json:"created_at"` CreatedAt time.Time `db:"created_at" json:"created_at"`
UpdatedAt time.Time `db:"updated_at" json:"updated_at,omitempty"` UpdatedAt *time.Time `db:"updated_at" json:"updated_at,omitempty"`
} }
type BasketItem struct { type BasketItem struct {
BasketID string `db:"basket_id" json:"basket_id"` BasketID string `db:"basket_id" json:"basket_id"`
ProductID int `db:"product_id" json:"product_id"` ProductID string `db:"product_id" json:"product_id"`
Quantity int `db:"quantity" json:"quantity"` Quantity int `db:"quantity" json:"quantity"`
Price float64 `db:"price" json:"price"` Price float64 `db:"price" json:"price"`
CreatedAt time.Time `db:"created_at" json:"created_at"` CreatedAt time.Time `db:"created_at" json:"created_at"`
UpdatedAt time.Time `db:"updated_at" json:"updated_at,omitempty"` UpdatedAt *time.Time `db:"updated_at" json:"updated_at,omitempty"`
} }

View File

@@ -9,38 +9,23 @@ type GetProductRequestDTO struct {
} }
type GetProductResponseDTO struct { type GetProductResponseDTO struct {
ID string `json:"id"` ID string `json:"id"`
Name string `json:"name"` Name string `json:"name"`
Slug string `json:"slug"` Slug string `json:"slug"`
Price float64 `json:"price"` Price float64 `json:"price"`
CreatedAt time.Time `json:"created_at"` CreatedAt time.Time `json:"created_at"`
UpdatedAt time.Time `json:"updated_at,omitempty"` UpdatedAt *time.Time `json:"updated_at,omitempty"`
}
type GetProductListRequestDTO struct {
CategoryID string `json:"category_id"`
} }
type GetProductListResponseDTO struct { type GetProductListResponseDTO struct {
Products []GetProductResponseDTO `json:"products"` Products []GetProductResponseDTO `json:"products"`
} }
type AddProductToBasketRequestDTO struct { type GetProductDetailsResponseDTO struct {
ProductID string `json:"product_id"` ID string `json:"id"`
Quantity int `json:"quantity"` SLug string `json:"slug"`
} Name string `json:"name"`
Price string `json:"price"`
type AddProductToBasketResponseDTO struct { CreatedAt time.Time `json:"created_at"`
ProductID string `json:"product_id"` UpdatedAt *time.Time `json:"updated_at,omitempty"`
BasketID string `json:"basket_id"`
}
type RemoveProductFromBasketRequestDTO struct {
ProductID string `json:"product_id"`
Quantity int `json:"quantity"`
}
type RemoveProductFromBasketResponseDTO struct {
ProductID string `json:"product_id"`
BasketID string `json:"basket_id"`
} }

View File

@@ -1,12 +1,12 @@
package catalog package catalog
import "github.com/jackc/pgtype" import "time"
type Product struct { type Product struct {
ID string `db:"id"` ID string `json:"id" db:"id"`
Slug string `db:"slug"` Slug string `json:"slug" db:"slug"`
Name string `db:"name"` Name string `json:"name" db:"name"`
Price float64 `db:"price"` Price float64 `json:"price" db:"price"`
CreatedAt pgtype.Timestamp `db:"created_at"` CreatedAt time.Time `json:"created_at" db:"created_at"`
UpdatedAt pgtype.Timestamp `db:"updated_at,omitempty"` UpdatedAt *time.Time `json:"updated_at" db:"updated_at, omitempty"`
} }

View File

@@ -5,9 +5,9 @@ import (
) )
type Product struct { type Product struct {
Name string `db:"name"` Name string `db:"name"`
Slug string `db:"slug"` Slug string `db:"slug"`
Price float64 `db:"price"` Price float64 `db:"price"`
CreatedAt time.Time `db:"created_at"` CreatedAt time.Time `db:"created_at"`
UpdatedAt time.Time `db:"updated_at,omitempty"` UpdatedAt *time.Time `db:"updated_at"`
} }

2
go.mod
View File

@@ -1,6 +1,6 @@
module git.ego.freeddns.org/egommerce/api-entities module git.ego.freeddns.org/egommerce/api-entities
go 1.19 go 1.24
require github.com/jackc/pgtype v1.14.3 require github.com/jackc/pgtype v1.14.3

View File

@@ -3,17 +3,10 @@ package identity
import "time" import "time"
type User struct { type User struct {
ID string `db:"id" json:"id"` ID string `db:"id" json:"id"`
Email string `db:"email" json:"email"` Email string `db:"email" json:"email"`
Username string `db:"username" json:"username"` Username string `db:"username" json:"username"`
Password string `db:"password" json:"password"` Password string `db:"password" json:"password"`
CreatedAt time.Time `db:"created_at" json:"created_at"` CreatedAt time.Time `db:"created_at" json:"created_at"`
ModifiedAt time.Time `db:"modified_at" json:"modified_at"` // FIXME: zero-value issue UpdatedAt *time.Time `db:"updated_at,omitempty" json:"updated_at,omitempty"`
} }
// var TestUser = &User{
// ID: 1,
// Username: "test",
// Password: "test",
// CreateDate: time.Now(),
// }

View File

@@ -1,20 +1,22 @@
package order package order
import "github.com/jackc/pgtype" import (
"time"
)
type OrderEntity struct { type Order struct {
ID string `db:"id" json:"id"` ID string `db:"id" json:"id"`
State string `db:"state" json:"state"` State string `db:"state" json:"state"`
CreatedAt pgtype.Timestamp `db:"created_at" json:"created_at"` CreatedAt time.Time `db:"created_at" json:"created_at"`
UpdatedAt pgtype.Timestamp `db:"updated_at" json:"updated_at,omitempty"` UpdatedAt *time.Time `db:"updated_at" json:"updated_at,omitempty"`
} }
type OrderItemEntity struct { type OrderItem struct {
ID string `db:"id" json:"id"` ID string `db:"id" json:"id"`
OrderID string `db:"order_id" json:"order_id"` OrderID string `db:"order_id" json:"order_id"`
ProductID int `db:"product_id" json:"product_id"` ProductID int `db:"product_id" json:"product_id"`
Quantity int `db:"quantity" json:"quantity"` Quantity int `db:"quantity" json:"quantity"`
Price float64 `db:"price" json:"price"` Price float64 `db:"price" json:"price"`
CreatedAt pgtype.Timestamp `db:"created_at" json:"created_at"` CreatedAt time.Time `db:"created_at" json:"created_at"`
UpdatedAt pgtype.Timestamp `db:"updated_at" json:"updated_at,omitempty"` UpdatedAt *time.Time `db:"updated_at" json:"updated_at,omitempty"`
} }

View File

@@ -3,16 +3,16 @@ package order
import "time" import "time"
type Order struct { type Order struct {
State string `db:"state" json:"state"` State string `db:"state" json:"state"`
CreatedAt time.Time `db:"created_at" json:"created_at"` CreatedAt time.Time `db:"created_at" json:"created_at"`
UpdatedAt time.Time `db:"updated_at" json:"updated_at,omitempty"` UpdatedAt *time.Time `db:"updated_at" json:"updated_at,omitempty"`
} }
type OrderItem struct { type OrderItem struct {
OrderID string `db:"order_id" json:"order_id"` OrderID string `db:"order_id" json:"order_id"`
ProductID int `db:"product_id" json:"product_id"` ProductID int `db:"product_id" json:"product_id"`
Quantity int `db:"quantity" json:"quantity"` Quantity int `db:"quantity" json:"quantity"`
Price float64 `db:"price" json:"price"` Price float64 `db:"price" json:"price"`
CreatedAt time.Time `db:"created_at" json:"created_at"` CreatedAt time.Time `db:"created_at" json:"created_at"`
UpdatedAt time.Time `db:"updated_at" json:"updated_at,omitempty"` UpdatedAt *time.Time `db:"updated_at" json:"updated_at,omitempty"`
} }

View File

@@ -1,6 +1,6 @@
package pricing package pricing
type ProductPriceEntity struct { type ProductPrice struct {
ID int `db:"id"` ID int `db:"id"`
PID string `db:"pid"` PID string `db:"pid"`
Price int `db:"price"` Price int `db:"price"`