2016-06-12 22:39:00 +00:00
|
|
|
package footballdata
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
type TeamFixturesRequest struct{ request }
|
|
|
|
|
2016-06-25 10:15:58 +00:00
|
|
|
// TimeFrame Modifies the request to specify a specific time frame.
|
2016-06-12 22:39:00 +00:00
|
|
|
func (r TeamFixturesRequest) TimeFrame(timeframe time.Duration) TeamFixturesRequest {
|
2016-06-25 10:15:58 +00:00
|
|
|
r.urlValues.Set("timeFrame", durationToTimeFrame(timeframe))
|
2016-06-12 22:39:00 +00:00
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
2016-06-25 10:15:58 +00:00
|
|
|
// Season Modifies the request to specify a list of leagues by their code.
|
2016-06-12 22:39:00 +00:00
|
|
|
func (r TeamFixturesRequest) Season(season uint64) TeamFixturesRequest {
|
2016-06-25 10:15:58 +00:00
|
|
|
r.urlValues.Set("season", fmt.Sprintf("%d", season))
|
2016-06-12 22:39:00 +00:00
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
2016-06-25 10:15:58 +00:00
|
|
|
// Venue Modifies the request to specify a venue.
|
2016-06-12 22:39:00 +00:00
|
|
|
func (r TeamFixturesRequest) Venue(venue Venue) TeamFixturesRequest {
|
2016-06-25 10:15:58 +00:00
|
|
|
r.urlValues.Set("venue", string(venue))
|
2016-06-12 22:39:00 +00:00
|
|
|
return r
|
|
|
|
}
|
|
|
|
|
2016-06-25 10:15:58 +00:00
|
|
|
// Do Executes the request.
|
2016-06-12 22:39:00 +00:00
|
|
|
func (r TeamFixturesRequest) Do() (s FixturesResponse, err error) {
|
|
|
|
d, _, err := r.doJson("GET")
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
err = d.Decode(&s)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2016-06-25 10:15:58 +00:00
|
|
|
// FixturesOfTeam Prepares a request to fetch the fixtures of a soccer season.
|
|
|
|
func (c *client) FixturesOfTeam(id uint64) TeamFixturesRequest {
|
2016-06-13 17:47:09 +00:00
|
|
|
return TeamFixturesRequest{c.req("teams/%d/fixtures", id)}
|
2016-06-12 22:39:00 +00:00
|
|
|
}
|