Try with the following String provider = "swift"; SwiftApi swiftApi = ContextBuilder.newBuilder(provider) .endpoint("https://dal05.objectstorage.softlayer.net/auth/v1.0") .credentials("TENANT_NAME:USER_NAME", "API_KEY") .modules(modules) .buildApi(SwiftApi.class); ContainerApi containerApi = swiftApi.getContainerApiForRegion("dal05"); Set<Container> containers = containerApi.list().toSet();
On Fri, Oct 17, 2014 at 8:28 PM, Jai M <jaiganes...@gmail.com> wrote: > Hi Andrea, > > I am using the following code snippet > String provider = "openstack-swift"; > SwiftApi swiftApi = ContextBuilder.newBuilder(provider) > > .endpoint("https://dal05.objectstorage.softlayer.net/auth/v1.0") > .credentials("TENANT_NAME:USER_NAME", "API_KEY") > .modules(modules) > .buildApi(SwiftApi.class); > ContainerApi containerApi = swiftApi.getContainerApiForRegion("dal05"); > Set<Container> containers = containerApi.list().toSet(); > > When I try this, I get the below exception > > > 2014-10-17 09:59:19,302 [main] DEBUG SLF4JLogger Receiving response > -2004695267: HTTP/1.1 400 Bad Request > 2014-10-17 09:59:19,308 DEBUG [jclouds.wire] [main] << "<html><h1>Bad > Request</h1><p>The server could not comply with the request since it is > either malformed or otherwise incorrect.</p></html>" > 2014-10-17 09:59:19,308 [main] DEBUG SLF4JLogger << "<html><h1>Bad > Request</h1><p>The server could not comply with the request since it is > either malformed or otherwise incorrect.</p></html>" > org.jclouds.http.HttpResponseException: command: POST > https://dal05.objectstorage.softlayer.net/auth/v1.0/tokens HTTP/1.1 failed > with response: HTTP/1.1 400 Bad Request; content: [<html><h1>Bad > Request</h1><p>The server could not comply with the request since it is > either malformed or otherwise incorrect.</p></html>] > at > org.jclouds.openstack.swift.v1.handlers.SwiftErrorHandler.handleError(SwiftErrorHandler.java:46) > at > org.jclouds.http.handlers.DelegatingErrorHandler.handleError(DelegatingErrorHandler.java:65) > at > org.jclouds.http.internal.BaseHttpCommandExecutorService.shouldContinue(BaseHttpCommandExecutorService.java:135) > at > org.jclouds.http.internal.BaseHttpCommandExecutorService.invoke(BaseHttpCommandExecutorService.java:105) > at > org.jclouds.rest.internal.InvokeHttpMethod.invoke(InvokeHttpMethod.java:90) > at > org.jclouds.rest.internal.InvokeHttpMethod.apply(InvokeHttpMethod.java:73) > at > org.jclouds.rest.internal.InvokeHttpMethod.apply(InvokeHttpMethod.java:44) > at > org.jclouds.rest.internal.DelegatesToInvocationFunction.handle(DelegatesToInvocationFunction.java:156) > at > org.jclouds.rest.internal.DelegatesToInvocationFunction.invoke(DelegatesToInvocationFunction.java:123) > at > com.sun.proxy.$Proxy100.authenticateWithTenantNameAndCredentials(Unknown > Source) > at > org.jclouds.openstack.keystone.v2_0.functions.AuthenticatePasswordCredentials.authenticateWithTenantName(AuthenticatePasswordCredentials.java:43) > at > org.jclouds.openstack.keystone.v2_0.functions.AuthenticatePasswordCredentials.authenticateWithTenantName(AuthenticatePasswordCredentials.java:31) > at > org.jclouds.openstack.keystone.v2_0.functions.internal.BaseAuthenticator.apply(BaseAuthenticator.java:79) > at > org.jclouds.openstack.keystone.v2_0.functions.internal.BaseAuthenticator.apply(BaseAuthenticator.java:36) > > > In the wire logs, I see it is a POST request with the following payload > "{"auth":{" > passwordCredentials":{"username":"USERID","password":"API_KEY"},"tenantName":"ACC-278436-15"}}" > > However the actual api call should be a get with AUTH headers. > > Thanks > Jai > > On Fri, Oct 17, 2014 at 11:49 AM, Andrea Turli <andrea.tu...@gmail.com> > wrote: >> >> Hi Jai, >> >> please try with >> >> identity=tenantname:user >> credential=api_key >> >> Notice, you'll probably need to point at something like >> >> https://<locationId>.objectstorage.softlayer.net/auth/v1.0 >> >> where locationId is something like `ams01` or `dal01` >> >> Best, >> Andrea >> >> On Fri, Oct 17, 2014 at 4:30 PM, Jai M <jaiganes...@gmail.com> wrote: >> > I am using the openstack-swift api to interact with SoftLayer Object >> > storage. However the authentication is failing. >> > >> > I see the payload for the POST request to get the token is in the below >> > format >> > >> > >> > "{"auth":{"passwordCredentials":{"username":"USERID","password":"API_KEY"},"tenantName":"ACC-278436-15"}}" >> > >> > This does not work for SL. The SL spec requires it to be a GET with >> > headers >> > >> > "X-Auth-User: ACC-278436-15:USERID" >> > "X-Auth-Key: API_KEY" >> > >> > Is there a way I can switch/plugin a different authentication mechanism >> > for >> > SoftLayer or should I use the blobstore api directly instead of swift >> > api ? >> > >> > Let me know. >> > >> > Rgds >> > Jai >> > >> > > >