<html><body><div style="color:#000; background-color:#fff; font-family:times new roman, new york, times, serif;font-size:13px"><div><span></span></div><div id="yui_3_16_0_1_1430389558890_4636">Bill - That would be an issue for us&nbsp;as we cannot manipulate the values (especially username) sent by an external IDP which is the authoritative source of user information. We will have to figure out another way, perhaps, an internal KC user attribute that&nbsp;can be made unique to prevent name clashes.</div><div id="yui_3_16_0_1_1430389558890_4638"><br></div><div id="yui_3_16_0_1_1430389558890_4640">Thanks,</div><div id="yui_3_16_0_1_1430389558890_4639">Raghu<br>&nbsp; </div><div id="yui_3_16_0_1_1430389558890_4602" style="font-family: times new roman, new york, times, serif; font-size: 13px;"> <div id="yui_3_16_0_1_1430389558890_4601" style="font-family: HelveticaNeue, Helvetica Neue, Helvetica, Arial, Lucida Grande, sans-serif; font-size: 16px;"> <div id="yui_3_16_0_1_1430389558890_4600" dir="ltr"> <hr size="1" id="yui_3_16_0_1_1430389558890_4603">  <font id="yui_3_16_0_1_1430389558890_4599" face="Arial" size="2"> <b><span style="font-weight: bold;">From:</span></b> Bill Burke &lt;bburke@redhat.com&gt;<br> <b><span style="font-weight: bold;">To:</span></b> Henk Laracker &lt;Henk.Laracker@planonsoftware.com&gt;; "keycloak-user@lists.jboss.org" &lt;keycloak-user@lists.jboss.org&gt; <br> <b><span style="font-weight: bold;">Sent:</span></b> Thursday, April 30, 2015 7:26 PM<br> <b><span style="font-weight: bold;">Subject:</span></b> Re: [keycloak-user] IDP SAMLV2.0 with Salesforce<br> </font> </div> <div class="y_msg_container" id="yui_3_16_0_1_1430389558890_4657"><br>Right now, the username is prefixed with the broker name.&nbsp; THis is to<br clear="none">avoid name clashes if you are brokering multiple IDPS (i.e. multiple<br clear="none">social providers).<br clear="none"><br clear="none">On 4/30/2015 2:51 PM, Henk Laracker wrote:<br clear="none">&gt; Hi Bill,<br clear="none">&gt; <br clear="none">&gt; Thank you this worked out! I user is created with my name<br clear="none">&gt; <a href="mailto:saml.henk.laracker@p" shape="rect" ymailto="mailto:saml.henk.laracker@p">saml.henk.laracker@p</a>***n.nl , do you have any idee why the “saml” prefix<br clear="none">&gt; is added?<br clear="none">&gt; <br clear="none">&gt; <br clear="none">&gt; Henk<br clear="none">&gt; <br clear="none">&gt; On 30/04/15 18:44, "Bill Burke" &lt;<a href="mailto:bburke@redhat.com" shape="rect" ymailto="mailto:bburke@redhat.com">bburke@redhat.com</a>&gt; wrote:<br clear="none">&gt; <br clear="none">&gt;&gt; Ok, I was able to get this to work.&nbsp; The problem was I had to set a<br clear="none">&gt;&gt; "profile" for the connected app on Salesforce.&nbsp; I added a "System<br clear="none">&gt;&gt; Adminstrator" profile to the Connected App and it worked.<br clear="none">&gt;&gt;<br clear="none">&gt;&gt; I'm not sure how to upload a app certificate yet.&nbsp; Not sure what format<br clear="none">&gt;&gt; Salesforce is looking for.<br clear="none">&gt;&gt;<br clear="none">&gt;&gt; On 4/30/2015 11:39 AM, Bill Burke wrote:<br clear="none">&gt;&gt;&gt; I set up a salesforce example and looked at the login response SAML<br clear="none">&gt;&gt;&gt; document.&nbsp; Looks like no assertion data is being sent back at all by<br clear="none">&gt;&gt;&gt; salesforce.<br clear="none">&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt; On 4/30/2015 9:43 AM, Bill Burke wrote:<br clear="none">&gt;&gt;&gt;&gt; i have no idea.&nbsp; Basically this error is stating that the login<br clear="none">&gt;&gt;&gt;&gt; response<br clear="none">&gt;&gt;&gt;&gt; saml document has no assertions within it.&nbsp; If there are no assertions,<br clear="none">&gt;&gt;&gt;&gt; then there has been no identity data sent.<br clear="none">&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt; I'm looking now, but can you send me a link on how to set up Salesforce<br clear="none">&gt;&gt;&gt;&gt; as an IDP?&nbsp; Is one able to set up a free account and such?<br clear="none">&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt; On 4/30/2015 9:25 AM, Henk Laracker wrote:<br clear="none">&gt;&gt;&gt;&gt;&gt; Hi Bill,<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; I don¹t know why I missed that, thanks! Salesforce respons know with<br clear="none">&gt;&gt;&gt;&gt;&gt; the<br clear="none">&gt;&gt;&gt;&gt;&gt; correct login page. After logging in in Salesforce, I¹m redirected to<br clear="none">&gt;&gt;&gt;&gt;&gt; keycloak again with a internal error:<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; Caused by: org.keycloak.broker.provider.IdentityBrokerException:<br clear="none">&gt;&gt;&gt;&gt;&gt; Could not<br clear="none">&gt;&gt;&gt;&gt;&gt; process response from SAML identity provider.<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.keycloak.broker.saml.SAMLEndpoint$Binding.handleLoginResponse(SAMLE<br clear="none">&gt;&gt;&gt;&gt;&gt; ndpo<br clear="none">&gt;&gt;&gt;&gt;&gt; int.java:299)<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.keycloak.broker.saml.SAMLEndpoint$Binding.handleSamlResponse(SAMLEn<br clear="none">&gt;&gt;&gt;&gt;&gt; dpoi<br clear="none">&gt;&gt;&gt;&gt;&gt; nt.java:343)<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.keycloak.broker.saml.SAMLEndpoint$Binding.execute(SAMLEndpoint.java<br clear="none">&gt;&gt;&gt;&gt;&gt; :169<br clear="none">&gt;&gt;&gt;&gt;&gt; )<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.keycloak.broker.saml.SAMLEndpoint.postBinding(SAMLEndpoint.java:117<br clear="none">&gt;&gt;&gt;&gt;&gt; )<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)<br clear="none">&gt;&gt;&gt;&gt;&gt; [rt.jar:1.8.0_45]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.ja<br clear="none">&gt;&gt;&gt;&gt;&gt; va:6<br clear="none">&gt;&gt;&gt;&gt;&gt; 2) [rt.jar:1.8.0_45]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccesso<br clear="none">&gt;&gt;&gt;&gt;&gt; rImp<br clear="none">&gt;&gt;&gt;&gt;&gt; l.java:43) [rt.jar:1.8.0_45]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at java.lang.reflect.Method.invoke(Method.java:497) [rt.jar:1.8.0_45]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.jboss.resteasy.core.MethodInjectorImpl.invoke(MethodInjectorImpl.ja<br clear="none">&gt;&gt;&gt;&gt;&gt; va:1<br clear="none">&gt;&gt;&gt;&gt;&gt; 37) [resteasy-jaxrs-3.0.10.Final.jar:]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.jboss.resteasy.core.ResourceMethodInvoker.invokeOnTarget(ResourceMe<br clear="none">&gt;&gt;&gt;&gt;&gt; thod<br clear="none">&gt;&gt;&gt;&gt;&gt; Invoker.java:296) [resteasy-jaxrs-3.0.10.Final.jar:]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.jboss.resteasy.core.ResourceMethodInvoker.invoke(ResourceMethodInvo<br clear="none">&gt;&gt;&gt;&gt;&gt; ker.<br clear="none">&gt;&gt;&gt;&gt;&gt; java:250) [resteasy-jaxrs-3.0.10.Final.jar:]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.jboss.resteasy.core.ResourceLocatorInvoker.invokeOnTargetObject(Res<br clear="none">&gt;&gt;&gt;&gt;&gt; ourc<br clear="none">&gt;&gt;&gt;&gt;&gt; eLocatorInvoker.java:140) [resteasy-jaxrs-3.0.10.Final.jar:]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.jboss.resteasy.core.ResourceLocatorInvoker.invoke(ResourceLocatorIn<br clear="none">&gt;&gt;&gt;&gt;&gt; voke<br clear="none">&gt;&gt;&gt;&gt;&gt; r.java:109) [resteasy-jaxrs-3.0.10.Final.jar:]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.jboss.resteasy.core.ResourceLocatorInvoker.invokeOnTargetObject(Res<br clear="none">&gt;&gt;&gt;&gt;&gt; ourc<br clear="none">&gt;&gt;&gt;&gt;&gt; eLocatorInvoker.java:135) [resteasy-jaxrs-3.0.10.Final.jar:]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.jboss.resteasy.core.ResourceLocatorInvoker.invoke(ResourceLocatorIn<br clear="none">&gt;&gt;&gt;&gt;&gt; voke<br clear="none">&gt;&gt;&gt;&gt;&gt; r.java:103) [resteasy-jaxrs-3.0.10.Final.jar:]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatc<br clear="none">&gt;&gt;&gt;&gt;&gt; her.<br clear="none">&gt;&gt;&gt;&gt;&gt; java:356) [resteasy-jaxrs-3.0.10.Final.jar:]<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; ... 39 more<br clear="none">&gt;&gt;&gt;&gt;&gt; Caused by: org.keycloak.broker.provider.IdentityBrokerException: No<br clear="none">&gt;&gt;&gt;&gt;&gt; assertion from response.<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.keycloak.broker.saml.SAMLEndpoint$Binding.getAssertion(SAMLEndpoint<br clear="none">&gt;&gt;&gt;&gt;&gt; .jav<br clear="none">&gt;&gt;&gt;&gt;&gt; a:309)<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; at<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; org.keycloak.broker.saml.SAMLEndpoint$Binding.handleLoginResponse(SAMLE<br clear="none">&gt;&gt;&gt;&gt;&gt; ndpo<br clear="none">&gt;&gt;&gt;&gt;&gt; int.java:264)<br clear="none">&gt;&gt;&gt;&gt;&gt; &nbsp;&nbsp;&nbsp; ... 54 more<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; Any idea?<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; Henk<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt; On 30/04/15 14:31, "Bill Burke" &lt;<a href="mailto:bburke@redhat.com" shape="rect" ymailto="mailto:bburke@redhat.com">bburke@redhat.com</a>&gt; wrote:<br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; You want to chain keycloak server to Salesforce?<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; If you create a SAMLv2 IdentityProvider in keycloak that points to<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; Salesforce, you;ll see after you create it, an Export button.&nbsp; Click<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; that.&nbsp; That will create an entity descriptor with all the information<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; you need.<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; On 4/30/2015 2:45 AM, Henk Laracker wrote:<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; Hi,<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; I like to use Salesforce as Identity Provider, the metadata<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; provided by<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; salesforce can be imported.<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; But I need to specify the Service Provider in salesforce, I have to<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; fill<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; in a couple of fields, but two of them I don¹t understand (and are<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; mandatory). Does someone have any clue<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;&nbsp; &nbsp; &nbsp; 1. entity id , remark of salesforce : get this value from your<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;&nbsp; &nbsp; &nbsp; &nbsp;  serviceprovider<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;&nbsp; &nbsp; &nbsp; 2. ACS URL, remark of slaesforce : The assertion consumer<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; service. Get<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;&nbsp; &nbsp; &nbsp; &nbsp;  this value from your service provider.<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; I have tried a lot of values but every-time I click the saml button<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; on<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; my app, it redirects to salesforce but I get a page with the error :<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; Error: Unable to resolve request into a Service Provider<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; Henk<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; _______________________________________________<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; keycloak-user mailing list<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; <a href="mailto:keycloak-user@lists.jboss.org" shape="rect" ymailto="mailto:keycloak-user@lists.jboss.org">keycloak-user@lists.jboss.org</a><br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/keycloak-user" target="_blank" shape="rect">https://lists.jboss.org/mailman/listinfo/keycloak-user</a><br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; --<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; Bill Burke<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; JBoss, a division of Red Hat<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; <a href="http://bill.burkecentral.com/" target="_blank" shape="rect">http://bill.burkecentral.com</a><div class="qtdSeparateBR"><br><br></div><div class="yqt4376269470" id="yqtfd63889"><br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; _______________________________________________<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; keycloak-user mailing list<br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; <a href="mailto:keycloak-user@lists.jboss.org" shape="rect" ymailto="mailto:keycloak-user@lists.jboss.org">keycloak-user@lists.jboss.org</a><br clear="none">&gt;&gt;&gt;&gt;&gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/keycloak-user" target="_blank" shape="rect">https://lists.jboss.org/mailman/listinfo/keycloak-user</a><br clear="none">&gt;&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;&gt;<br clear="none">&gt;&gt;&gt;<br clear="none">&gt;&gt;<br clear="none">&gt;&gt; -- <br clear="none">&gt;&gt; Bill Burke<br clear="none">&gt;&gt; JBoss, a division of Red Hat<br clear="none">&gt;&gt; <a href="http://bill.burkecentral.com/" target="_blank" shape="rect">http://bill.burkecentral.com</a><br clear="none">&gt;&gt; _______________________________________________<br clear="none">&gt;&gt; keycloak-user mailing list<br clear="none">&gt;&gt; <a href="mailto:keycloak-user@lists.jboss.org" shape="rect" ymailto="mailto:keycloak-user@lists.jboss.org">keycloak-user@lists.jboss.org</a><br clear="none">&gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/keycloak-user" target="_blank" shape="rect">https://lists.jboss.org/mailman/listinfo/keycloak-user</a><br clear="none">&gt; <br clear="none"><br clear="none">-- <br clear="none">Bill Burke<br clear="none">JBoss, a division of Red Hat<br clear="none"><a href="http://bill.burkecentral.com/" target="_blank" shape="rect">http://bill.burkecentral.com</a><br clear="none">_______________________________________________<br clear="none">keycloak-user mailing list<br clear="none"><a href="mailto:keycloak-user@lists.jboss.org" shape="rect" ymailto="mailto:keycloak-user@lists.jboss.org">keycloak-user@lists.jboss.org</a><br clear="none"><a href="https://lists.jboss.org/mailman/listinfo/keycloak-user" target="_blank" shape="rect">https://lists.jboss.org/mailman/listinfo/keycloak-user</a></div><br><br></div> </div> </div>  </div></body></html>