// 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 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