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