2019-03-23 03:32:38 +03:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding:utf-8 -*-
|
|
|
|
|
|
|
|
import requests
|
|
|
|
import utils
|
|
|
|
|
|
|
|
def producthunt(string, entities):
|
2019-04-07 09:01:04 +03:00
|
|
|
"""Grab the Product Hunt trends"""
|
2019-03-23 03:32:38 +03:00
|
|
|
|
2019-04-07 09:01:04 +03:00
|
|
|
# Developer token
|
|
|
|
developertoken = utils.config('developer_token')
|
|
|
|
|
|
|
|
# Number of products
|
|
|
|
limit = 5
|
|
|
|
|
|
|
|
# Answer key
|
|
|
|
answerkey = 'today'
|
|
|
|
|
2019-04-07 10:16:17 +03:00
|
|
|
# Day date
|
|
|
|
daydate = ''
|
|
|
|
|
2019-04-07 09:01:04 +03:00
|
|
|
for item in entities:
|
|
|
|
if item['entity'] == 'number':
|
|
|
|
limit = item['resolution']['value']
|
2019-04-07 10:16:17 +03:00
|
|
|
if item['entity'] == 'date':
|
|
|
|
answerkey = 'specific_day'
|
|
|
|
|
|
|
|
if 'strPastValue' in item['resolution']:
|
|
|
|
daydate = item['resolution']['strPastValue']
|
|
|
|
else:
|
|
|
|
daydate = item['resolution']['strValue']
|
2019-04-07 09:01:04 +03:00
|
|
|
|
|
|
|
utils.output('inter', 'reaching', utils.translate('reaching'))
|
|
|
|
|
|
|
|
try:
|
2019-04-07 10:16:17 +03:00
|
|
|
url = 'https://api.producthunt.com/v1/posts'
|
|
|
|
if (daydate != ''):
|
|
|
|
url = url + '?day=' + daydate
|
|
|
|
|
|
|
|
r = utils.http('GET', url, { 'Authorization': 'Bearer ' + developertoken })
|
2019-04-07 11:37:07 +03:00
|
|
|
response = r.json()
|
|
|
|
|
|
|
|
if 'error' in response and response['error'] == 'unauthorized_oauth':
|
|
|
|
return utils.output('end', 'invalid_developer_token', utils.translate('invalid_developer_token'))
|
|
|
|
|
|
|
|
posts = list(enumerate(response['posts']))
|
2019-04-07 09:01:04 +03:00
|
|
|
result = ''
|
|
|
|
|
2019-04-07 10:16:17 +03:00
|
|
|
if len(posts) == 0:
|
|
|
|
return utils.output('end', 'not_found', utils.translate('not_found'))
|
|
|
|
|
2019-04-07 09:01:04 +03:00
|
|
|
if limit > len(posts):
|
|
|
|
utils.output('inter', 'limit_max', utils.translate('limit_max', {
|
|
|
|
'limit': limit,
|
|
|
|
'new_limit': len(posts)
|
|
|
|
}))
|
|
|
|
limit = len(posts)
|
|
|
|
elif limit == 0:
|
|
|
|
limit = 5
|
|
|
|
|
|
|
|
for i, post in posts:
|
2019-04-07 10:16:17 +03:00
|
|
|
# If the product maker is known
|
2019-04-07 09:01:04 +03:00
|
|
|
if post['maker_inside']:
|
|
|
|
author = list(reversed(post['makers']))[0]
|
2019-04-07 10:16:17 +03:00
|
|
|
result += utils.translate('list_element', {
|
2019-04-07 09:01:04 +03:00
|
|
|
'rank': i + 1,
|
|
|
|
'post_url': post['discussion_url'],
|
|
|
|
'product_name': post['name'],
|
|
|
|
'author_url': author['profile_url'],
|
|
|
|
'author_name': author['name'],
|
|
|
|
'votes_nb': post['votes_count']
|
|
|
|
}
|
|
|
|
)
|
2019-04-07 10:16:17 +03:00
|
|
|
else:
|
|
|
|
result += utils.translate('list_element_with_unknown_maker', {
|
|
|
|
'rank': i + 1,
|
|
|
|
'post_url': post['discussion_url'],
|
|
|
|
'product_name': post['name'],
|
|
|
|
'votes_nb': post['votes_count']
|
|
|
|
}
|
|
|
|
)
|
2019-04-07 09:01:04 +03:00
|
|
|
|
|
|
|
if (i + 1) == limit:
|
|
|
|
break
|
|
|
|
|
|
|
|
return utils.output('end', answerkey, utils.translate(answerkey, {
|
|
|
|
'limit': limit,
|
2019-04-07 10:16:17 +03:00
|
|
|
'result': result,
|
|
|
|
'date': daydate
|
2019-04-07 09:01:04 +03:00
|
|
|
}
|
|
|
|
)
|
|
|
|
)
|
|
|
|
except requests.exceptions.RequestException as e:
|
|
|
|
return utils.output('end', 'unreachable', utils.translate('unreachable'))
|