コード例 #1
0
        public IActionResult Login(string nome, string password)
        {
            ViewData["ReturnUrl"] = Request.Query["ReturnURL"];
            Utilizador utilizador = new Utilizador {
                NomeUtilizador = nome, Password = password
            };

            if (nome != null && password != null)
            {
                FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;

                List <Utilizador> LstUtilizadores = context.ObterListaUtilizadores().Where(u => u.NomeUtilizador == utilizador.NomeUtilizador).ToList();

                if (LstUtilizadores.Count == 0)
                {
                    ModelState.AddModelError("", "Não foram encontrados utlizadores com esse nome!");
                }

                foreach (var user in LstUtilizadores)
                {
                    var passwordHasher = new PasswordHasher <string>();
                    if (passwordHasher.VerifyHashedPassword(null, user.Password, utilizador.Password) == PasswordVerificationResult.Success)
                    {
                        var claims = new List <Claim>
                        {
                            new Claim(ClaimTypes.Name, user.Id.ToString()),
                            new Claim(ClaimTypes.GivenName, user.NomeCompleto),
                            new Claim(ClaimTypes.Role, user.Admin ? "Admin" : "User"),
                            new Claim(ClaimTypes.Role, user.TipoUtilizador == 1 ? "Tech" : user.TipoUtilizador == 2 ? "Comercial" : "Escritorio")
                        };
                        var claimsIdentity = new ClaimsIdentity(claims, CookieAuthenticationDefaults.AuthenticationScheme);
                        HttpContext.SignInAsync(CookieAuthenticationDefaults.AuthenticationScheme, new ClaimsPrincipal(claimsIdentity));
                        context.AdicionarLog(utilizador.NomeUtilizador, "LOGIN SUCESSO", 4);

                        if (ViewData["ReturnUrl"].ToString() != "" && ViewData["ReturnUrl"].ToString() != null)
                        {
                            Response.Redirect(ViewData["ReturnUrl"].ToString(), true);
                        }
                        else
                        {
                            return(RedirectToAction("Index", "Home"));
                        }
                    }
                    else
                    {
                        context.AdicionarLog(utilizador.NomeUtilizador, "LOGIN SEM SUCESSO", 4);

                        ModelState.AddModelError("", "Password errada!");
                    }
                }
            }
            return(View());
        }
コード例 #2
0
        public virtual ActionResult PrintFolhaObra(int id)
        {
            FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;
            FolhaObra            fo      = context.ObterFolhaObra(id);

            if (!this.User.IsInRole("Admin") && !this.User.IsInRole("Escritorio") && fo.IntervencaosServico.Where(i => i.IdTecnico == context.ObterUtilizador(int.Parse(this.User.Claims.First().Value.ToString())).IdPHC).Count() == 0)
            {
                return(Redirect("~/Home/AcessoNegado"));
            }

            var file   = context.PreencherFormularioFolhaObra(fo).ToArray();
            var output = new MemoryStream();

            output.Write(file, 0, file.Length);
            output.Position = 0;

            var cd = new System.Net.Mime.ContentDisposition
            {
                FileName     = "FolhaObra_" + id + ".pdf",
                Inline       = false,
                Size         = file.Length,
                CreationDate = DateTime.Now,
            };

            Response.Headers.Add("Content-Disposition", cd.ToString());
            context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Foi impressa uma folha de obra: " + id, 3);

            return(File(output, System.Net.Mime.MediaTypeNames.Application.Pdf));
        }
コード例 #3
0
        public ActionResult Adicionar(int IdCliente, int IdLoja, DateTime txtData, int txtComercial, string Obs)
        {
            if (IdCliente == 0 && IdLoja == 0 && txtComercial == 0)
            {
                return(View());
            }

            FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;
            Visita visita = new Visita()
            {
                IdVisita   = 0,
                DataVisita = txtData,
                Cliente    = new Cliente()
                {
                    IdCliente = IdCliente,
                    IdLoja    = IdLoja
                },
                IdComercial  = txtComercial,
                ResumoVisita = Obs,
                ObsVisita    = "",
                EstadoVisita = "Agendado",
                Contacto     = new Contacto()
                {
                    IdContacto = 0
                }
            };
            List <Visita> lstVisitas = new List <Visita>();

            lstVisitas.Add(visita);

            context.CriarVisitas(lstVisitas);
            context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Foi adicionada uma visita nova ao cliente: " + IdCliente, 5);

            return(RedirectToAction("Index", "Visitas"));
        }
コード例 #4
0
        public JsonResult EditarStockFisico(string refproduto, string stockfisico, int armazemid)
        {
            FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;
            Produto produtoFinal         = context.ObterProduto(refproduto, armazemid);

            context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Foi alterado o stock fisico do produto " + refproduto + " de " + produtoFinal.Stock_Fisico + " para " + stockfisico, 1);

            Double.TryParse(stockfisico, out double stock_fisico);
            produtoFinal.Stock_Fisico = stock_fisico;

            context.EditarArtigo(produtoFinal);
            return(Json("ok"));
        }
コード例 #5
0
        public ActionResult Apagar(string Id, int armazemid)
        {
            try
            {
                FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;
                context.ApagarArtigo(context.ObterProduto(Id, armazemid));
                context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Foi apagado o produto " + Id, 1);

                return(RedirectToAction(nameof(Index)));
            }
            catch
            {
                return(View());
            }
        }
コード例 #6
0
        public ActionResult Print(string id)
        {
            if (id == null)
            {
                return(RedirectToAction("Index"));
            }

            FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;
            var filePath = Path.GetTempFileName();

            context.DesenharEtiquetaMarcacao(context.ObterMarcacao(int.Parse(id))).Save(filePath, System.Drawing.Imaging.ImageFormat.Bmp);

            context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Impressa etiqueta normal da marcação: " + id, 2);
            //return File(outputStream, "image/bmp");
            return(File(BitMapToMemoryStream(filePath), "application/pdf"));
        }
コード例 #7
0
        public ActionResult Editar(string id, Produto produto)
        {
            try
            {
                FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;
                produto.Ref_Produto = id;
                context.EditarArtigo(produto);
                context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Foi alterado o produto " + produto.Ref_Produto, 1);

                return(Redirect("~/Produtos/Editar/" + id + "?armazemid=" + produto.Armazem_ID));
            }
            catch
            {
                return(View());
            }
        }
コード例 #8
0
        public ActionResult Criar(Produto produto)
        {
            try
            {
                FT_ManagementContext context  = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;
                List <Produto>       produtos = new List <Produto>
                {
                    produto
                };

                context.CriarArtigos(produtos);
                context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Foi criado um novo artigo: " + produto.Ref_Produto, 1);
                return(RedirectToAction(nameof(Index)));
            }
            catch
            {
                return(View());
            }
        }
コード例 #9
0
        public virtual ActionResult Exportar(string Ano)
        {
            FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;

            var file   = context.GerarMapaFerias(Ano);
            var output = new MemoryStream();

            output.Write(file, 0, file.Length);
            output.Position = 0;

            var cd = new System.Net.Mime.ContentDisposition
            {
                FileName     = "MapaFerias_" + Ano + ".xlsx",
                Inline       = false,
                Size         = file.Length,
                CreationDate = DateTime.Now,
            };

            Response.Headers.Add("Content-Disposition", cd.ToString());
            context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Foi gerado um mapa de ferias", 5);

            return(File(output, System.Net.Mime.MediaTypeNames.Application.Xml));
        }
コード例 #10
0
        public ActionResult Print(string id)
        {
            if (id == null)
            {
                return(RedirectToAction("Index"));
            }

            FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;
            FolhaObra            fo      = context.ObterFolhaObra(int.Parse(id));

            if (!this.User.IsInRole("Admin") && !this.User.IsInRole("Escritorio") && fo.IntervencaosServico.Where(i => i.IdTecnico == context.ObterUtilizador(int.Parse(this.User.Claims.First().Value.ToString())).IdPHC).Count() == 0)
            {
                return(Redirect("~/Home/AcessoNegado"));
            }

            var filePath = Path.GetTempFileName();

            context.DesenharEtiquetaFolhaObra(fo).Save(filePath, System.Drawing.Imaging.ImageFormat.Bmp);

            context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Impressa etiqueta normal da marcação: " + id, 2);
            //return File(outputStream, "image/bmp");
            return(File(BitMapToMemoryStream(filePath), "application/pdf"));
        }
