account.go
author Mikael Berthe <mikael@lilotux.net>
Thu, 13 Apr 2017 23:43:10 +0200
changeset 115 0684ac8b6634
parent 114 0a1f493588ee
child 120 579912e9d0ef
permissions -rw-r--r--
Add FollowRequestAuthorize()
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
8
6d89be3dd966 Placeholders.
Ollivier Robert <roberto@keltia.net>
parents:
diff changeset
     1
package gondole
109
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
     2
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
     3
import (
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
     4
	"encoding/json"
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
     5
	"fmt"
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
     6
	"strconv"
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
     7
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
     8
	"github.com/sendgrid/rest"
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
     9
)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    10
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    11
// getAccountsOptions contains option fields for POST and DELETE API calls
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    12
type getAccountsOptions struct {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    13
	// The ID is used for most commands
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    14
	ID int
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    15
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    16
	// The following fields are used when searching for accounts
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    17
	Q     string
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    18
	Limit int
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    19
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    20
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    21
// getSingleAccount returns an account entity
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    22
// The target can be "account", "verify_credentials", "follow", "unfollow",
115
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
    23
// "block", "unblock", "mute", "unmute", "follow_requests/authorize" or
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
    24
// "follow_requests/reject".
109
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    25
// The id is optional and depends on the target.
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    26
func (g *Client) getSingleAccount(target string, id int) (*Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    27
	var endPoint string
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    28
	method := rest.Get
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    29
	strID := strconv.Itoa(id)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    30
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    31
	switch target {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    32
	case "account":
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    33
		endPoint = "accounts/" + strID
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    34
	case "verify_credentials":
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    35
		endPoint = "accounts/verify_credentials"
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    36
	case "follow", "unfollow", "block", "unblock", "mute", "unmute":
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    37
		endPoint = "accounts/" + strID + "/" + target
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    38
		method = rest.Post
115
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
    39
	case "follow_requests/authorize", "follow_requests/reject":
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
    40
		// The documentation is incorrect, the endpoint actually
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
    41
		// is "follow_requests/:id/{authorize|reject}"
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
    42
		endPoint = target[:16] + strID + "/" + target[16:]
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
    43
		method = rest.Post
109
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    44
	default:
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    45
		return nil, ErrInvalidParameter
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    46
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    47
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    48
	req := g.prepareRequest(endPoint)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    49
	req.Method = method
115
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
    50
109
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    51
	r, err := rest.API(req)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    52
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    53
		return nil, fmt.Errorf("getAccount (%s): %s", target, err.Error())
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    54
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    55
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    56
	// Check for error reply
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    57
	var errorResult Error
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    58
	if err := json.Unmarshal([]byte(r.Body), &errorResult); err == nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    59
		// The empty object is not an error
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    60
		if errorResult.Text != "" {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    61
			return nil, fmt.Errorf("%s", errorResult.Text)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    62
		}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    63
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    64
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
    65
	// Not an error reply; let's unmarshal the data
109
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    66
	var account Account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    67
	err = json.Unmarshal([]byte(r.Body), &account)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    68
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    69
		return nil, fmt.Errorf("getAccount (%s) API: %s", target, err.Error())
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    70
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    71
	return &account, nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    72
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    73
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    74
// getMultipleAccounts returns a list of account entities
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    75
// The target can be "followers", "following", "search", "blocks", "mutes",
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    76
// "follow_requests".
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    77
// The id is optional and depends on the target.
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    78
func (g *Client) getMultipleAccounts(target string, opts *getAccountsOptions) ([]Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    79
	var endPoint string
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    80
	switch target {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    81
	case "followers", "following":
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    82
		if opts == nil || opts.ID < 1 {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    83
			return []Account{}, ErrInvalidID
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    84
		}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    85
		endPoint = "accounts/" + strconv.Itoa(opts.ID) + "/" + target
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    86
	case "follow_requests", "blocks", "mutes":
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    87
		endPoint = target
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    88
	case "search":
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    89
		if opts == nil || opts.Q == "" {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    90
			return []Account{}, ErrInvalidParameter
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    91
		}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    92
		endPoint = "accounts/" + target
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    93
	default:
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    94
		return nil, ErrInvalidParameter
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    95
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    96
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
    97
	req := g.prepareRequest(endPoint)
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
    98
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
    99
	// Handle target-specific query parameters
109
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   100
	if target == "search" {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   101
		req.QueryParams["q"] = opts.Q
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   102
		if opts.Limit > 0 {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   103
			req.QueryParams["limit"] = strconv.Itoa(opts.Limit)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   104
		}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   105
	}
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   106
109
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   107
	r, err := rest.API(req)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   108
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   109
		return nil, fmt.Errorf("getAccount (%s): %s", target, err.Error())
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   110
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   111
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   112
	// Check for error reply
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   113
	var errorResult Error
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   114
	if err := json.Unmarshal([]byte(r.Body), &errorResult); err == nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   115
		// The empty object is not an error
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   116
		if errorResult.Text != "" {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   117
			return nil, fmt.Errorf("%s", errorResult.Text)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   118
		}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   119
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   120
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   121
	// Not an error reply; let's unmarshal the data
109
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   122
	var accounts []Account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   123
	err = json.Unmarshal([]byte(r.Body), &accounts)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   124
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   125
		return nil, fmt.Errorf("getAccount (%s) API: %s", target, err.Error())
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   126
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   127
	return accounts, nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   128
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   129
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   130
// GetAccount returns an account entity
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   131
// The returned value can be nil if there is an error or if the
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   132
// requested ID does not exist.
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   133
func (g *Client) GetAccount(id int) (*Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   134
	account, err := g.getSingleAccount("account", id)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   135
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   136
		return nil, err
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   137
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   138
	if account != nil && account.ID == 0 {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   139
		return nil, ErrEntityNotFound
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   140
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   141
	return account, nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   142
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   143
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   144
// GetCurrentAccount returns the current user account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   145
func (g *Client) GetCurrentAccount() (*Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   146
	account, err := g.getSingleAccount("verify_credentials", 0)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   147
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   148
		return nil, err
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   149
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   150
	if account != nil && account.ID == 0 {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   151
		return nil, ErrEntityNotFound
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   152
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   153
	return account, nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   154
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   155
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   156
// GetAccountFollowers returns the list of accounts following a given account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   157
func (g *Client) GetAccountFollowers(accountID int) ([]Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   158
	o := &getAccountsOptions{ID: accountID}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   159
	return g.getMultipleAccounts("followers", o)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   160
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   161
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   162
// GetAccountFollowing returns the list of accounts a given account is following
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   163
func (g *Client) GetAccountFollowing(accountID int) ([]Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   164
	o := &getAccountsOptions{ID: accountID}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   165
	return g.getMultipleAccounts("following", o)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   166
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   167
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   168
// FollowAccount follows an account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   169
func (g *Client) FollowAccount(id int) error {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   170
	account, err := g.getSingleAccount("follow", id)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   171
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   172
		return err
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   173
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   174
	if account != nil && account.ID != id {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   175
		return ErrEntityNotFound
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   176
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   177
	return nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   178
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   179
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   180
// UnfollowAccount unfollows an account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   181
func (g *Client) UnfollowAccount(id int) error {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   182
	account, err := g.getSingleAccount("unfollow", id)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   183
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   184
		return err
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   185
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   186
	if account != nil && account.ID != id {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   187
		return ErrEntityNotFound
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   188
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   189
	return nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   190
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   191
111
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   192
// FollowRemoteAccount follows a remote account
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   193
// The parameter 'id' is a URI (username@domain).
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   194
func (g *Client) FollowRemoteAccount(id string) (*Account, error) {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   195
	if id == "" {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   196
		return nil, ErrInvalidID
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   197
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   198
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   199
	req := g.prepareRequest("follows")
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   200
	req.Method = rest.Post
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   201
	req.QueryParams["uri"] = id
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   202
	r, err := rest.API(req)
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   203
	if err != nil {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   204
		return nil, fmt.Errorf("FollowRemoteAccount: %s", err.Error())
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   205
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   206
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   207
	// Check for error reply
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   208
	var errorResult Error
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   209
	if err := json.Unmarshal([]byte(r.Body), &errorResult); err == nil {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   210
		// The empty object is not an error
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   211
		if errorResult.Text != "" {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   212
			return nil, fmt.Errorf("%s", errorResult.Text)
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   213
		}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   214
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   215
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   216
	// Not an error reply; let's unmarshal the data
111
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   217
	var account Account
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   218
	err = json.Unmarshal([]byte(r.Body), &account)
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   219
	if err != nil {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   220
		return nil, fmt.Errorf("FollowRemoteAccount API: %s", err.Error())
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   221
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   222
	if account.ID == 0 {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   223
		return nil, ErrEntityNotFound
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   224
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   225
	return &account, nil
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   226
}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   227
109
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   228
// BlockAccount blocks an account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   229
func (g *Client) BlockAccount(id int) error {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   230
	account, err := g.getSingleAccount("block", id)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   231
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   232
		return err
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   233
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   234
	if account != nil && account.ID != id {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   235
		return ErrEntityNotFound
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   236
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   237
	return nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   238
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   239
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   240
// UnblockAccount unblocks an account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   241
func (g *Client) UnblockAccount(id int) error {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   242
	account, err := g.getSingleAccount("unblock", id)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   243
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   244
		return err
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   245
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   246
	if account != nil && account.ID != id {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   247
		return ErrEntityNotFound
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   248
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   249
	return nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   250
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   251
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   252
// MuteAccount mutes an account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   253
func (g *Client) MuteAccount(id int) error {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   254
	account, err := g.getSingleAccount("mute", id)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   255
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   256
		return err
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   257
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   258
	if account != nil && account.ID != id {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   259
		return ErrEntityNotFound
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   260
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   261
	return nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   262
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   263
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   264
// UnmuteAccount unmutes an account
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   265
func (g *Client) UnmuteAccount(id int) error {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   266
	account, err := g.getSingleAccount("unmute", id)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   267
	if err != nil {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   268
		return err
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   269
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   270
	if account != nil && account.ID != id {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   271
		return ErrEntityNotFound
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   272
	}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   273
	return nil
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   274
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   275
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   276
// SearchAccounts returns a list of accounts matching the query string
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   277
// The limit parameter is optional (can be 0).
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   278
func (g *Client) SearchAccounts(query string, limit int) ([]Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   279
	o := &getAccountsOptions{Q: query, Limit: limit}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   280
	return g.getMultipleAccounts("search", o)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   281
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   282
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   283
// GetBlockedAccounts returns the list of blocked accounts
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   284
func (g *Client) GetBlockedAccounts() ([]Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   285
	return g.getMultipleAccounts("blocks", nil)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   286
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   287
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   288
// GetMutedAccounts returns the list of muted accounts
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   289
func (g *Client) GetMutedAccounts() ([]Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   290
	return g.getMultipleAccounts("mutes", nil)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   291
}
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   292
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   293
// GetAccountFollowRequests returns the list of follow requests accounts
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   294
func (g *Client) GetAccountFollowRequests() ([]Account, error) {
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   295
	return g.getMultipleAccounts("follow_requests", nil)
37de1a30f465 Add account-related API calls
Mikael Berthe <mikael@lilotux.net>
parents: 8
diff changeset
   296
}
111
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   297
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   298
// GetAccountRelationships returns a list of relationship entities for the given accounts
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   299
// NOTE: Currently it doesn't seem to work with several items.
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   300
func (g *Client) GetAccountRelationships(accountIDs []int) ([]Relationship, error) {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   301
	if len(accountIDs) < 1 {
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   302
		return nil, ErrInvalidID
111
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   303
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   304
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   305
	req := g.prepareRequest("accounts/relationships")
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   306
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   307
	if len(accountIDs) > 1 { // XXX
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   308
		return nil, fmt.Errorf("accounts/relationships currently does not work with more than 1 ID")
111
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   309
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   310
	req.QueryParams["id"] = strconv.Itoa(accountIDs[0])
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   311
	/*
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   312
		for i, id := range accountIDList {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   313
			qID := fmt.Sprintf("id[%d]", i+1)
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   314
			req.QueryParams[qID] = strconv.Itoa(id)
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   315
		}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   316
	*/
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   317
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   318
	r, err := rest.API(req)
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   319
	if err != nil {
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   320
		return nil, fmt.Errorf("GetAccountRelationships: %s", err.Error())
111
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   321
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   322
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   323
	// Check for error reply
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   324
	var errorResult Error
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   325
	if err := json.Unmarshal([]byte(r.Body), &errorResult); err == nil {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   326
		// The empty object is not an error
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   327
		if errorResult.Text != "" {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   328
			return nil, fmt.Errorf("%s", errorResult.Text)
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   329
		}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   330
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   331
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   332
	// Not an error reply; let's unmarshal the data
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   333
	var rl []Relationship
111
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   334
	err = json.Unmarshal([]byte(r.Body), &rl)
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   335
	if err != nil {
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   336
		return nil, fmt.Errorf("accounts/relationships API: %s", err.Error())
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   337
	}
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   338
	return rl, nil
fc7cd6c90b2e Add FollowRemoteAccount() and GetAccountRelationships()
Mikael Berthe <mikael@lilotux.net>
parents: 110
diff changeset
   339
}
114
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   340
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   341
// GetAccountStatuses returns a list of status entities for the given account
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   342
// If onlyMedia is true, returns only statuses that have media attachments.
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   343
// If excludeReplies is true, skip statuses that reply to other statuses.
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   344
func (g *Client) GetAccountStatuses(accountID int, onlyMedia, excludeReplies bool) ([]Status, error) {
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   345
	if accountID < 1 {
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   346
		return nil, ErrInvalidID
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   347
	}
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   348
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   349
	endPoint := "accounts/" + strconv.Itoa(accountID) + "/" + "statuses"
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   350
	req := g.prepareRequest(endPoint)
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   351
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   352
	if onlyMedia {
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   353
		req.QueryParams["only_media"] = "true"
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   354
	}
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   355
	if excludeReplies {
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   356
		req.QueryParams["exclude_replies"] = "true"
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   357
	}
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   358
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   359
	r, err := rest.API(req)
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   360
	if err != nil {
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   361
		return nil, fmt.Errorf("GetAccountStatuses: %s", err.Error())
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   362
	}
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   363
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   364
	// Check for error reply
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   365
	var errorResult Error
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   366
	if err := json.Unmarshal([]byte(r.Body), &errorResult); err == nil {
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   367
		// The empty object is not an error
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   368
		if errorResult.Text != "" {
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   369
			return nil, fmt.Errorf("%s", errorResult.Text)
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   370
		}
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   371
	}
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   372
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   373
	// Not an error reply; let's unmarshal the data
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   374
	var sl []Status
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   375
	err = json.Unmarshal([]byte(r.Body), &sl)
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   376
	if err != nil {
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   377
		return nil, fmt.Errorf("accounts/statuses API: %s", err.Error())
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   378
	}
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   379
	return sl, nil
0a1f493588ee Add GetAccountStatuses()
Mikael Berthe <mikael@lilotux.net>
parents: 111
diff changeset
   380
}
115
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   381
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   382
// FollowRequestAuthorize authorizes or rejects an account follow-request
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   383
func (g *Client) FollowRequestAuthorize(accountID int, authorize bool) error {
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   384
	endPoint := "follow_requests/reject"
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   385
	if authorize {
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   386
		endPoint = "follow_requests/authorize"
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   387
	}
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   388
	_, err := g.getSingleAccount(endPoint, accountID)
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   389
	return err
0684ac8b6634 Add FollowRequestAuthorize()
Mikael Berthe <mikael@lilotux.net>
parents: 114
diff changeset
   390
}