10 // List is metadata for a list of users.
13 Title string `json:"title"`
16 // GetLists returns all the lists on the current account.
17 func (c *Client) GetLists(ctx context.Context) ([]*List, error) {
19 err := c.doAPI(ctx, http.MethodGet, "/api/v1/lists", nil, &lists, nil)
26 // GetAccountLists returns the lists containing a given account.
27 func (c *Client) GetAccountLists(ctx context.Context, id string) ([]*List, error) {
29 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/accounts/%s/lists", url.PathEscape(string(id))), nil, &lists, nil)
36 // GetListAccounts returns the accounts in a given list.
37 func (c *Client) GetListAccounts(ctx context.Context, id string) ([]*Account, error) {
38 var accounts []*Account
39 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/lists/%s/accounts", url.PathEscape(string(id))), url.Values{"limit": {"0"}}, &accounts, nil)
46 // GetList retrieves a list by string.
47 func (c *Client) GetList(ctx context.Context, id string) (*List, error) {
49 err := c.doAPI(ctx, http.MethodGet, fmt.Sprintf("/api/v1/lists/%s", url.PathEscape(string(id))), nil, &list, nil)
56 // CreateList creates a new list with a given title.
57 func (c *Client) CreateList(ctx context.Context, title string) (*List, error) {
58 params := url.Values{}
59 params.Set("title", title)
62 err := c.doAPI(ctx, http.MethodPost, "/api/v1/lists", params, &list, nil)
69 // RenameList assigns a new title to a list.
70 func (c *Client) RenameList(ctx context.Context, id string, title string) (*List, error) {
71 params := url.Values{}
72 params.Set("title", title)
75 err := c.doAPI(ctx, http.MethodPut, fmt.Sprintf("/api/v1/lists/%s", url.PathEscape(string(id))), params, &list, nil)
82 // DeleteList removes a list.
83 func (c *Client) DeleteList(ctx context.Context, id string) error {
84 return c.doAPI(ctx, http.MethodDelete, fmt.Sprintf("/api/v1/lists/%s", url.PathEscape(string(id))), nil, nil, nil)
87 // AddToList adds accounts to a list.
89 // Only accounts already followed by the user can be added to a list.
90 func (c *Client) AddToList(ctx context.Context, list string, accounts ...string) error {
91 params := url.Values{}
92 for _, acct := range accounts {
93 params.Add("account_ids", string(acct))
96 return c.doAPI(ctx, http.MethodPost, fmt.Sprintf("/api/v1/lists/%s/accounts", url.PathEscape(string(list))), params, nil, nil)
99 // RemoveFromList removes accounts from a list.
100 func (c *Client) RemoveFromList(ctx context.Context, list string, accounts ...string) error {
101 params := url.Values{}
102 for _, acct := range accounts {
103 params.Add("account_ids", string(acct))
106 return c.doAPI(ctx, http.MethodDelete, fmt.Sprintf("/api/v1/lists/%s/accounts", url.PathEscape(string(list))), params, nil, nil)