public async Task <ActionResult <License> > PostLicense([FromForm] LicenseRequest request, IFormFile image) { var list = new List <string>(); foreach (string condition in request.condition) { list.Add(condition); } request.conditions = JsonConvert.SerializeObject(list); var license = new License { name = request.name, cost = request.cost, conditions = request.conditions }; _context.licenses.Add(license); await _context.SaveChangesAsync(); var image_name = ImagesHelper.save(image); _context.images.Add(new Image { name = image_name, imageable_id = license.id, imageable_type = "License" }); await _context.SaveChangesAsync(); return(CreatedAtAction("GetLicense", new { id = license.id }, license)); }
public async Task <IActionResult> PutLicense(int id, [FromForm] LicenseRequest request, IFormFile image) { var list = new List <string>(); foreach (string condition in request.condition) { list.Add(condition); } request.conditions = JsonConvert.SerializeObject(list); var license = new License { id = request.id, name = request.name, cost = request.cost, conditions = request.conditions, updated_at = DateTime.Now, }; _context.Entry(license).State = EntityState.Modified; if (image != null) { string image_name; var pImage = _context.images.Where(i => (i.imageable_id == request.id && i.imageable_type == "License")).FirstOrDefault(); ImagesHelper.delete(pImage.name); image_name = ImagesHelper.save(image); var local = _context.Set <Image>().Local.FirstOrDefault(i => i.id == pImage.id); if (local != null) { _context.Entry(local).State = EntityState.Detached; } _context.Entry(new Image { id = pImage.id, name = image_name, imageable_id = request.id, imageable_type = "License" }).State = EntityState.Modified; } try { await _context.SaveChangesAsync(); } catch (DbUpdateConcurrencyException) { if (!LicenseExists(id)) { return(NotFound()); } else { throw; } } return(NoContent()); }