[ekiga] Fixed unsubscription from SIP accounts
- From: Julien Puydt <jpuydt src gnome org>
- To: svn-commits-list gnome org
- Subject: [ekiga] Fixed unsubscription from SIP accounts
- Date: Mon, 15 Jun 2009 08:45:05 -0400 (EDT)
commit fa635aee76a914dc1dfb54338739a6b25ef23c2b
Author: Julien Puydt <jpuydt gnome org>
Date: Mon Jun 15 14:44:42 2009 +0200
Fixed unsubscription from SIP accounts
lib/engine/components/opal/sip-endpoint.cpp | 29 +++++++++++++++++---------
1 files changed, 19 insertions(+), 10 deletions(-)
---
diff --git a/lib/engine/components/opal/sip-endpoint.cpp b/lib/engine/components/opal/sip-endpoint.cpp
index 273ee2d..06f0c14 100644
--- a/lib/engine/components/opal/sip-endpoint.cpp
+++ b/lib/engine/components/opal/sip-endpoint.cpp
@@ -63,27 +63,36 @@ namespace Opal {
public:
subscriber (const Opal::Account & _account,
- Opal::Sip::EndPoint & _manager)
+ Opal::Sip::EndPoint & _manager,
+ bool _registering)
: PThread (1000, AutoDeleteThread),
account (_account),
- manager (_manager)
+ manager (_manager),
+ registering (_registering)
{
this->Resume ();
};
void Main ()
{
- manager.Register (account.get_username (),
- account.get_host (),
- account.get_authentication_username (),
- account.get_password (),
- account.is_enabled (),
- account.get_timeout ());
+ if (registering) {
+
+ manager.Register (account.get_username (),
+ account.get_host (),
+ account.get_authentication_username (),
+ account.get_password (),
+ account.is_enabled (),
+ account.get_timeout ());
+ } else {
+
+ manager.Unregister (account.get_aor ());
+ }
};
private:
const Opal::Account & account;
Opal::Sip::EndPoint & manager;
+ bool registering;
};
};
};
@@ -543,7 +552,7 @@ Opal::Sip::EndPoint::subscribe (const Opal::Account & account)
if (account.get_protocol_name () != "SIP")
return false;
- new subscriber (account, *this);
+ new subscriber (account, *this, true);
return true;
}
@@ -554,7 +563,7 @@ Opal::Sip::EndPoint::unsubscribe (const Opal::Account & account)
if (account.get_protocol_name () != "SIP")
return false;
- new subscriber (account, *this);
+ new subscriber (account, *this, false);
return true;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]