<html><head><meta http-equiv="Content-Type" content="text/html charset=iso-8859-1"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div><br></div>Hi Morgan,<div><br></div><div><div><div>On 16/07/2013, at 1:02 AM, Morgan Fainberg <<a href="mailto:m@metacloud.com">m@metacloud.com</a>> wrote:</div><blockquote type="cite"><div class="gmail_quote">On Mon, Jul 15, 2013 at 1:06 AM, Kieran Spear <span dir="ltr"><<a href="mailto:kispear@gmail.com" target="_blank">kispear@gmail.com</a>></span> wrote:<br></div><br><div>Hi Kieran,</div><div><br></div><div>I'd be happy to help you with the backporting of this fix if you need any assistance.</div><div><br></div><div>Here are some quick answers to your questions:</div>
<div><br></div><div>1. The individual tokens are stored in independent keys in their entirety, since the memcache backend replaces the SQL backend. In the usertoken-<userid> we should only be storing the hashed value. It looks like there is a bug there (I'll check and get a fix proposed in gerrit today to address this).</div></blockquote><div><br></div>That's what it looks like. I've pushed out a one-line fix to hash the token data on our cloud and it works well.</div><div><br><blockquote type="cite">
<div><br></div><div>2. There has been a lot of discussion on this topic and some other solutions have been proposed (such as use a clock-mechanism to expire tokens, etc). However, to stay compatible with the current business logic, which requires the ability to revoke subsets of tokens for the user (instead. all tokens for the user on every change to the user's roles/project associations, etc), a list of current tokens for the user must be maintained. Ideally, the token list shouldn't ever be massive, meaning the extra calls to memcache should be limited. The general plan is to develop another approach to solve this issue without the need of keeping a user-token-list, but it just wasn't viewed as possible for Havana. Checking the first two tokens wouldn't exactly solve the issue, as tokens can in theory be requested with varying expiration times; this means that tokens in the middle of the list could be expired whereas the tokens at the start of the list are invalid.</div></blockquote><div><br></div>Thanks for your work in this area. Good point on the expiry times. I'm probably guilty of premature optimisation here anyway. Will work on back porting this shortly.</div><div><br></div><div>Kieran</div><div><br><blockquote type="cite">
<div><br></div><div>Keeping the expiry time low is definitely a good idea.</div><div><br></div><div><br></div><div>Let me know if you want any further details. I'd be happy to elaborate / fill-in more.</div><div><br>
</div><div>Cheers,</div><div>Morgan Fainberg</div>
_______________________________________________<br>OpenStack-dev mailing list<br><a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev<br></blockquote></div><br></div></body></html>