blob: aa0f2b3ff84e4f3f0806633a7daac293bdb6f13b [file] [log] [blame] [edit]
// Copyright 2010 The ChromiumOS Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef UPDATE_ENGINE_COMMON_PROXY_RESOLVER_H_
#define UPDATE_ENGINE_COMMON_PROXY_RESOLVER_H_
#include <deque>
#include <string>
#include <base/logging.h>
#include <brillo/message_loops/message_loop.h>
#include "update_engine/common/utils.h"
namespace chromeos_update_engine {
extern const char kNoProxy[];
// Callback for a call to GetProxiesForUrl().
// Resultant proxies are in |out_proxy|. Each will be in one of the
// following forms:
// http://<host>[:<port>] - HTTP proxy
// socks{4,5}://<host>[:<port>] - SOCKS4/5 proxy
// kNoProxy - no proxy
using ProxiesResolvedFn =
base::OnceCallback<void(const std::deque<std::string>& proxies)>;
// An id that identifies a proxy request. Used to cancel an ongoing request
// before the callback is called.
typedef brillo::MessageLoop::TaskId ProxyRequestId;
// A constant identifying an invalid ProxyRequestId.
extern const ProxyRequestId kProxyRequestIdNull;
class ProxyResolver {
public:
ProxyResolver() {}
ProxyResolver(const ProxyResolver&) = delete;
ProxyResolver& operator=(const ProxyResolver&) = delete;
virtual ~ProxyResolver() {}
// Finds proxies for the given URL and returns them via the callback.
// Returns the id of the pending request on success or `kProxyRequestIdNull`
// otherwise.
virtual ProxyRequestId GetProxiesForUrl(const std::string& url,
ProxiesResolvedFn callback) = 0;
// Cancel the proxy resolution request initiated by GetProxiesForUrl(). The
// |request| value must be the one provided by GetProxiesForUrl().
virtual bool CancelProxyRequest(ProxyRequestId request) = 0;
};
// Always says to not use a proxy
class DirectProxyResolver : public ProxyResolver {
public:
DirectProxyResolver() = default;
DirectProxyResolver(const DirectProxyResolver&) = delete;
DirectProxyResolver& operator=(const DirectProxyResolver&) = delete;
~DirectProxyResolver() override;
ProxyRequestId GetProxiesForUrl(const std::string& url,
ProxiesResolvedFn callback) override;
bool CancelProxyRequest(ProxyRequestId request) override;
// Set the number of direct (non-) proxies to be returned by resolver.
// The default value is 1; higher numbers are currently used in testing.
inline void set_num_proxies(size_t num_proxies) {
num_proxies_ = num_proxies;
}
private:
// The ID of the main loop callback.
brillo::MessageLoop::TaskId idle_callback_id_{
brillo::MessageLoop::kTaskIdNull};
// Number of direct proxies to return on resolved list; currently used for
// testing.
size_t num_proxies_{1};
// The MainLoop callback, from here we return to the client.
void ReturnCallback(ProxiesResolvedFn callback);
};
} // namespace chromeos_update_engine
#endif // UPDATE_ENGINE_COMMON_PROXY_RESOLVER_H_