Skip to content

Commit

Permalink
Extract helper for download request query params
Browse files Browse the repository at this point in the history
There's a proper abstraction lurking close by, but I'm not convinced I'm seeing it.
Instead of jumping to conclusions, this extracts a cohesive helper method
which can be moved onto the abstraction once it's defined.
  • Loading branch information
Katrina Owen committed Feb 27, 2019
1 parent 0ae6180 commit 7513bcb
Showing 1 changed file with 34 additions and 26 deletions.
60 changes: 34 additions & 26 deletions cmd/download.go
Original file line number Diff line number Diff line change
Expand Up @@ -54,16 +54,6 @@ func runDownload(cfg config.Config, flags *pflag.FlagSet, args []string) error {
return err
}

track, err := flags.GetString("track")
if err != nil {
return err
}

team, err := flags.GetString("team")
if err != nil {
return err
}

identifier, err := downloadIdentifier(flags)
if err != nil {
return err
Expand All @@ -80,25 +70,10 @@ func runDownload(cfg config.Config, flags *pflag.FlagSet, args []string) error {
return err
}

uuid, err := flags.GetString("uuid")
req, err = addQueryToDownloadRequest(flags, req)
if err != nil {
return err
}
slug, err := flags.GetString("exercise")
if err != nil {
return err
}
if uuid == "" {
q := req.URL.Query()
q.Add("exercise_id", slug)
if track != "" {
q.Add("track_id", track)
}
if team != "" {
q.Add("team_id", team)
}
req.URL.RawQuery = q.Encode()
}

res, err := client.Do(req)
if err != nil {
Expand Down Expand Up @@ -269,6 +244,39 @@ func downloadIdentifier(flags *pflag.FlagSet) (string, error) {
return identifier, nil
}

func addQueryToDownloadRequest(flags *pflag.FlagSet, req *http.Request) (*http.Request, error) {
uuid, err := flags.GetString("uuid")
if err != nil {
return req, err
}
slug, err := flags.GetString("exercise")
if err != nil {
return req, err
}
track, err := flags.GetString("track")
if err != nil {
return req, err
}

team, err := flags.GetString("team")
if err != nil {
return req, err
}

if uuid == "" {
q := req.URL.Query()
q.Add("exercise_id", slug)
if track != "" {
q.Add("track_id", track)
}
if team != "" {
q.Add("team_id", team)
}
req.URL.RawQuery = q.Encode()
}
return req, nil
}

func setupDownloadFlags(flags *pflag.FlagSet) {
flags.StringP("uuid", "u", "", "the solution UUID")
flags.StringP("track", "t", "", "the track ID")
Expand Down

0 comments on commit 7513bcb

Please sign in to comment.