Modularizando o src

Dependencies:   EALib EthernetInterface_vz mbed-rtos mbed

Fork of header_main_colinas_V0-20-09-14 by VZTECH

call_box.cpp

Committer:
klauss
Date:
2015-04-30
Revision:
119:ee6a53069455
Parent:
117:e9facba9db27
Child:
121:ee02790d00b7

File content as of revision 119:ee6a53069455:

#include "call_box.h"

Call_Box::Call_Box( int ext, int port ){
    this->ext = ext;
    this->port = port;
    t.start();
    remaining_attempts = __MAX_ATTEMPTS__;
    timeout = __TIMEOUT__;
    msg_id = 0x10;
    timeslice = 0x00;
    status = cb_idle;
    sip = new Sip( ext, port );
    sip_socket_fd = sip->get_socket_fd();
    if( sip == NULL )
    {
        memory_is_over = true;
        if( debug_memory ) debug_msg("[%d] Sip allocation fail", this->ext );
    }
    
    next_aging_type = __CYCLES__;
    invite_response = true;
    bye_response = true;
    invite_retry_count = MAX_INVITE_RETRY;
    cb_new_counter++;
    invite_try_number = 0;
}

int Call_Box::get_status( void ){ return this->status; }

void Call_Box::cb_set_status( uint8_t status ){ this->status = status; }

int Call_Box::get_sip_status( void ){
    if( sip == NULL ) return -1;
    
    else return this->sip->get_status();
}

int Call_Box::set_sip_status( uint8_t status ){
    if( sip == NULL ) return( -1 );
    
    sip->sip_set_status( status );
    
    return( 0 );
}

Call_Box::~Call_Box( void ){
    if( sip != NULL ) delete( sip );
    cb_delete_counter++;
}

int Call_Box::get_port( void ){ return( this->port ); }

int Call_Box::get_ext( void ){ return( this->ext ); }

float Call_Box::get_elapsed_time( void ){ return( this->t.read_ms() ); }

void Call_Box::reset_elapsed_time( void ){ 
    this->t.reset(); 
    timeout = __TIMEOUT__;
    next_aging_type = __CYCLES__;
}

void Call_Box::registry( void ){
    if ( drop_registry_pkg )
    {
        send_msg("[%d] Dropando registry pck", this->ext );
        return;
    }    
    
    if( this->sip != NULL )
    {
        if( sip->registry() > 0x00 ) reset_elapsed_time();
        if( debug_aging ) send_msg( "[%d] Registered - ( %f )", this->ext, __TIMEOUT__ - t.read() );
    
    } else {
        debug_msg("[%d] Eu definitivamente nao deveria estar aqui!!!", this->ext );
        deleted_sip++;
    }
}

VZ_call * Call_Box::invite ( void )
{
    VZ_call * call = NULL;
    
    if( this->sip != NULL )
    {
        call = sip->invite();
    } else {   
        debug_msg("[%d] Eu definitivamente nao deveria estar aqui!!!", this->ext );
        
        deleted_sip++;
    }
    
    if( debug_cb ) send_msg("[%d] Call returned value :: %p ", this->ext, (void * )call );
    if( call == NULL ) t.start();
    return( call );
}

/*  Retorna 
    = 0 :: ok
    < 0 :: tive problemas
    > 0 :: devo remover essa call do vetor de calls 
*/
int Call_Box::listen_SIP_server( void ){
    if( this->sip == NULL )
    {
        debug_msg("[%d] Eu definitivamente nao deveria estar aqui!!!", this->ext );
        
        deleted_sip++;
        
        return ( -3 );
    } else {
        if( status == cb_on_call || status == cb_idle ){
            return ( sip->listen_SIP_server() );
        } else return ( 0 );
    }
}

void Call_Box::set_msg_id( uint8_t msg_id ){
    this->msg_id = ( msg_id > 0x10 ) ? msg_id : 0x11;
}
uint8_t Call_Box::get_msg_id( void ){ return( this->msg_id ); }

