亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? vmysql.c

?? 相當優秀的 UNIX 進程管理工具
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* * $Id: vmysql.c,v 1.15.2.2 2004/06/26 02:20:56 tomcollins Exp $ * Copyright (C) 1999-2003 Inter7 Internet Technologies, Inc. * * 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 2 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, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA */ /* TODOAdd error result for "unable to read vpopmail.mysql" and return it*/  #include <pwd.h>#include <unistd.h>#include <stdio.h>#include <stdlib.h>#include <sys/types.h>#include <string.h>#include <time.h>#include <mysql.h>#include "config.h"#include "vpopmail.h"#include "vauth.h"#include "vlimits.h"#include "vmysql.h"static MYSQL mysql_update;static MYSQL mysql_read_getall;#ifdef MYSQL_REPLICATIONstatic MYSQL mysql_read;#else#define mysql_read mysql_update#endifstatic int update_open = 0;static int read_getall_open = 0;#ifdef MYSQL_REPLICATIONstatic int read_open = 0;#else#define read_open update_open#endifstatic MYSQL_RES *res_update = NULL;static MYSQL_RES *res_read_getall = NULL;#ifdef MYSQL_REPLICATIONstatic MYSQL_RES *res_read = NULL;#else#define res_read res_update#endifstatic MYSQL_ROW row;static MYSQL_ROW row_getall;#define SQL_BUF_SIZE 2048static char SqlBufRead[SQL_BUF_SIZE];static char SqlBufUpdate[SQL_BUF_SIZE];#define SMALL_BUFF 200char IUser[SMALL_BUFF];char IPass[SMALL_BUFF];char IGecos[SMALL_BUFF];char IDir[SMALL_BUFF];char IShell[SMALL_BUFF];char IClearPass[SMALL_BUFF];void vcreate_dir_control(char *domain);void vcreate_vlog_table();#ifdef POP_AUTH_OPEN_RELAYvoid vcreate_relay_table();#endif#ifdef VALIASvoid vcreate_valias_table();#endif#ifdef ENABLE_AUTH_LOGGINGvoid vcreate_lastauth_table();#endif/*  * get mysql connection info */int load_connection_info() {    FILE *fp;    char conn_info[256];    char config[256];    int eof;    static int loaded = 0;    char *port;    char delimiters[] = "|\n";    char *conf_read, *conf_update;    if (loaded) return 0;    loaded = 1;    sprintf(config, "%s/etc/%s", VPOPMAILDIR, "vpopmail.mysql");    fp = fopen(config, "r");    if (fp == NULL) {        fprintf(stderr, "vmysql: can't read settings from %s\n", config);        return(VA_NO_AUTH_CONNECTION);    }        /* skip comments and blank lines */    do {        eof = (fgets (conn_info, sizeof(conn_info), fp) == NULL);    } while (!eof && ((*conn_info == '#') || (*conn_info == '\n')));    if (eof) {        /* no valid data read, return error */        fprintf(stderr, "vmysql: no valid settings in %s\n", config);        return(VA_NO_AUTH_CONNECTION);    }    conf_read = strdup(conn_info);    MYSQL_READ_SERVER = strtok(conf_read, delimiters);    if (MYSQL_READ_SERVER == NULL) return VA_PARSE_ERROR;    port = strtok(NULL, delimiters);    if (port == NULL) return VA_PARSE_ERROR;    MYSQL_READ_PORT = atoi(port);    MYSQL_READ_USER = strtok(NULL, delimiters);    if (MYSQL_READ_USER == NULL) return VA_PARSE_ERROR;    MYSQL_READ_PASSWD = strtok(NULL, delimiters);    if (MYSQL_READ_PASSWD == NULL) return VA_PARSE_ERROR;    MYSQL_READ_DATABASE = strtok(NULL, delimiters);    if (MYSQL_READ_DATABASE == NULL) return VA_PARSE_ERROR;        /* skip comments and blank lines */    do {        eof = (fgets (conn_info, sizeof(conn_info), fp) == NULL);    } while (!eof && ((*conn_info == '#') || (*conn_info == '\n')));        if (eof) {        /* re-use read-only settings for update */        MYSQL_UPDATE_SERVER = MYSQL_READ_SERVER;        MYSQL_UPDATE_PORT = MYSQL_READ_PORT;        MYSQL_UPDATE_USER = MYSQL_READ_USER;        MYSQL_UPDATE_PASSWD = MYSQL_READ_PASSWD;        MYSQL_UPDATE_DATABASE = MYSQL_READ_DATABASE;    } else {        conf_update = strdup(conn_info);        MYSQL_UPDATE_SERVER = strtok(conf_update, delimiters);        if (MYSQL_UPDATE_SERVER == NULL) return VA_PARSE_ERROR;        port = strtok(NULL, delimiters);        if (port == NULL) return VA_PARSE_ERROR;        MYSQL_UPDATE_PORT = atoi(port);        MYSQL_UPDATE_USER = strtok(NULL, delimiters);        if (MYSQL_UPDATE_USER == NULL) return VA_PARSE_ERROR;        MYSQL_UPDATE_PASSWD = strtok(NULL, delimiters);        if (MYSQL_UPDATE_PASSWD == NULL) return VA_PARSE_ERROR;        MYSQL_UPDATE_DATABASE = strtok(NULL, delimiters);        if (MYSQL_UPDATE_DATABASE == NULL) return VA_PARSE_ERROR;    }/* useful debugging info    fprintf(stderr, "read settings: server:%s port:%d user:%s pw:%s db:%s\n",        MYSQL_READ_SERVER, MYSQL_READ_PORT, MYSQL_READ_USER,        MYSQL_READ_PASSWD, MYSQL_READ_DATABASE);    fprintf(stderr, "update settings: server:%s port:%d user:%s pw:%s db:%s\n",        MYSQL_UPDATE_SERVER, MYSQL_UPDATE_PORT, MYSQL_UPDATE_USER,	MYSQL_UPDATE_PASSWD, MYSQL_UPDATE_DATABASE);    */    return 0;}/*  * Open a connection to mysql for updates */int vauth_open_update(){    unsigned int timeout = 2;    if ( update_open != 0 ) return(0);    update_open = 1;    verrori = load_connection_info();    if (verrori) return -1;	    mysql_init(&mysql_update);    mysql_options(&mysql_update, MYSQL_OPT_CONNECT_TIMEOUT, (char *)&timeout);    /* Try to connect to the mysql update server */    if (!(mysql_real_connect(&mysql_update, MYSQL_UPDATE_SERVER,			     MYSQL_UPDATE_USER, MYSQL_UPDATE_PASSWD, NULL, MYSQL_UPDATE_PORT,			     NULL, 0))) {            /* if we can not connect, report a error and return */      verrori = VA_NO_AUTH_CONNECTION;      return(VA_NO_AUTH_CONNECTION);    }    /* set the database we use */    if (mysql_select_db(&mysql_update, MYSQL_UPDATE_DATABASE)) {      /* we were able to connect, so create the database */       snprintf( SqlBufUpdate, SQL_BUF_SIZE, 		"create database %s", MYSQL_UPDATE_DATABASE );      if (mysql_query(&mysql_update,SqlBufUpdate)) {		/* we could not create the database	 * so report the error and return 	 */	fprintf(stderr, "vmysql: couldn't create database '%s': %s\n", MYSQL_UPDATE_DATABASE,	  mysql_error(&mysql_update));	return(-1);      }       /* set the database (we just created)*/       if (mysql_select_db(&mysql_update, MYSQL_UPDATE_DATABASE)) {	fprintf(stderr, "could not enter (just created) %s database\n", MYSQL_UPDATE_DATABASE);	return(-1);      }        }    return(0);}#ifdef MYSQL_REPLICATION/* * Open a connection to the database for read-only queries */int vauth_open_read(){    /* if we are already connected, just return */    if ( read_open != 0 ) return(0);    read_open = 1;        /* connect to mysql and set the database */    verrori = load_connection_info();    if (verrori) return -1;    mysql_init(&mysql_read);    if (!(mysql_real_connect(&mysql_read, MYSQL_READ_SERVER,             MYSQL_READ_USER, MYSQL_READ_PASSWD, MYSQL_READ_DATABASE,             MYSQL_READ_PORT, NULL, 0))) {        /* we could not connect, at least try the update server */        if (!(mysql_real_connect(&mysql_read, MYSQL_UPDATE_SERVER,             MYSQL_UPDATE_USER, MYSQL_UPDATE_PASSWD, MYSQL_UPDATE_DATABASE,            MYSQL_READ_PORT, NULL, 0))) {            verrori = VA_NO_AUTH_CONNECTION;            return( VA_NO_AUTH_CONNECTION );        }    }    /* return success */    return(0);}#else#define vauth_open_read vauth_open_update#endif/* * Open a connection to the database for read-only queries */int vauth_open_read_getall(){    /* if we are already connected, just return */    if ( read_getall_open != 0 ) return(0);    read_getall_open = 1;        /* connect to mysql and set the database */    verrori = load_connection_info();    if (verrori) return -1;    mysql_init(&mysql_read_getall);    if (!(mysql_real_connect(&mysql_read_getall, MYSQL_READ_SERVER,             MYSQL_READ_USER, MYSQL_READ_PASSWD, MYSQL_READ_DATABASE,             MYSQL_READ_PORT, NULL, 0))) {        /* we could not connect, at least try the update server */        if (!(mysql_real_connect(&mysql_read_getall, MYSQL_UPDATE_SERVER,             MYSQL_UPDATE_USER, MYSQL_UPDATE_PASSWD, MYSQL_UPDATE_DATABASE,             MYSQL_UPDATE_PORT, NULL, 0))) {            verrori = VA_NO_AUTH_CONNECTION;            return(-1);        }        return(-1);    }    /* return success */    return(0);}int vauth_create_table (char *table, char *layout, int showerror){  int err;  char SqlBufCreate[SQL_BUF_SIZE];  if ((err = vauth_open_update()) != 0) return (err);  snprintf (SqlBufCreate, SQL_BUF_SIZE, "CREATE TABLE %s ( %s )", table, layout);  if (mysql_query (&mysql_update, SqlBufCreate)) {    if (showerror)      fprintf (stderr, "vmysql: error creating table '%s': %s\n", table,         mysql_error(&mysql_update));    return -1;  } else {    return 0;  }} int vauth_adddomain( char *domain ){#ifndef MANY_DOMAINS  vset_default_domain( domain );  return (vauth_create_table (vauth_munch_domain( domain ), TABLE_LAYOUT, 1));#else  /* if creation fails, don't show an error */  vauth_create_table (MYSQL_DEFAULT_TABLE, TABLE_LAYOUT, 0);  return (0);#endif}int vauth_adduser(char *user, char *domain, char *pass, char *gecos,     char *dir, int apop ){ char *domstr; char dom_dir[156]; uid_t uid;  gid_t gid; char dirbuf[200]; char quota[30]; char Crypted[100]; int err;        if ( (err=vauth_open_update()) != 0 ) return(err);    vset_default_domain( domain );    strncpy( quota, "NOQUOTA", 30 );#ifndef MANY_DOMAINS    domstr = vauth_munch_domain( domain );#else    domstr = MYSQL_DEFAULT_TABLE;#endif    if ( domain == NULL || domain[0] == 0 ) {        domstr = MYSQL_LARGE_USERS_TABLE;    }    if ( strlen(domain) <= 0 ) {        if ( strlen(dir) > 0 ) {            snprintf(dirbuf, SQL_BUF_SIZE,                 "%s/users/%s/%s", VPOPMAILDIR, dir, user);        } else {            snprintf(dirbuf, SQL_BUF_SIZE, "%s/users/%s", VPOPMAILDIR, user);        }    } else {        vget_assign(domain, dom_dir, 156, &uid, &gid );        if ( strlen(dir) > 0 ) {            snprintf(dirbuf,SQL_BUF_SIZE, "%s/%s/%s", dom_dir, dir, user);        } else {            snprintf(dirbuf, SQL_BUF_SIZE, "%s/%s", dom_dir, user);        }    }    if ( pass[0] != 0 ) {        mkpasswd3(pass,Crypted, 100);    } else {        Crypted[0] = 0;    }    qnprintf( SqlBufUpdate, SQL_BUF_SIZE, INSERT,       domstr, user, #ifdef MANY_DOMAINS      domain,#endif      Crypted, apop, gecos, dirbuf, quota#ifdef CLEAR_PASS, pass#endif);    if (mysql_query(&mysql_update,SqlBufUpdate)) {        fprintf(stderr, "vmysql: sql error[2]: %s\n", mysql_error(&mysql_update));        return(-1);    }     return(0);}struct vqpasswd *vauth_getpw(char *user, char *domain){ char *domstr; static struct vqpasswd vpw; static char in_domain[156]; int err; uid_t myuid; uid_t uid; gid_t gid;    vget_assign(domain,NULL,0,&uid,&gid);    myuid = geteuid();    if ( myuid != 0 && myuid != uid ) return(NULL);    verrori = 0;    if ( (err=vauth_open_read()) != 0 ) {        verrori = err;        return(NULL);    }    lowerit(user);    lowerit(domain);    snprintf (in_domain, sizeof(in_domain), "%s", domain);    vset_default_domain( in_domain );#ifndef MANY_DOMAINS    domstr = vauth_munch_domain( in_domain );#else    domstr = MYSQL_DEFAULT_TABLE; #endif    if ( domstr == NULL || domstr[0] == 0 ) domstr = MYSQL_LARGE_USERS_TABLE;    qnprintf(SqlBufRead, SQL_BUF_SIZE, USER_SELECT, domstr, user#ifdef MANY_DOMAINS, in_domain#endif);    if (mysql_query(&mysql_read,SqlBufRead)) {        fprintf(stderr, "vmysql: sql error[3]: %s\n", mysql_error(&mysql_read));        return(NULL);    }    if (!(res_read = mysql_store_result(&mysql_read))) {        fprintf(stderr, "vmysql: store result failed 1\n");        return(NULL);    }        if ( mysql_num_rows(res_read) == 0 ) {        mysql_free_result(res_read);        return(NULL);    }    memset(IUser, 0, sizeof(IUser));    memset(IPass, 0, sizeof(IPass));    memset(IGecos, 0, sizeof(IGecos));    memset(IDir, 0, sizeof(IDir));    memset(IShell, 0, sizeof(IShell));    memset(IClearPass, 0, sizeof(IClearPass));    vpw.pw_name   = IUser;    vpw.pw_passwd = IPass;    vpw.pw_gecos  = IGecos;    vpw.pw_dir    = IDir;    vpw.pw_shell  = IShell;    vpw.pw_clear_passwd  = IClearPass;    if((row = mysql_fetch_row(res_read))) {        strncpy(vpw.pw_name,row[0],SMALL_BUFF);        if ( row[1] != 0 )  strncpy(vpw.pw_passwd,row[1],SMALL_BUFF);        if ( row[2] != 0 ) vpw.pw_uid    = atoi(row[2]);        if ( row[3] != 0 ) vpw.pw_gid    = atoi(row[3]);        if ( row[4] != 0 ) strncpy(vpw.pw_gecos,row[4],SMALL_BUFF);        if ( row[5] != 0 ) strncpy(vpw.pw_dir,row[5],SMALL_BUFF);        if ( row[6] != 0 ) strncpy(vpw.pw_shell, row[6],SMALL_BUFF);#ifdef CLEAR_PASS        if ( row[7] != 0 )  strncpy(vpw.pw_clear_passwd, row[7],SMALL_BUFF);#endif    } else {        mysql_free_result(res_read);        return(NULL);    }    mysql_free_result(res_read);    vlimits_setflags (&vpw, in_domain);    return(&vpw);}/* del a domain from the auth backend * - drop the domain's table, or del all users from users table * - delete domain's entries from lastauth table * - delete domain's limit's entries */int vauth_deldomain( char *domain ){ char *tmpstr; int err;        if ( (err=vauth_open_update()) != 0 ) return(err);    vset_default_domain( domain );#ifndef MANY_DOMAINS    /* convert the domain name to the table name (eg convert . to _ ) */    tmpstr = vauth_munch_domain( domain );    snprintf( SqlBufUpdate, SQL_BUF_SIZE, "drop table %s", tmpstr);#else    tmpstr = MYSQL_DEFAULT_TABLE;    qnprintf( SqlBufUpdate, SQL_BUF_SIZE, "delete from %s where pw_domain = '%s'",        tmpstr, domain );#endif     if (mysql_query(&mysql_update,SqlBufUpdate)) {        return(-1);    } 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲va欧美va人人爽午夜| 成人免费不卡视频| 成人午夜av影视| 欧美一区二区视频免费观看| 日本一区二区在线不卡| 亚洲va国产天堂va久久en| 成人在线综合网站| 精品国精品自拍自在线| 一区二区三区视频在线观看| 黄页网站大全一区二区| 在线观看区一区二| 中文字幕一区二区三区四区| 韩国毛片一区二区三区| 欧美午夜电影在线播放| 中文字幕视频一区| 国产精品亚洲综合一区在线观看| 欧美二区乱c少妇| 一片黄亚洲嫩模| 91网上在线视频| 国产精品久久久久一区二区三区 | 91蜜桃在线观看| ww久久中文字幕| 麻豆91小视频| 欧美一区二区三区免费视频 | 在线影院国内精品| 亚洲人成7777| 国产精一品亚洲二区在线视频| 91精品国产aⅴ一区二区| 亚洲精品欧美综合四区| 91天堂素人约啪| 欧美激情综合在线| 成人免费高清在线| 国产色一区二区| 国产成人综合在线观看| 欧美激情中文不卡| www..com久久爱| 亚洲欧美激情在线| 色先锋aa成人| 亚洲国产成人高清精品| 欧美日韩一级大片网址| 亚洲成a天堂v人片| 欧美一区二区在线免费观看| 日本三级韩国三级欧美三级| 欧美一区二区播放| 狠狠色狠狠色综合日日91app| 日韩一区二区三区在线| 看片的网站亚洲| 国产亚洲一区二区三区四区| 成人av网站在线观看免费| 中文字幕一区二区三区不卡| 91欧美一区二区| 日韩影视精彩在线| 精品国产污网站| 成人免费观看视频| 亚洲国产精品久久久久秋霞影院| 日韩一级高清毛片| 成人激情免费电影网址| 亚洲麻豆国产自偷在线| 欧美精品自拍偷拍动漫精品| 久久黄色级2电影| 国产精品久久久久aaaa| 欧美视频在线不卡| 久久99精品一区二区三区三区| 337p日本欧洲亚洲大胆色噜噜| 99久久99久久久精品齐齐| 亚洲午夜在线视频| 久久亚洲精品小早川怜子| 91在线观看高清| 美女诱惑一区二区| 成人免费在线视频观看| 欧美精品自拍偷拍| av毛片久久久久**hd| 视频在线观看国产精品| 国产欧美精品区一区二区三区 | 成人白浆超碰人人人人| 午夜影院久久久| 久久久国产精品麻豆| 在线精品视频免费播放| 国模冰冰炮一区二区| 亚洲国产日韩a在线播放性色| 久久综合九色综合欧美98| 91蜜桃在线观看| 精品午夜久久福利影院| 日本一区二区动态图| 91精品免费观看| 色综合久久综合网| 国产二区国产一区在线观看| 一区二区三区欧美久久| 国产日韩欧美一区二区三区乱码 | 亚洲免费电影在线| xvideos.蜜桃一区二区| 精品视频在线免费| hitomi一区二区三区精品| 国模大尺度一区二区三区| 亚洲电影视频在线| 亚洲国产精品传媒在线观看| 日韩精品一区二区在线观看| 精品视频在线视频| 91免费版pro下载短视频| 国产成人免费在线视频| 美女性感视频久久| 亚洲1区2区3区4区| 亚洲综合图片区| 一区二区三区不卡视频| 中文字幕在线一区| 国产欧美日韩综合| 国产欧美日韩视频一区二区| 精品粉嫩aⅴ一区二区三区四区| 欧美另类z0zxhd电影| 欧美四级电影网| 欧美日韩一区二区三区免费看| 成人app网站| 粉嫩一区二区三区性色av| 久久精品噜噜噜成人av农村| 午夜精品久久久久久久久久久 | 在线看不卡av| 91激情五月电影| 色天使色偷偷av一区二区| 成人一级片在线观看| 成人av动漫网站| caoporm超碰国产精品| 91一区二区三区在线观看| 99久久99久久精品免费看蜜桃| 成人午夜电影网站| 不卡一区二区中文字幕| 不卡视频一二三| 精品国产亚洲在线| 26uuuu精品一区二区| 国产日产欧美一区二区视频| 久久久精品黄色| 国产精品久久久久久久久免费桃花| 中文在线免费一区三区高中清不卡| 久久久久97国产精华液好用吗| 久久久久国色av免费看影院| 日本一区二区成人在线| 亚洲人成人一区二区在线观看| 亚洲欧洲制服丝袜| 五月天精品一区二区三区| 肉丝袜脚交视频一区二区| 日本 国产 欧美色综合| 韩国三级在线一区| 99久久精品国产网站| 欧美色倩网站大全免费| 精品免费视频.| 中文一区一区三区高中清不卡| 亚洲人成精品久久久久| 人妖欧美一区二区| 成人亚洲一区二区一| 在线亚洲精品福利网址导航| 日韩一区二区在线观看视频 | 色久优优欧美色久优优| 欧美电影影音先锋| 中国色在线观看另类| 午夜视频一区二区| 国产精品白丝jk黑袜喷水| 日本高清不卡aⅴ免费网站| 日韩一区二区三区视频在线 | 欧美日韩免费一区二区三区视频| 欧美久久一二区| 日本一区二区三区高清不卡| 一区二区三区欧美在线观看| 韩国理伦片一区二区三区在线播放 | 激情久久五月天| 在线免费视频一区二区| 精品国产污污免费网站入口| 亚洲精品高清在线| 国产精品综合二区| 欧美视频一区二区三区在线观看| 久久久美女艺术照精彩视频福利播放| 亚洲色图另类专区| 国产麻豆91精品| 在线91免费看| 一区二区三区四区在线免费观看 | 亚洲福利国产精品| 成人久久久精品乱码一区二区三区| 欧美日韩精品三区| 亚洲精品大片www| 粉嫩久久99精品久久久久久夜| 在线播放一区二区三区| 亚洲欧美在线视频观看| 国产成人免费在线| 精品国产电影一区二区| 亚洲v日本v欧美v久久精品| av中文字幕不卡| 亚洲国产精品激情在线观看| 美腿丝袜在线亚洲一区| 欧美裸体一区二区三区| 一区二区在线观看免费视频播放| 成人免费视频播放| 国产日韩欧美精品电影三级在线 | 成人av综合在线| 久久综合色综合88| 久久国产精品99久久人人澡| 91麻豆精品国产无毒不卡在线观看| 亚洲最大成人综合| 91国产丝袜在线播放| 一区二区三区中文在线观看| 色噜噜久久综合| 夜夜亚洲天天久久| 91国偷自产一区二区三区成为亚洲经典|