13 type StatusPleroma struct {
14 InReplyToAccountAcct string `json:"in_reply_to_account_acct"`
17 type ReplyInfo struct {
19 Number int `json:"number"`
22 // Status is struct to hold status.
25 URI string `json:"uri"`
26 URL string `json:"url"`
27 Account Account `json:"account"`
28 InReplyToID interface{} `json:"in_reply_to_id"`
29 InReplyToAccountID interface{} `json:"in_reply_to_account_id"`
30 Reblog *Status `json:"reblog"`
31 Content string `json:"content"`
32 CreatedAt time.Time `json:"created_at"`
33 Emojis []Emoji `json:"emojis"`
34 RepliesCount int64 `json:"replies_count"`
35 ReblogsCount int64 `json:"reblogs_count"`
36 FavouritesCount int64 `json:"favourites_count"`
37 Reblogged interface{} `json:"reblogged"`
38 Favourited interface{} `json:"favourited"`
39 Muted interface{} `json:"muted"`
40 Sensitive bool `json:"sensitive"`
41 SpoilerText string `json:"spoiler_text"`
42 Visibility string `json:"visibility"`
43 MediaAttachments []Attachment `json:"media_attachments"`
44 Mentions []Mention `json:"mentions"`
45 Tags []Tag `json:"tags"`
46 Card *Card `json:"card"`
47 Application Application `json:"application"`
48 Language string `json:"language"`
49 Pinned interface{} `json:"pinned"`
52 Pleroma StatusPleroma `json:"pleroma"`
53 ShowReplies bool `json:"show_replies"`
54 ReplyMap map[string][]ReplyInfo `json:"reply_map"`
55 ReplyNumber int `json:"reply_number"`
56 RetweetedByID string `json:"retweeted_by_id"`
59 // Context hold information for mastodon context.
61 Ancestors []*Status `json:"ancestors"`
62 Descendants []*Status `json:"descendants"`
65 // Card hold information for mastodon card.
67 URL string `json:"url"`
68 Title string `json:"title"`
69 Description string `json:"description"`
70 Image string `json:"image"`
71 Type string `json:"type"`
72 AuthorName string `json:"author_name"`
73 AuthorURL string `json:"author_url"`
74 ProviderName string `json:"provider_name"`
75 ProviderURL string `json:"provider_url"`
76 HTML string `json:"html"`
77 Width int64 `json:"width"`
78 Height int64 `json:"height"`
81 // GetFavourites return the favorite list of the current user.
82 func (c *Client) GetFavourites(ctx context.Context, pg *Pagination) ([]*Status, error) {
83 var statuses []*Status
84 err := c.doAPI(ctx, http.MethodGet, "/api/v1/favourites", nil, &statuses, pg)
91 // GetStatus return status specified by id.
92 func (c *Client) GetStatus(ctx context.Context, id string) (*Status, error) {
94 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/statuses/%s", id), nil, &status, nil)
101 // GetStatusContext return status specified by id.
102 func (c *Client) GetStatusContext(ctx context.Context, id string) (*Context, error) {
104 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/statuses/%s/context", id), nil, &context, nil)
111 // GetStatusCard return status specified by id.
112 func (c *Client) GetStatusCard(ctx context.Context, id string) (*Card, error) {
114 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/statuses/%s/card", id), nil, &card, nil)
121 // GetRebloggedBy returns the account list of the user who reblogged the toot of id.
122 func (c *Client) GetRebloggedBy(ctx context.Context, id string, pg *Pagination) ([]*Account, error) {
123 var accounts []*Account
124 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/statuses/%s/reblogged_by", id), nil, &accounts, pg)
131 // GetFavouritedBy returns the account list of the user who liked the toot of id.
132 func (c *Client) GetFavouritedBy(ctx context.Context, id string, pg *Pagination) ([]*Account, error) {
133 var accounts []*Account
134 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/statuses/%s/favourited_by", id), nil, &accounts, pg)
141 // Reblog is reblog the toot of id and return status of reblog.
142 func (c *Client) Reblog(ctx context.Context, id string) (*Status, error) {
144 err := c.doAPI(ctx, http.MethodPost, fmt.Sprintf("/api/v1/statuses/%s/reblog", id), nil, &status, nil)
151 // Unreblog is unreblog the toot of id and return status of the original toot.
152 func (c *Client) Unreblog(ctx context.Context, id string) (*Status, error) {
154 err := c.doAPI(ctx, http.MethodPost, fmt.Sprintf("/api/v1/statuses/%s/unreblog", id), nil, &status, nil)
161 // Favourite is favourite the toot of id and return status of the favourite toot.
162 func (c *Client) Favourite(ctx context.Context, id string) (*Status, error) {
164 err := c.doAPI(ctx, http.MethodPost, fmt.Sprintf("/api/v1/statuses/%s/favourite", id), nil, &status, nil)
171 // Unfavourite is unfavourite the toot of id and return status of the unfavourite toot.
172 func (c *Client) Unfavourite(ctx context.Context, id string) (*Status, error) {
174 err := c.doAPI(ctx, http.MethodPost, fmt.Sprintf("/api/v1/statuses/%s/unfavourite", id), nil, &status, nil)
181 // GetTimelineHome return statuses from home timeline.
182 func (c *Client) GetTimelineHome(ctx context.Context, pg *Pagination) ([]*Status, error) {
183 var statuses []*Status
184 err := c.doAPI(ctx, http.MethodGet, "/api/v1/timelines/home", nil, &statuses, pg)
191 // GetTimelinePublic return statuses from public timeline.
192 func (c *Client) GetTimelinePublic(ctx context.Context, isLocal bool, pg *Pagination) ([]*Status, error) {
193 params := url.Values{}
195 params.Set("local", "true")
198 var statuses []*Status
199 err := c.doAPI(ctx, http.MethodGet, "/api/v1/timelines/public", params, &statuses, pg)
206 // GetTimelineHashtag return statuses from tagged timeline.
207 func (c *Client) GetTimelineHashtag(ctx context.Context, tag string, isLocal bool, pg *Pagination) ([]*Status, error) {
208 params := url.Values{}
210 params.Set("local", "t")
213 var statuses []*Status
214 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/timelines/tag/%s", url.PathEscape(tag)), params, &statuses, pg)
221 // GetTimelineList return statuses from a list timeline.
222 func (c *Client) GetTimelineList(ctx context.Context, id string, pg *Pagination) ([]*Status, error) {
223 var statuses []*Status
224 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/timelines/list/%s", url.PathEscape(string(id))), nil, &statuses, pg)
231 // GetTimelineMedia return statuses from media timeline.
232 // NOTE: This is an experimental feature of pawoo.net.
233 func (c *Client) GetTimelineMedia(ctx context.Context, isLocal bool, pg *Pagination) ([]*Status, error) {
234 params := url.Values{}
235 params.Set("media", "t")
237 params.Set("local", "t")
240 var statuses []*Status
241 err := c.doAPI(ctx, http.MethodGet, "/api/v1/timelines/public", params, &statuses, pg)
248 // PostStatus post the toot.
249 func (c *Client) PostStatus(ctx context.Context, toot *Toot) (*Status, error) {
250 params := url.Values{}
251 params.Set("status", toot.Status)
252 if toot.InReplyToID != "" {
253 params.Set("in_reply_to_id", string(toot.InReplyToID))
255 if toot.MediaIDs != nil {
256 for _, media := range toot.MediaIDs {
257 params.Add("media_ids[]", string(media))
260 if toot.Visibility != "" {
261 params.Set("visibility", fmt.Sprint(toot.Visibility))
264 params.Set("sensitive", "true")
266 if toot.SpoilerText != "" {
267 params.Set("spoiler_text", toot.SpoilerText)
269 if toot.ContentType != "" {
270 params.Set("content_type", toot.ContentType)
274 err := c.doAPI(ctx, http.MethodPost, "/api/v1/statuses", params, &status, nil)
281 // DeleteStatus delete the toot.
282 func (c *Client) DeleteStatus(ctx context.Context, id string) error {
283 return c.doAPI(ctx, http.MethodDelete, fmt.Sprintf("/api/v1/statuses/%s", id), nil, nil, nil)
286 // Search search content with query.
287 func (c *Client) Search(ctx context.Context, q string, qType string, limit int, resolve bool, offset int) (*Results, error) {
288 params := url.Values{}
290 params.Set("type", qType)
291 params.Set("limit", fmt.Sprint(limit))
292 params.Set("resolve", fmt.Sprint(resolve))
293 params.Set("offset", fmt.Sprint(offset))
295 err := c.doAPI(ctx, http.MethodGet, "/api/v2/search", params, &results, nil)
302 // UploadMedia upload a media attachment from a file.
303 func (c *Client) UploadMedia(ctx context.Context, file string) (*Attachment, error) {
304 var attachment Attachment
305 err := c.doAPI(ctx, http.MethodPost, "/api/v1/media", file, &attachment, nil)
309 return &attachment, nil
312 // UploadMediaFromReader uploads a media attachment from a io.Reader.
313 func (c *Client) UploadMediaFromReader(ctx context.Context, reader io.Reader) (*Attachment, error) {
314 var attachment Attachment
315 err := c.doAPI(ctx, http.MethodPost, "/api/v1/media", reader, &attachment, nil)
319 return &attachment, nil
322 // UploadMediaFromReader uploads a media attachment from a io.Reader.
323 func (c *Client) UploadMediaFromMultipartFileHeader(ctx context.Context, fh *multipart.FileHeader) (*Attachment, error) {
324 var attachment Attachment
325 err := c.doAPI(ctx, http.MethodPost, "/api/v1/media", fh, &attachment, nil)
329 return &attachment, nil
332 // GetTimelineDirect return statuses from direct timeline.
333 func (c *Client) GetTimelineDirect(ctx context.Context, pg *Pagination) ([]*Status, error) {
334 params := url.Values{}
336 var statuses []*Status
337 err := c.doAPI(ctx, http.MethodGet, "/api/v1/timelines/direct", params, &statuses, pg)