<html><head>
<meta http-equiv="Content-Type" content="text/html; charset=Windows-1252"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; color: rgb(0, 0, 0); font-size: 14px; font-family: Calibri, sans-serif; "><div>Glad it's working for you.</div><div><br></div><div>As for 35357 vs 5000, 5000 is the standard endpoint for public requests. 35357 is the service endpoint that I usually use for bootstrapping and is used for admin and internal requests (from other services for example). If you get the service token from the keystone config file you can use the 35357 endpoint without a password or username. It's how you bootstrap your system or recover if you forgot the admin password.</div><div><br></div><div>You can use the service token like this without a password, username, or tenant set.</div><div><br></div><div>SERVICE_TOKEN=<value from file> SERVICE_ENDPOINT=<a href="http://foo:35357/v2.0">http://foo:35357/v2.0</a> keystone user-list</div><div><br></div><div><br></div><div><br></div><span id="OLK_SRC_BODY_SECTION"><div style="font-family:Calibri; font-size:11pt; text-align:left; color:black; BORDER-BOTTOM: medium none; BORDER-LEFT: medium none; PADDING-BOTTOM: 0in; PADDING-LEFT: 0in; PADDING-RIGHT: 0in; BORDER-TOP: #b5c4df 1pt solid; BORDER-RIGHT: medium none; PADDING-TOP: 3pt"><span style="font-weight:bold">From: </span> Jeff Silverman <<a href="mailto:jeff@sweetlabs.com">jeff@sweetlabs.com</a>><br><span style="font-weight:bold">Date: </span> Monday, August 4, 2014 6:23 PM<br><span style="font-weight:bold">To: </span> Abel Lopez <<a href="mailto:alopgeek@gmail.com">alopgeek@gmail.com</a>>, "<a href="mailto:openstack-operators@lists.openstack.org">openstack-operators@lists.openstack.org</a>" <<a href="mailto:openstack-operators@lists.openstack.org">openstack-operators@lists.openstack.org</a>><br><span style="font-weight:bold">Subject: </span> Re: [Openstack-operators] keystone is throwing Authorization Failed: 'module' object is not callable errors<br></div><div><br></div><div dir="ltr"><div class="gmail_default" style="font-family:'times new roman',serif">Abel,</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">
I tried that.  Unfortunately, the argument to the curl command is -d '{ "key1": "value", "password", "comp'cated" }' .  The ' character is significant in " delimited strings.  The \ is not significant in " delimited strings.  I spent about an hour playing with the echo command working this out.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">The solution that I came up with is -d @f.txt which means get the data from file f.txt.  Then I put </div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">{ "key1": "value", "password", "comp'cated" }<br></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">In the file f.txt.  Because f.txt isn't parsed by the shell, I can use special characters.  In fact, I can use binary characters, so if I want to pass a .jpeg file to the API (I have no idea why I'd want to do that, but work with me here), I could do that.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">
keystone has mysteriously started working.  I don't know why.  I added some debugging code to it, and it started working.  So then I took the debugging code out of it, and it's still working.  I don't believe that my changes made a difference.  Something else has changed, but I don't know what that might be.  I am going to do some more testing.  Very frustrating.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">
Everybody who has helped me: thank you so very much.  I really appreciate it.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">Jeff</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Mon, Aug 4, 2014 at 5:15 PM, Abel Lopez <span dir="ltr"><<a href="mailto:alopgeek@gmail.com" target="_blank">alopgeek@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">You made reference to a complex password in the configs, IIRC, ! ? $ may be interpreted by the shell, if you have those, escape them like this<div>
pa\$\$word<div><div class="h5"><span></span><br><br>On Monday, August 4, 2014, Jeff Silverman <<a href="mailto:jeff@sweetlabs.com" target="_blank">jeff@sweetlabs.com</a>> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_default" style="font-family:times new roman,serif">Abel,</div><div class="gmail_default" style="font-family:times new roman,serif"><br></div><div class="gmail_default" style="font-family:times new roman,serif">
Sticking a \ in front of what, exactly, please?   I'm still a newbie.</div><div class="gmail_default" style="font-family:times new roman,serif"><br></div><div class="gmail_default" style="font-family:times new roman,serif">


Thank you</div><div class="gmail_default" style="font-family:times new roman,serif"><br></div><div class="gmail_default" style="font-family:times new roman,serif"><br></div><div class="gmail_default" style="font-family:times new roman,serif">


Jeff</div><div class="gmail_default" style="font-family:times new roman,serif"><br></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Mon, Aug 4, 2014 at 3:48 PM, Abel Lopez <span dir="ltr"><<a>alopgeek@gmail.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">I’ve seen similar before, especially with $ and !, try sticking a \ in front, see if that helps<div><br><div><div><div><div>On Aug 4, 2014, at 2:51 PM, Jeff Silverman <<a>jeff@sweetlabs.com</a>> wrote:</div><br></div></div><blockquote type="cite"><div><div><div dir="ltr"><div class="gmail_default" style="font-family:'times new roman',serif">Matt,</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">



The --debug switch was most helpful.  Unfortunately, my co-worker picked a very secure password with special characters, and since the curl command -d switch has its arguments enclosed by ' and " I couldn't figure out how to escape the special characters that were tripping up the shell.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">However, I read the curl man page to see how it handled binary data (for example, if I wanted to upload a JPEG using curl) and I found an interesting wrinkle with the -d switch: if the next character is an @ character, then -d interpreters the string as a filename to get the data from.  So I created a file f.txt which contains</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default"><div class="gmail_default"><font face="courier new,monospace">{"auth": {"tenantName": "admin", "passwordCredentials": {"username": "admin", "password": "XXXXX>'MA/#Z9e?_T9_XXXX}}}</font></div><div style="font-family:'times new roman',serif"><br></div></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">



Then I used:</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default"><div class="gmail_default"><font face="courier new,monospace"># curl -i -X POST <a href="http://controller1-prod.sea.opencandy.com:5000/v2.0/tokens" target="_blank">http://controller1-prod.sea.opencandy.com:5000/v2.0/tokens</a> -H "Content-Type: application/json" -H "Accept: application/json" -H "User-Agent: python-keystoneclient" -d @f.txt</font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="times new roman,serif">and got </font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="courier new,monospace">HTTP/1.1 200 OK</font></div><div class="gmail_default"><font face="courier new,monospace">Vary: X-Auth-Token</font></div><div class="gmail_default"><font face="courier new,monospace">Content-Type: application/json</font></div><div class="gmail_default"><font face="courier new,monospace">Date: Mon, 04 Aug 2014 21:26:32 GMT</font></div><div class="gmail_default"><font face="courier new,monospace">Transfer-Encoding: chunked</font></div><div class="gmail_default"><font face="courier new,monospace"><br></font></div><div class="gmail_default"><font face="courier new,monospace">{"access": {"token": {"expires": "2014-08-05T21:26:32Z", ...}}}</font></div><div class="gmail_default"><font face="courier new,monospace"><br></font></div><div class="gmail_default"><font face="courier new,monospace"><br></font></div><div class="gmail_default"><font face="courier new,monospace"># curl -i -X POST <a href="http://controller1-prod.sea.opencandy.com:35357/v2.0/tokens" target="_blank">http://controller1-prod.sea.opencandy.com:35357/v2.0/tokens</a> -H "Content-Type: application/json" -H "Accept: application/json" -H "User-Agent: python-keystoneclient" -d @f.txt</font></div><div class="gmail_default"><font face="courier new,monospace">HTTP/1.1 200 OK</font></div><div class="gmail_default"><font face="courier new,monospace">Vary: X-Auth-Token</font></div><div class="gmail_default"><font face="courier new,monospace">Content-Type: application/json</font></div><div class="gmail_default"><font face="courier new,monospace">Date: Mon, 04 Aug 2014 21:29:31 GMT</font></div><div class="gmail_default"><font face="courier new,monospace">Transfer-Encoding: chunked</font></div><div class="gmail_default"><font face="courier new,monospace"><br></font></div><div class="gmail_default"><font face="courier new,monospace">{"access": {"token": {"expires": "2014-08-05T21:29:31Z", ....}}}</font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="times new roman,serif">Insofar as I can tell the outputs are the same except for some trivial changes in time stamps.  So what is supposed to be the difference between going through port 5000 and going through port 35357 ?  Obviously, there must be a difference or else 1) you wouldn't have brought it to my attention and 2) the programmer that created the API wouldn't have gone to the trouble of using two ports when one would do.</font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="times new roman,serif">Many thanks,</font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="times new roman,serif">Jeff</font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Aug 1, 2014 at 5:27 PM, Fischer, Matt <span dir="ltr"><<a>matthew.fischer@twcable.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;font-size:14px;font-family:Calibri,sans-serif"><div>The keystone client does indeed hide failures from you and wrap them, which makes it annoying to debug, see <a href="https://bugs.launchpad.net/python-keystoneclient/+bug/1210625" target="_blank">https://bugs.launchpad.net/python-keystoneclient/+bug/1210625</a>. If you
 do a —debug however you can see the exact call you are attempting and how to repro it with curl. To get a token, you need to POST, I figure the default action for curl is a GET which may be why you are having issues with your curl command. </div><div><br></div><div>Here is a curl request to get a token.</div><div><br></div><div><div>keystone --debug token-get</div><div>DEBUG:keystoneclient.session:REQ: curl -i -X POST <a href="http://example.com:5000/v2.0/tokens" target="_blank">http://example.com:5000/v2.0/tokens</a> -H "Content-Type: application/json" -H "Accept: application/json" -H "User-Agent: python-keystoneclient" -d '{"auth": {"tenantName": "admin", "passwordCredentials": {"username":
 "admin", "password": "myPassword"}}}'</div></div><div><br></div><div><br></div><div>More debugging hints:</div><div><br></div><div>If you still have problems the server-side logs are generally way more useful. You can enable debug in the config file and then run keystone by hand (after stopping it) by doing /usr/bin/keystone-all. That will generally provide better feedback.</div><div><br></div><div>Also :35357 is the service endpoint for which I usually use a service token, is there a reason you're using that and not the standard :5000?</div><div><br></div><div><br></div><div><br></div><span><div style="font-family:Calibri;font-size:11pt;text-align:left;border-width:1pt medium medium;border-style:solid none none;padding:3pt 0in 0in;border-top-color:rgb(181,196,223)"><span style="font-weight:bold">From: </span>Jeff Silverman <<a>jeff@sweetlabs.com</a>><br><span style="font-weight:bold">Date: </span>Friday, August 1, 2014 3:35 PM<br><span style="font-weight:bold">To: </span>"<a>openstack-operators@lists.openstack.org</a>" <<a>openstack-operators@lists.openstack.org</a>><br><span style="font-weight:bold">Subject: </span>[Openstack-operators] keystone is throwing Authorization Failed: 'module' object is not callable errors<br></div><div><div><div><br></div><div dir="ltr"><div class="gmail_default" style="font-family:'times new roman',serif">I did something to keystone, I'm not sure what.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default"><div class="gmail_default" style="font-family:'times new roman',serif"><a>root@controller1-prod.controller1-prod</a>:~# keystone role-list</div><div class="gmail_default" style="font-family:'times new roman',serif">Authorization Failed: 'module' object is not callable<br></div><div class="gmail_default" style="font-family:'times new roman',serif"><a>root@controller1-prod.controller1-prod</a>:~#</div><div class="gmail_default" style="font-family:'times new roman',serif"><a>root@controller1-prod.controller1-prod</a>:~# keystone role-get admin</div><div class="gmail_default" style="font-family:'times new roman',serif">Authorization Failed: 'module' object is not callable<br></div><div class="gmail_default" style="font-family:'times new roman',serif"><a>root@controller1-prod.controller1-prod</a>:~# </div><div><br></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">I have envars OS_USERNAME, OS_PASSWORD, OS_TENANT defined.  OS_AUTH_URL has a URL:</div><div class="gmail_default"><div class="gmail_default"><font face="times new roman,serif"><a>root@controller1-prod.controller1-prod</a>:~# curl -i
<a href="http://controller1-prod.sea.opencandy.com:35357/v2.0" target="_blank">http://controller1-prod.sea.opencandy.com:35357/v2.0</a></font></div><div class="gmail_default"><font face="times new roman,serif">HTTP/1.1 200 OK</font></div><div class="gmail_default"><font face="times new roman,serif">Vary: X-Auth-Token</font></div><div class="gmail_default"><font face="times new roman,serif">Content-Type: application/json</font></div><div class="gmail_default"><font face="times new roman,serif">Date: Fri, 01 Aug 2014 21:10:47 GMT</font></div><div class="gmail_default"><font face="times new roman,serif">Transfer-Encoding: chunked</font></div><div class="gmail_default"><font face="times new roman,serif"><br></font></div><div class="gmail_default"><font face="times new roman,serif">{"version": {"status": "stable", "updated": "2012-10-13T17:42:56Z", "media-types": [{"base": "application/json", "type": "application/vnd.openstack.identity-v2.0+json"}, {"base": "application/xml",
 "type": "application/vnd.openstack.identity-v2.0+xml"}], "id": "v2.0", "links": [{"href": "<a href="http://controller1-prod.sea.opencandy.com:35357/v2.0/" target="_blank">http://controller1-prod.sea.opencandy.com:35357/v2.0/</a>", "rel": "self"}, {"href": "<a href="http://docs.openstack.org/api/openstack-identity-service/2.0/content/" target="_blank">http://docs.openstack.org/api/openstack-identity-service/2.0/content/</a>",
 "type": "text/html", "rel": "describedby"}, {"href": "<a href="http://docs.openstack.org/api/openstack-identity-service/2.0/identity-dev-guide-2.0.pdf" target="_blank">http://docs.openstack.org/api/openstack-identity-service/2.0/identity-dev-guide-2.0.pdf</a>", "type": "application/pdf",
 "rel": "describedby"}]}}<a>root@controller1-prod.controller1-prod</a>:~# </font></div><div style="font-family:'times new roman',serif"><br></div></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">I have been poking at keystone with pdb to try find the point where the exception is raised, with little success.  Maybe I am incompetent as a python programmer.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">I have discovered that keystoneclient does a call to the identity server to get a token - I think.  I tried to simulate the call using curl.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif"><pre><a>root@controller1-prod.controller1-prod</a>:~# curl -i <a href="http://controller1-prod.sea.opencandy.com:35357/v2.0/tokens" target="_blank">http://controller1-prod.sea.opencandy.com:35357/v2.0/tokens</a><br>



