Modularizando o src

Dependencies:   EALib EthernetInterface_vz mbed-rtos mbed

Fork of header_main_colinas_V0-20-09-14 by VZTECH

Committer:
klauss
Date:
Tue Nov 24 14:06:22 2015 +0000
Revision:
137:32dd35a6dbc9
Parent:
135:2f4290590e51
core source of the .bin (09/21/2015) in the field

Who changed what in which revision?

UserRevisionLine numberNew contents of line
klauss 69:65665afbad5d 1 /**
klauss 69:65665afbad5d 2 * @file sip.h
klauss 69:65665afbad5d 3 * @Synopsis Implementa as funções utilizadas no tratamento SIP entre a Header e o server
klauss 69:65665afbad5d 4 * @author Jhonatan Casale
klauss 69:65665afbad5d 5 * @version 1
klauss 69:65665afbad5d 6 * @date 2014-11-05
klauss 69:65665afbad5d 7 * \class Sip
klauss 69:65665afbad5d 8 */
klauss 0:4d17cd9c8f9d 9 #ifndef __SIP_H__
klauss 0:4d17cd9c8f9d 10 #define __SIP_H__
klauss 0:4d17cd9c8f9d 11
klauss 121:ee02790d00b7 12 #include "EthernetInterface.h"
klauss 0:4d17cd9c8f9d 13 #include "mbed.h"
klauss 121:ee02790d00b7 14 #include <stdint.h>
klauss 0:4d17cd9c8f9d 15 #include "call.h"
klauss 132:05cd37f7e007 16 %: include "config_manager.h"
klauss 132:05cd37f7e007 17 %: include "shared_variables.h"
klauss 0:4d17cd9c8f9d 18
klauss 119:ee6a53069455 19 const uint8_t INVITE_MAX_WAITING_TIME = 45;
klauss 69:65665afbad5d 20 ///< Indica o timeout de espera de resposta de pedido de ligação para o servidor, após esse tempo responde ligação encerrado para o Call_box
klauss 132:05cd37f7e007 21
klauss 119:ee6a53069455 22 const uint16_t SIP_MAXFIELDSIZE = 256;
klauss 69:65665afbad5d 23 ///< Define o tamanho máximo de algumas mensagens usadas na negociação Sip.
klauss 132:05cd37f7e007 24
klauss 121:ee02790d00b7 25 const uint16_t SIP_MAXMSGSIZE = 1024;
klauss 132:05cd37f7e007 26 ///< Define o tamanho máximo das mensagens enviadas.
klauss 132:05cd37f7e007 27
klauss 119:ee6a53069455 28 static const char SIP_ALLOW[] = "Allow: ACK, BYE, CANCEL, INFO, INVITE, NOTIFY, OPTIONS, REFER";
klauss 69:65665afbad5d 29 ///< String de composição de pacotes enviados pela Header para o *
klauss 0:4d17cd9c8f9d 30
klauss 132:05cd37f7e007 31 static const char fill_random_aux[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789pP";
klauss 119:ee6a53069455 32
klauss 121:ee02790d00b7 33 const uint8_t CALLBOX_STRING_SIZE = 32;
klauss 121:ee02790d00b7 34
klauss 121:ee02790d00b7 35 const uint8_t CONTENT_LENGTH_MSG_SIZE = 65;
klauss 121:ee02790d00b7 36
klauss 119:ee6a53069455 37 const uint8_t sip_idle = 0;
klauss 119:ee6a53069455 38 const uint8_t sip_waiting_trying = 1 << 1;
klauss 119:ee6a53069455 39 const uint8_t sip_trying = 1 << 2;
klauss 119:ee6a53069455 40 const uint8_t sip_ringing = 1 << 3;
klauss 119:ee6a53069455 41 const uint8_t sip_busy = 1 << 4;
klauss 119:ee6a53069455 42 const uint8_t sip_ok = 1 << 5; // don't used
klauss 119:ee6a53069455 43 const uint8_t sip_on_call = 1 << 6;
klauss 119:ee6a53069455 44 const uint8_t sip_denied = 1 << 7;
klauss 0:4d17cd9c8f9d 45
klauss 0:4d17cd9c8f9d 46 class Sip{
klauss 0:4d17cd9c8f9d 47
klauss 0:4d17cd9c8f9d 48 private :
klauss 121:ee02790d00b7 49 uint8_t status; ///< Representa o status do objeto Sip em dado momento.
klauss 121:ee02790d00b7 50
klauss 119:ee6a53069455 51 int my_ext;
klauss 119:ee6a53069455 52 int my_port;
klauss 119:ee6a53069455 53 int peer_ext;
klauss 119:ee6a53069455 54 int server_port;
klauss 119:ee6a53069455 55 int my_rtp_port;
klauss 119:ee6a53069455 56
klauss 119:ee6a53069455 57 int listen_SIP_server_return;
klauss 119:ee6a53069455 58 int last_cseq;
klauss 119:ee6a53069455 59
klauss 119:ee6a53069455 60 char server_ip[ 20 ];
klauss 119:ee6a53069455 61 char my_ip[ 20 ];
klauss 119:ee6a53069455 62 char my_display[ 20 ];
klauss 119:ee6a53069455 63 char SVNREV[ 16 ];
klauss 121:ee02790d00b7 64 char buffer[ SIP_MAXMSGSIZE ];
klauss 121:ee02790d00b7 65 char last_invite_tag [ SIP_MAXFIELDSIZE ];
klauss 121:ee02790d00b7 66 char last_invite_callid [ SIP_MAXFIELDSIZE ];
klauss 121:ee02790d00b7 67 char last_branch [ SIP_MAXFIELDSIZE ];
klauss 119:ee6a53069455 68
klauss 121:ee02790d00b7 69 void __init_sock__ ( void );
klauss 121:ee02790d00b7 70 void __end_sock__ ( void );
klauss 121:ee02790d00b7 71 void __reconnect__ ( void );
klauss 119:ee6a53069455 72
klauss 119:ee6a53069455 73 bool waiting;
klauss 119:ee6a53069455 74
klauss 119:ee6a53069455 75 UDPSocket sock;
klauss 119:ee6a53069455 76
klauss 119:ee6a53069455 77 Endpoint sip_server;
klauss 119:ee6a53069455 78
klauss 91:c2a86b1f8aaa 79 VZ_call * call;
klauss 119:ee6a53069455 80
klauss 91:c2a86b1f8aaa 81 Timer invite_timer;
klauss 119:ee6a53069455 82
klauss 0:4d17cd9c8f9d 83 public :
klauss 69:65665afbad5d 84 /**
klauss 69:65665afbad5d 85 * @Synopsis Cria um objeto Sip setando ramal e porta e o restando buscando valores default.
klauss 69:65665afbad5d 86 *
klauss 69:65665afbad5d 87 * @param id O identificador do objeto ( por definição de projeto o ramal ( ext ) ).
klauss 69:65665afbad5d 88 * @param my_port A porta do objeto Sip para comunicação com o servidor.
klauss 69:65665afbad5d 89 *
klauss 69:65665afbad5d 90 * Exemplo:
klauss 69:65665afbad5d 91 *
klauss 69:65665afbad5d 92 * @code
klauss 69:65665afbad5d 93 * ...
klauss 69:65665afbad5d 94 * Sip * sip = new Sip( 5002, 5002 );
klauss 69:65665afbad5d 95 * ...
klauss 69:65665afbad5d 96 * @endcode
klauss 69:65665afbad5d 97 */
klauss 121:ee02790d00b7 98 Sip ( const int my_ext, const uint16_t my_port );
klauss 114:472502b31a12 99
klauss 114:472502b31a12 100 /**
klauss 69:65665afbad5d 101 * @Synopsis Destroi o objeto Sip
klauss 69:65665afbad5d 102 *
klauss 69:65665afbad5d 103 * Exemplo:
klauss 69:65665afbad5d 104 *
klauss 69:65665afbad5d 105 * @code
klauss 69:65665afbad5d 106 * ...
klauss 69:65665afbad5d 107 * delete( sip );
klauss 69:65665afbad5d 108 * ...
klauss 69:65665afbad5d 109 * @endcode
klauss 69:65665afbad5d 110 */
klauss 121:ee02790d00b7 111 ~Sip ( void );
klauss 69:65665afbad5d 112
klauss 69:65665afbad5d 113 /**
klauss 69:65665afbad5d 114 * @Synopsis Responsavel por montar encaminhar o pacote de registro para o servidor.
klauss 69:65665afbad5d 115 *
klauss 69:65665afbad5d 116 * Exemplo:
klauss 69:65665afbad5d 117 * @code
klauss 69:65665afbad5d 118 * ...
klauss 69:65665afbad5d 119 * sip->registry();
klauss 69:65665afbad5d 120 * ...
klauss 69:65665afbad5d 121 * @endcode
klauss 69:65665afbad5d 122 */
klauss 121:ee02790d00b7 123 int registry ( void );
klauss 69:65665afbad5d 124
klauss 69:65665afbad5d 125 /**
klauss 69:65665afbad5d 126 * @Synopsis Efetivamente envia o pedido de ligação para o servidor.
klauss 69:65665afbad5d 127 *
klauss 69:65665afbad5d 128 * @return Uma referência para uma ligação, caso a negociação resulte na aceitação por parte do servidor, NULL, caso contrário.
klauss 69:65665afbad5d 129 * \note Como por conveniência, foi configurado no servidor * que existiria musica de conforto, o que fez com que, assim que é
klauss 69:65665afbad5d 130 * feito o envio do pacote de invite, uma chamada é criada para se trocar os dados desse audio de conforto, ficando a Header na
klauss 69:65665afbad5d 131 * espera do servidor aceitar ou não o pedido de forma definitiva, no caso em que o server dizer "ok", a mesma chamada é retornada,
klauss 69:65665afbad5d 132 * porém, no caso de timeout ou negativa do server, a chamada é destruida e NULL é retornado.
klauss 69:65665afbad5d 133 *
klauss 69:65665afbad5d 134 * Exemplo:
klauss 69:65665afbad5d 135 * @code
klauss 69:65665afbad5d 136 * ...
klauss 69:65665afbad5d 137 * VZ_call * call = sip->invite();
klauss 69:65665afbad5d 138 * ...
klauss 69:65665afbad5d 139 * @endcode
klauss 69:65665afbad5d 140 */
klauss 121:ee02790d00b7 141 VZ_call * invite ( void );
klauss 69:65665afbad5d 142
klauss 69:65665afbad5d 143 /**
klauss 69:65665afbad5d 144 * @Synopsis Gera um nro de cseq para preenchimento no cabeçalho dos pacotes Sip.
klauss 69:65665afbad5d 145 *
klauss 69:65665afbad5d 146 * @return O numero gerado.
klauss 69:65665afbad5d 147 *
klauss 69:65665afbad5d 148 * Exemplo:
klauss 69:65665afbad5d 149 * @code
klauss 69:65665afbad5d 150 * ...
klauss 69:65665afbad5d 151 * int cseq = sip->get_cseq();
klauss 69:65665afbad5d 152 * ...
klauss 69:65665afbad5d 153 * @endcode
klauss 69:65665afbad5d 154 */
klauss 121:ee02790d00b7 155 int get_cseq ( void );
klauss 0:4d17cd9c8f9d 156
klauss 69:65665afbad5d 157 /**
klauss 69:65665afbad5d 158 * @Synopsis Efetivamente cria o pacote de registro.
klauss 69:65665afbad5d 159 *
klauss 69:65665afbad5d 160 * @param buffer Recebe um ponteiro para uma região de memória onde irá escrever o pacote de registro.
klauss 69:65665afbad5d 161 *
klauss 69:65665afbad5d 162 * @return Um ponteiro para o inicio do pacote montado ( mesmo endereço passado como parâmetro ).
klauss 69:65665afbad5d 163 */
klauss 121:ee02790d00b7 164 char * build_registry_package ( void );
klauss 69:65665afbad5d 165
klauss 69:65665afbad5d 166 /**
klauss 69:65665afbad5d 167 * @Synopsis Efetivamente cria um pacote de invite ( pedido de chamada ) do Call_box para o server.
klauss 69:65665afbad5d 168 *
klauss 69:65665afbad5d 169 * @param s Um ponteiro para uma região de memória onde irá escrever o pacote de invite.
klauss 69:65665afbad5d 170 * @param callbox_string Uma string de identifcação do Call_box.
klauss 69:65665afbad5d 171 * @param cseq O nro de cseq que irá ser colocado no pacote.
klauss 69:65665afbad5d 172 *
klauss 69:65665afbad5d 173 * @return
klauss 69:65665afbad5d 174 */
klauss 121:ee02790d00b7 175 char * build_invite_package ( int * cseq, const bool retry = false );
klauss 69:65665afbad5d 176
klauss 69:65665afbad5d 177 /**
klauss 69:65665afbad5d 178 * @Synopsis Efetivamente cria um pacote de "despedida" para o servidor, usado para encerrar ligações.
klauss 69:65665afbad5d 179 *
klauss 69:65665afbad5d 180 * @param buffer Um ponteiro para uma região de memória onde irá escrever o pacote de bye.
klauss 69:65665afbad5d 181 *
klauss 69:65665afbad5d 182 * @return Um ponteiro para o inicio do pacote montado ( mesmo endereço passado como parâmetro ).
klauss 69:65665afbad5d 183 */
klauss 121:ee02790d00b7 184 char * build_bye_package ( void );
klauss 69:65665afbad5d 185
klauss 69:65665afbad5d 186 /**
klauss 69:65665afbad5d 187 * @Synopsis Efetivamente cria um pacote de ack de mensagem recebida.
klauss 69:65665afbad5d 188 *
klauss 69:65665afbad5d 189 * @param buffer Um ponteiro para a posição de memória onde será criado o pacote ack
klauss 69:65665afbad5d 190 * @param orig O pacote original recebido do servidor, serve como referência na criação do pacote de resposta,
klauss 69:65665afbad5d 191 *
klauss 69:65665afbad5d 192 * @return Um ponteiro para o inicio do pacote montado ( mesmo endereço passado como parâmetro ).
klauss 69:65665afbad5d 193 */
klauss 132:05cd37f7e007 194 char * build_ack_package ( void );
klauss 69:65665afbad5d 195
klauss 69:65665afbad5d 196 /**
klauss 69:65665afbad5d 197 * @Synopsis
klauss 69:65665afbad5d 198 *
klauss 69:65665afbad5d 199 * @param buffer Um ponteiro para a posição de memória onde será montado o pacote.
klauss 69:65665afbad5d 200 * @param orig O pacote de origem, serve como referência na criação do pacote.
klauss 69:65665afbad5d 201 *
klauss 69:65665afbad5d 202 * @return Um ponteiro para o inicio do pacote montado ( mesmo endereço passado como parâmetro ).
klauss 69:65665afbad5d 203 */
klauss 132:05cd37f7e007 204 char * build_reply_package ( void );
klauss 69:65665afbad5d 205
klauss 69:65665afbad5d 206 /**
klauss 69:65665afbad5d 207 * @Synopsis Preenche de forma aleatótia 16 posições de memória.
klauss 69:65665afbad5d 208 *
klauss 69:65665afbad5d 209 * @param buffer Um ponteiro que aponta para o inicio das 16 ( bytes ) posições que serão preenchidas.
klauss 69:65665afbad5d 210 *
klauss 69:65665afbad5d 211 * @return Retorna um ponteiro para os dados preenchidos ( mesmo endereço passado como parâmetro.
klauss 69:65665afbad5d 212 */
klauss 121:ee02790d00b7 213 char * fill_random16h ( char * buffer );
klauss 69:65665afbad5d 214
klauss 69:65665afbad5d 215 /**
klauss 69:65665afbad5d 216 * @Synopsis Preenche de forma aleatótia dados.
klauss 69:65665afbad5d 217 *
klauss 69:65665afbad5d 218 * @param buffer Um ponteiro que aponta para o inicio das posições a serem preenchidas.
klauss 69:65665afbad5d 219 * @param size A quantidade ( em posições ) que serão preenchidas.
klauss 69:65665afbad5d 220 *
klauss 69:65665afbad5d 221 * @return Um ponteiro para o inicio das posições preenchidas ( mesmo endereço do parâmetro passado ).
klauss 69:65665afbad5d 222 */
klauss 121:ee02790d00b7 223 char * fill_random ( char * buffer, const int size );
klauss 69:65665afbad5d 224
klauss 69:65665afbad5d 225 /**
klauss 69:65665afbad5d 226 * @Synopsis Gera aleatóriamente a porta RTP de onde os dados de audiao serão enviados da Header.
klauss 69:65665afbad5d 227 *
klauss 69:65665afbad5d 228 * @return O nro da porta que será usada na negociação Sip.
klauss 69:65665afbad5d 229 */
klauss 121:ee02790d00b7 230 int fill_random_rtp_port ( void );
klauss 0:4d17cd9c8f9d 231
klauss 69:65665afbad5d 232 /**
klauss 69:65665afbad5d 233 * @Synopsis Dado um pacote recebido do server, decodifica o nro cseq.
klauss 69:65665afbad5d 234 *
klauss 69:65665afbad5d 235 * @param package O pacote do qual se tem interesse em decodificar.
klauss 69:65665afbad5d 236 * @param cseq Um ponteiro que aponta para a posição de memória onde será escrito o cseq.
klauss 69:65665afbad5d 237 *
klauss 69:65665afbad5d 238 * @return Um ponteiro para o inicio da posição de memória que contem o cseq ( mesma passada como parâmetro ).
klauss 69:65665afbad5d 239 */
klauss 121:ee02790d00b7 240 char * decode_cseq ( const unsigned char * package, char * cseq );
klauss 69:65665afbad5d 241
klauss 69:65665afbad5d 242 /**
klauss 69:65665afbad5d 243 * @Synopsis Dado um pacote recebido do server, decodifica o branch.
klauss 69:65665afbad5d 244 *
klauss 69:65665afbad5d 245 * @param package Um ponteiro para o pacote recebido do servidor o qual temos interesse em decodificar.
klauss 69:65665afbad5d 246 * @param branch Um ponteiro para o inicio da posição de memória onde escreveremos o branch
klauss 69:65665afbad5d 247 *
klauss 69:65665afbad5d 248 * @return Um ponteiro para o inicio da posição de memória onde escrevemos o branch ( mesma passada como parâmentro ).
klauss 69:65665afbad5d 249 */
klauss 121:ee02790d00b7 250 char * decode_branch ( const unsigned char * package, char * branch );
klauss 69:65665afbad5d 251
klauss 69:65665afbad5d 252 /**
klauss 69:65665afbad5d 253 * @Synopsis Busca por uma determinado substring em um pacote recebido do servidor. Copiando o restando desse pacote para
klauss 69:65665afbad5d 254 * uma posição de interesse.
klauss 69:65665afbad5d 255 *
klauss 69:65665afbad5d 256 * @param package O pacote que se tem interesse em decodificar.
klauss 69:65665afbad5d 257 * @param tag A substring que a função ira buscar em package.
klauss 69:65665afbad5d 258 * @param out A região de memória para onde o restante dos dados contidos em package será copiado, caso a substring seja
klauss 69:65665afbad5d 259 * encontrada.
klauss 69:65665afbad5d 260 *
klauss 69:65665afbad5d 261 * @return 1, caso tenha encontrado a string tag contida no package, copia o restando do conteudo de package para out e retorna 1,
klauss 69:65665afbad5d 262 * retorna 0 caso a substring não seja encontrada.
klauss 69:65665afbad5d 263 */
klauss 121:ee02790d00b7 264 int decode_gettag ( const unsigned char * package, const char * tag, char * out );
klauss 0:4d17cd9c8f9d 265
klauss 69:65665afbad5d 266 /**
klauss 69:65665afbad5d 267 * @Synopsis Recebe um ramal de comunicação com o servidor, realizando solicitações futuras com esse ramal.
klauss 69:65665afbad5d 268 *
klauss 69:65665afbad5d 269 * @param new_server_ext O Ramal do servidor que será associado ao objeto Sip
klauss 69:65665afbad5d 270 *
klauss 69:65665afbad5d 271 * Exemplo:
klauss 69:65665afbad5d 272 * @code
klauss 69:65665afbad5d 273 * ...
klauss 69:65665afbad5d 274 * sip->set_server_ext( 913 );
klauss 69:65665afbad5d 275 * ...
klauss 69:65665afbad5d 276 * @endcode
klauss 69:65665afbad5d 277 */
klauss 121:ee02790d00b7 278 void set_server_ext ( const int new_server_ext );
klauss 69:65665afbad5d 279
klauss 69:65665afbad5d 280 /**
klauss 69:65665afbad5d 281 * @Synopsis Recebe uma porta de comunicação com o servidor, setando e realizando comunicaões entre Header-Server atraves
klauss 69:65665afbad5d 282 * dessa porta
klauss 69:65665afbad5d 283 *
klauss 69:65665afbad5d 284 * @param new_server_port A porta do servidor que será associada ao objeto Sip
klauss 69:65665afbad5d 285 *
klauss 69:65665afbad5d 286 * Exemplo:
klauss 69:65665afbad5d 287 * @code
klauss 69:65665afbad5d 288 * ...
klauss 69:65665afbad5d 289 * sip->set_server_port( 818 );
klauss 69:65665afbad5d 290 * ...
klauss 69:65665afbad5d 291 * @endcode
klauss 69:65665afbad5d 292 */
klauss 121:ee02790d00b7 293 void set_server_port ( const int new_server_port );
klauss 69:65665afbad5d 294
klauss 69:65665afbad5d 295 /**
klauss 69:65665afbad5d 296 * @Synopsis Seta a porta de comunicação Sip da Header.
klauss 69:65665afbad5d 297 *
klauss 69:65665afbad5d 298 * @param port Porta que será associada ao objeto Sip criado.
klauss 69:65665afbad5d 299 *
klauss 69:65665afbad5d 300 * Exemplo:
klauss 69:65665afbad5d 301 * @code
klauss 69:65665afbad5d 302 * ...
klauss 69:65665afbad5d 303 * sipset_port( 1028 );
klauss 69:65665afbad5d 304 * ...
klauss 69:65665afbad5d 305 * @endcode
klauss 69:65665afbad5d 306 *
klauss 69:65665afbad5d 307 *
klauss 69:65665afbad5d 308 */
klauss 121:ee02790d00b7 309 void set_port ( const int port );
klauss 69:65665afbad5d 310
klauss 69:65665afbad5d 311 /**
klauss 69:65665afbad5d 312 * @Synopsis Seta o valor passado como parâmetro como sendo o endeço IP de contato do servidor.
klauss 69:65665afbad5d 313 *
klauss 69:65665afbad5d 314 * @param new_server_ip O endereço que será associado ao objeto Sip.
klauss 69:65665afbad5d 315 *
klauss 69:65665afbad5d 316 * Exemplo:
klauss 69:65665afbad5d 317 * @code
klauss 69:65665afbad5d 318 * ...
klauss 69:65665afbad5d 319 * sip->set_server_ip( "192.168.120.8" );
klauss 69:65665afbad5d 320 * ...
klauss 69:65665afbad5d 321 * @endcode
klauss 69:65665afbad5d 322 */
klauss 121:ee02790d00b7 323 void set_server_ip ( const char * new_server_ip );
klauss 0:4d17cd9c8f9d 324
klauss 69:65665afbad5d 325 /**
klauss 69:65665afbad5d 326 * @Synopsis Responsavel por ouvir o servidor *, verificando se o mesmo esta mandando alguma mensagem, seja Sip ou qualquer outra
klauss 69:65665afbad5d 327 * nas portas acordadas.
klauss 69:65665afbad5d 328 *
klauss 69:65665afbad5d 329 * @return 0, sucesso na execução, sem pendencia, ou retorna um nro maior que zero, representando o nro do ramal cuja ligação deve
klauss 69:65665afbad5d 330 * ser encerrada.
klauss 69:65665afbad5d 331 */
klauss 121:ee02790d00b7 332 int listen_SIP_server ( void );
klauss 69:65665afbad5d 333
klauss 69:65665afbad5d 334 /**
klauss 69:65665afbad5d 335 * @Synopsis Envia efetivamente o pacote de despedita com Call_box pro servidor
klauss 69:65665afbad5d 336 *
klauss 69:65665afbad5d 337 * Exemplo:
klauss 69:65665afbad5d 338 * @code
klauss 69:65665afbad5d 339 * ...
klauss 69:65665afbad5d 340 * sip->send_bye();
klauss 69:65665afbad5d 341 * ...
klauss 69:65665afbad5d 342 * @endcode
klauss 69:65665afbad5d 343 */
klauss 121:ee02790d00b7 344 void send_bye ( void );
klauss 69:65665afbad5d 345
klauss 69:65665afbad5d 346 /**
klauss 78:1353744f01e1 347 * @Synopsis Retorna o status atual do objeto
klauss 69:65665afbad5d 348 *
klauss 78:1353744f01e1 349 * @return O valor correspondente ao status do objeto
klauss 69:65665afbad5d 350 */
klauss 121:ee02790d00b7 351 int get_status ( void );
klauss 119:ee6a53069455 352
klauss 119:ee6a53069455 353 /*------------------------------------------------------------------------------------------------*/
klauss 121:ee02790d00b7 354 int get_socket_fd ( void );
klauss 121:ee02790d00b7 355
klauss 121:ee02790d00b7 356 int udp_incomming_pkg ( void );
klauss 121:ee02790d00b7 357
klauss 121:ee02790d00b7 358 int get_ext ( void );
klauss 121:ee02790d00b7 359
klauss 121:ee02790d00b7 360 int get_port ( void );
klauss 121:ee02790d00b7 361
klauss 119:ee6a53069455 362 int get_sip_rtp_port ( void );
klauss 121:ee02790d00b7 363
klauss 119:ee6a53069455 364 int print_yourself ( void );
klauss 121:ee02790d00b7 365
klauss 119:ee6a53069455 366 int retry_send_last_invite_pkg_to_ast ( void );
klauss 119:ee6a53069455 367
klauss 121:ee02790d00b7 368
klauss 121:ee02790d00b7 369 void set_sip_rtp_port ( const int new_my_rtp_port );
klauss 121:ee02790d00b7 370
klauss 121:ee02790d00b7 371 void sip_set_status ( const uint8_t status );
klauss 121:ee02790d00b7 372
klauss 121:ee02790d00b7 373 void reset_call ( void );
klauss 132:05cd37f7e007 374
klauss 132:05cd37f7e007 375 void update ( void );
klauss 0:4d17cd9c8f9d 376 };
klauss 0:4d17cd9c8f9d 377 #endif