void Call_Box::set_timeslice( uint8_t timeslice ){
    this->timeslice = timeslice;
}
uint8_t Call_Box::get_timeslice( void ){ return( this->timeslice ); }

void Call_Box::send_bye( void ){ 
    if( this->sip == NULL )
    {
        debug_msg("[%d] Eu definitivamente nao deveria estar aqui!!!", this->ext );
        
        deleted_sip++;
    } else {
        sip->send_bye();
    }
}

void Call_Box::reset_sip( void ){
    debug_msg("[%d] reset_sip", this->ext );
    
    if( this->sip != NULL )
    {
         delete( this->sip );
         debug_msg("[%d] deletei", this->ext );
    }
    
    this->sip = new Sip( ext, port );
    debug_msg( "[%d ]sobrescrevi", this->ext );
    
    deleted_sip++;
    
    if( sip == NULL ) memory_is_over = true;
}

void Call_Box::set_sip_status( int status ){
    if( this->sip != NULL ){
        this->sip->status = status;
    }else{
        if( debug_cb) debug_msg("[%d] Sip equals NULL o.O", this->ext );
        deleted_sip++;
        debug_msg("[%d] Sip equals NULL o.O", this->ext );
    }        
}

void Call_Box::set_invite_response_ok ( void )
{ 
    this->invite_response = true; 
    if ( debug_invite ) send_msg ("[%d] Invite response :: ok", this->ext );
}

void Call_Box::set_invite_response_pending( void ){ this->invite_response = false; }

bool Call_Box::get_invite_response( void ){ return( this->invite_response ); }

void Call_Box::invite_retry_count_reset( void ){ invite_retry_count = MAX_INVITE_RETRY; }

uint16_t Call_Box::get_invite_retry_count( void ){ 
    return ( invite_retry_count ) ? invite_retry_count-- : 0;
}

void Call_Box::set_bye_response_ok( void ){ this->bye_response = true; }

void Call_Box::set_bye_response_pending( void ){ this->bye_response = false; }

bool Call_Box::get_bye_response( void ){ return( this->bye_response ); }


int Call_Box::get_sip_socket_fd ( void ) { return( sip_socket_fd ); }

int Call_Box::sip_udp_incomming_pkg( void ){
    return sip->udp_incomming_pkg();
}

void Call_Box::reset_cb_status ( void ) { if( sip != NULL ) sip->reset_call(); }

int Call_Box::get_sip_ext( void ){ return this->sip->get_ext(); }

int Call_Box::get_sip_port( void ){ return this->sip->get_port(); }

int Call_Box::get_timer ( void )
{
    int now = t.read ();
    if( now >= 9999 || now <= 0 ) t.reset ();
    return t.read (); 
}

int Call_Box::get_rtp_port ( void )
{
    if( this->sip != NULL ){
        return this->sip->get_sip_rtp_port();
    }else{
        debug_msg("[%d] Eu definitivamente nao deveria estar aqui!!!", this->ext );
        
        deleted_sip++;
        
        return -1;
    }
}

void Call_Box::set_rtp_port ( int new_rtp_port )
{
    if( this->sip != NULL ){
        this->sip->set_sip_rtp_port( new_rtp_port );
    }else{
        debug_msg("[%d] Eu definitivamente nao deveria estar aqui!!!", this->ext );
        
        deleted_sip++;
    }
}

void Call_Box::init_rtp_timer ( void )
{
    this->rtp_timer.start();   
}

void Call_Box::reset_rtp_timer ( void )
{
    this->rtp_timer.stop();
    this->rtp_timer.reset();
}

bool Call_Box::is_rtp_timer_timeout ( void )
{
    return ( rtp_timer.read () > RTP_REQUEST_PORT_TIMEOUT ) ? true : false;  
}

int Call_Box::get_rtp_timer ( void )
{
    return ( rtp_timer.read () );
}

