aboutsummaryrefslogtreecommitdiffstats
path: root/pkg/favourites/service.go
blob: f73f400a5ec3a9257e88e60c174f3c6be2fb9e91 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package favourites

import (
	"context"
	"errors"
	"fmt"

	"github.com/LMBishop/confplanner/pkg/database/sqlc"
	"github.com/jackc/pgx/v5"
	"github.com/jackc/pgx/v5/pgtype"
	"github.com/jackc/pgx/v5/pgxpool"
)

type Service interface {
	GetAllFavouritesForUser(id int32) (*[]sqlc.Favourite, error)
	GetFavouritesForUserConference(id int32, conference int32) (*[]sqlc.Favourite, error)
	CreateFavouriteForUser(id int32, eventGUID pgtype.UUID, eventID *int32, conferenceID int32) (*sqlc.Favourite, error)
	DeleteFavouriteForUserByEventDetails(id int32, eventGUID pgtype.UUID, eventID *int32, conferenceID int32) error
}

var (
	ErrImproperType = errors.New("improper type")
	ErrNotFound     = errors.New("not found")
)

type service struct {
	pool *pgxpool.Pool
}

func NewService(pool *pgxpool.Pool) Service {
	return &service{
		pool: pool,
	}
}

func (s *service) CreateFavouriteForUser(userID int32, eventGUID pgtype.UUID, eventID *int32, conferenceID int32) (*sqlc.Favourite, error) {
	queries := sqlc.New(s.pool)

	var pgEventID pgtype.Int4
	if eventID != nil {
		pgEventID = pgtype.Int4{
			Int32: *eventID,
			Valid: true,
		}
	}

	favourite, err := queries.CreateFavourite(context.Background(), sqlc.CreateFavouriteParams{
		UserID:       userID,
		EventGuid:    eventGUID,
		EventID:      pgEventID,
		ConferenceID: conferenceID,
	})
	if err != nil {
		return nil, fmt.Errorf("could not create favourite: %w", err)
	}

	return &favourite, nil
}

func (s *service) GetAllFavouritesForUser(userID int32) (*[]sqlc.Favourite, error) {
	queries := sqlc.New(s.pool)

	favourites, err := queries.GetFavouritesForUser(context.Background(), userID)
	if err != nil {
		if errors.Is(err, pgx.ErrNoRows) {
			empty := make([]sqlc.Favourite, 0)
			return &empty, nil
		}
		return nil, fmt.Errorf("could not fetch user: %w", err)
	}

	return &favourites, nil
}

func (s *service) GetFavouritesForUserConference(userID int32, conferenceID int32) (*[]sqlc.Favourite, error) {
	queries := sqlc.New(s.pool)

	favourites, err := queries.GetFavouritesForUserConference(context.Background(), sqlc.GetFavouritesForUserConferenceParams{
		UserID:       userID,
		ConferenceID: conferenceID,
	})
	if err != nil {
		if errors.Is(err, pgx.ErrNoRows) {
			empty := make([]sqlc.Favourite, 0)
			return &empty, nil
		}
		return nil, fmt.Errorf("could not fetch user: %w", err)
	}

	return &favourites, nil
}

func (s *service) DeleteFavouriteForUserByEventDetails(id int32, eventGUID pgtype.UUID, eventID *int32, conferenceID int32) error {
	queries := sqlc.New(s.pool)

	var pgEventID pgtype.Int4
	if eventID != nil {
		pgEventID = pgtype.Int4{
			Int32: *eventID,
			Valid: true,
		}
	}
	rowsAffected, err := queries.DeleteFavouriteByEventDetails(context.Background(), sqlc.DeleteFavouriteByEventDetailsParams{
		EventGuid:    eventGUID,
		EventID:      pgEventID,
		UserID:       id,
		ConferenceID: conferenceID,
	})
	if err != nil {
		return fmt.Errorf("could not delete favourite: %w", err)
	}
	if rowsAffected == 0 {
		return ErrNotFound
	}

	return nil
}