Begin migration to sqlc
This commit is contained in:
@ -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
|
||||
}
|
||||
|
Reference in New Issue
Block a user