Skip to content

Instantly share code, notes, and snippets.

@RhysC
Created September 24, 2014 10:09
Show Gist options
  • Save RhysC/96d9580fa9a0a85f8a8a to your computer and use it in GitHub Desktop.
Save RhysC/96d9580fa9a0a85f8a8a to your computer and use it in GitHub Desktop.
Claims not coming back from identity server
using System.Collections.Generic;
using System.IdentityModel.Tokens;
using System.Web.Mvc;
using System.Web.Optimization;
using System.Web.Routing;
using Microsoft.Owin;
using Microsoft.Owin.Security.Cookies;
using Microsoft.Owin.Security.OpenIdConnect;
using OauthScratch.MvcOwinClient;
using Owin;
[assembly: OwinStartup(typeof(Startup))]
namespace OauthScratch.MvcOwinClient
{
public static class Constants
{
public const string BaseAddress = "http://localhost:3344/core";//The server project URL
}
public class Startup
{
public void Configuration(IAppBuilder app)
{
AreaRegistration.RegisterAllAreas();
FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
RouteConfig.RegisterRoutes(RouteTable.Routes);
BundleConfig.RegisterBundles(BundleTable.Bundles);
SetUpAuth(app);
}
private static void SetUpAuth(IAppBuilder app)
{
JwtSecurityTokenHandler.InboundClaimTypeMap = new Dictionary<string, string>();
app.UseCookieAuthentication(new CookieAuthenticationOptions
{
AuthenticationType = "Cookies"
});
app.UseOpenIdConnectAuthentication(new OpenIdConnectAuthenticationOptions
{
ClientId = "implicitclient",
Authority = Constants.BaseAddress,
RedirectUri = "http://localhost:51207/",
ResponseType = "id_token token",
Scope = "openid email profile",
SignInAsAuthenticationType = "Cookies",
});
}
}
}
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Security.Claims;
using System.Security.Cryptography.X509Certificates;
using Microsoft.Owin.Hosting;
using Owin;
using Thinktecture.IdentityServer.Core;
using Thinktecture.IdentityServer.Core.Configuration;
using Thinktecture.IdentityServer.Core.Logging;
using Thinktecture.IdentityServer.Core.Models;
using Thinktecture.IdentityServer.Core.Services.InMemory;
namespace OauthScratch.IdentityServer
{
class Program
{
static void Main(string[] args)
{
Console.Title = "IdentityServer v3 SelfHost";
LogProvider.SetCurrentLogProvider(new DiagnosticsTraceLogProvider());
const string url = "http://localhost:3344/core";
using (WebApp.Start<Startup>(url))
{
Console.WriteLine("\n\nServer listening at {0}. Press enter to stop", url);
Console.ReadLine();
}
}
}
public class Startup
{
public void Configuration(IAppBuilder appBuilder)
{
var factory = InMemoryFactory.Create(
users: Users.Get(),
clients: Clients.Get(),
scopes: Scopes.Get());
var options = new IdentityServerOptions
{
IssuerUri = "https://idsrv3.com",
SiteName = "Thinktecture IdentityServer v3 - preview 1 (SelfHost)",
PublicHostName = "http://localhost:3344",
SigningCertificate = Certificate.Get(),
Factory = factory,
};
appBuilder.UseIdentityServer(options);
}
}
internal class Scopes
{
public static IEnumerable<Scope> Get()
{
return new Scope[]
{
new Scope
{
Name = Constants.StandardScopes.OpenId,
DisplayName = "Your user identifier",
Required = true,
IsOpenIdScope = true,
Claims = new List<ScopeClaim>
{
new ScopeClaim
{
AlwaysIncludeInIdToken = true,
Name = "sub",
Description = "subject identifier"
}
}
},
new Scope
{
Name = Constants.StandardScopes.Profile,
DisplayName = "Basic profile",
Description = "Your basic user profile information (first name, last name, etc.). This is a really long string to see what the UI look like when someone puts in too much stuff here. I know this is not what we really want, but this is just test data (for now). KThxBye.",
IsOpenIdScope = true,
Emphasize = true,
Claims = (Constants.ScopeToClaimsMapping[Constants.StandardScopes.Profile].Select(x=>new ScopeClaim{Name = x, Description = x})).ToList()
},
new Scope
{
Name = Constants.StandardScopes.Email,
DisplayName = "Your email address",
IsOpenIdScope = true,
Emphasize = true,
Claims = new List<ScopeClaim>
{
new ScopeClaim
{
Name = "email",
Description = "email address",
},
new ScopeClaim
{
Name = "email_verified",
Description = "email is verified",
}
}
}
};
}
}
internal class Clients
{
public static IEnumerable<Client> Get()
{
return new[]
{
new Client
{
ClientName = "Sample Implicit Clients",
Enabled = true,
ClientId = "implicitclient",
ClientSecret = "secret",
Flow = Flows.Implicit,
ClientUri = "http://www.myurl.com.au",
LogoUri =
new Uri(
""),
RequireConsent = true,
AllowRememberConsent = true,
RedirectUris = new List<Uri>
{
new Uri("http://localhost:51207/"),
},
}
};
}
}
internal class Users
{
public static IEnumerable<InMemoryUser> Get()
{
return new InMemoryUser[]
{
new InMemoryUser{Subject = "alice", Username = "alice", Password = "alice",
Claims = new Claim[]
{
new Claim(Constants.ClaimTypes.GivenName, "Alice"),
new Claim(Constants.ClaimTypes.FamilyName, "Smith"),
new Claim(Constants.ClaimTypes.Email, "AliceSmith@email.com"),
}
}
};
}
}
static class Certificate
{
public static X509Certificate2 Get()
{
var assembly = typeof(Certificate).Assembly;
using (var stream = assembly.GetManifestResourceStream("OauthScratch.IdentityServer.idsrv3test.pfx"))
{
return new X509Certificate2(ReadStream(stream), "idsrv3test");
}
}
private static byte[] ReadStream(Stream input)
{
var buffer = new byte[16 * 1024];
using (var ms = new MemoryStream())
{
int read;
while ((read = input.Read(buffer, 0, buffer.Length)) > 0)
{
ms.Write(buffer, 0, read);
}
return ms.ToArray();
}
}
}
}
nonce : 635471500609186321.MWRjYjk2MTktMDFlYi00MDM5LTg1OTYtYzJhMjU2MTczZDBmOGFkMDZlZTMtNjI0Yy00N2Y4LWJjOTctZjI5ZGNjZmNkZTQ1
iat : 1411553269
at_hash : iWzOfaiYAYc1ACmdKpqzvg
sub : alice
amr : password
auth_time : 1411553269
idp : idsrv
name : alice
iss : https://idsrv3.com
aud : implicitclient
exp : 1411556869
nbf : 1411553269
## from System.Security.Claims.ClaimsPrincipal.Current.Claims
## was excpecting given name, family name and email too given the check boxes where displayed in the request screen and check on submission
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment