<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div>Hello Daniel,</div><div>Thanks for your answer, unfortunately we still don't manage to connect with a server_* user on the behalf of another normal user.</div><div>This is basically what we do, let us know if we do something wrong:</div><div><br></div><div>{ </div><div>  string expires = DateTime.Now.Subtract(new DateTime(1970,1,1,0,0,0, DateTimeKind.Utc)).TotalSeconds + 3600 + "";</div><div>  string token_encrypted = Encrypt(this.AdminUsername + ":" + this.TargetUsername + ":" + expires, this.AdminPassword);</div><div>  //this.AdminUsername = server_* user name</div><div>  //this.TargetUsername = normal user name (target user)</div><div>  //this.AdminPassword = server_* user password (SHA1 encrypted)</div><div>  //Encrypt do the equivalent of the AES 256 CBC openssl encryption (cf <a href="https://gist.github.com/scottlowe/1411917">https://gist.github.com/scottlowe/1411917</a>, we just removed the salt part)</div><div>  session_SHA = this.AdminUsername + ":" + this.TargetUsername + ":" + token_encrypted;</div><div>  //session_SHA is the token used to authenticate on a request</div><div>}</div><div><br></div><div>Thanks</div><div>Best regards</div><div><br></div><div><br></div><div><br></div><div><br></div><div apple-content-edited="true">
<span class="Apple-style-span" style="border-collapse: separate; border-spacing: 0px;"><span class="Apple-style-span" style="border-collapse: separate; font-variant: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; "><font class="Apple-style-span" face="Verdana" size="2" color="#a2a2a2"><div>Enguerran Boissier</div><div><a href="http://www.terradue.com">www.terradue.com</a></div></font></span><br class="Apple-interchange-newline"><span></span><span></span><span></span><span style="color: rgb(0, 0, 0); font-family: Helvetica;  font-weight: normal; font-style: normal; "></span><span><img height="41" width="132" apple-inline="yes" id="84C1AED2-B787-4221-B1EB-D0948F133FFB" apple-width="yes" apple-height="yes" src="cid:0CDA2A7B-17B1-464F-B3C8-1E7154FBC33A@office.terradue.int"></span>
</span></div>
<br><div><div>On 28 Jul 2014, at 10:45, Daniel Molina <<a href="mailto:dmolina@opennebula.org">dmolina@opennebula.org</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div dir="ltr">Hi Cesare,<br><br>The server_* authentication is a special method where a user can authenticate on behalf of other user. This method was included in OpenNebula for scenarios such as an Apache server configured to use x509 certificates, Apache has already authenticated the user and we just encrypt a token with the serveradmin credentials and OpenNebula will decrypt the token and will perform all the actions as the target_username.<br>

<br>Users using the server_* auth method are special users and should not have any resource.<br><br>You can see an example on how Sunstone uses this method:<br>A user logs in:<br><a href="https://github.com/OpenNebula/one/blob/master/src/sunstone/sunstone-server.rb#L169">https://github.com/OpenNebula/one/blob/master/src/sunstone/sunstone-server.rb#L169</a><div>

do_auth is called to authenticate the user:<br><a href="https://github.com/OpenNebula/one/blob/master/src/cloud/common/CloudAuth/SunstoneCloudAuth.rb#L18">https://github.com/OpenNebula/one/blob/master/src/cloud/common/CloudAuth/SunstoneCloudAuth.rb#L18</a></div>

<div>a token is generated using the server_* method<br><a href="https://github.com/OpenNebula/one/blob/master/src/authm_mad/remotes/server_cipher/server_cipher_auth.rb#L85">https://github.com/OpenNebula/one/blob/master/src/authm_mad/remotes/server_cipher/server_cipher_auth.rb#L85</a></div>

<div>this info is sent to one and then checked by the auth driver:<br><a href="https://github.com/OpenNebula/one/blob/master/src/authm_mad/remotes/server_cipher/server_cipher_auth.rb#L110">https://github.com/OpenNebula/one/blob/master/src/authm_mad/remotes/server_cipher/server_cipher_auth.rb#L110</a></div>

<div><br>Hope this helps<br><br><a href="http://docs.opennebula.org/4.6/administration/sunstone_gui/cloud_auth.html">http://docs.opennebula.org/4.6/administration/sunstone_gui/cloud_auth.html</a><div><br></div><div><br></div>

<div class="gmail_extra"><br><br><div class="gmail_quote">On 25 July 2014 12:39, Cesare Rossi <span dir="ltr"><<a href="mailto:cesare.rossi@terradue.com" target="_blank">cesare.rossi@terradue.com</a>></span> wrote:<br>


<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><div>Dear All,</div><div><br></div><div>we are interacting with the XML-RPC API. We are trying to perform the special authentication method available with the users' drivers <i>server_cipher</i> or <i>server_x509 </i>(i.e. using username:target_username:secret), but it seems not working.</div>


<div><br></div><div>The question is: is it possible to use with that API such kind of users ? If yes, how ?</div><div><br></div><div>Thanks in advance,</div><div><br></div><div>Cheers</div><span><font color="#888888"><br>


<div>
<div>Cesare Rossi</div><div>Terradue</div><div>Rome, Italy | Oxford, UK</div><div><a href="http://www.terradue.com/" target="_blank">http://www.terradue.com</a></div><div><br></div><br>

</div>
<br>
</font></span></div><br>_______________________________________________<br>
Dev mailing list<br>
<a href="mailto:Dev@lists.opennebula.org" target="_blank">Dev@lists.opennebula.org</a><br>
<a href="http://lists.opennebula.org/listinfo.cgi/dev-opennebula.org" target="_blank">http://lists.opennebula.org/listinfo.cgi/dev-opennebula.org</a><br>
<br></blockquote></div><br><br clear="all"><div><br></div>-- <br><div dir="ltr"><div>--<br></div>Daniel Molina<br>Project Engineer<br>OpenNebula - Flexible Enterprise Cloud Made Simple<br><a href="http://www.opennebula.org/" target="_blank">www.OpenNebula.org</a> | <a href="mailto:dmolina@opennebula.org" target="_blank">dmolina@opennebula.org</a> | @OpenNebula</div>



</div></div></div>
</blockquote></div><br></body></html>