-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathcelery_migration_app.py
41 lines (35 loc) · 1.47 KB
/
celery_migration_app.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
from celery import Celery
from migration_util import *
from pathlib import Path
from requests.exceptions import RequestException
from googleapiclient.errors import HttpError
app = Celery(__name__)
app.conf.update({
'result_backend': f'file://{(Path.cwd() / "celery" / "results").resolve().as_posix()}',
'broker_url': 'filesystem://',
'broker_transport_options': {
'data_folder_in': 'celery/out',
'data_folder_out': 'celery/out',
'data_folder_processed': 'celery/processed',
'processed_folder': 'celery/processed',
'store_processed': True
},
'imports': ('celery_migration_app',),
'result_persistent': True,
'task_serializer': 'json',
'result_serializer': 'json',
'accept_content': ['json']})
r = redis.Redis(host='0.0.0.0', port=6379, db=0, decode_responses=True)
@app.task(autoretry_for=(RequestException, HttpError),
retry_backoff=True,
retry_kwargs={'max_retries': 20})
def migrate_photo(photo_title, photo_url, album_title, photo_tags):
google_creds = authorize_with_google()
service = get_google_photos_service(google_creds)
with r.lock("find-album"):
album_id = find_album_on_google(album_title)
if album_id is None:
album_id = create_album_on_google(service, album_title)
photo_data = get_photo_from_flickr(photo_url)
return upload_photo_to_google(google_creds, service, album_id, photo_data,
photo_title, photo_tags)