1
0
Fork 0
mirror of https://gitlab.gnome.org/GNOME/calls.git synced 2025-01-07 20:35:31 +00:00

sip: origin: Use CallsAccountState instead of SipAccountState

This commit is contained in:
Evangelos Ribeiro Tzaras 2021-04-29 14:23:15 +02:00
parent 0e5bd82568
commit 781adaddee
4 changed files with 31 additions and 43 deletions

View file

@ -25,6 +25,7 @@
#define G_LOG_DOMAIN "CallsSipOrigin" #define G_LOG_DOMAIN "CallsSipOrigin"
#include "calls-account.h"
#include "calls-credentials.h" #include "calls-credentials.h"
#include "calls-message-source.h" #include "calls-message-source.h"
#include "calls-origin.h" #include "calls-origin.h"
@ -34,6 +35,7 @@
#include "calls-sip-util.h" #include "calls-sip-util.h"
#include "calls-sip-media-manager.h" #include "calls-sip-media-manager.h"
#include "config.h" #include "config.h"
#include "enum-types.h"
#include <glib/gi18n.h> #include <glib/gi18n.h>
#include <glib-object.h> #include <glib-object.h>
@ -82,7 +84,7 @@ struct _CallsSipOrigin
/* Needed to handle shutdown correctly. See sip_callback and dispose method */ /* Needed to handle shutdown correctly. See sip_callback and dispose method */
gboolean is_nua_shutdown; gboolean is_nua_shutdown;
SipAccountState state; CallsAccountState state;
CallsSipMediaManager *media_manager; CallsSipMediaManager *media_manager;
@ -446,20 +448,20 @@ sip_r_register (int status,
if (status == 200) { if (status == 200) {
g_debug ("REGISTER successful"); g_debug ("REGISTER successful");
origin->state = SIP_ACCOUNT_ONLINE; origin->state = CALLS_ACCOUNT_ONLINE;
} }
else if (status == 401 || status == 407) { else if (status == 401 || status == 407) {
sip_authenticate (origin, nh, sip); sip_authenticate (origin, nh, sip);
origin->state = SIP_ACCOUNT_AUTHENTICATING; origin->state = CALLS_ACCOUNT_AUTHENTICATING;
} }
else if (status == 403) { else if (status == 403) {
g_warning ("wrong credentials?"); g_warning ("wrong credentials?");
origin->state = SIP_ACCOUNT_ERROR_RETRY; origin->state = CALLS_ACCOUNT_AUTHENTICATION_FAILURE;
} }
else if (status == 904) { else if (status == 904) {
g_warning ("unmatched challenge"); g_warning ("unmatched challenge");
origin->state = SIP_ACCOUNT_ERROR_RETRY; origin->state = CALLS_ACCOUNT_AUTHENTICATION_FAILURE;
} }
g_object_notify_by_pspec (G_OBJECT (origin), props[PROP_ACC_STATE]); g_object_notify_by_pspec (G_OBJECT (origin), props[PROP_ACC_STATE]);
} }
@ -882,7 +884,6 @@ static gboolean
init_sip_account (CallsSipOrigin *self, init_sip_account (CallsSipOrigin *self,
GError **error) GError **error)
{ {
gboolean recoverable = FALSE;
gboolean auto_connect = FALSE; gboolean auto_connect = FALSE;
if (self->use_direct_connection) { if (self->use_direct_connection) {
@ -895,7 +896,8 @@ init_sip_account (CallsSipOrigin *self,
"Must have completed account setup before calling" "Must have completed account setup before calling"
"init_sip_account ()" "init_sip_account ()"
"Try again when account is setup"); "Try again when account is setup");
recoverable = TRUE;
self->state = CALLS_ACCOUNT_NO_CREDENTIALS;
goto err; goto err;
} }
@ -904,6 +906,8 @@ init_sip_account (CallsSipOrigin *self,
if (self->nua == NULL) { if (self->nua == NULL) {
g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED, g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
"Failed setting up nua context"); "Failed setting up nua context");
self->state = CALLS_ACCOUNT_NULL;
goto err; goto err;
} }
@ -911,14 +915,16 @@ init_sip_account (CallsSipOrigin *self,
if (self->oper == NULL) { if (self->oper == NULL) {
g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED, g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
"Failed setting operation handles"); "Failed setting operation handles");
self->state = CALLS_ACCOUNT_NULL;
goto err; goto err;
} }
/* In the case of a direct connection we're immediately good to go */ /* In the case of a direct connection we're immediately good to go */
if (self->use_direct_connection) if (self->use_direct_connection)
self->state = SIP_ACCOUNT_ONLINE; self->state = CALLS_ACCOUNT_ONLINE;
else { else {
self->state = SIP_ACCOUNT_OFFLINE; self->state = CALLS_ACCOUNT_OFFLINE;
g_object_get (self->credentials, "auto-connect", &auto_connect, NULL); g_object_get (self->credentials, "auto-connect", &auto_connect, NULL);
/* try to go online */ /* try to go online */
@ -930,7 +936,6 @@ init_sip_account (CallsSipOrigin *self,
return TRUE; return TRUE;
err: err:
self->state = recoverable ? SIP_ACCOUNT_ERROR_RETRY : SIP_ACCOUNT_ERROR;
g_object_notify_by_pspec (G_OBJECT (self), props[PROP_ACC_STATE]); g_object_notify_by_pspec (G_OBJECT (self), props[PROP_ACC_STATE]);
return FALSE; return FALSE;
} }
@ -1041,7 +1046,7 @@ calls_sip_origin_dispose (GObject *object)
{ {
CallsSipOrigin *self = CALLS_SIP_ORIGIN (object); CallsSipOrigin *self = CALLS_SIP_ORIGIN (object);
if (self->state == SIP_ACCOUNT_NULL) if (self->state == CALLS_ACCOUNT_NULL)
return; return;
remove_calls (self, NULL); remove_calls (self, NULL);
@ -1050,7 +1055,7 @@ calls_sip_origin_dispose (GObject *object)
g_clear_pointer (&self->oper->call_handle, nua_handle_unref); g_clear_pointer (&self->oper->call_handle, nua_handle_unref);
g_clear_pointer (&self->oper->register_handle, nua_handle_unref); g_clear_pointer (&self->oper->register_handle, nua_handle_unref);
if (!self->use_direct_connection && self->state == SIP_ACCOUNT_OFFLINE) if (!self->use_direct_connection && self->state == CALLS_ACCOUNT_OFFLINE)
calls_sip_origin_go_online (self, FALSE); calls_sip_origin_go_online (self, FALSE);
} }
@ -1066,7 +1071,7 @@ calls_sip_origin_dispose (GObject *object)
self->nua = NULL; self->nua = NULL;
} }
self->state = SIP_ACCOUNT_NULL; self->state = CALLS_ACCOUNT_NULL;
G_OBJECT_CLASS (calls_sip_origin_parent_class)->dispose (object); G_OBJECT_CLASS (calls_sip_origin_parent_class)->dispose (object);
} }
@ -1130,8 +1135,8 @@ calls_sip_origin_class_init (CallsSipOriginClass *klass)
g_param_spec_enum ("account-state", g_param_spec_enum ("account-state",
"Account state", "Account state",
"The state of the SIP account", "The state of the SIP account",
SIP_TYPE_ACCOUNT_STATE, CALLS_TYPE_ACCOUNT_STATE,
SIP_ACCOUNT_NULL, CALLS_ACCOUNT_NULL,
G_PARAM_READWRITE); G_PARAM_READWRITE);
g_object_class_install_property (object_class, PROP_ACC_STATE, props[PROP_ACC_STATE]); g_object_class_install_property (object_class, PROP_ACC_STATE, props[PROP_ACC_STATE]);
@ -1200,7 +1205,7 @@ calls_sip_origin_go_online (CallsSipOrigin *self,
g_autofree char *display_name = NULL; g_autofree char *display_name = NULL;
g_autofree char *registrar_url = NULL; g_autofree char *registrar_url = NULL;
if (self->state == SIP_ACCOUNT_ONLINE) if (self->state == CALLS_ACCOUNT_ONLINE)
return; return;
g_object_get (self->credentials, g_object_get (self->credentials,
@ -1217,7 +1222,7 @@ calls_sip_origin_go_online (CallsSipOrigin *self,
TAG_END ()); TAG_END ());
} }
else { else {
if (self->state == SIP_ACCOUNT_OFFLINE) if (self->state == CALLS_ACCOUNT_OFFLINE)
return; return;
nua_unregister (self->oper->register_handle, nua_unregister (self->oper->register_handle,

View file

@ -57,27 +57,6 @@ typedef enum
SIP_ENGINE_READY, SIP_ENGINE_READY,
} SipEngineState; } SipEngineState;
/**
* SipAccountState:
* @SIP_ACCOUNT_NULL: Not initialized
* @SIP_ACCOUNT_OFFLINE: Account considered offline (not ready for placing or receiving calls)
* @SIP_ACCOUNT_REGISTERING: REGISTER sent
* @SIP_ACCOUNT_AUTHENTICATING: Authenticating using web-auth/proxy-auth
* @SIP_ACCOUNT_ERROR: Unrecoverable error
* @SIP_ACCOUNT_ERROR_RETRY: Recoverable error (f.e. using other credentials)
* @SIP_ACCOUNT_ONLINE: Account considered online (can place and receive calls)
*/
typedef enum
{
SIP_ACCOUNT_NULL = 0,
SIP_ACCOUNT_OFFLINE,
SIP_ACCOUNT_REGISTERING,
SIP_ACCOUNT_AUTHENTICATING,
SIP_ACCOUNT_ERROR,
SIP_ACCOUNT_ERROR_RETRY,
SIP_ACCOUNT_ONLINE,
} SipAccountState;
gboolean check_sips (const gchar *addr); gboolean check_sips (const gchar *addr);
gboolean check_ipv6 (const gchar *host); gboolean check_ipv6 (const gchar *host);

View file

@ -45,12 +45,13 @@ struct _CallsAccountInterface
}; };
/** /**
* CallsAccountState: * CallsAccountState:
* @CALLS_ACCOUNT_NULL: Not initialized * @CALLS_ACCOUNT_NULL: Not initialized or error
* @CALLS_ACCOUNT_OFFLINE: Account considered offline (not ready for placing or receiving calls) * @CALLS_ACCOUNT_OFFLINE: Account considered offline (not ready for placing or receiving calls)
* @CALLS_ACCOUNT_CONNECTING: Trying to connect to server * @CALLS_ACCOUNT_CONNECTING: Trying to connect to server
* @CALLS_ACCOUNT_CONNECTION_FAILURE: Could not connect to server (f.e. DNS error, unreachable) * @CALLS_ACCOUNT_CONNECTION_FAILURE: Could not connect to server (f.e. DNS error, unreachable)
* @CALLS_ACCOUNT_AUTHENTICATING: Authenticating using web-auth/proxy-auth * @CALLS_ACCOUNT_AUTHENTICATING: Authenticating using web-auth/proxy-auth
* @CALLS_ACCOUNT_AUTHENTICATION_FAILURE: Could not authenticate to server (f.e. wrong credentials) * @CALLS_ACCOUNT_AUTHENTICATION_FAILURE: Could not authenticate to server (f.e. wrong credentials)
* @CALLS_ACCOUNT_NO_CREDENTIALS: Credentials are missing
* @CALLS_ACCOUNT_ONLINE: Account considered online (can place and receive calls) * @CALLS_ACCOUNT_ONLINE: Account considered online (can place and receive calls)
*/ */
typedef enum { typedef enum {
@ -60,6 +61,8 @@ typedef enum {
CALLS_ACCOUNT_CONNECTION_FAILURE, CALLS_ACCOUNT_CONNECTION_FAILURE,
CALLS_ACCOUNT_AUTHENTICATING, CALLS_ACCOUNT_AUTHENTICATING,
CALLS_ACCOUNT_AUTHENTICATION_FAILURE, CALLS_ACCOUNT_AUTHENTICATION_FAILURE,
CALLS_ACCOUNT_NO_CREDENTIALS,
CALLS_ACCOUNT_UNKNOWN_ERROR,
CALLS_ACCOUNT_ONLINE CALLS_ACCOUNT_ONLINE
} CallsAccountState; } CallsAccountState;

View file

@ -11,6 +11,7 @@
#include "calls-sip-provider.h" #include "calls-sip-provider.h"
#include "calls-sip-origin.h" #include "calls-sip-origin.h"
#include "calls-sip-util.h" #include "calls-sip-util.h"
#include "calls-account.h"
#include "gst-rfc3551.h" #include "gst-rfc3551.h"
#include <gtk/gtk.h> #include <gtk/gtk.h>
@ -84,7 +85,7 @@ static void
test_sip_origin_objects (SipFixture *fixture, test_sip_origin_objects (SipFixture *fixture,
gconstpointer user_data) gconstpointer user_data)
{ {
SipAccountState state_alice, state_bob, state_offline; CallsAccountState state_alice, state_bob, state_offline;
g_assert_true (G_IS_OBJECT (fixture->origin_alice)); g_assert_true (G_IS_OBJECT (fixture->origin_alice));
g_assert_true (G_IS_OBJECT (fixture->origin_bob)); g_assert_true (G_IS_OBJECT (fixture->origin_bob));
@ -112,9 +113,9 @@ test_sip_origin_objects (SipFixture *fixture,
"account-state", &state_offline, "account-state", &state_offline,
NULL); NULL);
g_assert_cmpint (state_alice, ==, SIP_ACCOUNT_ONLINE); g_assert_cmpint (state_alice, ==, CALLS_ACCOUNT_ONLINE);
g_assert_cmpint (state_bob, ==, SIP_ACCOUNT_ONLINE); g_assert_cmpint (state_bob, ==, CALLS_ACCOUNT_ONLINE);
g_assert_cmpint (state_offline, ==, SIP_ACCOUNT_OFFLINE); g_assert_cmpint (state_offline, ==, CALLS_ACCOUNT_OFFLINE);
} }
static void static void