예제 #1
0
        public override async Task <IdentityResult> CreateAsync(ApplicationUser user, string password)
        {
            user.password = password;
            await _store.CreateAsync(user);

            return(new SuccessIdentityResult());
        }
        public async Task UserRoleStore_create_user_add_to_role()
        {
            var user     = _userTestFactory.CreateUser();
            var username = "******";
            await _userStore.SetUserNameAsync(user, username, default(CancellationToken));

            await _userStore.SetNormalizedUserNameAsync(user, username, default(CancellationToken));

            await _userStore.CreateAsync(user, default(CancellationToken));

            var foundUser = await _userStore.FindByIdAsync(user.Id, default(CancellationToken));

            foundUser.UserName.ShouldMatch(user.UserName);

            var role = _roleTestFactory.CreateRole();
            await _roleStore.CreateAsync(role, default(CancellationToken));

            await _roleStore.SetNormalizedRoleNameAsync(role, role.Name, default(CancellationToken));

            await _userRoleStore.AddToRoleAsync(user, role.Name, default(CancellationToken));

            var roles = await _userRoleStore.GetRolesAsync(user, default(CancellationToken));

            roles.Count.ShouldBeGreaterThan(0);

            var users = await _userRoleStore.GetUsersInRoleAsync(role.Name, default(CancellationToken));

            users.Count.ShouldBeGreaterThan(0);

            var firstUser = users.FirstOrDefault();

            firstUser.ShouldNotBeNull();
            firstUser.UserName.ShouldMatch(user.UserName);
        }
예제 #3
0
        public async Task UserStore_create_find_by_name()
        {
            var user     = _userTestFactory.CreateUser();
            var username = "******";
            await _userStore.SetUserNameAsync(user, username, default(CancellationToken));

            await _userStore.SetNormalizedUserNameAsync(user, username, default(CancellationToken));

            await _userStore.CreateAsync(user, default(CancellationToken));

            var foundUser = await _userStore.FindByNameAsync(user.UserName, default(CancellationToken));

            foundUser.UserName.ShouldMatch(user.UserName);
        }
예제 #4
0
        public async Task <IActionResult> CreateAdmin(CreateAdminEditModel model)
        {
            if (ModelState.IsValid)
            {
                // Create the user
                if (!await _userStore.UserExistsAsync(model.UserName))
                {
                    var user = new User {
                        UserName = model.UserName, Name = model.Name, Email = model.Email
                    };
                    var result = await _userStore.CreateAsync(user, model.Password, "Administrator");

                    if (result.Success)
                    {
                        return(RedirectToAction("Login", "Account", new { area = "Admin" }));
                    }
                    ModelState.AddModelError(string.Empty, result.Error);
                }
                else
                {
                    ModelState.AddModelError(string.Empty, "UserName is already taken.");
                }
            }

            return(View(model));
        }
예제 #5
0
        public async Task <NameAnswer> SignUpAsync(string username, string password, uint role)
        {
            if (String.IsNullOrEmpty(username) || username.Length > 64)
            {
                return(new NameAnswer
                {
                    Error = "Username value must be valid and less / equal 64 characters"
                });
            }

            if (String.IsNullOrEmpty(password) || password.Length > 64 || password.Length < 8)
            {
                return(new NameAnswer
                {
                    Error = "Password value must be valid and between 8 and 64 characters"
                });
            }

            var user = await _userStore.GetAsync(username);

            if (user != null)
            {
                return(new NameAnswer
                {
                    Error = "User does exist!"
                });
            }

            var salt    = SecureWithSHA512(GetRandomSalt());
            var combine = CombineWithSalt(username, password, salt);
            var hash    = SecureWithSHA512(combine);

            user = new User
            {
                Name     = username,
                Salt     = salt,
                Password = hash,
                RoleId   = role
            };

            user = await _userStore.CreateAsync(user);

            if (user == null)
            {
                return(new NameAnswer
                {
                    Error = "User registration has failed"
                });
            }

            return(new NameAnswer
            {
                Id = user.Id,
                Name = user.Name
            });
        }
