using System.Security.Claims; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; using Yavsc.Helpers; using Yavsc.Models; using Yavsc.Models.Messaging; namespace Yavsc.Controllers { [Produces("application/json")] [Route("api/dimiss")] public class DimissClicksApiController : Controller { private readonly ApplicationDbContext _context; public DimissClicksApiController(ApplicationDbContext context) { _context = context; } // GET: api/DimissClicksApi [HttpGet] public IEnumerable GetDimissClicked() { var uid = User.FindFirstValue(ClaimTypes.NameIdentifier); return _context.DimissClicked.Where(d=>d.UserId == uid); } [HttpGet("click/{noteid}"),AllowAnonymous] public async Task Click(long noteid ) { if (User.IsSignedIn()) return await PostDimissClicked(new DimissClicked { NotificationId= noteid, UserId = User.GetUserId()}); await HttpContext.Session.LoadAsync(); var clicked = HttpContext.Session.GetString("clicked"); if (clicked == null) { HttpContext.Session.SetString("clicked",noteid.ToString()); } else HttpContext.Session.SetString("clicked",$"{clicked}:{noteid}"); await HttpContext.Session.CommitAsync(); return Ok(); } // GET: api/DimissClicksApi/5 [HttpGet("{id}", Name = "GetDimissClicked")] public async Task GetDimissClicked([FromRoute] string id) { var uid = User.FindFirstValue(ClaimTypes.NameIdentifier); if (uid != id) return new ChallengeResult(); if (!ModelState.IsValid) { return BadRequest(ModelState); } DimissClicked dimissClicked = await _context.DimissClicked.SingleAsync(m => m.UserId == id); if (dimissClicked == null) { return NotFound(); } return Ok(dimissClicked); } // PUT: api/DimissClicksApi/5 [HttpPut("{id}")] public async Task PutDimissClicked([FromRoute] string id, [FromBody] DimissClicked dimissClicked) { var uid = User.FindFirstValue(ClaimTypes.NameIdentifier); if (uid != id || uid != dimissClicked.UserId) return new ChallengeResult(); if (!ModelState.IsValid) { return BadRequest(ModelState); } if (id != dimissClicked.UserId) { return BadRequest(); } _context.Entry(dimissClicked).State = EntityState.Modified; try { await _context.SaveChangesAsync(User.GetUserId()); } catch (DbUpdateConcurrencyException) { if (!DimissClickedExists(id)) { return NotFound(); } else { throw; } } return new StatusCodeResult(StatusCodes.Status204NoContent); } // POST: api/DimissClicksApi [HttpPost] public async Task PostDimissClicked([FromBody] DimissClicked dimissClicked) { var uid = User.FindFirstValue(ClaimTypes.NameIdentifier); if (uid != dimissClicked.UserId) return new ChallengeResult(); if (!ModelState.IsValid) { return BadRequest(ModelState); } _context.DimissClicked.Add(dimissClicked); try { await _context.SaveChangesAsync(User.GetUserId()); } catch (DbUpdateException) { if (DimissClickedExists(dimissClicked.UserId)) { return new StatusCodeResult(StatusCodes.Status409Conflict); } else { throw; } } return CreatedAtRoute("GetDimissClicked", new { id = dimissClicked.UserId }, dimissClicked); } // DELETE: api/DimissClicksApi/5 [HttpDelete("{id}")] public async Task DeleteDimissClicked([FromRoute] string id) { var uid = User.FindFirstValue(ClaimTypes.NameIdentifier); if (!User.IsInRole("Administrator")) if (uid != id) return new ChallengeResult(); if (!ModelState.IsValid) { return BadRequest(ModelState); } DimissClicked dimissClicked = await _context.DimissClicked.SingleAsync(m => m.UserId == id); if (dimissClicked == null) { return NotFound(); } _context.DimissClicked.Remove(dimissClicked); await _context.SaveChangesAsync(User.GetUserId()); return Ok(dimissClicked); } protected override void Dispose(bool disposing) { if (disposing) { _context.Dispose(); } base.Dispose(disposing); } private bool DimissClickedExists(string id) { return _context.DimissClicked.Count(e => e.UserId == id) > 0; } } }