search.go
author Mikael Berthe <mikael@lilotux.net>
Thu, 13 Apr 2017 21:25:10 +0200
changeset 113 bb9aaa5440c1
child 120 579912e9d0ef
permissions -rw-r--r--
Add Search() (using endpoint /search)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
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
}