Add gRPC observability: logging, metrics, recovery interceptors
This commit is contained in:
@@ -34,33 +34,42 @@ func (indexer *JacketIndexer) Search(query string, limit int32, tracker string)
|
||||
url := indexer.cfg.Indexer.Url
|
||||
uri := fmt.Sprintf("%v/api/v2.0/indexers/%v/results/torznab?apikey=%v&limit=%d&cat=3010,3040&q=%v&t=search", url, searchTracker, indexer.cfg.Indexer.ApiKey, limit, query)
|
||||
|
||||
log.Debug().Str("uri", uri).Msg("Sending search request")
|
||||
log.Trace().Str("tracker", searchTracker).Str("query", query).Int32("limit", limit).Msg("jackett request")
|
||||
|
||||
req, err := http.NewRequest("GET", uri, nil)
|
||||
if err != nil {
|
||||
log.Error().Err(err).Msg("Error creating request")
|
||||
log.Error().Err(err).Msg("error creating request")
|
||||
return SearchResult{}, err
|
||||
}
|
||||
|
||||
start := time.Now()
|
||||
resp, err := indexer.client.Do(req)
|
||||
if err != nil {
|
||||
log.Error().Err(err).Msg("Error making search request")
|
||||
log.Error().Err(err).Msg("error making search request")
|
||||
return SearchResult{}, err
|
||||
}
|
||||
defer resp.Body.Close()
|
||||
|
||||
body, err := io.ReadAll(resp.Body)
|
||||
if err != nil {
|
||||
log.Error().Err(err).Msg("Error reading search response body")
|
||||
log.Error().Err(err).Msg("error reading search response body")
|
||||
return SearchResult{}, err
|
||||
}
|
||||
|
||||
log.Trace().
|
||||
Int("status", resp.StatusCode).
|
||||
Int("body_bytes", len(body)).
|
||||
Dur("duration", time.Since(start)).
|
||||
Msg("jackett response")
|
||||
|
||||
var searchResult SearchResult
|
||||
if err := xml.Unmarshal(body, &searchResult); err != nil {
|
||||
log.Error().Err(err).Msg("Error parsing search XML")
|
||||
log.Error().Err(err).Msg("error parsing search XML")
|
||||
return SearchResult{}, err
|
||||
}
|
||||
|
||||
log.Trace().Int("items", len(searchResult.Items)).Msg("jackett XML parsed")
|
||||
|
||||
return searchResult, nil
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user