X-Git-Url: https://git.adam-barratt.org.uk/?a=blobdiff_plain;f=search.cgi;h=37695386b8bbde31bc82e6e303219247c776d582;hb=2833afc99423e6cc0abe0fa6d0fafbf9275c8f2d;hp=9a38e3e93d9af5e62a7c94a9142b4d662de38c45;hpb=784c4020017d260775339c1231052ca4eb387f02;p=mirror%2Fuserdir-ldap-cgi.git
diff --git a/search.cgi b/search.cgi
index 9a38e3e..3769538 100755
--- a/search.cgi
+++ b/search.cgi
@@ -17,11 +17,11 @@ use Net::LDAP qw(LDAP_SUCCESS LDAP_PROTOCOL_ERROR);
my %config = &Util::ReadConfigFile;
my $query = new CGI;
-my $id = $query->param('id');
+my $id = uri_escape($query->param('id'));
my $authtoken = $query->param('authtoken');
my $password = &Util::CheckAuthToken($authtoken);
-my $dosearch = $query->param('dosearch');
-my $searchdn = $query->param('searchdn');
+my $dosearch = uri_escape($query->param('dosearch'));
+my $searchdn = uri_escape($query->param('searchdn'));
my $ldap = undef;
my $proto = ($ENV{HTTPS} ? "https" : "http");
@@ -61,7 +61,7 @@ if (!$dosearch) {
# go through %searchdata and pull out all the search criteria the user
# specified...
- my $filter = "(objectclass=inetOrgPerson)";
+ my $filter = "(objectclass=inetOrgPerson)(!(accountStatus=*))";
foreach (keys(%searchdata)) {
if ($query->param($searchdata{$_}{formname})) {
if ($query->param($searchdata{$_}{fuzzy})) {
@@ -236,7 +236,7 @@ if (!$dosearch) {
# If this is ourselves, present a link to do mods
if ($auth && ($id eq $data->{uid}->[0])) { #TODO: extract this string into a url for translation...
- $outsub{searchresults} .= "Edit my settings\n";
+ $outsub{searchresults} .= "Edit my settings\n";
}
$outsub{searchresults} .= "
\n";