示例#1
0
        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;
            }));
        }
示例#2
0
        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());
        }
示例#3
0
        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);
        }