(r *http.Request)
| 491 | } |
| 492 | |
| 493 | func (mu MultiUpstreams) GetUpstreams(r *http.Request) ([]*Upstream, error) { |
| 494 | var upstreams []*Upstream |
| 495 | |
| 496 | for i, src := range mu.sources { |
| 497 | select { |
| 498 | case <-r.Context().Done(): |
| 499 | return upstreams, context.Canceled |
| 500 | default: |
| 501 | } |
| 502 | |
| 503 | up, err := src.GetUpstreams(r) |
| 504 | if err != nil { |
| 505 | if c := mu.logger.Check(zapcore.ErrorLevel, "upstream source returned error"); c != nil { |
| 506 | c.Write( |
| 507 | zap.Int("source_idx", i), |
| 508 | zap.Error(err), |
| 509 | ) |
| 510 | } |
| 511 | } else if len(up) == 0 { |
| 512 | if c := mu.logger.Check(zapcore.WarnLevel, "upstream source returned 0 upstreams"); c != nil { |
| 513 | c.Write(zap.Int("source_idx", i)) |
| 514 | } |
| 515 | } else { |
| 516 | upstreams = append(upstreams, up...) |
| 517 | } |
| 518 | } |
| 519 | |
| 520 | return upstreams, nil |
| 521 | } |
| 522 | |
| 523 | // UpstreamResolver holds the set of addresses of DNS resolvers of |
| 524 | // upstream addresses |
nothing calls this directly
no test coverage detected