mirror of
https://github.com/Team254/cheesy-arena-lite.git
synced 2026-03-10 06:06:47 -04:00
60 lines
1.3 KiB
Go
60 lines
1.3 KiB
Go
// Copyright 2014 Team 254. All Rights Reserved.
|
|
// Author: pat@patfairbank.com (Patrick Fairbank)
|
|
//
|
|
// Model and datastore CRUD methods for a match at an event.
|
|
|
|
package main
|
|
|
|
import (
|
|
"time"
|
|
)
|
|
|
|
type Match struct {
|
|
Id int
|
|
Type string
|
|
DisplayName string
|
|
Time time.Time
|
|
Red1 int
|
|
Red1IsSurrogate bool
|
|
Red2 int
|
|
Red2IsSurrogate bool
|
|
Red3 int
|
|
Red3IsSurrogate bool
|
|
Blue1 int
|
|
Blue1IsSurrogate bool
|
|
Blue2 int
|
|
Blue2IsSurrogate bool
|
|
Blue3 int
|
|
Blue3IsSurrogate bool
|
|
Status string
|
|
StartedAt time.Time
|
|
}
|
|
|
|
func (database *Database) CreateMatch(match *Match) error {
|
|
return database.matchMap.Insert(match)
|
|
}
|
|
|
|
func (database *Database) GetMatchById(id int) (*Match, error) {
|
|
match := new(Match)
|
|
err := database.matchMap.Get(match, id)
|
|
if err != nil && err.Error() == "sql: no rows in result set" {
|
|
match = nil
|
|
err = nil
|
|
}
|
|
return match, err
|
|
}
|
|
|
|
func (database *Database) SaveMatch(match *Match) error {
|
|
_, err := database.matchMap.Update(match)
|
|
return err
|
|
}
|
|
|
|
func (database *Database) DeleteMatch(match *Match) error {
|
|
_, err := database.matchMap.Delete(match)
|
|
return err
|
|
}
|
|
|
|
func (database *Database) TruncateMatches() error {
|
|
return database.matchMap.TruncateTables()
|
|
}
|