diff --git a/server/AyaNova/Controllers/CustomerNotifySubscriptionController.cs b/server/AyaNova/Controllers/CustomerNotifySubscriptionController.cs new file mode 100644 index 00000000..98ae7ac6 --- /dev/null +++ b/server/AyaNova/Controllers/CustomerNotifySubscriptionController.cs @@ -0,0 +1,176 @@ +using System.Threading.Tasks; +using Microsoft.AspNetCore.Mvc; +using Microsoft.AspNetCore.Routing; +using Microsoft.AspNetCore.Authorization; +using Microsoft.Extensions.Logging; +using AyaNova.Models; +using AyaNova.Api.ControllerHelpers; +using AyaNova.Biz; +using System.Linq; +using Microsoft.EntityFrameworkCore; +using System.Collections.Generic; +using System; + +namespace AyaNova.Api.Controllers +{ + [ApiController] + [ApiVersion("8.0")] + [Route("api/v{version:apiVersion}/customer-notify-subscription")] + [Produces("application/json")] + [Authorize] + public class CustomerNotifySubscriptionController : ControllerBase + { + private readonly AyContext ct; + private readonly ILogger log; + private readonly ApiServerState serverState; + + /// + /// ctor + /// + /// + /// + /// + public CustomerNotifySubscriptionController(AyContext dbcontext, ILogger logger, ApiServerState apiServerState) + { + ct = dbcontext; + log = logger; + serverState = apiServerState; + } + + /// + /// Create CustomerNotifySubscription + /// + /// + /// From route path + /// + [HttpPost] + public async Task PostCustomerNotifySubscription([FromBody] CustomerNotifySubscription newObject, ApiVersion apiVersion) + { + if (!serverState.IsOpen) + return StatusCode(503, new ApiErrorResponse(serverState.ApiErrorCode, null, serverState.Reason)); + CustomerNotifySubscriptionBiz biz = CustomerNotifySubscriptionBiz.GetBiz(ct, HttpContext); + if (!Authorized.HasCreateRole(HttpContext.Items, biz.BizType)) + return StatusCode(403, new ApiNotAuthorizedResponse()); + if (!ModelState.IsValid) + return BadRequest(new ApiErrorResponse(ModelState)); + CustomerNotifySubscription o = await biz.CreateAsync(newObject); + if (o == null) + return BadRequest(new ApiErrorResponse(biz.Errors)); + else + return CreatedAtAction(nameof(CustomerNotifySubscriptionController.GetCustomerNotifySubscription), new { id = o.Id, version = apiVersion.ToString() }, new ApiCreatedResponse(o)); + } + + + /// + /// Get CustomerNotifySubscription + /// + /// + /// CustomerNotifySubscription + [HttpGet("{id}")] + public async Task GetCustomerNotifySubscription([FromRoute] long id) + { + if (!serverState.IsOpen) + return StatusCode(503, new ApiErrorResponse(serverState.ApiErrorCode, null, serverState.Reason)); + CustomerNotifySubscriptionBiz biz = CustomerNotifySubscriptionBiz.GetBiz(ct, HttpContext); + if (!Authorized.HasReadFullRole(HttpContext.Items, biz.BizType)) + return StatusCode(403, new ApiNotAuthorizedResponse()); + if (!ModelState.IsValid) + return BadRequest(new ApiErrorResponse(ModelState)); + var o = await biz.GetAsync(id); + if (o == null) return NotFound(new ApiErrorResponse(ApiErrorCode.NOT_FOUND)); + return Ok(ApiOkResponse.Response(o)); + } + + /// + /// Update CustomerNotifySubscription + /// + /// + /// + [HttpPut] + public async Task PutCustomerNotifySubscription([FromBody] CustomerNotifySubscription updatedObject) + { + if (!serverState.IsOpen) + return StatusCode(503, new ApiErrorResponse(serverState.ApiErrorCode, null, serverState.Reason)); + if (!ModelState.IsValid) + return BadRequest(new ApiErrorResponse(ModelState)); + CustomerNotifySubscriptionBiz biz = CustomerNotifySubscriptionBiz.GetBiz(ct, HttpContext); + if (!Authorized.HasModifyRole(HttpContext.Items, biz.BizType)) + return StatusCode(403, new ApiNotAuthorizedResponse()); + var o = await biz.PutAsync(updatedObject); + if (o == null) + { + if (biz.Errors.Exists(z => z.Code == ApiErrorCode.CONCURRENCY_CONFLICT)) + return StatusCode(409, new ApiErrorResponse(biz.Errors)); + else + return BadRequest(new ApiErrorResponse(biz.Errors)); + } + return Ok(ApiOkResponse.Response(new { Concurrency = o.Concurrency })); + } + + /// + /// Delete CustomerNotifySubscription + /// + /// + /// NoContent + [HttpDelete("{id}")] + public async Task DeleteCustomerNotifySubscription([FromRoute] long id) + { + if (!serverState.IsOpen) + return StatusCode(503, new ApiErrorResponse(serverState.ApiErrorCode, null, serverState.Reason)); + if (!ModelState.IsValid) + return BadRequest(new ApiErrorResponse(ModelState)); + CustomerNotifySubscriptionBiz biz = CustomerNotifySubscriptionBiz.GetBiz(ct, HttpContext); + if (!Authorized.HasDeleteRole(HttpContext.Items, biz.BizType)) + return StatusCode(403, new ApiNotAuthorizedResponse()); + if (!await biz.DeleteAsync(id)) + return BadRequest(new ApiErrorResponse(biz.Errors)); + return NoContent(); + } + + + /// + /// Get Subscription list + /// + /// User's notification subscription list + [HttpGet("list")] + public async Task GetQueue() + { + if (!serverState.IsOpen) + return StatusCode(503, new ApiErrorResponse(serverState.ApiErrorCode, null, serverState.Reason)); + + + var subs = await ct.CustomerNotifySubscription.AsNoTracking().ToListAsync(); + + List ret = new List(); + foreach (var s in subs) + { + ret.Add(new CustomerNotifySubscriptionRecord(s.Id, s.EventType, s.AyaType, s.CustomerTags, s.Tags, await GetStatusName(s, ct), s.AgeValue, s.DecValue)); + } + + return Ok(ApiOkResponse.Response(ret)); + } + private record CustomerNotifySubscriptionRecord( + long id, NotifyEventType eventType, AyaType AyaType, + List customerTags, List tags, string status, TimeSpan ageValue, decimal decValue + ); + + //Provide extra info about subscription + private static async Task GetStatusName(CustomerNotifySubscription s, AyContext ct) + { + switch (s.EventType) + { + case NotifyEventType.WorkorderStatusAge: + case NotifyEventType.WorkorderStatusChange: + //add status text to info + return await ct.WorkOrderStatus.AsNoTracking().Where(x => x.Id == s.IdValue).Select(x => x.Name).FirstOrDefaultAsync(); + case NotifyEventType.QuoteStatusAge: + case NotifyEventType.QuoteStatusChange: + return await ct.QuoteStatus.AsNoTracking().Where(x => x.Id == s.IdValue).Select(x => x.Name).FirstOrDefaultAsync(); + } + return string.Empty; + } + //------------ + + + }//eoc +}//eons \ No newline at end of file