// Copyright (c) 2009 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef NET_PROXY_PROXY_JS_BINDINGS_H
#define NET_PROXY_PROXY_JS_BINDINGS_H
#include <string>
class MessageLoop;
namespace net {
class HostResolver;
// Interface for the javascript bindings.
class ProxyResolverJSBindings {
public:
virtual ~ProxyResolverJSBindings() {}
// Handler for "alert(message)"
virtual void Alert(const std::string& message) = 0;
// Handler for "myIpAddress()". Returns empty string on failure.
virtual std::string MyIpAddress() = 0;
// Handler for "myIpAddressEx()". Returns empty string on failure.
//
// This is a Microsoft extension to PAC for IPv6, see:
// http://blogs.msdn.com/wndp/articles/IPV6_PAC_Extensions_v0_9.aspx
virtual std::string MyIpAddressEx() = 0;
// Handler for "dnsResolve(host)". Returns empty string on failure.
virtual std::string DnsResolve(const std::string& host) = 0;
// Handler for "dnsResolveEx(host)". Returns empty string on failure.
//
// This is a Microsoft extension to PAC for IPv6, see:
// http://blogs.msdn.com/wndp/articles/IPV6_PAC_Extensions_v0_9.aspx
virtual std::string DnsResolveEx(const std::string& host) = 0;
// Handler for when an error is encountered. |line_number| may be -1
// if a line number is not applicable to this error.
virtual void OnError(int line_number, const std::string& error) = 0;
// Creates a default javascript bindings implementation that will:
// - Send script error messages to LOG(INFO)
// - Send script alert()s to LOG(INFO)
// - Use the provided host resolver to service dnsResolve().
//
// |host_resolver| will be used in async mode on |host_resolver_loop|. If
// |host_resolver_loop| is NULL, then |host_resolver| will be used in sync
// mode on the PAC thread.
static ProxyResolverJSBindings* CreateDefault(
HostResolver* host_resolver, MessageLoop* host_resolver_loop);
};
} // namespace net
#endif // NET_PROXY_PROXY_JS_BINDINGS_H