Tmdb Client Error: {"success":false,"status_code":11,"status_message":"Internal error: Something went wrong, contact TMDb.","combined_credits":{"cast":[{"adult":false,"backdrop_path":"/1RrT0DdlsxGcLTWYU9LnRWWxoDi.jpg","genre_ids":[10749,10402,35],"id":43903,"original_language":"en","original_title":"Dames","overview":"A reformer's daughter wins the lead role in a scandalous Broadway show.","popularity":4.652,"poster_path":"/uBRbAgn9FrC5RY48RiwMTl8QlbD.jpg","release_date":"1934-09-01","title":"Dames","video":false,"vote_average":6.3,"vote_count":34,"character":"Chorus Girl (uncredited)","credit_id":"5c83c961c3a3684e95da8c71","order":17,"media_type":"movie"}],"crew":[]}}
96 'Content-Type' => 'application/json;charset=utf-8',
97 'Authorization' => sprintf('Bearer %s', Configurator::$instance->get('tmdb'))
98 ];
99
100 // Append language preference to headers to avoid adult content
101 $headers['Accept-Language'] = 'en-US'; // Example: Set language preference to English
102
103 // Make the GET request with headers
104 $resp = EasyCurl::setHeaders($headers)->get(...$args);
105
106 // Check if response status is not 200 OK
107 if ($resp->getStatus() != 200) {
108 throw new TmdbClientException('Tmdb Client Error: ' . $resp->getBody(), $resp->getStatus());
109 }
110
111 // Check for adult content in response (assuming TMDB API supports such filtering)
112 $jsonResponse = json_decode($resp->getBody(), true);
113
114
115 return $resp;
116 }
117
118
119 public function getGenre(): array
120 {
121 return $this->request('genre/' . $this->getType() . '/list')['genres'] ?? [];