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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? vmysql.c

?? 相當(dāng)優(yōu)秀的 UNIX 進(jìn)程管理工具
?? 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);    } 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
7777精品伊人久久久大香线蕉的 | 黄色资源网久久资源365| 精油按摩中文字幕久久| 美腿丝袜亚洲色图| 国产高清不卡一区二区| 欧美中文字幕亚洲一区二区va在线| 日韩丝袜情趣美女图片| 国产精品久久久久影视| 五月天精品一区二区三区| 国产夫妻精品视频| 777xxx欧美| 综合久久久久久久| 精品一区二区三区免费毛片爱| 91美女片黄在线| 精品国产乱码久久久久久影片| 亚洲九九爱视频| 国产伦精品一区二区三区视频青涩| 亚洲精品菠萝久久久久久久| 国内精品在线播放| 日韩视频一区二区| 性做久久久久久久免费看| 91亚洲精品一区二区乱码| 国产精品你懂的| 国产91丝袜在线观看| 精品国产1区二区| 麻豆视频观看网址久久| 欧美精品1区2区3区| 亚洲最大成人综合| 色综合中文字幕国产| 中文字幕国产精品一区二区| 麻豆精品蜜桃视频网站| 日韩一区二区三区四区五区六区| 一区二区三区国产| 91福利视频网站| 亚洲同性同志一二三专区| www.爱久久.com| 国产精品网站在线观看| 成人一级视频在线观看| 国产日产欧美一区二区视频| 国产成人久久精品77777最新版本| 日韩欧美成人午夜| 久久99精品久久久久久| 欧美tk—视频vk| 国产原创一区二区| 国产婷婷色一区二区三区在线| 精品一区二区三区影院在线午夜| 在线不卡一区二区| 免费一级片91| 日韩欧美在线综合网| 久久精品国产一区二区三| 日韩三级精品电影久久久 | 中文字幕制服丝袜一区二区三区| 不卡的av在线播放| 99re热这里只有精品视频| 国产精品久久久久久久久晋中| 成人免费看片app下载| 国产精品视频在线看| 99精品国产视频| 亚洲自拍偷拍网站| 8x8x8国产精品| 久久国产麻豆精品| 国产精品欧美精品| 92国产精品观看| 亚洲成人精品影院| 91麻豆精品国产91久久久久 | 中文字幕一区二区三区不卡在线 | 久久99精品国产麻豆婷婷洗澡| 久久精品夜色噜噜亚洲a∨| 高清不卡在线观看av| 日本一区二区三区国色天香| 成人高清av在线| 亚洲黄网站在线观看| 欧美久久一区二区| 麻豆91精品视频| 久久精品亚洲麻豆av一区二区| 99精品欧美一区二区三区小说| 亚洲永久免费av| 日韩久久免费av| 国产精品99久久不卡二区| 综合久久久久久| 欧美一区二区视频网站| 国产成人免费xxxxxxxx| 亚洲自拍偷拍图区| 精品sm在线观看| 色综合久久天天综合网| 蜜桃一区二区三区四区| 国产精品免费视频一区| 欧美日韩1区2区| 国产91清纯白嫩初高中在线观看| 有坂深雪av一区二区精品| 日韩一级大片在线| 99国产精品国产精品毛片| 日韩高清电影一区| 中文字幕色av一区二区三区| 欧美喷潮久久久xxxxx| 国产aⅴ精品一区二区三区色成熟| 玉米视频成人免费看| 欧美精品一区二区不卡| 色一区在线观看| 国产在线乱码一区二区三区| 亚洲精品日日夜夜| 精品福利av导航| 色国产精品一区在线观看| 国内一区二区视频| 亚洲国产精品久久人人爱| 国产女人aaa级久久久级| 欧美日韩高清一区| 91免费国产视频网站| 九九**精品视频免费播放| 亚洲综合色视频| 亚洲国产精品av| 欧美一二三区在线| 在线亚洲高清视频| 成人黄色大片在线观看| 麻豆精品一区二区综合av| 亚洲影院在线观看| 国产精品麻豆99久久久久久| 日韩天堂在线观看| 欧美日韩视频在线一区二区| 99久久国产综合色|国产精品| 狠狠色狠狠色合久久伊人| 亚洲bt欧美bt精品777| 中文字幕一区二区三区色视频| 久久综合中文字幕| 91精品国产91热久久久做人人| 日本高清不卡aⅴ免费网站| 国产成人久久精品77777最新版本| 久久精品理论片| 琪琪一区二区三区| 亚洲成av人片| 一区二区在线观看免费视频播放| 欧美国产精品v| 精品处破学生在线二十三| 在线播放国产精品二区一二区四区| 91视频观看视频| 日本午夜精品一区二区三区电影| 日韩手机在线导航| 精品一区二区三区av| 久久久蜜桃精品| 91精品国产综合久久精品| 国产精品主播直播| 一区二区三区免费| 国产嫩草影院久久久久| 911精品国产一区二区在线| 欧美在线free| 日本乱人伦一区| 福利视频网站一区二区三区| 一区二区三区在线免费播放| 欧美日韩亚洲综合在线| 97久久久精品综合88久久| 成人99免费视频| 午夜视黄欧洲亚洲| 亚洲欧洲综合另类| 一区二区不卡在线播放| 亚洲视频香蕉人妖| 日韩精品一区二| 51精品久久久久久久蜜臀| av一本久道久久综合久久鬼色| 日本一区二区三区国色天香 | 亚洲精品少妇30p| 国产精品对白交换视频| 成人综合激情网| 亚洲青青青在线视频| 99精品欧美一区二区三区小说| 亚洲人成影院在线观看| 欧美三区免费完整视频在线观看| 亚洲国产精品一区二区久久 | 国产精品久久久久久久久免费樱桃| 91久久精品一区二区三区| 成人美女视频在线观看18| 91精品国产综合久久精品麻豆| 欧洲一区二区三区免费视频| 国产高清无密码一区二区三区| 午夜精品123| 依依成人综合视频| 午夜免费久久看| 亚洲日本在线观看| 国产欧美精品一区aⅴ影院| 欧美日韩一区二区三区高清| 国产一区欧美二区| 日本一道高清亚洲日美韩| 亚洲美女偷拍久久| 国产清纯白嫩初高生在线观看91 | 日韩欧美一级二级三级| 欧美性猛片xxxx免费看久爱| 欧美三级一区二区| 欧美一区二区在线免费观看| 中文字幕乱码久久午夜不卡| 制服丝袜在线91| 欧洲在线/亚洲| 欧美日韩一级大片网址| 欧洲精品一区二区三区在线观看| va亚洲va日韩不卡在线观看| 首页欧美精品中文字幕| 亚洲老妇xxxxxx| 亚洲精品亚洲人成人网在线播放| 中文字幕免费不卡| 国产精品久久久久久久浪潮网站| 久久婷婷综合激情| 久久先锋影音av鲁色资源网|