diff options
author | Frédéric Guillot <fred@miniflux.net> | 2018-06-19 22:58:29 -0700 |
---|---|---|
committer | Frédéric Guillot <fred@miniflux.net> | 2018-06-19 22:58:29 -0700 |
commit | bddca15b69692bd055c507f2469e68dca1e56098 (patch) | |
tree | 913989e170cc3ac46558c682f8ec10813a0ae3c5 /api/payload.go | |
parent | 261695c14c2d768f392cfb774e7940660edaa3d9 (diff) |
Add new fields for feed username/password
Diffstat (limited to 'api/payload.go')
-rw-r--r-- | api/payload.go | 45 |
1 files changed, 26 insertions, 19 deletions
diff --git a/api/payload.go b/api/payload.go index bf470eb..45cb826 100644 --- a/api/payload.go +++ b/api/payload.go @@ -23,6 +23,20 @@ type entriesResponse struct { Entries model.Entries `json:"entries"` } +type feedCreation struct { + FeedURL string `json:"feed_url"` + CategoryID int64 `json:"category_id"` + Username string `json:"username"` + Password string `json:"password"` + Crawler bool `json:"crawler"` +} + +type subscriptionDiscovery struct { + URL string `json:"url"` + Username string `json:"username"` + Password string `json:"password"` +} + func decodeUserPayload(r io.ReadCloser) (*model.User, error) { var user model.User @@ -35,19 +49,16 @@ func decodeUserPayload(r io.ReadCloser) (*model.User, error) { return &user, nil } -func decodeURLPayload(r io.ReadCloser) (string, error) { - type payload struct { - URL string `json:"url"` - } +func decodeURLPayload(r io.ReadCloser) (*subscriptionDiscovery, error) { + defer r.Close() - var p payload + var s subscriptionDiscovery decoder := json.NewDecoder(r) - defer r.Close() - if err := decoder.Decode(&p); err != nil { - return "", fmt.Errorf("invalid JSON payload: %v", err) + if err := decoder.Decode(&s); err != nil { + return nil, fmt.Errorf("invalid JSON payload: %v", err) } - return p.URL, nil + return &s, nil } func decodeEntryStatusPayload(r io.ReadCloser) ([]int64, string, error) { @@ -66,20 +77,16 @@ func decodeEntryStatusPayload(r io.ReadCloser) ([]int64, string, error) { return p.EntryIDs, p.Status, nil } -func decodeFeedCreationPayload(r io.ReadCloser) (string, int64, error) { - type payload struct { - FeedURL string `json:"feed_url"` - CategoryID int64 `json:"category_id"` - } +func decodeFeedCreationPayload(r io.ReadCloser) (*feedCreation, error) { + defer r.Close() - var p payload + var fc feedCreation decoder := json.NewDecoder(r) - defer r.Close() - if err := decoder.Decode(&p); err != nil { - return "", 0, fmt.Errorf("invalid JSON payload: %v", err) + if err := decoder.Decode(&fc); err != nil { + return nil, fmt.Errorf("invalid JSON payload: %v", err) } - return p.FeedURL, p.CategoryID, nil + return &fc, nil } func decodeFeedModificationPayload(r io.ReadCloser) (*model.Feed, error) { |