author | Mikael Berthe <mikael@lilotux.net> |
Thu, 13 Apr 2017 21:25:10 +0200 | |
changeset 113 | bb9aaa5440c1 |
child 120 | 579912e9d0ef |
permissions | -rw-r--r-- |
113
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
1 |
package gondole |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
2 |
|
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
3 |
import ( |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
4 |
"encoding/json" |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
5 |
"fmt" |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
6 |
|
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
7 |
"github.com/sendgrid/rest" |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
8 |
) |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
9 |
|
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
10 |
// Search search for contents (accounts or statuses) and returns a Results |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
11 |
func (g *Client) Search(query string, resolve bool) (*Results, error) { |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
12 |
if query == "" { |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
13 |
return nil, ErrInvalidParameter |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
14 |
} |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
15 |
req := g.prepareRequest("search") |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
16 |
req.QueryParams["q"] = query |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
17 |
if resolve { |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
18 |
req.QueryParams["resolve"] = "true" |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
19 |
} |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
20 |
r, err := rest.API(req) |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
21 |
if err != nil { |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
22 |
return nil, fmt.Errorf("search: %s", err.Error()) |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
23 |
} |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
24 |
|
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
25 |
// Check for error reply |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
26 |
var errorResult Error |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
27 |
if err := json.Unmarshal([]byte(r.Body), &errorResult); err == nil { |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
28 |
// The empty object is not an error |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
29 |
if errorResult.Text != "" { |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
30 |
return nil, fmt.Errorf("%s", errorResult.Text) |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
31 |
} |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
32 |
} |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
33 |
|
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
34 |
// Not an error reply; let's unmarshal the data |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
35 |
var results Results |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
36 |
err = json.Unmarshal([]byte(r.Body), &results) |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
37 |
if err != nil { |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
38 |
return nil, fmt.Errorf("search API: %s", err.Error()) |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
39 |
} |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
40 |
return &results, nil |
bb9aaa5440c1
Add Search() (using endpoint /search)
Mikael Berthe <mikael@lilotux.net>
parents:
diff
changeset
|
41 |
} |