From b3f844271775ccf446536c84ede8029a7c3eec44 Mon Sep 17 00:00:00 2001 From: Erik Lopez Date: Thu, 16 Jul 2020 10:57:57 -0400 Subject: [PATCH] putting this our for comment --- richcontext/scholapi/scholapi.py | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/richcontext/scholapi/scholapi.py b/richcontext/scholapi/scholapi.py index 2a3f5e8..63fe4ee 100755 --- a/richcontext/scholapi/scholapi.py +++ b/richcontext/scholapi/scholapi.py @@ -359,6 +359,22 @@ class _ScholInfra_SemanticScholar (_ScholInfra): """ http://api.semanticscholar.org/ """ + def __init__ (self, parent=None, name="Generic", api_url=None, cgi_url=None): + super(_ScholInfra_SemanticScholar, self).__init__( parent, name, api_url, cgi_url ) + self.time = 0 + self.tries = 0 + self.MAX_QUERIES = 100 + self.MAX_ELAPSED_TIME = 5 * 60 + + def check_limit(self, t): + if self.tries > 100 and (t - self.time) <= self.MAX_ELAPSED_TIME: + print("We are sleeping for {}} secs".format( (t - self.time))) + time.sleep( (t - self.time)) + elif self.tries <= 100: + self.tries += 1 + elif (t - self.time) > self.MAX_ELAPSED_TIME: + self.time = time.time() + self.tries = 0 def publication_lookup (self, identifier): """ @@ -369,6 +385,9 @@ def publication_lookup (self, identifier): message = None t0 = time.time() + + self.check_limit(t0) + url = self._get_api_url(identifier) meta = json.loads(requests.get(url).text)