mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-14 07:02:34 +01:00
180 lines
5.0 KiB
PHP
180 lines
5.0 KiB
PHP
<?php
|
|
/**
|
|
* Invoice Ninja (https://invoiceninja.com).
|
|
*
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
*
|
|
* @copyright Copyright (c) 2024. Invoice Ninja LLC (https://invoiceninja.com)
|
|
*
|
|
* @license https://www.elastic.co/licensing/elastic-license
|
|
*/
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Http\Requests\CompanyUser\UpdateCompanyUserPreferencesRequest;
|
|
use App\Http\Requests\CompanyUser\UpdateCompanyUserRequest;
|
|
use App\Models\CompanyUser;
|
|
use App\Models\User;
|
|
use App\Transformers\CompanyUserTransformer;
|
|
use App\Transformers\UserTransformer;
|
|
use Illuminate\Database\Eloquent\ModelNotFoundException;
|
|
use Illuminate\Http\Response;
|
|
|
|
class CompanyUserController extends BaseController
|
|
{
|
|
protected $entity_type = CompanyUser::class;
|
|
|
|
protected $entity_transformer = CompanyUserTransformer::class;
|
|
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
}
|
|
|
|
/**
|
|
* Display a listing of the resource.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function index()
|
|
{
|
|
}
|
|
|
|
/**
|
|
* Show the form for creating a new resource.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function create()
|
|
{
|
|
}
|
|
|
|
public function store()
|
|
{
|
|
}
|
|
|
|
/**
|
|
* Display the specified resource.
|
|
*
|
|
* @param int $id
|
|
* @return void
|
|
*/
|
|
public function show($id)
|
|
{
|
|
//
|
|
}
|
|
|
|
/**
|
|
* Show the form for editing the specified resource.
|
|
*
|
|
* @param int $id
|
|
* @return void
|
|
*/
|
|
public function edit($id)
|
|
{
|
|
//
|
|
}
|
|
|
|
/**
|
|
* Store a newly created resource in storage.
|
|
*
|
|
*
|
|
* @OA\Post(
|
|
* path="/api/v1/company_users",
|
|
* operationId="updateCompanyUser",
|
|
* tags={"company_user"},
|
|
* summary="Update a company user record",
|
|
* description="Attempts to update a company user record. A company user can modify only their settings fields. Full access for Admin users",
|
|
* @OA\Parameter(ref="#/components/parameters/X-Requested-With"),
|
|
* @OA\Response(
|
|
* response=200,
|
|
* description="The Company User response",
|
|
* @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/CompanyUser"),
|
|
* ),
|
|
* @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"),
|
|
* ),
|
|
* )
|
|
* @param UpdateCompanyUserRequest $request
|
|
* @param User $user
|
|
* @return Response|mixed|void
|
|
*/
|
|
public function update(UpdateCompanyUserRequest $request, User $user)
|
|
{
|
|
/** @var \App\Models\User $auth_user */
|
|
$auth_user = auth()->user();
|
|
$company = $auth_user->company();
|
|
|
|
$company_user = CompanyUser::query()->where('user_id', $user->id)->where('company_id', $company->id)->first();
|
|
|
|
if (! $company_user) {
|
|
throw new ModelNotFoundException(ctrans('texts.company_user_not_found'));
|
|
|
|
return;
|
|
}
|
|
|
|
if ($auth_user->isAdmin()) {
|
|
$company_user->fill($request->input('company_user'));
|
|
} else {
|
|
$company_user->settings = $request->input('company_user')['settings'];
|
|
$company_user->notifications = $request->input('company_user')['notifications'];
|
|
|
|
if(isset($request->input('company_user')['react_settings'])) {
|
|
$company_user->react_settings = $request->input('company_user')['react_settings'];
|
|
}
|
|
|
|
}
|
|
|
|
$company_user->save();
|
|
|
|
return $this->itemResponse($company_user->fresh());
|
|
}
|
|
|
|
public function updatePreferences(UpdateCompanyUserPreferencesRequest $request, User $user)
|
|
{
|
|
/** @var \App\Models\User $auth_user */
|
|
$auth_user = auth()->user();
|
|
$company = $auth_user->company();
|
|
|
|
$company = $auth_user->company();
|
|
|
|
$company_user = CompanyUser::whereUserId($user->id)->whereCompanyId($company->id)->first();
|
|
|
|
if (! $company_user) {
|
|
throw new ModelNotFoundException(ctrans('texts.company_user_not_found'));
|
|
return;
|
|
}
|
|
|
|
$this->entity_type = User::class;
|
|
|
|
$this->entity_transformer = UserTransformer::class;
|
|
|
|
$company_user->react_settings = $request->react_settings;
|
|
$company_user->save();
|
|
|
|
return $this->itemResponse($user->fresh());
|
|
}
|
|
|
|
|
|
/**
|
|
* Remove the specified resource from storage.
|
|
*
|
|
* @param int $id
|
|
* @return void
|
|
*/
|
|
public function destroy($id)
|
|
{
|
|
//
|
|
}
|
|
}
|