From b5ab2ee676dc39095d01e8bcf09a7386545a17d6 Mon Sep 17 00:00:00 2001 From: quickwick <2566133+quickwick@users.noreply.github.com> Date: Thu, 24 Mar 2022 17:25:53 -0700 Subject: [PATCH] Add stickers endpoint for search (#2483) --- bridges/GiphyBridge.php | 63 ++++++++++++++++++++++++++++------------- 1 file changed, 44 insertions(+), 19 deletions(-) diff --git a/bridges/GiphyBridge.php b/bridges/GiphyBridge.php index 2f94dac5..40c1f2df 100644 --- a/bridges/GiphyBridge.php +++ b/bridges/GiphyBridge.php @@ -14,6 +14,16 @@ class GiphyBridge extends BridgeAbstract { 'exampleValue' => 'bird', 'required' => true ), + 'noGif' => array( + 'name' => 'Without gifs', + 'type' => 'checkbox', + 'title' => 'Exclude gifs from the results' + ), + 'noStick' => array( + 'name' => 'Without stickers', + 'type' => 'checkbox', + 'title' => 'Exclude stickers from the results' + ), 'n' => array( 'name' => 'max number of returned items (max 50)', 'type' => 'number', @@ -21,25 +31,8 @@ class GiphyBridge extends BridgeAbstract { ) )); - public function collectData() { - /** - * This uses a public beta key which has severe rate limiting. - * - * https://giphy.api-docs.io/1.0/welcome/access-and-api-keys - * https://giphy.api-docs.io/1.0/gifs/search-1 - */ - $apiKey = 'dc6zaTOxFJmzC'; - $limit = min($this->getInput('n') ?: 10, 50); - $uri = sprintf( - 'https://api.giphy.com/v1/gifs/search?q=%s&limit=%s&api_key=%s', - rawurlencode($this->getInput('s')), - $limit, - $apiKey - ); - - $result = json_decode(getContents($uri)); - - foreach($result->data as $entry) { + protected function getGiphyItems($entries){ + foreach($entries as $entry) { $createdAt = new \DateTime($entry->import_datetime); $this->items[] = array( @@ -59,6 +52,38 @@ class GiphyBridge extends BridgeAbstract { HTML ); } + } + + public function collectData() { + /** + * This uses a public beta key which has severe rate limiting. + * + * https://giphy.api-docs.io/1.0/welcome/access-and-api-keys + * https://giphy.api-docs.io/1.0/gifs/search-1 + */ + $apiKey = 'dc6zaTOxFJmzC'; + $limit = min($this->getInput('n') ?: 10, 50); + $endpoints = array(); + if (empty($this->getInput('noGif'))) { + $endpoints[] = 'gifs'; + } + if (empty($this->getInput('noStick'))) { + $endpoints[] = 'stickers'; + } + + foreach ($endpoints as $endpoint) { + $uri = sprintf( + 'https://api.giphy.com/v1/%s/search?q=%s&limit=%s&api_key=%s', + $endpoint, + rawurlencode($this->getInput('s')), + $limit, + $apiKey + ); + + $result = json_decode(getContents($uri)); + + $this->getGiphyItems($result->data); + } usort($this->items, function ($a, $b) { return $a['timestamp'] < $b['timestamp'];