diff options
Diffstat (limited to 'jingle')
-rw-r--r-- | jingle/notifier/communicator/login.cc | 31 | ||||
-rw-r--r-- | jingle/notifier/communicator/login.h | 31 | ||||
-rw-r--r-- | jingle/notifier/communicator/single_login_attempt.cc | 10 | ||||
-rw-r--r-- | jingle/notifier/communicator/single_login_attempt.h | 27 | ||||
-rw-r--r-- | jingle/notifier/listener/mediator_thread_impl.cc | 9 | ||||
-rw-r--r-- | jingle/notifier/listener/mediator_thread_impl.h | 25 | ||||
-rw-r--r-- | jingle/notifier/listener/talk_mediator_impl.h | 1 |
7 files changed, 64 insertions, 70 deletions
diff --git a/jingle/notifier/communicator/login.cc b/jingle/notifier/communicator/login.cc index c12ca06..33a2124 100644 --- a/jingle/notifier/communicator/login.cc +++ b/jingle/notifier/communicator/login.cc @@ -30,13 +30,15 @@ namespace notifier { // Redirect valid for 5 minutes. static const int kRedirectTimeoutMinutes = 5; -Login::Login(const buzz::XmppClientSettings& user_settings, +Login::Login(Delegate* delegate, + const buzz::XmppClientSettings& user_settings, const ConnectionOptions& options, net::HostResolver* host_resolver, ServerInformation* server_list, int server_count, bool try_ssltcp_first) - : login_settings_(new LoginSettings(user_settings, + : delegate_(delegate), + login_settings_(new LoginSettings(user_settings, options, host_resolver, server_list, @@ -66,16 +68,16 @@ void Login::StartConnection() { VLOG(1) << "Starting connection..."; - single_attempt_.reset(new SingleLoginAttempt(login_settings_.get())); + single_attempt_.reset(new SingleLoginAttempt(login_settings_.get(), this)); +} + +void Login::OnConnect(base::WeakPtr<talk_base::Task> base_task) { + ResetReconnectState(); + delegate_->OnConnect(base_task); +} - // Do the signaling hook-ups. - single_attempt_->SignalNeedAutoReconnect.connect( - this, - &Login::TryReconnect); - single_attempt_->SignalRedirect.connect(this, &Login::OnRedirect); - single_attempt_->SignalConnect.connect( - this, - &Login::OnConnect); +void Login::OnNeedReconnect() { + TryReconnect(); } void Login::OnRedirect(const std::string& redirect_server, int redirect_port) { @@ -89,11 +91,6 @@ void Login::OnRedirect(const std::string& redirect_server, int redirect_port) { StartConnection(); } -void Login::OnConnect(base::WeakPtr<talk_base::Task> base_task) { - ResetReconnectState(); - SignalConnect(base_task); -} - void Login::OnIPAddressChanged() { VLOG(1) << "Detected IP address change"; // Reconnect in 1 to 9 seconds (vary the time a little to try to @@ -116,7 +113,7 @@ void Login::TryReconnect() { << reconnect_interval_.InSeconds() << " seconds"; reconnect_timer_.Start( reconnect_interval_, this, &Login::DoReconnect); - SignalDisconnect(); + delegate_->OnDisconnect(); } void Login::DoReconnect() { diff --git a/jingle/notifier/communicator/login.h b/jingle/notifier/communicator/login.h index b66ee7b..d80de6c 100644 --- a/jingle/notifier/communicator/login.h +++ b/jingle/notifier/communicator/login.h @@ -11,9 +11,8 @@ #include "base/time.h" #include "base/timer.h" #include "base/weak_ptr.h" +#include "jingle/notifier/communicator/single_login_attempt.h" #include "net/base/network_change_notifier.h" -#include "talk/base/proxyinfo.h" -#include "talk/base/sigslot.h" #include "talk/xmpp/xmppengine.h" namespace buzz { @@ -36,16 +35,25 @@ namespace notifier { class ConnectionOptions; class LoginSettings; struct ServerInformation; -class SingleLoginAttempt; // Does the login, keeps it alive (with refreshing cookies and reattempting // login when disconnected), figures out what actions to take on the various // errors that may occur. class Login : public net::NetworkChangeNotifier::Observer, - public sigslot::has_slots<> { + public SingleLoginAttempt::Delegate { public: - // firewall may be NULL. - Login(const buzz::XmppClientSettings& user_settings, + class Delegate { + public: + virtual ~Delegate() {} + + virtual void OnConnect(base::WeakPtr<talk_base::Task> base_task) = 0; + virtual void OnDisconnect() = 0; + }; + + // Does not take ownership of |delegate|, |host_resolver|, or + // |server_list|, none of which may be NULL. + Login(Delegate* delegate, + const buzz::XmppClientSettings& user_settings, const ConnectionOptions& options, net::HostResolver* host_resolver, ServerInformation* server_list, @@ -58,13 +66,14 @@ class Login : public net::NetworkChangeNotifier::Observer, // net::NetworkChangeNotifier::Observer implementation. virtual void OnIPAddressChanged(); - sigslot::signal1<base::WeakPtr<talk_base::Task> > SignalConnect; - sigslot::signal0<> SignalDisconnect; + // SingleLoginAttempt::Delegate implementation. + virtual void OnConnect(base::WeakPtr<talk_base::Task> base_task); + virtual void OnNeedReconnect(); + virtual void OnRedirect(const std::string& redirect_server, + int redirect_port); private: void OnLogoff(); - void OnRedirect(const std::string& redirect_server, int redirect_port); - void OnConnect(base::WeakPtr<talk_base::Task> parent); // Stops any existing reconnect timer and sets an initial reconnect // interval. @@ -78,7 +87,7 @@ class Login : public net::NetworkChangeNotifier::Observer, // reconnection. void DoReconnect(); - talk_base::TaskParent* parent_; + Delegate* delegate_; scoped_ptr<LoginSettings> login_settings_; scoped_ptr<SingleLoginAttempt> single_attempt_; diff --git a/jingle/notifier/communicator/single_login_attempt.cc b/jingle/notifier/communicator/single_login_attempt.cc index 2d2fbe0..548174b 100644 --- a/jingle/notifier/communicator/single_login_attempt.cc +++ b/jingle/notifier/communicator/single_login_attempt.cc @@ -28,8 +28,10 @@ class NetLog; namespace notifier { -SingleLoginAttempt::SingleLoginAttempt(LoginSettings* login_settings) +SingleLoginAttempt::SingleLoginAttempt(LoginSettings* login_settings, + Delegate* delegate) : login_settings_(login_settings), + delegate_(delegate), connection_generator_( ALLOW_THIS_IN_INITIALIZER_LIST(this), login_settings_->host_resolver(), @@ -43,7 +45,7 @@ SingleLoginAttempt::SingleLoginAttempt(LoginSettings* login_settings) SingleLoginAttempt::~SingleLoginAttempt() {} void SingleLoginAttempt::OnConnect(base::WeakPtr<talk_base::Task> base_task) { - SignalConnect(base_task); + delegate_->OnConnect(base_task); } void SingleLoginAttempt::OnError(buzz::XmppEngine::Error error, int subcode, @@ -81,7 +83,7 @@ void SingleLoginAttempt::OnError(buzz::XmppEngine::Error error, int subcode, if (redirect_port == 0) { redirect_port = kDefaultXmppPort; } - SignalRedirect(redirect_server, redirect_port); + delegate_->OnRedirect(redirect_server, redirect_port); // May be deleted at this point. return; } @@ -122,7 +124,7 @@ void SingleLoginAttempt::OnExhaustedSettings( if (!successfully_resolved_dns) VLOG(1) << "Could not resolve DNS: " << first_dns_error; VLOG(1) << "Could not connect to any XMPP server"; - SignalNeedAutoReconnect(); + delegate_->OnNeedReconnect(); } } // namespace notifier diff --git a/jingle/notifier/communicator/single_login_attempt.h b/jingle/notifier/communicator/single_login_attempt.h index ed8c7bf..6c33c51 100644 --- a/jingle/notifier/communicator/single_login_attempt.h +++ b/jingle/notifier/communicator/single_login_attempt.h @@ -10,7 +10,6 @@ #include "base/scoped_ptr.h" #include "jingle/notifier/base/xmpp_connection.h" #include "jingle/notifier/communicator/xmpp_connection_generator.h" -#include "talk/base/sigslot.h" #include "talk/xmpp/xmppengine.h" namespace talk_base { @@ -29,7 +28,19 @@ class LoginSettings; class SingleLoginAttempt : public XmppConnection::Delegate, public XmppConnectionGenerator::Delegate { public: - explicit SingleLoginAttempt(LoginSettings* login_settings); + class Delegate { + public: + virtual ~Delegate() {} + + virtual void OnConnect(base::WeakPtr<talk_base::Task> base_task) = 0; + virtual void OnNeedReconnect() = 0; + virtual void OnRedirect(const std::string& redirect_server, + int redirect_port) = 0; + }; + + // Does not take ownership of |login_settings| or |delegate|. + // Neither may be NULL. + SingleLoginAttempt(LoginSettings* login_settings, Delegate* delegate); virtual ~SingleLoginAttempt(); @@ -44,19 +55,9 @@ class SingleLoginAttempt : public XmppConnection::Delegate, virtual void OnExhaustedSettings(bool successfully_resolved_dns, int first_dns_error); - // Typically handled by storing the redirect for 5 seconds, and setting it - // into LoginSettings, then creating a new SingleLoginAttempt, and doing - // StartConnection. - // - // SignalRedirect(const std::string& redirect_server, int redirect_port); - sigslot::signal2<const std::string&, int> SignalRedirect; - - sigslot::signal0<> SignalNeedAutoReconnect; - - sigslot::signal1<base::WeakPtr<talk_base::Task> > SignalConnect; - private: LoginSettings* login_settings_; + Delegate* delegate_; XmppConnectionGenerator connection_generator_; scoped_ptr<XmppConnection> xmpp_connection_; diff --git a/jingle/notifier/listener/mediator_thread_impl.cc b/jingle/notifier/listener/mediator_thread_impl.cc index 9782c55..fb3f709 100644 --- a/jingle/notifier/listener/mediator_thread_impl.cc +++ b/jingle/notifier/listener/mediator_thread_impl.cc @@ -16,7 +16,6 @@ #include "jingle/notifier/listener/subscribe_task.h" #include "net/base/host_port_pair.h" #include "net/base/host_resolver.h" -#include "talk/xmpp/xmppclient.h" #include "talk/xmpp/xmppclientsettings.h" // We manage the lifetime of notifier::MediatorThreadImpl ourselves. @@ -150,17 +149,13 @@ void MediatorThreadImpl::DoLogin( // Autodetect proxy is on by default. notifier::ConnectionOptions options; - login_.reset(new notifier::Login(settings, + login_.reset(new notifier::Login(this, + settings, options, host_resolver_.get(), server_list, server_list_count, notifier_options_.try_ssltcp_first)); - - login_->SignalConnect.connect( - this, &MediatorThreadImpl::OnConnect); - login_->SignalDisconnect.connect( - this, &MediatorThreadImpl::OnDisconnect); login_->StartConnection(); } diff --git a/jingle/notifier/listener/mediator_thread_impl.h b/jingle/notifier/listener/mediator_thread_impl.h index 32a49e8..17efcad 100644 --- a/jingle/notifier/listener/mediator_thread_impl.h +++ b/jingle/notifier/listener/mediator_thread_impl.h @@ -28,16 +28,16 @@ #include "base/ref_counted.h" #include "base/scoped_ptr.h" #include "base/thread.h" +#include "base/weak_ptr.h" #include "jingle/notifier/base/notifier_options.h" #include "jingle/notifier/communicator/login.h" #include "jingle/notifier/listener/mediator_thread.h" #include "talk/base/sigslot.h" -#include "talk/xmpp/xmppclientsettings.h" class MessageLoop; namespace buzz { -class XmppClient; +class XmppClientSettings; } // namespace buzz namespace net { @@ -45,19 +45,9 @@ class HostResolver; } // namespace net namespace notifier { -class TaskPump; -} // namespace notifier - -namespace talk_base { -class SocketServer; -class Thread; -} // namespace talk_base - -namespace notifier { -class MediatorThreadImpl - : public MediatorThread, - public sigslot::has_slots<> { +class MediatorThreadImpl : public MediatorThread, public Login::Delegate, + public sigslot::has_slots<> { public: explicit MediatorThreadImpl(const NotifierOptions& notifier_options); virtual ~MediatorThreadImpl(); @@ -77,19 +67,20 @@ class MediatorThreadImpl const std::vector<std::string>& subscribed_services_list); virtual void SendNotification(const OutgoingNotificationData& data); + // Login::Delegate implementation. + virtual void OnConnect(base::WeakPtr<talk_base::Task> base_task); + virtual void OnDisconnect(); + protected: // Should only be called after Start(). MessageLoop* worker_message_loop(); - virtual void OnDisconnect(); - // These handle messages indicating an event happened in the outside // world. These are all called from the worker thread. They are protected // so they can be used by subclasses. void OnIncomingNotification( const IncomingNotificationData& notification_data); void OnOutgoingNotification(bool success); - void OnConnect(base::WeakPtr<talk_base::Task> parent); void OnSubscriptionStateChange(bool success); scoped_refptr<ObserverListThreadSafe<Observer> > observers_; diff --git a/jingle/notifier/listener/talk_mediator_impl.h b/jingle/notifier/listener/talk_mediator_impl.h index d5b9d2f..48c284b 100644 --- a/jingle/notifier/listener/talk_mediator_impl.h +++ b/jingle/notifier/listener/talk_mediator_impl.h @@ -17,7 +17,6 @@ #include "base/scoped_ptr.h" #include "jingle/notifier/listener/mediator_thread.h" #include "jingle/notifier/listener/talk_mediator.h" -#include "talk/base/sigslot.h" #include "talk/xmpp/xmppclientsettings.h" namespace notifier { |