mirror of
https://github.com/byo-software/steam-openid-connect-provider.git
synced 2025-01-25 08:46:30 +00:00
Merge pull request #7 from SunriseM/feature/fetch-aditional-claims
Use ISteamUser/GetPlayersSummaries to fetch additional claims #6
This commit is contained in:
commit
dcf54caf9f
2 changed files with 115 additions and 0 deletions
109
src/ProfileService.cs
Normal file
109
src/ProfileService.cs
Normal file
|
@ -0,0 +1,109 @@
|
||||||
|
using IdentityServer4.Models;
|
||||||
|
using IdentityServer4.Extensions;
|
||||||
|
using IdentityServer4.Services;
|
||||||
|
using System;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Security.Claims;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Net.Http;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using Microsoft.AspNetCore.Identity;
|
||||||
|
using Microsoft.Extensions.Configuration;
|
||||||
|
|
||||||
|
namespace IdentityServer.Services
|
||||||
|
{
|
||||||
|
public class ProfileService : IProfileService
|
||||||
|
{
|
||||||
|
private IConfiguration _configuration;
|
||||||
|
private readonly IUserClaimsPrincipalFactory<IdentityUser> _claimsFactory;
|
||||||
|
private readonly UserManager<IdentityUser> _userManager;
|
||||||
|
|
||||||
|
private async Task<IPlayerSummary> FetchUserSummary(string steamid64)
|
||||||
|
{
|
||||||
|
using (var httpClient = new HttpClient())
|
||||||
|
{
|
||||||
|
|
||||||
|
var baseurl = "https://api.steampowered.com/ISteamUser/GetPlayerSummaries/v0002";
|
||||||
|
var applicationKey = _configuration["Authentication:Steam:ApplicationKey"];
|
||||||
|
var url = $"{baseurl}/?key={applicationKey}&steamids={steamid64}";
|
||||||
|
|
||||||
|
var res = await httpClient.GetStringAsync(url);
|
||||||
|
var json = JsonConvert.DeserializeObject<IPlayerSummary>(res);
|
||||||
|
return json;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class Player {
|
||||||
|
public string steamid { get; set; }
|
||||||
|
public int communityvisibilitystate { get; set; }
|
||||||
|
public int profilestate { get; set; }
|
||||||
|
public string personaname { get; set; }
|
||||||
|
public int commentpermission { get; set; }
|
||||||
|
public string profileurl { get; set; }
|
||||||
|
public string avatar { get; set; }
|
||||||
|
public string avatarmedium { get; set; }
|
||||||
|
public string avatarfull { get; set; }
|
||||||
|
public string avatarhash { get; set; }
|
||||||
|
public int lastlogoff { get; set; }
|
||||||
|
public int personastate { get; set; }
|
||||||
|
public string realname { get; set; }
|
||||||
|
public string primaryclanid { get; set; }
|
||||||
|
public int timecreated { get; set; }
|
||||||
|
public int personastateflags { get; set; }
|
||||||
|
public string loccountrycode { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public class Response {
|
||||||
|
public List<Player> players { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public class IPlayerSummary {
|
||||||
|
public Response response { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public ProfileService(
|
||||||
|
UserManager<IdentityUser> userManager,
|
||||||
|
IUserClaimsPrincipalFactory<IdentityUser> claimsFactory,
|
||||||
|
IConfiguration configuration
|
||||||
|
)
|
||||||
|
{
|
||||||
|
_userManager = userManager;
|
||||||
|
_claimsFactory = claimsFactory;
|
||||||
|
_configuration = configuration;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task GetProfileDataAsync(ProfileDataRequestContext context)
|
||||||
|
{
|
||||||
|
var sub = context.Subject.GetSubjectId();
|
||||||
|
var user = await _userManager.FindByIdAsync(sub);
|
||||||
|
var principal = await _claimsFactory.CreateAsync(user);
|
||||||
|
|
||||||
|
var claims = principal.Claims.ToList();
|
||||||
|
claims = claims.Where(claim => context.RequestedClaimTypes.Contains(claim.Type)).ToList();
|
||||||
|
|
||||||
|
var steamurl = "https://steamcommunity.com/openid/id/";
|
||||||
|
var steamid64 = sub.Substring(steamurl.Length);
|
||||||
|
|
||||||
|
var userSummary = await FetchUserSummary(steamid64);
|
||||||
|
var player = userSummary.response.players[0];
|
||||||
|
|
||||||
|
if (player != null)
|
||||||
|
{
|
||||||
|
claims.Add(new Claim("picture", player.avatarfull));
|
||||||
|
claims.Add(new Claim("nickname", player.personaname));
|
||||||
|
claims.Add(new Claim("given_name", player.realname));
|
||||||
|
claims.Add(new Claim("website", player.profileurl));
|
||||||
|
}
|
||||||
|
|
||||||
|
context.IssuedClaims = claims;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async Task IsActiveAsync(IsActiveContext context)
|
||||||
|
{
|
||||||
|
var sub = context.Subject.GetSubjectId();
|
||||||
|
var user = await _userManager.FindByIdAsync(sub);
|
||||||
|
context.IsActive = user != null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -8,6 +8,8 @@ using Microsoft.EntityFrameworkCore;
|
||||||
using Microsoft.Extensions.Configuration;
|
using Microsoft.Extensions.Configuration;
|
||||||
using Microsoft.Extensions.DependencyInjection;
|
using Microsoft.Extensions.DependencyInjection;
|
||||||
using Microsoft.Extensions.Hosting;
|
using Microsoft.Extensions.Hosting;
|
||||||
|
using IdentityServer4.Services;
|
||||||
|
using IdentityServer.Services;
|
||||||
|
|
||||||
namespace SteamOpenIdConnectProvider
|
namespace SteamOpenIdConnectProvider
|
||||||
{
|
{
|
||||||
|
@ -27,6 +29,8 @@ namespace SteamOpenIdConnectProvider
|
||||||
.AddNewtonsoftJson()
|
.AddNewtonsoftJson()
|
||||||
.SetCompatibilityVersion(CompatibilityVersion.Version_3_0);
|
.SetCompatibilityVersion(CompatibilityVersion.Version_3_0);
|
||||||
|
|
||||||
|
services.AddSingleton<IConfiguration>(Configuration);
|
||||||
|
|
||||||
services.AddDbContext<AppInMemoryDbContext>(options =>
|
services.AddDbContext<AppInMemoryDbContext>(options =>
|
||||||
options.UseInMemoryDatabase("default"));
|
options.UseInMemoryDatabase("default"));
|
||||||
|
|
||||||
|
@ -52,6 +56,8 @@ namespace SteamOpenIdConnectProvider
|
||||||
.AddDeveloperSigningCredential(true)
|
.AddDeveloperSigningCredential(true)
|
||||||
.AddInMemoryIdentityResources(IdentityServerConfig.GetIdentityResources());
|
.AddInMemoryIdentityResources(IdentityServerConfig.GetIdentityResources());
|
||||||
|
|
||||||
|
services.AddScoped<IProfileService, ProfileService>();
|
||||||
|
|
||||||
services.AddAuthentication()
|
services.AddAuthentication()
|
||||||
.AddCookie(options =>
|
.AddCookie(options =>
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue