view Agendas/trunk/src/Agendas.Web/Controllers/PatrocinadorController.cs @ 292:1408ac17cb64

Patrocinadores: Faltaba aplicar seguridad a la Api de Patrocinadores.
author juanjose.montesdeocaarbos
date Thu, 09 Feb 2012 08:40:38 -0300
parents 1e889a2e45c5
children 8c742d5ccf67
line wrap: on
line source

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using AltNetHispano.Agendas.Domain;
using AltNetHispano.Agendas.Factories;
using AltNetHispano.Agendas.Web.Models;
using AltNetHispano.Agendas.Web.Services;


namespace AltNetHispano.Agendas.Web.Controllers
{
    public class PatrocinadorController : Controller
    {
		private HttpServerUtilityBase _server;

		public HttpServerUtilityBase HttpServer
		{
			get
			{
				if (_server == null)
				{
					var httpServer = HttpContext.Server;
					_server =  httpServer;
				}

				return _server;
			}
		}

		public PatrocinadorController()
		{
		}

		public PatrocinadorController(HttpServerUtilityBase server)
		{
			_server = server;
		}

    	public ActionResult GetLogo(string id)
		{
			var patrocinadores = AgendaFactory.GetPatrocinadorRepository();

			var patrocinador = patrocinadores.Get(new Guid(id));

			return File(patrocinador.Logo, "image/jpg");
		}

    	public ActionResult Index()
        {
        	var patrocinadores = AgendaFactory.GetPatrocinadorRepository();

        	var model = new PatrocinadorIndexModel
        	            	{
        	            		Items = from p in patrocinadores.GetAll()
										select new PatrocinadorDto
										       	{
										       		Id = p.Id,
													Nombre = p.Nombre
										       	}
        	            	};

            return View(model);
        }

		[CustomAuthorize(Roles = Roles.Administrador)]
        public ActionResult Nuevo()
        {
			var model = new PatrocinadorNewModel();
			return View("DefaultEditor", model);
        }

        [HttpPost]
		[CustomAuthorize(Roles = Roles.Administrador)]
		public ActionResult Nuevo(PatrocinadorNewModel model)
		{
			if (ModelState.IsValid)
			{
				var patrocinadores = AgendaFactory.GetPatrocinadorRepository();

				if (patrocinadores.GetByNombre(model.Nombre) == null)
				{
					var tempLogoFile = Path.Combine(HttpServer.MapPath("~/App_Data"),
													model.Nombre +
													model.Logo.FileName.Substring(model.Logo.FileName.LastIndexOf(".")));
					model.Logo.SaveAs(tempLogoFile);
					var patrocinador = new Patrocinador(model.Nombre);
					patrocinador.LoadLogo(tempLogoFile);

					patrocinadores.Save(patrocinador);

					return RedirectToAction("Index");
				}
				this.AddError("El patrocinador ya existe.");
			}

			return View("DefaultEditor", model);
        }

		[CustomAuthorize(Roles = Roles.Administrador)]
		public ActionResult Modificar(string id)
		{
			var patrocinadores = AgendaFactory.GetPatrocinadorRepository();

			var patrocinador = patrocinadores.GetById(id);
			if (patrocinador == null)
			{
				this.AddError("No se encontró el patrocinador que intenta modificar");
				return RedirectToAction("Index");
			}
			var model = new PatrocinadorEditModel
			            	{
								Id = new Guid(id).ToString(),
								Nombre = patrocinador.Nombre
			            	};
			return View("DefaultEditor", model);
		}

		[HttpPost]
		[CustomAuthorize(Roles = Roles.Administrador)]
		public ActionResult Modificar(PatrocinadorEditModel model)
		{
			if (ModelState.IsValid)
			{
				var patrocinadores = AgendaFactory.GetPatrocinadorRepository();
				var patrocinador = patrocinadores.GetById(model.Id);
				if (patrocinador != null)
				{
					var tempLogoFile = Path.Combine(HttpServer.MapPath("~/App_Data"),
													model.Nombre +
													model.Logo.FileName.Substring(model.Logo.FileName.LastIndexOf(".")));
					model.Logo.SaveAs(tempLogoFile);
					patrocinador.Nombre = model.Nombre;
					patrocinador.LoadLogo(tempLogoFile);

					patrocinadores.Save(patrocinador);

					return RedirectToAction("Index");
				}
				this.AddError("No se encuentra el patrocinador.");
			}
			return View("DefaultEditor", model);
		}

		[CustomAuthorize(Roles = Roles.Administrador)]
		public ActionResult Eliminar(string id)
        {
			if (!string.IsNullOrWhiteSpace(id))
			{
				var patrocinadores = AgendaFactory.GetPatrocinadorRepository();
				var patrocinador = patrocinadores.GetById(id);

				patrocinadores.Delete(patrocinador);
			}
			return RedirectToAction("Index");
		}

    }
}