Begin migration to sqlc

This commit is contained in:
2021-11-08 21:32:30 +00:00
parent f019c47d21
commit cf1bc70103
17 changed files with 427 additions and 72 deletions

View File

@ -1,6 +1,11 @@
package postgres
import "git.javil.eu/jacob1123/budgeteer"
import (
"context"
"database/sql"
"git.javil.eu/jacob1123/budgeteer"
)
// Budget returns a budget for a given id.
func (s *Repository) Budget(id string) (*budgeteer.Budget, error) {
@ -12,32 +17,27 @@ func (s *Repository) Budget(id string) (*budgeteer.Budget, error) {
return b, nil
}
func (s *Repository) BudgetsForUser(id string) ([]*budgeteer.Budget, error) {
user := &budgeteer.User{
ID: id,
}
err := s.DB.Model(&user).
Column("user.*", "Budgets").
Select()
func (s *Repository) BudgetsForUser(id string) ([]Budget, error) {
budgets, err := s.DB.GetBudgetsForUser(context.Background(), sql.NullString{id, true})
if err != nil {
return nil, err
}
return user.Budgets, nil
return budgets, nil
}
func (s *Repository) NewBudget(name string, userID string) (*budgeteer.Budget, error) {
b := &budgeteer.Budget{ID: s.IDGenerator.New(), Name: name}
err := s.DB.Insert(b)
func (s *Repository) NewBudget(name string, userID string) (Budget, error) {
b := CreateBudgetParams{ID: s.IDGenerator.New(), Name: name}
budget, err := s.DB.CreateBudget(context.Background(), b)
if err != nil {
return nil, err
}
ub := &budgeteer.UserBudget{UserID: userID, BudgetID: b.ID}
err = s.DB.Insert(ub)
ub := LinkBudgetToUserParams{UserID: userID, BudgetID: budget.ID}
_, err = s.DB.LinkBudgetToUser(context.Background(), ub)
if err != nil {
return nil, err
}
return b, nil
return budget, nil
}