123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Security.Claims;
- using System.Text.Json;
- using System.Threading.Tasks;
- namespace wispro.sp.web.Utils
- {
- public class JwtParser
- {
- public static IEnumerable<Claim> ParseClaimsFromJwt(string jwt)
- {
- var claims = new List<Claim>();
- var payload = jwt.Split('.')[1];
- var jsonBytes = ParseBase64WithoutPadding(payload);
- var keyValuePairs = JsonSerializer.Deserialize<Dictionary<string, object>>(jsonBytes);
- keyValuePairs.TryGetValue(ClaimTypes.Role, out object roles);
- if (roles != null)
- {
- if (roles.ToString().Trim().StartsWith(","))
- {
- var parsedRoles = JsonSerializer.Deserialize<string[]>(roles.ToString());
- foreach (var parsedRole in parsedRoles)
- {
- claims.Add(new Claim(ClaimTypes.Role, parsedRole));
- }
- }
- else
- {
- claims.Add(new Claim(ClaimTypes.Role, roles.ToString()));
- }
- keyValuePairs.Remove(ClaimTypes.Role);
- }
- claims.AddRange(keyValuePairs.Select(kvp => new Claim(kvp.Key, kvp.Value.ToString())));
- return claims;
- }
- private static byte[] ParseBase64WithoutPadding(string base64)
- {
- switch (base64.Length % 4)
- {
- case 2: base64 += "=="; break;
- case 3: base64 += "="; break;
- }
- return Convert.FromBase64String(base64);
- }
- }
- }
|