int Call_Box::print_yourself ( void )
{   
    send_msg ("");
    send_msg ("Values ::\r\n");
    switch( status ) {
        case cb_idle : {
            send_msg ("status :: cb_idle" );
            break;
        }
        case cb_ringing : {
            send_msg ("status :: cb_ringing" );
            break;
        }
        case cb_trying : {
            send_msg ("status :: cb_trying" );
            break;
        }
        case cb_on_call : {
            send_msg ("status :: cb_on_call" );
            break;
        }
        case cb_busy : {
            send_msg ("status :: cb_busy" );
            break;
        }
        case cb_denied : {
            send_msg ("status :: cb_denied" );
            break;
        }
    }
    send_msg ("ext :: %i", ext );
    send_msg ("port :: %i", port );
    send_msg ("Timer t :: %d", ( int )t.read () );
    send_msg ("remaining_attempts :: %u", remaining_attempts );
    send_msg ("timeout :: %f", timeout );
    send_msg ("msg_id :: %d", msg_id );
    send_msg ("timeslice :: %u", timeslice );
    send_msg ("next_aging_type :: %u", next_aging_type );
    send_msg ("invite_response :: %s", ( invite_response ) ? "true" : "false" );
    send_msg ("invite_retry_count :: %u", invite_retry_count );
    send_msg ("bye_response :: %s", ( bye_response ) ? "true" : "false" );
    send_msg ("sip_socket_fd :: %d", sip_socket_fd );
    send_msg ("");
    
    return ( sizeof( Call_Box ) );
}

int Call_Box::call_init ( int timeslice )
{
    invite_timer.reset ();
 
    invite_timer.start ();
    
    this->timeslice = timeslice;
    
    this->status = cb_ringing;
    
    set_invite_response_pending ();            
    
    invite_try_number = 0;

    msg_id_update ();
    
    return 0;    
}

int Call_Box::call_end ( bool send_bye_to_ast )
{
    uint8_t timeslice = this->timeslice;
    
    this->timeslice = 0;
    
    this->status = cb_idle;
    
    if ( sip != NULL ) {
        sip -> sip_set_status ( sip_idle );
    } else {
        if( debug_cb ) debug_msg("[%d] Sip equals NULL o.O", this->ext );
    }
    
    set_rtp_port ( 0 );
    
    reset_rtp_timer ();
    
    if ( send_bye_to_ast )
    {
        if ( timeslice != 0 ) send_bye ();
    }
    
    reset_cb_status ();
    
    invite_timer.stop ();
    
    invite_timer.reset ();
    
    invite_try_number = 0;
    
    msg_id_update ();
    
    return timeslice;
}

int Call_Box::call_confirmed ( void )
{
    set_invite_response_pending ();
    
    this->status = cb_on_call;
    
    msg_id_update ();
    
    return 0;
}

uint8_t Call_Box::msg_id_update ( void )
{    
    this->msg_id = ( ( this->msg_id + 1 ) & ~BIT7 ) ? msg_id : 0x11;
    
    return this->msg_id;
}

void Call_Box::call_config ( void )
{
    set_invite_response_ok (); 
    reset_rtp_timer ();
    init_rtp_timer ();    
}

bool Call_Box::time_to_retry ( void )
{
    if ( invite_timer.read_ms () > 1000 ){
        invite_timer.reset ();
        return true;
    } else {
        return false;    
    }
}

uint8_t Call_Box::get_invite_try_number ( void ) {return invite_try_number; }

int Call_Box::retry_send_invite_pkg_to_ast ( void )
{   
    if( this->sip != NULL )
    {
        invite_try_number++;
        return (  sip -> retry_send_last_invite_pkg_to_ast () );
    } else {
        debug_msg("[%d] Eu definitivamente nao deveria estar aqui!!!", this->ext );
        
        deleted_sip++;
        
        return ( 0 );
    }
}