feat: add container management functionality

This commit is contained in:
Tran Anh Tuan
2026-05-11 09:42:19 +07:00
parent 9f27436d5d
commit 7c9a0d4670
15 changed files with 1654 additions and 1 deletions

View File

@@ -0,0 +1,55 @@
package repositories
import (
"context"
"wm-backend/internal/mapper"
"wm-backend/internal/models"
db "wm-backend/sqlc_gen"
"github.com/rs/zerolog/log"
)
func CreateContainer(ctx context.Context, queries *db.Queries, body models.Container) (models.Container, error) {
result, err := queries.CreateContainer(ctx, *mapper.ToModelContainer(&body))
if err != nil {
return models.Container{}, err
}
return *mapper.ToDomainContainer(result), nil
}
func GetContainerByID(ctx context.Context, queries *db.Queries, id int64) (models.Container, error) {
result, err := queries.GetContainerByID(ctx, id)
if err != nil {
return models.Container{}, err
}
return *mapper.ToDomainContainer(result), nil
}
func ListContainers(ctx context.Context, queries *db.Queries) ([]models.Container, error) {
results, err := queries.ListContainers(ctx)
if err != nil {
return nil, err
}
var items []models.Container
for _, r := range results {
items = append(items, *mapper.ToDomainContainer(r))
}
return items, nil
}
func UpdateContainer(ctx context.Context, queries *db.Queries, body models.Container) (models.Container, error) {
result, err := queries.UpdateContainer(ctx, *mapper.ToUpdateModelContainer(&body))
if err != nil {
return models.Container{}, err
}
return *mapper.ToDomainContainer(result), nil
}
func DeleteContainer(ctx context.Context, queries *db.Queries, id int64) (int64, error) {
rowsAffected, err := queries.DeleteContainer(ctx, id)
log.Info().Int64("id", id).Int64("rowsAffected", rowsAffected).Msg("Deleted container")
if err != nil {
return rowsAffected, err
}
return rowsAffected, nil
}