2020-07-11 13:49:07 -04:00
|
|
|
package reddit
|
2020-04-29 15:59:18 -04:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
2020-07-11 14:11:41 -04:00
|
|
|
"net/http"
|
2020-04-29 15:59:18 -04:00
|
|
|
"net/url"
|
|
|
|
"strings"
|
2020-05-04 15:16:34 -04:00
|
|
|
|
|
|
|
"github.com/google/go-querystring/query"
|
2020-04-29 15:59:18 -04:00
|
|
|
)
|
|
|
|
|
2020-06-27 23:53:59 -04:00
|
|
|
// PostService handles communication with the post
|
2020-06-22 21:52:34 -04:00
|
|
|
// related methods of the Reddit API.
|
2020-07-13 23:05:24 -04:00
|
|
|
//
|
|
|
|
// Reddit API docs: https://www.reddit.com/dev/api/#section_links_and_comments
|
2020-06-27 23:53:59 -04:00
|
|
|
type PostService service
|
2020-04-29 15:59:18 -04:00
|
|
|
|
2020-05-04 15:16:34 -04:00
|
|
|
type submittedLinkRoot struct {
|
|
|
|
JSON struct {
|
|
|
|
Data *Submitted `json:"data,omitempty"`
|
|
|
|
} `json:"json"`
|
|
|
|
}
|
|
|
|
|
2020-06-22 21:52:34 -04:00
|
|
|
// Submitted is a newly submitted post on Reddit.
|
2020-05-04 15:16:34 -04:00
|
|
|
type Submitted struct {
|
|
|
|
ID string `json:"id,omitempty"`
|
|
|
|
FullID string `json:"name,omitempty"`
|
|
|
|
URL string `json:"url,omitempty"`
|
|
|
|
}
|
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
// SubmitTextOptions are options used for text posts.
|
|
|
|
type SubmitTextOptions struct {
|
2020-05-04 15:16:34 -04:00
|
|
|
Subreddit string `url:"sr,omitempty"`
|
|
|
|
Title string `url:"title,omitempty"`
|
|
|
|
Text string `url:"text,omitempty"`
|
|
|
|
|
|
|
|
FlairID string `url:"flair_id,omitempty"`
|
|
|
|
FlairText string `url:"flair_text,omitempty"`
|
|
|
|
|
|
|
|
SendReplies *bool `url:"sendreplies,omitempty"`
|
|
|
|
NSFW bool `url:"nsfw,omitempty"`
|
|
|
|
Spoiler bool `url:"spoiler,omitempty"`
|
|
|
|
}
|
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
// SubmitLinkOptions are options used for link posts.
|
|
|
|
type SubmitLinkOptions struct {
|
2020-05-04 15:16:34 -04:00
|
|
|
Subreddit string `url:"sr,omitempty"`
|
|
|
|
Title string `url:"title,omitempty"`
|
|
|
|
URL string `url:"url,omitempty"`
|
|
|
|
|
|
|
|
FlairID string `url:"flair_id,omitempty"`
|
|
|
|
FlairText string `url:"flair_text,omitempty"`
|
|
|
|
|
|
|
|
SendReplies *bool `url:"sendreplies,omitempty"`
|
|
|
|
Resubmit bool `url:"resubmit,omitempty"`
|
|
|
|
NSFW bool `url:"nsfw,omitempty"`
|
|
|
|
Spoiler bool `url:"spoiler,omitempty"`
|
|
|
|
}
|
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
func (s *PostService) submit(ctx context.Context, v interface{}) (*Submitted, *Response, error) {
|
|
|
|
path := "api/submit"
|
|
|
|
|
|
|
|
form, err := query.Values(v)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
form.Set("api_type", "json")
|
|
|
|
|
|
|
|
req, err := s.client.NewRequestWithForm(http.MethodPost, path, form)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
root := new(submittedLinkRoot)
|
|
|
|
resp, err := s.client.Do(ctx, req, root)
|
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return root.JSON.Data, resp, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// SubmitText submits a text post.
|
|
|
|
func (s *PostService) SubmitText(ctx context.Context, opts SubmitTextOptions) (*Submitted, *Response, error) {
|
2020-05-04 15:16:34 -04:00
|
|
|
type submit struct {
|
2020-07-13 23:05:24 -04:00
|
|
|
SubmitTextOptions
|
2020-05-04 15:16:34 -04:00
|
|
|
Kind string `url:"kind,omitempty"`
|
|
|
|
}
|
|
|
|
return s.submit(ctx, &submit{opts, "self"})
|
|
|
|
}
|
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
// SubmitLink submits a link post.
|
|
|
|
func (s *PostService) SubmitLink(ctx context.Context, opts SubmitLinkOptions) (*Submitted, *Response, error) {
|
2020-05-04 15:16:34 -04:00
|
|
|
type submit struct {
|
2020-07-13 23:05:24 -04:00
|
|
|
SubmitLinkOptions
|
2020-05-04 15:16:34 -04:00
|
|
|
Kind string `url:"kind,omitempty"`
|
|
|
|
}
|
|
|
|
return s.submit(ctx, &submit{opts, "link"})
|
|
|
|
}
|
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
// Edit edits a post.
|
|
|
|
func (s *PostService) Edit(ctx context.Context, id string, text string) (*Post, *Response, error) {
|
|
|
|
path := "api/editusertext"
|
2020-05-04 15:16:34 -04:00
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
form := url.Values{}
|
2020-05-04 15:16:34 -04:00
|
|
|
form.Set("api_type", "json")
|
2020-07-13 23:05:24 -04:00
|
|
|
form.Set("return_rtjson", "true")
|
|
|
|
form.Set("thing_id", id)
|
|
|
|
form.Set("text", text)
|
2020-05-04 15:16:34 -04:00
|
|
|
|
2020-07-11 14:11:41 -04:00
|
|
|
req, err := s.client.NewRequestWithForm(http.MethodPost, path, form)
|
2020-05-04 15:16:34 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
root := new(Post)
|
2020-05-04 15:16:34 -04:00
|
|
|
resp, err := s.client.Do(ctx, req, root)
|
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
return root, resp, nil
|
2020-05-04 15:16:34 -04:00
|
|
|
}
|
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
// Hide hides posts.
|
|
|
|
func (s *PostService) Hide(ctx context.Context, ids ...string) (*Response, error) {
|
|
|
|
if len(ids) == 0 {
|
|
|
|
return nil, errors.New("must provide at least 1 id")
|
|
|
|
}
|
|
|
|
|
|
|
|
path := "api/hide"
|
2020-05-04 15:16:34 -04:00
|
|
|
|
|
|
|
form := url.Values{}
|
2020-07-13 23:05:24 -04:00
|
|
|
form.Set("id", strings.Join(ids, ","))
|
2020-05-04 15:16:34 -04:00
|
|
|
|
2020-07-11 14:11:41 -04:00
|
|
|
req, err := s.client.NewRequestWithForm(http.MethodPost, path, form)
|
2020-05-04 15:16:34 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s.client.Do(ctx, req, nil)
|
|
|
|
}
|
|
|
|
|
2020-07-13 23:05:24 -04:00
|
|
|
// Unhide unhides posts.
|
|
|
|
func (s *PostService) Unhide(ctx context.Context, ids ...string) (*Response, error) {
|
|
|
|
if len(ids) == 0 {
|
|
|
|
return nil, errors.New("must provide at least 1 id")
|
|
|
|
}
|
|
|
|
|
|
|
|
path := "api/unhide"
|
2020-05-04 15:16:34 -04:00
|
|
|
|
|
|
|
form := url.Values{}
|
2020-07-13 23:05:24 -04:00
|
|
|
form.Set("id", strings.Join(ids, ","))
|
2020-05-04 15:16:34 -04:00
|
|
|
|
2020-07-11 14:11:41 -04:00
|
|
|
req, err := s.client.NewRequestWithForm(http.MethodPost, path, form)
|
2020-05-04 15:16:34 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s.client.Do(ctx, req, nil)
|
|
|
|
}
|
|
|
|
|
2020-06-22 21:52:34 -04:00
|
|
|
// MarkNSFW marks a post as NSFW.
|
2020-06-27 23:53:59 -04:00
|
|
|
func (s *PostService) MarkNSFW(ctx context.Context, id string) (*Response, error) {
|
2020-05-04 15:16:34 -04:00
|
|
|
path := "api/marknsfw"
|
|
|
|
|
|
|
|
form := url.Values{}
|
|
|
|
form.Set("id", id)
|
|
|
|
|
2020-07-11 14:11:41 -04:00
|
|
|
req, err := s.client.NewRequestWithForm(http.MethodPost, path, form)
|
2020-05-04 15:16:34 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s.client.Do(ctx, req, nil)
|
|
|
|
}
|
|
|
|
|
2020-06-22 21:52:34 -04:00
|
|
|
// UnmarkNSFW unmarks a post as NSFW.
|
2020-06-27 23:53:59 -04:00
|
|
|
func (s *PostService) UnmarkNSFW(ctx context.Context, id string) (*Response, error) {
|
2020-05-04 15:16:34 -04:00
|
|
|
path := "api/unmarknsfw"
|
|
|
|
|
|
|
|
form := url.Values{}
|
|
|
|
form.Set("id", id)
|
|
|
|
|
2020-07-11 14:11:41 -04:00
|
|
|
req, err := s.client.NewRequestWithForm(http.MethodPost, path, form)
|
2020-05-04 15:16:34 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s.client.Do(ctx, req, nil)
|
|
|
|
}
|
|
|
|
|
2020-06-22 21:52:34 -04:00
|
|
|
// Spoiler marks a post as a spoiler.
|
2020-06-27 23:53:59 -04:00
|
|
|
func (s *PostService) Spoiler(ctx context.Context, id string) (*Response, error) {
|
2020-05-04 15:16:34 -04:00
|
|
|
path := "api/spoiler"
|
|
|
|
|
|
|
|
form := url.Values{}
|
|
|
|
form.Set("id", id)
|
|
|
|
|
2020-07-11 14:11:41 -04:00
|
|
|
req, err := s.client.NewRequestWithForm(http.MethodPost, path, form)
|
2020-05-04 15:16:34 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s.client.Do(ctx, req, nil)
|
|
|
|
}
|
|
|
|
|
2020-06-22 21:52:34 -04:00
|
|
|
// Unspoiler unmarks a post as a spoiler.
|
2020-06-27 23:53:59 -04:00
|
|
|
func (s *PostService) Unspoiler(ctx context.Context, id string) (*Response, error) {
|
2020-05-04 15:16:34 -04:00
|
|
|
path := "api/unspoiler"
|
|
|
|
|
|
|
|
form := url.Values{}
|
|
|
|
form.Set("id", id)
|
|
|
|
|
2020-07-11 14:11:41 -04:00
|
|
|
req, err := s.client.NewRequestWithForm(http.MethodPost, path, form)
|
2020-05-04 15:16:34 -04:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s.client.Do(ctx, req, nil)
|
|
|
|
}
|