Skip to content

Rackspace Identity Code Samples

alanquillin edited this page Apr 8, 2013 · 6 revisions

Identity service (keystone)

Since all service endpoints use the identity service for authentication and authorization, we will start here.

User Authentication

Authenticate with username and password
try
{
    IIdentityProvider identityProvider = new Providers.Rackspace.IdentityProvider();
    var userAccess = identityProvider.Authenticate(new RackspaceCloudIdentity
                                                       {
                                                           Username = "MyUserName", 
                                                           Password = "MyPassword"
                                                       });
}
catch(ResponseException ex2)
{
    // do something
}
Authenticate with username and API key
try
{
    IIdentityProvider identityProvider = new Providers.Rackspace.IdentityProvider();
    var userAccess = identityProvider.Authenticate(new RackspaceCloudIdentity
                                                       {
                                                           Username = "MyUserName", 
                                                           APIKey = "MyAPIKey"
                                                       });
}
catch(ResponseException ex2)
{
    // do something
}

By default, the US (default) cloud instance is used (This is the instance for all Cloud Regions EXCEPT LON. All future cloud instances will be in US (default) the cloud region). If you need to target the LON cloud instance, you only need to pass in the CloudInstance.UK

Authenticate at the LON cloud instance.
try
{
    IIdentityProvider identityProvider = new Providers.Rackspace.IdentityProvider();
    var userAccess = identityProvider.Authenticate(new RackspaceCloudIdentity{
                                                        Username = "MyUserName", 
                                                        Password = "MyPassword", CloudInstance =CloudInstance.UK});
}
catch(ResponseException ex2)
{
    // do something
}

User Details and Roles

retrieving details about a user is reserved for either admins, or the requesting user retrieving their own information. The examples below show a user retrieving their own if, but we will have an examples of what administrative accounts can do.

Basic user methods

Retrieve user details by username
try
{
    IIdentityProvider identityProvider = new Providers.Rackspace.IdentityProvider();
    var identity = new RackspaceCloudIdentity{ Username = "MyUserName",   APIKey = "MyPassword" };
    var userDetails = identityProvider.GetUserByName(identity, "MyUserName");
}
catch(ResponseException ex2)
{
    // do something
}
Retrieve user details by user id
try
{
    IIdentityProvider identityProvider = new Providers.Rackspace.IdentityProvider();
    var identity = new RackspaceCloudIdentity{ Username = "MyUserName",   APIKey = "MyPassword" };
    var userDetails = identityProvider.GetUser(identity, "UserId");
}
catch(ResponseException ex2)
{
    // do something
}

Administrative user methods

These methods are only available to user that exist in the identity:user-admin role. If the requesting user does not exist in this role, a exception will be thrown.

Add User
List all global Roles
try
{
    IIdentityProvider identityProvider = new Providers.Rackspace.IdentityProvider();
    var identity = new RackspaceCloudIdentity{ Username = "MyAdminUserName",   APIKey = "MyAdminPassword" };
    var userDetails = identityProvider.ListRoles(identity)
}
catch(ResponseException ex2)
{
    // do something
}
Clone this wiki locally