authentication - OWIN - Associating application information to auth server -


i've been following tutorial found here setting authorization server, separate client app. http://bitoftech.net/2014/06/01/token-based-authentication-asp-net-web-api-2-owin-asp-net-identity/
can example , working, feel i'm missing few steps application.

i'd have authorization server provide oauth tokens, used separate project (and potentially multiple others) authenticate users. understand point of separate authorization logic , business logic, i'm not sure how pair created users on auth server users on application.

for example, when user creates account first time, they'll send username/password authorization server. @ point app create own user information (empty profile , settings etc), , how store application's userid authorization information? i've tried adding client userid claim on auth server, i'm not sure if understand means or if that's correct approach.

basically, think should able do, not sure how it, in asp.net webapi application, should accept authorization: bearer < token > header, , somehow able grab userid (relevant specific application) authorization server. second, unrelated application should able accept same access token , own userid (assuming user has account both applications) auth server.

am looking @ right way? how associate different applications' userids users created on auth server?

assuming i'm understanding you're trying correctly, if you're using microsoft's oauth owin implementation, should able override oauthauthorizationserverprovider , override appropriate grant*().

see http://www.asp.net/aspnet/overview/owin-and-katana/owin-oauth-20-authorization-server more details.

if you're using resourceowner grant, it's straight forward:

public override task grantresourceownercredentials(oauthgrantresourceownercredentialscontext context) {      var user = ...;     if (!passwordprovider.validatepassword(context.password, user.password))     {         context.seterror("invalid_grant", "the password incorrect.");         return task.fromresult<object>(null);     }      // build claims identity     var identity = new claimsidentity(owinauthconfig.oauthauthorizationoptions.authenticationtype);     identity.buildclaims(user);      // create properties     var properties = createproperties(user);      // create ticket , process it.     var ticket = new authenticationticket(identity, properties);     context.validated(ticket);     return task.fromresult<object>(null); } 

where build claims like:

public static class applicationoauthproviderhelper {     public static void buildclaims(this claimsidentity identity, user user)     {         var claims = new list<claim>         {             new claim(claimtypes.name, user.username),             new claim(claimtypes.nameidentifier, user.userid.tostring())         };          // custom claims, user app ids.         // ex. claim { claimtype = "app1/userid", value = "34242" }         var externalappclaims = magicalfunctionthatgetsexternalclaims(user);         foreach(var claim in externalappclaims)         {             claims.add(new claim(claim.claimtype, claim.value));         }          identity.addclaims(claims);     } } 

which might used in web api controller as:

var useridstring = (user.identity claimsidentity).findfirst("app1/userid"); 

let me know if doesn't answer question!


Comments

Popular posts from this blog

javascript - Jquery show_hide, what to add in order to make the page scroll to the bottom of the hidden field once button is clicked -

python - Django-cities exits with "killed" -

python - How to get a widget position inside it's layout in Kivy? -