import simplejson import urllib import openerp import openerp.addons.web.http as http from openerp.addons.web.http import request import openerp.addons.web.controllers.main as webmain from openerp.addons.web.http import SessionExpiredException from werkzeug.exceptions import BadRequest import werkzeug.utils class google_auth(http.Controller): @http.route('/googleauth/oauth2callback', type='http', auth="none") def oauth2callback(self, **kw): """ This route/function is called by Google when user Accept/Refuse the consent of Google """ state = simplejson.loads(kw['state']) dbname = state.get('d') service = state.get('s') url_return = state.get('from') registry = openerp.modules.registry.RegistryManager.get(dbname) with registry.cursor() as cr: if kw.get('code'): registry.get('google.%s' % service).set_all_tokens(cr,request.session.uid,kw['code']) return werkzeug.utils.redirect(url_return) #TODO - Display error at customer if url contains ?Error= elif kw.get('error'): return werkzeug.utils.redirect("%s%s%s" % (url_return ,"?Error=" , kw.get('error'))) else: return werkzeug.utils.redirect("%s%s%s" % (url_return ,"?Error=Unknown_error")) @http.route('/web_calendar_sync/sync_calendar/sync_data', type='json', auth='user') def sync_data(self, arch, fields, model,**kw): """ This route/function is called when we want to synchronize openERP calendar with Google Calendar Function return a dictionary with the status : NeedConfigFromAdmin, NeedAuth, NeedRefresh, NoNewEventFromGoogle, SUCCESS if not crm meeting The dictionary may contains an url, to allow OpenERP Client to redirect user on this URL for authorization for example """ if model == 'crm.meeting': gs_obj = request.registry.get('google.service') gc_obj = request.registry.get('google.calendar') # Checking that admin have already configured Google API for google synchronization ! client_id = gs_obj.get_client_id(request.cr, request.uid,'calendar',context=kw.get('LocalContext')) if not client_id or client_id == '': return { "status" : "NeedConfigFromAdmin", "url" : '' } # Checking that user have already accepted OpenERP to access his calendar ! if gc_obj.need_authorize(request.cr, request.uid,context=kw.get('LocalContext')): url = gc_obj.authorize_google_uri(request.cr, request.uid, from_url=kw.get('fromurl'),context=kw.get('LocalContext')) return { "status" : "NeedAuth", "url" : url } # If App authorized, and user access accepted, We launch the synchronization return gc_obj.synchronize_events(request.cr, request.uid, [], kw.get('LocalContext')) return { "status" : "SUCCESS" } @http.route('/gmail/delete_all', type='http', auth='user') def delete_all(self, **kw): gs_obj = request.registry.get('google.service') gc_obj = request.registry.get('google.calendar') #We check that admin has already configure api for google synchronization ! client_id = gs_obj.get_client_id(request.cr, request.uid,'calendar',context=kw.get('LocalContext')) if not client_id or client_id == '': return { "status" : "NeedConfigFromAdmin", "url" : '' } #We check that user has already accepted openerp to access his calendar ! if gc_obj.need_authorize(request.cr, request.uid,context=kw.get('LocalContext')): url = gc_obj.authorize_google_uri(request.cr, request.uid, from_url=kw.get('fromurl'),context=kw.get('LocalContext')) return { "status" : "NeedAuth", "url" : url } #We launch the synchronization gc_obj.delete_all(request.cr, request.uid, kw.get('LocalContext')) @http.route('/googleauth/AuthorizeMe', type='http', auth="none") def authorize_app(self,**val): if val.get('done'): return; registry = openerp.modules.registry.RegistryManager.get(request.session.get('db')) gs_pool = registry.get('google.service') with registry.cursor() as cr: url = gs_pool._get_authorize_uri(cr,request.session.uid,service='calendar',from_url='') return werkzeug.utils.redirect(url) ##REDIRECT WHERE THE USER WAS BEFORE (with state) @http.route('/googleauth/GiveMeAToken', type='http', auth="none") def authorize_me(self,**val): registry = openerp.modules.registry.RegistryManager.get(request.session.get('db')) gs_pool = registry.get('google.service') with registry.cursor() as cr: token = gs_pool._get_google_token_json(cr, request.session.uid, 'api_code') print '#####################################' print '## YOUR TOKEN : ',token, " ##" print '#####################################' #return werkzeug.utils.redirect(url) return