This commit is contained in:
Dennis Eichhorn 2024-04-12 00:52:06 +00:00
parent 92b66064dc
commit 55134be232
3 changed files with 70 additions and 311 deletions

View File

@ -19,7 +19,7 @@
"type": 2, "type": 2,
"subtype": 1, "subtype": 1,
"name": "Vehicles", "name": "Vehicles",
"uri": "{/base}/fleet/vehicle/list?{?}", "uri": "{/base}/fleet/vehicle/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 1, "order": 1,
@ -33,7 +33,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "List", "name": "List",
"uri": "{/base}/fleet/vehicle/list?{?}", "uri": "{/base}/fleet/vehicle/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 1, "order": 1,
@ -48,7 +48,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "Create", "name": "Create",
"uri": "{/base}/fleet/vehicle/create?{?}", "uri": "{/base}/fleet/vehicle/create",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 1, "order": 1,
@ -65,7 +65,7 @@
"type": 2, "type": 2,
"subtype": 1, "subtype": 1,
"name": "Drivers", "name": "Drivers",
"uri": "{/base}/fleet/driver/list?{?}", "uri": "{/base}/fleet/driver/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 1, "order": 1,
@ -79,7 +79,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "List", "name": "List",
"uri": "{/base}/fleet/driver/list?{?}", "uri": "{/base}/fleet/driver/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 1, "order": 1,
@ -94,7 +94,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "Create", "name": "Create",
"uri": "{/base}/fleet/driver/create?{?}", "uri": "{/base}/fleet/driver/create",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 1, "order": 1,
@ -111,7 +111,7 @@
"type": 2, "type": 2,
"subtype": 1, "subtype": 1,
"name": "Inspections", "name": "Inspections",
"uri": "{/base}/fleet/inspection/list?{?}", "uri": "{/base}/fleet/inspection/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 1, "order": 1,
@ -125,7 +125,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "List", "name": "List",
"uri": "{/base}/fleet/inspection/list?{?}", "uri": "{/base}/fleet/inspection/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 1, "order": 1,
@ -140,7 +140,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "VehicleInspectionTypes", "name": "VehicleInspectionTypes",
"uri": "{/base}/fleet/inspection/vehicle/type/list?{?}", "uri": "{/base}/fleet/inspection/vehicle/type/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 5, "order": 5,
@ -155,7 +155,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "DriverInspectionTypes", "name": "DriverInspectionTypes",
"uri": "{/base}/fleet/inspection/driver/type/list?{?}", "uri": "{/base}/fleet/inspection/driver/type/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 5, "order": 5,
@ -172,7 +172,7 @@
"type": 2, "type": 2,
"subtype": 1, "subtype": 1,
"name": "VehicleAttributes", "name": "VehicleAttributes",
"uri": "{/base}/fleet/vehicle/attribute/type/list?{?}", "uri": "{/base}/fleet/vehicle/attribute/type/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 5, "order": 5,
@ -186,7 +186,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "Types", "name": "Types",
"uri": "{/base}/fleet/vehicle/attribute/type/list?{?}", "uri": "{/base}/fleet/vehicle/attribute/type/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 15, "order": 15,
@ -201,7 +201,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "Values", "name": "Values",
"uri": "{/base}/fleet/vehicle/attribute/value/list?{?}", "uri": "{/base}/fleet/vehicle/attribute/value/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 15, "order": 15,
@ -218,7 +218,7 @@
"type": 2, "type": 2,
"subtype": 1, "subtype": 1,
"name": "DriverAttributes", "name": "DriverAttributes",
"uri": "{/base}/fleet/driver/attribute/type/list?{?}", "uri": "{/base}/fleet/driver/attribute/type/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 5, "order": 5,
@ -232,7 +232,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "Types", "name": "Types",
"uri": "{/base}/fleet/driver/attribute/type/list?{?}", "uri": "{/base}/fleet/driver/attribute/type/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 15, "order": 15,
@ -247,7 +247,7 @@
"type": 3, "type": 3,
"subtype": 1, "subtype": 1,
"name": "Values", "name": "Values",
"uri": "{/base}/fleet/driver/attribute/value/list?{?}", "uri": "{/base}/fleet/driver/attribute/value/list",
"target": "self", "target": "self",
"icon": null, "icon": null,
"order": 15, "order": 15,

View File

@ -24,12 +24,8 @@ use Modules\FleetManagement\Models\Driver\DriverStatus;
use Modules\FleetManagement\Models\Inspection; use Modules\FleetManagement\Models\Inspection;
use Modules\FleetManagement\Models\InspectionStatus; use Modules\FleetManagement\Models\InspectionStatus;
use Modules\FleetManagement\Models\PermissionCategory; use Modules\FleetManagement\Models\PermissionCategory;
use Modules\Media\Models\CollectionMapper; use Modules\Media\Models\NullCollection;
use Modules\Media\Models\MediaMapper;
use Modules\Media\Models\NullMedia;
use Modules\Media\Models\PathSettings; use Modules\Media\Models\PathSettings;
use Modules\Media\Models\Reference;
use Modules\Media\Models\ReferenceMapper;
use phpOMS\Account\PermissionType; use phpOMS\Account\PermissionType;
use phpOMS\Localization\BaseStringL11n; use phpOMS\Localization\BaseStringL11n;
use phpOMS\Localization\BaseStringL11nType; use phpOMS\Localization\BaseStringL11nType;
@ -187,99 +183,29 @@ final class ApiDriverController extends Controller
{ {
$path = $this->createDriverDir($driver); $path = $this->createDriverDir($driver);
$collection = null; if (!empty($request->files)) {
$this->app->moduleManager->get('Media', 'Api')->uploadFiles(
if (!empty($uploadedFiles = $request->files)) {
$uploaded = $this->app->moduleManager->get('Media', 'Api')->uploadFiles(
names: [], names: [],
fileNames: [], fileNames: [],
files: $uploadedFiles, files: $request->files,
account: $request->header->account, account: $request->header->account,
basePath: __DIR__ . '/../../../Modules/Media/Files' . $path, basePath: __DIR__ . '/../../../Modules/Media/Files' . $path,
virtualPath: $path, virtualPath: $path,
pathSettings: PathSettings::FILE_PATH pathSettings: PathSettings::FILE_PATH,
rel: $driver->id,
mapper: DriverMapper::class,
field: 'files'
); );
}
foreach ($uploaded as $media) { if (!empty($media = $request->getDataJson('media'))) {
$this->createModelRelation( $this->app->moduleManager->get('Media', 'Api')->addMediaToCollectionAndModel(
$request->header->account, $request->header->account,
$media,
$driver->id, $driver->id,
$media->id,
DriverMapper::class, DriverMapper::class,
'files', 'files',
'', $path
$request->getOrigin()
);
if ($collection === null) {
/** @var \Modules\Media\Models\Collection $collection */
$collection = MediaMapper::getParentCollection($path)->limit(1)->execute();
if ($collection->id === 0) {
$collection = $this->app->moduleManager->get('Media')->createRecursiveMediaCollection(
$path,
$request->header->account,
__DIR__ . '/../../../Modules/Media/Files' . $path
);
}
}
$this->createModelRelation(
$request->header->account,
$collection->id,
$media->id,
CollectionMapper::class,
'sources',
'',
$request->getOrigin()
);
}
}
$mediaFiles = $request->getDataJson('media');
foreach ($mediaFiles as $file) {
/** @var \Modules\Media\Models\Media $media */
$media = MediaMapper::get()->where('id', (int) $file)->limit(1)->execute();
$this->createModelRelation(
$request->header->account,
$driver->id,
$media->id,
DriverMapper::class,
'files',
'',
$request->getOrigin()
);
$ref = new Reference();
$ref->name = $media->name;
$ref->source = new NullMedia($media->id);
$ref->createdBy = new NullAccount($request->header->account);
$ref->setVirtualPath($path);
$this->createModel($request->header->account, $ref, ReferenceMapper::class, 'media_reference', $request->getOrigin());
if ($collection === null) {
/** @var \Modules\Media\Models\Collection $collection */
$collection = MediaMapper::getParentCollection($path)->limit(1)->execute();
if ($collection->id === 0) {
$collection = $this->app->moduleManager->get('Media')->createRecursiveMediaCollection(
$path,
$request->header->account,
__DIR__ . '/../../../Modules/Media/Files' . $path
);
}
}
$this->createModelRelation(
$request->header->account,
$collection->id,
$ref->id,
CollectionMapper::class,
'sources',
'',
$request->getOrigin()
); );
} }
} }
@ -330,85 +256,39 @@ final class ApiDriverController extends Controller
$driver = DriverMapper::get()->where('id', (int) $request->getData('driver'))->execute(); $driver = DriverMapper::get()->where('id', (int) $request->getData('driver'))->execute();
$path = $this->createDriverDir($driver); $path = $this->createDriverDir($driver);
$uploaded = []; $uploaded = new NullCollection();
if (!empty($uploadedFiles = $request->files)) { if (!empty($request->files)) {
$uploaded = $this->app->moduleManager->get('Media', 'Api')->uploadFiles( $uploaded = $this->app->moduleManager->get('Media', 'Api')->uploadFiles(
names: [], names: [],
fileNames: [], fileNames: [],
files: $uploadedFiles, files: $request->files,
account: $request->header->account, account: $request->header->account,
basePath: __DIR__ . '/../../../Modules/Media/Files' . $path, basePath: __DIR__ . '/../../../Modules/Media/Files' . $path,
virtualPath: $path, virtualPath: $path,
pathSettings: PathSettings::FILE_PATH, pathSettings: PathSettings::FILE_PATH,
hasAccountRelation: false, hasAccountRelation: false,
readContent: $request->getDataBool('parse_content') ?? false readContent: $request->getDataBool('parse_content') ?? false,
type: $request->getDataInt('type'),
rel: $driver->id,
mapper: DriverMapper::class,
field: 'files'
); );
}
$collection = null; if (!empty($media = $request->getDataJson('media'))) {
foreach ($uploaded as $media) { $this->app->moduleManager->get('Media', 'Api')->addMediaToCollectionAndModel(
$this->createModelRelation(
$request->header->account, $request->header->account,
$media,
$driver->id, $driver->id,
$media->id,
DriverMapper::class, DriverMapper::class,
'files', 'files',
'', $path
$request->getOrigin()
);
if ($request->hasData('type')) {
$this->createModelRelation(
$request->header->account,
$media->id,
$request->getDataInt('type'),
MediaMapper::class,
'types',
'',
$request->getOrigin()
); );
} }
if ($collection === null) { $this->fillJsonResponse($request, $response, NotificationLevel::OK, '', $this->app->l11nManager->getText($response->header->l11n->language, '0', '0', 'SuccessfulAdd'), [
/** @var \Modules\Media\Models\Collection $collection */ 'upload' => $uploaded->sources,
$collection = MediaMapper::getParentCollection($path)->limit(1)->execute(); 'media' => $media,
if ($collection->id === 0) {
$collection = $this->app->moduleManager->get('Media')->createRecursiveMediaCollection(
$path,
$request->header->account,
__DIR__ . '/../../../Modules/Media/Files' . $path,
);
}
}
$this->createModelRelation(
$request->header->account,
$collection->id,
$media->id,
CollectionMapper::class,
'sources',
'',
$request->getOrigin()
);
}
}
$mediaFiles = $request->getDataJson('media');
foreach ($mediaFiles as $media) {
$this->createModelRelation(
$request->header->account,
$driver->id,
(int) $media,
DriverMapper::class,
'files',
'',
$request->getOrigin()
);
}
$this->fillJsonResponse($request, $response, NotificationLevel::OK, 'Media', 'Media added to driver.', [
'upload' => $uploaded,
'media' => $mediaFiles,
]); ]);
} }

