|  | @@ -6,29 +6,14 @@ const i18nTagToT9n = (i18nTag) => {
 | 
											
												
													
														|  |    return i18nTag;
 |  |    return i18nTag;
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -const validator = {
 |  | 
 | 
											
												
													
														|  | -  set(obj, prop, value) {
 |  | 
 | 
											
												
													
														|  | -    if (prop === 'state' && value !== 'signIn') {
 |  | 
 | 
											
												
													
														|  | -      $('.at-form-authentication').hide();
 |  | 
 | 
											
												
													
														|  | -    } else if (prop === 'state' && value === 'signIn') {
 |  | 
 | 
											
												
													
														|  | -      $('.at-form-authentication').show();
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | -    // The default behavior to store the value
 |  | 
 | 
											
												
													
														|  | -    obj[prop] = value;
 |  | 
 | 
											
												
													
														|  | -    // Indicate success
 |  | 
 | 
											
												
													
														|  | -    return true;
 |  | 
 | 
											
												
													
														|  | -  },
 |  | 
 | 
											
												
													
														|  | -};
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -Template.userFormsLayout.onCreated(() => {
 |  | 
 | 
											
												
													
														|  | 
 |  | +Template.userFormsLayout.onCreated(function() {
 | 
											
												
													
														|  | 
 |  | +  Meteor.call('getDefaultAuthenticationMethod', (error, result) => {
 | 
											
												
													
														|  | 
 |  | +    this.data.defaultAuthenticationMethod = new ReactiveVar(error ? undefined : result);
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  |    Meteor.subscribe('setting');
 |  |    Meteor.subscribe('setting');
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |  });
 |  |  });
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  Template.userFormsLayout.onRendered(() => {
 |  |  Template.userFormsLayout.onRendered(() => {
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -  AccountsTemplates.state.form.keys = new Proxy(AccountsTemplates.state.form.keys, validator);
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |    const i18nTag = navigator.language;
 |  |    const i18nTag = navigator.language;
 | 
											
												
													
														|  |    if (i18nTag) {
 |  |    if (i18nTag) {
 | 
											
												
													
														|  |      T9n.setLanguage(i18nTagToT9n(i18nTag));
 |  |      T9n.setLanguage(i18nTagToT9n(i18nTag));
 | 
											
										
											
												
													
														|  | @@ -37,7 +22,6 @@ Template.userFormsLayout.onRendered(() => {
 | 
											
												
													
														|  |  });
 |  |  });
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  Template.userFormsLayout.helpers({
 |  |  Template.userFormsLayout.helpers({
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |    currentSetting() {
 |  |    currentSetting() {
 | 
											
												
													
														|  |      return Settings.findOne();
 |  |      return Settings.findOne();
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
										
											
												
													
														|  | @@ -92,13 +76,14 @@ Template.userFormsLayout.events({
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      });
 |  |      });
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  | -  'click #at-btn'(event) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  'click #at-btn'(event, instance) {
 | 
											
												
													
														|  |      /* All authentication method can be managed/called here.
 |  |      /* All authentication method can be managed/called here.
 | 
											
												
													
														|  |         !! DON'T FORGET to correctly fill the fields of the user during its creation if necessary authenticationMethod : String !!
 |  |         !! DON'T FORGET to correctly fill the fields of the user during its creation if necessary authenticationMethod : String !!
 | 
											
												
													
														|  |      */
 |  |      */
 | 
											
												
													
														|  | -    const authenticationMethodSelected = $('.select-authentication').val();
 |  | 
 | 
											
												
													
														|  | -    // Local account
 |  | 
 | 
											
												
													
														|  | -    if (authenticationMethodSelected === 'password') {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    const email = $('#at-field-username_and_email').val();
 | 
											
												
													
														|  | 
 |  | +    const password = $('#at-field-password').val();
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    if (FlowRouter.getRouteName() !== 'atSignIn' || password === '' || email === '') {
 | 
											
												
													
														|  |        return;
 |  |        return;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -106,29 +91,11 @@ Template.userFormsLayout.events({
 | 
											
												
													
														|  |      event.preventDefault();
 |  |      event.preventDefault();
 | 
											
												
													
														|  |      event.stopImmediatePropagation();
 |  |      event.stopImmediatePropagation();
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    const email = $('#at-field-username_and_email').val();
 |  | 
 | 
											
												
													
														|  | -    const password = $('#at-field-password').val();
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -    // Ldap account
 |  | 
 | 
											
												
													
														|  | -    if (authenticationMethodSelected === 'ldap') {
 |  | 
 | 
											
												
													
														|  | -      // Check if the user can use the ldap connection
 |  | 
 | 
											
												
													
														|  | -      Meteor.subscribe('user-authenticationMethod', email, {
 |  | 
 | 
											
												
													
														|  | -        onReady() {
 |  | 
 | 
											
												
													
														|  | -          const user = Users.findOne();
 |  | 
 | 
											
												
													
														|  | -          if (user === undefined || user.authenticationMethod === 'ldap') {
 |  | 
 | 
											
												
													
														|  | -            // Use the ldap connection package
 |  | 
 | 
											
												
													
														|  | -            Meteor.loginWithLDAP(email, password, function(error) {
 |  | 
 | 
											
												
													
														|  | -              if (!error) {
 |  | 
 | 
											
												
													
														|  | -                // Connection
 |  | 
 | 
											
												
													
														|  | -                return FlowRouter.go('/');
 |  | 
 | 
											
												
													
														|  | -              }
 |  | 
 | 
											
												
													
														|  | -              return error;
 |  | 
 | 
											
												
													
														|  | -            });
 |  | 
 | 
											
												
													
														|  | -          }
 |  | 
 | 
											
												
													
														|  | -          return this.stop();
 |  | 
 | 
											
												
													
														|  | -        },
 |  | 
 | 
											
												
													
														|  | -      });
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | 
 |  | +    Meteor.subscribe('user-authenticationMethod', email, {
 | 
											
												
													
														|  | 
 |  | +      onReady() { 
 | 
											
												
													
														|  | 
 |  | +        return authentication.call(this, instance, email, password);
 | 
											
												
													
														|  | 
 |  | +      },
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |  });
 |  |  });
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -137,3 +104,38 @@ Template.defaultLayout.events({
 | 
											
												
													
														|  |      Modal.close();
 |  |      Modal.close();
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |  });
 |  |  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +function authentication(instance, email, password) {
 | 
											
												
													
														|  | 
 |  | +  let user = Users.findOne();
 | 
											
												
													
														|  | 
 |  | +  // Authentication with password
 | 
											
												
													
														|  | 
 |  | +  if (user && user.authenticationMethod === 'password') {
 | 
											
												
													
														|  | 
 |  | +    $('#at-pwd-form').submit();
 | 
											
												
													
														|  | 
 |  | +    // Meteor.call('logoutWithTimer', user._id, () => {});
 | 
											
												
													
														|  | 
 |  | +    return this.stop();
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  // If user doesn't exist, uses the default authentication method if it defined
 | 
											
												
													
														|  | 
 |  | +  if (user === undefined) {
 | 
											
												
													
														|  | 
 |  | +    user = {
 | 
											
												
													
														|  | 
 |  | +      'authenticationMethod': instance.data.defaultAuthenticationMethod.get(),
 | 
											
												
													
														|  | 
 |  | +    };
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  // Authentication with LDAP
 | 
											
												
													
														|  | 
 |  | +  if (user.authenticationMethod === 'ldap') {
 | 
											
												
													
														|  | 
 |  | +    // Use the ldap connection package
 | 
											
												
													
														|  | 
 |  | +    Meteor.loginWithLDAP(email, password, function(error) {
 | 
											
												
													
														|  | 
 |  | +      if (!error) {
 | 
											
												
													
														|  | 
 |  | +        // Meteor.call('logoutWithTimer', Users.findOne()._id, () => {});
 | 
											
												
													
														|  | 
 |  | +        return FlowRouter.go('/');
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +      return error;
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  /* else {
 | 
											
												
													
														|  | 
 |  | +    process.env.DEFAULT_AUTHENTICATION_METHOD is not defined
 | 
											
												
													
														|  | 
 |  | +  } */
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  return this.stop();
 | 
											
												
													
														|  | 
 |  | +}
 |