validateInvestmentCreate($request))) { $response->data[$request->uri->__toString()] = new FormValidation($val); $response->header->status = RequestStatusCode::R_400; return; } /** @var Investment $investment */ $investment = $this->createInvestmentFromRequest($request); $this->createModel($request->header->account, $investment, InvestmentMapper::class, 'investment', $request->getOrigin()); if (!empty($request->files) || !empty($request->getDataJson('media')) ) { $this->createInvestmentMedia($investment, $request); } $this->fillJsonResponse( $request, $response, NotificationLevel::OK, '', $this->app->l11nManager->getText($response->header->l11n->language, '0', '0', 'SucessfulCreate'), $investment ); } /** * Method to create investment from request. * * @param RequestAbstract $request Request * * @return Investment Returns the created investment from the request * * @since 1.0.0 */ public function createInvestmentFromRequest(RequestAbstract $request) : Investment { $investment = new Investment(); $investment->name = $request->getDataString('name') ?? ''; $investment->description = $request->getDataString('description') ?? ''; $investment->unit = $request->getDataInt('unit') ?? $this->app->unitId; $investment->createdBy = new NullAccount($request->header->account); return $investment; } /** * Create media files for investment * * @param Investment $investment Investment * @param RequestAbstract $request Request incl. media do upload * * @return void * * @since 1.0.0 */ private function createInvestmentMedia(Investment $investment, RequestAbstract $request) : void { $path = $this->createInvestmentDir($investment); if (!empty($uploadedFiles = $request->files)) { $uploaded = $this->app->moduleManager->get('Media')->uploadFiles( names: [], fileNames: [], files: $uploadedFiles, account: $request->header->account, basePath: __DIR__ . '/../../../Modules/Media/Files' . $path, virtualPath: $path, pathSettings: PathSettings::FILE_PATH ); $collection = null; foreach ($uploaded as $media) { $this->createModelRelation( $request->header->account, $investment->id, $media->id, InvestmentMapper::class, 'files', '', $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() ); } } if (!empty($mediaFiles = $request->getDataJson('media'))) { $collection = null; 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, $investment->id, $media->id, InvestmentMapper::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() ); } } } /** * Api method to create a bill * * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return void * * @api * * @since 1.0.0 */ public function apiMediaAddToInvestment(RequestAbstract $request, ResponseAbstract $response, mixed $data = null) : void { if (!empty($val = $this->validateMediaAddToInvestment($request))) { $response->data[$request->uri->__toString()] = new FormValidation($val); $response->header->status = RequestStatusCode::R_400; return; } /** @var \Modules\FleetManagement\Models\Investment $investment */ $investment = InvestmentMapper::get()->where('id', (int) $request->getData('investment'))->execute(); $path = $this->createInvestmentDir($investment); $uploaded = []; if (!empty($uploadedFiles = $request->files)) { $uploaded = $this->app->moduleManager->get('Media')->uploadFiles( names: [], fileNames: [], files: $uploadedFiles, account: $request->header->account, basePath: __DIR__ . '/../../../Modules/Media/Files' . $path, virtualPath: $path, pathSettings: PathSettings::FILE_PATH, hasAccountRelation: false, readContent: (bool) ($request->getData('parse_content') ?? false) ); $collection = null; foreach ($uploaded as $media) { $this->createModelRelation( $request->header->account, $investment->id, $media->id, InvestmentMapper::class, 'files', '', $request->getOrigin() ); if ($request->hasData('type')) { $this->createModelRelation( $request->header->account, $media->id, $request->getDataInt('type'), MediaMapper::class, 'types', '', $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() ); } } if (!empty($mediaFiles = $request->getDataJson('media'))) { foreach ($mediaFiles as $media) { $this->createModelRelation( $request->header->account, $investment->id, (int) $media, InvestmentMapper::class, 'files', '', $request->getOrigin() ); } } $this->fillJsonResponse($request, $response, NotificationLevel::OK, 'Media', 'Media added to investment.', [ 'upload' => $uploaded, 'media' => $mediaFiles, ]); } /** * Method to validate bill creation from request * * @param RequestAbstract $request Request * * @return array * * @since 1.0.0 */ private function validateMediaAddToInvestment(RequestAbstract $request) : array { $val = []; if (($val['media'] = (!$request->hasData('media') && empty($request->files))) || ($val['investment'] = !$request->hasData('investment')) ) { return $val; } return []; } /** * Validate investment create request * * @param RequestAbstract $request Request * * @return array Returns the validation array of the request * * @since 1.0.0 */ private function validateInvestmentCreate(RequestAbstract $request) : array { $val = []; if (($val['name'] = !$request->hasData('name')) ) { return $val; } return []; } /** * Create media directory path * * @param Investment $investment Investment * * @return string * * @since 1.0.0 */ private function createInvestmentDir(Investment $investment) : string { return '/Modules/InvestmentManagement/Investment/' . $this->app->unitId . '/' . $investment->id; } /** * Create media directory path * * @param Investment $investment Investment * * @return string * * @since 1.0.0 */ private function createInvestmentObjectDir(InvestmentObject $object) : string { return '/Modules/InvestmentManagement/Investment/' . $this->app->unitId . '/' . $object->investment; } /** * Api method to create a investment * * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return void * * @api * * @since 1.0.0 */ public function apiInvestmentOptionCreate(RequestAbstract $request, ResponseAbstract $response, mixed $data = null) : void { if (!empty($val = $this->validateInvestmentOptionCreate($request))) { $response->data[$request->uri->__toString()] = new FormValidation($val); $response->header->status = RequestStatusCode::R_400; return; } /** @var InvestmentOption $investment */ $investment = $this->createInvestmentOptionFromRequest($request); $this->createModel($request->header->account, $investment, InvestmentObjectMapper::class, 'investment_option', $request->getOrigin()); if (!empty($request->files) || !empty($request->getDataJson('media')) ) { $this->createInvestmentObjectMedia($investment, $request); } $this->fillJsonResponse( $request, $response, NotificationLevel::OK, '', $this->app->l11nManager->getText($response->header->l11n->language, '0', '0', 'SucessfulCreate'), $investment ); } /** * Validate investment create request * * @param RequestAbstract $request Request * * @return array Returns the validation array of the request * * @since 1.0.0 */ private function validateInvestmentOptionCreate(RequestAbstract $request) : array { $val = []; if (($val['name'] = !$request->hasData('name')) || ($val['investment'] = !$request->hasData('investment')) ) { return $val; } return []; } /** * Method to create investment from request. * * @param RequestAbstract $request Request * * @return InvestmentObject Returns the created investment from the request * * @since 1.0.0 */ public function createInvestmentOptionFromRequest(RequestAbstract $request) : InvestmentObject { $investment = new InvestmentObject(); $investment->name = $request->getDataString('name') ?? ''; $investment->description = $request->getDataString('description') ?? ''; $investment->link = $request->getDataString('link') ?? ''; $investment->investment = (int) $request->getData('investment'); $investment->parent = $request->getDataInt('parent'); $investment->supplier = $request->getDataInt('supplier') ?? 0; $investment->supplierName = $request->getDataString('supplierName') ?? ''; $investment->item = $request->getDataInt('item'); $investment->performanceDate = $request->getDataDateTime('performance') ?? $investment->createdAt; // @todo: reconsider the following lines. This seems rather complicated. if ($request->hasData('amount')) { $types = AmountTypeMapper::getAll()->execute(); foreach ($types as $type) { if ($type->title = 'costs') { $defaultGroup = new AmountGroup(); $defaultGroup->name = 'Purchase Price'; // @todo: replace with api l11n $defaultGroup->type = $type->id; $amount = new Amount(); $amount->amount = new FloatInt((int) $request->getDataInt('amount')); $defaultGroup->amounts[] = $amount; $investment->amountGroups[] = $defaultGroup; } elseif ($type->title === 'cashflow') { $defaultGroup = new AmountGroup(); $defaultGroup->name = 'Cashflow'; // @todo: replace with api l11n $defaultGroup->type = $type->id; // @todo: calculate date based on performance date + offer conditions / 30 days $amount = new Amount(); $amount->amount = new FloatInt((int) $request->getDataInt('amount')); $defaultGroup->amounts[] = $amount; $investment->amountGroups[] = $defaultGroup; } elseif ($type->title === 'depreciation') { $defaultGroup = new AmountGroup(); $defaultGroup->name = 'Depreciation'; // @todo: replace with api l11n $defaultGroup->type = $type->id; // @todo: calculate automatic depreciation; $amount = new Amount(); $amount->amount = new FloatInt((int) $request->getDataInt('amount')); $defaultGroup->amounts[] = $amount; $investment->amountGroups[] = $defaultGroup; } } } return $investment; } /** * Api method to create a investment * * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return void * * @api * * @since 1.0.0 */ public function apiAmountTypeCreate(RequestAbstract $request, ResponseAbstract $response, mixed $data = null) : void { if (!empty($val = $this->validateAmountTypeCreate($request))) { $response->data[$request->uri->__toString()] = new FormValidation($val); $response->header->status = RequestStatusCode::R_400; return; } /** @var BaseStringL11nType $amount */ $amount = $this->createAmountTypeFromRequest($request); $this->createModel($request->header->account, $amount, AmountTypeMapper::class, 'amount_type', $request->getOrigin()); $this->fillJsonResponse( $request, $response, NotificationLevel::OK, '', $this->app->l11nManager->getText($response->header->l11n->language, '0', '0', 'SucessfulCreate'), $amount ); } /** * Create media files for investment * * @param InvestmentObject $investment Investment * @param RequestAbstract $request Request incl. media do upload * * @return void * * @since 1.0.0 */ private function createInvestmentObjectMedia(InvestmentObject $investment, RequestAbstract $request) : void { $path = $this->createInvestmentObjectDir($investment); if (!empty($uploadedFiles = $request->files)) { $uploaded = $this->app->moduleManager->get('Media')->uploadFiles( names: [], fileNames: [], files: $uploadedFiles, account: $request->header->account, basePath: __DIR__ . '/../../../Modules/Media/Files' . $path, virtualPath: $path, pathSettings: PathSettings::FILE_PATH ); $collection = null; foreach ($uploaded as $media) { $this->createModelRelation( $request->header->account, $investment->id, $media->id, InvestmentObjectMapper::class, 'files', '', $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() ); } } if (!empty($mediaFiles = $request->getDataJson('media'))) { $collection = null; 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, $investment->id, $media->id, InvestmentObjectMapper::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() ); } } } /** * Api method to create a bill * * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return void * * @api * * @since 1.0.0 */ public function apiMediaAddToInvestmentObject(RequestAbstract $request, ResponseAbstract $response, mixed $data = null) : void { if (!empty($val = $this->validateMediaAddToInvestment($request))) { $response->data[$request->uri->__toString()] = new FormValidation($val); $response->header->status = RequestStatusCode::R_400; return; } /** @var \Modules\FleetManagement\Models\InvestmentObject $investment */ $investment = InvestmentObjectMapper::get()->where('id', (int) $request->getData('option'))->execute(); $path = $this->createInvestmentObjectDir($investment); $uploaded = []; if (!empty($uploadedFiles = $request->files)) { $uploaded = $this->app->moduleManager->get('Media')->uploadFiles( names: [], fileNames: [], files: $uploadedFiles, account: $request->header->account, basePath: __DIR__ . '/../../../Modules/Media/Files' . $path, virtualPath: $path, pathSettings: PathSettings::FILE_PATH, hasAccountRelation: false, readContent: (bool) ($request->getData('parse_content') ?? false) ); $collection = null; foreach ($uploaded as $media) { $this->createModelRelation( $request->header->account, $investment->id, $media->id, InvestmentObjectMapper::class, 'files', '', $request->getOrigin() ); if ($request->hasData('type')) { $this->createModelRelation( $request->header->account, $media->id, $request->getDataInt('type'), MediaMapper::class, 'types', '', $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() ); } } if (!empty($mediaFiles = $request->getDataJson('media'))) { foreach ($mediaFiles as $media) { $this->createModelRelation( $request->header->account, $investment->id, (int) $media, InvestmentObjectMapper::class, 'files', '', $request->getOrigin() ); } } $this->fillJsonResponse($request, $response, NotificationLevel::OK, 'Media', 'Media added to investment.', [ 'upload' => $uploaded, 'media' => $mediaFiles, ]); } /** * Method to validate bill creation from request * * @param RequestAbstract $request Request * * @return array * * @since 1.0.0 */ private function validateMediaAddToInvestment(RequestAbstract $request) : array { $val = []; if (($val['media'] = (!$request->hasData('media') && empty($request->files))) || ($val['investment'] = !$request->hasData('investment')) ) { return $val; } return []; } /** * Method to create investment from request. * * @param RequestAbstract $request Request * * @return BaseStringL11nType Returns the created investment from the request * * @since 1.0.0 */ public function createAmountTypeFromRequest(RequestAbstract $request) : BaseStringL11nType { $type = new BaseStringL11nType(); $type->title = $request->getDataString('name') ?? ''; $type->setL11n($request->getDataString('title') ?? '', $request->getDataString('language') ?? ISO639x1Enum::_EN); return $type; } /** * Validate investment create request * * @param RequestAbstract $request Request * * @return array Returns the validation array of the request * * @since 1.0.0 */ private function validateAmountTypeCreate(RequestAbstract $request) : array { $val = []; if (($val['name'] = !$request->hasData('name')) || ($val['title'] = !$request->hasData('title')) ) { return $val; } return []; } /** * Api method to create investment attribute l11n * * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return void * * @api * * @since 1.0.0 */ public function apiAmountTypeL11nCreate(RequestAbstract $request, ResponseAbstract $response, mixed $data = null) : void { if (!empty($val = $this->validateAmountTypeL11nCreate($request))) { $response->data['amount_type_l11n_create'] = new FormValidation($val); $response->header->status = RequestStatusCode::R_400; return; } $typeL11n = $this->createAmountTypeL11nFromRequest($request); $this->createModel($request->header->account, $typeL11n, AmountTypeL11nMapper::class, 'amount_type_l11n', $request->getOrigin()); $this->fillJsonResponse($request, $response, NotificationLevel::OK, 'Localization', 'Localization successfully created', $typeL11n); } /** * Method to create investment attribute l11n from request. * * @param RequestAbstract $request Request * * @return BaseStringL11n * * @since 1.0.0 */ private function createAmountTypeL11nFromRequest(RequestAbstract $request) : BaseStringL11n { $typeL11n = new BaseStringL11n(); $typeL11n->ref = $request->getDataInt('type') ?? 0; $typeL11n->setLanguage( $request->getDataString('language') ?? $request->header->l11n->language ); $typeL11n->content = $request->getDataString('title') ?? ''; return $typeL11n; } /** * Validate investment attribute l11n create request * * @param RequestAbstract $request Request * * @return array * * @since 1.0.0 */ private function validateAmountTypeL11nCreate(RequestAbstract $request) : array { $val = []; if (($val['title'] = !$request->hasData('title')) || ($val['type'] = !$request->hasData('type')) ) { return $val; } return []; } /** * Api method to create notes * * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return void * * @api * * @since 1.0.0 */ public function apiNoteCreate(RequestAbstract $request, ResponseAbstract $response, mixed $data = null) : void { if (!empty($val = $this->validateNoteCreate($request))) { $response->data['investment_note_create'] = new FormValidation($val); $response->header->status = RequestStatusCode::R_400; return; } $request->setData('virtualpath', '/Modules/FleetManagement/Investment/' . $request->getData('id'), true); $this->app->moduleManager->get('Editor', 'Api')->apiEditorCreate($request, $response, $data); if ($response->header->status !== RequestStatusCode::R_200) { return; } $responseData = $response->get($request->uri->__toString()); if (!\is_array($responseData)) { return; } $model = $responseData['response']; $this->createModelRelation($request->header->account, (int) $request->getData('id'), $model->id, InvestmentMapper::class, 'notes', '', $request->getOrigin()); } /** * Validate item note create request * * @param RequestAbstract $request Request * * @return array * * @since 1.0.0 */ private function validateNoteCreate(RequestAbstract $request) : array { $val = []; if (($val['id'] = !$request->hasData('id')) ) { return $val; } return []; } /** * Api method to update note * * @param RequestAbstract $request Request * @param ResponseAbstract $response Response * @param mixed $data Generic data * * @return void * * @api * * @since 1.0.0 */ public function apiNoteEdit(RequestAbstract $request, ResponseAbstract $response, mixed $data = null) : void { $this->app->moduleManager->get('Editor', 'Api')->apiEditorUpdate($request, $response, $data); if ($response->header->status !== RequestStatusCode::R_200) { return; } $responseData = $response->get($request->uri->__toString()); if (!\is_array($responseData)) { return; } } }