| OLD | NEW |
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef NET_PROXY_PROXY_RESOLVER_V8_H_ | 5 #ifndef NET_PROXY_PROXY_RESOLVER_V8_H_ |
| 6 #define NET_PROXY_PROXY_RESOLVER_V8_H_ | 6 #define NET_PROXY_PROXY_RESOLVER_V8_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/scoped_ptr.h" | 10 #include "base/scoped_ptr.h" |
| 11 #include "net/proxy/proxy_resolver.h" | 11 #include "net/proxy/proxy_resolver.h" |
| 12 | 12 |
| 13 class MessageLoop; |
| 14 |
| 13 namespace net { | 15 namespace net { |
| 14 | 16 |
| 17 class HostResolver; |
| 18 |
| 15 // Implementation of ProxyResolver that uses V8 to evaluate PAC scripts. | 19 // Implementation of ProxyResolver that uses V8 to evaluate PAC scripts. |
| 16 // | 20 // |
| 17 // ---------------------------------------------------------------------------- | 21 // ---------------------------------------------------------------------------- |
| 18 // !!! Important note on threading model: | 22 // !!! Important note on threading model: |
| 19 // ---------------------------------------------------------------------------- | 23 // ---------------------------------------------------------------------------- |
| 20 // There can be only one instance of V8 running at a time. To enforce this | 24 // There can be only one instance of V8 running at a time. To enforce this |
| 21 // constraint, ProxyResolverV8 holds a v8::Locker during execution. Therefore | 25 // constraint, ProxyResolverV8 holds a v8::Locker during execution. Therefore |
| 22 // it is OK to run multiple instances of ProxyResolverV8 on different threads, | 26 // it is OK to run multiple instances of ProxyResolverV8 on different threads, |
| 23 // since only one will be running inside V8 at a time. | 27 // since only one will be running inside V8 at a time. |
| 24 // | 28 // |
| 25 // It is important that *ALL* instances of V8 in the process be using | 29 // It is important that *ALL* instances of V8 in the process be using |
| 26 // v8::Locker. If not there can be race conditions beween the non-locked V8 | 30 // v8::Locker. If not there can be race conditions beween the non-locked V8 |
| 27 // instances and the locked V8 instances used by ProxyResolverV8 (assuming they | 31 // instances and the locked V8 instances used by ProxyResolverV8 (assuming they |
| 28 // run on different threads). | 32 // run on different threads). |
| 29 // | 33 // |
| 30 // This is the case with the V8 instance used by chromium's renderer -- it runs | 34 // This is the case with the V8 instance used by chromium's renderer -- it runs |
| 31 // on a different thread from ProxyResolver (renderer thread vs PAC thread), | 35 // on a different thread from ProxyResolver (renderer thread vs PAC thread), |
| 32 // and does not use locking since it expects to be alone. | 36 // and does not use locking since it expects to be alone. |
| 33 class ProxyResolverV8 : public ProxyResolver { | 37 class ProxyResolverV8 : public ProxyResolver { |
| 34 public: | 38 public: |
| 35 // Constructs a ProxyResolverV8 with default javascript bindings. | |
| 36 // | |
| 37 // The default javascript bindings will: | |
| 38 // - Send script error messages to LOG(INFO) | |
| 39 // - Send script alert()s to LOG(INFO) | |
| 40 // - Use the default host mapper to service dnsResolve(), synchronously | |
| 41 // on the V8 thread. | |
| 42 // | |
| 43 // For clients that need more control (for example, sending the script output | |
| 44 // to a UI widget), use the ProxyResolverV8(JSBindings*) and specify your | |
| 45 // own bindings. | |
| 46 ProxyResolverV8(); | |
| 47 | |
| 48 class JSBindings; | 39 class JSBindings; |
| 49 | 40 |
| 50 // Constructs a ProxyResolverV8 with custom bindings. ProxyResolverV8 takes | 41 // Constructs a ProxyResolverV8 with custom bindings. ProxyResolverV8 takes |
| 51 // ownership of |custom_js_bindings| and deletes it when ProxyResolverV8 | 42 // ownership of |custom_js_bindings| and deletes it when ProxyResolverV8 |
| 52 // is destroyed. | 43 // is destroyed. |
| 53 explicit ProxyResolverV8(JSBindings* custom_js_bindings); | 44 explicit ProxyResolverV8(JSBindings* custom_js_bindings); |
| 54 | 45 |
| 55 ~ProxyResolverV8(); | 46 ~ProxyResolverV8(); |
| 56 | 47 |
| 57 // ProxyResolver implementation: | 48 // ProxyResolver implementation: |
| 58 virtual int GetProxyForURL(const GURL& query_url, | 49 virtual int GetProxyForURL(const GURL& query_url, |
| 59 const GURL& /*pac_url*/, | 50 const GURL& /*pac_url*/, |
| 60 ProxyInfo* results); | 51 ProxyInfo* results); |
| 61 virtual void SetPacScript(const std::string& bytes); | 52 virtual void SetPacScript(const std::string& bytes); |
| 62 | 53 |
| 63 JSBindings* js_bindings() const { return js_bindings_.get(); } | 54 JSBindings* js_bindings() const { return js_bindings_.get(); } |
| 64 | 55 |
| 56 // Creates a default javascript bindings implementation that will: |
| 57 // - Send script error messages to LOG(INFO) |
| 58 // - Send script alert()s to LOG(INFO) |
| 59 // - Use the provided host mapper to service dnsResolve(). |
| 60 // |
| 61 // For clients that need more control (for example, sending the script output |
| 62 // to a UI widget), use the ProxyResolverV8(JSBindings*) and specify your |
| 63 // own bindings. |
| 64 // |
| 65 // |host_resolver| will be used in async mode on |host_resolver_loop|. If |
| 66 // |host_resolver_loop| is NULL, then |host_resolver| will be used in sync |
| 67 // mode on the PAC thread. |
| 68 static JSBindings* CreateDefaultBindings(HostResolver* host_resolver, |
| 69 MessageLoop* host_resolver_loop); |
| 70 |
| 65 private: | 71 private: |
| 66 // Context holds the Javascript state for the most recently loaded PAC | 72 // Context holds the Javascript state for the most recently loaded PAC |
| 67 // script. It corresponds with the data from the last call to | 73 // script. It corresponds with the data from the last call to |
| 68 // SetPacScript(). | 74 // SetPacScript(). |
| 69 class Context; | 75 class Context; |
| 70 scoped_ptr<Context> context_; | 76 scoped_ptr<Context> context_; |
| 71 | 77 |
| 72 scoped_ptr<JSBindings> js_bindings_; | 78 scoped_ptr<JSBindings> js_bindings_; |
| 73 | 79 |
| 74 DISALLOW_COPY_AND_ASSIGN(ProxyResolverV8); | 80 DISALLOW_COPY_AND_ASSIGN(ProxyResolverV8); |
| (...skipping 14 matching lines...) Expand all Loading... |
| 89 virtual std::string DnsResolve(const std::string& host) = 0; | 95 virtual std::string DnsResolve(const std::string& host) = 0; |
| 90 | 96 |
| 91 // Handler for when an error is encountered. |line_number| may be -1 | 97 // Handler for when an error is encountered. |line_number| may be -1 |
| 92 // if a line number is not applicable to this error. | 98 // if a line number is not applicable to this error. |
| 93 virtual void OnError(int line_number, const std::string& error) = 0; | 99 virtual void OnError(int line_number, const std::string& error) = 0; |
| 94 }; | 100 }; |
| 95 | 101 |
| 96 } // namespace net | 102 } // namespace net |
| 97 | 103 |
| 98 #endif // NET_PROXY_PROXY_RESOLVER_V8_H_ | 104 #endif // NET_PROXY_PROXY_RESOLVER_V8_H_ |
| OLD | NEW |