HTTP/1.1 404 Not Found<br>Vary: X-Auth-Token<br>Content-Type: application/json<br>Date: Fri, 01 Aug 2014 20:26:00 GMT<br>Transfer-Encoding: chunked<br><br>{"error": {"message": "The resource could not be found.", "code": 404, "title": "Not Found"}}</pre></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">One of the things I find frustrating is the code assumes that any error is an authorization problem, which means that any bug is handled and doesn't percolate up the stack.  There seems
 to be no way to get the debugger to halt on a handled exception.  In client.py, there is</div><div class="gmail_default" style="font-family:'times new roman',serif"><div class="gmail_default">        except Exception as e:</div><div class="gmail_default">            raise exceptions.AuthorizationFailure("Authorization Failed: "</div><div>which makes debugging a challenge..</div></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">I think that the exception is in the call to a.get_auth_ref(self.session).  I think that the problem is that a, a Password object, is not callable.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default"><div class="gmail_default" style="font-family:'times new roman',serif">(Pdb) print callable(a)</div><div class="gmail_default" style="font-family:'times new roman',serif">False</div><div class="gmail_default" style="font-family:'times new roman',serif">(Pdb) </div><div class="gmail_default"><div class="gmail_default"><font face="times new roman,serif">(Pdb) list</font></div><div class="gmail_default"><font face="times new roman,serif">168  <span style="white-space:pre-wrap"></span>                                     token=token,</font></div><div class="gmail_default"><font face="times new roman,serif">169  <span style="white-space:pre-wrap"></span>                                     trust_id=trust_id,</font></div><div class="gmail_default"><font face="times new roman,serif">170  <span style="white-space:pre-wrap"></span>                                     tenant_id=project_id or tenant_id,</font></div><div class="gmail_default"><font face="times new roman,serif">171  <span style="white-space:pre-wrap"></span>                                     tenant_name=project_name or tenant_name)</font></div><div class="gmail_default"><font face="times new roman,serif">172  <span style="white-space:pre-wrap"></span></font></div><div class="gmail_default"><font face="times new roman,serif">173  -><span style="white-space:pre-wrap"></span>           return a.get_auth_ref(self.session)</font></div><div class="gmail_default"><font face="times new roman,serif">174  <span style="white-space:pre-wrap"></span>       except (exceptions.AuthorizationFailure, exceptions.Unauthorized):</font></div><div class="gmail_default"><font face="times new roman,serif">175  <span style="white-space:pre-wrap"></span>           _logger.debug("Authorization Failed.")</font></div><div class="gmail_default"><font face="times new roman,serif">176  <span style="white-space:pre-wrap"></span>           raise</font></div><div class="gmail_default"><font face="times new roman,serif">177  <span style="white-space:pre-wrap"></span>       except exceptions.EndpointNotFound:</font></div><div class="gmail_default"><font face="times new roman,serif">178  <span style="white-space:pre-wrap"></span>           msg = 'There was no suitable authentication url for this request'</font></div><div style="font-family:'times new roman',serif"><br></div></div><div style="font-family:'times new roman',serif"><br></div><div><div><font face="times new roman,serif">(Pdb) pp vars(a)</font></div><div><font face="times new roman,serif">{'auth_ref': None,</font></div><div><font face="times new roman,serif"> 'auth_url': '<a href="http://controller1-prod.sea.opencandy.com:35357/v2.0" target="_blank">http://controller1-prod.sea.opencandy.com:35357/v2.0</a>',</font></div><div><font face="times new roman,serif"> 'password': "XXXXXXXXXXX",</font></div><div><font face="times new roman,serif"> 'tenant_id': None,</font></div><div><font face="times new roman,serif"> 'tenant_name': 'admin',</font></div><div><font face="times new roman,serif"> 'token': None,</font></div><div><font face="times new roman,serif"> 'trust_id': None,</font></div><div><font face="times new roman,serif"> 'username': 'admin'}</font></div><div><font face="times new roman,serif">(Pdb) </font></div></div><div style="font-family:'times new roman',serif"><br></div></div><div class="gmail_default" style="font-family:'times new roman',serif">I instrumented the code to see if I could get a better handle on the exception getting thrown:</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default"><div class="gmail_default"><font face="times new roman,serif">(Pdb) list 165,184</font></div><div class="gmail_default"><font face="times new roman,serif">165  <span style="white-space:pre-wrap"></span>           a = v2_auth.Auth._factory(auth_url,</font></div><div class="gmail_default"><font face="times new roman,serif">166  <span style="white-space:pre-wrap"></span>                                     username=username,</font></div><div class="gmail_default"><font face="times new roman,serif">167  <span style="white-space:pre-wrap"></span>                                     password=password,</font></div><div class="gmail_default"><font face="times new roman,serif">168  <span style="white-space:pre-wrap"></span>                                     token=token,</font></div><div class="gmail_default"><font face="times new roman,serif">169  <span style="white-space:pre-wrap"></span>                                     trust_id=trust_id,</font></div><div class="gmail_default"><font face="times new roman,serif">170  <span style="white-space:pre-wrap"></span>                                     tenant_id=project_id or tenant_id,</font></div><div class="gmail_default"><font face="times new roman,serif">171  <span style="white-space:pre-wrap"></span>                                     tenant_name=project_name or tenant_name)</font></div><div class="gmail_default"><font face="times new roman,serif">172  <span style="white-space:pre-wrap"></span></font></div><div class="gmail_default"><font face="times new roman,serif">173  <span style="white-space:pre-wrap"></span>           try:</font></div><div class="gmail_default"><font face="times new roman,serif">174  <span style="white-space:pre-wrap"></span>               return a.get_auth_ref(self.session)</font></div><div class="gmail_default"><font face="times new roman,serif">175  <span style="white-space:pre-wrap"></span>           except Exception as e:</font></div><div class="gmail_default"><font face="times new roman,serif">176  <span style="white-space:pre-wrap"></span>               print "Hit an exception %s" % e </font></div><div class="gmail_default"><font face="times new roman,serif">177  <span style="white-space:pre-wrap"></span>               pdb.set_trace()</font></div><div class="gmail_default"><font face="times new roman,serif">178  -><span style="white-space:pre-wrap"></span>               raise</font></div><div class="gmail_default"><font face="times new roman,serif">179  <span style="white-space:pre-wrap"></span>       except (exceptions.AuthorizationFailure, exceptions.Unauthorized):</font></div><div class="gmail_default"><font face="times new roman,serif">180  <span style="white-space:pre-wrap"></span>           _logger.debug("Authorization Failed.")</font></div><div class="gmail_default"><font face="times new roman,serif">181  <span style="white-space:pre-wrap"></span>           raise</font></div><div class="gmail_default"><font face="times new roman,serif">182  <span style="white-space:pre-wrap"></span>       except exceptions.EndpointNotFound:</font></div><div class="gmail_default"><font face="times new roman,serif">183  <span style="white-space:pre-wrap"></span>           msg = 'There was no suitable authentication url for this request'</font></div><div class="gmail_default"><font face="times new roman,serif">184  <span style="white-space:pre-wrap"></span>           raise exceptions.AuthorizationFailure(msg)</font></div><div style="font-family:'times new roman',serif"><br></div><div style="font-family:'times new roman',serif"><div>(Pdb) c</div><div>Hit an exception 'module' object is not callable</div><div>> /usr/lib/python2.6/site-packages/keystoneclient/v2_0/client.py(178)get_raw_token_from_identity_service()</div><div>-> raise</div><div><br></div></div></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">Not sure what to do next.</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif">Jeff</div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div><div class="gmail_default" style="font-family:'times new roman',serif"><br></div></div><div><br></div>
