utils.h 4.77 KB
Newer Older
Simon Morlat's avatar
Simon Morlat committed
1 2 3 4 5 6
/*
	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
7
    the Free Software Foundation, either version 2 of the License, or
Simon Morlat's avatar
Simon Morlat committed
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
    (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/>.
*/

#ifndef BELLE_SIP_UTILS_H
#define BELLE_SIP_UTILS_H

#include <stdarg.h>
#include <stdio.h>
Simon Morlat's avatar
Simon Morlat committed
24
#include <stdlib.h>
25
#include <errno.h>
26
#include "belle-sip/defs.h"
Simon Morlat's avatar
Simon Morlat committed
27

28 29 30 31 32 33 34 35 36 37 38
#ifdef BCTBX_LOG_DOMAIN
#undef BCTBX_LOG_DOMAIN
#endif
#ifndef BELLE_SIP_LOG_DOMAIN
#define BELLE_SIP_LOG_DOMAIN "belle-sip"
#endif

#define BCTBX_LOG_DOMAIN BELLE_SIP_LOG_DOMAIN


#include "bctoolbox/logging.h"
Simon Morlat's avatar
Simon Morlat committed
39 40 41

BELLE_SIP_BEGIN_DECLS

42 43 44 45 46
#define belle_sip_malloc bctbx_malloc
#define belle_sip_malloc0 bctbx_malloc0
#define belle_sip_realloc bctbx_realloc
#define belle_sip_free bctbx_free
#define belle_sip_strdup bctbx_strdup
Simon Morlat's avatar
Simon Morlat committed
47 48

BELLE_SIP_END_DECLS
49

Simon Morlat's avatar
Simon Morlat committed
50 51 52 53
/***************/
/* logging api */
/***************/

54 55 56 57 58 59 60
#define BELLE_SIP_LOG_FATAL BCTBX_LOG_FATAL
#define	BELLE_SIP_LOG_ERROR BCTBX_LOG_ERROR
#define	BELLE_SIP_LOG_WARNING BCTBX_LOG_WARNING
#define	BELLE_SIP_LOG_MESSAGE BCTBX_LOG_MESSAGE
#define	BELLE_SIP_LOG_DEBUG	BCTBX_LOG_DEBUG
#define	BELLE_SIP_LOG_END BCTBX_LOG_END
#define  belle_sip_log_level BctbxLogLevel
Simon Morlat's avatar
Simon Morlat committed
61

62
#define belle_sip_log_function_t BctoolboxLogFunc
Simon Morlat's avatar
Simon Morlat committed
63

64

Ghislain MARY's avatar
Ghislain MARY committed
65 66 67 68 69 70 71
typedef enum {
	BELLE_SIP_NOT_IMPLEMENTED = -2,
	BELLE_SIP_BUFFER_OVERFLOW = -1,
	BELLE_SIP_OK = 0
} belle_sip_error_code;


72 73 74 75 76 77
#ifdef __GNUC__
#define BELLE_SIP_CHECK_FORMAT_ARGS(m,n) __attribute__((format(printf,m,n)))
#else
#define BELLE_SIP_CHECK_FORMAT_ARGS(m,n)
#endif

Simon Morlat's avatar
Simon Morlat committed
78 79
BELLE_SIP_BEGIN_DECLS

80
#define belle_sip_log_level_enabled(level) bctbx_log_level_enabled(BELLE_SIP_LOG_DOMAIN,level)
81 82

#ifdef BELLE_SIP_DEBUG_MODE
83
#define belle_sip_deb(...) bctbx_debug(...)
84 85 86 87 88 89 90 91 92 93 94 95 96 97
#else

#define belle_sip_debug(...)

#endif

#ifdef BELLE_SIP_NOMESSAGE_MODE

#define belle_sip_log(...)
#define belle_sip_message(...)
#define belle_sip_warning(...)

#else

