126 lines
3.1 KiB
Go
126 lines
3.1 KiB
Go
package storage
|
|
|
|
import (
|
|
"database/sql"
|
|
"fmt"
|
|
"synlotto-website/models"
|
|
"time"
|
|
)
|
|
|
|
// todo should be a ticket function?
|
|
func GetSyndicateTickets(db *sql.DB, syndicateID int) []models.Ticket {
|
|
rows, err := db.Query(`
|
|
SELECT id, userId, syndicateId, game_type, draw_date, ball1, ball2, ball3, ball4, ball5, ball6,
|
|
bonus1, bonus2, matched_main, matched_bonus, prize_tier, prize_amount, prize_label, is_winner
|
|
FROM my_tickets
|
|
WHERE syndicateId = ?
|
|
ORDER BY draw_date DESC
|
|
`, syndicateID)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
defer rows.Close()
|
|
|
|
var tickets []models.Ticket
|
|
for rows.Next() {
|
|
var t models.Ticket
|
|
err := rows.Scan(
|
|
&t.Id, &t.UserId, &t.SyndicateId, &t.GameType, &t.DrawDate,
|
|
&t.Ball1, &t.Ball2, &t.Ball3, &t.Ball4, &t.Ball5, &t.Ball6,
|
|
&t.Bonus1, &t.Bonus2, &t.MatchedMain, &t.MatchedBonus,
|
|
&t.PrizeTier, &t.PrizeAmount, &t.PrizeLabel, &t.IsWinner,
|
|
)
|
|
if err == nil {
|
|
tickets = append(tickets, t)
|
|
}
|
|
}
|
|
return tickets
|
|
}
|
|
|
|
// both a read and inset break up
|
|
func AcceptInvite(db *sql.DB, inviteID, userID int) error {
|
|
var syndicateID int
|
|
err := db.QueryRow(`
|
|
SELECT syndicate_id FROM syndicate_invites
|
|
WHERE id = ? AND invited_user_id = ? AND status = 'pending'
|
|
`, inviteID, userID).Scan(&syndicateID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if err := UpdateInviteStatus(db, inviteID, "accepted"); err != nil {
|
|
return err
|
|
}
|
|
|
|
_, err = db.Exec(`
|
|
INSERT INTO syndicate_members (syndicate_id, user_id, joined_at)
|
|
VALUES (?, ?, CURRENT_TIMESTAMP)
|
|
`, syndicateID, userID)
|
|
return err
|
|
}
|
|
|
|
func CreateSyndicate(db *sql.DB, ownerID int, name, description string) (int64, error) {
|
|
tx, err := db.Begin()
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
defer tx.Rollback()
|
|
|
|
result, err := tx.Exec(`
|
|
INSERT INTO syndicates (name, description, owner_id, created_at)
|
|
VALUES (?, ?, ?, ?)
|
|
`, name, description, ownerID, time.Now())
|
|
if err != nil {
|
|
return 0, fmt.Errorf("failed to create syndicate: %w", err)
|
|
}
|
|
|
|
syndicateID, err := result.LastInsertId()
|
|
if err != nil {
|
|
return 0, fmt.Errorf("failed to get syndicate ID: %w", err)
|
|
}
|
|
|
|
_, err = tx.Exec(`
|
|
INSERT INTO syndicate_members (syndicate_id, user_id, role, joined_at)
|
|
VALUES (?, ?, 'manager', CURRENT_TIMESTAMP)
|
|
`, syndicateID, ownerID)
|
|
if err != nil {
|
|
return 0, fmt.Errorf("failed to add owner as member: %w", err)
|
|
}
|
|
|
|
if err := tx.Commit(); err != nil {
|
|
return 0, fmt.Errorf("commit failed: %w", err)
|
|
}
|
|
|
|
return syndicateID, nil
|
|
}
|
|
|
|
func InviteToSyndicate(db *sql.DB, inviterID, syndicateID int, username string) error {
|
|
var inviteeID int
|
|
err := db.QueryRow(`
|
|
SELECT id FROM users WHERE username = ?
|
|
`, username).Scan(&inviteeID)
|
|
if err == sql.ErrNoRows {
|
|
return fmt.Errorf("user not found")
|
|
} else if err != nil {
|
|
return err
|
|
}
|
|
|
|
var count int
|
|
err = db.QueryRow(`
|
|
SELECT COUNT(*) FROM syndicate_members
|
|
WHERE syndicate_id = ? AND user_id = ?
|
|
`, syndicateID, inviteeID).Scan(&count)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if count > 0 {
|
|
return fmt.Errorf("user already a member or invited")
|
|
}
|
|
|
|
_, err = db.Exec(`
|
|
INSERT INTO syndicate_members (syndicate_id, user_id, is_manager, status)
|
|
VALUES (?, ?, 0, 'invited')
|
|
`, syndicateID, inviteeID)
|
|
return err
|
|
}
|