59 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package repos
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"gralias/models"
 | |
| 
 | |
| 	"github.com/jmoiron/sqlx"
 | |
| )
 | |
| 
 | |
| type WordCardsRepo interface {
 | |
| 	WordCardsCreate(ctx context.Context, card *models.WordCard) error
 | |
| 	WordCardsGetByRoomID(ctx context.Context, roomID string) ([]models.WordCard, error)
 | |
| 	WordCardGetByWordAndRoomID(ctx context.Context, word, roomID string) (*models.WordCard, error)
 | |
| 	WordCardReveal(ctx context.Context, word, roomID string) error
 | |
| 	WordCardsRevealAll(ctx context.Context, roomID string) error
 | |
| 	WordCardsDeleteByRoomID(ctx context.Context, roomID string) error
 | |
| }
 | |
| 
 | |
| func (p *RepoProvider) WordCardsCreate(ctx context.Context, card *models.WordCard) error {
 | |
| 	db := getDB(ctx, p.DB)
 | |
| 	_, err := db.ExecContext(ctx, `INSERT INTO word_cards (room_id, word, color, revealed, mime_view) VALUES (?, ?, ?, ?, ?)`, card.RoomID, card.Word, card.Color, card.Revealed, card.Mime)
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func (p *RepoProvider) WordCardsGetByRoomID(ctx context.Context, roomID string) ([]models.WordCard, error) {
 | |
| 	cards := []models.WordCard{}
 | |
| 	err := sqlx.SelectContext(ctx, p.DB, &cards, `SELECT * FROM word_cards WHERE room_id = ?`, roomID)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return cards, nil
 | |
| }
 | |
| 
 | |
| func (p *RepoProvider) WordCardGetByWordAndRoomID(ctx context.Context, word, roomID string) (*models.WordCard, error) {
 | |
| 	card := &models.WordCard{}
 | |
| 	err := sqlx.GetContext(ctx, p.DB, card, `SELECT * FROM word_cards WHERE word = ? AND room_id = ?`, word, roomID)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return card, nil
 | |
| }
 | |
| 
 | |
| func (p *RepoProvider) WordCardReveal(ctx context.Context, word, roomID string) error {
 | |
| 	db := getDB(ctx, p.DB)
 | |
| 	_, err := db.ExecContext(ctx, `UPDATE word_cards SET revealed = TRUE WHERE word = ? AND room_id = ?`, word, roomID)
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func (p *RepoProvider) WordCardsRevealAll(ctx context.Context, roomID string) error {
 | |
| 	db := getDB(ctx, p.DB)
 | |
| 	_, err := db.ExecContext(ctx, `UPDATE word_cards SET revealed = TRUE WHERE room_id = ?`, roomID)
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func (p *RepoProvider) WordCardsDeleteByRoomID(ctx context.Context, roomID string) error {
 | |
| 	db := getDB(ctx, p.DB)
 | |
| 	_, err := db.ExecContext(ctx, `DELETE FROM word_cards WHERE room_id = ?`, roomID)
 | |
| 	return err
 | |
| } | 
