Compare commits

...

14 Commits

10 changed files with 60 additions and 39 deletions

View File

@@ -4,13 +4,13 @@ import (
"time" "time"
) )
type BasketModel 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 BasketItemModel 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 int `db:"product_id" json:"product_id"`
Quantity int `db:"quantity" json:"quantity"` Quantity int `db:"quantity" json:"quantity"`

View File

@@ -5,20 +5,20 @@ import (
) )
type GetProductRequestDTO struct { type GetProductRequestDTO struct {
ProductID int `json:"product_id"` ProductID string `json:"product_id"`
} }
type GetProductResponseDTO struct { type GetProductResponseDTO struct {
ID int `json:"id"` ID string `json:"id"`
PID string `json:"pid"`
Name string `json:"name"` Name string `json:"name"`
Slug string `json:"slug"`
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 GetProductListRequestDTO struct { type GetProductListRequestDTO struct {
CategoryID int `json:"category_id"` CategoryID string `json:"category_id"`
} }
type GetProductListResponseDTO struct { type GetProductListResponseDTO struct {
@@ -26,21 +26,21 @@ type GetProductListResponseDTO struct {
} }
type AddProductToBasketRequestDTO struct { type AddProductToBasketRequestDTO struct {
ProductID int `json:"product_id"` ProductID string `json:"product_id"`
Quantity int `json:"quantity"` Quantity int `json:"quantity"`
} }
type AddProductToBasketResponseDTO struct { type AddProductToBasketResponseDTO struct {
ProductID int `json:"product_id"` ProductID string `json:"product_id"`
BasketID string `json:"basket_id"` BasketID string `json:"basket_id"`
} }
type RemoveProductFromBasketRequestDTO struct { type RemoveProductFromBasketRequestDTO struct {
ProductID int `json:"product_id"` ProductID string `json:"product_id"`
Quantity int `json:"quantity"` Quantity int `json:"quantity"`
} }
type RemoveProductFromBasketResponseDTO struct { type RemoveProductFromBasketResponseDTO struct {
ProductID int `json:"product_id"` ProductID string `json:"product_id"`
BasketID string `json:"basket_id"` BasketID string `json:"basket_id"`
} }

View File

@@ -1,12 +1,12 @@
package catalog package catalog
import "github.com/jackc/pgtype" import "time"
type ProductEntity struct { type Product struct {
ID int `db:"id"` ID string `json:"id", db:"id"`
PID string `db:"pid"` 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

@@ -4,10 +4,10 @@ import (
"time" "time"
) )
type ProductModel struct { type Product struct {
PID string `db:"pid"`
Name string `db:"name"` Name string `db:"name"`
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,omitempty"`
} }

5
identity/dto/headers.go Normal file
View File

@@ -0,0 +1,5 @@
package identity
type AuthorizationHeaderDTO struct {
Authorization string `reqHeader:"authorization"`
}

8
identity/entity/role.go Normal file
View File

@@ -0,0 +1,8 @@
package identity
type Role struct {
ID string `db:"id" json:"id"`
Name string `db:"name" json:"name"`
DisplayName string `db:"display_name" json:"display_name"`
URL string `db:"url" json:"url"`
}

View File

@@ -0,0 +1,8 @@
package identity
type URLAccess struct {
ID string `db:"id" json:"id"`
Roles []string `db:"roles" json:"roles"`
URL string `db:"url" json:"url"`
Service string `db:"service" json:"service"`
}

View File

@@ -3,12 +3,12 @@ package identity
import "time" import "time"
type User struct { type User struct {
ID int `json:"id"` ID string `db:"id" json:"id"`
Email string `json:"email"` Email string `db:"email" json:"email"`
Username string `json:"username"` Username string `db:"username" json:"username"`
Password string `json:"password"` Password string `db:"password" json:"password"`
CreateDate time.Time `json:"create_date"` CreatedAt time.Time `db:"created_at" json:"created_at"`
ModifyDate time.Time `json:"modify_date"` // FIXME: zero-value issue ModifiedAt time.Time `db:"modified_at" json:"modified_at"` // FIXME: zero-value issue
} }
// var TestUser = &User{ // var TestUser = &User{

View File

@@ -2,13 +2,13 @@ package order
import "time" import "time"
type OrderModel 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 OrderItemModel 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"`

View File

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