예제 #6
0
        public async Task Create(T user, CancellationToken cancellationToken = default)
        {
            var foundUser = await _userStore.FindByNameAsync(user.UserName, cancellationToken);

            if (foundUser != null)
            {
                return;
            }
            await _userStore.CreateAsync(user, cancellationToken);
        }
        public async Task CreateUserFIxture()
        {
            var expected = new ApplicationUser
            {
                UserName     = "******",
                PasswordHash = "abcdefhijklmnopqrstuvwxyz",
                Claims       = new List <IdentityUserClaim <int> >
                {
                    new IdentityUserClaim <int> {
                        ClaimType = "TestClaimType1", ClaimValue = "TestClaimValue1"
                    },
                    new IdentityUserClaim <int> {
                        ClaimType = "TestClaimType2", ClaimValue = "TestClaimValue2"
                    }
                }
            };

            var response = await userStore.CreateAsync(expected, System.Threading.CancellationToken.None);

            Assert.IsTrue(response.Succeeded);

            var actualByName = await userStore.FindByNameAsync(expected.UserName, System.Threading.CancellationToken.None);

            Assert.IsNotNull(actualByName);
            Assert.AreEqual(expected.UserName, actualByName.UserName);
            Assert.AreEqual(expected.PasswordHash, actualByName.PasswordHash);
            CollectionAssert.AreEqual(
                expected.Claims.Select(iuc => (iuc.ClaimType, iuc.ClaimValue)).ToArray(),
                actualByName.Claims.Select(iuc => (iuc.ClaimType, iuc.ClaimValue)).ToArray());

            var actualById = await userStore.FindByIdAsync(actualByName.Id.ToString(), System.Threading.CancellationToken.None);

            Assert.IsNotNull(actualById);
            Assert.AreEqual(expected.UserName, actualById.UserName);
            Assert.AreEqual(expected.PasswordHash, actualById.PasswordHash);
            CollectionAssert.AreEqual(
                expected.Claims.Select(iuc => (iuc.ClaimType, iuc.ClaimValue)).ToArray(),
                actualById.Claims.Select(iuc => (iuc.ClaimType, iuc.ClaimValue)).ToArray());

            await userStore.DeleteAsync(expected, System.Threading.CancellationToken.None);
        }
예제 #8
0
        public async Task <IActionResult> NewPreliminaryApplication([FromBody] PreliminaryApplicationDto applicationDto)
        {
            var user = await _users.FindByNameAsync(applicationDto.Email, new CancellationToken(false));

            if (user != null)
            {
                return(BadRequest("Already pre-registered"));
            }

            var newUser = new IdentityUser()
            {
                Id                 = Guid.NewGuid().ToString(),
                Email              = applicationDto.Email,
                UserName           = applicationDto.Email,
                NormalizedUserName = applicationDto.Email,
                EmailConfirmed     = false
            };

            newUser.PasswordHash = new PasswordHasher <IdentityUser>().HashPassword(newUser, RandomString(40));

            var newCoreUser = CoreUser.Create(Guid.Parse(newUser.Id));

            newCoreUser.Update(new CoreUserDto()
            {
                Access  = AccessEnum.Standard,
                Picture = @""
            });

            _readWriteRepository.Create <CoreUser, Guid>(newCoreUser);

            var application = Application.Create(Guid.Parse(newUser.Id), 1);

            var preliminaryDto = new ApplicationDto()
            {
                UserId      = Guid.Parse(newUser.Id),
                Name        = applicationDto.Name,
                Status      = StatusEnum.Preliminary,
                DateOfBirth = applicationDto.DateOfBirth,
                State       = applicationDto.State,
                Country     = applicationDto.Country,
                //Hold over variables
                PhoneNo        = application.PhoneNo,
                RegistrationNo = application.RegistrationNo
            };

            application.Update(preliminaryDto);

            _readWriteRepository.Create <Application, int>(application);

            await _users.CreateAsync(newUser, default(CancellationToken));

            return(Ok());
        }
예제 #9
0
        public async Task Create_User_many_Factor()
        {
            var testUser = CreateTestUser();


            var createUserResult = await _userStore.CreateAsync(testUser, CancellationToken.None);

            createUserResult.ShouldNotBeNull();
            createUserResult.Succeeded.ShouldBeTrue();
            int nCount = 10;

            for (int i = 0; i < nCount; ++i)
            {
                var challengeFactor = CreateTestFactor();
                var identityResult  = await _multiFactorUserStore.AddToFactorAsync(
                    testUser, challengeFactor, CancellationToken.None);

                identityResult.ShouldNotBeNull();
                identityResult.Succeeded.ShouldBeTrue();

                var findResult = await _multiFactorUserStore.FindByIdAsync(challengeFactor.FactorId,
                                                                           CancellationToken.None);

                findResult.ShouldNotBeNull();
                findResult.FactorId.ShouldBe(challengeFactor.FactorId);
            }

            var factors = await _multiFactorUserStore.GetFactorsAsync(testUser, CancellationToken.None);

            factors.ShouldNotBeNull();
            factors.Count.ShouldBe(nCount);
            foreach (var factor in factors)
            {
                factor.ShouldNotBeNull();
                factor.Challenge.ShouldNotBeNull();
                factor.ChallengeResponseHash.ShouldNotBeNull();
                factor.FactorId.ShouldNotBeNull();
            }
        }
