⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 db_utils.c

📁 用来作为linux中SIP SERVER,完成VOIP网络电话中服务器的功能
💻 C
字号:
/* * $Id: db_utils.c,v 1.3 2004/12/06 13:02:10 sobomax Exp $ * * 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 <string.h>#include <time.h>#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;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -