cleanning
parent
bbab9a21f0
commit
3d6efe321f
@ -1,75 +0,0 @@
|
|||||||
using System.Collections.Generic;
|
|
||||||
using System.IO;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Security.Claims;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Microsoft.AspNet.Authorization;
|
|
||||||
using Microsoft.AspNet.Hosting;
|
|
||||||
using Microsoft.AspNet.Mvc;
|
|
||||||
using Microsoft.Extensions.Logging;
|
|
||||||
using Microsoft.Extensions.OptionsModel;
|
|
||||||
using Microsoft.Net.Http.Headers;
|
|
||||||
using Yavsc.Models;
|
|
||||||
|
|
||||||
namespace Yavsc.Controllers
|
|
||||||
{
|
|
||||||
[Authorize, ServiceFilter(typeof(LanguageActionFilter))]
|
|
||||||
public class UserFilesController : Controller
|
|
||||||
{
|
|
||||||
private SiteSettings _siteSettings;
|
|
||||||
IHostingEnvironment _environment;
|
|
||||||
private IAuthorizationService _authorizationService;
|
|
||||||
ApplicationDbContext _context;
|
|
||||||
ILogger _logger;
|
|
||||||
public UserFilesController(
|
|
||||||
ApplicationDbContext context,
|
|
||||||
IHostingEnvironment environment, IOptions<SiteSettings> siteSettings,
|
|
||||||
IAuthorizationService authorizationService, ILoggerFactory loggerFactory)
|
|
||||||
{
|
|
||||||
_context = context;
|
|
||||||
_siteSettings = siteSettings.Value;
|
|
||||||
_environment = environment;
|
|
||||||
_authorizationService = authorizationService;
|
|
||||||
_logger = loggerFactory.CreateLogger<UserFilesController>();
|
|
||||||
}
|
|
||||||
|
|
||||||
[HttpPost, Produces("application/json")]
|
|
||||||
public async Task<IActionResult> Create(BlogFilesPost model)
|
|
||||||
{
|
|
||||||
var blogEntry = _context.Blogspot.FirstOrDefault(
|
|
||||||
be => be.Id == model.PostId);
|
|
||||||
if (blogEntry == null)
|
|
||||||
return new HttpNotFoundResult();
|
|
||||||
if (!ModelState.IsValid)
|
|
||||||
return new BadRequestObjectResult(ModelState);
|
|
||||||
var results = new List<string>();
|
|
||||||
var uploads = Path.Combine(
|
|
||||||
Path.Combine(_environment.WebRootPath, _siteSettings.UserFiles.DirName),
|
|
||||||
User.GetUserId()
|
|
||||||
);
|
|
||||||
// uploads = Path.Combine(uploads, model.PostId.ToString());
|
|
||||||
var spot = new FileSpotInfo(uploads, blogEntry);
|
|
||||||
if (!await _authorizationService.AuthorizeAsync(User, spot, new EditRequirement()))
|
|
||||||
{
|
|
||||||
return new HttpStatusCodeResult(403);
|
|
||||||
}
|
|
||||||
if (!spot.PathInfo.Exists) spot.PathInfo.Create();
|
|
||||||
foreach (var file in model.File)
|
|
||||||
{
|
|
||||||
var fileName = ContentDispositionHeaderValue.Parse(file.ContentDisposition).FileName.Trim('"');
|
|
||||||
var permUrl = $"~/{_siteSettings.UserFiles.DirName}/{model.PostId}/{fileName}";
|
|
||||||
results.Add(permUrl);
|
|
||||||
_logger.LogWarning($"Create: {model.PostId} {file.ContentDisposition}");
|
|
||||||
/* if (file.Length > 0)
|
|
||||||
{
|
|
||||||
var fileName = ContentDispositionHeaderValue.Parse(file.ContentDisposition).FileName.Trim('"');
|
|
||||||
var fullName = Path.Combine(spot.PathInfo.FullName, fileName);
|
|
||||||
results.Add(permUrl);
|
|
||||||
await file.SaveAsAsync(fullName);
|
|
||||||
} */
|
|
||||||
}
|
|
||||||
return Ok(results);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in New Issue