mirror of
https://github.com/standardebooks/web.git
synced 2025-07-05 14:20:29 -04:00
131 lines
3.8 KiB
PHP
131 lines
3.8 KiB
PHP
<?
|
|
|
|
use function Safe\session_start;
|
|
|
|
try{
|
|
session_start();
|
|
|
|
$httpMethod = HttpInput::ValidateRequestMethod([Enums\HttpMethod::Post, Enums\HttpMethod::Patch, Enums\HttpMethod::Put]);
|
|
$exceptionRedirectUrl = '/projects/new';
|
|
|
|
if(Session::$User === null){
|
|
throw new Exceptions\LoginRequiredException();
|
|
}
|
|
|
|
// POSTing a new `Project`.
|
|
if($httpMethod == Enums\HttpMethod::Post){
|
|
if(!Session::$User->Benefits->CanEditProjects){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
|
|
$project = new Project();
|
|
|
|
$project->FillFromHttpPost();
|
|
|
|
// Are we creating a new placeholder at the same time?
|
|
if(!isset($project->EbookId)){
|
|
$project->Ebook = new Ebook();
|
|
$project->Ebook->FillFromEbookPlaceholderForm();
|
|
if(isset($project->Ebook->EbookPlaceholder) && ($project->Status == Enums\ProjectStatusType::InProgress || $project->Status == Enums\ProjectStatusType::Stalled)){
|
|
$project->Ebook->EbookPlaceholder->IsInProgress = true;
|
|
}
|
|
$project->Ebook->Validate();
|
|
|
|
$project->Validate(true, true);
|
|
|
|
try{
|
|
$project->Ebook->Create();
|
|
$project->EbookId = $project->Ebook->EbookId;
|
|
}
|
|
catch(Exceptions\EbookExistsException $ex){
|
|
// If the `Ebook` already exists, create the `Project` anyway.
|
|
$project->Ebook = Ebook::GetByIdentifier($project->Ebook->Identifier);
|
|
if($project->Ebook->EbookPlaceholder !== null && !$project->Ebook->EbookPlaceholder->IsInProgress){
|
|
$project->EbookId = $project->Ebook->EbookId;
|
|
$_SESSION['is-only-ebook-project-created'] = true;
|
|
}
|
|
else{
|
|
// `Ebook` exists and it's not a placeholder, so really fail.
|
|
throw new Exceptions\EbookIsNotAPlaceholderException();
|
|
}
|
|
}
|
|
|
|
$project->Create();
|
|
}
|
|
else{
|
|
$project->Create();
|
|
}
|
|
|
|
// Set the placeholder to in progress.
|
|
if(isset($project->Ebook->EbookPlaceholder)){
|
|
$project->Ebook->EbookPlaceholder->IsInProgress = true;
|
|
$project->Ebook->EbookPlaceholder->Save();
|
|
}
|
|
|
|
$_SESSION['project'] = $project;
|
|
if(!isset($_SESSION['is-only-ebook-project-created'])){
|
|
$_SESSION['is-project-created'] = true;
|
|
}
|
|
|
|
http_response_code(Enums\HttpCode::SeeOther->value);
|
|
header('Location: /projects');
|
|
}
|
|
|
|
// PUTing a `Project`.
|
|
if($httpMethod == Enums\HttpMethod::Put){
|
|
if(!Session::$User->Benefits->CanEditProjects){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
|
|
$project = Project::Get(HttpInput::Int(GET, 'project-id'));
|
|
$exceptionRedirectUrl = $project->EditUrl;
|
|
|
|
$project->FillFromHttpPost();
|
|
|
|
$project->Save();
|
|
|
|
$_SESSION['is-project-saved'] = true;
|
|
http_response_code(Enums\HttpCode::SeeOther->value);
|
|
header('Location: ' . $project->Ebook->Url);
|
|
}
|
|
|
|
// PATCHing a `Project`.
|
|
if($httpMethod == Enums\HttpMethod::Patch){
|
|
$project = Project::Get(HttpInput::Int(GET, 'project-id'));
|
|
$exceptionRedirectUrl = $project->EditUrl;
|
|
|
|
if(
|
|
!Session::$User->Benefits->CanEditProjects
|
|
&&
|
|
$project->ManagerUserId != Session::$User->UserId
|
|
&&
|
|
$project->ReviewerUserId != Session::$User->UserId
|
|
){
|
|
throw new Exceptions\InvalidPermissionsException();
|
|
}
|
|
|
|
$project->PropertyFromHttp('Status');
|
|
|
|
$project->Save();
|
|
|
|
$_SESSION['is-project-saved'] = true;
|
|
http_response_code(Enums\HttpCode::SeeOther->value);
|
|
header('Location: ' . $project->Ebook->Url);
|
|
}
|
|
}
|
|
catch(Exceptions\EbookNotFoundException){
|
|
Template::ExitWithCode(Enums\HttpCode::NotFound);
|
|
}
|
|
catch(Exceptions\LoginRequiredException){
|
|
Template::RedirectToLogin();
|
|
}
|
|
catch(Exceptions\InvalidPermissionsException){
|
|
Template::ExitWithCode(Enums\HttpCode::Forbidden);
|
|
}
|
|
catch(Exceptions\InvalidProjectException | Exceptions\InvalidEbookException | Exceptions\ProjectExistsException | Exceptions\EbookIsNotAPlaceholderException $ex){
|
|
$_SESSION['project'] = $project;
|
|
$_SESSION['exception'] = $ex;
|
|
|
|
http_response_code(Enums\HttpCode::SeeOther->value);
|
|
header('Location: ' . $exceptionRedirectUrl);
|
|
}
|