QrCodeController.php 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\TwoFAccount;
  4. use App\Services\QrCodeService;
  5. use App\Http\Requests\QrCodeDecodeRequest;
  6. class QrCodeController extends Controller
  7. {
  8. /**
  9. * The TwoFAccount Service instance.
  10. */
  11. protected $qrcodeService;
  12. /**
  13. * Create a new controller instance.
  14. *
  15. * @param QrCodeService $qrcodeService
  16. * @return void
  17. */
  18. public function __construct(QrCodeService $qrcodeService)
  19. {
  20. $this->qrcodeService = $qrcodeService;
  21. }
  22. /**
  23. * Show a QR code image
  24. *
  25. * @param App\TwoFAccount $twofaccount
  26. * @return \Illuminate\Http\Response
  27. */
  28. public function show(TwoFAccount $twofaccount)
  29. {
  30. return response()->json(['qrcode' => $this->qrcodeService->encode($twofaccount->uri)], 200);
  31. }
  32. /**
  33. * Decode an uploaded QR Code image
  34. *
  35. * @param \App\Http\Requests\QrCodeDecodeRequest $request
  36. * @return \Illuminate\Http\Response
  37. */
  38. public function decode(QrCodeDecodeRequest $request)
  39. {
  40. $file = $request->file('qrcode');
  41. return response()->json(['data' => $this->qrcodeService->decode($file)], 200);
  42. }
  43. }