using System.Collections.Generic; using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Authorization; using Oqtane.Repository; using Oqtane.Models; using Oqtane.Shared; using System.Linq; namespace Oqtane.Controllers { [Route("{site}/api/[controller]")] public class PageController : Controller { private readonly IPageRepository Pages; public PageController(IPageRepository Pages) { this.Pages = Pages; } // GET: api/?siteid=x [HttpGet] public IEnumerable Get(string siteid) { if (siteid == "") { return Pages.GetPages(); } else { return Pages.GetPages(int.Parse(siteid)); } } // GET api//5 [HttpGet("{id}")] public Page Get(int id) { return Pages.GetPage(id); } // POST api/ [HttpPost] [Authorize(Roles = Constants.AdminRole)] public Page Post([FromBody] Page Page) { if (ModelState.IsValid) { Page = Pages.AddPage(Page); } return Page; } // PUT api//5 [HttpPut("{id}")] [Authorize(Roles = Constants.AdminRole)] public Page Put(int id, [FromBody] Page Page) { if (ModelState.IsValid) { Page = Pages.UpdatePage(Page); } return Page; } // PUT api//?siteid=x&parentid=y [HttpPut] [Authorize(Roles = Constants.AdminRole)] public void Put(int siteid, int? parentid) { int order = 1; List pages = Pages.GetPages(siteid).ToList(); foreach (Page page in pages.Where(item => item.ParentId == parentid).OrderBy(item => item.Order)) { if (page.Order != order) { page.Order = order; Pages.UpdatePage(page); } order += 2; } } // DELETE api//5 [HttpDelete("{id}")] [Authorize(Roles = Constants.AdminRole)] public void Delete(int id) { Pages.DeletePage(id); } } }