mirror of
https://github.com/standardebooks/web.git
synced 2025-07-04 22:00:35 -04:00
174 lines
5.9 KiB
PHP
174 lines
5.9 KiB
PHP
<?
|
|
use function Safe\session_start;
|
|
|
|
try{
|
|
session_start();
|
|
$httpMethod = HttpInput::ValidateRequestMethod([Enums\HttpMethod::Post, Enums\HttpMethod::Patch, Enums\HttpMethod::Put]);
|
|
$exceptionRedirectUrl = '/artworks/new';
|
|
$artwork = new Artwork();
|
|
|
|
if(Session::$User === null){
|
|
throw new Exceptions\LoginRequiredException();
|
|
}
|
|
|
|
// POSTing a new artwork.
|
|
if($httpMethod == Enums\HttpMethod::Post){
|
|
if(!Session::$User->Benefits->CanUploadArtwork){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
$artwork->FillFromHttpPost();
|
|
|
|
$artwork->SubmitterUserId = Session::$User->UserId ?? null;
|
|
|
|
// Only approved reviewers can set the status to anything but unverified when uploading.
|
|
// The submitter cannot review their own submissions unless they have special permission.
|
|
if($artwork->Status !== Enums\ArtworkStatusType::Unverified && !$artwork->CanStatusBeChangedBy(Session::$User)){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
|
|
// If the artwork is approved, set the reviewer.
|
|
if($artwork->Status !== Enums\ArtworkStatusType::Unverified){
|
|
$artwork->ReviewerUserId = Session::$User->UserId;
|
|
}
|
|
|
|
$artwork->Create(HttpInput::File('artwork-image'));
|
|
|
|
$_SESSION['artwork'] = $artwork;
|
|
$_SESSION['is-artwork-created'] = true;
|
|
|
|
http_response_code(Enums\HttpCode::SeeOther->value);
|
|
header('Location: /artworks/new');
|
|
}
|
|
|
|
// PUTing an artwork.
|
|
if($httpMethod == Enums\HttpMethod::Put){
|
|
$originalArtwork = Artwork::GetByUrl(HttpInput::Str(GET, 'artist-url-name'), HttpInput::Str(GET, 'artwork-url-name'));
|
|
|
|
if(!$originalArtwork->CanBeEditedBy(Session::$User)){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
|
|
$exceptionRedirectUrl = $originalArtwork->EditUrl;
|
|
|
|
try{
|
|
$artwork->FillFromHttpPost();
|
|
}
|
|
catch(Exceptions\AppException $ex){
|
|
// Restore the original artwork so the user can correct the error and try again.
|
|
$artwork = $originalArtwork;
|
|
throw $ex;
|
|
}
|
|
|
|
$artwork->ArtworkId = $originalArtwork->ArtworkId;
|
|
$artwork->Created = $originalArtwork->Created;
|
|
$artwork->SubmitterUserId = $originalArtwork->SubmitterUserId;
|
|
$artwork->Status = $originalArtwork->Status; // Overwrite any value got from POST because we need permission to change the status.
|
|
|
|
$newStatus = Enums\ArtworkStatusType::tryFrom(HttpInput::Str(POST, 'artwork-status') ?? '');
|
|
if($newStatus !== null){
|
|
if($originalArtwork->Status != $newStatus && !$originalArtwork->CanStatusBeChangedBy(Session::$User)){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
|
|
$artwork->ReviewerUserId = Session::$User->UserId;
|
|
$artwork->Status = $newStatus;
|
|
}
|
|
|
|
if(HttpInput::File('artwork-image') === null){
|
|
$artwork->MimeType = $originalArtwork->MimeType;
|
|
}
|
|
|
|
$artwork->Save(HttpInput::File('artwork-image'));
|
|
|
|
$_SESSION['artwork'] = $artwork;
|
|
$_SESSION['is-artwork-saved'] = true;
|
|
|
|
http_response_code(Enums\HttpCode::SeeOther->value);
|
|
header('Location: ' . $artwork->Url);
|
|
}
|
|
|
|
// PATCHing an artwork.
|
|
if($httpMethod == Enums\HttpMethod::Patch){
|
|
$artwork = Artwork::GetByUrl(HttpInput::Str(GET, 'artist-url-name'), HttpInput::Str(GET, 'artwork-url-name'));
|
|
|
|
$exceptionRedirectUrl = $artwork->Url;
|
|
|
|
// We can PATCH the status, the ebook www filesystem path, or both.
|
|
if(isset($_POST['artwork-status'])){
|
|
$newStatus = Enums\ArtworkStatusType::tryFrom(HttpInput::Str(POST, 'artwork-status') ?? '');
|
|
if($artwork->Status != $newStatus){
|
|
if(!$artwork->CanStatusBeChangedBy(Session::$User)){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
|
|
if($newStatus !== null){
|
|
$artwork->ReviewerUserId = Session::$User->UserId;
|
|
$artwork->Status = $newStatus;
|
|
}
|
|
else{
|
|
unset($artwork->Status);
|
|
}
|
|
}
|
|
}
|
|
|
|
if(isset($_POST['artwork-ebook-url'])){
|
|
$newEbookUrl = HttpInput::Str(POST, 'artwork-ebook-url');
|
|
if(isset($newEbookUrl)){
|
|
try{
|
|
$newEbook = Ebook::GetByIdentifier('url:' . $newEbookUrl);
|
|
}
|
|
catch(Exceptions\EbookNotFoundException){
|
|
throw new Exceptions\InvalidUrlException($newEbookUrl);
|
|
}
|
|
|
|
if($artwork->EbookId != $newEbook->EbookId && !$artwork->CanEbookUrlBeChangedBy(Session::$User)){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
|
|
$artwork->EbookId = $newEbook->EbookId;
|
|
}
|
|
else{
|
|
if(isset($artwork->EbookId) && !$artwork->CanEbookUrlBeChangedBy(Session::$User)){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
|
|
$artwork->EbookId = null;
|
|
}
|
|
}
|
|
|
|
$artwork->Save();
|
|
|
|
$_SESSION['artwork'] = $artwork;
|
|
$_SESSION['is-artwork-saved'] = true;
|
|
|
|
http_response_code(Enums\HttpCode::SeeOther->value);
|
|
header('Location: ' . $artwork->Url);
|
|
}
|
|
}
|
|
catch(Exceptions\LoginRequiredException){
|
|
Template::RedirectToLogin();
|
|
}
|
|
catch(Exceptions\InvalidPermissionsException){
|
|
Template::ExitWithCode(Enums\HttpCode::Forbidden);
|
|
}
|
|
catch(Exceptions\ArtworkNotFoundException){
|
|
Template::ExitWithCode(Enums\HttpCode::NotFound);
|
|
}
|
|
catch(Exceptions\InvalidArtworkException | Exceptions\InvalidArtworkTagException | Exceptions\InvalidArtistException | Exceptions\InvalidImageUploadException | Exceptions\InvalidFileUploadException | Exceptions\InvalidUrlException | Exceptions\InvalidRequestException $ex){
|
|
// If we were passed a more generic file upload exception from `HttpInput`, swap it for a more specific exception to show to the user.
|
|
if($ex instanceof Exceptions\InvalidFileUploadException){
|
|
$ex = new Exceptions\InvalidImageUploadException();
|
|
}
|
|
|
|
// If the `Artwork` reports that no image is uploaded, check to see if the image upload was too large. If so, show the user a clearer error message.
|
|
if($ex instanceof Exceptions\InvalidArtworkException && $ex->Has(Exceptions\InvalidImageUploadException::class) && HttpInput::IsRequestTooLarge()){
|
|
$ex->Remove(Exceptions\InvalidImageUploadException::class);
|
|
$ex->Add(new Exceptions\InvalidRequestException('File upload too large.'));
|
|
}
|
|
|
|
$_SESSION['artwork'] = $artwork;
|
|
$_SESSION['exception'] = $ex;
|
|
|
|
http_response_code(Enums\HttpCode::SeeOther->value);
|
|
header('Location: ' . $exceptionRedirectUrl);
|
|
}
|