98 99 100 101 102 103
#define belle_sip_log bctbx_log
#define belle_sip_message bctbx_message
#define belle_sip_warning bctbx_warning
#define belle_sip_error bctbx_error
#define belle_sip_fatal bctbx_fatal
#define belle_sip_logv bctbx_logv
104 105 106
#endif


107 108 109
#define belle_sip_set_log_file bctbx_set_log_file
#define belle_sip_set_log_handler bctbx_set_log_handler
#define belle_sip_get_log_handler bctbx_get_log_handler
Simon Morlat's avatar
Simon Morlat committed
110

111 112 113
#define belle_sip_strdup_printf bctbx_strdup_printf
#define belle_sip_strcat_vprintf bctbx_strcat_vprintf
#define belle_sip_strcat_printf bctbx_strcat_printf
Simon Morlat's avatar
Simon Morlat committed
114

115
BELLESIP_EXPORT belle_sip_error_code BELLE_SIP_CHECK_FORMAT_ARGS(4,5) belle_sip_snprintf(char *buff, size_t buff_size, size_t *offset, const char *fmt, ...);
116
BELLESIP_EXPORT belle_sip_error_code belle_sip_snprintf_valist(char *buff, size_t buff_size, size_t *offset, const char *fmt, va_list args);
Ghislain MARY's avatar
Ghislain MARY committed
117

118
#define belle_sip_set_log_level(level) bctbx_set_log_level(BELLE_SIP_LOG_DOMAIN,level);
Simon Morlat's avatar
Simon Morlat committed
119

Sylvain Berfini's avatar
Sylvain Berfini committed
120
BELLESIP_EXPORT char * belle_sip_random_token(char *ret, size_t size);
121

Ghislain MARY's avatar
Ghislain MARY committed
122
BELLESIP_EXPORT unsigned char * belle_sip_random_bytes(unsigned char *ret, size_t size);
123

Ghislain MARY's avatar
Ghislain MARY committed
124
BELLESIP_EXPORT char * belle_sip_octets_to_text(const unsigned char *hash, size_t hash_len, char *ret, size_t size);
125

Ghislain MARY's avatar
Ghislain MARY committed
126
BELLESIP_EXPORT char * belle_sip_create_tag(char *ret, size_t size);
127

128
BELLESIP_EXPORT const char* belle_sip_version_to_string(void);
129

130 131 132 133 134
/**
 * Returns string without surrounding quotes if any, else just call belle_sip_strdup().
**/
BELLESIP_EXPORT char *belle_sip_unquote_strdup(const char *str);

Simon Morlat's avatar
Simon Morlat committed
135 136 137 138
BELLESIP_EXPORT uint64_t belle_sip_time_ms(void);

BELLESIP_EXPORT unsigned int belle_sip_random(void);

139
#if defined(_WIN32)
140 141

#include <winsock2.h>
142
#include <ws2tcpip.h>
143 144

typedef SOCKET belle_sip_socket_t;
145
typedef HANDLE belle_sip_fd_t;
146
#else
147 148 149 150 151

#include <sys/types.h>
#include <sys/socket.h>
#include <netdb.h>

152
typedef int belle_sip_socket_t;
153
typedef int belle_sip_fd_t;
154

155 156
#endif

157 158

typedef void (*belle_sip_background_task_end_callback_t)(void *);
jehan's avatar
jehan committed
159 160 161
BELLESIP_EXPORT unsigned long belle_sip_begin_background_task(const char *name, belle_sip_background_task_end_callback_t cb, void *data);
BELLESIP_EXPORT void belle_sip_end_background_task(unsigned long id);

162 163 164 165 166 167 168
/**
 * create a directory if it doesn't already exists
 *
 * @param[in]   path        The directory to be created
 * @return 0 in case of succes, -1 otherwise, note it returns -1 if the directory already exists
 */
BELLESIP_EXPORT int belle_sip_mkdir(const char *path);
169

Simon Morlat's avatar
Simon Morlat committed
170 171 172 173
BELLE_SIP_END_DECLS

#endif