2000-01-22 12:49:49 +00:00
|
|
|
/* GSWSessionTimeOutManager.m - GSWeb: Class GSWSessionTimeOutManager
|
|
|
|
Copyright (C) 1999 Free Software Foundation, Inc.
|
|
|
|
|
|
|
|
Written by: Manuel Guesdon <mguesdon@sbuilders.com>
|
|
|
|
Date: Mar 1999
|
|
|
|
|
|
|
|
This file is part of the GNUstep Web Library.
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Library General Public
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
version 2 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
Library General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
|
|
License along with this library; if not, write to the Free
|
|
|
|
Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
static char rcsId[] = "$Id$";
|
|
|
|
|
2000-10-30 15:36:50 +00:00
|
|
|
#include <GSWeb/GSWeb.h>
|
2000-01-22 12:49:49 +00:00
|
|
|
#include "GSWSessionTimeOut.h"
|
|
|
|
|
|
|
|
//====================================================================
|
|
|
|
@implementation GSWSessionTimeOutManager
|
|
|
|
-(id)init
|
|
|
|
{
|
|
|
|
//OK
|
|
|
|
if ((self=[super init]))
|
|
|
|
{
|
|
|
|
sessionOrderedTimeOuts=[[NSMutableOrderedArray alloc]initWithCompareSelector:@selector(compareTimeOutDate:)];
|
|
|
|
sessionTimeOuts=[NSMutableDictionary new];
|
|
|
|
// selfLock=[NSRecursiveLock new];
|
|
|
|
selfLock=[NSLock new];
|
|
|
|
};
|
|
|
|
return self;
|
|
|
|
};
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
-(void)dealloc
|
|
|
|
{
|
2001-03-11 Manuel Guesdon <mguesdon@orange-concept.com>
* GSWeb.framework/GSWWOCompatibility.h/.m: added
* GSWeb.framework/GNUmakefile: added GSWWOCompatibility.h/.m
* GSWeb.framework/GSWApplication.h/m: added WOApplicationMain, handle WO/GSWeb names
* GSWeb.framework/GSWContext.m: handle WO/GSWeb names, added traces
* GSWeb.framework/GSWConstants.h/.m: handle WO/GSWeb names
* GSWeb.framework/GSWDynamicURLString.m: handle WO/GSWeb names
* GSWeb.framework/GSWProjectBundle.m/.h: handle WO/GSWeb names, suppress warnings
* GSWeb.framework/GSWSession.m: handle WO/GSWeb names
* GSWeb.framework/GSWRequest.m: handle WO/GSWeb names
* GSWeb.framework/GSWTemplateParser.m: handle WO/GSWeb names,
added tag counts to help errors hunt
* GSWeb.framework/GSWBundle.m: handle WO/GSWeb names, added traces
* GSWeb.framework/GSWResourceManager.m: handle WO/GSWeb names
* GSWeb.framework/GSWURLValuedElementData.m: handle WO/GSWeb names
* GSWeb.framework/GSWComponentRequestHandler.m: handle WO/GSWeb names
* GSWeb.framework/GSWDirectAction.m: handle WO/GSWeb names
* GSWeb.framework/GSWForm.m/.h: handle WO/GSWeb names
* GSWeb.framework/GSWHyperlink.m/.h: handle WO/GSWeb names
* GSWeb.framework/GSWResourceRequestHandler.m: handle WO/GSWeb names
* GSWeb.framework/GSWDirectActionRequestHandler.m: handle WO/GSWeb names
* GSWeb.framework/GSWActiveImage.m/.h: handle WO/GSWeb names
* GSWeb.framework/GSWBindingNameAssociation.h/.m: handle WO/GSWeb names
* GSWeb.framework/GSWBrowser.h/.m: handle WO/GSWeb names
* GSWeb.framework/GSWComponent.h/.m: handle WO/GSWeb names
* GSWeb.framework/GSWHTMLURLValuedElement.h/.m: handle WO/GSWeb names
* GSWeb.framework/GSWImageButton.h/.m: handle WO/GSWeb names
* GSWeb.framework/GSWInput.h/.m: handle WO/GSWeb names
* GSWeb.framework/GSWPopUpButton.h/.m: handle WO/GSWeb names
* GSWeb.framework/GSWString.h/.m: handle WO/GSWeb names
* GSWeb.framework/GSWAssociation.m: handle WO/GSWeb names
* GSWeb.framework/GSWCheckBox.m: handle WO/GSWeb names
* GSWeb.framework/GSWCheckBoxList.m: handle WO/GSWeb names
* GSWeb.framework/GSWComponentDefinition.m: handle WO/GSWeb names
* GSWeb.framework/GSWRadioButton.m: handle WO/GSWeb names
* GSWeb.framework/GSWRadioButtonList.m: handle WO/GSWeb names
* GSWeb.framework/GSWText.m: handle WO/GSWeb names
* GSWeb.framework/GSWTextField.m: handle WO/GSWeb names
* GSWeb.framework/GSWDeployedBundle.m: warnings
* GSWeb.framework/GSWeb.h: added include GSWeb/GSWSessionTimeOut.h, GSWWOCompatibility.h
* GSWeb.framework/GSWAdaptor.m: traces
* GSWeb.framework/GSWDefaultAdaptor.m: handle WO/GSWeb names, added traces
* GSWeb.framework/GSWDefaultAdaptorThread.m/.h: handle WO/GSWeb names
* GSWeb.framework/NSNonBlockingFileHandle.m: added traces
* GSWeb.framework/GSWTemplateParserANTLR.m: handle WO/GSWeb names
* GSWeb.framework/GSWTemplateParserXML.m: handle WO/GSWeb names
added tag count to help errors hunt
remove "Tag gsweb invalid" message
handle unicode strings in node content traces
remove html and body tags if they are not present in the template
* GSWeb.framework/GSWTemplateParseXML.h: added ivar _isHTMLTag, _isBodyTag
* GSWeb.framework/GSWSessionTimeOutManager.m: dealloc sessionOrderedTimeOuts instead
of deallocating 2 times sessionTimeOuts
* GSWExtensions.framework/French.lproj/GSWSessionRestorationErrorPage.gswc/GSWSessionRestorationErrorPage.html:
tag mismatch, Encode french characters
* GSWExtensions.framework/GSWSessionRestorationErrorPage.gswc/GSWSessionRestorationErrorPage.html:
tag mismatch
* GSWHTMLBareString.m: handle unicode strings in description
* GSWExtensions.framework/French.lproj/GSWExceptionPage.gswc/GSWExceptionPage.html:
Encode french characters, Tag Mismatch
* GSWExtensions.framework/French.lproj/GSWPageRestorationErrorPage.gswc/GSWPageRestorationErrorPage.html:
Encode french characters
* GSWExtensions.framework/French.lproj/GSWSessionCreationErrorPage.gswc/GSWSessionCreationErrorPage.html:
Encode french characters
* GSWExtensions.framework/GSWExceptionPage.gswc/GSWExceptionPage.html:
Tag Mismatch
* GSWExtensions.framework/GSWExceptionPage.gswc/GSWExceptionPage.gswd:
added convertHTMLEntities for strings
* GSWeb.framework/GSWRepetition.m: added traces, fix "count" property bug, standardize ivars
* GSWeb.framework/NSObject+IVarAccess+PerformSel.m: added traces, handle underscored ivars search
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gsweb/trunk@9332 72102866-910b-0410-8b05-ffd578937521
2001-03-11 17:15:44 +00:00
|
|
|
DESTROY(sessionOrderedTimeOuts);
|
2000-01-22 12:49:49 +00:00
|
|
|
DESTROY(sessionTimeOuts);
|
|
|
|
//Do Not Retain ! DESTROY(target);
|
|
|
|
DESTROY(timer);
|
|
|
|
DESTROY(selfLock);
|
|
|
|
[super dealloc];
|
|
|
|
};
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
-(void)updateTimeOutForSessionWithID:(NSString*)sessionID_
|
|
|
|
timeOut:(NSTimeInterval)timeOut_
|
|
|
|
{
|
|
|
|
//OK
|
|
|
|
LOGObjectFnStart();
|
|
|
|
[self lock];
|
|
|
|
NS_DURING
|
|
|
|
{
|
|
|
|
NSTimer* _timer=nil;
|
|
|
|
GSWSessionTimeOut* _sessionTimeOut=nil;
|
|
|
|
NSDebugMLLog(@"sessions",@"timeOut_=%ld",(long)timeOut_);
|
|
|
|
_sessionTimeOut=[sessionTimeOuts objectForKey:sessionID_];
|
|
|
|
NSDebugMLLog(@"sessions",@"_sessionTimeOut=%@",_sessionTimeOut);
|
|
|
|
NSDebugMLLog(@"sessions",@"sessionOrderedTimeOuts=%@",sessionOrderedTimeOuts);
|
|
|
|
if (_sessionTimeOut)
|
|
|
|
{
|
|
|
|
[_sessionTimeOut retain];
|
|
|
|
[sessionOrderedTimeOuts removeObject:_sessionTimeOut];
|
|
|
|
[_sessionTimeOut setLastAccessTime:[NSDate timeIntervalSinceReferenceDate]];
|
|
|
|
if (timeOut_!=[_sessionTimeOut sessionTimeOut])
|
|
|
|
[_sessionTimeOut setSessionTimeOut:timeOut_];
|
|
|
|
[sessionOrderedTimeOuts addObject:_sessionTimeOut];
|
|
|
|
[_sessionTimeOut release];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
_sessionTimeOut=[GSWSessionTimeOut timeOutWithSessionID:sessionID_
|
|
|
|
lastAccessTime:[NSDate timeIntervalSinceReferenceDate]
|
|
|
|
sessionTimeOut:timeOut_];
|
|
|
|
[sessionTimeOuts setObject:_sessionTimeOut
|
|
|
|
forKey:sessionID_];
|
|
|
|
[sessionOrderedTimeOuts addObject:_sessionTimeOut];
|
|
|
|
};
|
|
|
|
NSDebugMLLog(@"sessions",@"sessionOrderedTimeOuts=%@",sessionOrderedTimeOuts);
|
|
|
|
NSDebugMLLog(@"sessions",@"_sessionTimeOut=%@",_sessionTimeOut);
|
|
|
|
_timer=[self resetTimer];
|
|
|
|
NSDebugMLLog(@"sessions",@"_timer=%@",_timer);
|
|
|
|
if (_timer)
|
|
|
|
{
|
2000-03-20 15:50:51 +00:00
|
|
|
[GSWApplication logWithFormat:@"lock Target..."];
|
2000-01-22 12:49:49 +00:00
|
|
|
[target lock];
|
|
|
|
NS_DURING
|
|
|
|
{
|
|
|
|
[self addTimer:_timer];
|
|
|
|
}
|
|
|
|
NS_HANDLER
|
|
|
|
{
|
|
|
|
LOGException(@"%@ (%@)",localException,[localException reason]);
|
|
|
|
//TODO
|
|
|
|
[target unlock];
|
|
|
|
[self unlock];
|
|
|
|
[localException raise];
|
|
|
|
}
|
|
|
|
NS_ENDHANDLER;
|
|
|
|
|
2000-03-20 15:50:51 +00:00
|
|
|
[GSWApplication logWithFormat:@"unlock Target..."];
|
2000-01-22 12:49:49 +00:00
|
|
|
[target unlock];
|
|
|
|
};
|
|
|
|
}
|
|
|
|
NS_HANDLER
|
|
|
|
{
|
|
|
|
LOGException(@"%@ (%@)",localException,[localException reason]);
|
|
|
|
//TODO
|
|
|
|
[self unlock];
|
|
|
|
[localException raise];
|
|
|
|
}
|
|
|
|
NS_ENDHANDLER;
|
|
|
|
[self unlock];
|
|
|
|
LOGObjectFnStop();
|
|
|
|
};
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
-(void)handleTimer:(id)timer_
|
|
|
|
{
|
|
|
|
//OK
|
2000-03-20 15:50:51 +00:00
|
|
|
[GSWApplication statusLogWithFormat:@"Start HandleTimer"];
|
2000-01-22 12:49:49 +00:00
|
|
|
// LOGObjectFnStart();
|
|
|
|
[GSWApp lockRequestHandling];
|
|
|
|
NS_DURING
|
|
|
|
{
|
|
|
|
[self lock];
|
|
|
|
NS_DURING
|
|
|
|
{
|
|
|
|
GSWSessionTimeOut* _sessionTimeOut=nil;
|
|
|
|
NSTimeInterval _now=[NSDate timeIntervalSinceReferenceDate];
|
|
|
|
NSTimer* _timer=nil;
|
|
|
|
int _removedNb=0;
|
|
|
|
if ([sessionOrderedTimeOuts count]>0)
|
|
|
|
_sessionTimeOut=[sessionOrderedTimeOuts objectAtIndex:0];
|
|
|
|
while (/*_removedNb<20 && */_sessionTimeOut && [_sessionTimeOut timeOutTime]<_now)
|
|
|
|
{
|
|
|
|
id _session=nil;
|
|
|
|
[target lock];
|
|
|
|
NS_DURING
|
|
|
|
{
|
|
|
|
_session=[target performSelector:callback
|
|
|
|
withObject:[_sessionTimeOut sessionID]];
|
|
|
|
NSDebugMLLog(@"sessions",@"_session=%@",_session);
|
|
|
|
}
|
|
|
|
NS_HANDLER
|
|
|
|
{
|
|
|
|
LOGException(@"%@ (%@)",localException,[localException reason]);
|
|
|
|
//TODO
|
|
|
|
[target unlock];
|
|
|
|
|
|
|
|
_timer=[self resetTimer];
|
|
|
|
if (_timer)
|
|
|
|
[self addTimer:_timer];
|
|
|
|
|
|
|
|
[self unlock];
|
|
|
|
[GSWApp unlockRequestHandling];
|
|
|
|
[localException raise];
|
|
|
|
}
|
|
|
|
NS_ENDHANDLER;
|
|
|
|
[target unlock];
|
|
|
|
|
|
|
|
if (_session)
|
|
|
|
{
|
|
|
|
NSDebugMLLog(@"sessions",@"sessionOrderedTimeOuts=%@",sessionOrderedTimeOuts);
|
|
|
|
[_session terminate];
|
|
|
|
NSDebugMLLog(@"sessions",@"sessionOrderedTimeOuts=%@",sessionOrderedTimeOuts);
|
|
|
|
[sessionOrderedTimeOuts removeObjectAtIndex:0];
|
|
|
|
NSDebugMLLog(@"sessions",@"sessionOrderedTimeOuts=%@",sessionOrderedTimeOuts);
|
|
|
|
_removedNb++;
|
|
|
|
if ([sessionOrderedTimeOuts count]>0)
|
|
|
|
_sessionTimeOut=[sessionOrderedTimeOuts objectAtIndex:0];
|
|
|
|
else
|
|
|
|
_sessionTimeOut=nil;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
_sessionTimeOut=nil;
|
|
|
|
};
|
|
|
|
|
|
|
|
_timer=[self resetTimer];
|
|
|
|
if (_timer)
|
|
|
|
[self addTimer:_timer];
|
|
|
|
}
|
|
|
|
NS_HANDLER
|
|
|
|
{
|
|
|
|
LOGException(@"%@ (%@)",localException,[localException reason]);
|
|
|
|
//TODO
|
|
|
|
[self unlock];
|
|
|
|
[GSWApp unlockRequestHandling];
|
|
|
|
[localException raise];
|
|
|
|
};
|
|
|
|
NS_ENDHANDLER;
|
|
|
|
NSDebugMLLog(@"sessions",@"sessionOrderedTimeOuts=%@",sessionOrderedTimeOuts);
|
|
|
|
[self unlock];
|
|
|
|
}
|
|
|
|
NS_HANDLER
|
|
|
|
{
|
|
|
|
LOGException(@"%@ (%@)",localException,[localException reason]);
|
|
|
|
//TODO
|
|
|
|
[GSWApp unlockRequestHandling];
|
|
|
|
[localException raise];
|
|
|
|
};
|
|
|
|
NS_ENDHANDLER;
|
|
|
|
[GSWApp unlockRequestHandling];
|
|
|
|
// LOGObjectFnStop();
|
2000-03-20 15:50:51 +00:00
|
|
|
[GSWApplication statusLogWithFormat:@"Stop HandleTimer"];
|
2000-01-22 12:49:49 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
-(NSTimer*)resetTimer
|
|
|
|
{
|
|
|
|
NSTimer* _newTimer=nil;
|
|
|
|
GSWSessionTimeOut* _sessionTimeOut=nil;
|
|
|
|
LOGObjectFnStart();
|
|
|
|
// [self lock];
|
|
|
|
NS_DURING
|
|
|
|
{
|
|
|
|
NSTimeInterval _now=[NSDate timeIntervalSinceReferenceDate];
|
|
|
|
NSTimeInterval _timerFireTimeInterval=[[timer fireDate]timeIntervalSinceReferenceDate];
|
|
|
|
|
|
|
|
NSDebugMLLog(@"sessions",@"sessionOrderedTimeOuts=%@",sessionOrderedTimeOuts);
|
|
|
|
if ([sessionOrderedTimeOuts count]>0)
|
|
|
|
{
|
|
|
|
_sessionTimeOut=[sessionOrderedTimeOuts objectAtIndex:0];
|
|
|
|
NSDebugMLLog(@"sessions",@"_sessionTimeOut=%@",_sessionTimeOut);
|
|
|
|
NSDebugMLLog(@"sessions",@"[timer fireDate]=%@",[timer fireDate]);
|
|
|
|
NSDebugMLLog(@"sessions",@"[old timer isValide]=%s",
|
|
|
|
[timer isValid] ? "YES" : "NO");
|
|
|
|
if (_sessionTimeOut
|
|
|
|
&& (![timer isValid]
|
|
|
|
|| [_sessionTimeOut timeOutTime]<_timerFireTimeInterval
|
|
|
|
|| _timerFireTimeInterval<_now))
|
|
|
|
{
|
|
|
|
NSTimeInterval _timerTimeInterval=[_sessionTimeOut timeOutTime]-_now;
|
|
|
|
NSDebugMLLog(@"sessions",@"_timerTimeInterval=%ld",(long)_timerTimeInterval);
|
|
|
|
_timerTimeInterval=max(_timerTimeInterval,10);//20s minimum
|
|
|
|
NSDebugMLLog(@"sessions",@"_timerTimeInterval=%ld",(long)_timerTimeInterval);
|
|
|
|
_newTimer=[NSTimer timerWithTimeInterval:_timerTimeInterval
|
|
|
|
target:self
|
|
|
|
selector:@selector(handleTimer:)
|
|
|
|
userInfo:nil
|
|
|
|
repeats:NO];
|
|
|
|
NSDebugMLLog(@"sessions",@"old timer=%@",timer);
|
|
|
|
NSDebugMLLog(@"sessions",@"new timer=%@",_newTimer);
|
|
|
|
//If timer is a repeat one (anormal) or will be fired in the future
|
|
|
|
NSDebugMLLog(@"sessions",@"[old timer fireDate]=%@",
|
|
|
|
[timer fireDate]);
|
|
|
|
NSDebugMLLog(@"sessions",@"[old timer isValide]=%s",
|
|
|
|
[timer isValid] ? "YES" : "NO");
|
|
|
|
/*
|
|
|
|
if (timer && [[timer fireDate]compare:[NSDate date]]==NSOrderedDescending)
|
|
|
|
[timer invalidate];
|
|
|
|
*/
|
|
|
|
ASSIGN(timer,_newTimer);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
else
|
|
|
|
ASSIGN(timer,_newTimer);
|
|
|
|
}
|
|
|
|
NS_HANDLER
|
|
|
|
{
|
|
|
|
LOGException(@"%@ (%@)",localException,[localException reason]);
|
|
|
|
//TODO
|
|
|
|
// [self unlock];
|
|
|
|
[localException raise];
|
|
|
|
}
|
|
|
|
NS_ENDHANDLER;
|
|
|
|
// [self unlock];
|
|
|
|
LOGObjectFnStop();
|
|
|
|
return _newTimer;
|
|
|
|
};
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
-(void)addTimer:(NSTimer*)timer_
|
|
|
|
{
|
|
|
|
//OK
|
|
|
|
LOGObjectFnStart();
|
|
|
|
[GSWApp addTimer:timer];
|
|
|
|
LOGObjectFnStop();
|
|
|
|
};
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
-(void)removeCallBack
|
|
|
|
{
|
|
|
|
target=nil;
|
|
|
|
callback=NULL;
|
|
|
|
};
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
-(void)setCallBack:(SEL)callback_
|
|
|
|
target:(id)target_
|
|
|
|
{
|
|
|
|
//OK
|
|
|
|
target=target_; //Do not retain !
|
|
|
|
callback=callback_;
|
|
|
|
};
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
-(void)lock
|
|
|
|
{
|
|
|
|
LOGObjectFnStart();
|
|
|
|
NSDebugMLLog(@"sessions",@"selfLockn=%d",selfLockn);
|
|
|
|
TmpLockBeforeDate(selfLock,[NSDate dateWithTimeIntervalSinceNow:GSLOCK_DELAY_S]);
|
|
|
|
#ifndef NDEBUG
|
|
|
|
selfLockn++;
|
|
|
|
#endif
|
|
|
|
NSDebugMLLog(@"sessions",@"selfLockn=%d",selfLockn);
|
|
|
|
LOGObjectFnStop();
|
|
|
|
};
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------
|
|
|
|
-(void)unlock
|
|
|
|
{
|
|
|
|
LOGObjectFnStart();
|
|
|
|
NSDebugMLLog(@"sessions",@"selfLockn=%d",selfLockn);
|
|
|
|
TmpUnlock(selfLock);
|
|
|
|
#ifndef NDEBUG
|
|
|
|
selfLockn--;
|
|
|
|
#endif
|
|
|
|
NSDebugMLLog(@"sessions",@"selfLockn=%d",selfLockn);
|
|
|
|
LOGObjectFnStop();
|
|
|
|
};
|
|
|
|
|
|
|
|
@end
|