Skip to content

Commit

Permalink
qualify: beautify some err handling
Browse files Browse the repository at this point in the history
Do not restart timer if it makes no sense
  • Loading branch information
cspiel1 committed Jan 3, 2025
1 parent 107f5d9 commit a69dd01
Showing 1 changed file with 17 additions and 24 deletions.
41 changes: 17 additions & 24 deletions modules/qualify/qualify.c
Original file line number Diff line number Diff line change
Expand Up @@ -53,9 +53,9 @@ static struct qualify q = { NULL };


/* Forward declaration */
static int call_start_qualify(struct call *call,
const struct account *acc,
struct qualle *qualle);
static void call_start_qualify(struct call *call,
const struct account *acc,
struct qualle *qualle);


static void qualle_destructor(void *arg)
Expand Down Expand Up @@ -145,16 +145,14 @@ static void to_handler(void *arg)
static void interval_handler(void *arg)
{
struct qualle *qualle = arg;
(void)call_start_qualify(qualle->call, call_account(qualle->call),
qualle);
call_start_qualify(qualle->call, call_account(qualle->call), qualle);
}


static int call_start_qualify(struct call *call,
static void call_start_qualify(struct call *call,
const struct account *acc,
struct qualle *qualle)
{
int err;
struct sa peer_addr;
char peer_uri[128];
uint32_t qual_to = 0;
Expand All @@ -164,20 +162,19 @@ static int call_start_qualify(struct call *call,
account_extra_uint(acc, "qual_int", &qual_int);
account_extra_uint(acc, "qual_to", &qual_to);

if (!call || !qual_int || !qual_to) {
return EINVAL;
}
if (!call || !qual_int || !qual_to)
return;

if (qual_to >= qual_int) {
warning("qualify: timeout >= interval (%u >= %u)\n",
qual_to, qual_int);
return EINVAL;
return;
}

if (newle) {
qualle = mem_zalloc(sizeof(*qualle), qualle_destructor);
if (!qualle)
return ENOMEM;
return;

qualle->call = call;
tmr_init(&qualle->to_tmr);
Expand All @@ -188,32 +185,28 @@ static int call_start_qualify(struct call *call,

(void)call_msg_src(call, &peer_addr);

err = re_snprintf(peer_uri, sizeof(peer_uri),
int n = re_snprintf(peer_uri, sizeof(peer_uri),
"sip:%J%s", &peer_addr,
sip_transp_param(call_transp(call)));

if (err <= 0) {
warning("qualify: failed to get peer URI for %s (%m)\n",
call_peeruri(call), err);
tmr_start(&qualle->int_tmr, qual_int * 1000, interval_handler,
qualle);
return err;
if (n <= 0) {
warning("qualify: failed to get peer URI for %s\n",
call_peeruri(call));
return;
}

err = ua_options_send(call_get_ua(call), peer_uri,
options_resp_handler, mem_ref(qualle));
int err = ua_options_send(call_get_ua(call), peer_uri,
options_resp_handler, mem_ref(qualle));
if (err) {
mem_deref(qualle);
warning("qualify: sending OPTIONS failed (%m)\n", err);
tmr_start(&qualle->int_tmr, qual_int * 1000, interval_handler,
qualle);
return err;
return;
}

tmr_start(&qualle->to_tmr, qual_to * 1000, to_handler, qualle);
tmr_start(&qualle->int_tmr, qual_int * 1000, interval_handler, qualle);

return 0;
}


Expand Down

0 comments on commit a69dd01

Please sign in to comment.