public async Task <UserStatusModel> AutoSignIn(UserAutoSignInModel model) { var provider = await _repositoryProvider.GetFirst(x => x.Slug == model.ProviderSlug && x.State == MREntityState.Active); if (provider == null) { _eNotFound("Provider not found"); } return(new UserStatusModel { CallbackToken = ProviderTokenGenerator.Generate(provider.Id, _userId), CallbackUrl = string.IsNullOrWhiteSpace(model.RedirectUrl) ? provider.Options.CallbackUrl : model.RedirectUrl }); }
public async Task <UserStatusModel> SignUp(UserSignupModel model) { var exists = await _managerUser.FindByEmailAsync(model.Email); if (exists != null) { throw new MRException <UserStatusModel>((int)ExceptionCode.SYSTEM_EXCEPTION, "User with this email already exists"); } var user = _mapper.Map <User>(model); var saveResult = await _managerUser.CreateAsync(user); if (!saveResult.Succeeded) { throw new MRException <UserStatusModel>((int)ExceptionCode.SYSTEM_EXCEPTION, "Can not create user"); } await _managerUser.AddPasswordAsync(user, model.Password); await _managerUser.AddToRoleAsync(user, AppRoles.USER.ToString()); string providerToken = null; if (!string.IsNullOrWhiteSpace(model.ProviderSlug)) { var provider = await _repositoryProvider.GetFirst(x => x.Slug == model.ProviderSlug && x.State == MREntityState.Active); if (provider != null) { if (!provider.Options.IsRegistrationAvaliable) { throw new MRException <object>(-1, "Provider registration disabled"); } providerToken = ProviderTokenGenerator.Generate(provider.Id, user.Id); } } var token = _serviceToken.GenerateToken(user.Id, user.Email, new List <string> { AppRoles.USER.ToString() }); var response = new UserStatusModel { FirstName = user.FirstName, LastName = user.LastName, Email = user.Email, AccessToken = token, Roles = new List <string> { AppRoles.USER.ToString() }, LanguageCode = user.LanguageCode, Sex = user.Sex, CallbackUrl = model.CallbackUrl, CallbackToken = providerToken, IsEmailConfirmed = false, IsEmailOnChange = false }; return(response); }
public async Task <UserStatusModel> SignIn(UserSignInModel model) { var user = await _managerUser.FindByEmailAsync(model.Email); if (user == null || !await _managerUser.CheckPasswordAsync(user, model.Password)) { _eNotFound <UserStatusModel>("User not found"); } var userRoles = await _managerUser.GetRolesAsync(user); var token = _serviceToken.GenerateToken(user.Id, user.Email, userRoles); UserLoginInfo li = null; string callbackToken = null; if (!string.IsNullOrWhiteSpace(model.ProviderSlug)) { var provider = await _repositoryProvider.GetFirst(x => x.Slug == model.ProviderSlug && x.State == MREntityState.Active); if (provider != null && provider.Options.IsEnabled) { li = new UserLoginInfo(provider.Id, token, provider.Slug); _serviceToken.GenerateToken("SOME_SECRET_KEY", "MR_IDENTITY", "SOME_PROVIDER", 60, new List <Tuple <string, string> > { new Tuple <string, string>("provider.id", provider.Id), new Tuple <string, string>("user.id", user.Id) }, "name", "password"); callbackToken = ProviderTokenGenerator.Generate(provider.Id, user.Id); } } if (li == null) { li = new UserLoginInfo(_tokenOptions.Issuer, token, _tokenOptions.Issuer); } if (await _managerUser.FindByLoginAsync(li.LoginProvider, li.ProviderKey) != null) { await _managerUser.RemoveLoginAsync(user, li.LoginProvider, li.ProviderKey); } await _managerUser.AddLoginAsync(user, li); var isEmailOnChange = await _repositoryEmailChangeUnit.Any(x => x.State == MREntityState.Active && x.UserId == user.Id && x.Status == Infrastructure.Entity.Enum.EmailChangeResult.NEW); _logger.LogInformation($"User login"); return(new UserStatusModel { FirstName = user.FirstName, LastName = user.LastName, Roles = userRoles.ToList(), AccessToken = token, LanguageCode = user.LanguageCode, Email = user.Email, Sex = user.Sex, IsEmailConfirmed = user.IsEmailConfirmed, IsEmailOnChange = isEmailOnChange, CallbackUrl = model.CallbackUrl, CallbackToken = callbackToken }); }