yavsc/web/Controllers/FileSystemController.cs

127 lines
3.0 KiB
C#

10 years ago
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.IO;
using System.Web.Security;
using System.Text.RegularExpressions;
namespace Yavsc.Controllers
{
public class FileSystemController : Controller
{
private static string usersDir ="~/users";
10 years ago
public static string UsersDir {
get {
return usersDir;
}
}
[Authorize]
public ActionResult Index()
{
string user = Membership.GetUser ().UserName;
ViewData ["UserName"] = user;
10 years ago
DirectoryInfo di = new DirectoryInfo (
Path.Combine(
Server.MapPath(UsersDir),
10 years ago
user));
if (!di.Exists)
di.Create ();
return View (new FileInfoCollection( di.GetFiles()));
}
public ActionResult Details(string id)
{
foreach (char x in Path.GetInvalidPathChars()) {
if (id.Contains (x)) {
ViewData ["Message"] =
string.Format (
"Something went wrong following the following path : {0} (\"{1}\")",
id,x);
return RedirectToAction ("Index");
}
}
string fpath = Path.Combine (BaseDir, id);
ViewData["Content"] = Url.Content (fpath);
FileInfo fi = new FileInfo (fpath);
return View (fi);
}
public ActionResult Create()
{
return View ();
}
[HttpPost]
[Authorize]
public ActionResult Create(FormCollection collection)
{
try {
string fnre = "[A-Za-z0-9~\\-.]+";
HttpFileCollectionBase hfc = Request.Files;
for (int i=0; i<hfc.Count; i++)
{
if (!Regex.Match(hfc[i].FileName,fnre).Success)
{
ViewData ["Message"] += string.Format("<p>File name '{0}' refused</p>",hfc[i].FileName);
ModelState.AddModelError(
"AFile",
string.Format(
"The file name {0} dosn't match an acceptable file name {1}",
hfc[i].FileName,fnre))
;
return View();
}
}
for (int i=0; i<hfc.Count; i++)
{
// TODO Limit with hfc[h].ContentLength
hfc[i].SaveAs(Path.Combine(BaseDir,hfc[i].FileName));
ViewData ["Message"] += string.Format("<p>File name '{0}' saved</p>",hfc[i].FileName);
}
return RedirectToAction ("Index","FileSystem");
} catch (Exception e) {
ViewData ["Message"] = "Exception:"+e.Message;
return View ();
}
}
public static string BaseDir { get { return Path.Combine (UsersDir, Membership.GetUser ().UserName); } }
public ActionResult Edit(int id)
{
return View ();
}
[HttpPost]
public ActionResult Edit(int id, FormCollection collection)
{
try {
return RedirectToAction ("Index");
} catch {
return View ();
}
}
public ActionResult Delete(int id)
{
return View ();
}
[HttpPost]
public ActionResult Delete(int id, FormCollection collection)
{
try {
return RedirectToAction ("Index");
} catch {
return View ();
}
}
}
}