| Index: chrome/browser/extensions/api/networking_private/networking_private_process_client.h
|
| diff --git a/chrome/browser/extensions/api/networking_private/networking_private_process_client.h b/chrome/browser/extensions/api/networking_private/networking_private_process_client.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..3b33cd040092244610ba7b9abe44fc6f9ca593de
|
| --- /dev/null
|
| +++ b/chrome/browser/extensions/api/networking_private/networking_private_process_client.h
|
| @@ -0,0 +1,248 @@
|
| +// Copyright 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.
|
| +
|
| +#ifndef CHROME_BROWSER_EXTENSIONS_API_NETWORKING_PRIVATE_NETWORKING_PRIVATE_PROCESS_CLIENT_H_
|
| +#define CHROME_BROWSER_EXTENSIONS_API_NETWORKING_PRIVATE_NETWORKING_PRIVATE_PROCESS_CLIENT_H_
|
| +
|
| +#include <string>
|
| +#include <vector>
|
| +
|
| +#include "base/basictypes.h"
|
| +#include "base/compiler_specific.h"
|
| +#include "base/id_map.h"
|
| +#include "base/memory/weak_ptr.h"
|
| +#include "base/observer_list.h"
|
| +#include "base/strings/string16.h"
|
| +#include "base/supports_user_data.h"
|
| +#include "base/values.h"
|
| +#include "content/public/browser/browser_thread.h"
|
| +#include "content/public/browser/utility_process_host.h"
|
| +#include "content/public/browser/utility_process_host_client.h"
|
| +
|
| +class Profile;
|
| +
|
| +namespace extensions {
|
| +
|
| +namespace api {
|
| +namespace networking_private {
|
| +struct VerificationProperties;
|
| +} // namespace networking_private
|
| +} // namespace api
|
| +
|
| +// This class is the client for the out-of-process networkingPrivate handler.
|
| +class NetworkingPrivateProcessClient
|
| + : public content::UtilityProcessHostClient {
|
| + public:
|
| + // Interface for Verify* methods implementation.
|
| + class CryptoVerify {
|
| + public:
|
| + virtual bool VerifyDestination(
|
| + const api::networking_private::VerificationProperties& properties) = 0;
|
| +
|
| + virtual bool VerifyAndEncryptData(
|
| + const api::networking_private::VerificationProperties& properties,
|
| + const std::string& plaintext,
|
| + std::string* base64_encoded_ciphertext) = 0;
|
| + };
|
| +
|
| + // Interface for observing Network Events.
|
| + class Observer {
|
| + public:
|
| + virtual void OnNetworksChangedEvent(
|
| + const std::vector<std::string>& network_guids) = 0;
|
| + virtual void OnNetworkListChangedEvent(
|
| + const std::vector<std::string>& network_guids) = 0;
|
| + };
|
| +
|
| + // An error callback used by most of API functions to receive error results
|
| + // from the NetworkingPrivateProcessClient.
|
| + typedef base::Callback<
|
| + void(const std::string& error_name,
|
| + scoped_ptr<base::DictionaryValue> error_data)> ErrorCallback;
|
| +
|
| + // An error callback used by most of Crypto Verify* API functions to receive
|
| + // error results from the NetworkingPrivateProcessClient.
|
| + // TODO(mef): Cleanup networking_private_api.* to make consistent
|
| + // NetworkingPrivateXXXFunction naming and error callbacks.
|
| + typedef base::Callback<
|
| + void(const std::string& error_name,
|
| + const std::string& error)> CryptoErrorCallback;
|
| +
|
| + // Callback used to return bool result from VerifyDestination function.
|
| + typedef base::Callback<void(bool result)> BoolResultCallback;
|
| +
|
| + // Callback used to return string result from VerifyAndEncryptData function.
|
| + typedef base::Callback<void(const std::string& result)> StringResultCallback;
|
| +
|
| + // Callback used to return Dictionary of network properties.
|
| + typedef base::Callback<
|
| + void(const std::string& network_guid,
|
| + const base::DictionaryValue& dictionary)> DictionaryResultCallback;
|
| +
|
| + // Callback used to return List of visibile networks.
|
| + typedef base::Callback<
|
| + void(const base::ListValue& network_list)> ListResultCallback;
|
| +
|
| + // Callback used to notify API function of completed API call without data.
|
| + typedef base::Callback<void()> VoidResultCallback;
|
| +
|
| + explicit NetworkingPrivateProcessClient(Profile* profile);
|
| +
|
| + // Gets the properties of the network with id |service_path|. See note on
|
| + // |callback| and |error_callback|, in class description above.
|
| + void GetProperties(const std::string& service_path,
|
| + const DictionaryResultCallback& callback,
|
| + const ErrorCallback& error_callback);
|
| +
|
| + // Start connect to the network with id |service_path|. See note on
|
| + // |callback| and |error_callback|, in class description above.
|
| + void StartConnect(const std::string& service_path,
|
| + const VoidResultCallback& callback,
|
| + const ErrorCallback& error_callback);
|
| +
|
| + // Start disconnect from the network with id |service_path|. See note on
|
| + // |callback| and |error_callback|, in class description above.
|
| + void StartDisconnect(const std::string& service_path,
|
| + const VoidResultCallback& callback,
|
| + const ErrorCallback& error_callback);
|
| +
|
| + // Sets the |properties| of the network with id |service_path|. See note on
|
| + // |callback| and |error_callback|, in class description above.
|
| + void SetProperties(const std::string& service_path,
|
| + const base::DictionaryValue& properties,
|
| + const VoidResultCallback& callback,
|
| + const ErrorCallback& error_callback);
|
| +
|
| + // Requests network scan. Broadcasts NetworkListChangedEvent upon completion.
|
| + void RequestNetworkScan();
|
| +
|
| + // Gets the list of visible networks and calls |callback|.
|
| + void GetVisibleNetworks(const ListResultCallback& callback);
|
| +
|
| + // Verify that Chromecast provides valid cryptographically signed properties.
|
| + void VerifyDestination(scoped_ptr<base::ListValue> args,
|
| + const BoolResultCallback& callback,
|
| + const CryptoErrorCallback& error_callback);
|
| +
|
| + // Verify that Chromecast provides valid cryptographically signed properties.
|
| + // If valid, then encrypt data using Chromecast's public key.
|
| + void VerifyAndEncryptData(scoped_ptr<base::ListValue> args,
|
| + const StringResultCallback& callback,
|
| + const CryptoErrorCallback& error_callback);
|
| +
|
| + // Adds observer to network events.
|
| + void AddObserver(Observer* network_events_observer);
|
| +
|
| + // Removes observer to network events. If there is no observers,
|
| + // then process can be shut down when there are no more calls pending return.
|
| + void RemoveObserver(Observer* network_events_observer);
|
| +
|
| + // Switches Utility Process to use WiFiServiceMock for browser_tests and
|
| + // mock CryptoVerify implementation.
|
| + void SetUpForTest(const base::DictionaryValue& parameters,
|
| + CryptoVerify* crypto_verify_mock);
|
| +
|
| + // Teardown test for browser_tests.
|
| + void TearDownForTest();
|
| +
|
| + // Gets a NetworkingPrivateProcessClient instances, creating one if it
|
| + // doesn't exist.
|
| + static scoped_refptr<NetworkingPrivateProcessClient>
|
| + GetForProfile(Profile* profile);
|
| +
|
| + private:
|
| + // Callbacks to run when reply message is received from UtilityProcess.
|
| + typedef int32 MessageCallbacksID;
|
| + struct MessageCallbacks {
|
| + MessageCallbacks();
|
| + ~MessageCallbacks();
|
| +
|
| + DictionaryResultCallback get_properties_callback;
|
| + VoidResultCallback start_connect_callback;
|
| + VoidResultCallback start_disconnect_callback;
|
| + VoidResultCallback set_properties_callback;
|
| + ListResultCallback get_visible_networks_callback;
|
| + ErrorCallback error_callback;
|
| +
|
| + MessageCallbacksID id;
|
| + };
|
| + typedef IDMap<MessageCallbacks, IDMapOwnPointer> MessageCallbacksMap;
|
| +
|
| + // UtilityProcessHostClient implementation:
|
| + virtual void OnProcessCrashed(int exit_code) OVERRIDE;
|
| + virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE;
|
| +
|
| + // Message handlers
|
| + void OnApiError(MessageCallbacksID message_id,
|
| + const std::string& error_code,
|
| + const base::DictionaryValue& error_data);
|
| + void OnGetPropertiesSucceeded(MessageCallbacksID message_id,
|
| + const std::string& network_guid,
|
| + const base::DictionaryValue& properties);
|
| + void OnGetVisibleNetworksSucceeded(MessageCallbacksID message_id,
|
| + const base::ListValue& network_list);
|
| + void OnNetworksChangedEvent(const std::vector<std::string>& network_guids);
|
| + void OnNetworkListChangedEvent(const std::vector<std::string>& network_guids);
|
| + void OnSetPropertiesSucceeded(MessageCallbacksID message_id,
|
| + const std::string& network_guid);
|
| + void OnStartConnectSucceeded(MessageCallbacksID message_id,
|
| + const std::string& network_guid);
|
| + void OnStartDisconnectSucceeded(MessageCallbacksID message_id,
|
| + const std::string& network_guid);
|
| +
|
| + virtual ~NetworkingPrivateProcessClient();
|
| +
|
| + // Launches the task to start the external process.
|
| + void Start();
|
| + // Creates a new UtilityProcessHost, which launches the utility process.
|
| + void StartProcessOnIOThread(content::BrowserThread::ID thread_id);
|
| + // Deletes a UtilityProcessHost, which stops the utility process.
|
| + void ShutdownProcessOnIOThread();
|
| + // Shuts down utility process if there are no more events listeners and
|
| + // all calls are completed.
|
| + void ShutdownIfDone();
|
| +
|
| + // Sends message to UtilityProcess.
|
| + void Send(IPC::Message* message);
|
| + void SendOnIOThread(IPC::Message* message);
|
| +
|
| + void VerifyDestinationOnWorkerThread(
|
| + scoped_ptr<base::ListValue> args,
|
| + const BoolResultCallback& callback,
|
| + const CryptoErrorCallback& error_callback);
|
| +
|
| + void VerifyAndEncryptDataOnWorkerThread(
|
| + scoped_ptr<base::ListValue> args,
|
| + const StringResultCallback& callback,
|
| + const CryptoErrorCallback& error_callback);
|
| +
|
| + // Add new |MessageCallbacks| to |callbacks_map_|.
|
| + MessageCallbacks* AddMessageCallbacks();
|
| + // Removes MessageCallbacks for |message_id| from |callbacks_map_|.
|
| + // Shuts down utility process if there are no more events listeners and
|
| + // all calls are completed.
|
| + void RemoveMessageCallbacks(MessageCallbacksID message_id);
|
| +
|
| + // Callbacks to run when message is received from UtilityProcess.
|
| + MessageCallbacksMap callbacks_map_;
|
| +
|
| + // Browser profile, which is running API listening for events.
|
| + Profile* profile_;
|
| +
|
| + // Handles sending messages to the external process. Deletes itself when
|
| + // the external process dies.
|
| + base::WeakPtr<content::UtilityProcessHost> utility_process_host_;
|
| +
|
| + // Observers to Network Events.
|
| + ObserverList<Observer> network_events_observers_;
|
| +
|
| + // Interface for Verify* methods.
|
| + scoped_ptr<CryptoVerify> crypto_verify_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(NetworkingPrivateProcessClient);
|
| +};
|
| +
|
| +} // namespace extensions
|
| +
|
| +#endif // CHROME_BROWSER_EXTENSIONS_API_NETWORKING_PRIVATE_NETWORKING_PRIVATE_PROCESS_CLIENT_H_
|
|
|