diff options
author | Frédéric Guillot <fred@miniflux.net> | 2018-04-29 16:35:04 -0700 |
---|---|---|
committer | Frédéric Guillot <fred@miniflux.net> | 2018-04-29 16:35:04 -0700 |
commit | f49b42f70f902d4da1e0fa4080e99164b331b716 (patch) | |
tree | c6bdd19f11d100c44b0d30344ec37038f649e988 /api/payload.go | |
parent | 1eba1730d1af50ed545f4fde78b22d6fb62ca11e (diff) |
Use vanilla HTTP handlers (refactoring)
Diffstat (limited to 'api/payload.go')
-rw-r--r-- | api/payload.go | 30 |
1 files changed, 18 insertions, 12 deletions
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) } |