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 a list of which customers will potentially receive a notification based on tags /// /// /// From route path /// [HttpPost("who")] public async Task GetWho([FromBody] List customerTags, ApiVersion apiVersion) { if (!serverState.IsOpen) return StatusCode(503, new ApiErrorResponse(serverState.ApiErrorCode, null, serverState.Reason)); if (!Authorized.HasCreateRole(HttpContext.Items, AyaType.CustomerNotifySubscription)) return StatusCode(403, new ApiNotAuthorizedResponse()); if (!ModelState.IsValid) return BadRequest(new ApiErrorResponse(ModelState)); string custTagsWhere = DataList.DataListSqlFilterCriteriaBuilder.TagFilterToSqlCriteriaHelper("acustomer.tags", customerTags, false); List ret = new List(); using (var cmd = ct.Database.GetDbConnection().CreateCommand()) { await ct.Database.OpenConnectionAsync(); cmd.CommandText = $"select id, name, COALESCE(emailaddress,'') from acustomer where active=true {custTagsWhere} order by name"; using (var dr = await cmd.ExecuteReaderAsync()) { while (dr.Read()) { ret.Add(new CustomerNotifySubscriptionWhoRecord(dr.GetInt64(0), dr.GetString(1), dr.GetString(2) )); } } } // WHERE ARRAY['red','green'::varchar(255)] <@ tags //array1.All(i => array2.Contains(i)) array1 <@ array2 //https://www.npgsql.org/efcore/mapping/array.html // var ret = await ct.Customer.Where(z => z.Active == true && (customerTags.All(i => z.Tags.Contains(i)))).Select(c => new CustomerNotifySubscriptionWhoRecord(c.Id, c.Name, c.EmailAddress)).ToListAsync(); return Ok(ApiOkResponse.Response(ret)); } private record CustomerNotifySubscriptionWhoRecord(long Id, string Name, string EmailAddress); /// /// Get Subscription list /// /// User's notification subscription list [HttpGet("list")] public async Task GetList() { if (!serverState.IsOpen) return StatusCode(503, new ApiErrorResponse(serverState.ApiErrorCode, null, serverState.Reason)); if (!Authorized.HasModifyRole(HttpContext.Items, AyaType.CustomerNotifySubscription)) return StatusCode(403, new ApiNotAuthorizedResponse()); var subs = await ct.CustomerNotifySubscription.AsNoTracking().OrderBy(z=>z.Id).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