SearchController.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. <?php
  2. namespace App\Http\Controllers\Movie;
  3. use Illuminate\Http\Request;
  4. use Illuminate\Support\Facades\Http;
  5. use Illuminate\Support\Facades\Validator;
  6. use App\Http\Controllers\Controller;
  7. use App\Http\Traits\CommonTrait;
  8. use App\Http\Traits\PagingTrait;
  9. use App\Models\DTO\Movie\ListParams;
  10. use App\Models\DTO\Movie\InfoParams;
  11. use App\Models\DTO\SearchData;
  12. use App\Models\Movie\Movie;
  13. use App\Models\Movie\MovieReview;
  14. use Exception;
  15. class SearchController extends Controller
  16. {
  17. use CommonTrait;
  18. use PagingTrait;
  19. private string $host;
  20. private Movie $movieModel;
  21. private MovieReview $movieReviewModel;
  22. public function __construct(
  23. Movie $movieModel,
  24. MovieReview $movieReviewModel
  25. ) {
  26. $this->middleware('front');
  27. if(env('APP_ENV') == "local") {
  28. $this->host = ('host.mysql.moview:1050');
  29. }else{
  30. $this->host = ('172.17.0.1:1050');
  31. }
  32. $this->movieModel = $movieModel;
  33. $this->movieReviewModel = $movieReviewModel;
  34. }
  35. /**
  36. * 영화 DB
  37. * @method GET
  38. * @see /movie/search
  39. */
  40. public function index(Request $request, ListParams $params)
  41. {
  42. $rules = [
  43. 'page' => 'nullable|numeric',
  44. 'keyword' => 'nullable|string|max:100',
  45. 'director' => 'nullable|string|max:30',
  46. 's_year' => 'nullable|date_format:Y|before:e_year',
  47. 'e_year' => 'nullable|date_format:Y|after:s_year',
  48. 's_open_dt' => 'nullable|date_format:Y-m-d|before:e_open_dt',
  49. 'e_open_dt' => 'nullable|date_format:Y-m-d|after:s_open_dt',
  50. 'genre' => 'nullable|numeric',
  51. 'type' => 'nullable|numeric'
  52. ];
  53. $attributes = [
  54. 'page' => '페이지 번호',
  55. 'keyword' => '검색어',
  56. 'director' => '감독',
  57. 's_year' => '제작 시작연도',
  58. 'e_year' => '제작 종료연도',
  59. 's_open_dt' => '개봉 시작일',
  60. 'e_open_dt' => '개봉 종료일',
  61. 'genre' => '장르',
  62. 'type' => '유형'
  63. ];
  64. $message = [
  65. 'page.numeric' => '페이지 번호는 숫자여야 합니다.',
  66. 'keyword.max' => '검색어 최대 글자는 100자 입니다.',
  67. 's_year.date_format' => '제작 시작연도 형식이 옳지 않습니다.',
  68. 's_year.before' => '제작 시작연도는 종료 연도보다 작아야 합니다.',
  69. 'e_year.date_format' => '제작 시작연도 형식이 옳지 않습니다.',
  70. 'e_year.after' => '제작 종료연도는 시작 연도보다 커야 합니다.',
  71. 's_open_dt.date_format' => '개봉 시작일 형식이 옳지 않습니다.',
  72. 's_open_dt.before' => '개봉 시작일은 종료일 보다 작아야 합니다.',
  73. 'e_open_dt.date_format' => '개봉 종료일 형식이 옳지 않습니다.',
  74. 'e_open_dt.after' => '개봉 종료일은 시작일 보다 커야 합니다.',
  75. ];
  76. // 검색 유효성 검사
  77. Validator::make($request->all(), $rules, $message, $attributes)->validated();
  78. $params = SearchData::fromRequest($request);
  79. $params->director = $request->get('director');
  80. $params->sYear = $request->get('s_year');
  81. $params->eYear = $request->get('e_year');
  82. $params->sOpenDt = $request->get('s_open_dt');
  83. $params->eOpenDt = $request->get('e_open_dt');
  84. $params->genre = $request->get('genre', []);
  85. $params->type = $request->get('type', []);
  86. $params->perPage = 20;
  87. $movies = $this->movieModel->list($params);
  88. if($movies->total > 0) {
  89. $queryString = $request->getQueryString();
  90. foreach($movies->list as &$row) {
  91. $row->open_dt = ($row->open_dt ? date('Y.m.d', strtotime($row->open_dt)) : null);
  92. $row->viewURL = route('movie.search.show', base64_encode($row->movie_cd));
  93. if($queryString) {
  94. $row->viewURL .= ('?' . $queryString);
  95. }
  96. }
  97. }
  98. return view('movie.search.index', [
  99. 'params' => $params,
  100. 'movies' => $movies
  101. ]);
  102. }
  103. /**
  104. * 영화 DB 상세 보기
  105. * @method GET
  106. * @see /movie/search/{movie_id}
  107. */
  108. public function show(string $base64, Request $request, InfoParams $params)
  109. {
  110. try {
  111. if(!$base64) {
  112. throw new Exception('잘못된 접근입니다. [1]');
  113. }
  114. $movieCd = base64_decode($base64);
  115. if(!$movieCd) {
  116. throw new Exception('잘못된 접근입니다. [2]');
  117. }
  118. $listURL = route('movie.search.index');
  119. if($queryString = $request->getQueryString()) {
  120. $listURL .= ('?' . $queryString);
  121. }
  122. // 검색 조건
  123. $url = ($this->host . MOVIE_INFO);
  124. $params->movieCd = $movieCd;
  125. $response = Http::get($url, $params->toArray());
  126. if(!$response->ok()) {
  127. throw new Exception('요청한 정보가 없습니다.');
  128. }
  129. $data = json_decode($response->body());
  130. $info = $data->info;
  131. $detail = $data->detail;
  132. $movieNm = $info->MovieNm;
  133. if($info->MovieNmEn) {
  134. $movieNm .= (' (' . $info->MovieNmEn . ')');
  135. }
  136. $avgRate = $this->movieReviewModel->getAvgRate($movieCd);
  137. return view('movie.search.show', [
  138. 'movieCd' => $base64,
  139. 'movieNm' => $movieNm,
  140. 'info' => $info,
  141. 'detail' => $detail,
  142. 'listURL' => $listURL,
  143. 'avgRate' => $avgRate
  144. ]);
  145. }catch(Exception $e) {
  146. abort($e->getCode(), $e->getMessage());
  147. }
  148. }
  149. }