/
me_search_boards_controller.go
54 lines (47 loc) · 1.55 KB
/
me_search_boards_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
50
51
52
53
54
package controllers
import (
"github.com/BrandonRomano/wrecker"
"github.com/carrot/go-pinterest/models"
"strconv"
)
// MeSearchBoardsController is the controller that is responsible for all
// /v1/me/search/boards/ endpoints in the Pinterest API.
type MeSearchBoardsController struct {
wreckerClient *wrecker.Wrecker
}
// newMeSearchBoardsController instantiates a new MeSearchBoardsController
func newMeSearchBoardsController(wc *wrecker.Wrecker) *MeSearchBoardsController {
return &MeSearchBoardsController{
wreckerClient: wc,
}
}
// MeSearchBoardsFetchOptionals is a struct that represents the optional parameters
// that can be passed to the Fetch endpoint
type MeSearchBoardsFetchOptionals struct {
Cursor string
Limit int
}
// Fetch searches the logged in user's Boards
// Endpoint: [GET] /v1/me/search/boards/
func (msbc *MeSearchBoardsController) Fetch(query string, optionals *MeSearchBoardsFetchOptionals) (*[]models.Board, *models.Page, error) {
// Build + execute request
resp := new(models.Response)
resp.Data = &[]models.Board{}
request := msbc.wreckerClient.Get("/me/search/boards/").
URLParam("fields", models.BOARD_FIELDS).
URLParam("query", query).
Into(resp)
if optionals.Cursor != "" {
request.URLParam("cursor", optionals.Cursor)
}
if optionals.Limit != 0 {
request.URLParam("limit", strconv.Itoa(optionals.Limit))
}
httpResp, err := request.Execute()
// Check Error
if err = models.WrapPinterestError(httpResp, resp, err); err != nil {
return nil, nil, err
}
// OK
return resp.Data.(*[]models.Board), &resp.Page, nil
}