Exemplo n.º 1
0
        public async Task <BindResult> BindAsync(string type, string token)
        {
            ClaimsPrincipal cp;

            Claim[] claims = null;
            switch (type)
            {
            case "google-id_token":
            case "norton-id_token":
                // These will throw, but best to let it happen and catch all the way up top.
                cp = await _jwtTokenValidation.ValidateToken(type, token);

                claims = cp.Claims.ToArray();
                break;

            case "norton-seat_id":
            case "norton-entitlement_id":
                claims = new[]
                {
                    new Claim(ClaimTypes.Name, "bob")
                };
                break;
            }

            var key      = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(_configuration["SecurityKey"]));
            var creds    = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);
            var jwtToken = new JwtSecurityToken(
                issuer: "yourdomain.com",
                audience: "yourdomain.com",
                claims: claims,
                expires: DateTime.Now.AddMinutes(30),
                signingCredentials: creds);

            return(new BindResult()
            {
                Type = type,
                Token = new JwtSecurityTokenHandler().WriteToken(jwtToken),
                SPOCEntity = Guid.NewGuid().ToString()
            });
        }