public async Task <Usuario> VerificaLoginGoogle(UsuarioSocialViewModel login) { return(await Task.Run(() => { var usuario = _usuarioRepository.PegarUsuarioLogin(x => x.Login == login.Email && x.ContaGoogle); if (usuario != null) { return usuario; } return null; })); }
public async Task <IActionResult> LoginComGoogle([FromBody] UsuarioSocialViewModel usuario) { if (!ModelState.IsValid) { return(BadRequest()); } IActionResult response = Unauthorized(); var usuarioLogado = await AutenticaComGoogle(usuario); if (usuarioLogado != null) { usuarioLogado.Token = await CriaToken(usuarioLogado, usuario.IdToken); if (usuarioLogado.Token == null) { return(StatusCode(StatusCodes.Status401Unauthorized)); } return(Ok(usuarioLogado)); } return(Unauthorized()); }
private async Task <UsuarioLogadoViewModel> AutenticaComGoogle(UsuarioSocialViewModel login) { if (login != null) { var usuario = await _loginServico.VerificaLoginGoogle(login); if (usuario == null) { return(null); } if (!usuario.Ativo) { return(null); } if (!usuario.ContaGoogle) { return(null); } try { var organizacoes = await _organizacaoService.ListarOrganizacoesUsuarioEmail(usuario.Login); OrganizacaoUsuario organizacaoUsuario = null; if (organizacoes.Any(x => x.UltimaAcessada)) { organizacaoUsuario = organizacoes.FirstOrDefault(x => x.UsuarioPlataforma && x.UltimaAcessada); } else { organizacaoUsuario = organizacoes.FirstOrDefault(x => x.UsuarioPlataforma); } var pessoa = await _pessoaRepository.BuscarPorEmail(usuario.Login); if (!usuario.Ativo) { return(null); } UsuarioLogadoViewModel usuarioLogado = null; if (!pessoa.GoobeeAdmin) { if (organizacaoUsuario == null || !organizacaoUsuario.IdUsuario.HasValue) { return(null); } if (organizacaoUsuario.Pessoa == null || organizacaoUsuario.Pessoa.Status == false) { return(null); } List <Guid> idsTimes = new List <Guid>(); foreach (var timePessoa in organizacaoUsuario.Pessoa.TimePessoas) { if (timePessoa.IdOrganizacao == organizacaoUsuario.IdOrganizacao) { idsTimes.Add(timePessoa.IdTime); } } usuarioLogado = new UsuarioLogadoViewModel() { DataCriacao = organizacaoUsuario.Pessoa.DataCriacao, Email = organizacaoUsuario.Pessoa.Email, Nome = organizacaoUsuario.Pessoa.Nome, Foto = organizacaoUsuario.Pessoa.Foto, Id = organizacaoUsuario.IdUsuario.Value, IdPessoa = organizacaoUsuario.IdPessoa, IdOrganizacao = organizacaoUsuario.IdOrganizacao, RoleEnum = organizacaoUsuario.OrganizacaoUsuarioRole.Role, IdsTimes = idsTimes }; } else { Guid?idOrganizacao; if (pessoa.IdUltimaOrgAcessada.HasValue) { idOrganizacao = pessoa.IdUltimaOrgAcessada.Value; } else { idOrganizacao = _organizacaoRepository.GetAll().FirstOrDefault()?.Id; } usuarioLogado = new UsuarioLogadoViewModel() { DataCriacao = DateTime.Now, Email = pessoa.Email, Nome = pessoa.Nome, Foto = pessoa.Foto, Id = usuario.Id, IdPessoa = pessoa.Id, IdOrganizacao = idOrganizacao, RoleEnum = OrganizacaoUsuarioRoleEnum.GoobeeAdmin, IdsTimes = new List <Guid>() }; } return(usuarioLogado); } catch (Exception error) { return(null); } } return(null); }