bill-server-go/internal/city/domain.go

48 lines
1.7 KiB
Go

package city
import (
"bill-server/internal/user"
"context"
)
// Represents 'cities' object.
type City struct {
ID int `json:"id"`
Name string `json:"name"`
Created int64 `json:"created"`
Modified int64 `json:"modified"`
User int `json:"user"`
}
// Represents our 1-to-many relationship, User to Cities.
// In other words, a single user can have many cities.
// This is used for the presentation layer only.
type CityAndUser struct {
ID int `json:"id"`
Name string `json:"name"`
Created int64 `json:"created"`
Modified int64 `json:"modified"`
User user.User `json:"user"`
}
// Our repository will implement these methods.
type CityRepository interface {
GetCities(ctx context.Context) (*[]CityAndUser, error)
GetCity(ctx context.Context, cityID int) (*CityAndUser, error)
CreateCity(ctx context.Context, city *City) error
UpdateCity(ctx context.Context, cityID int, city *City) error
DeleteCity(ctx context.Context, cityID int) error
}
// Our use-case or service will implement these methods.
// Method names does not matter - I intentionally changed the names here so they are different from the repository.
// Usually, 'services' should be as close as possible to a business use-case / problem.
// Some methods will also take 'userID' as an argument - because we need it to fill the 'User' value in the struct.
type CityService interface {
FetchCities(ctx context.Context) (*[]CityAndUser, error)
FetchCity(ctx context.Context, cityID int) (*CityAndUser, error)
BuildCity(ctx context.Context, city *City, userID int) error
ModifyCity(ctx context.Context, cityID int, city *City, userID int) error
DestroyCity(ctx context.Context, cityID int) error
}