<div dir="ltr">Hello,<div><br></div><div>I make a follow-up on this thread as I received no feedback on my pac4j binding proposal.</div><div><br></div><div>Are you interested in this authentication library? Can we improve its design?</div><div><br></div><div>Thank you for your help</div><div><br></div><div>Regards,</div><div>Michaël</div></div><div class="gmail_extra"><br><div class="gmail_quote">2014-05-27 20:02 GMT+02:00 Michaël REMOND <span dir="ltr"><<a href="mailto:michaelremond@gmail.com" target="_blank">michaelremond@gmail.com</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hello dear Community,<div><br></div><div>I made a first draft of what could be a pac4j binding for Undertow. You can find our standard demo application here <a href="https://github.com/pac4j/undertow-pac4j-demo" target="_blank">https://github.com/pac4j/undertow-pac4j-demo</a>. You can test several different authentication providers (facebook, twitter, form, CAS, SAML...).</div>
<div><br></div><div>I'd like to share some implementation details with you:</div><div> - I implemented a new AuthenticationMechanism delegating the authentication to a pac4j client; so this mechanism is rather "generic" in regards to what you got in undertow (one for basic auth, one for form...)</div>
<div> - pac4j needs a session mechanism so I used the Undertow SessionManager to store some attributes but also the User Profile once the user is successfully authenticated</div><div> - pac4j also needs a callback url to finish the authentication process so I developped a dedicated handler</div>
<div> - finally I used the EagerFormParsingHandler to grab the required POSTed data</div><div><br></div><div>To conclude I have to say I really appreciated the maturity of the framework because it was pretty straightforward to play with all the concepts and the ability to change from the IO thread to the dispatcher is really powerfull.</div>
<div><br></div><div>Jérôme and I are really interrested to get your feedback on this work. Does this binding makes sense to you? How can we improve this work to fit perfectly in Undertow and how can we extract a viable library from the demo?</div>
<div><br></div><div>Thank you for your help,</div><div><br></div><div>Regards,</div><div>Michaël</div><div><br></div></div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><br><div class="gmail_quote">2014-05-13 15:01 GMT+02:00 Stuart Douglas <span dir="ltr"><<a href="mailto:sdouglas@redhat.com" target="_blank">sdouglas@redhat.com</a>></span>:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">This does sound pretty cool. I would start by looking at the existing authenticator implementations and the security docs at<br>
<br>
<a href="http://undertow.io/documentation/core/security.html" target="_blank">http://undertow.io/<u></u>documentation/core/security.<u></u>html</a><br>
<br>
Stuart<br>
<br>
Michaël REMOND wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div>
Hi,<br>
<br>
I currently contribute to a Java library from Jerome Leleu, able to<br>
protect applications and delegate authentications to various identity<br>
providers. It currently supports 5 different protocols: CAS, OAuth,<br>
OpenID, HTTP and SAML and 18 identity providers (Facebook, Twitter,<br>
Google, Yahoo...) through a very simple and unified API accross<br>
protocols/JVM frameworks: <a href="https://github.com/leleuj/pac4j" target="_blank">https://github.com/leleuj/<u></u>pac4j</a>.<br>
<br>
The pac4j librairies are used in various JVM frameworks with the<br>
appropriate implementations: Spring Security, Shiro, CAS, J2E and Play.<br>
Although the core pac4j librairies gathers "a lot of" code (300 classes,<br>
26000 lines of source code), the implementations to specific JVM<br>
frameworks are pretty straigtforward: from 4 classes for Spring Security<br>
to 11 classes for Play Framework 2.x.<br>
<br>
We are currently targeting new plateforms and especially async one; we<br>
got an implementation from ratpack (<a href="http://www.ratpack.io/" target="_blank">http://www.ratpack.io/</a>) and we<br>
discussed also with the guys from vert.x. They gave us some ideas in<br>
order to improve our library by becoming more "reactive".<br>
<br>
I think that pac4j could be helpful for the Undertow community too by<br>
bringing client multi-protocols support.<br>
<br>
I looked at the security model from Undertow and I start to think about<br>
a possible integration by developing a "Pac4jAuthenticationMechanism"<u></u>.<br>
<br>
What do you think about such development? Are you interested in a demo<br>
app showing how this could work? Do you have suggestions?<br>
<br>
Thanks.<br>
Best regards,<br>
Michael Remond<br>
<br></div></div><div>
______________________________<u></u>_________________<br>
undertow-dev mailing list<br>
<a href="mailto:undertow-dev@lists.jboss.org" target="_blank">undertow-dev@lists.jboss.org</a><br>
<a href="https://lists.jboss.org/mailman/listinfo/undertow-dev" target="_blank">https://lists.jboss.org/<u></u>mailman/listinfo/undertow-dev</a><br>
</div></blockquote>
</blockquote></div><br></div>
</div></div></blockquote></div><br></div>