feat: initial commit
This commit is contained in:
commit
e214116e40
253 changed files with 17406 additions and 0 deletions
80
src/includes/fetchers/movie.php.liquid
Normal file
80
src/includes/fetchers/movie.php.liquid
Normal file
|
@ -0,0 +1,80 @@
|
|||
<?php
|
||||
require __DIR__ . "/../../vendor/autoload.php";
|
||||
require __DIR__ . "/../../server/utils/init.php";
|
||||
|
||||
use GuzzleHttp\Client;
|
||||
|
||||
$requestUri = $_SERVER["REQUEST_URI"];
|
||||
$url = trim(parse_url($requestUri, PHP_URL_PATH), "/");
|
||||
$postgrestUrl = $_ENV["POSTGREST_URL"] ?? getenv("POSTGREST_URL");
|
||||
$postgrestApiKey = $_ENV["POSTGREST_API_KEY"] ?? getenv("POSTGREST_API_KEY");
|
||||
|
||||
if (!preg_match('/^watching\/movies\/[\w-]+$/', $url)) {
|
||||
echo file_get_contents(__DIR__ . "/../../404/index.html");
|
||||
exit();
|
||||
}
|
||||
|
||||
$cacheKey = "movie_" . md5($url);
|
||||
$movie = null;
|
||||
$useRedis = false;
|
||||
|
||||
try {
|
||||
if (extension_loaded('redis')) {
|
||||
$redis = new Redis();
|
||||
$redis->connect('127.0.0.1', 6379);
|
||||
$useRedis = true;
|
||||
}
|
||||
} catch (Exception $e) {
|
||||
error_log("Redis not available: " . $e->getMessage());
|
||||
}
|
||||
|
||||
if ($useRedis && $redis->exists($cacheKey)) {
|
||||
$movie = json_decode($redis->get($cacheKey), true);
|
||||
} else {
|
||||
$apiUrl = "$postgrestUrl/optimized_movies?url=eq./" . $url;
|
||||
$client = new Client();
|
||||
|
||||
try {
|
||||
$response = $client->request("GET", $apiUrl, [
|
||||
"headers" => [
|
||||
"Accept" => "application/json",
|
||||
"Authorization" => "Bearer {$postgrestApiKey}",
|
||||
],
|
||||
]);
|
||||
|
||||
$movieData = json_decode($response->getBody(), true);
|
||||
|
||||
if (!$movieData) {
|
||||
echo file_get_contents(__DIR__ . "/../../404/index.html");
|
||||
exit();
|
||||
}
|
||||
|
||||
$movie = $movieData[0];
|
||||
|
||||
if ($useRedis) {
|
||||
$redis->setex($cacheKey, 3600, json_encode($movie));
|
||||
}
|
||||
} catch (Exception $e) {
|
||||
error_log($e->getMessage());
|
||||
echo file_get_contents(__DIR__ . "/../../404/index.html");
|
||||
exit();
|
||||
}
|
||||
}
|
||||
|
||||
$movie["description"] = parseMarkdown($movie["description"]);
|
||||
$pageTitle = htmlspecialchars(
|
||||
"Movies • " . $movie["title"],
|
||||
ENT_QUOTES,
|
||||
"UTF-8"
|
||||
);
|
||||
$pageDescription = truncateText(htmlspecialchars(
|
||||
strip_tags($movie["description"]),
|
||||
ENT_QUOTES,
|
||||
"UTF-8"
|
||||
), 250);
|
||||
$ogImage = htmlspecialchars($movie["backdrop"] . "?class=w800", ENT_QUOTES, "UTF-8");
|
||||
$fullUrl = "https://www.coryd.dev" . $requestUri;
|
||||
|
||||
header("Cache-Control: public, max-age=3600");
|
||||
header("Expires: " . gmdate("D, d M Y H:i:s", time() + 3600) . " GMT");
|
||||
?>
|
Loading…
Add table
Add a link
Reference in a new issue