CompanyController.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  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\Services\Notification\ActionEmail\ActionEmailService;
  13. use Illuminate\Mail\Mailable;
  14. use Illuminate\Support\Facades\DB;
  15. use Illuminate\Support\Facades\Hash;
  16. use Illuminate\Support\Facades\Mail;
  17. use function App\Http\Controllers\badRequest;
  18. use App\Http\Controllers\Controller;
  19. use App\Http\Requests\API\Company\ActionRequest;
  20. use App\Http\Requests\API\Company\CreateOrUpdateRequest;
  21. use App\Http\Resources\API\CompanyResource;
  22. use App\Models\Company;
  23. use App\Models\User;
  24. use App\Services\File\FileAssociationService;
  25. use Carbon\Carbon;
  26. use Illuminate\Http\Request;
  27. use Illuminate\Support\Facades\Auth;
  28. use App\Models\Enums\CompanyReviewStatus;
  29. class CompanyController extends Controller
  30. {
  31. public function index(Request $request)
  32. {
  33. if(Auth::user()->super_admin){
  34. $company=Company::query()->filter($request->all())->get();
  35. return CompanyResource::collection($company);
  36. }else{
  37. $company=Auth::user()->company;
  38. return new CompanyResource($company);
  39. }
  40. }
  41. public function store(CreateOrUpdateRequest $request)
  42. {
  43. $company = new Company();
  44. $company->fill([
  45. ...$request->all(),
  46. ]);
  47. $company->save();
  48. return $this->created();
  49. }
  50. public function show(string $id)
  51. {
  52. $companyId=Auth::user()->company->id;
  53. if(empty(Auth::user()->super_admin)){
  54. if($companyId!=$id){
  55. return $this->forbidden("You are not a user under this company");
  56. }
  57. }
  58. $field = Company::query()->findOrFail($id);
  59. return new CompanyResource($field);
  60. }
  61. public function update(Request $request,string $id){
  62. $company = Company::findOrFail($id);
  63. $company->email =$request->email;
  64. $company->save();
  65. return $this->noContent();
  66. }
  67. public function destroy(string $id)
  68. {
  69. $company = Company::findOrFail($id);
  70. $company->delete();
  71. return $this->noContent();
  72. }
  73. //注册用户时注册公司
  74. public function registerCompany(FileAssociationService $service,CreateOrUpdateRequest $request)
  75. {
  76. $company = new Company();
  77. $service->check(
  78. $request->get("file_ids",[]),
  79. FileObjectType::COMPANY,
  80. $request->get("file_uuid"),
  81. );
  82. $company->fill([
  83. ...$request->all(),
  84. ]);
  85. $company->save();
  86. $service->association($company->id);
  87. return $this->created();
  88. }
  89. //公司审核
  90. public function action(ActionRequest $request){
  91. $company = Company::findOrFail($request->id);
  92. $status=$request->get('status');
  93. $expDate=$request->get('exp_date');
  94. $roleId=$request->get('role_id');
  95. $user = new User();
  96. //通过审核->改变公司状态->设置公司过期时间->最后生成默认账户
  97. DB::transaction(function () use($status,$expDate,$company,$user,$roleId){
  98. if ($status == 1){
  99. //1.改变公司状态->设置公司过期时间
  100. $company->review_status=CompanyReviewStatus::APPROVED;
  101. $company->exp_date = $expDate === null ? Carbon::now()->addYear()->toDateString():$expDate;
  102. //2.生成默认账户
  103. $user->name='admin_'.$company->name;
  104. $user->email=$company->email;
  105. $user->username=$company->email;
  106. $user->company_id=$company->id;
  107. $user->password=Hash::make('admin@#123');
  108. //TODO 此处给的默认角色为硬编码,暂未设置默认角色为哪个
  109. $role = Role::query()->findOrFail($roleId);
  110. $user->syncRoles($role);
  111. // $user->role_id=6;
  112. // $user->syncRoles(6);
  113. $user->save();
  114. }else{
  115. $company->review_status=CompanyReviewStatus::REJECTED;
  116. }
  117. //公司保存
  118. $company->save();
  119. });
  120. //发送邮件到公司账户
  121. Mail::to($company->email)->send(new CompanyAction($company,$user));
  122. return $this->noContent();
  123. }
  124. }