pagination handling added to flickr and 500px
This commit is contained in:
parent
ba08942632
commit
529fabc1ba
1 changed files with 61 additions and 209 deletions
266
pesos.py
266
pesos.py
|
@ -16,15 +16,6 @@ from slugify import slugify
|
||||||
import oauth
|
import oauth
|
||||||
import argparse
|
import argparse
|
||||||
|
|
||||||
""" TODO
|
|
||||||
|
|
||||||
- followings?
|
|
||||||
|
|
||||||
- favs from:
|
|
||||||
- wordpress.com
|
|
||||||
- twitter
|
|
||||||
|
|
||||||
"""
|
|
||||||
|
|
||||||
class Bookmark(object):
|
class Bookmark(object):
|
||||||
def __init__(self, title, url, fname=None):
|
def __init__(self, title, url, fname=None):
|
||||||
|
@ -378,17 +369,44 @@ class FlickrFavs(Favs):
|
||||||
'api_key': shared.config.get('flickr', 'api_key'),
|
'api_key': shared.config.get('flickr', 'api_key'),
|
||||||
'user_id': shared.config.get('flickr', 'user_id'),
|
'user_id': shared.config.get('flickr', 'user_id'),
|
||||||
'extras': 'description,geo,tags,url_z,url_b,owner_name,date_upload',
|
'extras': 'description,geo,tags,url_z,url_b,owner_name,date_upload',
|
||||||
'per_page': 500,
|
'per_page': 500, # maximim
|
||||||
'format': 'json',
|
'format': 'json',
|
||||||
'nojsoncallback': '1',
|
'nojsoncallback': '1',
|
||||||
'min_fave_date': self.lastpulled
|
'min_fave_date': self.lastpulled
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def getpaged(self, offset):
|
||||||
|
logging.info('requesting page #%d of paginated results', offset)
|
||||||
|
self.params.update({
|
||||||
|
'page': offset
|
||||||
|
})
|
||||||
|
r = requests.get(
|
||||||
|
self.url,
|
||||||
|
params=self.params
|
||||||
|
)
|
||||||
|
parsed = json.loads(r.text)
|
||||||
|
return parsed.get('photos', {}).get('photo', [])
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
r = requests.get(self.url,params=self.params)
|
r = requests.get(self.url,params=self.params)
|
||||||
js = json.loads(r.text)
|
js = json.loads(r.text)
|
||||||
for photo in js.get('photos', {}).get('photo', []):
|
js = js.get('photos', {})
|
||||||
|
|
||||||
|
photos = js.get('photo', [])
|
||||||
|
|
||||||
|
total = int(js.get('pages', 1))
|
||||||
|
current = int(js.get('page', 1))
|
||||||
|
cntr = total - current
|
||||||
|
|
||||||
|
while cntr > 0:
|
||||||
|
current = current + 1
|
||||||
|
paged = self.getpaged(current)
|
||||||
|
photos = photos + paged
|
||||||
|
cntr = total - current
|
||||||
|
|
||||||
|
for photo in photos:
|
||||||
fav = FlickrFav(photo)
|
fav = FlickrFav(photo)
|
||||||
|
if not fav.exists:
|
||||||
fav.run()
|
fav.run()
|
||||||
fav.write()
|
fav.write()
|
||||||
|
|
||||||
|
@ -398,16 +416,42 @@ class FivehpxFavs(Favs):
|
||||||
super(FivehpxFavs, self).__init__('500px')
|
super(FivehpxFavs, self).__init__('500px')
|
||||||
self.params = {
|
self.params = {
|
||||||
'consumer_key': shared.config.get('500px', 'api_key'),
|
'consumer_key': shared.config.get('500px', 'api_key'),
|
||||||
'rpp': 100,
|
'rpp': 100, # maximum
|
||||||
'image_size': 4,
|
'image_size': 4,
|
||||||
'include_tags': 1,
|
'include_tags': 1,
|
||||||
'include_geo': 1
|
'include_geo': 1,
|
||||||
|
'sort': 'created_at',
|
||||||
|
'sort_direction': 'desc'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def getpaged(self, offset):
|
||||||
|
logging.info('requesting page #%d of paginated results', offset)
|
||||||
|
self.params.update({
|
||||||
|
'page': offset
|
||||||
|
})
|
||||||
|
r = requests.get(
|
||||||
|
self.url,
|
||||||
|
params=self.params
|
||||||
|
)
|
||||||
|
parsed = json.loads(r.text)
|
||||||
|
return parsed.get('photos')
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
r = requests.get(self.url,params=self.params)
|
r = requests.get(self.url,params=self.params)
|
||||||
js = json.loads(r.text)
|
js = json.loads(r.text)
|
||||||
for photo in js.get('photos', []):
|
photos = js.get('photos')
|
||||||
|
|
||||||
|
total = int(js.get('total_pages', 1))
|
||||||
|
current = int(js.get('current_page', 1))
|
||||||
|
cntr = total - current
|
||||||
|
|
||||||
|
while cntr > 0:
|
||||||
|
current = current + 1
|
||||||
|
paged = self.getpaged(current)
|
||||||
|
photos = photos + paged
|
||||||
|
cntr = total - current
|
||||||
|
|
||||||
|
for photo in photos:
|
||||||
fav = FivehpxFav(photo)
|
fav = FivehpxFav(photo)
|
||||||
if not fav.exists:
|
if not fav.exists:
|
||||||
fav.run()
|
fav.run()
|
||||||
|
@ -438,7 +482,6 @@ class TumblrFavs(Favs):
|
||||||
|
|
||||||
js = json.loads(r.text)
|
js = json.loads(r.text)
|
||||||
total = int(js.get('response', {}).get('liked_count', 20))
|
total = int(js.get('response', {}).get('liked_count', 20))
|
||||||
print('total: %d' % total)
|
|
||||||
offset = 20
|
offset = 20
|
||||||
cntr = total - offset
|
cntr = total - offset
|
||||||
likes = js.get('response', {}).get('liked_posts', [])
|
likes = js.get('response', {}).get('liked_posts', [])
|
||||||
|
@ -507,9 +550,9 @@ class DAFavs(Favs):
|
||||||
)
|
)
|
||||||
|
|
||||||
js = json.loads(r.text)
|
js = json.loads(r.text)
|
||||||
|
favs = js.get('results', [])
|
||||||
has_more = js.get('has_more')
|
has_more = js.get('has_more')
|
||||||
offset = js.get('next_offset')
|
offset = js.get('next_offset')
|
||||||
favs = js.get('results', [])
|
|
||||||
while True == has_more:
|
while True == has_more:
|
||||||
logging.debug('iterating over DA results with offset %d', offset)
|
logging.debug('iterating over DA results with offset %d', offset)
|
||||||
paged = self.getpaged(offset)
|
paged = self.getpaged(offset)
|
||||||
|
@ -529,197 +572,6 @@ class DAFavs(Favs):
|
||||||
f.run()
|
f.run()
|
||||||
f.write()
|
f.write()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#class WPFavs(Favs):
|
|
||||||
#def __init__(self):
|
|
||||||
#from pprint import pprint
|
|
||||||
#super(DAFavs, self).__init__('wordpress')
|
|
||||||
#self.oauth = oauth.DAOauth()
|
|
||||||
#self.params = {
|
|
||||||
#'limit': 24,
|
|
||||||
#'mature_content': 'true',
|
|
||||||
#'username': shared.config.get('deviantart', 'username')
|
|
||||||
#}
|
|
||||||
#self.likes = []
|
|
||||||
|
|
||||||
#def getpaged(self, offset):
|
|
||||||
#self.params.update({'offset': offset})
|
|
||||||
#r = self.oauth.request(
|
|
||||||
#self.url,
|
|
||||||
#self.params
|
|
||||||
#)
|
|
||||||
#return json.loads(r.text)
|
|
||||||
|
|
||||||
#def getsinglemeta(self, daid):
|
|
||||||
#r = self.oauth.request(
|
|
||||||
#'https://www.deviantart.com/api/v1/oauth2/deviation/metadata',
|
|
||||||
#params={
|
|
||||||
#'deviationids[]': daid,
|
|
||||||
#'ext_submission': False,
|
|
||||||
#'ext_camera': False,
|
|
||||||
#'ext_stats': False,
|
|
||||||
#'ext_collection': False,
|
|
||||||
#'mature_content': True,
|
|
||||||
#}
|
|
||||||
#)
|
|
||||||
#meta = {}
|
|
||||||
#try:
|
|
||||||
#meta = json.loads(r.text)
|
|
||||||
#return meta.get('metadata', []).pop()
|
|
||||||
#except:
|
|
||||||
#return meta
|
|
||||||
|
|
||||||
#def has_more(self, q):
|
|
||||||
#if 'True' == q or 'true' == q:
|
|
||||||
#return True
|
|
||||||
#return False
|
|
||||||
|
|
||||||
#def run(self):
|
|
||||||
#r = self.oauth.request(
|
|
||||||
#self.url,
|
|
||||||
#self.params
|
|
||||||
#)
|
|
||||||
|
|
||||||
#js = json.loads(r.text)
|
|
||||||
#has_more = js.get('has_more')
|
|
||||||
#offset = js.get('next_offset')
|
|
||||||
#favs = js.get('results', [])
|
|
||||||
#while True == has_more:
|
|
||||||
#logging.debug('iterating over DA results with offset %d', offset)
|
|
||||||
#paged = self.getpaged(offset)
|
|
||||||
#favs = favs + paged.get('results', [])
|
|
||||||
#has_more = paged.get('has_more')
|
|
||||||
#n = paged.get('next_offset')
|
|
||||||
#if n:
|
|
||||||
#offset = offset + n
|
|
||||||
|
|
||||||
#self.favs = favs
|
|
||||||
#for fav in self.favs:
|
|
||||||
#f = DAFav(fav)
|
|
||||||
#if f.exists:
|
|
||||||
#continue
|
|
||||||
|
|
||||||
#f.fav.update({'meta': self.getsinglemeta(fav.get('deviationid'))})
|
|
||||||
#f.run()
|
|
||||||
#f.write()
|
|
||||||
|
|
||||||
#class Following(object):
|
|
||||||
#def __init__(self, confgroup):
|
|
||||||
#self.confgroup = confgroup
|
|
||||||
#self.url = shared.config.get(confgroup, 'following_api')
|
|
||||||
#self.followings = []
|
|
||||||
|
|
||||||
|
|
||||||
#class FlickrFollowing(Following):
|
|
||||||
#def __init__(self):
|
|
||||||
#super(FlickrFollowing, self).__init__('flickr')
|
|
||||||
#self.oauth = oauth.FlickrOauth()
|
|
||||||
|
|
||||||
|
|
||||||
#def run(self):
|
|
||||||
#r = self.oauth.request(self.url, params={
|
|
||||||
#'method': 'flickr.contacts.getList',
|
|
||||||
#'format': 'json',
|
|
||||||
#'nojsoncallback': 1,
|
|
||||||
#'api_key': shared.config.get(self.confgroup, 'api_key')
|
|
||||||
#})
|
|
||||||
|
|
||||||
#try:
|
|
||||||
#contacts = json.loads(r.text)
|
|
||||||
#for c in contacts.get('contacts', {}).get('contact', []):
|
|
||||||
#self.followings.append({
|
|
||||||
#'url': "https://www.flickr.com/people/%s/" % c.get('nsid'),
|
|
||||||
#'name': c.get('realname'),
|
|
||||||
#'username': c.get('username'),
|
|
||||||
#'userid': c.get('nsid')
|
|
||||||
#})
|
|
||||||
|
|
||||||
#except Exception as e:
|
|
||||||
#logging.error('getting following from flickr failed: %s', e)
|
|
||||||
|
|
||||||
|
|
||||||
#class TumblrFollowing(Following):
|
|
||||||
#def __init__(self):
|
|
||||||
#super(TumblrFollowing, self).__init__('tumblr')
|
|
||||||
#self.oauth = oauth.FlickrOauth()
|
|
||||||
|
|
||||||
|
|
||||||
#def run(self):
|
|
||||||
#r = self.oauth.request(self.url, params={
|
|
||||||
#'method': 'flickr.contacts.getList',
|
|
||||||
#'format': 'json',
|
|
||||||
#'nojsoncallback': 1,
|
|
||||||
#'api_key': shared.config.get(self.confgroup, 'api_key')
|
|
||||||
#})
|
|
||||||
|
|
||||||
#try:
|
|
||||||
#contacts = json.loads(r.text)
|
|
||||||
#for c in contacts.get('contacts', {}).get('contact', []):
|
|
||||||
#self.followings.append({
|
|
||||||
#'url': "https://www.flickr.com/people/%s/" % c.get('nsid'),
|
|
||||||
#'name': c.get('realname'),
|
|
||||||
#'username': c.get('username'),
|
|
||||||
#'userid': c.get('nsid')
|
|
||||||
#})
|
|
||||||
|
|
||||||
#except Exception as e:
|
|
||||||
#logging.error('getting following from flickr failed: %s', e)
|
|
||||||
|
|
||||||
|
|
||||||
#class FlickrFollowing(object):
|
|
||||||
#def __init__(self):
|
|
||||||
#super(FlickrFollowing, self).__init__('flickr')
|
|
||||||
#self.params = {
|
|
||||||
#'consumer_key': shared.config.get('500px', 'api_key'),
|
|
||||||
#'rpp': 100,
|
|
||||||
#'image_size': 4,
|
|
||||||
#'include_tags': 1,
|
|
||||||
#'include_geo': 1
|
|
||||||
#}
|
|
||||||
|
|
||||||
#def run(self):
|
|
||||||
#r = requests.get(self.url,params=self.params)
|
|
||||||
#js = json.loads(r.text)
|
|
||||||
#for photo in js.get('photos', []):
|
|
||||||
#fav = FivehpxFav(photo)
|
|
||||||
#if not fav.exists:
|
|
||||||
#fav.run()
|
|
||||||
#fav.write()
|
|
||||||
|
|
||||||
|
|
||||||
#def run(self):
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#https://api.flickr.com/services/rest/?method=flickr.contacts.getList&api_key=27d8a5bf7dabf882ff1c710894041f64&format=json&nojsoncallback=1&auth_token=72157682938907284-9c5f21debeec9833&api_sig=8ac87b900f44debea06a3765ed223680
|
|
||||||
|
|
||||||
|
|
||||||
#class Following(object):
|
|
||||||
#def __init__(self, confgroup):
|
|
||||||
#self.confgroup = confgroup
|
|
||||||
#self.url = shared.config.get(confgroup, 'fav_api')
|
|
||||||
|
|
||||||
|
|
||||||
#class FlickrFollowing(Following):
|
|
||||||
#def __init__(self):
|
|
||||||
#super(FlickrFollowing, self).__init__('flickr')
|
|
||||||
#self.params = {
|
|
||||||
#'method': 'flickr.contacts.getList',
|
|
||||||
#'api_key': shared.config.get('flickr', 'api_key'),
|
|
||||||
#'format': 'json',
|
|
||||||
#'nojsoncallback': '1',
|
|
||||||
#}
|
|
||||||
|
|
||||||
#def run(self):
|
|
||||||
#r = requests.get(self.url,params=self.params)
|
|
||||||
#js = json.loads(r.text)
|
|
||||||
#pprint(js)
|
|
||||||
#for contact in js.get('contacts', {}).get('contact', []):
|
|
||||||
#pprint(contact)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
||||||
parser = argparse.ArgumentParser(description='Parameters for NASG')
|
parser = argparse.ArgumentParser(description='Parameters for NASG')
|
||||||
|
|
Loading…
Reference in a new issue