예제 #10
0
        public async Task SeedAsync()
        {
            var cts = new CancellationTokenSource();

            var role = new IdentityRole("Admin");
            await mRoleStore.CreateAsync(role, cts.Token);

            var user = new ApiUser {
                Id = "mike", UserName = "******"
            };

            user.PasswordHash = mHasher.HashPassword(user, "123");

            await mUserStore.CreateAsync(user, cts.Token);
        }
        public async Task CreateAsync_NewIdentityUser_ShouldPersistUserToDocument()
        {
            await _userStore.CreateAsync(new RavenIdentityUser()
            {
                UserName = "******", Email = "*****@*****.**"
            });

            using (var session = AsyncDocumentSession)
            {
                var user = (await session.Query <RavenIdentityUser>()
                            .SingleOrDefaultAsync(u => u.UserName == "user.one")
                            .ConfigureAwait(false));

                Assert.IsNotNull(user);
            }
        }
예제 #12
0
        public virtual async Task <IdentityResult> CreateAsync(TUser user)
        {
            // ThrowIfDisposed();
            // await UpdateSecurityStampInternal(user);
            // var result = await ValidateUserAsync(user);
            // if (!result.Succeeded)
            // {
            //     return result;
            // }
            // if (Options.Lockout.AllowedForNewUsers && SupportsUserLockout)
            // {
            //     await GetUserLockoutStore().SetLockoutEnabledAsync(user, true, CancellationToken);
            // }
            // await UpdateNormalizedUserNameAsync(user);
            // await UpdateNormalizedEmailAsync(user);

            return(await Store.CreateAsync(user, CancellationToken));
        }
예제 #13
0
 public void CreateAsyncStoredProcExists()
 {
     try
     {
         var userModel = new UserModel()
         {
             Id                 = Guid.NewGuid().ToString(),
             UserName           = It.IsAny <string>(),
             NormalizedUserName = It.IsAny <string>(),
             PasswordHash       = It.IsAny <string>(),
             IsActive           = true,
         };
         userStoreMethodLookup.CreateAsync(userModel, cancellationTokenSource.Token).Wait();
     }
     catch
     {
         Assert.Fail();
     }
 }
예제 #14
0
        public void CreateAsync()
        {
            var userModel = new UserModel()
            {
                Id                 = Guid.NewGuid().ToString(),
                UserName           = It.IsAny <string>(),
                NormalizedUserName = It.IsAny <string>(),
                PasswordHash       = It.IsAny <string>(),
                IsActive           = true,
            };
            var returnModel = new UserModel();

            repository.Setup(x => x.GetData(It.IsAny <string>(), It.IsAny <CancellationToken>(), It.IsAny <(string, object)[]>())).ReturnsAsync(returnModel).Verifiable();
            var task = userStore.CreateAsync(userModel, cancellationTokenSource.Token);

            task.Wait();
            Assert.IsTrue(task.Result.Succeeded);
            repository.Verify();
            repository.VerifyNoOtherCalls();
        }
