rss2twitter/vendor/github.com/ChimeraCoder/anaconda/search.go
2018-12-05 00:15:53 -06:00

57 sor
1,6 KiB
Go

package anaconda
import (
"net/url"
)
type SearchMetadata struct {
CompletedIn float32 `json:"completed_in"`
MaxId int64 `json:"max_id"`
MaxIdString string `json:"max_id_str"`
Query string `json:"query"`
RefreshUrl string `json:"refresh_url"`
Count int `json:"count"`
SinceId int64 `json:"since_id"`
SinceIdString string `json:"since_id_str"`
NextResults string `json:"next_results"`
}
type SearchResponse struct {
Statuses []Tweet `json:"statuses"`
Metadata SearchMetadata `json:"search_metadata"`
}
func (sr *SearchResponse) GetNext(a *TwitterApi) (SearchResponse, error) {
if sr.Metadata.NextResults == "" {
return SearchResponse{}, nil
}
nextUrl, err := url.Parse(sr.Metadata.NextResults)
if err != nil {
return SearchResponse{}, err
}
v := nextUrl.Query()
// remove the q parameter from the url.Values so that it
// can be added back via the next GetSearch method call.
delete(v, "q")
q, _ := url.QueryUnescape(sr.Metadata.Query)
if err != nil {
return SearchResponse{}, err
}
newSr, err := a.GetSearch(q, v)
return newSr, err
}
func (a TwitterApi) GetSearch(queryString string, v url.Values) (sr SearchResponse, err error) {
v = cleanValues(v)
v.Set("q", queryString)
response_ch := make(chan response)
a.queryQueue <- query{a.baseUrl + "/search/tweets.json", v, &sr, _GET, response_ch}
// We have to read from the response channel before assigning to timeline
// Otherwise this will happen before the responses have been written
resp := <-response_ch
err = resp.err
return sr, err
}