Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 24 Apr 2009 21:58:02 GMT
From:      Morton Jonuschat <mjonuschat@gmail.com>
To:        freebsd-gnats-submit@FreeBSD.org
Subject:   ports/133982: New port: www/mod_auth_mysql_debian Apache 2 module for MySQL authentication
Message-ID:  <200904242158.n3OLw2C7055066@www.freebsd.org>
Resent-Message-ID: <200904242200.n3OM0E4H033894@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

>Number:         133982
>Category:       ports
>Synopsis:       New port: www/mod_auth_mysql_debian Apache 2 module for MySQL authentication
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-ports-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          update
>Submitter-Id:   current-users
>Arrival-Date:   Fri Apr 24 22:00:14 UTC 2009
>Closed-Date:
>Last-Modified:
>Originator:     Morton Jonuschat
>Release:        7.2-RC1
>Organization:
>Environment:
FreeBSD localhost 7.2-RC1 FreeBSD 7.2-RC1 #0: Sat Apr 18 09:06:35 CEST 2009     root@localhost:/usr/obj/usr/src/sys/GENERIC  i386
>Description:
New port for the Debian provided version of an Apache2 MySQL authentication module

A module for the Apache 2 web server which enables HTTP authentication against information stored in a MySQL database.

WWW: http://packages.debian.org/en/lenny/libapache2-mod-auth-mysql


>How-To-Repeat:

>Fix:


Patch attached with submission follows:

