Access Control Service V2 and Facebook Integration
        Posted  
        
            by Your DisplayName here!
        on Least Privilege
        
        See other posts from Least Privilege
        
            or by Your DisplayName here!
        
        
        
        Published on Fri, 22 Apr 2011 15:12:03 GMT
        Indexed on 
            2011/06/20
            16:38 UTC
        
        
        Read the original article
        Hit count: 311
        
IdentityModel
I haven’t been blogging about ACS2 in the past because it was not released and I was kinda busy with other stuff. Needless to say I spent quite some time with ACS2 already (both in customer situations as well as in the classroom and at conferences).
ACS2 rocks! It’s IMHO the most interesting and useful (and most unique) part of the whole Azure offering!
For my talk at VSLive yesterday, I played a little with the Facebook integration. See Steve’s post on the general setup.
One claim that you get back from Facebook is an access token. This token can be used to directly talk to Facebook and query additional properties about the user. Which properties you have access to depends on which authorization your Facebook app requests. You can specify this in the identity provider registration page for Facebook in ACS2. In my example I added access to the home town property of the user.
Once you have the access token from ACS you can use e.g. the Facebook SDK from Codeplex (also available via NuGet) to talk to the Facebook API.
In my sample I used the WIF ClaimsAuthenticationManager to add the additional home town claim. This is not necessarily how you would do it in a “real” app. Depends ;)
The code looks like this (sample code!):
public class ClaimsTransformer : ClaimsAuthenticationManager
{
public override IClaimsPrincipal Authenticate(
string resourceName, IClaimsPrincipal incomingPrincipal)
{
if (!incomingPrincipal.Identity.IsAuthenticated)
{
return base.Authenticate(resourceName, incomingPrincipal);
}
string accessToken;
if (incomingPrincipal.TryGetClaimValue(
"http://www.facebook.com/claims/AccessToken", out accessToken))
{
try
{
var home = GetFacebookHometown(accessToken);
if (!string.IsNullOrWhiteSpace(home))
{
incomingPrincipal.Identities[0].Claims.Add(
new Claim("http://www.facebook.com/claims/HomeTown", home));
}
}
catch { }
}
return incomingPrincipal;
}
     >private string GetFacebookHometown(string >token)
    {
        var client
= new FacebookClient(token);
        dynamic parameters
= new ExpandoObject();
        parameters.fields = "hometown";
        dynamic result
= client.Get("me">, parameters);
        return result.hometown.name;
    }
}
© Least Privilege or respective owner