diff --git a/app/MetadataResolver/MetadataResolver.php b/app/MetadataResolver/MetadataResolver.php index 246a77a..00c7101 100644 --- a/app/MetadataResolver/MetadataResolver.php +++ b/app/MetadataResolver/MetadataResolver.php @@ -15,6 +15,7 @@ class MetadataResolver implements Resolver '~www\.pixiv\.net/member_illust\.php\?illust_id=\d+~' => PixivResolver::class, '~fantia\.jp/posts/\d+~' => FantiaResolver::class, '~dmm\.co\.jp/~' => FanzaResolver::class, + '~www\.patreon\.com/~' => PatreonResolver::class, '~www\.deviantart\.com/.*/art/.*~' => DeviantArtResolver::class, '/.*/' => OGPResolver::class ]; diff --git a/app/MetadataResolver/PatreonResolver.php b/app/MetadataResolver/PatreonResolver.php new file mode 100644 index 0000000..78f461a --- /dev/null +++ b/app/MetadataResolver/PatreonResolver.php @@ -0,0 +1,28 @@ +get($url); + if ($res->getStatusCode() === 200) { + $ogpResolver = new OGPResolver(); + $metadata = $ogpResolver->parse($res->getBody()); + + parse_str(parse_url($metadata->image, PHP_URL_QUERY), $temp); + $expires_at_unixtime = $temp["token-time"]; + $expires_at = Carbon::createFromTimestamp($expires_at_unixtime); + + $metadata->expires_at = $expires_at; + + return $metadata; + } else { + throw new \RuntimeException("{$res->getStatusCode()}: $url"); + } + } +}