mirror of
https://github.com/crater-invoice/crater.git
synced 2025-10-27 11:41:09 -04:00
86 lines
2.4 KiB
PHP
86 lines
2.4 KiB
PHP
<?php
|
|
|
|
namespace Crater\Http\Controllers\V1\Admin\Company;
|
|
|
|
use Crater\Http\Controllers\Controller;
|
|
use Crater\Http\Requests\CompaniesRequest;
|
|
use Crater\Http\Resources\CompanyResource;
|
|
use Crater\Models\Company;
|
|
use Crater\Models\User;
|
|
use Illuminate\Http\Request;
|
|
use Silber\Bouncer\BouncerFacade;
|
|
use Vinkla\Hashids\Facades\Hashids;
|
|
|
|
class CompaniesController extends Controller
|
|
{
|
|
public function store(CompaniesRequest $request)
|
|
{
|
|
$this->authorize('create company');
|
|
|
|
$user = $request->user();
|
|
|
|
$company = Company::create($request->getCompanyPayload());
|
|
$company->unique_hash = Hashids::connection(Company::class)->encode($company->id);
|
|
$company->save();
|
|
$company->setupDefaultData();
|
|
$user->companies()->attach($company->id);
|
|
$user->assign('super admin');
|
|
|
|
if ($request->address) {
|
|
$company->address()->create($request->address);
|
|
}
|
|
|
|
return new CompanyResource($company);
|
|
}
|
|
|
|
public function destroy(Request $request)
|
|
{
|
|
$company = Company::find($request->header('company'));
|
|
|
|
$this->authorize('delete company', $company);
|
|
|
|
$user = $request->user();
|
|
|
|
if ($request->name !== $company->name) {
|
|
return respondJson('company_name_must_match_with_given_name', 'Company name must match with given name');
|
|
}
|
|
|
|
if ($user->loadCount('companies')->companies_count <= 1) {
|
|
return respondJson('You_cannot_delete_all_companies', 'You cannot delete all companies');
|
|
}
|
|
|
|
$company->deleteCompany($user);
|
|
|
|
return response()->json([
|
|
'success' => true
|
|
]);
|
|
}
|
|
|
|
public function transferOwnership(Request $request, User $user)
|
|
{
|
|
$company = Company::find($request->header('company'));
|
|
$this->authorize('transfer company ownership', $company);
|
|
|
|
if ($user->hasCompany($company->id)) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => 'User does not belongs to this company.'
|
|
]);
|
|
}
|
|
|
|
$company->update(['owner_id' => $user->id]);
|
|
BouncerFacade::sync($user)->roles(['super admin']);
|
|
|
|
return response()->json([
|
|
'success' => true
|
|
]);
|
|
}
|
|
|
|
public function getUserCompanies(Request $request)
|
|
{
|
|
$companies = $request->user()->companies;
|
|
|
|
return CompanyResource::collection($companies);
|
|
}
|
|
}
|