diff --git a/app/Http/Controllers/TaskController.php b/app/Http/Controllers/TaskController.php index 0b64615be59f..d5a3bee52c5d 100644 --- a/app/Http/Controllers/TaskController.php +++ b/app/Http/Controllers/TaskController.php @@ -21,12 +21,14 @@ use App\Http\Requests\Task\EditTaskRequest; use App\Http\Requests\Task\ShowTaskRequest; use App\Http\Requests\Task\StoreTaskRequest; use App\Http\Requests\Task\UpdateTaskRequest; +use App\Http\Requests\Task\UploadTaskRequest; use App\Models\Task; use App\Repositories\TaskRepository; use App\Transformers\TaskTransformer; use App\Utils\Ninja; use App\Utils\Traits\BulkOptions; use App\Utils\Traits\MakesHash; +use App\Utils\Traits\SavesDocuments; use App\Utils\Traits\Uploadable; use Illuminate\Http\Request; use Illuminate\Http\Response; @@ -40,6 +42,7 @@ class TaskController extends BaseController use MakesHash; use Uploadable; use BulkOptions; + use SavesDocuments; protected $entity_type = Task::class; @@ -506,4 +509,65 @@ class TaskController extends BaseController { //todo } + +/** + * Update the specified resource in storage. + * + * @param UploadTaskRequest $request + * @param Task $task + * @return Response + * + * + * + * @OA\Put( + * path="/api/v1/tasks/{id}/upload", + * operationId="uploadTask", + * tags={"tasks"}, + * summary="Uploads a document to a task", + * description="Handles the uploading of a document to a task", + * @OA\Parameter(ref="#/components/parameters/X-Api-Secret"), + * @OA\Parameter(ref="#/components/parameters/X-Api-Token"), + * @OA\Parameter(ref="#/components/parameters/X-Requested-With"), + * @OA\Parameter(ref="#/components/parameters/include"), + * @OA\Parameter( + * name="id", + * in="path", + * description="The Task Hashed ID", + * example="D2J234DFA", + * required=true, + * @OA\Schema( + * type="string", + * format="string", + * ), + * ), + * @OA\Response( + * response=200, + * description="Returns the Task object", + * @OA\Header(header="X-MINIMUM-CLIENT-VERSION", ref="#/components/headers/X-MINIMUM-CLIENT-VERSION"), + * @OA\Header(header="X-RateLimit-Remaining", ref="#/components/headers/X-RateLimit-Remaining"), + * @OA\Header(header="X-RateLimit-Limit", ref="#/components/headers/X-RateLimit-Limit"), + * @OA\JsonContent(ref="#/components/schemas/Task"), + * ), + * @OA\Response( + * response=422, + * description="Validation error", + * @OA\JsonContent(ref="#/components/schemas/ValidationError"), + * + * ), + * @OA\Response( + * response="default", + * description="Unexpected Error", + * @OA\JsonContent(ref="#/components/schemas/Error"), + * ), + * ) + */ + public function upload(UploadTaskRequest $request, Task $task) + { + + if ($request->has('documents')) + $this->saveDocuments($request->file('documents'), $task); + + return $this->itemResponse($task->fresh()); + + } } diff --git a/app/Http/Controllers/VendorController.php b/app/Http/Controllers/VendorController.php index f9ce40c6cb92..04394ac0c861 100644 --- a/app/Http/Controllers/VendorController.php +++ b/app/Http/Controllers/VendorController.php @@ -21,12 +21,14 @@ use App\Http\Requests\Vendor\EditVendorRequest; use App\Http\Requests\Vendor\ShowVendorRequest; use App\Http\Requests\Vendor\StoreVendorRequest; use App\Http\Requests\Vendor\UpdateVendorRequest; +use App\Http\Requests\Vendor\UploadVendorRequest; use App\Models\Vendor; use App\Repositories\VendorRepository; use App\Transformers\VendorTransformer; use App\Utils\Ninja; use App\Utils\Traits\BulkOptions; use App\Utils\Traits\MakesHash; +use App\Utils\Traits\SavesDocuments; use App\Utils\Traits\Uploadable; use Illuminate\Http\Request; use Illuminate\Http\Response; @@ -39,6 +41,7 @@ class VendorController extends BaseController use MakesHash; use Uploadable; use BulkOptions; + use SavesDocuments; protected $entity_type = Vendor::class; @@ -511,4 +514,65 @@ class VendorController extends BaseController { //todo } + + /** + * Update the specified resource in storage. + * + * @param UploadVendorRequest $request + * @param Vendor $vendor + * @return Response + * + * + * + * @OA\Put( + * path="/api/v1/vendors/{id}/upload", + * operationId="uploadVendor", + * tags={"vendors"}, + * summary="Uploads a document to a vendor", + * description="Handles the uploading of a document to a vendor", + * @OA\Parameter(ref="#/components/parameters/X-Api-Secret"), + * @OA\Parameter(ref="#/components/parameters/X-Api-Token"), + * @OA\Parameter(ref="#/components/parameters/X-Requested-With"), + * @OA\Parameter(ref="#/components/parameters/include"), + * @OA\Parameter( + * name="id", + * in="path", + * description="The Vendor Hashed ID", + * example="D2J234DFA", + * required=true, + * @OA\Schema( + * type="string", + * format="string", + * ), + * ), + * @OA\Response( + * response=200, + * description="Returns the Vendor object", + * @OA\Header(header="X-MINIMUM-CLIENT-VERSION", ref="#/components/headers/X-MINIMUM-CLIENT-VERSION"), + * @OA\Header(header="X-RateLimit-Remaining", ref="#/components/headers/X-RateLimit-Remaining"), + * @OA\Header(header="X-RateLimit-Limit", ref="#/components/headers/X-RateLimit-Limit"), + * @OA\JsonContent(ref="#/components/schemas/Vendor"), + * ), + * @OA\Response( + * response=422, + * description="Validation error", + * @OA\JsonContent(ref="#/components/schemas/ValidationError"), + * + * ), + * @OA\Response( + * response="default", + * description="Unexpected Error", + * @OA\JsonContent(ref="#/components/schemas/Error"), + * ), + * ) + */ + public function upload(UploadVendorRequest $request, Vendor $vendor) + { + + if ($request->has('documents')) + $this->saveDocuments($request->file('documents'), $vendor); + + return $this->itemResponse($vendor->fresh()); + + } } diff --git a/app/Http/Requests/Task/UploadTaskRequest.php b/app/Http/Requests/Task/UploadTaskRequest.php new file mode 100644 index 000000000000..58b6abd97ea3 --- /dev/null +++ b/app/Http/Requests/Task/UploadTaskRequest.php @@ -0,0 +1,39 @@ +user()->can('edit', $this->task); + } + + public function rules() + { + + $rules = []; + + if($this->input('documents')) + $rules['documents'] = 'file|mimes:html,csv,png,ai,svg,jpeg,tiff,pdf,gif,psd,txt,doc,xls,ppt,xlsx,docx,pptx|max:2000000'; + + return $rules; + + } +} diff --git a/app/Http/Requests/Vendor/UploadVendorRequest.php b/app/Http/Requests/Vendor/UploadVendorRequest.php new file mode 100644 index 000000000000..8aceb379db23 --- /dev/null +++ b/app/Http/Requests/Vendor/UploadVendorRequest.php @@ -0,0 +1,39 @@ +user()->can('edit', $this->vendor); + } + + public function rules() + { + + $rules = []; + + if($this->input('documents')) + $rules['documents'] = 'file|mimes:html,csv,png,ai,svg,jpeg,tiff,pdf,gif,psd,txt,doc,xls,ppt,xlsx,docx,pptx|max:2000000'; + + return $rules; + + } +} diff --git a/routes/api.php b/routes/api.php index 653244096ed3..10e5349c3b82 100644 --- a/routes/api.php +++ b/routes/api.php @@ -28,94 +28,126 @@ Route::group(['middleware' => ['api_db', 'token_auth', 'locale'], 'prefix' => 'a Route::get('health_check', 'PingController@health')->name('health_check'); Route::get('activities', 'ActivityController@index'); - Route::get('activities/download_entity/{activity}', 'ActivityController@downloadHistoricalEntity'); + Route::post('claim_license', 'LicenseController@index')->name('license.index'); + Route::resource('clients', 'ClientController'); // name = (clients. index / create / show / update / destroy / edit Route::put('clients/{client}/upload', 'ClientController@upload')->name('clients.upload'); - Route::post('clients/bulk', 'ClientController@bulk')->name('clients.bulk'); - Route::resource('invoices', 'InvoiceController'); // name = (invoices. index / create / show / update / destroy / edit + Route::resource('client_statement', 'ClientStatementController@statement'); // name = (client_statement. index / create / show / update / destroy / edit - Route::get('invoices/{invoice}/delivery_note', 'InvoiceController@deliveryNote')->name('invoices.delivery_note'); + Route::post('companies/purge/{company}', 'MigrationController@purgeCompany')->middleware('password_protected'); + Route::post('companies/purge_save_settings/{company}', 'MigrationController@purgeCompanySaveSettings')->middleware('password_protected'); + Route::resource('companies', 'CompanyController'); // name = (companies. index / create / show / update / destroy / edit + Route::put('companies/{company}/upload', 'CompanyController@upload'); - Route::get('invoices/{invoice}/{action}', 'InvoiceController@action')->name('invoices.action'); - Route::put('invoices/{invoice}/upload', 'InvoiceController@upload')->name('invoices.upload'); + Route::get('company_ledger', 'CompanyLedgerController@index')->name('company_ledger.index'); - Route::get('invoice/{invitation_key}/download', 'InvoiceController@downloadPdf')->name('invoices.downloadPdf'); + Route::resource('company_gateways', 'CompanyGatewayController'); + Route::post('company_gateways/bulk', 'CompanyGatewayController@bulk')->name('company_gateways.bulk'); - Route::post('invoices/bulk', 'InvoiceController@bulk')->name('invoices.bulk'); + Route::put('company_users/{user}', 'CompanyUserController@update'); Route::resource('credits', 'CreditController'); // name = (credits. index / create / show / update / destroy / edit Route::put('credits/{credit}/upload', 'CreditController@upload')->name('credits.upload'); - Route::get('credits/{credit}/{action}', 'CreditController@action')->name('credits.action'); - Route::post('credits/bulk', 'CreditController@bulk')->name('credits.bulk'); - Route::resource('products', 'ProductController'); // name = (products. index / create / show / update / destroy / edit + Route::resource('designs', 'DesignController'); // name = (payments. index / create / show / update / destroy / edit + Route::post('designs/bulk', 'DesignController@bulk')->name('designs.bulk'); - Route::post('products/bulk', 'ProductController@bulk')->name('products.bulk'); - - Route::resource('quotes', 'QuoteController'); // name = (quotes. index / create / show / update / destroy / edit - - Route::get('quotes/{quote}/{action}', 'QuoteController@action')->name('quotes.action'); - - Route::post('quotes/bulk', 'QuoteController@bulk')->name('quotes.bulk'); - - Route::resource('recurring_invoices', 'RecurringInvoiceController'); // name = (recurring_invoices. index / create / show / update / destroy / edit - - Route::post('recurring_invoices/bulk', 'RecurringInvoiceController@bulk')->name('recurring_invoices.bulk'); - - Route::resource('recurring_quotes', 'RecurringQuoteController'); // name = (recurring_invoices. index / create / show / update / destroy / edit - - Route::post('recurring_quotes/bulk', 'RecurringQuoteController@bulk')->name('recurring_quotes.bulk'); - - Route::resource('expenses', 'ExpenseController'); // name = (expenses. index / create / show / update / destroy / edit - Route::put('expenses/{expense}/upload', 'ExpenseController@upload'); - - Route::post('expenses/bulk', 'ExpenseController@bulk')->name('expenses.bulk'); - - Route::resource('expense_categories', 'ExpenseCategoryController'); // name = (expense_categories. index / create / show / update / destroy / edit - - Route::post('expense_categories/bulk', 'ExpenseCategoryController@bulk')->name('expense_categories.bulk'); - - Route::resource('tasks', 'TaskController'); // name = (tasks. index / create / show / update / destroy / edit - - Route::post('tasks/bulk', 'TaskController@bulk')->name('tasks.bulk'); - - Route::resource('task_statuses', 'TaskStatusController'); // name = (task_statuses. index / create / show / update / destroy / edit - - Route::post('task_statuses/bulk', 'TaskStatusController@bulk')->name('task_statuses.bulk'); - - Route::resource('projects', 'ProjectController'); // name = (projects. index / create / show / update / destroy / edit - Route::post('projects/bulk', 'ProjectController@bulk')->name('projects.bulk'); - - Route::resource('vendors', 'VendorController'); // name = (vendors. index / create / show / update / destroy / edit - - Route::post('vendors/bulk', 'VendorController@bulk')->name('vendors.bulk'); Route::resource('documents', 'DocumentController'); // name = (documents. index / create / show / update / destroy / edit Route::get('documents/{document}/download', 'DocumentController@download')->name('documents.download'); Route::post('documents/bulk', 'DocumentController@bulk')->name('documents.bulk'); - Route::resource('client_statement', 'ClientStatementController@statement'); // name = (client_statement. index / create / show / update / destroy / edit + Route::post('emails', 'EmailController@send')->name('email.send'); - Route::resource('payment_terms', 'PaymentTermController'); // name = (payments. index / create / show / update / destroy / edit + Route::resource('expenses', 'ExpenseController'); // name = (expenses. index / create / show / update / destroy / edit + Route::put('expenses/{expense}/upload', 'ExpenseController@upload'); + Route::post('expenses/bulk', 'ExpenseController@bulk')->name('expenses.bulk'); - Route::post('payment_terms/bulk', 'PaymentTermController@bulk')->name('payment_terms.bulk'); + Route::resource('expense_categories', 'ExpenseCategoryController'); // name = (expense_categories. index / create / show / update / destroy / edit + Route::post('expense_categories/bulk', 'ExpenseCategoryController@bulk')->name('expense_categories.bulk'); - Route::resource('payments', 'PaymentController'); // name = (payments. index / create / show / update / destroy / edit + Route::resource('group_settings', 'GroupSettingController'); + Route::post('group_settings/bulk', 'GroupSettingController@bulk'); - Route::post('payments/refund', 'PaymentController@refund')->name('payments.refund'); + Route::post('import', 'ImportController@import')->name('import.import'); + Route::post('preimport', 'ImportController@preimport')->name('import.preimport'); - Route::post('payments/bulk', 'PaymentController@bulk')->name('payments.bulk'); + Route::resource('invoices', 'InvoiceController'); // name = (invoices. index / create / show / update / destroy / edit + Route::get('invoices/{invoice}/delivery_note', 'InvoiceController@deliveryNote')->name('invoices.delivery_note'); + Route::get('invoices/{invoice}/{action}', 'InvoiceController@action')->name('invoices.action'); + Route::put('invoices/{invoice}/upload', 'InvoiceController@upload')->name('invoices.upload'); + Route::get('invoice/{invitation_key}/download', 'InvoiceController@downloadPdf')->name('invoices.downloadPdf'); + Route::post('invoices/bulk', 'InvoiceController@bulk')->name('invoices.bulk'); Route::post('migrate', 'MigrationController@index')->name('migrate.start'); - Route::resource('designs', 'DesignController'); // name = (payments. index / create / show / update / destroy / edit - Route::post('designs/bulk', 'DesignController@bulk')->name('designs.bulk'); + Route::post('migration/purge/{company}', 'MigrationController@purgeCompany')->middleware('password_protected'); + Route::post('migration/purge_save_settings/{company}', 'MigrationController@purgeCompanySaveSettings')->middleware('password_protected'); + Route::post('migration/start', 'MigrationController@startMigration'); + + Route::resource('payments', 'PaymentController'); // name = (payments. index / create / show / update / destroy / edit + Route::post('payments/refund', 'PaymentController@refund')->name('payments.refund'); + Route::post('payments/bulk', 'PaymentController@bulk')->name('payments.bulk'); + Route::put('payments/{payment}/upload', 'PaymentController@upload'); + + Route::resource('payment_terms', 'PaymentTermController'); // name = (payments. index / create / show / update / destroy / edit + Route::post('payment_terms/bulk', 'PaymentTermController@bulk')->name('payment_terms.bulk'); + + Route::post('preview', 'PreviewController@show')->name('preview.show'); + + Route::resource('products', 'ProductController'); // name = (products. index / create / show / update / destroy / edit + Route::post('products/bulk', 'ProductController@bulk')->name('products.bulk'); + Route::put('products/{product}/upload', 'ProductController@upload'); + + Route::resource('projects', 'ProjectController'); // name = (projects. index / create / show / update / destroy / edit + Route::post('projects/bulk', 'ProjectController@bulk')->name('projects.bulk'); + + Route::resource('quotes', 'QuoteController'); // name = (quotes. index / create / show / update / destroy / edit + Route::get('quotes/{quote}/{action}', 'QuoteController@action')->name('quotes.action'); + Route::post('quotes/bulk', 'QuoteController@bulk')->name('quotes.bulk'); + Route::put('quotes/{quote}/upload', 'QuoteController@upload'); + + Route::resource('recurring_invoices', 'RecurringInvoiceController'); // name = (recurring_invoices. index / create / show / update / destroy / edit + Route::post('recurring_invoices/bulk', 'RecurringInvoiceController@bulk')->name('recurring_invoices.bulk'); + Route::put('recurring_invoices/{recurring_invoice}/upload', 'RecurringInvoiceController@upload'); + Route::resource('recurring_quotes', 'RecurringQuoteController'); // name = (recurring_invoices. index / create / show / update / destroy / edit + + Route::post('recurring_quotes/bulk', 'RecurringQuoteController@bulk')->name('recurring_quotes.bulk'); + + Route::post('refresh', 'Auth\LoginController@refresh'); + + Route::get('scheduler', 'SchedulerController@index'); + Route::post('support/messages/send', 'Support\Messages\SendingController'); + + Route::post('self-update', 'SelfUpdateController@update')->middleware('password_protected'); + Route::post('self-update/check_version', 'SelfUpdateController@checkVersion'); + + Route::resource('system_logs', 'SystemLogController'); + + Route::resource('tasks', 'TaskController'); // name = (tasks. index / create / show / update / destroy / edit + Route::post('tasks/bulk', 'TaskController@bulk')->name('tasks.bulk'); + Route::put('tasks/{task}/upload', 'TaskController@upload'); + + Route::resource('task_statuses', 'TaskStatusController'); // name = (task_statuses. index / create / show / update / destroy / edit + Route::post('task_statuses/bulk', 'TaskStatusController@bulk')->name('task_statuses.bulk'); + + Route::resource('tax_rates', 'TaxRateController'); // name = (tax_rates. index / create / show / update / destroy / edit + Route::post('tax_rates/bulk', 'TaxRateController@bulk')->name('tax_rates.bulk'); + + Route::post('templates', 'TemplateController@show')->name('templates.show'); + + Route::resource('tokens', 'TokenController')->middleware('password_protected'); // name = (tokens. index / create / show / update / destroy / edit + Route::post('tokens/bulk', 'TokenController@bulk')->name('tokens.bulk')->middleware('password_protected'); + + Route::resource('vendors', 'VendorController'); // name = (vendors. index / create / show / update / destroy / edit + Route::post('vendors/bulk', 'VendorController@bulk')->name('vendors.bulk'); + Route::put('vendors/{vendor}/upload', 'VendorController@upload'); Route::get('users', 'UserController@index'); Route::put('users/{user}', 'UserController@update')->middleware('password_protected'); @@ -124,68 +156,14 @@ Route::group(['middleware' => ['api_db', 'token_auth', 'locale'], 'prefix' => 'a Route::delete('users/{user}/detach_from_company', 'UserController@detach')->middleware('password_protected'); Route::post('users/bulk', 'UserController@bulk')->name('users.bulk')->middleware('password_protected'); - Route::post('migration/purge/{company}', 'MigrationController@purgeCompany')->middleware('password_protected'); - Route::post('migration/purge_save_settings/{company}', 'MigrationController@purgeCompanySaveSettings')->middleware('password_protected'); - Route::post('companies/purge/{company}', 'MigrationController@purgeCompany')->middleware('password_protected'); - Route::post('companies/purge_save_settings/{company}', 'MigrationController@purgeCompanySaveSettings')->middleware('password_protected'); - - Route::post('migration/start', 'MigrationController@startMigration'); - - Route::resource('companies', 'CompanyController'); // name = (companies. index / create / show / update / destroy / edit - Route::put('companies/{company}/upload', 'CompanyController@upload'); - - Route::resource('tokens', 'TokenController')->middleware('password_protected'); // name = (tokens. index / create / show / update / destroy / edit - Route::post('tokens/bulk', 'TokenController@bulk')->name('tokens.bulk')->middleware('password_protected'); - - Route::resource('company_gateways', 'CompanyGatewayController'); - - Route::post('company_gateways/bulk', 'CompanyGatewayController@bulk')->name('company_gateways.bulk'); - - Route::put('company_users/{user}', 'CompanyUserController@update'); - - Route::resource('group_settings', 'GroupSettingController'); - Route::post('group_settings/bulk', 'GroupSettingController@bulk'); - - Route::resource('tax_rates', 'TaxRateController'); // name = (tax_rates. index / create / show / update / destroy / edit - Route::post('tax_rates/bulk', 'TaxRateController@bulk')->name('tax_rates.bulk'); - - Route::post('refresh', 'Auth\LoginController@refresh'); - - Route::post('templates', 'TemplateController@show')->name('templates.show'); - - Route::post('preview', 'PreviewController@show')->name('preview.show'); - - Route::post('self-update', 'SelfUpdateController@update')->middleware('password_protected'); - - Route::post('self-update/check_version', 'SelfUpdateController@checkVersion'); - - Route::post('claim_license', 'LicenseController@index')->name('license.index'); - - Route::post('emails', 'EmailController@send')->name('email.send'); + Route::resource('webhooks', 'WebhookController'); + Route::post('webhooks/bulk', 'WebhookController@bulk')->name('webhooks.bulk'); /*Subscription and Webhook routes */ // Route::post('hooks', 'SubscriptionController@subscribe')->name('hooks.subscribe'); // Route::delete('hooks/{subscription_id}', 'SubscriptionController@unsubscribe')->name('hooks.unsubscribe'); - Route::resource('webhooks', 'WebhookController'); - Route::resource('system_logs', 'SystemLogController'); - Route::post('webhooks/bulk', 'WebhookController@bulk')->name('webhooks.bulk'); - - /*Company Ledger */ - Route::get('company_ledger', 'CompanyLedgerController@index')->name('company_ledger.index'); - - Route::post('preimport', 'ImportController@preimport')->name('import.preimport'); - Route::post('import', 'ImportController@import')->name('import.import'); - - /* - Route::resource('tasks', 'TaskController'); // name = (tasks. index / create / show / update / destroy / edit - - Route::post('tasks/bulk', 'TaskController@bulk')->name('tasks.bulk'); - - */ - Route::get('scheduler', 'SchedulerController@index'); - Route::post('support/messages/send', 'Support\Messages\SendingController'); }); Route::match(['get', 'post'], 'payment_webhook/{company_key}/{company_gateway_id}', 'PaymentWebhookController')