2 openerp.auth_openid = function(instance) {
4 var QWeb = instance.web.qweb;
6 instance.web.Login = instance.web.Login.extend({
8 this._super.apply(this, arguments);
11 this._default_error_message = this.$element.find('.login_error_message').text();
13 this.$openid_selected_button = $();
14 this.$openid_selected_input = $();
15 this.$openid_selected_provider = null;
18 var openIdProvider = null;
19 if (this.has_local_storage && this.remember_credentials) {
20 openIdProvider = localStorage.getItem('openid-provider');
24 $openid_selected_provider = openIdProvider;
25 this.do_openid_select('a[href="#' + openIdProvider + '"]', openIdProvider, true);
27 if (this.has_local_storage && this.remember_credentials) {
28 this.$openid_selected_input.find('input').val(localStorage.getItem('openid-login'));
32 this.do_openid_select('a[data-url=""]', 'login,password', true);
35 this.$element.find('a[data-url]').click(function (event) {
36 event.preventDefault();
37 var selected_oidh = $(this).attr('href').substr(1);
38 if (selected_oidh != self.$openid_selected_provider) {
39 self.do_openid_select(this, selected_oidh);
43 this._check_fragment();
48 do_openid_select: function (button, provider, noautosubmit) {
51 self.$openid_selected_button.add(self.$openid_selected_input).removeClass('selected');
52 self.$openid_selected_button = self.$element.find(button).addClass('selected');
54 var input = _(provider.split(',')).map(function(p) { return 'li[data-provider="'+p+'"]'; }).join(',');
55 self.$openid_selected_input = self.$element.find(input).addClass('selected');
57 self.$openid_selected_input.find('input:first').focus();
58 self.$openid_selected_provider = (self.$openid_selected_button.attr('href') || '').substr(1);
60 if (self.has_local_storage && self.remember_credentials) {
61 localStorage.setItem('openid-provider', self.$openid_selected_provider);
64 if (!noautosubmit && self.$openid_selected_input.length == 0) {
65 self.$element.find('form').submit();
70 _check_fragment: function() {
72 var fragment = jQuery.deparam.fragment();
73 console.log(fragment);
74 if (fragment.loginerror !== undefined) {
75 this.rpc('/auth_openid/login/status', {}, function(result) {
76 if (_.contains(['success', 'failure'], result.status) && result.message) {
77 self.do_warn('Invalid OpenID Login', result.message);
79 if (result.status === 'setup_needed' && result.message) {
80 window.location.replace(result.message);
86 on_submit: function(ev) {
88 var dataurl = this.$openid_selected_button.attr('data-url');
91 // login-password submitted
92 this.reset_error_message();
97 var id = this.$openid_selected_input.find('input').val();
98 if (this.has_local_storage && this.remember_credentials) {
99 localStorage.setItem('openid-login', id);
102 var db = this.$element.find("form [name=db]").val();
103 var openid_url = dataurl.replace('{id}', id);
105 this.do_openid_login(db, openid_url);
110 do_openid_login: function(db, openid_url) {
112 this.rpc('/auth_openid/login/verify', {'db': db, 'url': openid_url}, function(result) {
114 self.do_warn(result.title, result.error);
117 if (result.session_id) {
118 self.session.set_cookie('session_id', result.session_id);
120 if (result.action === 'post') {
122 document.write(result.value);
124 } else if (result.action === 'redirect') {
125 window.location.replace(result.value);
127 // XXX display error ?
133 do_warn: function(title, msg) {
134 //console.warn(title, msg);
135 this.$element.find('.login_error_message').text(msg).show();
138 reset_error_message: function() {
139 this.$element.find('.login_error_message').text(this._default_error_message);