feat: gif retry query (#33)

Retry up to 3 times the query to tenor
This commit is contained in:
Anthony Laibe 2021-09-20 16:07:22 +02:00 committed by GitHub
parent 23db2d1216
commit 9e4c12f408
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -3,9 +3,12 @@ import json
import strformat import strformat
import os import os
import sequtils import sequtils
import chronicles
from statusgo_backend/gif import getRecentGifs, getFavoriteGifs, setFavoriteGifs, setRecentGifs from statusgo_backend/gif import getRecentGifs, getFavoriteGifs, setFavoriteGifs, setRecentGifs
logScope:
topics = "gif"
const MAX_RECENT = 50 const MAX_RECENT = 50
# set via `nim c` param `-d:TENOR_API_KEY:[api_key]`; should be set in CI/release builds # set via `nim c` param `-d:TENOR_API_KEY:[api_key]`; should be set in CI/release builds
@ -73,9 +76,24 @@ proc newGifClient*(): GifClient =
result.favorites = @[] result.favorites = @[]
result.recents = @[] result.recents = @[]
proc getContentWithRetry(self: GifClient, path: string, maxRetry: int = 3): string =
var currentRetry = 0
while true:
try:
let content = self.client.getContent(fmt("{baseUrl}{path}{defaultParams}"))
return content
except Exception as e:
currentRetry += 1
error "could not query tenor API", msg=e.msg
if currentRetry >= maxRetry:
raise
sleep(100 * currentRetry)
proc tenorQuery(self: GifClient, path: string): seq[GifItem] = proc tenorQuery(self: GifClient, path: string): seq[GifItem] =
try: try:
let content = self.client.getContent(fmt("{baseUrl}{path}{defaultParams}")) let content = self.getContentWithRetry(path)
let doc = content.parseJson() let doc = content.parseJson()
var items: seq[GifItem] = @[] var items: seq[GifItem] = @[]
@ -84,7 +102,6 @@ proc tenorQuery(self: GifClient, path: string): seq[GifItem] =
return items return items
except: except:
echo getCurrentExceptionMsg()
return @[] return @[]
proc search*(self: GifClient, query: string): seq[GifItem] = proc search*(self: GifClient, query: string): seq[GifItem] =