From 8a5427c69152113f20d1baf4e8cac9fe8c3293cf Mon Sep 17 00:00:00 2001 From: Anders Bjerner Date: Fri, 1 Oct 2021 09:38:54 +0200 Subject: [PATCH] All endpoints should use new JsonResult due to Umbraco breaking stuff --- .../Controllers/Api/RedirectsController.cs | 55 +++++++++++-------- 1 file changed, 31 insertions(+), 24 deletions(-) diff --git a/src/Skybrud.Umbraco.Redirects/Controllers/Api/RedirectsController.cs b/src/Skybrud.Umbraco.Redirects/Controllers/Api/RedirectsController.cs index 1520711..5378ca7 100644 --- a/src/Skybrud.Umbraco.Redirects/Controllers/Api/RedirectsController.cs +++ b/src/Skybrud.Umbraco.Redirects/Controllers/Api/RedirectsController.cs @@ -56,19 +56,19 @@ public RedirectsController(ILogger logger, IRedirectsServic /// list once - even if it has been assigned multiple domains. /// [HttpGet] - public object GetRootNodes() { + public ActionResult GetRootNodes() { RedirectRootNode[] rootNodes = _redirects.GetRootNodes(); - return new { + return new JsonResult(new { total = rootNodes.Length, items = rootNodes.Select(x => new RedirectRootNodeModel(x)) - }; + }); } [HttpPost] - public object AddRedirect([FromBody] JObject m) { + public ActionResult AddRedirect([FromBody] JObject m) { AddRedirectOptions model = m.ToObject(); @@ -81,9 +81,9 @@ public object AddRedirect([FromBody] JObject m) { // Add the redirect Redirect redirect = _redirects.AddRedirect(model); - - // Return the redirect - return redirect; + + // Map the result for the API + return new JsonResult(_backOffice.Map(redirect)); } catch (RedirectsException ex) { @@ -97,7 +97,7 @@ public object AddRedirect([FromBody] JObject m) { } [HttpPost] - public object EditRedirect(Guid redirectId, [FromBody] EditRedirectOptions model) { + public ActionResult EditRedirect(Guid redirectId, [FromBody] EditRedirectOptions model) { try { @@ -125,8 +125,8 @@ public object EditRedirect(Guid redirectId, [FromBody] EditRedirectOptions model // Save/update the redirect _redirects.SaveRedirect(redirect); - // Return the redirect - return redirect; + // Map the result for the API + return new JsonResult(_backOffice.Map(redirect)); } catch (RedirectsException ex) { @@ -153,7 +153,7 @@ public object EditRedirect(Guid redirectId, [FromBody] EditRedirectOptions model /// Indicates whether the query string should be forwarded. false by default. /// The updated redirect. [HttpGet] - public object EditRedirect(Guid rootNodeKey, Guid redirectId, string url, + public ActionResult EditRedirect(Guid rootNodeKey, Guid redirectId, string url, string linkMode, int linkId, Guid linkKey, string linkUrl, bool permanent = true, bool forward = false) { @@ -200,9 +200,9 @@ public object EditRedirect(Guid rootNodeKey, Guid redirectId, string url, // Save/update the redirect _redirects.SaveRedirect(redirect); - - // Return the redirect - return redirect; + + // Map the result for the API + return new JsonResult(_backOffice.Map(redirect)); } catch (RedirectsException ex) { @@ -220,7 +220,7 @@ public object EditRedirect(Guid rootNodeKey, Guid redirectId, string url, /// /// The ID of the redirect. [HttpGet] - public object DeleteRedirect(Guid redirectId) { + public ActionResult DeleteRedirect(Guid redirectId) { try { @@ -230,9 +230,9 @@ public object DeleteRedirect(Guid redirectId) { // Delete the redirect _redirects.DeleteRedirect(redirect); - - // Return the redirect - return redirect; + + // Map the result for the API + return new JsonResult(_backOffice.Map(redirect)); } catch (RedirectsException ex) { @@ -255,7 +255,7 @@ public object DeleteRedirect(Guid redirectId) { /// The root node key that the returned redirects should match. null means all redirects. means all global redirects. /// A list of redirects. [HttpGet] - public object GetRedirects(int page = 1, int limit = 20, string type = null, string text = null, Guid? rootNodeKey = null) { + public ActionResult GetRedirects(int page = 1, int limit = 20, string type = null, string text = null, Guid? rootNodeKey = null) { try { @@ -286,7 +286,7 @@ public object GetRedirects(int page = 1, int limit = 20, string type = null, str } [HttpGet] - public object GetRedirectsForNode(string type, Guid key) { + public ActionResult GetRedirectsForNode(string type, Guid key) { try { @@ -342,10 +342,10 @@ public object GetRedirectsForNode(string type, Guid key) { Redirect[] redirects = _redirects.GetRedirectsByNodeKey(node.Type, key); // Generate the response - return new { + return new JsonResult(new { node, redirects = _backOffice.Map(redirects) - }; + }); } catch (RedirectsException ex) { @@ -356,8 +356,15 @@ public object GetRedirectsForNode(string type, Guid key) { } - private ObjectResult Error(RedirectsException ex) { - return StatusCode((int) ex.StatusCode, new RedirectsError(ex)); + private ActionResult Error(RedirectsException ex) { + + // Initialize a new error model based on the exception + RedirectsError body = new RedirectsError(ex); + + return new JsonResult(body) { + StatusCode = (int) ex.StatusCode + }; + } }