diff options
Diffstat (limited to 'zarb-ml/mageia-sysadm/2010-November/000917.html')
-rw-r--r-- | zarb-ml/mageia-sysadm/2010-November/000917.html | 158 |
1 files changed, 158 insertions, 0 deletions
diff --git a/zarb-ml/mageia-sysadm/2010-November/000917.html b/zarb-ml/mageia-sysadm/2010-November/000917.html new file mode 100644 index 000000000..0397799a1 --- /dev/null +++ b/zarb-ml/mageia-sysadm/2010-November/000917.html @@ -0,0 +1,158 @@ +<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2//EN"> +<HTML> + <HEAD> + <TITLE> [Mageia-sysadm] [139] Dont hardcode filters, but use user's store configuration + </TITLE> + <LINK REL="Index" HREF="index.html" > + <LINK REL="made" HREF="mailto:mageia-sysadm%40mageia.org?Subject=Re%3A%20%5BMageia-sysadm%5D%20%5B139%5D%20Dont%20hardcode%20filters%2C%0A%09but%20use%20user%27s%20store%20configuration&In-Reply-To=%3C20101125113451.78E743FD60%40valstar.mageia.org%3E"> + <META NAME="robots" CONTENT="index,nofollow"> + <META http-equiv="Content-Type" content="text/html; charset=us-ascii"> + <LINK REL="Previous" HREF="000916.html"> + <LINK REL="Next" HREF="000918.html"> + </HEAD> + <BODY BGCOLOR="#ffffff"> + <H1>[Mageia-sysadm] [139] Dont hardcode filters, but use user's store configuration</H1> + <B>root at mageia.org</B> + <A HREF="mailto:mageia-sysadm%40mageia.org?Subject=Re%3A%20%5BMageia-sysadm%5D%20%5B139%5D%20Dont%20hardcode%20filters%2C%0A%09but%20use%20user%27s%20store%20configuration&In-Reply-To=%3C20101125113451.78E743FD60%40valstar.mageia.org%3E" + TITLE="[Mageia-sysadm] [139] Dont hardcode filters, but use user's store configuration">root at mageia.org + </A><BR> + <I>Thu Nov 25 12:34:51 CET 2010</I> + <P><UL> + <LI>Previous message: <A HREF="000916.html">[Mageia-sysadm] Puppet Report for valstar.mageia.org +</A></li> + <LI>Next message: <A HREF="000918.html">[Mageia-sysadm] [140] Merge 138 from trunk, allow configurable login attribute +</A></li> + <LI> <B>Messages sorted by:</B> + <a href="date.html#917">[ date ]</a> + <a href="thread.html#917">[ thread ]</a> + <a href="subject.html#917">[ subject ]</a> + <a href="author.html#917">[ author ]</a> + </LI> + </UL> + <HR> +<!--beginarticle--> +<PRE>Revision: 139 +Author: buchan +Date: 2010-11-25 12:34:51 +0100 (Thu, 25 Nov 2010) +Log Message: +----------- +Dont hardcode filters, but use user's store configuration +This allows configuration of which user attribute to login with, by +only changing authentication configuration (e.g. in catdap_local.yml) + +Modified Paths: +-------------- + identity/CatDap/trunk/lib/CatDap/Controller/user.pm + +Modified: identity/CatDap/trunk/lib/CatDap/Controller/user.pm +=================================================================== +--- identity/CatDap/trunk/lib/CatDap/Controller/user.pm 2010-11-25 09:26:28 UTC (rev 138) ++++ identity/CatDap/trunk/lib/CatDap/Controller/user.pm 2010-11-25 11:34:51 UTC (rev 139) +@@ -126,6 +126,7 @@ + my $password; + my $mesg; + my $dn; ++ my $userfilter; + + if (not defined $c->user ) { + $c->stash(template => 'index.tt'); +@@ -140,8 +141,10 @@ + + my $user = $c->user->username; + my $entry; +- $c->log->debug("Searching for user $user"); +- $mesg = $c->model('User')->search("(&(objectclass=inetOrgPerson)(uid=$user))"); ++ $userfilter = $c->user->store->user_filter; ++ $userfilter =~ s/\%s/$user/g, ++ $c->log->debug("Searching for user $user with filter $userfilter"); ++ $mesg = $c->model('User')->search($userfilter); + $entry = $mesg->entry; + my %mods; + my %params = %{$c->req->parameters}; +@@ -165,7 +168,7 @@ + } + } + +- $mesg = $c->model('User')->search("(&(objectclass=inetOrgPerson)(uid=$user))"); ++ $mesg = $c->model('User')->search($userfilter); + $c->log->debug($mesg->error) if $mesg->code; + $entry = $mesg->entry; + $c->log->debug($mesg->error) if $mesg->code; +@@ -222,12 +225,14 @@ + + sub add : Local { + my ( $self, $c) = @_; +- my ($mesg,$entry,$user,$attr,$value); ++ my ($mesg,$entry,$user,$attr,$value,$userfilter); + $attr = $c->req->param('attribute'); + $value = $c->req->param('value'); + $user = $c->user->username; +- $c->log->debug("Searching for user $user"); +- $mesg = $c->model('User')->search("(&(objectclass=inetOrgPerson)(uid=$user))"); ++ $userfilter = $c->user->store->user_filter; ++ $userfilter = s/%s/$c->user->username/g; ++ $c->log->debug("Searching for user $user with $userfilter"); ++ $mesg = $c->model('User')->search($userfilter); + $entry = $mesg->entry; + $entry->add( $attr => $value); + $c->log->info("Adding $attr = $value to user $user"); +@@ -239,10 +244,12 @@ + + sub delete : Local : Args(2) { + my ( $self, $c, $attrname,$attrvalue) = @_; +- my ($mesg,$entry,$user); ++ my ($mesg,$entry,$user,$userfilter); + $user = $c->user->username; ++ $userfilter = $c->user->store->user_filter; ++ $userfilter =~ s/%s/$c->user->username/g; + $c->log->debug("Searching for user $user"); +- $mesg = $c->model('User')->search("(&(objectclass=inetOrgPerson)(uid=$user))"); ++ $mesg = $c->model('User')->search($userfilter); + $entry = $mesg->entry; + $c->log->info("Deleting $attrname = $attrvalue from user $user"); + $entry->delete($attrname => $attrvalue); +-------------- next part -------------- +An HTML attachment was scrubbed... +URL: </pipermail/mageia-sysadm/attachments/20101125/01989e65/attachment.html> +</PRE> + + + + + + + + + + + + + + + + + + + + + +<!--endarticle--> + <HR> + <P><UL> + <!--threads--> + <LI>Previous message: <A HREF="000916.html">[Mageia-sysadm] Puppet Report for valstar.mageia.org +</A></li> + <LI>Next message: <A HREF="000918.html">[Mageia-sysadm] [140] Merge 138 from trunk, allow configurable login attribute +</A></li> + <LI> <B>Messages sorted by:</B> + <a href="date.html#917">[ date ]</a> + <a href="thread.html#917">[ thread ]</a> + <a href="subject.html#917">[ subject ]</a> + <a href="author.html#917">[ author ]</a> + </LI> + </UL> + +<hr> +<a href="https://www.mageia.org/mailman/listinfo/mageia-sysadm">More information about the Mageia-sysadm +mailing list</a><br> +</body></html> |