示例#1
0
        public string CreateToken(IMiCakeUser miCakeUser)
        {
            IDictionary <string, object> claimCollection = null;

            var userProperties = miCakeUser.GetType().GetProperties(BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Instance);

            foreach (var userProperty in userProperties)
            {
                var jwtProperty = userProperty.GetCustomAttribute <JwtClaimAttribute>();
                if (jwtProperty != null)
                {
                    claimCollection = claimCollection ?? new Dictionary <string, object>();
                    claimCollection.Add(jwtProperty.ClaimName == null ? userProperty.Name.ToLower() : jwtProperty.ClaimName.ToLower(), userProperty.GetValue(miCakeUser).ToString());
                }
            }

            var expireTime         = DateTime.Now.AddMinutes(miCakeJwtOptions.ExpirationMinutes);
            var signingCredentials = new SigningCredentials(new SymmetricSecurityKey(miCakeJwtOptions.SecurityKey), miCakeJwtOptions.Algorithm);

            return(CreateTokenCore(miCakeJwtOptions.Issuer,
                                   miCakeJwtOptions.Audience,
                                   null,
                                   null,
                                   expireTime,
                                   null,
                                   signingCredentials,
                                   miCakeJwtOptions.EncryptingCredentials,
                                   claimCollection));
        }
示例#2
0
 public Task <JwtTokenAuthResult> CreateToken(IMiCakeUser miCakeUser, CancellationToken cancellationToken = default)
 {
     return(CreateToken(miCakeUser, defaultSubjectId, cancellationToken));
 }
示例#3
0
 public Task <JwtTokenAuthResult> CreateToken(IMiCakeUser miCakeUser, string subjectId, CancellationToken cancellationToken = default)
 {
     return(GenerateAuthToken(subjectId, CreateSecurityTokenDescriptorByMiCakeUser(miCakeUser, cancellationToken), cancellationToken));
 }
示例#4
0
        protected virtual SecurityTokenDescriptor CreateSecurityTokenDescriptorByMiCakeUser(IMiCakeUser miCakeUser, CancellationToken cancellationToken = default)
        {
            IDictionary <string, object> claimCollection = null;

            var userProperties = miCakeUser.GetType().GetProperties(BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Instance);

            foreach (var userProperty in userProperties)
            {
                var jwtProperty = userProperty.GetCustomAttribute <JwtClaimAttribute>();
                if (jwtProperty != null)
                {
                    claimCollection ??= new Dictionary <string, object>();
                    claimCollection.Add(jwtProperty.ClaimName == null ? userProperty.Name.ToLower() : jwtProperty.ClaimName.ToLower(), userProperty.GetValue(miCakeUser).ToString());
                }
            }

            var expireTime         = DateTime.Now.AddSeconds(_jwtOptions.AccessTokenLifetime);
            var signingCredentials = new SigningCredentials(new SymmetricSecurityKey(_jwtOptions.SecurityKey), _jwtOptions.Algorithm);

            return(new SecurityTokenDescriptor
            {
                Issuer = _jwtOptions.Issuer,
                Audience = _jwtOptions.Audience,
                Expires = expireTime,
                SigningCredentials = signingCredentials,
                EncryptingCredentials = _jwtOptions.EncryptingCredentials,
                Claims = claimCollection
            });
        }