From f49b42f70f902d4da1e0fa4080e99164b331b716 Mon Sep 17 00:00:00 2001 From: Frédéric Guillot Date: Sun, 29 Apr 2018 16:35:04 -0700 Subject: Use vanilla HTTP handlers (refactoring) --- api/payload.go | 30 ++++++++++++++++++------------ 1 file changed, 18 insertions(+), 12 deletions(-) (limited to 'api/payload.go') diff --git a/api/payload.go b/api/payload.go index 46c3b04..bf470eb 100644 --- a/api/payload.go +++ b/api/payload.go @@ -23,10 +23,11 @@ type entriesResponse struct { Entries model.Entries `json:"entries"` } -func decodeUserPayload(data io.Reader) (*model.User, error) { +func decodeUserPayload(r io.ReadCloser) (*model.User, error) { var user model.User - decoder := json.NewDecoder(data) + decoder := json.NewDecoder(r) + defer r.Close() if err := decoder.Decode(&user); err != nil { return nil, fmt.Errorf("Unable to decode user JSON object: %v", err) } @@ -34,13 +35,14 @@ func decodeUserPayload(data io.Reader) (*model.User, error) { return &user, nil } -func decodeURLPayload(data io.Reader) (string, error) { +func decodeURLPayload(r io.ReadCloser) (string, error) { type payload struct { URL string `json:"url"` } var p payload - decoder := json.NewDecoder(data) + decoder := json.NewDecoder(r) + defer r.Close() if err := decoder.Decode(&p); err != nil { return "", fmt.Errorf("invalid JSON payload: %v", err) } @@ -48,14 +50,15 @@ func decodeURLPayload(data io.Reader) (string, error) { return p.URL, nil } -func decodeEntryStatusPayload(data io.Reader) ([]int64, string, error) { +func decodeEntryStatusPayload(r io.ReadCloser) ([]int64, string, error) { type payload struct { EntryIDs []int64 `json:"entry_ids"` Status string `json:"status"` } var p payload - decoder := json.NewDecoder(data) + decoder := json.NewDecoder(r) + defer r.Close() if err := decoder.Decode(&p); err != nil { return nil, "", fmt.Errorf("invalid JSON payload: %v", err) } @@ -63,14 +66,15 @@ func decodeEntryStatusPayload(data io.Reader) ([]int64, string, error) { return p.EntryIDs, p.Status, nil } -func decodeFeedCreationPayload(data io.Reader) (string, int64, error) { +func decodeFeedCreationPayload(r io.ReadCloser) (string, int64, error) { type payload struct { FeedURL string `json:"feed_url"` CategoryID int64 `json:"category_id"` } var p payload - decoder := json.NewDecoder(data) + decoder := json.NewDecoder(r) + defer r.Close() if err := decoder.Decode(&p); err != nil { return "", 0, fmt.Errorf("invalid JSON payload: %v", err) } @@ -78,10 +82,11 @@ func decodeFeedCreationPayload(data io.Reader) (string, int64, error) { return p.FeedURL, p.CategoryID, nil } -func decodeFeedModificationPayload(data io.Reader) (*model.Feed, error) { +func decodeFeedModificationPayload(r io.ReadCloser) (*model.Feed, error) { var feed model.Feed - decoder := json.NewDecoder(data) + decoder := json.NewDecoder(r) + defer r.Close() if err := decoder.Decode(&feed); err != nil { return nil, fmt.Errorf("Unable to decode feed JSON object: %v", err) } @@ -89,10 +94,11 @@ func decodeFeedModificationPayload(data io.Reader) (*model.Feed, error) { return &feed, nil } -func decodeCategoryPayload(data io.Reader) (*model.Category, error) { +func decodeCategoryPayload(r io.ReadCloser) (*model.Category, error) { var category model.Category - decoder := json.NewDecoder(data) + decoder := json.NewDecoder(r) + defer r.Close() if err := decoder.Decode(&category); err != nil { return nil, fmt.Errorf("Unable to decode category JSON object: %v", err) } -- cgit v1.2.3