75 lines
3.0 KiB
C#
75 lines
3.0 KiB
C#
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);
|
|
}
|
|
}
|
|
|
|
} |