-- <br><div dir="ltr"><b>Jeff Silverman</b><div>Systems Engineer</div><div><a href="tel:%28253%29%20459-2318" value="+12534592318" target="_blank">(253) 459-2318</a> (c)</div><div><img src="https://dl.dropboxusercontent.com/u/16943296/SweetLabs-Signatures/New_2014/signature-logo.png"><br></div></div></div></div></div></span><br><hr><font face="Arial" color="Gray" size="1">This E-mail and any of its attachments may contain Time Warner Cable proprietary information, which is privileged, confidential, or subject to copyright belonging to Time Warner Cable. This E-mail is intended solely
 for the use of the individual or entity to which it is addressed. If you are not the intended recipient of this E-mail, you are hereby notified that any dissemination, distribution, copying, or action taken in relation to the contents of and attachments to
 this E-mail is strictly prohibited and may be unlawful. If you have received this E-mail in error, please notify the sender immediately and permanently delete the original and any copy of this E-mail and any printout.<br></font></div></blockquote></div><br><br clear="all"><div><br></div>-- <br><div dir="ltr"><b>Jeff Silverman</b><div>Systems Engineer</div><div><a href="tel:%28253%29%20459-2318" value="+12534592318" target="_blank">(253) 459-2318</a> (c)</div><div><img src="https://dl.dropboxusercontent.com/u/16943296/SweetLabs-Signatures/New_2014/signature-logo.png"><br></div></div></div></div></div>
_______________________________________________<br>OpenStack-operators mailing list<br><a>OpenStack-operators@lists.openstack.org</a><br><a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-operators" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-operators</a><br></blockquote></div><br></div></div></blockquote></div><br><br clear="all"><div><br></div>-- <br><div dir="ltr"><b>Jeff Silverman</b><div>Systems Engineer</div><div><a href="tel:%28253%29%20459-2318" value="+12534592318" target="_blank">(253) 459-2318</a> (c)</div><div><img src="https://dl.dropboxusercontent.com/u/16943296/SweetLabs-Signatures/New_2014/signature-logo.png"><br></div></div></div></blockquote></div></div></div></blockquote></div><br><br clear="all"><div><br></div>-- <br><div dir="ltr"><b>Jeff Silverman</b><div>Systems Engineer</div><div>(253) 459-2318 (c)</div><div><img src="https://dl.dropboxusercontent.com/u/16943296/SweetLabs-Signatures/New_2014/signature-logo.png"><br></div></div></div></span></body></html>