Skip to main content

Fix Failed to Logout Properly in Aras Innovator When Using Chrome

Normally, Aras Innovator will save user's preference and disconnect session automatically when user logout. In order to perform this action in background, relevant code should be triggered in onbeforeunload event and then send request to server silently.
But newer version Chrome disallow "Synchronous XHR in page dismissal", this would make above post process failed (see error message in Figure 1). Therefore, all requests in onbeforeunload event are abandoned due to this kind of policy.

Figure 1. Error in console.

Solution

  1. Open "\Innovator\Client\javascript\aras_object.js".
  2. Add below code.
    
    Aras.prototype.handleUnloadSoapSend = function Aras_handleUnloadSoapSend(methodName,xmlBody,url) {
    	if (this.Browser.isCh() && window.fetch)
    	{
    		var soapMessage = '<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/">';
    		soapMessage += '<SOAP-ENV:Body>';
    		soapMessage += '<'+methodName+'>'+xmlBody+'</'+methodName+'>';
    		soapMessage += '</SOAP-ENV:Body>';
    		soapMessage += '</SOAP-ENV:Envelope>';
    		
    		if (!url)
    			url = this.getServerURL();
    		
    		fetch(url,{
    			method: 'POST',
    			headers: {
    				'AUTHUSER': encodeURIComponent(this.getCurrentLoginName()),
    				'AUTHPASSWORD': this.getCurrentPassword(),
    				'DATABASE': encodeURIComponent(this.getDatabase()),
    				'LOCALE': this.getCommonPropertyValue('systemInfo_CurrentLocale'),
    				'TIMEZONE_NAME': this.getCommonPropertyValue('systemInfo_CurrentTimeZoneName'),
    				'SOAPACTION': methodName
    			},
    			body: soapMessage,
    			mode: 'same-origin',
    			keepalive: true
    		}).then(function (response) {
    			//Do nothing
    		}).catch(function (error) {
    			//Do nothing
    		});
    	}
    	else
    	{
    		this.soapSend(methodName,xmlBody,url);
    	}
    };

  3. Move to line 641 and replace by below code.
    
    this.handleUnloadSoapSend('ApplyAML','<AML>'+xml+'</AML>');
    

  4. Move to line 1034 and replace by below code.
    
    this.handleUnloadSoapSend('Logoff','<logoff skip_unlock=\'0\'/>');
    
  5. Move to line 1036 and replace by below code.
    
    this.handleUnloadSoapSend('Logoff','',this.UserNotification.url);
    
  6. Move to line 5752 and replace by below code.
    
    this.handleUnloadSoapSend('ApplyItem',prefItem.xml);
    

Comments

Popular posts from this blog

aras.uiShowItemEx Method (aras Object)

aras.uiShowItemEx Method Shows Item with Item node. Syntax aras.uiShowItem( itemNd , viewMode , isOpenInTearOff ) Parameters Name Type Description itemNd Object Required. Item node. viewMode String Optional. Unknown purpose but only supports the following values: tab view (Default) openFile new ※Each supported value will get same result. Therefore, call method and pass undefined for this parameter is OK. isOpenInTearOff Boolean Optional. Specifies whether show Item with tear-off window. true - open in a tear-off window. false - open in a tab. (Default) Return Value An AsyncResult object or a Boolean. Returns AsyncResult object if the Item winodw is opened successfully, otherwise returns false. See Also aras Object Aras Innovator Client Framework

aras.uiShowItem Method (aras Object)

aras.uiShowItem Method Gets Item by Item ID and then shows the Item. Syntax aras.uiShowItem( itemTypeName , itemID , viewMode ) Parameters Name Type Description itemTypeName String Required. Name of the ItemType. itemID String Required. ID of the Item. viewMode String Optional. Unknown purpose but only supports the following values: tab view - This is default. openFile new ※Each supported value will get same result. Therefore, call method without this parameter is OK. Return Value An AsyncResult object or a Boolean. Returns AsyncResult object if the Item winodw is opened successfully, otherwise returns false. See Also aras Object Aras Innovator Client Framework

Search Tips in Aras Innovator

In "Jus Ask Innoavtor", we could learn some tips for querying data in simple search mode. But I would use those tips with examples to make it easier to understand. Suppose there are 5 records in my database. Exact String Matching Input words or terms without any special symbol will execute exact string matching. Input "A0119B/11101", 1 record returned. Input "A0119B", nothing returned. Input "11101", nothing returned. Approximate String Matching Use "*" or "%" as wildcard character to execute approximate string matching. Input "A0*", 2 records returned. Input "*1", 3 records returned. Input "*ED*", 2 records returned. Input "A*1*1", 1 record returned. Regular Expression Matching Use square brackets with simple regular expression to execute a query is acceptable, all allowed terms (which are tested by myself and refer to this article ) are sh...