/* * $Id$ * * 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 ser, a free SIP server. * * ser 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 * * For a license to use the ser software under conditions * other than those described here, or to purchase support for this * software, please contact iptel.org by e-mail at the following addresses: * info@iptel.org * * ser 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 */ #include #include #include "db_utils.h" #include "defs.h" 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; }