// Copyright (c) 2013 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. #include "ppapi/proxy/network_proxy_resource.h" #include "base/bind.h" #include "ppapi/proxy/dispatch_reply_message.h" #include "ppapi/proxy/ppapi_messages.h" #include "ppapi/shared_impl/tracked_callback.h" #include "ppapi/shared_impl/var.h" namespace ppapi { namespace proxy { NetworkProxyResource::NetworkProxyResource(Connection connection, PP_Instance instance) : PluginResource(connection, instance) { SendCreate(BROWSER, PpapiHostMsg_NetworkProxy_Create()); } NetworkProxyResource::~NetworkProxyResource() { } thunk::PPB_NetworkProxy_API* NetworkProxyResource::AsPPB_NetworkProxy_API() { return this; } int32_t NetworkProxyResource::GetProxyForURL( PP_Instance /* instance */, PP_Var url, PP_Var* proxy_string, scoped_refptr callback) { StringVar* string_url = StringVar::FromPPVar(url); if (!string_url) return PP_ERROR_BADARGUMENT; Call( BROWSER, PpapiHostMsg_NetworkProxy_GetProxyForURL(string_url->value()), base::Bind(&NetworkProxyResource::OnPluginMsgGetProxyForURLReply, base::Unretained(this), base::Unretained(proxy_string), callback)); return PP_OK_COMPLETIONPENDING; } void NetworkProxyResource::OnPluginMsgGetProxyForURLReply( PP_Var* proxy_string_out_param, scoped_refptr callback, const ResourceMessageReplyParams& params, const std::string& proxy_string) { if (!TrackedCallback::IsPending(callback)) { // The callback should not have already been run. If this resource is // deleted, LastPluginRefWasReleased in PluginResource should abort the // callback and should not run this callback. NOTREACHED(); return; } if (params.result() == PP_OK) { *proxy_string_out_param = (new StringVar(proxy_string))->GetPPVar(); } callback->Run(params.result()); } } // namespace proxy } // namespace ppapi