View File

@ -14,7 +14,6 @@ declare(strict_types=1);
namespace Modules\FleetManagement\Controller; namespace Modules\FleetManagement\Controller;
use Modules\Admin\Models\NullAccount;
use Modules\FleetManagement\Models\Driver\NullDriver; use Modules\FleetManagement\Models\Driver\NullDriver;
use Modules\FleetManagement\Models\FuelTypeL11nMapper; use Modules\FleetManagement\Models\FuelTypeL11nMapper;
use Modules\FleetManagement\Models\FuelTypeMapper; use Modules\FleetManagement\Models\FuelTypeMapper;
@ -31,12 +30,8 @@ use Modules\FleetManagement\Models\VehicleMapper;
use Modules\FleetManagement\Models\VehicleStatus; use Modules\FleetManagement\Models\VehicleStatus;
use Modules\FleetManagement\Models\VehicleTypeL11nMapper; use Modules\FleetManagement\Models\VehicleTypeL11nMapper;
use Modules\FleetManagement\Models\VehicleTypeMapper; use Modules\FleetManagement\Models\VehicleTypeMapper;
use Modules\Media\Models\CollectionMapper; use Modules\Media\Models\NullCollection;
use Modules\Media\Models\MediaMapper;
use Modules\Media\Models\NullMedia;
use Modules\Media\Models\PathSettings; use Modules\Media\Models\PathSettings;
use Modules\Media\Models\Reference;
use Modules\Media\Models\ReferenceMapper;
use phpOMS\Account\PermissionType; use phpOMS\Account\PermissionType;
use phpOMS\Localization\BaseStringL11n; use phpOMS\Localization\BaseStringL11n;
use phpOMS\Localization\BaseStringL11nType; use phpOMS\Localization\BaseStringL11nType;
@ -562,99 +557,29 @@ final class ApiVehicleController extends Controller
{ {
$path = $this->createVehicleDir($vehicle); $path = $this->createVehicleDir($vehicle);
$collection = null; if (!empty($request->files)) {
$this->app->moduleManager->get('Media', 'Api')->uploadFiles(
if (!empty($uploadedFiles = $request->files)) {
$uploaded = $this->app->moduleManager->get('Media', 'Api')->uploadFiles(
names: [], names: [],
fileNames: [], fileNames: [],
files: $uploadedFiles, files: $request->files,
account: $request->header->account, account: $request->header->account,
basePath: __DIR__ . '/../../../Modules/Media/Files' . $path, basePath: __DIR__ . '/../../../Modules/Media/Files' . $path,
virtualPath: $path, virtualPath: $path,
pathSettings: PathSettings::FILE_PATH pathSettings: PathSettings::FILE_PATH,
rel: $vehicle->id,
mapper: VehicleMapper::class,
field: 'files'
); );
}
foreach ($uploaded as $media) { if (!empty($media = $request->getDataJson('media'))) {
$this->createModelRelation( $this->app->moduleManager->get('Media', 'Api')->addMediaToCollectionAndModel(
$request->header->account, $request->header->account,
$media,
$vehicle->id, $vehicle->id,
$media->id,
VehicleMapper::class, VehicleMapper::class,
'files', 'files',
'', $path
$request->getOrigin()
);
if ($collection === null) {
/** @var \Modules\Media\Models\Collection $collection */
$collection = MediaMapper::getParentCollection($path)->limit(1)->execute();
if ($collection->id === 0) {
$collection = $this->app->moduleManager->get('Media')->createRecursiveMediaCollection(
$path,
$request->header->account,
__DIR__ . '/../../../Modules/Media/Files' . $path
);
}
}
$this->createModelRelation(
$request->header->account,
$collection->id,
$media->id,
CollectionMapper::class,
'sources',
'',
$request->getOrigin()
);
}
}
$mediaFiles = $request->getDataJson('media');
foreach ($mediaFiles as $file) {
/** @var \Modules\Media\Models\Media $media */
$media = MediaMapper::get()->where('id', (int) $file)->limit(1)->execute();
$this->createModelRelation(
$request->header->account,
$vehicle->id,
$media->id,
VehicleMapper::class,
'files',
'',
$request->getOrigin()
);
$ref = new Reference();
$ref->name = $media->name;
$ref->source = new NullMedia($media->id);
$ref->createdBy = new NullAccount($request->header->account);
$ref->setVirtualPath($path);
$this->createModel($request->header->account, $ref, ReferenceMapper::class, 'media_reference', $request->getOrigin());
if ($collection === null) {
/** @var \Modules\Media\Models\Collection $collection */
$collection = MediaMapper::getParentCollection($path)->limit(1)->execute();
if ($collection->id === 0) {
$collection = $this->app->moduleManager->get('Media')->createRecursiveMediaCollection(
$path,
$request->header->account,
__DIR__ . '/../../../Modules/Media/Files' . $path
);
}
}
$this->createModelRelation(
$request->header->account,
$collection->id,
$ref->id,
CollectionMapper::class,
'sources',
'',
$request->getOrigin()
); );
} }
} }
@ -706,85 +631,39 @@ final class ApiVehicleController extends Controller
$vehicle = VehicleMapper::get()->where('id', (int) $request->getData('vehicle'))->execute(); $vehicle = VehicleMapper::get()->where('id', (int) $request->getData('vehicle'))->execute();
$path = $this->createVehicleDir($vehicle); $path = $this->createVehicleDir($vehicle);
$uploaded = []; $uploaded = new NullCollection();
if (!empty($uploadedFiles = $request->files)) { if (!empty($request->files)) {
$uploaded = $this->app->moduleManager->get('Media', 'Api')->uploadFiles( $uploaded = $this->app->moduleManager->get('Media', 'Api')->uploadFiles(
names: [], names: [],
fileNames: [], fileNames: [],
files: $uploadedFiles, files: $request->files,
account: $request->header->account, account: $request->header->account,
basePath: __DIR__ . '/../../../Modules/Media/Files' . $path, basePath: __DIR__ . '/../../../Modules/Media/Files' . $path,
virtualPath: $path, virtualPath: $path,
pathSettings: PathSettings::FILE_PATH, pathSettings: PathSettings::FILE_PATH,
hasAccountRelation: false, hasAccountRelation: false,
readContent: $request->getDataBool('parse_content') ?? false readContent: $request->getDataBool('parse_content') ?? false,
type: $request->getDataInt('type'),
rel: $vehicle->id,
mapper: VehicleMapper::class,
field: 'files'
); );
}
$collection = null; if (!empty($media = $request->getDataJson('media'))) {
foreach ($uploaded as $media) { $this->app->moduleManager->get('Media', 'Api')->addMediaToCollectionAndModel(
$this->createModelRelation(
$request->header->account, $request->header->account,
$media,
$vehicle->id, $vehicle->id,
$media->id,
VehicleMapper::class, VehicleMapper::class,
'files', 'files',
'', $path
$request->getOrigin()
);
if ($request->hasData('type')) {
$this->createModelRelation(
$request->header->account,
$media->id,
$request->getDataInt('type'),
MediaMapper::class,
'types',
'',
$request->getOrigin()
); );
} }
if ($collection === null) { $this->fillJsonResponse($request, $response, NotificationLevel::OK, '', $this->app->l11nManager->getText($response->header->l11n->language, '0', '0', 'SuccessfulAdd'), [
/** @var \Modules\Media\Models\Collection $collection */ 'upload' => $uploaded->sources,
$collection = MediaMapper::getParentCollection($path)->limit(1)->execute(); 'media' => $media,
if ($collection->id === 0) {
$collection = $this->app->moduleManager->get('Media')->createRecursiveMediaCollection(
$path,
$request->header->account,
__DIR__ . '/../../../Modules/Media/Files' . $path,
);
}
}
$this->createModelRelation(
$request->header->account,
$collection->id,
$media->id,
CollectionMapper::class,
'sources',
'',
$request->getOrigin()
);
}
}
$mediaFiles = $request->getDataJson('media');
foreach ($mediaFiles as $media) {
$this->createModelRelation(
$request->header->account,
$vehicle->id,
(int) $media,
VehicleMapper::class,
'files',
'',
$request->getOrigin()
);
}
$this->fillJsonResponse($request, $response, NotificationLevel::OK, 'Media', 'Media added to vehicle.', [
'upload' => $uploaded,
'media' => $mediaFiles,
]); ]);
} }