mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-24 21:50:53 +00:00 
			
		
		
		
	Support both MySQL and traditional mailboxes in vmail.cgi (bug #2297)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@3781 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		| @@ -14,6 +14,7 @@ | ||||
| use CGI qw/:standard/; | ||||
| use Carp::Heavy; | ||||
| use CGI::Carp qw(fatalsToBrowser); | ||||
| use DBI; | ||||
|  | ||||
| $context=""; # Define here your by default context (so you dont need to put voicemail@context in the login | ||||
|  | ||||
| @@ -103,6 +104,28 @@ sub check_login() | ||||
| 			} | ||||
| 		} elsif (/\[(.*)\]/) { | ||||
| 			$category = $1; | ||||
|                 } elsif ($category eq "general") { | ||||
|                         if (/([^\s]+)\s*\=\s*(.*)/) { | ||||
|                                 if ($1 eq "dbname") { | ||||
|                                         $dbname = $2; | ||||
|                                 } elsif ($1 eq "dbpass") { | ||||
|                                         $dbpass = $2; | ||||
|                                 } elsif ($1 eq "dbhost") { | ||||
|                                         $dbhost = $2; | ||||
|                                 } elsif ($1 eq "dbuser") { | ||||
|                                         $dbuser = $2; | ||||
|                                 } | ||||
|                         } | ||||
|                         if ($dbname and $dbpass and $dbhost and $dbuser) { | ||||
|  | ||||
|                                 # db variables are present.  Use db for authentication. | ||||
|                                 my $dbh = DBI->connect("DBI:mysql:$dbname:$dbhost",$dbuser,$dbpass); | ||||
|                                 my $sth = $dbh->prepare(qq{select fullname,context from users where mailbox='$mbox' and password='$pass' and context='$context'}); | ||||
|                                 $sth->execute(); | ||||
|                                 if (($fullname, $category) = $sth->fetchrow_array()) {; | ||||
|                                         return ($fullname ? $fullname : "Extension $mbox in $context",$category); | ||||
|                                 } | ||||
|                         } | ||||
| 		} elsif (($category ne "general") && ($category ne "zonemessages")) {  | ||||
| 			if (/([^\s]+)\s*\=\>?\s*(.*)/) { | ||||
| 				@fields = split(/\,\s*/, $2); | ||||
| @@ -145,6 +168,28 @@ sub validmailbox() | ||||
| 			} | ||||
| 		} elsif (/\[(.*)\]/) { | ||||
| 			$category = $1; | ||||
|                 } elsif ($category eq "general") { | ||||
|                         if (/([^\s]+)\s*\=\s*(.*)/) { | ||||
|                                 if ($1 eq "dbname") { | ||||
|                                         $dbname = $2; | ||||
|                                 } elsif ($1 eq "dbpass") { | ||||
|                                         $dbpass = $2; | ||||
|                                 } elsif ($1 eq "dbhost") { | ||||
|                                         $dbhost = $2; | ||||
|                                 } elsif ($1 eq "dbuser") { | ||||
|                                         $dbuser = $2; | ||||
|                                 } | ||||
|                         } | ||||
|                         if ($dbname and $dbpass and $dbhost and $dbuser) { | ||||
|  | ||||
|                                 # db variables are present.  Use db for authentication. | ||||
|                                 my $dbh = DBI->connect("DBI:mysql:$dbname:$dbhost",$dbuser,$dbpass); | ||||
|                                 my $sth = $dbh->prepare(qq{select fullname,context from users where mailbox='$mbox' and password='$pass' and context='$context'}); | ||||
|                                 $sth->execute(); | ||||
| 				if (($fullname, $category) = $sth->fetchrow_array()) {; | ||||
|                                         return ($fullname ? $fullname : "unknown", $category); | ||||
|                                 } | ||||
|                         } | ||||
| 		} elsif (($category ne "general") && ($category ne "zonemessages") && ($category eq $context)) { | ||||
| 			if (/([^\s]+)\s*\=\>?\s*(.*)/) { | ||||
| 				@fields = split(/\,\s*/, $2); | ||||
| @@ -181,6 +226,37 @@ sub mailbox_options() | ||||
| 			$tmp .= $tmp2; | ||||
| 		} elsif (/\[(.*)\]/) { | ||||
| 			$category = $1; | ||||
|                 } elsif ($category eq "general") { | ||||
|                         if (/([^\s]+)\s*\=\s*(.*)/) { | ||||
|                                 if ($1 eq "dbname") { | ||||
|                                         $dbname = $2; | ||||
|                                 } elsif ($1 eq "dbpass") { | ||||
|                                         $dbpass = $2; | ||||
|                                 } elsif ($1 eq "dbhost") { | ||||
|                                         $dbhost = $2; | ||||
|                                 } elsif ($1 eq "dbuser") { | ||||
|                                         $dbuser = $2; | ||||
|                                 } | ||||
|                         } | ||||
|                         if ($dbname and $dbpass and $dbhost and $dbuser) { | ||||
|  | ||||
|                                 # db variables are present.  Use db for authentication. | ||||
|                                 my $dbh = DBI->connect("DBI:mysql:$dbname:$dbhost",$dbuser,$dbpass); | ||||
|                                 my $sth = $dbh->prepare(qq{select mailbox,fullname,context from users where context='$context' order by mailbox}); | ||||
|                                 $sth->execute(); | ||||
|                                 while (($mailbox, $fullname, $category) = $sth->fetchrow_array()) { | ||||
|                                         $text = $mailbox; | ||||
|                                         if ($fullname) { | ||||
|                                                 $text .= " (".$fullname.")"; | ||||
|                                         } | ||||
|                                         if ($mailbox eq $current) { | ||||
|                                                 $tmp .= "<OPTION SELECTED>$text</OPTION>\n"; | ||||
|                                         } else { | ||||
|                                                 $tmp .= "<OPTION>$text</OPTION>\n"; | ||||
|                                         } | ||||
|                                 } | ||||
|                                 return ($tmp, $category); | ||||
|                         } | ||||
| 		} elsif (($category ne "general") && ($category ne "zonemessages")) { | ||||
| 			if (/([^\s]+)\s*\=\>?\s*(.*)/) { | ||||
| 				@fields = split(/\,\s*/, $2); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user