60 lines
2.7 KiB
Python
60 lines
2.7 KiB
Python
# -*- coding: utf-8 -*-
|
|
# Part of Odoo, Flectra. See LICENSE file for full copyright and licensing details.
|
|
|
|
from flectra import http
|
|
from flectra.http import request
|
|
|
|
|
|
class GoogleCalendarController(http.Controller):
|
|
|
|
@http.route('/google_calendar/sync_data', type='json', auth='user')
|
|
def sync_data(self, model, **kw):
|
|
""" This route/function is called when we want to synchronize Flectra calendar with Google Calendar
|
|
Function return a dictionary with the status : need_config_from_admin, need_auth, need_refresh, success if not calendar_event
|
|
The dictionary may contains an url, to allow Flectra Client to redirect user on this URL for authorization for example
|
|
"""
|
|
if model == 'calendar.event':
|
|
GoogleService = request.env['google.service']
|
|
GoogleCal = request.env['google.calendar']
|
|
|
|
# Checking that admin have already configured Google API for google synchronization !
|
|
context = kw.get('local_context', {})
|
|
client_id = GoogleService.with_context(context).get_client_id('calendar')
|
|
|
|
if not client_id or client_id == '':
|
|
action_id = ''
|
|
if GoogleCal.can_authorize_google():
|
|
action_id = request.env.ref('google_calendar.action_config_settings_google_calendar').id
|
|
return {
|
|
"status": "need_config_from_admin",
|
|
"url": '',
|
|
"action": action_id
|
|
}
|
|
|
|
# Checking that user have already accepted Flectra to access his calendar !
|
|
if GoogleCal.need_authorize():
|
|
url = GoogleCal.with_context(context).authorize_google_uri(from_url=kw.get('fromurl'))
|
|
return {
|
|
"status": "need_auth",
|
|
"url": url
|
|
}
|
|
|
|
# If App authorized, and user access accepted, We launch the synchronization
|
|
return GoogleCal.with_context(context).synchronize_events()
|
|
|
|
return {"status": "success"}
|
|
|
|
@http.route('/google_calendar/remove_references', type='json', auth='user')
|
|
def remove_references(self, model, **kw):
|
|
""" This route/function is called when we want to remove all the references between one calendar Flectra and one Google Calendar """
|
|
status = "NOP"
|
|
if model == 'calendar.event':
|
|
GoogleCal = request.env['google.calendar']
|
|
# Checking that user have already accepted Flectra to access his calendar !
|
|
context = kw.get('local_context', {})
|
|
if GoogleCal.with_context(context).remove_references():
|
|
status = "OK"
|
|
else:
|
|
status = "KO"
|
|
return {"status": status}
|