using System; using System.Collections.Generic; using System.Linq; using System.Security.Claims; using Microsoft.AspNet.Authorization; using Microsoft.AspNet.Mvc; using Yavsc.Helpers; using Yavsc.Models; namespace Yavsc.ApiControllers { using System.Threading.Tasks; using Yavsc.Exceptions; public class FSQuotaException : Exception { } [Authorize,Route("api/fs")] public class FileSystemApiController : Controller { ApplicationDbContext dbContext; private IAuthorizationService AuthorizationService; public FileSystemApiController(ApplicationDbContext context, IAuthorizationService authorizationService) { AuthorizationService = authorizationService; dbContext = context; } [HttpGet()] public IActionResult Get() { return GetDir(null); } [HttpGet("{subdir}")] public IActionResult GetDir(string subdir="") { if (subdir !=null) if (!FileSystemHelpers.IsValidPath(subdir)) return new BadRequestResult(); var files = User.GetUserFiles(subdir); return Ok(files); } [HttpPost] public IEnumerable Post(string subdir="") { string root = null; InvalidPathException pathex = null; try { root = User.InitPostToFileSystem(subdir); } catch (InvalidPathException ex) { pathex = ex; } if (pathex!=null) yield return new BadRequestObjectResult(pathex); var user = dbContext.Users.Single( u => u.Id == User.GetUserId() ); foreach (var f in Request.Form.Files) { var item = user.ReceiveUserFile(root, f); dbContext.SaveChanges(User.GetUserId()); yield return Ok(item); }; } [HttpDelete] public async Task Delete (string id) { var user = dbContext.Users.Single( u => u.Id == User.GetUserId() ); InvalidPathException pathex = null; string root = null; try { root = User.InitPostToFileSystem(id); } catch (InvalidPathException ex) { pathex = ex; } if (pathex!=null) return new BadRequestObjectResult(pathex); user.DeleteUserFile(id); await dbContext.SaveChangesAsync(User.GetUserId()); return Ok(new { deleted=id }); } } }