CompanyController.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. <?php
  2. /**
  3. * Created by IntelliJ IDEA.
  4. * User: kelyliang
  5. * Date: 2024/3/20
  6. * Time: 下午 02:32
  7. */
  8. namespace App\Http\Controllers\API;
  9. use App\Mail\CompanyAction;
  10. use App\Models\CaptchaMail;
  11. use App\Models\Enums\FileObjectType;
  12. use App\Models\File;
  13. use App\Models\Role;
  14. use App\Models\Scopes\CompanyScope;
  15. use App\Services\Notification\ActionEmail\ActionEmailService;
  16. use Illuminate\Mail\Mailable;
  17. use Illuminate\Support\Facades\DB;
  18. use Illuminate\Support\Facades\Hash;
  19. use Illuminate\Support\Facades\Mail;
  20. use function App\Http\Controllers\badRequest;
  21. use App\Http\Controllers\Controller;
  22. use App\Http\Requests\API\Company\ActionRequest;
  23. use App\Http\Requests\API\Company\CreateOrUpdateRequest;
  24. use App\Http\Resources\API\CompanyResource;
  25. use App\Models\Company;
  26. use App\Models\User;
  27. use App\Services\File\FileAssociationService;
  28. use Carbon\Carbon;
  29. use Illuminate\Http\Request;
  30. use Illuminate\Support\Facades\Auth;
  31. use App\Models\Enums\CompanyReviewStatus;
  32. class CompanyController extends Controller
  33. {
  34. public function index(Request $request)
  35. {
  36. $pageSize=$request->get('page_size') ?? 0;
  37. if(Auth::user()->super_admin){
  38. $company=Company::query()->filter($request->all())->paginate($pageSize);
  39. make_display_id($company,$pageSize);
  40. return CompanyResource::collection($company);
  41. }else{
  42. $companyId=Auth::user()->company->id;
  43. $company=Company::query()->filter($request->all())->where('id',$companyId)->paginate($pageSize);
  44. make_display_id($company,$pageSize);
  45. return CompanyResource::collection($company);
  46. }
  47. }
  48. public function publicSearch(Request $request){
  49. $company=Company::query()->filter($request->all())->where('id',Auth::user()->company->id)->get();
  50. return CompanyResource::collection($company);
  51. }
  52. public function store(CreateOrUpdateRequest $request)
  53. {
  54. $company = new Company();
  55. $company->fill([
  56. ...$request->all(),
  57. 'review_status'=>CompanyReviewStatus::APPROVED,
  58. 'exp_date'=> $request->exp_date === null ? Carbon::now()->addYear()->toDateString():$request->exp_date,
  59. ]);
  60. $company->save();
  61. return $this->created();
  62. }
  63. public function show(string $id)
  64. {
  65. $companyId=Auth::user()->company->id;
  66. if(empty(Auth::user()->super_admin)){
  67. if($companyId!=$id){
  68. return $this->forbidden("You are not a user under this company");
  69. }
  70. }
  71. $field = Company::query()->findOrFail($id);
  72. return new CompanyResource($field);
  73. }
  74. public function update(Request $request,string $id){
  75. $company = Company::findOrFail($id);
  76. $company->email =$request->email;
  77. $company->exp_date =$request->exp_date;
  78. $company->save();
  79. return $this->noContent();
  80. }
  81. public function structure(Request $request)
  82. {
  83. if(Auth::user()->super_admin){
  84. $company=Company::query()->withoutGlobalScope(CompanyScope::class)->filter($request->all())->get();
  85. }else{
  86. $companyId=Auth::user()->company->id;
  87. $company=Company::query()->withoutGlobalScope(CompanyScope::class)->filter($request->all())->where('id',$companyId)->orWhere('parent',$companyId)->get();
  88. }
  89. return CompanyResource::collection($company);
  90. }
  91. public function destroy(string $id)
  92. {
  93. $company = Company::findOrFail($id);
  94. $company->delete();
  95. return $this->noContent();
  96. }
  97. //注册用户时注册公司
  98. public function registerCompany(FileAssociationService $service,CreateOrUpdateRequest $request)
  99. {
  100. $company = new Company();
  101. $company->fill([
  102. ...$request->all(),
  103. ]);
  104. $company->save();
  105. $this->filesAssociationCompany($request->get("file_ids", []), FileObjectType::COMPANY,$company->id);
  106. return $this->created();
  107. }
  108. public function filesAssociationCompany(array $fileIds, FileObjectType $fileObjectType,string $companyId){
  109. if (! $fileIds) {
  110. return;
  111. }
  112. foreach ($fileIds as $fileId){
  113. $file=File::query()
  114. ->where('object_type',$fileObjectType->value)
  115. ->whereNull("object_id")
  116. ->where('id',$fileId)
  117. ->first();
  118. $file->company_id=$companyId;
  119. $file->object_id =$companyId;
  120. $file->save();
  121. }
  122. }
  123. //公司审核
  124. public function action(ActionRequest $request){
  125. $company = Company::findOrFail($request->id);
  126. $status=$request->get('status');
  127. $expDate=$request->get('exp_date');
  128. $roleId=$request->get('role_id');
  129. $rejectReason=$request->get('reject_reason');
  130. $user = new User();
  131. //通过审核->改变公司状态->设置公司过期时间->最后生成默认账户
  132. DB::transaction(function () use($status,$expDate,$company,$user,$roleId,$rejectReason){
  133. if ($status == 1){
  134. //1.改变公司状态->设置公司过期时间
  135. $company->review_status=CompanyReviewStatus::APPROVED;
  136. $company->exp_date = $expDate === null ? Carbon::now()->addYear()->toDateString():$expDate;
  137. //2.生成默认账户
  138. $user->name='admin_'.$company->name;
  139. $user->email=$company->email;
  140. $user->username=$company->email;
  141. $user->company_id=$company->id;
  142. $user->password=Hash::make('admin@#123');
  143. $user->role_id=$roleId;
  144. //TODO 此处给的默认角色为硬编码,暂未设置默认角色为哪个
  145. $role = Role::query()->findOrFail($roleId);
  146. $user->syncRoles($role);
  147. // $user->role_id=6;
  148. // $user->syncRoles(6);
  149. $user->save();
  150. $company->save();
  151. Mail::to($company->email)->send(new CompanyAction($company,$user,$rejectReason??''));
  152. }else{
  153. $company->review_status=CompanyReviewStatus::REJECTED;
  154. $company->save();
  155. Mail::to($company->email)->send(new CompanyAction($company,$user,$rejectReason??''));
  156. $company->delete();
  157. }
  158. });
  159. return $this->noContent();
  160. }
  161. }