yavsc/Yavsc/ApiControllers/FileSystemApiController.cs

78 lines
2.5 KiB
C#

using System.Collections.Generic;
using System.IO;
using Microsoft.AspNet.Authorization;
using Microsoft.AspNet.Mvc;
using Yavsc.Helpers;
using Yavsc.Models;
namespace Yavsc.ApiControllers
{
[Authorize,Route("api/fs")]
public class FileSystemApiController : Controller
{
private IAuthorizationService AuthorizationService;
public FileSystemApiController(ApplicationDbContext context,
IAuthorizationService authorizationService)
{
AuthorizationService = authorizationService;
}
[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);
}
public class FileRecievedInfo
{
public string DestDir { get; set; }
public string ContentDisposition { get; set; }
public bool Overriden { get; set; }
}
[HttpPost]
public IEnumerable<FileRecievedInfo> Post(string subdir="")
{
var root = Path.Combine(Startup.UserFilesDirName, User.Identity.Name);
// TOSO secure this path
// if (subdir!=null) root = Path.Combine(root, subdir);
var diRoot = new DirectoryInfo(root);
if (!diRoot.Exists) diRoot.Create();
foreach (var f in Request.Form.Files.GetFiles("Files"))
{
var item = new FileRecievedInfo();
item.ContentDisposition = f.ContentDisposition;
var fi = new FileInfo(Path.Combine(root, f.ContentDisposition));
if (fi.Exists) item.Overriden = true;
using (var dest = fi.OpenWrite())
{
using (var org = f.OpenReadStream())
{
byte[] buffer = new byte[1024];
int o = 0, c;
while ((c = org.Read(buffer, o, 1024)) > 0)
{
dest.Write(buffer, o, c);
o += 1024;
// TODO quota
}
dest.Close();
org.Close();
}
}
yield return item;
};
}
}
}