http://osdir.com/ml/network.pureftpd.user/2005-11/msg00066.html



Mysql-auth per user connection limit feature: msg#00066
network.pureftpd.user

Subject:  Mysql-auth per user connection limit feature

I needed this feature, but haven't found any solution, so i implemented it,
and i saw, that some other people needs it too, so made a patch.
Here it is:
http://dblaci.hu/pure-ftpd/pure-ftpd-1.0.20-mysqlperusermax.patch

I added a comment to the feature request 993994 too.

DBLaci

p.s. i don't know if this mail is going to the right place, if not, sorry.

---------------------------------------------------------------------
To post a new message, e-mail: list@xxxxxxxxxxxx
To unsubscribe, e-mail: list-unsubscribe@xxxxxxxxxxxx
For additional commands, e-mail: list-help@xxxxxxxxxxxx



 

diff -ur pure-ftpd-1.0.20.old/pureftpd-mysql.conf pure-ftpd-1.0.20/pureftpd-mysql.conf
--- pure-ftpd-1.0.20.old/pureftpd-mysql.conf 2003-01-21 21:09:44.000000000 +0100
+++ pure-ftpd-1.0.20/pureftpd-mysql.conf 2005-11-18 12:27:34.000000000 +0100
@@ -106,6 +106,12 @@
 # MySQLGetRatioUL SELECT ULRatio FROM users WHERE User="L"
 # MySQLGetRatioDL SELECT DLRatio FROM users WHERE User="L"
 
+# Optional : concurrent session limit per user.
+# The server has to be compiled with per-user-limits support.
+# Value 0 means unlimited. (default)
+
+#MySQLGetPerUserMax SELECT PerUserMax FROM users WHERE User="L"
+
 
 # Optional : bandwidth throttling.
 # The server has to be compiled with throttling support.
diff -ur pure-ftpd-1.0.20.old/src/log_mysql.c pure-ftpd-1.0.20/src/log_mysql.c
--- pure-ftpd-1.0.20.old/src/log_mysql.c 2004-05-15 23:14:06.000000000 +0200
+++ pure-ftpd-1.0.20/src/log_mysql.c 2005-11-18 11:48:58.000000000 +0100
@@ -300,6 +300,9 @@
     const char *bandwidth_ul = NULL;   /* stored bandwidth UL */
     const char *bandwidth_dl = NULL;   /* stored bandwidth DL */
 #endif
+#ifdef PER_USER_LIMITS
+    const char *perusermax = NULL;     /* stored per user concurrent sessions */
+#endif
     char *escaped_account = NULL;
     char *escaped_ip = NULL;
     char *escaped_port = NULL;
@@ -543,6 +546,18 @@
         }
     }
 #endif
+#ifdef PER_USER_LIMITS
+    if ((perusermax = pw_mysql_getquery(id_sql_server, sqlreq_getperusermax,
+                                          escaped_account, escaped_ip,
+                                          escaped_port, escaped_peer_ip,
+                                          escaped_decimal_ip)) != NULL) {
+        const unsigned long q = (unsigned long) strtoul(perusermax, NULL, 10);
+       
+        if (q > 0UL) {
+            result->per_user_max = q;
+        }
+    }
+#endif
     result->slow_tilde_expansion = !tildexp;
     result->auth_ok =- result->auth_ok;
     bye:
@@ -572,6 +587,9 @@
     free((void *) bandwidth_ul);
     free((void *) bandwidth_dl);
 #endif   
+#ifdef PER_USER_LIMITS
+    free((void *) perusermax);
+#endif   
     free((void *) escaped_account);
     free((void *) escaped_ip);
     free((void *) escaped_port);
diff -ur pure-ftpd-1.0.20.old/src/log_mysql_p.h pure-ftpd-1.0.20/src/log_mysql_p.h
--- pure-ftpd-1.0.20.old/src/log_mysql_p.h 2004-02-29 22:49:28.000000000 +0100
+++ pure-ftpd-1.0.20/src/log_mysql_p.h 2005-11-18 11:21:18.000000000 +0100
@@ -38,6 +38,9 @@
 static char *sqlreq_getbandwidth_ul;
 static char *sqlreq_getbandwidth_dl;
 #endif
+#ifdef PER_USER_LIMITS
+static char *sqlreq_getperusermax;
+#endif
 static signed char server_down;
 
 static ConfigKeywords mysql_config_keywords[] = {
@@ -68,6 +71,9 @@
     { "MYSQLGetBandwidthUL", &sqlreq_getbandwidth_ul },
     { "MYSQLGetBandwidthDL", &sqlreq_getbandwidth_dl },
 #endif
+#ifdef PER_USER_LIMITS
+    { "MYSQLGetPerUserMax", &sqlreq_getperusermax },
+#endif
     { NULL, NULL }
 };


 

번호 제목 글쓴이 날짜 조회 수
57 rar [823] Shadow 2009.04.29 145304
56 wget [364] Shadow 2009.04.29 81285
55 rox-filer [555] file Shadow 2009.04.14 51463
54 enblend-enfuse-3.2 on MacOSX [216] file Shadow 2009.03.19 52077
» [펌] PureFtpd - Mysql-auth per user connection limit feature [6633] Shadow 2009.02.25 136873
52 맥이 아닌 machine에서 맥에 SSH 접속시 한글 표시법 [9665] Shadow 2009.02.10 231110
51 제로보드XE 소스코드 수정 부분 [8688] secret Shadow 2009.01.15 0
50 MacOSX System Configurations - MyConf! Shadow 2009.01.04 35925
49 remote X11forwarding from OSX to Windows [6277] Shadow 2009.01.03 151122
48 MacOSX에 ufraw를 설치하자~ [1] [886] file Shadow 2009.01.03 635902
47 XQuartz [5570] Shadow 2009.01.03 127841
46 [펌] CFGetHostUUIDString: unable to determine UUID for host. Error: 35 [5772] Shadow 2009.01.03 121219
45 com.apple.boot.plist & bootloader [6505] Shadow 2009.01.03 121375
44 samba over ssh [9704] secret Shadow 2008.12.30 0
43 lukemftpd 질문에 대한 내 답변 [1] Shadow 2008.12.24 30235
42 Mplayer & Mencoder - Compilation in MacOSX file sukhyun 2008.11.27 25722
41 Media Transcoding (Encoding) : mencoder & codecs [1] sukhyun 2008.11.26 26328
40 [작성중] 홈서버 구성 가이드 - 5. FTP를 이용한 파일서버 - LukemFTPd / PureFTPd [1] file sukhyun 2008.11.19 24799
39 [작성중] 홈서버 구성 가이드 - 2. 네트워크 구성과 공유기 설정 file sukhyun 2008.11.15 31260
38 [작성중] 홈 서버 구성 가이드 - 1. 홈서버 시스템의 선택 [4] sukhyun 2008.11.14 29198

사용자 로그인