view sip-out/call_clear.c @ 256:63252528a56c

sip-out: add CDR log line
author Mychaela Falconia <falcon@freecalypso.org>
date Tue, 15 Aug 2023 10:11:51 -0800
parents e54b0a9e322f
children
line wrap: on
line source

/*
 * In this module we implement final clearing of calls, i.e., freeing
 * of struct call, and all preliminary steps that need to happen
 * toward this ultimate end state.
 */

#include <sys/types.h>
#include <sys/socket.h>
#include <sys/time.h>
#include <netinet/in.h>
#include <stdio.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#include <strings.h>
#include <syslog.h>
#include "../include/out_routes.h"
#include "call.h"

extern struct call *call_list;
extern struct timeval cur_event_time;

void
sip_mark_end_time(call, linger)
	struct call *call;
	unsigned linger;
{
	call->sip_clear_time = cur_event_time.tv_sec + linger;
}

void
check_dead_call(call)
	struct call *call;
{
	if (call->overall_state != OVERALL_STATE_TEARDOWN)
		return;
	if (call->mncc)
		return;
	if (call->mgw_state != MGW_STATE_NO_EXIST)
		return;
	if (call->mgw_xact)
		return;
	if (call->sip_call_exists)
		call->overall_state = OVERALL_STATE_SIP_FINISH;
	else
		call->overall_state = OVERALL_STATE_GC;
}

void
clear_dead_calls()
{
	struct call *call, **pp;

	for (pp = &call_list; *pp; ) {
		call = *pp;
		if (call->overall_state == OVERALL_STATE_GC ||
		    call->overall_state == OVERALL_STATE_SIP_FINISH &&
		    call->sip_state >= SIP_STATE_ACCEPT_100 &&
		    cur_event_time.tv_sec >= call->sip_clear_time) {
			*pp = call->next;
			free(call);
			continue;
		}
		pp = &call->next;
	}
}