コード例 #11
0
        public ActionResult EmailFolhaObra(int id, string emailDestino)
        {
            FT_ManagementContext context = HttpContext.RequestServices.GetService(typeof(FT_ManagementContext)) as FT_ManagementContext;
            FolhaObra            fo      = context.ObterFolhaObra(id);

            if (!this.User.IsInRole("Admin") && !this.User.IsInRole("Escritorio") && fo.IntervencaosServico.Where(i => i.IdTecnico == context.ObterUtilizador(int.Parse(this.User.Claims.First().Value.ToString())).IdPHC).Count() == 0)
            {
                return(Redirect("~/Home/AcessoNegado"));
            }

            try
            {
                Console.WriteLine("Sending email");
                SmtpClient mySmtpClient = new SmtpClient(ConfigurationManager.AppSetting["Email:ClienteSMTP"])
                {
                    // set smtp-client with basicAuthentication
                    UseDefaultCredentials = false
                };
                System.Net.NetworkCredential basicAuthenticationInfo = new
                                                                       System.Net.NetworkCredential(ConfigurationManager.AppSetting["Email:EmailOrigem"], ConfigurationManager.AppSetting["Email:SenhaEmailOrigem"]);
                mySmtpClient.Credentials = basicAuthenticationInfo;

                // add from,to mailaddresses
                MailAddress from   = new MailAddress(ConfigurationManager.AppSetting["Email:EmailOrigem"], ConfigurationManager.AppSetting["Email:NomeOrigem"]);
                MailAddress to     = new MailAddress(emailDestino);
                MailMessage myMail = new System.Net.Mail.MailMessage(from, to);
                myMail.CC.Add(new MailAddress(ConfigurationManager.AppSetting["Email:EmailCC"]));

                // set subject and encoding
                myMail.Subject         = "Folha de Obra - " + DateTime.Now.ToString("dd/MM/yyyy HH:mm");
                myMail.SubjectEncoding = System.Text.Encoding.UTF8;

                // set body-message and encoding
                if (int.Parse(DateTime.Now.ToString("dd")) < 13)
                {
                    myMail.Body = "Bom Dia, ";
                }
                else
                {
                    myMail.Body = "Boa Tarde, ";
                }

                // set body-message and encoding
                myMail.Body        += "<br><br>Segue em anexo a folha de obra de acordo com o serviço realizado.<br><br><i>Atenção este é um email automático, por favor não responda a este email!</i><br><br><p style='margin:0cm;margin-bottom:.0001pt;font-size:15px;font-family:'Calibri',sans-serif;'><strong><span style='font-size:11px;font-family:'Rubik-Regular',serif;color:#0069A5;'><a href='http://www.food-tech.pt/'><span style='color:#0563C1;'>www.food-tech.pt</span></a></span></strong></p><p style='margin:0cm;margin-bottom:.0001pt;font-size:15px;font-family:'Calibri',sans-serif;'>&nbsp;</p><p style='margin:0cm;margin-bottom:.0001pt;font-size:15px;font-family:'Calibri',sans-serif;'><img width='250' src='' alt='image'></p><p style='margin:0cm;margin-bottom:.0001pt;font-size:15px;font-family:'Calibri',sans-serif;'><strong><span style='font-size:11px;font-family:'Rubik-Regular',serif;color:#0069A5;'>Subic, Lda</span></strong><strong><span style='font-size:11px;font-family:'Cambria',serif;color:#0069A5;'>&nbsp;</span></strong></p><p style='margin:0cm;margin-bottom:.0001pt;font-size:15px;font-family:'Calibri',sans-serif;'><em><span style='font-size:11px;font-family:'Rubik-Regular',serif;color:#0069A5;'></span></em></p><p style='margin:0cm;margin-bottom:.0001pt;font-size:15px;font-family:'Calibri',sans-serif;'><span style='font-size:11px;font-family:'Rubik-Regular',serif;color:black;'><a href='x-apple-data-detectors%3A//2/1' style='color:var(--linkColor);'>Rua Eng. Sabino Marques, 144</a>, Zona Industrial da Maia Sector II,</span><span style='font-size:11px;font-family:'Cambria',serif;color:black;'>&nbsp;</span></p><p style='margin:0cm;margin-bottom:.0001pt;font-size:15px;font-family:'Calibri',sans-serif;'><span style='font-size:11px;font-family:'Rubik-Regular',serif;color:black;'><a href='tel:4470-605' style='color:var(--linkColor);'>4470-605</a> Maia, Portugal &bull; Tel. <a href='tel:(+351)%20229%20479%20670' style='color:var(--linkColor);'>(+351) 229 479</a></span><span style='font-size:11px;font-family:'Cambria',serif;color:black;'>&nbsp;</span><span style='font-size:11px;font-family:'Rubik-Regular',serif;color:black;'><a href='tel:(+351)%20229%20479%20670' style='color:var(--linkColor);'>670</a></span></p><br><br>Powered by: JKSProds - Software";
                myMail.BodyEncoding = System.Text.Encoding.UTF8;
                // text or html
                myMail.IsBodyHtml = true;

                var        pdf = new MemoryStream(context.PreencherFormularioFolhaObra(fo).ToArray());
                Attachment att = new Attachment(pdf, "FolhaObra_" + id, System.Net.Mime.MediaTypeNames.Application.Pdf);
                myMail.Attachments.Add(att);

                mySmtpClient.SendMailAsync(myMail);
                context.AdicionarLog(context.ObterUtilizador(int.Parse(this.User.Claims.First().Value)).NomeUtilizador, "Foi enviado uma folha de obra: " + id + " para o email: " + emailDestino, 3);
            }

            catch (Exception)
            {
                return(Content("Erro"));
            }

            return(Content("Sucesso"));
        }