Example #1
0
        private void CreateAccount(CompleteAdditionalInformationModel model,
                                   ClaimsIdentity partialSignInUser)
        {
            var newUser = new User
            {
                Subject  = Guid.NewGuid().ToString(),
                IsActive = true
            };

            newUser.UserLogins.Add(new UserLogin()
            {
                Subject       = newUser.Subject,
                LoginProvider = "windows",
                ProviderKey   = partialSignInUser
                                .Claims
                                .First(c => c.Type == "external_provider_user_id")
                                .Value
            });

            newUser.UserClaims.Add(new UserClaim()
            {
                Id         = Guid.NewGuid().ToString(),
                Subject    = newUser.Subject,
                ClaimType  = Constants.ClaimTypes.Email,
                ClaimValue = partialSignInUser
                             .Claims
                             .First(c => c.Type == Constants.ClaimTypes.Email)
                             .Value
            });

            newUser.UserClaims.Add(new UserClaim()
            {
                Id         = Guid.NewGuid().ToString(),
                Subject    = newUser.Subject,
                ClaimType  = Constants.ClaimTypes.GivenName,
                ClaimValue = model.FirstName
            });


            newUser.UserClaims.Add(new UserClaim()
            {
                Id         = Guid.NewGuid().ToString(),
                Subject    = newUser.Subject,
                ClaimType  = Constants.ClaimTypes.FamilyName,
                ClaimValue = model.LastName
            });

            newUser.UserClaims.Add(new UserClaim()
            {
                Id         = Guid.NewGuid().ToString(),
                Subject    = newUser.Subject,
                ClaimType  = "role",
                ClaimValue = model.Role
            });

            Save(newUser);
        }
Example #2
0
        public async Task <ActionResult> Index(CompleteAdditionalInformationModel model)
        {
            var partialSignInUser = await EnsurePartialSignedUserFound();

            if (!ModelState.IsValid)
            {
                return(View());
            }

            CreateAccount(model, partialSignInUser);

            var environment = GetOwinContext().Environment;

            return(Redirect(await environment.GetPartialLoginResumeUrlAsync()));
        }
Example #3
0
        public async Task <ActionResult> Index(CompleteAdditionalInformationModel model)
        {
            // we're only allowed here when we have a partial sign-in
            var ctx = Request.GetOwinContext();
            var partialSignInUser = await ctx.Environment.GetIdentityServerPartialLoginAsync();

            if (partialSignInUser == null)
            {
                return(View("No partially signed-in user found."));
            }

            if (ModelState.IsValid)
            {
                using (var userRepository = new UserRepository())
                {
                    // create a user in our user store, including claims & windows as
                    // an external login.

                    // create a new account
                    var newUser = new User();
                    newUser.Subject  = Guid.NewGuid().ToString();
                    newUser.IsActive = true;

                    // add the external identity provider as login provider
                    // => external_provider_user_id contains the id/key
                    newUser.UserLogins.Add(new UserLogin()
                    {
                        Subject       = newUser.Subject,
                        LoginProvider = "windows",
                        ProviderKey   = partialSignInUser.Claims.First(c => c.Type == "external_provider_user_id").Value
                    });

                    // create e-mail claim
                    newUser.UserClaims.Add(new UserClaim()
                    {
                        Id         = Guid.NewGuid().ToString(),
                        Subject    = newUser.Subject,
                        ClaimType  = IdentityServer3.Core.Constants.ClaimTypes.Email,
                        ClaimValue = partialSignInUser.Claims.First(
                            c => c.Type == IdentityServer3.Core.Constants.ClaimTypes.Email).Value
                    });

                    // create claims from the model
                    newUser.UserClaims.Add(new UserClaim()
                    {
                        Id         = Guid.NewGuid().ToString(),
                        Subject    = newUser.Subject,
                        ClaimType  = IdentityServer3.Core.Constants.ClaimTypes.GivenName,
                        ClaimValue = model.FirstName
                    });
                    newUser.UserClaims.Add(new UserClaim()
                    {
                        Id         = Guid.NewGuid().ToString(),
                        Subject    = newUser.Subject,
                        ClaimType  = IdentityServer3.Core.Constants.ClaimTypes.FamilyName,
                        ClaimValue = model.LastName
                    });

                    newUser.UserClaims.Add(new UserClaim()
                    {
                        Id         = Guid.NewGuid().ToString(),
                        Subject    = newUser.Subject,
                        ClaimType  = "role",
                        ClaimValue = model.Role
                    });

                    // add the user
                    userRepository.AddUser(newUser);

                    // continue where we left off
                    return(Redirect(await ctx.Environment.GetPartialLoginResumeUrlAsync()));
                }
            }

            return(View());
        }