mirror of
https://github.com/b4tman/sync_ics2gcal
synced 2025-08-14 23:37:29 +00:00
+ default credentials support
https://googleapis.dev/python/google-auth/latest/reference/google.auth.html#google.auth.default https://developers.google.com/identity/protocols/application-default-credentials
This commit is contained in:
@@ -14,6 +14,21 @@ class GoogleCalendarService():
|
||||
service Resource
|
||||
"""
|
||||
|
||||
@staticmethod
|
||||
def default():
|
||||
"""make service Resource from default credentials (authorize)
|
||||
( https://developers.google.com/identity/protocols/application-default-credentials )
|
||||
( https://googleapis.dev/python/google-auth/latest/reference/google.auth.html#google.auth.default )
|
||||
|
||||
Returns:
|
||||
service Resource
|
||||
"""
|
||||
|
||||
scopes = ['https://www.googleapis.com/auth/calendar']
|
||||
credentials, _ = google.auth.default(scopes=scopes)
|
||||
service = discovery.build('calendar', 'v3', credentials=credentials)
|
||||
return service
|
||||
|
||||
@staticmethod
|
||||
def from_srv_acc_file(service_account_file):
|
||||
"""make service Resource from service account filename (authorize)
|
||||
@@ -27,6 +42,26 @@ class GoogleCalendarService():
|
||||
scoped_credentials = credentials.with_scopes(scopes)
|
||||
service = discovery.build('calendar', 'v3', credentials=scoped_credentials)
|
||||
return service
|
||||
|
||||
@staticmethod
|
||||
def from_config(config):
|
||||
"""make service Resource from config dict
|
||||
|
||||
Arguments:
|
||||
config -- dict() config with keys:
|
||||
(optional) service_account: - service account filename
|
||||
if key not in dict then default credentials will be used
|
||||
( https://developers.google.com/identity/protocols/application-default-credentials )
|
||||
|
||||
Returns:
|
||||
service Resource
|
||||
"""
|
||||
|
||||
if 'service_account' in config:
|
||||
service = GoogleCalendarService.from_srv_acc_file(config['service_account'])
|
||||
else:
|
||||
service = GoogleCalendarService.default()
|
||||
return service
|
||||
|
||||
def select_event_key(event):
|
||||
"""select event key for logging
|
||||
|
@@ -86,8 +86,7 @@ def main():
|
||||
if 'logging' in config:
|
||||
logging.config.dictConfig(config['logging'])
|
||||
|
||||
srv_acc_file = config['service_account']
|
||||
service = GoogleCalendarService.from_srv_acc_file(srv_acc_file)
|
||||
service = GoogleCalendarService.from_config(config)
|
||||
|
||||
if 'list' == args.command:
|
||||
list_calendars(service)
|
||||
|
@@ -34,14 +34,13 @@ def main():
|
||||
|
||||
calendarId = config['calendar']['google_id']
|
||||
ics_filepath = config['calendar']['source']
|
||||
srv_acc_file = config['service_account']
|
||||
|
||||
start = get_start_date(config['start_from'])
|
||||
|
||||
converter = CalendarConverter()
|
||||
converter.load(ics_filepath)
|
||||
|
||||
service = GoogleCalendarService.from_srv_acc_file(srv_acc_file)
|
||||
service = GoogleCalendarService.from_config(config)
|
||||
gcalendar = GoogleCalendar(service, calendarId)
|
||||
|
||||
sync = CalendarSync(gcalendar, converter)
|
||||
|
Reference in New Issue
Block a user