2018-08-06 12:30:51 +00:00
|
|
|
<?php
|
|
|
|
//https://www.5balloons.info/multi-page-step-form-in-laravel-with-validation/
|
|
|
|
namespace App\Http\Controllers\Publish;
|
|
|
|
|
2018-09-10 13:09:10 +00:00
|
|
|
use App\Models\Dataset;
|
2018-08-29 15:18:15 +00:00
|
|
|
use App\Http\Controllers\Controller;
|
2018-09-10 13:09:10 +00:00
|
|
|
use App\Models\License;
|
2018-08-29 15:18:15 +00:00
|
|
|
use App\Models\File;
|
2018-09-10 13:09:10 +00:00
|
|
|
use App\Models\Person;
|
|
|
|
use App\Models\Project;
|
2018-08-29 15:18:15 +00:00
|
|
|
use App\Models\Title;
|
2019-01-24 15:56:39 +00:00
|
|
|
use App\Models\Description;
|
2018-08-29 15:18:15 +00:00
|
|
|
use App\Rules\RdrFiletypes;
|
|
|
|
use App\Rules\RdrFilesize;
|
|
|
|
use Illuminate\Http\Request;
|
2018-08-06 12:30:51 +00:00
|
|
|
use Illuminate\Support\Facades\DB;
|
2018-08-29 15:18:15 +00:00
|
|
|
use Illuminate\Support\Facades\Response;
|
|
|
|
use Illuminate\Support\Facades\Storage;
|
|
|
|
use Illuminate\Support\Facades\Validator;
|
2018-10-29 13:24:41 +00:00
|
|
|
use App\Models\DatasetReference;
|
2019-03-18 13:32:29 +00:00
|
|
|
use App\Models\Subject;
|
2019-01-07 10:16:18 +00:00
|
|
|
use App\Models\GeolocationBox;
|
2019-01-30 16:46:12 +00:00
|
|
|
use App\Models\Page;
|
2019-02-21 13:07:00 +00:00
|
|
|
use Illuminate\Support\Facades\Auth;
|
2018-08-06 12:30:51 +00:00
|
|
|
|
|
|
|
class IndexController extends Controller
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Display a listing of the resource.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function index()
|
|
|
|
{
|
2018-10-18 14:51:46 +00:00
|
|
|
$builder = Dataset::query();
|
|
|
|
$datasets = $builder
|
2018-10-19 10:54:40 +00:00
|
|
|
//->where('server_state', 'inprogress')
|
|
|
|
->whereIn('server_state', ['inprogress', 'unpublished'])
|
2018-10-18 14:51:46 +00:00
|
|
|
->get();
|
|
|
|
return view('publish.index', compact('datasets'));
|
2018-08-06 12:30:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show the form for creating a new resource.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function createStep1(Request $request)
|
|
|
|
{
|
2018-08-29 15:18:15 +00:00
|
|
|
#$dataset = $request->session()->get('dataset');
|
2018-11-08 16:47:27 +00:00
|
|
|
$licenses = License::select('id', 'name_long')
|
|
|
|
->orderBy('sort_order')
|
|
|
|
->get();
|
2018-08-29 15:18:15 +00:00
|
|
|
$languages = DB::table('languages')
|
|
|
|
->where('active', true)
|
2019-01-22 17:24:18 +00:00
|
|
|
->pluck('part1', 'part1');
|
2018-08-29 15:18:15 +00:00
|
|
|
// ->toArray();
|
|
|
|
|
2018-10-18 14:51:46 +00:00
|
|
|
// $persons = Person::where('status', 1)
|
|
|
|
// ->pluck('last_name', 'id');
|
2018-08-31 14:47:04 +00:00
|
|
|
$projects = Project::pluck('label', 'id');
|
2019-01-22 17:24:18 +00:00
|
|
|
$relatedIdentifierTypes = ["ARK", "arXiv", "bibcode", "DOI", "EAN13", "EISSN", "Handle", "IGSN", "ISBN", "ISSN", "ISTC", "LISSN", "LSID", "PMID", "PURL", "UPC", "URL", "URN"];
|
|
|
|
$relatedIdentifierTypes = array_combine($relatedIdentifierTypes, $relatedIdentifierTypes);
|
|
|
|
|
|
|
|
$relationTypes = ["IsCitedBy", "Cites", "IsSupplementTo", "IsSupplementedBy", "IsContinuedBy", "Continues", "HasMetadata", "IsMetadataFor","IsNewVersionOf", "IsPreviousVersionOf", "IsPartOf", "HasPart", "IsReferencedBy", "References", "IsDocumentedBy", "Documents", "IsCompiledBy", "Compiles", "IsVariantFormOf", "IsOriginalFormOf", "IsIdenticalTo", "IsReviewedBy", "Reviews", "IsDerivedFrom", "IsSourceOf"];
|
|
|
|
$relationTypes = array_combine($relationTypes, $relationTypes);
|
2018-08-29 15:18:15 +00:00
|
|
|
|
2019-01-22 17:24:18 +00:00
|
|
|
$titleTypes = ['sub' => 'sub', 'alternative' => 'alternative', 'translated' => 'translated', 'other' => 'other'];
|
2019-01-24 16:33:04 +00:00
|
|
|
|
2019-03-18 13:32:29 +00:00
|
|
|
$keywordTypes = ['uncontrolled' => 'uncontrolled'];
|
|
|
|
|
2019-01-24 16:33:04 +00:00
|
|
|
$descriptionTypes = [ 'methods' => 'methods', 'series_information' => 'series_information', 'technical_info' => 'technical_info', 'other' => 'other'];
|
|
|
|
|
2019-01-30 16:46:12 +00:00
|
|
|
$page = Page::query()->where('page_slug', 'terms-and-conditions')->firstOrFail();
|
|
|
|
|
2019-01-22 17:24:18 +00:00
|
|
|
//$relationTypes = array('updates' => 'updates', 'updated-by' => 'updated-by', 'other' => 'other');
|
2019-03-18 13:32:29 +00:00
|
|
|
return view(
|
|
|
|
'publish.create-step1',
|
|
|
|
compact('licenses', 'languages', 'projects', 'relatedIdentifierTypes', 'relationTypes', 'titleTypes', 'keywordTypes', 'descriptionTypes', 'page')
|
|
|
|
);
|
2018-08-06 12:30:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Store a newly created resource in storage.
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function storeStep1(Request $request)
|
|
|
|
{
|
|
|
|
$validatedData = $this->validate($request, [
|
|
|
|
'Type' => 'required|min:4',
|
2018-08-29 15:18:15 +00:00
|
|
|
'rights' => 'required|boolean|in:1',
|
2018-08-06 12:30:51 +00:00
|
|
|
]);
|
|
|
|
// $validatedData = $request->validate([
|
|
|
|
// 'name' => 'required|unique:products',
|
|
|
|
// 'amount' => 'required|numeric',
|
|
|
|
// 'company' => 'required',
|
|
|
|
// 'available' => 'required',
|
|
|
|
// 'description' => 'required',
|
|
|
|
// ]);
|
|
|
|
if (empty($request->session()->get('dataset'))) {
|
|
|
|
// $dataset = new Dataset();
|
|
|
|
//$dataset->fill($validatedData);
|
|
|
|
// $dataset->type = $request->input('type');
|
|
|
|
$dataset = $request->except('rights', '_token');
|
|
|
|
$request->session()->put('dataset', $dataset);
|
|
|
|
} else {
|
|
|
|
$dataset = $request->session()->get('dataset');
|
|
|
|
//$dataset->fill($validatedData);
|
|
|
|
$dataset['Type'] = $request->input('Type');
|
|
|
|
$request->session()->put('dataset', $dataset);
|
|
|
|
}
|
|
|
|
return redirect()->route('dataset.create2');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show the step 2 Form for creating a new dataset.
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function createStep2(Request $request)
|
|
|
|
{
|
|
|
|
//if no dataset is'nt in session variable return to step1
|
|
|
|
if (empty($request->session()->get('dataset'))) {
|
|
|
|
return redirect()->route('dataset.create1');
|
|
|
|
}
|
|
|
|
|
|
|
|
$dataset = $request->session()->get('dataset');
|
|
|
|
|
|
|
|
//fill select variable
|
|
|
|
$languages = DB::table('languages')
|
|
|
|
->where('active', true)
|
|
|
|
->pluck('part2_t', 'part2_t');
|
|
|
|
|
|
|
|
return view('publish.create-step2', compact('dataset', 'languages'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Store a newly created resource in storage.
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function storeStep2(Request $request)
|
|
|
|
{
|
|
|
|
$validatedData = $this->validate($request, [
|
|
|
|
'Type' => 'required|min:4',
|
|
|
|
'BelongsToBibliography' => 'required|boolean',
|
|
|
|
"TitleMain.Value" => 'required|min:5|max:255',
|
|
|
|
"TitleMain.Language" => 'required|min:3',
|
|
|
|
"TitleAbstract.Value" => 'required|min:5|max:255',
|
2018-08-29 15:18:15 +00:00
|
|
|
"TitleAbstract.Language" => 'required|min:3',
|
2018-08-06 12:30:51 +00:00
|
|
|
]);
|
|
|
|
$optionalData = $request->all();
|
2018-08-29 15:18:15 +00:00
|
|
|
|
2018-08-06 12:30:51 +00:00
|
|
|
// $dataset = $request->except('rights', '_token', 'input_img');
|
|
|
|
|
|
|
|
$dataset = $request->session()->get('dataset');
|
2018-08-29 15:18:15 +00:00
|
|
|
|
2018-08-06 12:30:51 +00:00
|
|
|
//update dataset with validated data
|
2018-08-29 15:18:15 +00:00
|
|
|
$dataset['Type'] = $validatedData['Type'];
|
|
|
|
$dataset['BelongsToBibliography'] = $validatedData['BelongsToBibliography'];
|
|
|
|
$dataset['TitleMain']['Value'] = $validatedData['TitleMain']['Value'];
|
|
|
|
$dataset['TitleMain']['Language'] = $validatedData['TitleMain']['Language'];
|
|
|
|
$dataset['TitleAbstract']['Value'] = $validatedData['TitleAbstract']['Value'];
|
|
|
|
$dataset['TitleAbstract']['Language'] = $validatedData['TitleAbstract']['Language'];
|
2018-08-06 12:30:51 +00:00
|
|
|
if (isset($optionalData['CreatingCorporation'])) {
|
|
|
|
$dataset['CreatingCorporation'] = $optionalData['CreatingCorporation'];
|
|
|
|
}
|
|
|
|
if (isset($optionalData['EmbargoDate'])) {
|
|
|
|
$dataset['EmbargoDate'] = $optionalData['EmbargoDate'];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!isset($dataset['DatasetFile'])) {
|
|
|
|
$this->validate($request, [
|
2018-08-29 15:18:15 +00:00
|
|
|
'dataset_file' => 'required|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
|
|
|
|
]);
|
2018-08-06 12:30:51 +00:00
|
|
|
|
|
|
|
//update session variable
|
|
|
|
// $dataset = $request->session()->get('dataset');
|
|
|
|
$image = $request->file('dataset_file');
|
|
|
|
$fileName = "productImage-" . time() . '.' . $image->getClientOriginalExtension();
|
|
|
|
$path = $image->storeAs(
|
|
|
|
'files',
|
|
|
|
$fileName
|
|
|
|
);
|
|
|
|
// $path = Storage::putFile('files', $image, $fileName);
|
|
|
|
|
|
|
|
//$dataset = $request->session()->get('dataset');
|
|
|
|
$dataset['DatasetFile'] = $fileName;
|
|
|
|
}
|
|
|
|
$request->session()->put('dataset', $dataset);
|
|
|
|
return redirect()->route('dataset.create3');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show the Product Review page
|
|
|
|
*
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function createStep3(Request $request)
|
|
|
|
{
|
2018-08-29 15:18:15 +00:00
|
|
|
//if no dataset is'nt in session variable return to step1
|
2018-08-06 12:30:51 +00:00
|
|
|
if (empty($request->session()->get('dataset'))) {
|
|
|
|
return redirect()->route('dataset.create1');
|
|
|
|
}
|
|
|
|
$dataset = $request->session()->get('dataset');
|
|
|
|
return view('publish.create-step3', compact('dataset'));
|
|
|
|
}
|
|
|
|
|
2018-08-29 15:18:15 +00:00
|
|
|
/**
|
2018-08-06 12:30:51 +00:00
|
|
|
* Store a newly created resource in storage.
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2018-08-29 15:18:15 +00:00
|
|
|
public function storeTest(Request $request)
|
|
|
|
{
|
|
|
|
//$data = $request->all();
|
|
|
|
$data = json_decode($request->getContent(), true);
|
|
|
|
|
|
|
|
$validator = Validator::make($data, [
|
|
|
|
'type' => 'required|min:4',
|
|
|
|
'belongs_to_bibliography' => 'required|boolean',
|
|
|
|
]);
|
|
|
|
if ($validator->passes()) {
|
|
|
|
//TODO Handle your data
|
|
|
|
return response()->json(array(
|
|
|
|
'response' => 'success'));
|
|
|
|
} else {
|
|
|
|
//TODO Handle your error
|
|
|
|
//pass validator errors as errors object for ajax response
|
|
|
|
return response()->json(['errors' => $validator->errors()->all()], 422);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//https://laravel.io/forum/06-11-2014-how-to-save-eloquent-model-with-relations-in-one-go
|
|
|
|
//attach vs save https://stackoverflow.com/questions/35756469/laravel-5-many-to-many-attach-versus-save
|
2018-08-06 12:30:51 +00:00
|
|
|
public function store(Request $request)
|
|
|
|
{
|
2018-08-29 15:18:15 +00:00
|
|
|
$data = $request->all();
|
|
|
|
// $validatedData = $this->validate($request, [
|
|
|
|
// 'type' => 'required|min:4',
|
|
|
|
// 'rights' => 'required|boolean|in:1',
|
|
|
|
// ]);
|
|
|
|
$rules = [
|
2019-01-24 15:56:39 +00:00
|
|
|
// 'server_state' => 'required',
|
2018-08-29 15:18:15 +00:00
|
|
|
'type' => 'required|min:5',
|
|
|
|
'rights' => 'required|boolean|in:1',
|
|
|
|
'belongs_to_bibliography' => 'required|boolean',
|
2018-11-28 16:06:00 +00:00
|
|
|
'title_main.value' => 'required|min:4',
|
2018-08-29 15:18:15 +00:00
|
|
|
'title_main.language' => 'required',
|
2018-11-28 16:06:00 +00:00
|
|
|
'abstract_main.value' => 'required|min:4',
|
2018-08-31 14:47:04 +00:00
|
|
|
'abstract_main.language' => 'required',
|
2019-01-07 10:16:18 +00:00
|
|
|
'geolocation.xmin' => [
|
|
|
|
'nullable',
|
|
|
|
'regex:/^[-]?((((1[0-7][0-9])|([0-9]?[0-9]))\.(\d+))|180(\.0+)?)$/'
|
|
|
|
],
|
|
|
|
'geolocation.ymin' => [
|
|
|
|
'nullable',
|
|
|
|
'regex:/^[-]?(([0-8]?[0-9])\.(\d+))|(90(\.0+)?)$/'
|
|
|
|
],
|
|
|
|
'geolocation.xmax' => [
|
|
|
|
'nullable',
|
|
|
|
'regex:/^[-]?((((1[0-7][0-9])|([0-9]?[0-9]))\.(\d+))|180(\.0+)?)$/'
|
|
|
|
],
|
|
|
|
'geolocation.ymax' => [
|
|
|
|
'nullable',
|
|
|
|
'regex:/^[-]?(([0-8]?[0-9])\.(\d+))|(90(\.0+)?)$/'
|
|
|
|
],
|
2018-08-29 15:18:15 +00:00
|
|
|
];
|
|
|
|
if (null != $request->file('files')) {
|
|
|
|
$files = count($request->file('files')) - 1;
|
|
|
|
foreach (range(0, $files) as $index) {
|
|
|
|
// $rules['files.' . $index] = 'image|max:2048';
|
2018-11-28 16:06:00 +00:00
|
|
|
$rules['files.' . $index . '.file'] = ['required', 'file', new RdrFiletypes(), new RdrFilesize($index + 1)];
|
2018-08-29 15:18:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
$validator = Validator::make($request->all(), $rules);
|
|
|
|
if ($validator->passes()) {
|
|
|
|
//store dataset todo
|
|
|
|
//$data = $request->all();
|
2019-01-24 15:56:39 +00:00
|
|
|
$input = $request->except('files', 'licenses', 'abstract_main', 'title_main', 'references', 'titles');
|
2018-08-29 15:18:15 +00:00
|
|
|
// array_push($input, "Himbeere");
|
2019-01-24 15:56:39 +00:00
|
|
|
// $input += ['server_state' => 'created' ];
|
2019-02-21 13:07:00 +00:00
|
|
|
if (isset($data['server_state'])) {
|
|
|
|
$input['server_state'] = $data['server_state'];
|
|
|
|
} else {
|
|
|
|
$input['server_state'] = 'inprogress';
|
|
|
|
}
|
2018-08-29 15:18:15 +00:00
|
|
|
$dataset = new Dataset($input);
|
|
|
|
|
|
|
|
DB::beginTransaction(); //Start transaction!
|
|
|
|
try {
|
|
|
|
$dataset->save();
|
|
|
|
|
|
|
|
//store related files
|
2018-10-10 16:28:51 +00:00
|
|
|
if (isset($data['files'])) {
|
2018-08-29 15:18:15 +00:00
|
|
|
foreach ($data['files'] as $uploadedFile) {
|
|
|
|
$file = $uploadedFile['file'];
|
|
|
|
$label = urldecode($uploadedFile['label']);
|
|
|
|
$sorting = $uploadedFile['sorting'];
|
2018-09-11 08:05:25 +00:00
|
|
|
$fileName = "file-" . time() . '.' . $file->getClientOriginalExtension();
|
2018-08-29 15:18:15 +00:00
|
|
|
$mimeType = $file->getMimeType();
|
|
|
|
$datasetFolder = 'files/' . $dataset->id;
|
|
|
|
$path = $file->storeAs($datasetFolder, $fileName);
|
|
|
|
$size = Storage::size($path);
|
|
|
|
//$path = Storage::putFile('files', $image, $fileName);
|
|
|
|
$file = new File([
|
|
|
|
'path_name' => $path,
|
|
|
|
'file_size' => $size,
|
|
|
|
'mime_type' => $mimeType,
|
|
|
|
'label' => $label,
|
|
|
|
'sort_order' => $sorting,
|
|
|
|
'visible_in_frontdoor' => 1,
|
|
|
|
'visible_in_oai' => 1
|
|
|
|
]);
|
|
|
|
//$test = $file->path_name;
|
|
|
|
$dataset->files()->save($file);
|
|
|
|
$file->createHashValues();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//store licenses:
|
|
|
|
$licenses = $request->input('licenses');
|
|
|
|
$dataset->licenses()->sync($licenses);
|
|
|
|
|
2019-03-19 17:04:41 +00:00
|
|
|
$data_to_sync = [];
|
2018-10-19 10:54:40 +00:00
|
|
|
//store authors
|
2018-10-29 13:24:41 +00:00
|
|
|
if (isset($data['authors'])) {
|
2019-03-19 17:04:41 +00:00
|
|
|
//$data_to_sync = [];
|
2018-10-29 13:24:41 +00:00
|
|
|
foreach ($request->get('authors') as $key => $person_id) {
|
|
|
|
$pivot_data = ['role' => 'author', 'sort_order' => $key + 1];
|
|
|
|
// if ($galery_id == $request->get('mainPicture')) $pivot_data = ['main' => 1];
|
|
|
|
$data_to_sync[$person_id] = $pivot_data;
|
|
|
|
}
|
2019-03-19 17:04:41 +00:00
|
|
|
//$dataset->persons()->sync($data_to_sync);
|
2018-10-18 14:51:46 +00:00
|
|
|
}
|
2018-10-19 10:54:40 +00:00
|
|
|
|
|
|
|
//store contributors
|
2018-10-29 13:24:41 +00:00
|
|
|
if (isset($data['contributors'])) {
|
2019-03-19 17:04:41 +00:00
|
|
|
//$data_to_sync = [];
|
2018-10-29 13:24:41 +00:00
|
|
|
foreach ($request->get('contributors') as $key => $contributor_id) {
|
|
|
|
$pivot_data = ['role' => 'contributor', 'sort_order' => $key + 1];
|
|
|
|
$data_to_sync[$contributor_id] = $pivot_data;
|
|
|
|
}
|
2019-03-19 17:04:41 +00:00
|
|
|
//$dataset->persons()->sync($data_to_sync);
|
2018-10-19 10:54:40 +00:00
|
|
|
}
|
2018-10-29 13:24:41 +00:00
|
|
|
|
|
|
|
//store submitters
|
|
|
|
if (isset($data['submitters'])) {
|
2019-03-19 17:04:41 +00:00
|
|
|
//$data_to_sync = [];
|
2018-10-29 13:24:41 +00:00
|
|
|
foreach ($request->get('submitters') as $key => $submitter_id) {
|
|
|
|
$pivot_data = ['role' => 'submitter', 'sort_order' => $key + 1];
|
|
|
|
$data_to_sync[$submitter_id] = $pivot_data;
|
|
|
|
}
|
2019-03-19 17:04:41 +00:00
|
|
|
//$dataset->persons()->sync($data_to_sync);
|
2018-10-29 13:24:41 +00:00
|
|
|
}
|
2019-03-19 17:04:41 +00:00
|
|
|
$dataset->persons()->sync($data_to_sync);
|
2018-10-29 13:24:41 +00:00
|
|
|
|
2018-10-18 14:51:46 +00:00
|
|
|
|
2018-08-29 15:18:15 +00:00
|
|
|
//save main title:
|
|
|
|
if (isset($data['title_main'])) {
|
|
|
|
$formTitle = $request->input('title_main');
|
|
|
|
$title = new Title();
|
|
|
|
$title->value = $formTitle['value'];
|
|
|
|
$title->language = $formTitle['language'];
|
|
|
|
$dataset->addMainTitle($title);
|
|
|
|
}
|
|
|
|
|
2019-01-24 15:56:39 +00:00
|
|
|
//save additional titles
|
|
|
|
if (isset($data['titles'])) {
|
|
|
|
foreach ($request->get('titles') as $key => $title) {
|
|
|
|
$titleReference = new Title($title);
|
|
|
|
$dataset->titles()->save($titleReference);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-29 15:18:15 +00:00
|
|
|
//save main abstract:
|
|
|
|
if (isset($data['abstract_main'])) {
|
|
|
|
$formAbstract = $request->input('abstract_main');
|
2019-01-24 15:56:39 +00:00
|
|
|
$abstract = new Description();
|
2018-08-29 15:18:15 +00:00
|
|
|
$abstract->value = $formAbstract['value'];
|
|
|
|
$abstract->language = $formAbstract['language'];
|
|
|
|
$dataset->addMainAbstract($abstract);
|
|
|
|
}
|
2018-10-29 13:24:41 +00:00
|
|
|
|
2019-01-24 16:33:04 +00:00
|
|
|
//save additional descriptions
|
|
|
|
if (isset($data['descriptions'])) {
|
|
|
|
foreach ($request->get('descriptions') as $key => $description) {
|
|
|
|
$descriptionReference = new Description($description);
|
|
|
|
$dataset->abstracts()->save($descriptionReference);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-29 13:24:41 +00:00
|
|
|
//save references
|
|
|
|
if (isset($data['references'])) {
|
|
|
|
foreach ($request->get('references') as $key => $reference) {
|
|
|
|
$dataReference = new DatasetReference($reference);
|
|
|
|
$dataset->references()->save($dataReference);
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 10:16:18 +00:00
|
|
|
|
2019-03-18 13:32:29 +00:00
|
|
|
//save keywords
|
|
|
|
if (isset($data['keywords'])) {
|
|
|
|
foreach ($request->get('keywords') as $key => $keyword) {
|
|
|
|
$dataKeyword = new Subject($keyword);
|
|
|
|
$dataset->subjects()->save($dataKeyword);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-07 10:16:18 +00:00
|
|
|
if (isset($data['geolocation'])) {
|
|
|
|
$formGeolocation = $request->input('geolocation');
|
2019-02-19 17:52:52 +00:00
|
|
|
if ($formGeolocation['xmin'] !== null && $formGeolocation['ymin'] !== null &&
|
|
|
|
$formGeolocation['xmax'] !== null && $formGeolocation['ymax'] !== null) {
|
2019-01-07 10:16:18 +00:00
|
|
|
$geolocation = new GeolocationBox($formGeolocation);
|
|
|
|
$dataset->geolocation()->save($geolocation);
|
|
|
|
}
|
|
|
|
}
|
2019-02-21 13:07:00 +00:00
|
|
|
|
|
|
|
// Create relation between Dataset and actual User.
|
|
|
|
$user = Auth::user();
|
|
|
|
$dataset->user()->associate($user)->save();
|
2018-08-29 15:18:15 +00:00
|
|
|
|
2018-09-11 08:05:25 +00:00
|
|
|
// $error = 'Always throw this error';
|
|
|
|
// throw new \Exception($error);
|
2018-08-29 15:18:15 +00:00
|
|
|
|
|
|
|
// all good//commit everything
|
|
|
|
DB::commit();
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
DB::rollback();
|
2018-10-10 16:28:51 +00:00
|
|
|
if (isset($datasetFolder)) {
|
|
|
|
Storage::deleteDirectory($datasetFolder);
|
|
|
|
}
|
2018-08-29 15:18:15 +00:00
|
|
|
return response()->json([
|
|
|
|
'success' => false,
|
|
|
|
'error' => [
|
|
|
|
'code' => $e->getCode(),
|
|
|
|
'message' => $e->getMessage(),
|
|
|
|
],
|
|
|
|
], 422);
|
|
|
|
//throw $e;
|
|
|
|
} catch (\Throwable $e) {
|
|
|
|
DB::rollback();
|
2018-10-10 16:28:51 +00:00
|
|
|
if (isset($datasetFolder)) {
|
|
|
|
Storage::deleteDirectory($datasetFolder);
|
|
|
|
}
|
2018-08-29 15:18:15 +00:00
|
|
|
return response()->json([
|
|
|
|
'success' => false,
|
|
|
|
'error' => [
|
|
|
|
'code' => $e->getCode(),
|
|
|
|
'message' => $e->getMessage(),
|
|
|
|
],
|
|
|
|
], 422);
|
|
|
|
//throw $e;
|
|
|
|
}
|
|
|
|
|
|
|
|
return response()->json(array(
|
2018-08-31 14:47:04 +00:00
|
|
|
'success' => true,
|
2018-11-05 15:44:25 +00:00
|
|
|
//'redirect' => route('settings.document.edit', ['id' => $dataset->server_state]),
|
|
|
|
'redirect' => route('settings.document.edit', ['id' => $dataset->id]),
|
|
|
|
));
|
|
|
|
} else {
|
|
|
|
//TODO Handle validation error
|
|
|
|
//pass validator errors as errors object for ajax response
|
|
|
|
return response()->json([
|
|
|
|
'success' => false,
|
|
|
|
'errors' => $validator->errors()->all(),
|
|
|
|
], 422);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function storeTest1(Request $request)
|
|
|
|
{
|
|
|
|
$data = $request->all();
|
|
|
|
// $validatedData = $this->validate($request, [
|
|
|
|
// 'type' => 'required|min:4',
|
|
|
|
// 'rights' => 'required|boolean|in:1',
|
|
|
|
// ]);
|
|
|
|
$rules = [
|
|
|
|
'server_state' => 'required',
|
|
|
|
'type' => 'required|min:5',
|
|
|
|
'rights' => 'required|boolean|in:1',
|
|
|
|
'belongs_to_bibliography' => 'required|boolean',
|
|
|
|
'title_main.value' => 'required|min:5',
|
|
|
|
'title_main.language' => 'required',
|
|
|
|
'abstract_main.value' => 'required|min:5',
|
|
|
|
'abstract_main.language' => 'required',
|
|
|
|
];
|
|
|
|
if (null != $request->file('files')) {
|
2019-02-22 17:07:00 +00:00
|
|
|
$files = count($request->file('files')) -1;
|
2018-11-05 15:44:25 +00:00
|
|
|
foreach (range(0, $files) as $index) {
|
|
|
|
// $rules['files.' . $index] = 'image|max:2048';
|
2019-02-22 17:07:00 +00:00
|
|
|
$rules['files.' . $index . '.file'] = ['required', 'file', new RdrFiletypes(), new RdrFilesize($index)];
|
2018-11-05 15:44:25 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
$validator = Validator::make($request->all(), $rules);
|
|
|
|
if ($validator->passes()) {
|
|
|
|
//store dataset todo
|
|
|
|
//$data = $request->all();
|
|
|
|
$input = $request->except('files', 'licenses', 'abstract_main', 'title_main', 'references');
|
|
|
|
// array_push($input, "Himbeere");
|
|
|
|
$dataset = new Dataset($input);
|
|
|
|
|
|
|
|
DB::beginTransaction(); //Start transaction!
|
|
|
|
try {
|
|
|
|
// $dataset->save();
|
|
|
|
|
|
|
|
//store related files
|
|
|
|
if (isset($data['files'])) {
|
|
|
|
foreach ($data['files'] as $uploadedFile) {
|
|
|
|
$file = $uploadedFile['file'];
|
|
|
|
$label = urldecode($uploadedFile['label']);
|
|
|
|
$sorting = $uploadedFile['sorting'];
|
|
|
|
$fileName = "file-" . time() . '.' . $file->getClientOriginalExtension();
|
|
|
|
$mimeType = $file->getMimeType();
|
|
|
|
$datasetFolder = 'files/' . $dataset->id;
|
|
|
|
// $path = $file->storeAs($datasetFolder, $fileName);
|
|
|
|
// $size = Storage::size($path);
|
|
|
|
//$path = Storage::putFile('files', $image, $fileName);
|
|
|
|
// $file = new File([
|
|
|
|
// 'path_name' => $path,
|
|
|
|
// 'file_size' => $size,
|
|
|
|
// 'mime_type' => $mimeType,
|
|
|
|
// 'label' => $label,
|
|
|
|
// 'sort_order' => $sorting,
|
|
|
|
// 'visible_in_frontdoor' => 1,
|
|
|
|
// 'visible_in_oai' => 1
|
|
|
|
// ]);
|
|
|
|
//$test = $file->path_name;
|
|
|
|
// $dataset->files()->save($file);
|
|
|
|
// $file->createHashValues();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//store licenses:
|
|
|
|
$licenses = $request->input('licenses');
|
|
|
|
// $dataset->licenses()->sync($licenses);
|
|
|
|
|
|
|
|
//store authors
|
|
|
|
if (isset($data['authors'])) {
|
|
|
|
$data_to_sync = [];
|
|
|
|
foreach ($request->get('authors') as $key => $person_id) {
|
|
|
|
$pivot_data = ['role' => 'author', 'sort_order' => $key + 1];
|
|
|
|
// if ($galery_id == $request->get('mainPicture')) $pivot_data = ['main' => 1];
|
|
|
|
$data_to_sync[$person_id] = $pivot_data;
|
|
|
|
}
|
|
|
|
// $dataset->persons()->sync($data_to_sync);
|
|
|
|
}
|
|
|
|
|
|
|
|
//store contributors
|
|
|
|
if (isset($data['contributors'])) {
|
|
|
|
$data_to_sync = [];
|
|
|
|
foreach ($request->get('contributors') as $key => $contributor_id) {
|
|
|
|
$pivot_data = ['role' => 'contributor', 'sort_order' => $key + 1];
|
|
|
|
$data_to_sync[$contributor_id] = $pivot_data;
|
|
|
|
}
|
|
|
|
// $dataset->persons()->sync($data_to_sync);
|
|
|
|
}
|
|
|
|
|
|
|
|
//store submitters
|
|
|
|
if (isset($data['submitters'])) {
|
|
|
|
$data_to_sync = [];
|
|
|
|
foreach ($request->get('submitters') as $key => $submitter_id) {
|
|
|
|
$pivot_data = ['role' => 'submitter', 'sort_order' => $key + 1];
|
|
|
|
$data_to_sync[$submitter_id] = $pivot_data;
|
|
|
|
}
|
|
|
|
// $dataset->persons()->sync($data_to_sync);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//save main title:
|
|
|
|
if (isset($data['title_main'])) {
|
|
|
|
$formTitle = $request->input('title_main');
|
|
|
|
$title = new Title();
|
|
|
|
$title->value = $formTitle['value'];
|
|
|
|
$title->language = $formTitle['language'];
|
|
|
|
// $dataset->addMainTitle($title);
|
|
|
|
}
|
|
|
|
|
|
|
|
//save main abstract:
|
|
|
|
if (isset($data['abstract_main'])) {
|
|
|
|
$formAbstract = $request->input('abstract_main');
|
|
|
|
$abstract = new Title();
|
|
|
|
$abstract->value = $formAbstract['value'];
|
|
|
|
$abstract->language = $formAbstract['language'];
|
|
|
|
// $dataset->addMainAbstract($abstract);
|
|
|
|
}
|
|
|
|
|
|
|
|
//save references
|
|
|
|
if (isset($data['references'])) {
|
|
|
|
foreach ($request->get('references') as $key => $reference) {
|
|
|
|
$dataReference = new DatasetReference($reference);
|
|
|
|
// $dataset->references()->save($dataReference);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// $error = 'Always throw this error';
|
|
|
|
// throw new \Exception($error);
|
|
|
|
|
|
|
|
// all good//commit everything
|
|
|
|
// DB::commit();
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
DB::rollback();
|
|
|
|
if (isset($datasetFolder)) {
|
|
|
|
Storage::deleteDirectory($datasetFolder);
|
|
|
|
}
|
|
|
|
return response()->json([
|
|
|
|
'success' => false,
|
|
|
|
'error' => [
|
|
|
|
'code' => $e->getCode(),
|
|
|
|
'message' => $e->getMessage(),
|
|
|
|
],
|
|
|
|
], 422);
|
|
|
|
//throw $e;
|
|
|
|
} catch (\Throwable $e) {
|
|
|
|
DB::rollback();
|
|
|
|
if (isset($datasetFolder)) {
|
|
|
|
Storage::deleteDirectory($datasetFolder);
|
|
|
|
}
|
|
|
|
return response()->json([
|
|
|
|
'success' => false,
|
|
|
|
'error' => [
|
|
|
|
'code' => $e->getCode(),
|
|
|
|
'message' => $e->getMessage(),
|
|
|
|
],
|
|
|
|
], 422);
|
|
|
|
//throw $e;
|
|
|
|
}
|
|
|
|
|
|
|
|
return response()->json(array(
|
|
|
|
'success' => true,
|
|
|
|
'redirect' => route('settings.document.edit', ['id' => $dataset->server_state]),
|
2018-08-29 15:18:15 +00:00
|
|
|
));
|
|
|
|
} else {
|
|
|
|
//TODO Handle validation error
|
|
|
|
//pass validator errors as errors object for ajax response
|
|
|
|
return response()->json([
|
|
|
|
'success' => false,
|
|
|
|
'errors' => $validator->errors()->all(),
|
|
|
|
], 422);
|
|
|
|
}
|
2018-08-06 12:30:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Display the specified resource.
|
|
|
|
*
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function show($id)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Show the form for editing the specified resource.
|
|
|
|
*
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function edit($id)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the specified resource in storage.
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Http\Request $request
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function update(Request $request, $id)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove the specified resource from storage.
|
|
|
|
*
|
|
|
|
* @param int $id
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
|
|
|
public function destroy($id)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
}
|
|
|
|
}
|