예제 #15
0
        protected virtual async Task <AuthenticateResult> ProcessNewExternalAccountAsync(string provider, string providerId, IEnumerable <Claim> claims)
        {
            var user = await TryGetExistingUserFromExternalProviderClaimsAsync(provider, claims);

            if (user == null)
            {
                user = await InstantiateNewUserFromExternalProviderAsync(provider, providerId, claims);

                if (user == null)
                {
                    throw new InvalidOperationException("CreateNewAccountFromExternalProvider returned null");
                }

                var createResult = await _userStore.CreateAsync(user);

                if (!createResult.Succeeded)
                {
                    return(new AuthenticateResult(createResult.Errors.First()));
                }
            }

            var externalLogin     = new ExternalLoginInfo(provider, providerId);
            var addExternalResult = await _userStore.AddLoginAsync(user.Id, externalLogin);

            if (!addExternalResult.Succeeded)
            {
                return(new AuthenticateResult(addExternalResult.Errors.First()));
            }

            var result = await AccountCreatedFromExternalProviderAsync(user.Id, provider, providerId, claims);

            if (result != null)
            {
                return(result);
            }

            return(await SignInFromExternalProviderAsync(user.Id, provider));
        }
        public void Should_create_and_get_user()
        {
            //arrange
            var user = new IdentityUser
            {
                Id             = Guid.NewGuid(),
                UserName       = "******",
                PasswordHash   = "test_password",
                Email          = "*****@*****.**",
                EmailConfirmed = true,
                BirthDate      = DateTimeOffset.Now,
                City           = "TestCity",
                FirstName      = "FirstNameTest",
                SecondName     = "SecondNameTest",
                RegDate        = DateTimeOffset.Now,
                SecurityStamp  = Guid.NewGuid()
            };

            //act
            _userRepository.CreateAsync(user);

            var result = _userRepository.FindByIdAsync(user.Id).Result;

            //asserts
            Assert.AreEqual(user.Id, result.Id);
            Assert.AreEqual(user.UserName, result.UserName);
            //Assert.AreEqual(user.PasswordHash, result.PasswordHash);
            Assert.AreEqual(user.Email, result.Email);
            Assert.AreEqual(user.EmailConfirmed, result.EmailConfirmed);
            Assert.AreEqual(user.BirthDate, result.BirthDate);
            Assert.AreEqual(user.City, result.City);
            Assert.AreEqual(user.FirstName, result.FirstName);
            Assert.AreEqual(user.SecondName, result.SecondName);
            Assert.AreEqual(user.RegDate, result.RegDate);
            Assert.AreEqual(user.SecurityStamp, result.SecurityStamp);
        }
예제 #17
0
 public async Task CreateAsync(User user)
 {
     await _userStore.CreateAsync(user);
 }
