| 55 | const timeoutMessage = "no events before timeout" |
| 56 | |
| 57 | func (c *LongPollClient) doQuery(ctx context.Context) (*http.Response, error) { |
| 58 | logger := c.logger.WithField("method", "doQuery") |
| 59 | query := c.url.Query() |
| 60 | query.Set("since_time", fmt.Sprintf("%d", c.since)) |
| 61 | query.Set("timeout", c.timeout) |
| 62 | c.url.RawQuery = query.Encode() |
| 63 | |
| 64 | logger.Debugf("Query parameters: %s", c.url.RawQuery) |
| 65 | |
| 66 | req, err := http.NewRequestWithContext(ctx, http.MethodGet, c.url.String(), http.NoBody) |
| 67 | if err != nil { |
| 68 | logger.Errorf("failed to create request: %s", err) |
| 69 | return nil, err |
| 70 | } |
| 71 | req.Header.Set("Accept", "application/json") |
| 72 | resp, err := c.httpClient.Do(req) |
| 73 | if err != nil { |
| 74 | if errors.Is(err, context.Canceled) { |
| 75 | return nil, ctx.Err() // Don't log |
| 76 | } |
| 77 | logger.Errorf("failed to execute request: %s", err) |
| 78 | return nil, err |
| 79 | } |
| 80 | return resp, nil |
| 81 | } |
| 82 | |
| 83 | func (c *LongPollClient) poll(ctx context.Context) error { |
| 84 | logger := c.logger.WithField("method", "poll") |