CertController.php 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\Admin\CertRequest;
  5. use App\Models\NodeCertificate;
  6. use Exception;
  7. use Illuminate\Http\JsonResponse;
  8. use Illuminate\Http\RedirectResponse;
  9. use Log;
  10. class CertController extends Controller
  11. {
  12. public function index()
  13. {
  14. $certs = NodeCertificate::orderBy('id')->paginate()->appends(request('page'));
  15. foreach ($certs as $cert) {
  16. if ($cert->pem) {
  17. $certInfo = openssl_x509_parse($cert->pem);
  18. if ($certInfo) {
  19. $cert->issuer = $certInfo['issuer']['O'] ?? null;
  20. $cert->from = date('Y-m-d', $certInfo['validFrom_time_t']) ?: null;
  21. $cert->to = date('Y-m-d', $certInfo['validTo_time_t']) ?: null;
  22. }
  23. }
  24. }
  25. return view('admin.node.cert.index', ['certs' => $certs]);
  26. }
  27. public function store(CertRequest $request)
  28. {
  29. if ($cert = NodeCertificate::create($request->validated())) {
  30. return redirect(route('admin.node.cert.edit', $cert))->with('successMsg', trans('common.generate_item', ['attribute' => trans('common.success')]));
  31. }
  32. return redirect()->back()->withInput()->withErrors('生成失败');
  33. }
  34. public function create()
  35. {
  36. return view('admin.node.cert.info');
  37. }
  38. public function edit(NodeCertificate $cert)
  39. {
  40. return view('admin.node.cert.info', compact('cert'));
  41. }
  42. public function update(CertRequest $request, NodeCertificate $cert): RedirectResponse
  43. {
  44. if ($cert->update($request->validated())) {
  45. return redirect()->back()->with('successMsg', trans('common.update_action', ['action' => trans('common.success')]));
  46. }
  47. return redirect()->back()->withInput()->withErrors(trans('common.update_action', ['action' => trans('common.failed')]));
  48. }
  49. public function destroy(NodeCertificate $cert): JsonResponse
  50. {
  51. try {
  52. if ($cert->delete()) {
  53. return response()->json(['status' => 'success', 'message' => '删除成功']);
  54. }
  55. } catch (Exception $e) {
  56. Log::error('删除域名证书失败:'.$e->getMessage());
  57. return response()->json(['status' => 'fail', 'message' => '删除错误:'.$e->getMessage()]);
  58. }
  59. return response()->json(['status' => 'fail', 'message' => '删除失败']);
  60. }
  61. }