예제 #18
0
        private void GenerateData(IUserStore userStore)
        {
            CreateAsync(new Lot
            {
                Title = "HTC One M8 16GB Gunmetal Grey Unlocked",
                Description = "An item that has been used previously",
                StartTime = DateTime.Now,
                EndTime = DateTime.Now.AddMonths(1),
                StartPrice = new Currency("$125.66"),
                Owner = userStore.CreateAsync(new User { Email = "*****@*****.**", Username = "******" }, "123456").Result
            });

            CreateAsync(new Lot
            {
                Title = "HTC One M9 32GB",
                Description = "A brand-new, unused, unopened, undamaged item in its original packaging",
                StartTime = DateTime.Now,
                EndTime = DateTime.Now.AddMonths(1),
                StartPrice = new Currency("$320.00"),
                Owner = userStore.CreateAsync(new User { Email = "*****@*****.**", Username = "******" },"234567").Result
            });

            AddBid(_id, new Bid
            {
                User = userStore.CreateAsync(new User { Email = "*****@*****.**", Username = "******" },"345678").Result,
                Amount = new Currency("$300.00"),
                Timestamp = DateTime.Now.AddMinutes(1)
            });

            AddBid(_id, new Bid
            {
                User = userStore.CreateAsync(new User { Email = "*****@*****.**", Username = "******" }, "456789").Result,
                Amount = new Currency("$320.00"),
                Timestamp = DateTime.Now.AddMinutes(1)
            });
        }
        public async Task Can_Perform_Operations_On_Users_And_Get_Preferences_From_Api()
        {
            // Arrange
            var emailAddress = $"some.user.{Guid.NewGuid()}@some.domain.com";

            var user = new LondonTravelUser()
            {
                CreatedAt          = DateTime.UtcNow,
                Email              = emailAddress,
                EmailNormalized    = emailAddress,
                GivenName          = "Alexa",
                Surname            = "Amazon",
                UserName           = emailAddress,
                UserNameNormalized = emailAddress,
            };

            string accessToken = Controllers.AlexaController.GenerateAccessToken();

            string[] favoriteLines = new[] { "district", "northern" };
            string   userId;

            using (IUserStore <LondonTravelUser> store = GetUserStore())
            {
                // Act
                IdentityResult createResult = await store.CreateAsync(user, default);

                // Assert
                Assert.NotNull(createResult);
                Assert.True(createResult.Succeeded);
                Assert.NotEmpty(user.Id);

                // Arrange
                userId = user.Id;

                // Act
                LondonTravelUser actual = await store.FindByIdAsync(userId, default);

                // Assert
                Assert.NotNull(actual);
                Assert.Equal(userId, actual.Id);
                Assert.Null(actual.AlexaToken);
                Assert.Equal(user.CreatedAt, actual.CreatedAt);
                Assert.Equal(user.Email, actual.Email);
                Assert.False(actual.EmailConfirmed);
                Assert.NotEmpty(actual.ETag);
                Assert.Equal(Array.Empty <string>(), actual.FavoriteLines);
                Assert.Equal(user.GivenName, actual.GivenName);
                Assert.Equal(Array.Empty <LondonTravelLoginInfo>(), actual.Logins);
                Assert.Equal(user.Surname, actual.Surname);
                Assert.Equal(user.UserName, actual.UserName);

                // Arrange
                string etag = actual.ETag;

                actual.AlexaToken    = accessToken;
                actual.FavoriteLines = favoriteLines;

                // Act
                IdentityResult updateResult = await store.UpdateAsync(actual, default);

                // Assert
                Assert.NotNull(updateResult);
                Assert.True(updateResult.Succeeded);

                // Act
                actual = await store.FindByNameAsync(emailAddress, default);

                // Assert
                Assert.NotNull(actual);
                Assert.Equal(userId, actual.Id);
                Assert.Equal(emailAddress, actual.Email);
                Assert.NotEqual(etag, actual.ETag);
                Assert.Equal(accessToken, actual.AlexaToken);
                Assert.Equal(favoriteLines, actual.FavoriteLines);
            }

            // Arrange
            using (var message = new HttpRequestMessage(HttpMethod.Get, "api/preferences"))
            {
                message.Headers.Authorization = new AuthenticationHeaderValue("bearer", accessToken);

                using (var client = Fixture.CreateClient())
                {
                    // Act
                    using (var response = await client.SendAsync(message, default))
                    {
                        // Assert
                        Assert.Equal(HttpStatusCode.OK, response.StatusCode);
                        Assert.Equal("application/json", response.Content.Headers.ContentType.MediaType);

                        string json = await response.Content.ReadAsStringAsync();

                        dynamic preferences = JObject.Parse(json);

                        Assert.Equal(userId, (string)preferences.userId);
                        Assert.Equal(favoriteLines, preferences.favoriteLines.ToObject <string[]>() as IList <string>);
                    }
                }
            }

            // Arrange
            using (IUserStore <LondonTravelUser> store = GetUserStore())
            {
                // Act
                IdentityResult updateResult = await store.DeleteAsync(new LondonTravelUser()
                {
                    Id = userId
                }, default);

                // Assert
                Assert.NotNull(updateResult);
                Assert.True(updateResult.Succeeded);
            }

            // Arrange
            using (var message = new HttpRequestMessage(HttpMethod.Get, "api/preferences"))
            {
                message.Headers.Authorization = new AuthenticationHeaderValue("bearer", accessToken);

                using (var client = Fixture.CreateClient())
                {
                    // Act
                    using (var response = await client.SendAsync(message, default))
                    {
                        // Assert
                        Assert.Equal(HttpStatusCode.Unauthorized, response.StatusCode);
                        Assert.Equal("application/json", response.Content.Headers.ContentType.MediaType);
                    }
                }
            }
        }
예제 #20
0
 private static async Task CreateUser(IUserStore<IdentityUser, string> userStore, string id)
 {
     await Task.Run(async () => await userStore.CreateAsync(new IdentityUser
     {
         Id = id,
         Email = CreateEmailFromId(id),
         UserName = CreateNameFromId(id)
     }));
 }
예제 #21
0
 public Task CreateUser(ApplicationUser user)
 {
     //создание юзера
     return(_customUserStore.CreateAsync(user));
 }
예제 #22
0
 public Task ApplySeeds(User[] users)
 {
     return(Task.WhenAll(users.Select(user => _userStore.CreateAsync(user, CancellationToken.None))));
 }
예제 #23
0
 public Task <IdentityResult> CreateAsync(User user, CancellationToken cancellationToken)
 {
     return(_userStore.CreateAsync(user, cancellationToken));
 }