Merge pull request #2 from 178inaba/account

Add GetAccount
pull/4/head
mattn 2017-04-14 11:48:55 +09:00 committed by GitHub
commit 3646db025f
1 changed files with 64 additions and 36 deletions

View File

@ -124,6 +124,24 @@ func RegisterApp(appConfig *AppConfig) (*Application, error) {
return app, nil return app, nil
} }
type Account struct {
ID int64 `json:"id"`
Username string `json:"username"`
Acct string `json:"acct"`
DisplayName string `json:"display_name"`
Locked bool `json:"locked"`
CreatedAt time.Time `json:"created_at"`
FollowersCount int64 `json:"followers_count"`
FollowingCount int64 `json:"following_count"`
StatusesCount int64 `json:"statuses_count"`
Note string `json:"note"`
URL string `json:"url"`
Avatar string `json:"avatar"`
AvatarStatic string `json:"avatar_static"`
Header string `json:"header"`
HeaderStatic string `json:"header_static"`
}
type Visibility int64 type Visibility int64
type Toot struct { type Toot struct {
@ -144,23 +162,7 @@ type Status struct {
SpoilerText string `json:"spoiler_text"` SpoilerText string `json:"spoiler_text"`
Visibility string `json:"visibility"` Visibility string `json:"visibility"`
Application interface{} `json:"application"` Application interface{} `json:"application"`
Account struct { Account Account `json:"account"`
ID int64 `json:"id"`
Username string `json:"username"`
Acct string `json:"acct"`
DisplayName string `json:"display_name"`
Locked bool `json:"locked"`
CreatedAt time.Time `json:"created_at"`
FollowersCount int64 `json:"followers_count"`
FollowingCount int64 `json:"following_count"`
StatusesCount int64 `json:"statuses_count"`
Note string `json:"note"`
URL string `json:"url"`
Avatar string `json:"avatar"`
AvatarStatic string `json:"avatar_static"`
Header string `json:"header"`
HeaderStatic string `json:"header_static"`
} `json:"account"`
MediaAttachments []interface{} `json:"media_attachments"` MediaAttachments []interface{} `json:"media_attachments"`
Mentions []interface{} `json:"mentions"` Mentions []interface{} `json:"mentions"`
Tags []interface{} `json:"tags"` Tags []interface{} `json:"tags"`
@ -174,6 +176,32 @@ type Status struct {
Reblogged interface{} `json:"reblogged"` Reblogged interface{} `json:"reblogged"`
} }
func (c *client) GetAccount(id int) (*Account, error) {
url, err := url.Parse(c.config.Server)
if err != nil {
return nil, err
}
url.Path = path.Join(url.Path, fmt.Sprintf("/api/v1/accounts/%d", id))
req, err := http.NewRequest("GET", url.String(), nil)
if err != nil {
return nil, err
}
req.Header.Set("Authorization", "Bearer "+c.config.AccessToken)
resp, err := c.Do(req)
if err != nil {
return nil, err
}
defer resp.Body.Close()
account := &Account{}
err = json.NewDecoder(resp.Body).Decode(account)
if err != nil {
return nil, err
}
return account, nil
}
func (c *client) GetTimelineHome() ([]*Status, error) { func (c *client) GetTimelineHome() ([]*Status, error) {
url, err := url.Parse(c.config.Server) url, err := url.Parse(c.config.Server)
if err != nil { if err != nil {