/*
* $Id: db_utils.c 1210 2006-10-31 21:16:05Z bogdan_iancu $
*
* POSTGRES module, portions of this code were templated using
* the mysql module, thus it's similarity.
*
* Copyright (C) 2003 August.Net Services, LLC
*
* This file is part of openser, a free SIP server.
*
* openser 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 2 of the License, or
* (at your option) any later version
*
* openser 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, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* ---
*
* History
* -------
* 2003-04-06 initial code written (Greg Fausak/Andy Fullford)
*
*/
#define _GNU_SOURCE /* To avoid strptime warning */
#define _XOPEN_SOURCE 4 /* bsd */
#define _XOPEN_SOURCE_EXTENDED 1 /* solaris */
#include <strings.h>
#include <string.h>
#include <time.h>
#include "db_utils.h"
#include "defs.h"
/*
* Convert time_t structure to format accepted by PostgreSQL database
*/
int time2postgresql(time_t _time, char* _result, int _res_len)
{
struct tm* t;
/*
if (_time == MAX_TIME_T) {
snprintf(_result, _res_len, "0000-00-00 00:00:00");
}
*/
t = localtime(&_time);
return strftime(_result, _res_len, "%Y-%m-%d %H:%M:%S", t);
}
/*
* Convert PostgreSQL time representation to time_t structure
*/
time_t postgresql2time(const char* _str)
{
struct tm time;
/* It is necessary to zero tm structure first */
memset(&time, '\0', sizeof(struct tm));
strptime(_str, "%Y-%m-%d %H:%M:%S", &time);
/* Daylight saving information got lost in the database
* so let mktime to guess it. This eliminates the bug when
* contacts reloaded from the database have different time
* of expiration by one hour when daylight saving is used
*/
time.tm_isdst = -1;
return mktime(&time);
}
char* trim(char* _s);
/*
* SQL URL parser
*/
int parse_sql_url(char* _url, char** _user, char** _pass,
char** _host, char** _port, char** _db)
{
char* slash, *dcolon, *at, *db_slash;
*_user = '\0';
*_pass = '\0';
*_host = '\0';
*_port = '\0';
*_db = '\0';
/* Remove any leading and trailing spaces and tab */
_url = trim(_url);
if (strlen(_url) < 6) return -1;
if (*_url == '\0') return -2; /* Empty string */
slash = strchr(_url, '/');
if (!slash) return -3; /* Invalid string, slashes not found */
if ((*(++slash)) != '/') { /* Invalid URL, 2nd slash not found */
return -4;
}
slash++;
at = strchr(slash, '@');
db_slash = strrchr(slash, '/');
if (db_slash <= at)
db_slash = NULL;
if (db_slash) {
*db_slash++ = '\0';
*_db = trim(db_slash);
}
if (!at) {
dcolon = strchr(slash, ':');
if (dcolon) {
*dcolon++ = '\0';
*_port = trim(dcolon);
}
*_host = trim(slash);
} else {
dcolon = strchr(slash, ':');
*at++ = '\0';
if (dcolon) {
*dcolon++ = '\0';
if (dcolon < at) { /* user:passwd */
*_pass = trim(dcolon);
dcolon = strchr(at, ':');
if (dcolon) { /* host:port */
*dcolon++ = '\0';
*_port = trim(dcolon);
}
} else { /* host:port */
*_port = trim(dcolon);
}
}
*_host = trim(at);
*_user = trim(slash);
}
return 0;
}
/*
* Remove any tabs and spaces from the beginning and the end of
* a string
*/
char* trim(char* _s)
{
int len;
char* end;
/* Null pointer, there is nothing to do */
if (!_s) return _s;
/* Remove spaces and tabs from the beginning of string */
while ((*_s == ' ') || (*_s == '\t')) _s++;
len = strlen(_s);
end = _s + len - 1;
/* Remove trailing spaces and tabs */
while ((*end == ' ') || (*end == '\t')) end--;
if (end != (_s + len - 1)) {
*(end+1) = '\0';
}
return _s;
}
syntax highlighted by Code2HTML, v. 0.9.1