no problem anymore, that was a while back.  it's been working
correctly for quite some time.  if you check the later posts, I did
exactly what you suggest, and use session credentials.  it then had an
issue where it assumed that the form always called the fields "login"
and "password" so I overrode that behavior myself.  then
AuthenticatedPrincipalFactory doesn't actually adapt a principal back
to the type of principal you originally sent in, but instead sends you
back an IPrincipal, rather than derived version.  so I built my own
Authenticated factory as well, to get back a principal with my own,
extra attributes.

as far as the "login/password" fields issue, I'm pretty sure Florian
submitted a fix for that back to svn a while back as well.

Thanks for the answer though!

On 6/1/06, Stephan Richter <[EMAIL PROTECTED]> wrote:
On Wednesday 12 April 2006 12:54, Pete Taylor wrote:
> i have built a credentials plugin and an authenticator plugin, and set
> them up in my PAU. i built the credentials plugin such that if no
> credentials a recieved in the request, it checks the cookies for the
> expected credentials, and if they're there, builds the necessary
> credentials dict out of that instead, and returns that back for the
> authenticator plugin to use.

Aehm, this is exactly what the SessionCredentials do.

> the login logic then, assuming a principal is infact returned from
> pau.authenticate(self.request) (either because the cookies have the
> credentials or the request did), returns back
> self.request.setPrincipal(principal) and sets the cookies for the next
> use (in the case that the credentials were found in the request, but
> hadn't been set yet).
>
> my login form's action looks like this:
>
> @form.action('Login')
> def handle_login_action(self, action, data):
> lsm = component.getSiteManager(context=self.context)
> pau = component.getUtility(IAuthentication, context=lsm)
> principal = pau.authenticate(self.request)
> if principal is not None:
> self.setCookies()
> #i've both used this and not used this...
> #doesn't seem to affect anything one way or the other
> self.request.setPrincipal(principal)

Why are you doing this by hand? The authentication service should do all of
this for you.

> as a bit of extra background, i have a viewlet that needs to be aware
> of request.principal. in tales, i did a bit of tracking of "where and
> when" the current self.request was aware of request.principal. the
> primary page view found request/principal/id every time. the viewlet
> could find request/principal/id in tales, but not in the viewlet class
> (a form.Form), even though self.request is super'd up through. i
> attempted, in the viewlet, to look at
> "self.__parent__.request.principal" since i set __parent__ to the view
> that comes in on __init__, and i know that view can see
> request.principal, since it shows up in tales every time.
>
> still no luck, it always throws AttributeError on request.principal.

All this will work, if you use PAU correctly.

I strongly suggest setting up a simple PAU, all with standard components. It
is really not that hard and work beautifully.

Regards,
Stephan
--
Stephan Richter
CBU Physics & Chemistry (B.S.) / Tufts Physics (Ph.D. student)
Web2k - Web Software Design, Development and Training



--
"All guilt is relative, loyalty counts, and never let your conscience
be your guide."
 - Lucas Buck, American Gothic
_______________________________________________
Zope3-users mailing list
Zope3-users@zope.org
http://mail.zope.org/mailman/listinfo/zope3-users

Reply via email to