# This is a shell archive.  Save it in a file, remove anything before
# this line, and then unpack it by entering "sh file".  Note, it may
# create directories; files and directories will be owned by you and
# have default permissions.
#
# This archive contains:
#
#	mod_auth_mysql_debian
#	mod_auth_mysql_debian/files
#	mod_auth_mysql_debian/files/patch-008-make-scrambled-password
#	mod_auth_mysql_debian/files/patch-013-CVE-2008-2384-charset
#	mod_auth_mysql_debian/files/patch-005-directives
#	mod_auth_mysql_debian/files/patch-009-port-int
#	mod_auth_mysql_debian/files/patch-011-auth_basic
#	mod_auth_mysql_debian/files/patch-014-libcrypt
#	mod_auth_mysql_debian/files/patch-007-unify-namespace
#	mod_auth_mysql_debian/files/patch-003-ftbfs_apache2
#	mod_auth_mysql_debian/files/patch-004-reconnect
#	mod_auth_mysql_debian/files/Makefile
#	mod_auth_mysql_debian/files/patch-010-enctype-apache
#	mod_auth_mysql_debian/files/patch-006-options
#	mod_auth_mysql_debian/files/patch-012-charset
#	mod_auth_mysql_debian/files/patch-001-usage
#	mod_auth_mysql_debian/Makefile
#	mod_auth_mysql_debian/pkg-descr
#	mod_auth_mysql_debian/distinfo
#
echo c - mod_auth_mysql_debian
mkdir -p mod_auth_mysql_debian > /dev/null 2>&1
echo c - mod_auth_mysql_debian/files
mkdir -p mod_auth_mysql_debian/files > /dev/null 2>&1
echo x - mod_auth_mysql_debian/files/patch-008-make-scrambled-password
sed 's/^X//' >mod_auth_mysql_debian/files/patch-008-make-scrambled-password << 'f1e5c1f21c34d8a12c17860dfc3e0356'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 008-make_scrambled_password.dpatch by Joey Schulze <joey@debian.org>
X##
X## All lines beginning with `## DP:' are a description of the patch.
X## DP: Adjust the buffer size used by make_scrambled_password()
X
X@DPATCH@
Xdiff -urNad mod-auth-mysql~/mod_auth_mysql.c mod-auth-mysql/mod_auth_mysql.c
X--- mod_auth_mysql.c	2008-05-14 18:46:21.000000000 +0200
X+++ mod_auth_mysql.c	2008-05-14 22:15:44.000000000 +0200
X@@ -103,6 +103,9 @@
X #endif
X #define SHA1SUM_ENCRYPTION_FLAG		1<<6
X 
X+/* from include/sha1.h from the mysql-server source distribution */
X+#define SHA1_HASH_SIZE 20 /* Hash size in bytes */
X+
X static int check_no_encryption(const char *passwd, char *enc_passwd)
X {
X 	return (!strcmp(passwd, enc_passwd));
X@@ -229,7 +232,7 @@
X 
X static int check_mysql_encryption(const char *passwd, char *enc_passwd)
X {
X-	char scrambled_passwd[32];
X+	char scrambled_passwd[2*SHA1_HASH_SIZE + 2];
X 	
X 	make_scrambled_password(scrambled_passwd, passwd);
X 	return (!strcmp(scrambled_passwd, enc_passwd));
f1e5c1f21c34d8a12c17860dfc3e0356
echo x - mod_auth_mysql_debian/files/patch-013-CVE-2008-2384-charset
sed 's/^X//' >mod_auth_mysql_debian/files/patch-013-CVE-2008-2384-charset << 'ac9987cb4f26c6f935cd8892ddfdd537'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 013-CVE-2008-2384_charset.dpatch by  <joey@localhost>
X##
X## All lines beginning with `## DP:' are a description of the patch.
X## DP: Fix CVE-2008-2384: Encode strings securely via mysql_real_escape_string()
X
X@DPATCH@
Xdiff -urNad mod-auth-mysql~/mod_auth_mysql.c mod-auth-mysql/mod_auth_mysql.c
X--- mod_auth_mysql.c	2009-01-07 21:47:20.000000000 +0100
X+++ mod_auth_mysql.c	2009-01-08 21:12:47.000000000 +0100
X@@ -340,6 +340,8 @@ typedef struct {
X 
X module auth_mysql_module;
X 
X+static int open_auth_dblink(request_rec *r, mysql_auth_config_rec *sec);
X+
X #ifdef APACHE2
X static apr_status_t
X #else
X@@ -506,9 +508,9 @@ static const char *set_scrambled_passwor
X  * server when passed in as part of a query.
X  */
X #ifdef APACHE2
X-static char *mysql_escape(char *str, apr_pool_t *p)
X+static char *mysql_escape(mysql_auth_config_rec *sec, request_rec *r, char *str, apr_pool_t *p)
X #else
X-static char *mysql_escape(char *str, pool *p)
X+static char *mysql_escape(mysql_auth_config_rec *sec, request_rec *r, char *str, pool *p)
X #endif
X {
X 	char *dest;
X@@ -522,7 +524,7 @@ static char *mysql_escape(char *str, poo
X 		return str;
X 	}
X 	
X-	mysql_escape_string(dest, str, strlen(str));
X+	mysql_real_escape_string(sec->dbh, dest, str, strlen(str));
X 	
X 	return dest;
X }
X@@ -1374,25 +1376,18 @@ static int open_auth_dblink(request_rec 
X 	}
X 
X 	if (sec->db_charset) {
X+		const char *check;
X+
X 		APACHELOG(APLOG_DEBUG, r,
X 			"Setting character set to %s", sec->db_charset);
X 
X-		query = (char *) PSTRCAT(r->pool, "SET CHARACTER SET ", sec->db_charset, NULL);
X-		if (!query) {
X-			APACHELOG(APLOG_ERR, r,
X-				"Failed to create query string - we're no good...");
X-			return -1;
X-		}
X+		mysql_set_character_set(sec->dbh, sec->db_charset);
X 
X-		if (mysql_query(sec->dbh, query)) {
X-			if (sec->dbh)
X-			{
X-				APACHELOG(APLOG_ERR, r,
X-					"Query call failed: %s (%i)", mysql_error(sec->dbh),
X-					mysql_errno(sec->dbh));
X-			}
X+		check = mysql_character_set_name(sec->dbh);
X 
X-			APACHELOG(APLOG_DEBUG, r, "Failed query was: [%s]", query);
X+		if (!check || strcmp(sec->db_charset, check)) {
X+			APACHELOG(APLOG_ERR, r,
X+				"Failed to set character set to %s", sec->db_charset);
X 			return -1;
X 		}
X 	}
X@@ -1537,11 +1532,27 @@ static int mysql_check_user_password(req
X 	char *auth_table = "mysql_auth", *auth_user_field = "username",
X 		*auth_password_field = "passwd", *auth_password_clause = "";
X 	char *query;
X-	char *esc_user = mysql_escape(user, r->pool);
X+	char *esc_user = NULL;
X 	MYSQL_RES *result;
X 	MYSQL_ROW sql_row;
X+	int error = CR_UNKNOWN_ERROR;
X 	int rv;
X 		
X+	if (!sec->dbh) {
X+		APACHELOG(APLOG_DEBUG, r,
X+			"No DB connection open - firing one up");
X+		if ((error = open_auth_dblink(r, sec))) {
X+			APACHELOG(APLOG_DEBUG, r,
X+				"open_auth_dblink returned %i", error);
X+			return error;
X+		}
X+
X+		APACHELOG(APLOG_DEBUG, r,
X+			"Correctly opened a new DB connection");
X+	}
X+
X+	esc_user = mysql_escape(sec, r, user, r->pool);
X+
X 	if (sec->user_table) {
X 		auth_table = sec->user_table;
X 	}
X@@ -1627,8 +1638,8 @@ static int mysql_check_group(request_rec
X {
X 	char *auth_table = "mysql_auth", *auth_group_field="groups", *auth_group_clause="";
X 	char *query;
X-	char *esc_user = mysql_escape(user, r->pool);
X-	char *esc_group = mysql_escape(group, r->pool);
X+	char *esc_user = mysql_escape(sec, r, user, r->pool);
X+	char *esc_group = mysql_escape(sec, r, group, r->pool);
X 	MYSQL_RES *result;
X 	MYSQL_ROW row;
X 	char *auth_user_field = "username";
ac9987cb4f26c6f935cd8892ddfdd537
echo x - mod_auth_mysql_debian/files/patch-005-directives
sed 's/^X//' >mod_auth_mysql_debian/files/patch-005-directives << '0d68c3ff96acd83f78a831f9a0c35943'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 005-directives.dpatch by Joey Schulze <joey@debian.org>
X##
X## All lines beginning with `## DP:' are a description of the patch.
X## DP: Improve documentation for Auth_MySQL_Group_Field
X
X@DPATCH@
Xdiff -u -p -r1.1 -r1.2
X--- DIRECTIVES	14 May 2008 08:46:20 -0000	1.1
X+++ DIRECTIVES	14 May 2008 12:53:34 -0000	1.2
X@@ -125,7 +125,8 @@ AuthMySQL_Password_Field <password_field
X 	Synonym for Auth_MySQL_Password_Field.
X 
X Auth_MySQL_Group_Field <group_field_name>
X-	As per ...Username_Field above.  Defaults to 'groups'.
X+	As per ...Username_Field above.  Defaults to 'groups'.  The query 
X+	will use FIND_IN_SET(<group_name>,<group_field_name>).
X 	
X AuthMySQL_Group_Field <group_field_name>
X 	Synonym for Auth_MySQL_Group_Field.
0d68c3ff96acd83f78a831f9a0c35943
echo x - mod_auth_mysql_debian/files/patch-009-port-int
sed 's/^X//' >mod_auth_mysql_debian/files/patch-009-port-int << '729154df05a118c1109d0d291e2ce3c9'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 009-port-int.dpatch by Lehel Bernadt <lehel@pmc-services.hu>
X##
X## All lines beginning with `## DP:' are a description of the patch.
X## DP: Adjust port to int
X
X@DPATCH@
Xdiff -urNad mod-auth-mysql~/mod_auth_mysql.c mod-auth-mysql/mod_auth_mysql.c
X--- mod_auth_mysql.c	2008-05-15 08:44:54.000000000 +0200
X+++ mod_auth_mysql.c	2008-05-15 08:45:35.000000000 +0200
X@@ -753,11 +753,11 @@
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_socket),
X 		  OR_AUTHCFG,	"database host socket" ),
X 
X-   AP_INIT_TAKE1( "Auth_MySQL_Port",	ap_set_string_slot,
X+   AP_INIT_TAKE1( "Auth_MySQL_Port",	ap_set_int_slot,
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_port),
X 		  OR_AUTHCFG,	"database host port" ),
X 
X-   AP_INIT_TAKE1( "AuthMySQL_Port",	ap_set_string_slot,
X+   AP_INIT_TAKE1( "AuthMySQL_Port",	ap_set_int_slot,
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_port),
X 		  OR_AUTHCFG,	"database host port" ),
X 
X@@ -1021,11 +1021,11 @@
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_socket),
X 	  OR_AUTHCFG,	TAKE1,	"database host socket" },
X 
X-	{ "Auth_MySQL_Port",			ap_set_string_slot,
X+	{ "Auth_MySQL_Port",			ap_set_int_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_port),
X 	  OR_AUTHCFG,	TAKE1,	"database host socket" },
X 
X-	{ "AuthMySQL_Port",			ap_set_string_slot,
X+	{ "AuthMySQL_Port",			ap_set_int_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_port),
X 	  OR_AUTHCFG,	TAKE1,	"database host socket" },
X 
729154df05a118c1109d0d291e2ce3c9
echo x - mod_auth_mysql_debian/files/patch-011-auth_basic
sed 's/^X//' >mod_auth_mysql_debian/files/patch-011-auth_basic << '003611489d92db3e484441eb6db4cbf8'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 011-auth_basic.dpatch by Joey Schulze <joey@infodrom.org>
X##
X## DP: Document problems with other authentication modules
X
X@DPATCH@
Xdiff -urNad mod-auth-mysql~/USAGE mod-auth-mysql/USAGE
X--- USAGE	2008-11-21 16:16:37.000000000 +0100
X+++ USAGE	2008-11-21 16:24:41.000000000 +0100
X@@ -123,3 +123,22 @@
X 
X The full set of directives available are now listed in the file DIRECTIVES,
X for ease of perusal.
X+
X+Disable other Auth methods
X+--------------------------
X+
X+For some reason Apache has problems handing over authority to this
X+module if this is requested an another auth module is also loaded.
X+
X+If you have another authentication module loaded, you'll have to
X+disable it the hard way.
X+
X+AuthBasicAuthoritative Off
X+AuthUserFile /dev/null
X+
X+The following option is not sufficient
X+
X+Auth_MySQL_Authoritative On
X+
X+If you experience similar problems with group membership, try
X+repeating the same procedure with AuthGroupFile.
003611489d92db3e484441eb6db4cbf8
echo x - mod_auth_mysql_debian/files/patch-014-libcrypt
sed 's/^X//' >mod_auth_mysql_debian/files/patch-014-libcrypt << '5d6d69a4fac51480c960588c185085e1'
X--- mod_auth_mysql.c.orig	2009-04-24 19:28:41.994583658 +0200
X+++ mod_auth_mysql.c	2009-04-24 19:29:29.812631203 +0200
X@@ -60,7 +60,7 @@
X #include <errmsg.h>
X #include <mysqld_error.h>
X 
X-#ifdef HAVE_CRYPT_H
X+#if defined(HAVE_CRYPT_H) || defined(HAVE_LIBCRYPT)
X #include <crypt.h>
X #endif
X 
X@@ -99,7 +99,7 @@
X #define CRYPT_MD5_ENCRYPTION_FLAG	1<<3
X #endif
X #define PHP_MD5_ENCRYPTION_FLAG		1<<4
X-#ifdef HAVE_CRYPT_H
X+#if defined(HAVE_CRYPT_H) || defined(HAVE_LIBCRYPT)
X #define CRYPT_ENCRYPTION_FLAG		1<<5
X #endif
X #define SHA1SUM_ENCRYPTION_FLAG		1<<6
X@@ -136,7 +136,7 @@
X }
X #endif
X 
X-#ifdef HAVE_CRYPT_H
X+#if defined(HAVE_CRYPT_H) || defined(HAVE_LIBCRYPT)
X static int check_crypt_encryption(const char *passwd, char *enc_passwd)
X {
X 	return (!strcmp(crypt(passwd, enc_passwd), enc_passwd));
X@@ -264,7 +264,9 @@
X #if CRYPT_MD5
X 	{ "Crypt_MD5",		check_crypt_MD5_encryption,		CRYPT_MD5_ENCRYPTION_FLAG },
X #endif
X+#if defined(HAVE_CRYPT_H) || defined(HAVE_LIBCRYPT)
X 	{ "Crypt",		check_crypt_encryption,			CRYPT_ENCRYPTION_FLAG },
X+#endif
X 	{ "PHP_MD5",		check_PHP_MD5_encryption,		PHP_MD5_ENCRYPTION_FLAG	},
X 	{ "SHA1Sum",	check_SHA1Sum_encryption, SHA1SUM_ENCRYPTION_FLAG},
X 	{ "Apache",		check_apache_encryption,		APACHE_ENCRYPTION_FLAG  },
5d6d69a4fac51480c960588c185085e1
echo x - mod_auth_mysql_debian/files/patch-007-unify-namespace
sed 's/^X//' >mod_auth_mysql_debian/files/patch-007-unify-namespace << '4c5893bf3661b0686efd5200c88e6899'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 007-auth_mysql_user.dpatch by Joey Schulze <joey@debain.org>
X##
X## All lines beginning with `## DP:' are a description of the patch.
X## DP: Unify AuthMySQL_ and Auth_MySQL_ namespace
X
X@DPATCH@
Xdiff -urNad mod-auth-mysql~/DIRECTIVES mod-auth-mysql/DIRECTIVES
X--- DIRECTIVES	2008-05-14 21:05:45.000000000 +0200
X+++ DIRECTIVES	2008-05-14 21:05:45.000000000 +0200
X@@ -1,23 +1,27 @@
X All the directives understood by this version of mod-auth-mysql are listed
X-below.  The huge number of synonym directives is due to the merging of two
X-separate versions of the program, both of which had subtly different usage
X-symantics.  I'm sure there will be rationalisation in the near future.
X+below.  All directives exist in the two forms Auth_MySQL_* and AuthMySQL_*
X+and share the same semantics.  They are the result of merging two separate
X+versions of the mod_auth_mysql in the first place, both of which had subtly
X+different usage symantics.  The directive names have since then unified.
X+
X+Auth_MySQL <on/off>
X+	Enable/disable MySQL authentication
X 
X Auth_MySQL_Info <host> <user> <password>
X 	Server-wide config option to specify the database host, username,
X 	and password used to connect to the MySQL server.
X 
X 	This option affects all directories which do not override it via
X-	AuthMySQL_Host, AuthMySQL_User, and/or AuthMySQL_Password.
X+	Auth_MySQL_Host, Auth_MySQL_User, and/or Auth_MySQL_Password.
X 
X-AuthMySQL_DefaultHost <hostname>
X+Auth_MySQL_DefaultHost <hostname>
X 	Specifies the MySQL server to use for authentication.
X 	
X 	This option affects all directories which do not override it via
X-	AuthMySQL_Host.
X+	Auth_MySQL_Host.
X 
X-AuthMySQL_Host <hostname>
X-	Synonym for AuthMySQL_DefaultHost, to be used in .htaccess files and
X+Auth_MySQL_Host <hostname>
X+	Synonym for Auth_MySQL_DefaultHost, to be used in .htaccess files and
X 	directory-specific entries.
X 
X Auth_MySQL_DefaultPort <portnum>
X@@ -28,35 +32,37 @@
X 	Auth_MySQL_Port.
X 
X Auth_MySQL_Port <portnum>
X-	Specifies a non-default port to use (other than 3306) when talking
X-	to the MySQL server on AuthMySQL_Host or AuthMySQL_DefaultHost.
X+	Synonym for Auth_MySQL_DefaultPort, to be used in .htaccess files and
X+	directory-specific entries.
X 
X Auth_MySQL_DefaultSocket <socketname>
X-	If using a local MySQL server, you can
X-	specify a non-default named pipe to use instead of the default pipe
X-	name compiled into your MySQL client library.
X+	If using a local MySQL server, you can specify a non-default named
X+	pipe to use instead of the default pipe name compiled into your MySQL
X+	client library.
X 
X 	This option affects all directories which do not override it via
X 	Auth_MySQL_Socket.
X 
X Auth_MySQL_Socket <socketname>
X-	If using a local MySQL server, you can specify a non-default named
X-	pipe to use instead of the default one compiled into MySQL with this
X-	option.
X+	Synonym for Auth_MySQL_DefaultSocket, to be used in .htaccess files and
X+	directory-specific entries.
X 
X-AuthMySQL_DefaultUser <username>
X+Auth_MySQL_DefaultUser <username>
X 	Specifies the username for connection to the MySQL server.
X 
X-AuthMySQL_User <username>
X-	Synonym for AuthMySQL_DefaultUser, to be used in .htaccess files and
X+Auth_MySQL_User <username>
X+	Synonym for Auth_MySQL_DefaultUser, to be used in .htaccess files and
X 	directory-specific entries.
X 	
X-AuthMySQL_DefaultPassword <password>
X+Auth_MySQL_Username <username>
X+	Synonym for Auth_MySQL_User.
X+	
X+Auth_MySQL_DefaultPassword <password>
X 	Specifies the password user together with the above user.
X 
X-AuthMySQL_Password <password>
X-	Synonym for AuthMySQL_Password, to be used in .htaccess files and
X-	directory-specific entries.
X+Auth_MySQL_Password <password>
X+	Synonym for Auth_MySQL_DefaultPassword, to be used in .htaccess files
X+	and directory-specific entries.
X 
X Auth_MySQL_General_DB <database_name>
X 	Server-wide, specifies a default database name to use.
X@@ -65,13 +71,9 @@
X 	Synonym for Auth_MySQL_General_DB, to be used in .htaccess files and
X 	directory-specific entries.
X 
X-AuthMySQL_DefaultDB <database_name>
X+Auth_MySQL_DefaultDB <database_name>
X 	Synonym for Auth_MySQL_General_DB.
X 
X-AuthMySQL_DB <database_name>
X-	Synonym for Auth_MySQL_General_DB, to be used in .htaccess files and
X-	directory-specific entries.
X-
X AuthName "<Realm>"
X 	Describes the data you're guarding.
X 
X@@ -96,27 +98,18 @@
X 	The name of the MySQL table in the specified database which stores
X 	username:password pairs.  By default, it is 'mysql_auth'.
X 
X-AuthMySQL_Password_Table <password_table_name>
X-	Synonym for Auth_MySQL_Password_Table.
X-
X Auth_MySQL_Group_Table <group_table_name>
X 	As per ...Password_Table above, stores username:group pairs. 
X 	Normally you'll store username:password:group triplets in the one
X 	table, but we are nothing if not flexible.  Defaults to
X 	'mysql_auth'.
X 
X-AuthMySQL_Group_Table <group_table_name>
X-	Synonym for Auth_MySQL_Group_Table.
X-
X Auth_MySQL_Username_Field <username_field_name>
X 	The name of the field which stores usernames.  Defaults to
X 	'username'. The username/password combo specified in Auth_MySQL_Info
X 	must have select privileges to this field in the Password and Group
X 	tables.
X 
X-AuthMySQL_Username_Field <username_field_name>
X-	Synonym for Auth_MySQL_Username_Field.
X-
X Auth_MySQL_Password_Field <password_field_name>
X 	As per ...Username_Field above, but for passwords.  Same MySQL
X 	access privileges.  Defaults to 'password'.
X@@ -128,9 +121,6 @@
X 	As per ...Username_Field above.  Defaults to 'groups'.  The query 
X 	will use FIND_IN_SET(<group_name>,<group_field_name>).
X 	
X-AuthMySQL_Group_Field <group_field_name>
X-	Synonym for Auth_MySQL_Group_Field.
X-	
X Auth_MySQL_Group_User_Field <field_name>
X 	The name of the field in the groups table which stores the username. 
X 	Defaults to the field name specified for usernames in the passwords
X@@ -147,6 +137,9 @@
X 	Adds arbitrary clause to username:group matching query, for example:
X 	" AND Allowed=1". Clause has to start with space. Default is empty.
X  
X+Auth_MySQL_Where_Clause <SQL fragment>
X+	Synonym for Auth_MySQL_Password_Clause.
X+
X Auth_MySQL_Empty_Passwords <on/off>
X 	Whether or not to allow empty passwords.  If the password field is
X 	empty (equals to '') and this option is 'on', users would be able to
X@@ -154,9 +147,6 @@
X 	PASSWORD CHECKING.  If this is 'off', they would be denied access. 
X 	Default: 'on'.
X 
X-AuthMySQL_Empty_Passwords <on/off>
X-	Synonym for Auth_MySQL_Empty_Passwords.
X-
X Auth_MySQL_Encryption_Types <type_list>
X 
X 	Select which types of encryption to check, and in which order to
X@@ -205,9 +195,6 @@
X 	MySQL
X 		The hashing scheme used by the MySQL PASSWORD() function.
X 		
X-AuthMySQL_Encryption_Types <type_list>
X-	Synonym for Auth_MySQL_Encryption_Types.
X-
X Auth_MySQL_Encrypted_Passwords <on/off> (DEPRECATED)
X 	Equivalent to: Auth_MySQL_Encryption_Types Crypt_DES
X 	Only used if ...Encryption_Types is not set.  Defaults to 'on'.  If
X@@ -215,17 +202,11 @@
X 	...Encryption_Types is not set, passwords are expected to be in
X 	plaintext.
X 
X-AuthMySQL_Encrypted_Passwords <on/off> (DEPRECATED)
X-	Synonym for Auth_MySQL_Encrypted_Passwords.
X-
X Auth_MySQL_Scrambled_Passwords <on/off> (DEPRECATED)
X 	Equivalent to: Auth_MySQL_Encryption_Types MySQL
X 	The same restrictions apply to this directive as to
X 	...Encrypted_Passwords.
X 
X-AuthMySQL_Scrambled_Passwords <on/off> (DEPRECATED)
X-	Synonym for Auth_MySQL_Scrambled_Passwords.
X-
X Auth_MySQL_Authoritative <on/off>
X 	Whether or not to use other authentication schemes if the user is
X 	successfully authenticated.  That is, if the user passes the MySQL
X@@ -233,9 +214,6 @@
X 	option is set 'off'.  The default is 'on' (i.e. if the user passes
X 	the MySQL module, they're considered OK).
X 
X-AuthMySQL_Authoritative <on/off>
X-	Synonym for Auth_MySQL_Authoritative.
X-
X Auth_MySQL_Non_Persistent <on/off>
X 	If set to 'on', the link to the MySQL server is explicitly closed
X 	after each authentication request.  Note that I can't think of any
X@@ -245,10 +223,10 @@
X 	increase the maximum number of simultaneous threads in MySQL and
X 	keep this option off.  Default: off, and for good reason.
X 
X-AuthMySQL_Persistent <on/off>
X+Auth_MySQL_Persistent <on/off>
X 	An antonym for Auth_MySQL_Non_Persistent.
X 
X-AuthMySQL_AllowOverride <on/off>
X+Auth_MySQL_AllowOverride <on/off>
X 	Whether or not .htaccess files are allowed to use their own
X 	Host/User/Password/DB specifications.  If set to 'off', then the
X 	defaults specified in the httpd.conf cannot be overridden.
X@@ -257,6 +235,3 @@
X 	Whether or not to enable MySQL authentication.  If it's off, the
X 	MySQL authentication will simply pass authentication off to other
X 	modules defined.
X-
X-AuthMySQL <on/off>
X-	Synonym for Auth_MYSQL.
Xdiff -urNad mod-auth-mysql~/USAGE mod-auth-mysql/USAGE
X--- USAGE	2008-05-14 21:05:45.000000000 +0200
X+++ USAGE	2008-05-14 21:05:45.000000000 +0200
X@@ -44,9 +44,9 @@
X 
X or
X 
X-AuthMySQL_DefaultHost <host>
X-AuthMySQL_DefaultUser <user>
X-AuthMySQL_DefaultPassword <password>
X+Auth_MySQL_DefaultHost <host>
X+Auth_MySQL_DefaultUser <user>
X+Auth_MySQL_DefaultPassword <password>
X 
X This should be placed globally.
X 
X@@ -56,12 +56,12 @@
X Auth_MySQL_General_DB <database>
X 
X to set that.  This setting can be overridden in .htaccess files if
X-AuthMySQL_AllowOverride is set.
X+Auth_MySQL_AllowOverride is set.
X 
X On that topic, if you want .htaccess files to be restricted in what they're
X able to connect to database-wise, you can
X 
X-AuthMySQL_AllowOverride no
X+Auth_MySQL_AllowOverride no
X 
X and the host, user, password, and database name cannot be changed.
X 
Xdiff -urNad mod-auth-mysql~/mod_auth_mysql.c mod-auth-mysql/mod_auth_mysql.c
X--- mod_auth_mysql.c	2008-05-14 21:05:45.000000000 +0200
X+++ mod_auth_mysql.c	2008-05-14 21:16:30.000000000 +0200
X@@ -674,14 +674,30 @@
X    		  NULL,
X    		  RSRC_CONF,	"host, user and password of the MySQL database" ),
X 
X+   AP_INIT_TAKE3( "AuthMySQL_Info",	set_auth_mysql_info,
X+   		  NULL,
X+   		  RSRC_CONF,	"host, user and password of the MySQL database" ),
X+
X+   AP_INIT_TAKE1( "Auth_MySQL_DefaultHost",	set_auth_mysql_host,
X+		  NULL,
X+		  RSRC_CONF,	"Default MySQL host" ),
X+
X    AP_INIT_TAKE1( "AuthMySQL_DefaultHost",	set_auth_mysql_host,
X 		  NULL,
X 		  RSRC_CONF,	"Default MySQL host" ),
X 
X+   AP_INIT_TAKE1( "Auth_MySQL_DefaultUser",	set_auth_mysql_user,
X+		  NULL,
X+		  RSRC_CONF,	"Default MySQL user" ),
X+
X    AP_INIT_TAKE1( "AuthMySQL_DefaultUser",	set_auth_mysql_user,
X 		  NULL,
X 		  RSRC_CONF,	"Default MySQL user" ),
X 
X+   AP_INIT_TAKE1( "Auth_MySQL_DefaultPassword",	set_auth_mysql_pwd,
X+		  NULL,
X+		  RSRC_CONF,	"Default MySQL password" ),
X+
X    AP_INIT_TAKE1( "AuthMySQL_DefaultPassword",	set_auth_mysql_pwd,
X 		  NULL,
X 		  RSRC_CONF,	"Default MySQL password" ),
X@@ -690,23 +706,39 @@
X 		  NULL,
X 		  RSRC_CONF,	"Default MySQL server port" ),
X 	
X+   AP_INIT_TAKE1( "AuthMySQL_DefaultPort",	set_auth_mysql_port,
X+		  NULL,
X+		  RSRC_CONF,	"Default MySQL server port" ),
X+	
X    AP_INIT_TAKE1( "Auth_MySQL_DefaultSocket",	set_auth_mysql_socket,
X 		  NULL,
X 		  RSRC_CONF,	"Default MySQL server socket" ),
X 	  	
X+   AP_INIT_TAKE1( "AuthMySQL_DefaultSocket",	set_auth_mysql_socket,
X+		  NULL,
X+		  RSRC_CONF,	"Default MySQL server socket" ),
X+	  	
X    AP_INIT_TAKE1( "Auth_MySQL_General_DB",	set_auth_mysql_db,
X 		  NULL,
X 		  RSRC_CONF,	"default database for MySQL authentication" ),
X 
X+   AP_INIT_TAKE1( "AuthMySQL_General_DB",	set_auth_mysql_db,
X+		  NULL,
X+		  RSRC_CONF,	"default database for MySQL authentication" ),
X+
X+   AP_INIT_TAKE1( "Auth_MySQL_DefaultDB",	set_auth_mysql_db,
X+		  NULL,
X+		  RSRC_CONF,	"default database for MySQL authentication" ),
X+
X    AP_INIT_TAKE1( "AuthMySQL_DefaultDB",	set_auth_mysql_db,
X 		  NULL,
X 		  RSRC_CONF,	"default database for MySQL authentication" ),
X 
X-   AP_INIT_TAKE1( "AuthMySQL_Host",	ap_set_string_slot,
X+   AP_INIT_TAKE1( "Auth_MySQL_Host",	ap_set_string_slot,
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_host),
X 		  OR_AUTHCFG,	"database host" ),
X 
X-   AP_INIT_TAKE1( "Auth_MySQL_Host",	ap_set_string_slot,
X+   AP_INIT_TAKE1( "AuthMySQL_Host",	ap_set_string_slot,
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_host),
X 		  OR_AUTHCFG,	"database host" ),
X 
X@@ -730,12 +762,20 @@
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_user),
X 		  OR_AUTHCFG,	"database user" ),
X 
X+   AP_INIT_TAKE1( "AuthMySQL_Username",	ap_set_string_slot,
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_user),
X+		  OR_AUTHCFG,	"database user" ),
X+
X+   AP_INIT_TAKE1( "Auth_MySQL_User",	ap_set_string_slot,
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_user),
X+		  OR_AUTHCFG,	"database user" ),
X+
X    AP_INIT_TAKE1( "AuthMySQL_User",	ap_set_string_slot,
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_user),
X 		  OR_AUTHCFG,	"database user" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Password",	ap_set_string_slot,
X-		(void*)APR_OFFSETOF(mysql_auth_config_rec, db_pwd),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_pwd),
X 		  OR_AUTHCFG,	"database password" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Password",			ap_set_string_slot,
X@@ -762,13 +802,17 @@
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_table),
X 		  OR_AUTHCFG,	"Name of the MySQL table containing the group-name/user-name combination; can be the same as the password-table." ),
X 
X+   AP_INIT_TAKE1( "AuthMySQL_Group_Table",		ap_set_string_slot,
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_table),
X+		  OR_AUTHCFG,	"Name of the MySQL table containing the group-name/user-name combination; can be the same as the password-table." ),
X+
X    AP_INIT_TAKE1( "Auth_MySQL_Group_Clause",		ap_set_string_slot,
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_where_clause),
X 		  OR_AUTHCFG,	"Additional WHERE clause for group/user-name lookup" ),
X 
X-   AP_INIT_TAKE1( "AuthMySQL_Group_Table",		ap_set_string_slot,
X-		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_table),
X-		  OR_AUTHCFG,	"Name of the MySQL table containing the group-name/user-name combination; can be the same as the password-table." ),
X+   AP_INIT_TAKE1( "AuthMySQL_Group_Clause",		ap_set_string_slot,
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_where_clause),
X+		  OR_AUTHCFG,	"Additional WHERE clause for group/user-name lookup" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Password_Field",		ap_set_string_slot,
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, password_field),
X@@ -782,6 +826,10 @@
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, password_where_clause),
X 		  OR_AUTHCFG,	"Additional WHERE clause for group password/user-name lookup" ),
X 
X+   AP_INIT_TAKE1( "AuthMySQL_Password_Clause",		ap_set_string_slot,
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, password_where_clause),
X+		  OR_AUTHCFG,	"Additional WHERE clause for group password/user-name lookup" ),
X+
X    AP_INIT_TAKE1( "Auth_MySQL_Username_Field",		ap_set_string_slot,
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, user_field),
X 		  OR_AUTHCFG,	"The name of the user-name field in the MySQL password (and possibly group) table(s)." ),
X@@ -822,6 +870,10 @@
X 		 NULL,
X 		 OR_AUTHCFG,	"When 'on' the MySQL database is taken to be authoritative and access control is not passed along to other db or access modules." ),
X 
X+   AP_INIT_FLAG( "Auth_MySQL_AllowOverride",		set_auth_mysql_override,
X+		 NULL,
X+		 RSRC_CONF,	"Allow directory overrides of configuration" ),
X+
X    AP_INIT_FLAG( "AuthMySQL_AllowOverride",		set_auth_mysql_override,
X 		 NULL,
X 		 RSRC_CONF,	"Allow directory overrides of configuration" ),
X@@ -854,6 +906,14 @@
X 		 NULL,
X 		 OR_AUTHCFG,	"Use non-persistent MySQL links" ),
X 
X+   AP_INIT_FLAG( "AuthMySQL_Non_Persistent",		set_non_persistent,
X+		 NULL,
X+		 OR_AUTHCFG,	"Use non-persistent MySQL links" ),
X+
X+   AP_INIT_FLAG( "Auth_MySQL_Persistent",		set_persistent,
X+		 NULL,
X+		 OR_AUTHCFG,	"Use non-persistent MySQL links" ),
X+
X    AP_INIT_FLAG( "AuthMySQL_Persistent",		set_persistent,
X 		 NULL,
X 		 OR_AUTHCFG,	"Use non-persistent MySQL links" ),
X@@ -870,6 +930,10 @@
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, password_where_clause),
X 		  OR_AUTHCFG,	"Additional WHERE clause for group password/user-name lookup" ),
X 
X+   AP_INIT_TAKE1( "AuthMySQL_Where",		ap_set_string_slot,
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, password_where_clause),
X+		  OR_AUTHCFG,	"Additional WHERE clause for group password/user-name lookup" ),
X+
X   { NULL }
X };
X #else
X@@ -878,14 +942,30 @@
X 	  NULL,
X 	  RSRC_CONF,	TAKE3,	"host, user and password of the MySQL database" },
X 
X+	{ "AuthMySQL_Info",			set_auth_mysql_info,
X+	  NULL,
X+	  RSRC_CONF,	TAKE3,	"host, user and password of the MySQL database" },
X+
X+	{ "Auth_MySQL_DefaultHost",		set_auth_mysql_host,
X+	  NULL,
X+	  RSRC_CONF,	TAKE1,	"Default MySQL host" },
X+
X 	{ "AuthMySQL_DefaultHost",		set_auth_mysql_host,
X 	  NULL,
X 	  RSRC_CONF,	TAKE1,	"Default MySQL host" },
X 
X+	{ "Auth_MySQL_DefaultUser",		set_auth_mysql_user,
X+	  NULL,
X+	  RSRC_CONF,	TAKE1,	"Default MySQL user" },
X+
X 	{ "AuthMySQL_DefaultUser",		set_auth_mysql_user,
X 	  NULL,
X 	  RSRC_CONF,	TAKE1,	"Default MySQL user" },
X 
X+	{ "Auth_MySQL_DefaultPassword",		set_auth_mysql_pwd,
X+	  NULL,
X+	  RSRC_CONF,	TAKE1,	"Default MySQL password" },
X+
X 	{ "AuthMySQL_DefaultPassword",		set_auth_mysql_pwd,
X 	  NULL,
X 	  RSRC_CONF,	TAKE1,	"Default MySQL password" },
X@@ -894,23 +974,39 @@
X 	  NULL,
X 	  RSRC_CONF,	TAKE1,  "Default MySQL server port" },
X 	
X+	{ "AuthMySQL_DefaultPort",		set_auth_mysql_port,
X+	  NULL,
X+	  RSRC_CONF,	TAKE1,  "Default MySQL server port" },
X+	
X 	{ "Auth_MySQL_DefaultSocket",		set_auth_mysql_socket,
X 	  NULL,
X 	  RSRC_CONF,    TAKE1,  "Default MySQL server socket" },
X 	  	
X+	{ "AuthMySQL_DefaultSocket",		set_auth_mysql_socket,
X+	  NULL,
X+	  RSRC_CONF,    TAKE1,  "Default MySQL server socket" },
X+	  	
X 	{ "Auth_MySQL_General_DB",		set_auth_mysql_db,
X 	  NULL,
X 	  RSRC_CONF,	TAKE1,	"default database for MySQL authentication" },
X 	  
X+	{ "AuthMySQL_General_DB",		set_auth_mysql_db,
X+	  NULL,
X+	  RSRC_CONF,	TAKE1,	"default database for MySQL authentication" },
X+	  
X+	{ "Auth_MySQL_DefaultDB",		set_auth_mysql_db,
X+	  NULL,
X+	  RSRC_CONF,	TAKE1,	"default database for MySQL authentication" },
X+
X 	{ "AuthMySQL_DefaultDB",		set_auth_mysql_db,
X 	  NULL,
X 	  RSRC_CONF,	TAKE1,	"default database for MySQL authentication" },
X 
X-	{ "AuthMySQL_Host",			ap_set_string_slot,
X+	{ "Auth_MySQL_Host",			ap_set_string_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_host),
X 	  OR_AUTHCFG,	TAKE1,	"database host" },
X 
X-	{ "Auth_MySQL_Host",			ap_set_string_slot,
X+	{ "AuthMySQL_Host",			ap_set_string_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_host),
X 	  OR_AUTHCFG,	TAKE1,	"database host" },
X 
X@@ -918,14 +1014,30 @@
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_socket),
X 	  OR_AUTHCFG,	TAKE1,	"database host socket" },
X 
X+	{ "AuthMySQL_Socket",			ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, db_socket),
X+	  OR_AUTHCFG,	TAKE1,	"database host socket" },
X+
X 	{ "Auth_MySQL_Port",			ap_set_string_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_port),
X 	  OR_AUTHCFG,	TAKE1,	"database host socket" },
X 
X+	{ "AuthMySQL_Port",			ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, db_port),
X+	  OR_AUTHCFG,	TAKE1,	"database host socket" },
X+
X 	{ "Auth_MySQL_Username",		ap_set_string_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_user),
X 	  OR_AUTHCFG,	TAKE1,	"database user" },
X 	  
X+	{ "AuthMySQL_Username",		ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, db_user),
X+	  OR_AUTHCFG,	TAKE1,	"database user" },
X+	  
X+	{ "Auth_MySQL_User",			ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, db_user),
X+	  OR_AUTHCFG,	TAKE1,	"database user" },
X+	  
X 	{ "AuthMySQL_User",			ap_set_string_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_user),
X 	  OR_AUTHCFG,	TAKE1,	"database user" },
X@@ -958,14 +1070,18 @@
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, group_table),
X 	  OR_AUTHCFG,	TAKE1,	"Name of the MySQL table containing the group-name/user-name combination; can be the same as the password-table." },
X 	  
X+	{ "AuthMySQL_Group_Table",		ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, group_table),
X+	  OR_AUTHCFG,	TAKE1,	"Name of the MySQL table containing the group-name/user-name combination; can be the same as the password-table." },
X+	  
X 	{ "Auth_MySQL_Group_Clause",		ap_set_string_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, group_where_clause),
X 	  OR_AUTHCFG,	TAKE1,  "Additional WHERE clause for group/user-name lookup" },
X 	  
X-	{ "AuthMySQL_Group_Table",		ap_set_string_slot,
X-	  (void *) XtOffsetOf(mysql_auth_config_rec, group_table),
X-	  OR_AUTHCFG,	TAKE1,	"Name of the MySQL table containing the group-name/user-name combination; can be the same as the password-table." },
X-
X+	{ "AuthMySQL_Group_Clause",		ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, group_where_clause),
X+	  OR_AUTHCFG,	TAKE1,  "Additional WHERE clause for group/user-name lookup" },
X+	  
X 	{ "Auth_MySQL_Password_Field",		ap_set_string_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, password_field),
X 	  OR_AUTHCFG,	TAKE1,	"The name of the field in the MySQL password table" },
X@@ -978,6 +1094,10 @@
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, password_where_clause),
X 	  OR_AUTHCFG,	TAKE1,  "Additional WHERE clause for group password/user-name lookup" },
X 
X+	{ "AuthMySQL_Password_Clause",		ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, password_where_clause),
X+	  OR_AUTHCFG,	TAKE1,  "Additional WHERE clause for group password/user-name lookup" },
X+
X 	{ "Auth_MySQL_Username_Field",		ap_set_string_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, user_field),
X 	  OR_AUTHCFG,	TAKE1,	"The name of the user-name field in the MySQL password (and possibly group) table(s)." },
X@@ -1018,6 +1138,10 @@
X 	  NULL,
X 	  OR_AUTHCFG,	FLAG,	"When 'on' the MySQL database is taken to be authoritative and access control is not passed along to other db or access modules." },
X 
X+	{ "Auth_MySQL_AllowOverride",		set_auth_mysql_override,
X+	  NULL,
X+	  RSRC_CONF,	FLAG,	"Allow directory overrides of configuration" },
X+
X 	{ "AuthMySQL_AllowOverride",		set_auth_mysql_override,
X 	  NULL,
X 	  RSRC_CONF,	FLAG,	"Allow directory overrides of configuration" },
X@@ -1050,6 +1174,14 @@
X 	  NULL,
X 	  OR_AUTHCFG,	FLAG,	"Use non-persistent MySQL links" },
X 
X+	{ "AuthMySQL_Non_Persistent",		set_non_persistent,
X+	  NULL,
X+	  OR_AUTHCFG,	FLAG,	"Use non-persistent MySQL links" },
X+
X+	{ "Auth_MySQL_Persistent",		set_persistent,
X+	  NULL,
X+	  OR_AUTHCFG,	FLAG,	"Use non-persistent MySQL links" },
X+
X 	{ "AuthMySQL_Persistent",		set_persistent,
X 	  NULL,
X 	  OR_AUTHCFG,	FLAG,	"Use non-persistent MySQL links" },
X@@ -1066,6 +1198,10 @@
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, password_where_clause),
X 	  OR_AUTHCFG,	TAKE1,  "Additional WHERE clause for group password/user-name lookup" },
X 
X+	{ "AuthMySQL_Where",			ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, password_where_clause),
X+	  OR_AUTHCFG,	TAKE1,  "Additional WHERE clause for group password/user-name lookup" },
X+
X 	{ NULL }
X };
X 
4c5893bf3661b0686efd5200c88e6899
echo x - mod_auth_mysql_debian/files/patch-003-ftbfs_apache2
sed 's/^X//' >mod_auth_mysql_debian/files/patch-003-ftbfs_apache2 << 'd330cfc391c6d2da46cb8e20bbd111f9'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 003-ftbfs_apache2.2.dpatch by Julian Calaby <julian.calaby@gmail.com>
X##
X## DP: Fixes the FTBFS against apache2.2 (see #389579 for more information)
X
X@DPATCH@
X
X--- mod_auth_mysql.c	2006-11-21 15:07:43.000000000 +1100
X+++ mod_auth_mysql.c	2006-11-21 16:42:29.000000000 +1100
X@@ -48,6 +48,7 @@
X #include <http_log.h>
X #ifdef APACHE2
X #include "http_request.h"   /* for ap_hook_(check_user_id | auth_checker)*/
X+#include <apr_general.h>
X #include <apr_md5.h>
X #include <apr_sha1.h>
X #else
X@@ -684,123 +685,123 @@
X 		  RSRC_CONF,	"default database for MySQL authentication" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Host",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_host),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_host),
X 		  OR_AUTHCFG,	"database host" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Host",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_host),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_host),
X 		  OR_AUTHCFG,	"database host" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Socket",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_socket),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_socket),
X 		  OR_AUTHCFG,	"database host socket" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Socket",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_socket),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_socket),
X 		  OR_AUTHCFG,	"database host socket" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Port",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_port),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_port),
X 		  OR_AUTHCFG,	"database host port" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Port",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_port),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_port),
X 		  OR_AUTHCFG,	"database host port" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Username",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_user),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_user),
X 		  OR_AUTHCFG,	"database user" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_User",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_user),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_user),
X 		  OR_AUTHCFG,	"database user" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Password",	ap_set_string_slot,
X-		(void*)APR_XtOffsetOf(mysql_auth_config_rec, db_pwd),
X+		(void*)APR_OFFSETOF(mysql_auth_config_rec, db_pwd),
X 		  OR_AUTHCFG,	"database password" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Password",			ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_pwd),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_pwd),
X 		  OR_AUTHCFG,	"database password" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_DB",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_name),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_name),
X 		  OR_AUTHCFG,	"database name" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_DB",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, db_name),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_name),
X 		  OR_AUTHCFG,	"database name" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Password_Table",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, user_table),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, user_table),
X 		  OR_AUTHCFG,	"Name of the MySQL table containing the password/user-name combination" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Password_Table",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, user_table),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, user_table),
X 		  OR_AUTHCFG,	"Name of the MySQL table containing the password/user-name combination" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Group_Table",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, group_table),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_table),
X 		  OR_AUTHCFG,	"Name of the MySQL table containing the group-name/user-name combination; can be the same as the password-table." ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Group_Clause",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, group_where_clause),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_where_clause),
X 		  OR_AUTHCFG,	"Additional WHERE clause for group/user-name lookup" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Group_Table",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, group_table),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_table),
X 		  OR_AUTHCFG,	"Name of the MySQL table containing the group-name/user-name combination; can be the same as the password-table." ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Password_Field",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, password_field),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, password_field),
X 		  OR_AUTHCFG,	"The name of the field in the MySQL password table" ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Password_Field",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, password_field),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, password_field),
X 		  OR_AUTHCFG,	"The name of the field in the MySQL password table" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Password_Clause",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, password_where_clause),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, password_where_clause),
X 		  OR_AUTHCFG,	"Additional WHERE clause for group password/user-name lookup" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Username_Field",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, user_field),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, user_field),
X 		  OR_AUTHCFG,	"The name of the user-name field in the MySQL password (and possibly group) table(s)." ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Username_Field",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, user_field),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, user_field),
X 		  OR_AUTHCFG,	"The name of the user-name field in the MySQL password (and possibly group) table(s)." ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Group_Field",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, group_field),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_field),
X 		  OR_AUTHCFG,	"The name of the group field in the MySQL group table; must be set if you want to use groups." ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Group_Field",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, group_field),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_field),
X 		  OR_AUTHCFG,	"The name of the group field in the MySQL group table; must be set if you want to use groups." ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Group_User_Field",	ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, group_user_field),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_user_field),
X 		  OR_AUTHCFG,	"The name of the user-name field in the MySQL group table; defaults to the same as the username field for the password table." ),
X 
X    AP_INIT_TAKE1( "AuthMySQL_Group_User_Field",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, group_user_field),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_user_field),
X 		  OR_AUTHCFG,	"The name of the user-name field in the MySQL group table; defaults to the same as the username field for the password table." ),
X 
X    AP_INIT_FLAG( "Auth_MySQL_Empty_Passwords",		ap_set_flag_slot,
X-		 (void*)APR_XtOffsetOf(mysql_auth_config_rec, allow_empty_passwords),
X+		 (void*)APR_OFFSETOF(mysql_auth_config_rec, allow_empty_passwords),
X 		 OR_AUTHCFG,	"Enable (on) or disable (off) empty password strings; in which case any user password is accepted." ),
X 
X    AP_INIT_FLAG( "AuthMySQL_Empty_Passwords",		ap_set_flag_slot,
X-		 (void*)APR_XtOffsetOf(mysql_auth_config_rec, allow_empty_passwords),
X+		 (void*)APR_OFFSETOF(mysql_auth_config_rec, allow_empty_passwords),
X 		 OR_AUTHCFG,	"Enable (on) or disable (off) empty password strings; in which case any user password is accepted." ),
X 
X    AP_INIT_FLAG( "Auth_MySQL_Authoritative",		ap_set_flag_slot,
X-		 (void*)APR_XtOffsetOf(mysql_auth_config_rec, authoritative),
X+		 (void*)APR_OFFSETOF(mysql_auth_config_rec, authoritative),
X 		 OR_AUTHCFG,	"When 'on' the MySQL database is taken to be authoritative and access control is not passed along to other db or access modules." ),
X 
X    AP_INIT_FLAG( "AuthMySQL_Authoritative",		ap_set_flag_slot,
X-		 (void*)APR_XtOffsetOf(mysql_auth_config_rec, authoritative),
X+		 (void*)APR_OFFSETOF(mysql_auth_config_rec, authoritative),
X 		 OR_AUTHCFG,	"When 'on' the MySQL database is taken to be authoritative and access control is not passed along to other db or access modules." ),
X 
X    AP_INIT_FLAG( "AuthMySQL_AllowOverride",		set_auth_mysql_override,
X@@ -848,7 +849,7 @@
X 		 OR_AUTHCFG,	"Enable MySQL authentication" ),
X 
X    AP_INIT_TAKE1( "Auth_MySQL_Where",		ap_set_string_slot,
X-		  (void*)APR_XtOffsetOf(mysql_auth_config_rec, password_where_clause),
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, password_where_clause),
X 		  OR_AUTHCFG,	"Additional WHERE clause for group password/user-name lookup" ),
X 
X   { NULL }
d330cfc391c6d2da46cb8e20bbd111f9
echo x - mod_auth_mysql_debian/files/patch-004-reconnect
sed 's/^X//' >mod_auth_mysql_debian/files/patch-004-reconnect << 'a9938ad040b7ff8e5ff9989c0467920d'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 004-reconnect.dpatch by Matej Vela <vela@debian.org>
X##
X## All lines beginning with `## DP:' are a description of the patch.
X## DP: Automatically re-establish connections with MySQL 5.0.3+.
X
X@DPATCH@
Xdiff -urNad libapache-mod-auth-mysql-4.3.9~/mod_auth_mysql.c libapache-mod-auth-mysql-4.3.9/mod_auth_mysql.c
X--- mod_auth_mysql.c	2008-02-12 15:33:56.000000000 +0100
X+++ mod_auth_mysql.c	2008-02-12 15:43:30.000000000 +0100
X@@ -1092,6 +1092,9 @@
X 	char *dbname = auth_db_name, *user = auth_db_user, *pwd = auth_db_pwd;
X 	void (*sigpipe_handler)();
X 	unsigned long client_flag = 0;
X+#if MYSQL_VERSION_ID >= 50013
X+	my_bool do_reconnect = 1;
X+#endif
X 
X 	APACHELOG(APLOG_DEBUG, r, "Opening DB connection for %s", sec->dir);
X 	
X@@ -1160,6 +1163,13 @@
X 		return errno;
X 	}
X 
X+#if MYSQL_VERSION_ID >= 50013
X+	/* The default is no longer to automatically reconnect on failure,
X+	 * (as of 5.0.3) so we have to set that option here.  The option is
X+	 * available from 5.0.13.  */
X+	mysql_options(sec->dbh, MYSQL_OPT_RECONNECT, &do_reconnect);
X+#endif
X+
X 	signal(SIGPIPE, sigpipe_handler);
X 	
X 	APACHELOG(APLOG_DEBUG, r, "Persistent in %s is %i", sec->dir, sec->persistent);
a9938ad040b7ff8e5ff9989c0467920d
echo x - mod_auth_mysql_debian/files/Makefile
sed 's/^X//' >mod_auth_mysql_debian/files/Makefile << '75e190e16de44d8b2b76eb23506efc99'
X#
X# $FreeBSD: ports/www/mod_auth_mysql_another/files/Makefile,v 1.1 2006/04/15 13:21:00 mbr Exp $
X#
Xall: build
X
Xbuild:
X	%%APXS%% -c -L%%AP_LIB%% -I%%AP_INC%% -lmysqlclient -lm -lz mod_auth_mysql.c
X
Xinstall:
X	%%APXS%% -i mod_auth_mysql.so
75e190e16de44d8b2b76eb23506efc99
echo x - mod_auth_mysql_debian/files/patch-010-enctype-apache
sed 's/^X//' >mod_auth_mysql_debian/files/patch-010-enctype-apache << '3a9c7d03fce84ee2eab21a45bcdf57a3'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 010-enctype-apache.dpatch by Andreas Barth <aba@not.so.argh.org>
X##                              Joey Schulze <joey@infodrom.org>
X##
X## All lines beginning with `## DP:' are a description of the patch.
X## DP: Provide an Apache authentication method
X
X@DPATCH@
Xdiff -urNad mod-auth-mysql~/DIRECTIVES mod-auth-mysql/DIRECTIVES
X--- DIRECTIVES	2008-05-15 12:55:28.000000000 +0200
X+++ DIRECTIVES	2008-05-15 12:55:29.000000000 +0200
X@@ -194,6 +194,10 @@
X 
X 	MySQL
X 		The hashing scheme used by the MySQL PASSWORD() function.
X+	
X+	Apache
X+		The hashing scheme used by htpasswd utility. Compatible to
X+		authuserfile.
X 		
X Auth_MySQL_Encrypted_Passwords <on/off> (DEPRECATED)
X 	Equivalent to: Auth_MySQL_Encryption_Types Crypt_DES
Xdiff -urNad mod-auth-mysql~/mod_auth_mysql.c mod-auth-mysql/mod_auth_mysql.c
X--- mod_auth_mysql.c	2008-05-15 12:55:28.000000000 +0200
X+++ mod_auth_mysql.c	2008-05-15 12:56:28.000000000 +0200
X@@ -103,6 +103,7 @@
X #define CRYPT_ENCRYPTION_FLAG		1<<5
X #endif
X #define SHA1SUM_ENCRYPTION_FLAG		1<<6
X+#define APACHE_ENCRYPTION_FLAG		1<<7
X 
X /* from include/sha1.h from the mysql-server source distribution */
X #define SHA1_HASH_SIZE 20 /* Hash size in bytes */
X@@ -239,6 +240,15 @@
X 	return (!strcmp(scrambled_passwd, enc_passwd));
X }
X 
X+static int check_apache_encryption(const char *passwd, char *enc_passwd)
X+{
X+#ifdef APACHE2
X+	return (!apr_password_validate(passwd, enc_passwd));
X+#else
X+	return (!ap_validate_password(passwd, enc_passwd));
X+#endif
X+}
X+
X typedef struct {
X 	char *name;
X 	int (*check_function)(const char *passwd, char *enc_passwd);
X@@ -257,6 +267,7 @@
X 	{ "Crypt",		check_crypt_encryption,			CRYPT_ENCRYPTION_FLAG },
X 	{ "PHP_MD5",		check_PHP_MD5_encryption,		PHP_MD5_ENCRYPTION_FLAG	},
X 	{ "SHA1Sum",	check_SHA1Sum_encryption, SHA1SUM_ENCRYPTION_FLAG},
X+	{ "Apache",		check_apache_encryption,		APACHE_ENCRYPTION_FLAG  },
X 	/* add additional encryption types below */
X 	{ NULL,			NULL,					0 }
X };
3a9c7d03fce84ee2eab21a45bcdf57a3
echo x - mod_auth_mysql_debian/files/patch-006-options
sed 's/^X//' >mod_auth_mysql_debian/files/patch-006-options << '29fc4b8c507d90d8818c3589d661909a'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 006-options.dpatch by Adrian Bridgett <adrian@smop.co.uk>
X##
X## All lines beginning with `## DP:' are a description of the patch.
X## DP: Properly set 1-byte int config variables
X
X@DPATCH@
Xdiff -urNad mod-auth-mysql~/mod_auth_mysql.c mod-auth-mysql/mod_auth_mysql.c
X--- mod_auth_mysql.c	2008-05-14 19:35:05.000000000 +0200
X+++ mod_auth_mysql.c	2008-05-14 20:05:44.000000000 +0200
X@@ -645,6 +645,24 @@
X 	return NULL;
X }
X 
X+static const char *set_empty_passwords(cmd_parms *cmd, void *sconf, int arg)
X+{
X+	mysql_auth_config_rec *sec = (mysql_auth_config_rec *) sconf;
X+
X+	sec->allow_empty_passwords = arg;
X+	APACHELOG(APLOG_DEBUG, cmd, "set_empty_passwords: Setting allow_empty_passwords in %s to %i", sec->dir, sec->allow_empty_passwords);
X+	return NULL;
X+}
X+
X+static const char *set_authoritative(cmd_parms *cmd, void *sconf, int arg)
X+{
X+	mysql_auth_config_rec *sec = (mysql_auth_config_rec *) sconf;
X+
X+	sec->authoritative = arg;
X+	APACHELOG(APLOG_DEBUG, cmd, "set_authoritative: Setting authoritative in %s to %i", sec->dir, sec->authoritative);
X+	return NULL;
X+}
X+
X /* The command list.  What it's called, when it's legal to use it, and
X  * what to do when we find it.  Pretty cool, IMHO.
X  */
X@@ -788,20 +806,20 @@
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, group_user_field),
X 		  OR_AUTHCFG,	"The name of the user-name field in the MySQL group table; defaults to the same as the username field for the password table." ),
X 
X-   AP_INIT_FLAG( "Auth_MySQL_Empty_Passwords",		ap_set_flag_slot,
X-		 (void*)APR_OFFSETOF(mysql_auth_config_rec, allow_empty_passwords),
X+   AP_INIT_FLAG( "Auth_MySQL_Empty_Passwords",		set_empty_passwords,
X+		 NULL,
X 		 OR_AUTHCFG,	"Enable (on) or disable (off) empty password strings; in which case any user password is accepted." ),
X 
X-   AP_INIT_FLAG( "AuthMySQL_Empty_Passwords",		ap_set_flag_slot,
X-		 (void*)APR_OFFSETOF(mysql_auth_config_rec, allow_empty_passwords),
X+   AP_INIT_FLAG( "AuthMySQL_Empty_Passwords",		set_empty_passwords,
X+		 NULL,
X 		 OR_AUTHCFG,	"Enable (on) or disable (off) empty password strings; in which case any user password is accepted." ),
X 
X-   AP_INIT_FLAG( "Auth_MySQL_Authoritative",		ap_set_flag_slot,
X-		 (void*)APR_OFFSETOF(mysql_auth_config_rec, authoritative),
X+   AP_INIT_FLAG( "Auth_MySQL_Authoritative",		set_authoritative,
X+		 NULL,
X 		 OR_AUTHCFG,	"When 'on' the MySQL database is taken to be authoritative and access control is not passed along to other db or access modules." ),
X 
X-   AP_INIT_FLAG( "AuthMySQL_Authoritative",		ap_set_flag_slot,
X-		 (void*)APR_OFFSETOF(mysql_auth_config_rec, authoritative),
X+   AP_INIT_FLAG( "AuthMySQL_Authoritative",		set_authoritative,
X+		 NULL,
X 		 OR_AUTHCFG,	"When 'on' the MySQL database is taken to be authoritative and access control is not passed along to other db or access modules." ),
X 
X    AP_INIT_FLAG( "AuthMySQL_AllowOverride",		set_auth_mysql_override,
X@@ -984,20 +1002,20 @@
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, group_user_field),
X 	  OR_AUTHCFG,	TAKE1,	"The name of the user-name field in the MySQL group table; defaults to the same as the username field for the password table." },
X 
X-	{ "Auth_MySQL_Empty_Passwords",		ap_set_flag_slot,
X-	  (void *) XtOffsetOf(mysql_auth_config_rec, allow_empty_passwords),
X+	{ "Auth_MySQL_Empty_Passwords",		set_empty_passwords,
X+	  NULL,
X 	  OR_AUTHCFG,	FLAG,	"Enable (on) or disable (off) empty password strings; in which case any user password is accepted." },
X 
X-	{ "AuthMySQL_Empty_Passwords",		ap_set_flag_slot,
X-	  (void *) XtOffsetOf(mysql_auth_config_rec, allow_empty_passwords),
X+	{ "AuthMySQL_Empty_Passwords",		set_empty_passwords,
X+	  NULL,
X 	  OR_AUTHCFG,	FLAG,	"Enable (on) or disable (off) empty password strings; in which case any user password is accepted." },
X 
X-	{ "Auth_MySQL_Authoritative",		ap_set_flag_slot,
X-	  (void *) XtOffsetOf(mysql_auth_config_rec, authoritative),
X+	{ "Auth_MySQL_Authoritative",		set_authoritative,
X+	  NULL,
X 	  OR_AUTHCFG,	FLAG,	"When 'on' the MySQL database is taken to be authoritative and access control is not passed along to other db or access modules." },
X 
X-	{ "AuthMySQL_Authoritative",		ap_set_flag_slot,
X-	  (void *) XtOffsetOf(mysql_auth_config_rec, authoritative),
X+	{ "AuthMySQL_Authoritative",		set_authoritative,
X+	  NULL,
X 	  OR_AUTHCFG,	FLAG,	"When 'on' the MySQL database is taken to be authoritative and access control is not passed along to other db or access modules." },
X 
X 	{ "AuthMySQL_AllowOverride",		set_auth_mysql_override,
29fc4b8c507d90d8818c3589d661909a
echo x - mod_auth_mysql_debian/files/patch-012-charset
sed 's/^X//' >mod_auth_mysql_debian/files/patch-012-charset << 'fccc0cc7ae716b238ac11f1623201452'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 012-charset.dpatch by Joey Schulze <joey@infodrom.org>
X##
X## DP: Add support for specifying the connection character set
X## DP: via Auth_MySQL_CharacterSet.
X
X@DPATCH@
Xdiff -urNad mod-auth-mysql~/DIRECTIVES mod-auth-mysql/DIRECTIVES
X--- DIRECTIVES	2008-11-21 17:05:40.000000000 +0100
X+++ DIRECTIVES	2008-11-21 17:05:40.000000000 +0100
X@@ -74,6 +74,18 @@
X Auth_MySQL_DefaultDB <database_name>
X 	Synonym for Auth_MySQL_General_DB.
X 
X+Auth_MySQL_CharacterSet <character set>
X+
X+	Set the connection character set to the specified one.  Otherwise no
X+	particular character set is used when the connection is created.
X+	This could cause problems with differently encoded strings and table
X+	or column collations.  The parameter must be a valid MySQL
X+	character.  It is mandatory if the character set used for tables/rows
X+	differs from the default.
X+
X+AuthMySQL_CharacterSet <character set>
X+        Synonym for Auth_MySQL_CharacterSet.
X+
X AuthName "<Realm>"
X 	Describes the data you're guarding.
X 
Xdiff -urNad mod-auth-mysql~/mod_auth_mysql.c mod-auth-mysql/mod_auth_mysql.c
X--- mod_auth_mysql.c	2008-11-21 17:05:40.000000000 +0100
X+++ mod_auth_mysql.c	2008-11-21 17:05:50.000000000 +0100
X@@ -299,6 +299,7 @@
X 	char *db_user;
X 	char *db_pwd;
X 	char *db_name;
X+	char *db_charset;
X 	
X 	MYSQL *dbh;
X 
X@@ -344,6 +345,7 @@
X #else
X static void
X #endif
X+
X auth_mysql_cleanup(void *ptr)
X {
X 	mysql_auth_config_rec *sec = ptr;
X@@ -395,7 +397,7 @@
X 				sizeof(mysql_auth_config_rec));
X #endif
X 
X-	sec->db_name = sec->db_socket = sec->db_user = sec->db_pwd = NULL;
X+	sec->db_name = sec->db_socket = sec->db_user = sec->db_pwd = sec->db_charset = NULL;
X 
X 	sec->dbh = NULL;
X 	/* When the memory for this connection record is cleaned, we must
X@@ -804,6 +806,14 @@
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_name),
X 		  OR_AUTHCFG,	"database name" ),
X 
X+   AP_INIT_TAKE1( "Auth_MySQL_CharacterSet",		ap_set_string_slot,
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_charset),
X+		  OR_AUTHCFG,	"character set" ),
X+
X+   AP_INIT_TAKE1( "AuthMySQL_CharacterSet",	ap_set_string_slot,
X+		  (void*)APR_OFFSETOF(mysql_auth_config_rec, db_charset),
X+		  OR_AUTHCFG,	"character set" ),
X+
X    AP_INIT_TAKE1( "Auth_MySQL_Password_Table",		ap_set_string_slot,
X 		  (void*)APR_OFFSETOF(mysql_auth_config_rec, user_table),
X 		  OR_AUTHCFG,	"Name of the MySQL table containing the password/user-name combination" ),
X@@ -1072,6 +1082,14 @@
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, db_name),
X 	  OR_AUTHCFG,	TAKE1,	"database name" },
X 	  
X+	{ "Auth_MySQL_CharacterSet",			ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, db_charset),
X+	  OR_AUTHCFG,	TAKE1,	"character set" },
X+	  
X+	{ "AuthMySQL_CharacterSet",			ap_set_string_slot,
X+	  (void *) XtOffsetOf(mysql_auth_config_rec, db_charset),
X+	  OR_AUTHCFG,	TAKE1,	"character set" },
X+	  
X 	{ "Auth_MySQL_Password_Table",		ap_set_string_slot,
X 	  (void *) XtOffsetOf(mysql_auth_config_rec, user_table),
X 	  OR_AUTHCFG,	TAKE1,	"Name of the MySQL table containing the password/user-name combination" },
X@@ -1264,6 +1282,7 @@
X #if MYSQL_VERSION_ID >= 50013
X 	my_bool do_reconnect = 1;
X #endif
X+	char *query;
X 
X 	APACHELOG(APLOG_DEBUG, r, "Opening DB connection for %s", sec->dir);
X 	
X@@ -1354,6 +1373,30 @@
X #endif
X 	}
X 
X+	if (sec->db_charset) {
X+		APACHELOG(APLOG_DEBUG, r,
X+			"Setting character set to %s", sec->db_charset);
X+
X+		query = (char *) PSTRCAT(r->pool, "SET CHARACTER SET ", sec->db_charset, NULL);
X+		if (!query) {
X+			APACHELOG(APLOG_ERR, r,
X+				"Failed to create query string - we're no good...");
X+			return -1;
X+		}
X+
X+		if (mysql_query(sec->dbh, query)) {
X+			if (sec->dbh)
X+			{
X+				APACHELOG(APLOG_ERR, r,
X+					"Query call failed: %s (%i)", mysql_error(sec->dbh),
X+					mysql_errno(sec->dbh));
X+			}
X+
X+			APACHELOG(APLOG_DEBUG, r, "Failed query was: [%s]", query);
X+			return -1;
X+		}
X+	}
X+
X 	/* W00t!  We made it! */
X 	return 0;
X }
fccc0cc7ae716b238ac11f1623201452
echo x - mod_auth_mysql_debian/files/patch-001-usage
sed 's/^X//' >mod_auth_mysql_debian/files/patch-001-usage << '198fdbc242efc6483f5a816cf3dacff6'
X#! /bin/sh /usr/share/dpatch/dpatch-run
X## 001-usage.dpatch by Matthew Palmer <mpalmer@debian.org>
X##
X## DP: Explain the md5 and sha1 cryptographic methods better
X
X@DPATCH@
X
X--- USAGE
X+++ USAGE
X@@ -18,7 +18,10 @@
X 	primary key (username)
X );
X 
X-This would work quite well.
X+This would work quite well.  Remember that the passwd field needs to be long
X+enough to store the entire password string -- for example, if you are using
X+MD5 passwords, passwd needs to be 32 characters long, and if you are using
X+SHA1 it must be 40 characters long.
X 
X NOTE 1: You don't have to use a new table for the purpose of storing
X usernames and passwords; I quite happily use a 'members' table (with all
198fdbc242efc6483f5a816cf3dacff6
echo x - mod_auth_mysql_debian/Makefile
sed 's/^X//' >mod_auth_mysql_debian/Makefile << '5b79d25101ca0df03ce36ae5abbf814f'
X# New ports collection makefile for:    apache mod_auth_mysql_debian
X# Date created:		2009/04/24
X# Whom:			mjonuschat@gmail.com
X#
X# $FreeBSD$
X
XPORTNAME=	mod_auth_mysql
XPORTVERSION=	4.3.9
XCATEGORIES=	www
XMASTER_SITES=	${MASTER_SITE_DEBIAN}
XMASTER_SITE_SUBDIR=	pool/main/m/${PORTNAME:S/_/-/g}
XPKGNAMESUFFIX=	_debian
XDISTNAME=${PORTNAME:S/_/-/g}_${PORTVERSION}.orig
X
XMAINTAINER=	mjonuschat@gmail.com
XCOMMENT=	Allows users to use MySQL databases for user authentication
X
XUSE_MYSQL=	YES
X
XRUN_DEPENDS+=	mysql:${PORTSDIR}/databases/mysql50-server
X
XWRKSRC=		${WRKDIR}/${PORTNAME:S/_/-/g}-${PORTVERSION}
X
XHAS_CONFIGURE=	YES
XCONFIGURE_ARGS=	--with-apxs=${APXS}
XMODULENAME=	mod_auth_mysql
X
XUSE_APACHE=	20+
X
XAP_FAST_BUILD=	YES
XAP_GENPLIST=	YES
XAP_INC=		${LOCALBASE}/include/mysql
XAP_LIB=		${LOCALBASE}/lib/mysql
XAP_EXTRAS=	-DAPACHE2 -lmysqlclient -lz -lm
X
X.if !defined(NOPORTDOCS)
XPORTDOCS=	INSTALL DIRECTIVES USAGE
X.endif
X
Xpost-install:
X.if !defined(NOPORTDOCS)
X	@${MKDIR} ${DOCSDIR}
X	@cd ${WRKSRC} && ${INSTALL_DATA} ${PORTDOCS} ${DOCSDIR}
X.endif
X
X.include <bsd.port.mk>
5b79d25101ca0df03ce36ae5abbf814f
echo x - mod_auth_mysql_debian/pkg-descr
sed 's/^X//' >mod_auth_mysql_debian/pkg-descr << 'c2bcb625571e8f991bc45c3da606748b'
XA module for the Apache 2 web server which enables HTTP authentication
Xagainst information stored in a MySQL database.
X
XThere are a few different mod_auth_mysql modules in the ports tree. Some
Xonly work with apache 1.3, some haven't been updated or maintained for a few
Xyears.
X
XThis version of mod_auth_mysql is being maintained within the current 
XDebian Linux development and sees regular maintainance and updates.
X
XWWW: http://packages.qa.debian.org/m/mod-auth-mysql.html
X
X- Morton Jonuschat
Xmjonuschat@gmail.com
c2bcb625571e8f991bc45c3da606748b
echo x - mod_auth_mysql_debian/distinfo
sed 's/^X//' >mod_auth_mysql_debian/distinfo << 'd3dde000e2cd710fff7fd26d1e5f6f70'
XMD5 (mod-auth-mysql_4.3.9.orig.tar.gz) = 9c1ecbe5fb64d4c93444311ff34bfe35
XSHA256 (mod-auth-mysql_4.3.9.orig.tar.gz) = ed0d42547808fe9a213cf62e93ffef65e518da774bb497138d126f2de4a54d2e
XSIZE (mod-auth-mysql_4.3.9.orig.tar.gz) = 48479
d3dde000e2cd710fff7fd26d1e5f6f70
exit



>Release-Note:
>Audit-Trail:
>Unformatted:



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200904242158.n3OLw2C7055066>