yavsc/Yavsc/Helpers/FileSystemHelpers.cs

95 lines
3.2 KiB
C#

8 years ago
using System.IO;
8 years ago
using System.Linq;
8 years ago
using System.Net.Mime;
8 years ago
using System.Security.Claims;
8 years ago
using Microsoft.AspNet.Http;
using Yavsc.ApiControllers;
using Yavsc.Models;
using Yavsc.Models.FileSystem;
8 years ago
using Yavsc.ViewModels.UserFiles;
namespace Yavsc.Helpers
{
8 years ago
public static class FileSystemHelpers
{
public static UserDirectoryInfo GetUserFiles(this ClaimsPrincipal user, string subdir)
{
UserDirectoryInfo di = new UserDirectoryInfo(user.Identity.Name, subdir);
8 years ago
return di;
}
8 years ago
static char[] ValidChars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_~.".ToCharArray();
8 years ago
public static bool IsValidDirectoryName(this string name)
8 years ago
{
return !name.Any(c => !ValidChars.Contains(c));
8 years ago
}
public static bool IsValidPath(this string path)
8 years ago
{
if (path == null) return true;
8 years ago
foreach (var name in path.Split(Path.DirectorySeparatorChar))
8 years ago
{
if (name != null)
8 years ago
if (!IsValidDirectoryName(name)
8 years ago
|| name.Equals(".."))
return false;
}
8 years ago
return true;
}
8 years ago
public static string InitPostToFileSystem(
this ClaimsPrincipal user,
string subpath)
{
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();
if (subpath != null)
if (subpath.IsValidPath())
{
root = Path.Combine(root, subpath);
diRoot = new DirectoryInfo(root);
if (!diRoot.Exists) diRoot.Create();
}
return root;
}
public static FileRecievedInfo ReceiveUserFile(this ApplicationUser user, string root, long quota, ref long usage, IFormFile f)
{
var item = new FileRecievedInfo();
// form-data; name="file"; filename="capt0008.jpg"
ContentDisposition contentDisposition = new ContentDisposition(f.ContentDisposition);
item.FileName = contentDisposition.FileName;
var fi = new FileInfo(Path.Combine(root, item.FileName));
if (fi.Exists) item.Overriden = true;
using (var dest = fi.OpenWrite())
{
using (var org = f.OpenReadStream())
{
byte[] buffer = new byte[1024];
long len = org.Length;
user.DiskUsage += len;
if (len > (quota - usage)) throw new FSQuotaException();
while (len > 0)
{
int blen = len > 1024 ? 1024 : (int)len;
org.Read(buffer, 0, blen);
dest.Write(buffer, 0, blen);
len -= blen;
}
dest.Close();
org.Close();
}
}
return item;
}
}
}