sipstack.c 4.21 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
/*
	belle-sip - SIP (RFC3261) library.
    Copyright (C) 2010  Belledonne Communications SARL

    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/

#include "belle_sip_internal.h"
jehan's avatar
jehan committed
20
#include "listeningpoint_internal.h"
Simon Morlat's avatar
Simon Morlat committed
21 22


23
static void belle_sip_stack_destroy(belle_sip_stack_t *stack){
jehan's avatar
jehan committed
24
	belle_sip_object_unref(stack->ml);
25 26
}

27
BELLE_SIP_DECLARE_NO_IMPLEMENTED_INTERFACES(belle_sip_stack_t);
Simon Morlat's avatar
Simon Morlat committed
28
BELLE_SIP_INSTANCIATE_VPTR(belle_sip_stack_t,belle_sip_object_t,belle_sip_stack_destroy,NULL,NULL,FALSE);
Simon Morlat's avatar
Simon Morlat committed
29

30
belle_sip_stack_t * belle_sip_stack_new(const char *properties){
Simon Morlat's avatar
Simon Morlat committed
31
	belle_sip_stack_t *stack=belle_sip_object_new(belle_sip_stack_t);
32
	stack->ml=belle_sip_main_loop_new ();
33 34 35
	stack->timer_config.T1=500;
	stack->timer_config.T2=4000;
	stack->timer_config.T4=5000;
36
	stack->transport_timeout=30000;
37 38 39
	return stack;
}

40 41 42 43
const belle_sip_timer_config_t *belle_sip_stack_get_timer_config(const belle_sip_stack_t *stack){
	return &stack->timer_config;
}

44 45 46 47
int belle_sip_stack_get_transport_timeout(const belle_sip_stack_t *stack){
	return stack->transport_timeout;
}

48 49
belle_sip_listening_point_t *belle_sip_stack_create_listening_point(belle_sip_stack_t *s, const char *ipaddress, int port, const char *transport){
	belle_sip_listening_point_t *lp=NULL;
jehan's avatar
jehan committed
50
	if (strcasecmp(transport,"UDP")==0) {
51
		lp=belle_sip_udp_listening_point_new(s,ipaddress,port);
jehan's avatar
jehan committed
52 53
	} else if (strcasecmp(transport,"TCP") == 0) {
		lp=belle_sip_stream_listening_point_new(s,ipaddress,port);
54 55
	}else if (strcasecmp(transport,"TLS") == 0) {
		lp=belle_sip_tls_listening_point_new(s,ipaddress,port);
jehan's avatar
jehan committed
56
	} else {
57 58 59 60 61
		belle_sip_fatal("Unsupported transport %s",transport);
	}
	return lp;
}

62 63 64 65
void belle_sip_stack_delete_listening_point(belle_sip_stack_t *s, belle_sip_listening_point_t *lp){
	belle_sip_object_unref(lp);
}

66
belle_sip_provider_t *belle_sip_stack_create_provider(belle_sip_stack_t *s, belle_sip_listening_point_t *lp){
67 68 69 70 71 72
	belle_sip_provider_t *p=belle_sip_provider_new(s,lp);
	return p;
}

void belle_sip_stack_delete_provider(belle_sip_stack_t *s, belle_sip_provider_t *p){
	belle_sip_object_unref(p);
73 74
}

75 76 77 78
belle_sip_main_loop_t * belle_sip_stack_get_main_loop(belle_sip_stack_t *stack){
	return stack->ml;
}

79 80 81 82 83 84 85
void belle_sip_stack_main(belle_sip_stack_t *stack){
	belle_sip_main_loop_run(stack->ml);
}

void belle_sip_stack_sleep(belle_sip_stack_t *stack, unsigned int milliseconds){
	belle_sip_main_loop_sleep (stack->ml,milliseconds);
}
86

87
belle_sip_hop_t * belle_sip_stack_create_next_hop(belle_sip_stack_t *stack, belle_sip_request_t *req) {
88 89 90 91 92 93 94
	belle_sip_header_route_t *route=BELLE_SIP_HEADER_ROUTE(belle_sip_message_get_header(BELLE_SIP_MESSAGE(req),"route"));
	belle_sip_uri_t *uri;
	if (route!=NULL){
		uri=belle_sip_header_address_get_uri(BELLE_SIP_HEADER_ADDRESS(route));
	}else{
		uri=belle_sip_request_get_uri(req);
	}
95 96 97 98 99 100 101 102 103 104
	return belle_sip_hop_create(	belle_sip_uri_get_transport_param(uri)
								,belle_sip_uri_get_host(uri)
								,belle_sip_uri_get_listening_port(uri));
}
belle_sip_hop_t* belle_sip_hop_create(const char* transport, const char* host,int port) {
	belle_sip_hop_t* hop = belle_sip_new0(belle_sip_hop_t);
	if (transport) hop->transport=belle_sip_strdup(transport);
	if (host) hop->host=belle_sip_strdup(host);
	hop->port=port;
	return hop;
105
}
106 107 108 109 110 111 112 113 114 115
void belle_sip_hop_free(belle_sip_hop_t *hop){
	if (hop->host) {
		belle_sip_free(hop->host);
		hop->host=NULL;
	}
	if (hop->transport){
		belle_sip_free(hop->transport);
		hop->transport=NULL;
	}
}
116

Simon Morlat's avatar
Simon Morlat committed
117 118 119
void belle_sip_stack_set_tx_delay(belle_sip_stack_t *stack, int delay_ms){
	stack->tx_delay=delay_ms;
}
120 121 122
void belle_sip_stack_set_send_error(belle_sip_stack_t *stack, int send_error){
	stack->send_error=send_error;
}
Simon Morlat's avatar
Simon Morlat committed
123

jehan's avatar
jehan committed
124 125 126
const char* belle_sip_version_to_string() {
	return PACKAGE_VERSION;
}