/
me_controller.go
49 lines (43 loc) · 1.29 KB
/
me_controller.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package controllers
import (
"github.com/BrandonRomano/wrecker"
"github.com/carrot/go-pinterest/models"
)
// MeController is the controller that is responsible for all
// /v1/me/ endpoints in the Pinterest API.
type MeController struct {
wreckerClient *wrecker.Wrecker
Boards *MeBoardsController
Followers *MeFollowersController
Following *MeFollowingController
Pins *MePinsController
Search *MeSearchController
}
// NewMeController instantiates a new MeController
func NewMeController(wc *wrecker.Wrecker) *MeController {
return &MeController{
wreckerClient: wc,
Boards: newMeBoardsController(wc),
Followers: newMeFollowersController(wc),
Following: newMeFollowingController(wc),
Pins: newMePinsController(wc),
Search: newMeSearchController(wc),
}
}
// Fetch loads the authorized users info
// Endpoint: [GET] /v1/me/
func (mc *MeController) Fetch() (*models.User, error) {
// Build + execute request
resp := new(models.Response)
resp.Data = new(models.User)
httpResp, err := mc.wreckerClient.Get("/me/").
URLParam("fields", models.USER_FIELDS).
Into(resp).
Execute()
// Check Error
if err = models.WrapPinterestError(httpResp, resp, err); err != nil {
return nil, err
}
// OK
return resp.Data.(*models.User), nil
}