mirror of
https://github.com/gnustep/libs-gsweb.git
synced 2025-05-30 16:50:52 +00:00
2002-08-04 Manuel Guesdon <mguesdon@orange-concept.com>
* GSWeb.framework/GSWEmbeddedObject.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWGenericContainer.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWDirectActionRequestHandler.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWDynamicURLString.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWBindingNameAssociation.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWComponentDefinition.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWComponentRequestHandler.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWConstantValueAssociation.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWDisplayGroup.h/.m o ivar names changes to conform to coding standards o include for TCSimpleDB/ * GSWeb.framework/GSWKeyValueAssociation.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWParam.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWRequestHandler.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWResourceRequestHandler.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/NSString+Trimming.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWStats.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/NSNonBlockingFileHandle.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/NSString+HTML.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWStatisticsStore.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWHTMLURLValuedElement.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWApplication.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWBundle.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWDeployedBundle.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWTemplateParserXML.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWHTMLParserExt.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWMultiKeyDictionary.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWProjectBundle.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWTemplateParser.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWPageDefElement.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWUtils.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWeb.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWWOCompatibility.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWQuickTime.h o ivar names changes to conform to coding standards * GSWeb.framework/GSWTemplateParserANTLR.h/.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWDebug.m o ivar names changes to conform to coding standards * GSWeb.framework/GSWComponent.m o NSAsserts git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gsweb/trunk@14234 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
parent
f87b59dfca
commit
1e53c66863
77 changed files with 9292 additions and 8659 deletions
|
@ -1,11 +1,16 @@
|
|||
/* GSWDirectActionRequestHandler.m - GSWeb: Class GSWDirectActionRequestHandler
|
||||
Copyright (C) 1999 Free Software Foundation, Inc.
|
||||
/** GSWDirectActionRequestHandler.m - <title>GSWeb: Class GSWDirectActionRequestHandler</title>
|
||||
|
||||
Copyright (C) 1999-2002 Free Software Foundation, Inc.
|
||||
|
||||
Written by: Manuel Guesdon <mguesdon@sbuilders.com>
|
||||
Date: Feb 1999
|
||||
Written by: Manuel Guesdon <mguesdon@orange-concept.com>
|
||||
Date: Feb 1999
|
||||
|
||||
$Revision$
|
||||
$Date$
|
||||
|
||||
This file is part of the GNUstep Web Library.
|
||||
|
||||
<license>
|
||||
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
|
||||
|
@ -19,7 +24,8 @@
|
|||
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.
|
||||
*/
|
||||
</license>
|
||||
**/
|
||||
|
||||
static char rcsId[] = "$Id$";
|
||||
|
||||
|
@ -29,171 +35,176 @@ static char rcsId[] = "$Id$";
|
|||
@implementation GSWDirectActionRequestHandler
|
||||
|
||||
//--------------------------------------------------------------------
|
||||
-(GSWResponse*)handleRequest:(GSWRequest*)request_
|
||||
-(GSWResponse*)handleRequest:(GSWRequest*)aRequest
|
||||
{
|
||||
//OK
|
||||
GSWResponse* _response=nil;
|
||||
GSWStatisticsStore* _statisticsStore=nil;
|
||||
GSWApplication* _application=nil;
|
||||
GSWResponse* response=nil;
|
||||
GSWStatisticsStore* statisticsStore=nil;
|
||||
GSWApplication* application=nil;
|
||||
LOGObjectFnStart();
|
||||
_application=[GSWApplication application];
|
||||
if (0/*[_application isRefusingNewSessions]*/)
|
||||
{
|
||||
//TODO
|
||||
}
|
||||
application=[GSWApplication application];
|
||||
if (0/*[application isRefusingNewSessions]*/)
|
||||
{
|
||||
//TODO
|
||||
}
|
||||
else
|
||||
{
|
||||
id _submitButtonsActionPathFromRequest=nil;
|
||||
NSArray* _requestHandlerPathArray=nil;
|
||||
NSString* _actionName=nil;
|
||||
NSString* _className=nil;
|
||||
GSWContext* _context=nil;
|
||||
[_application lockRequestHandling];
|
||||
NS_DURING
|
||||
{
|
||||
id submitButtonsActionPathFromRequest=nil;
|
||||
NSArray* requestHandlerPathArray=nil;
|
||||
NSString* actionName=nil;
|
||||
NSString* className=nil;
|
||||
GSWContext* context=nil;
|
||||
[application lockRequestHandling];
|
||||
NS_DURING
|
||||
{
|
||||
NS_DURING
|
||||
{
|
||||
NS_DURING
|
||||
statisticsStore=[[GSWApplication application]statisticsStore];
|
||||
[statisticsStore _applicationWillHandleDirectActionRequest];
|
||||
submitButtonsActionPathFromRequest=[self submitButtonsActionPathFromRequest:aRequest]; //So what ?
|
||||
NSDebugMLLog(@"requests",@"submitButtonsActionPathFromRequest=%@",
|
||||
submitButtonsActionPathFromRequest);
|
||||
requestHandlerPathArray=[aRequest requestHandlerPathArray];
|
||||
NSDebugMLLog(@"requests",@"requestHandlerPathArray=%@",
|
||||
requestHandlerPathArray);
|
||||
switch([requestHandlerPathArray count])
|
||||
{
|
||||
_statisticsStore=[[GSWApplication application]statisticsStore];
|
||||
[_statisticsStore _applicationWillHandleDirectActionRequest];
|
||||
_submitButtonsActionPathFromRequest=[self submitButtonsActionPathFromRequest:request_]; //So what ?
|
||||
NSDebugMLLog(@"requests",@"_submitButtonsActionPathFromRequest=%@",_submitButtonsActionPathFromRequest);
|
||||
_requestHandlerPathArray=[request_ requestHandlerPathArray];
|
||||
NSDebugMLLog(@"requests",@"_requestHandlerPathArray=%@",_requestHandlerPathArray);
|
||||
switch([_requestHandlerPathArray count])
|
||||
{
|
||||
case 0:
|
||||
_actionName=@"default";
|
||||
_className=@"DirectAction";
|
||||
break;
|
||||
case 1:
|
||||
case 0:
|
||||
actionName=@"default";
|
||||
className=@"DirectAction";
|
||||
break;
|
||||
case 1:
|
||||
{
|
||||
NSString* tmpActionName=[NSString stringWithFormat:@"%@Action",
|
||||
[requestHandlerPathArray objectAtIndex:0]];
|
||||
SEL tmpActionSel=NSSelectorFromString(tmpActionName);
|
||||
Class aClass = NSClassFromString(@"DirectAction");
|
||||
NSDebugMLLog(@"requests",@"tmpActionName=%@",
|
||||
tmpActionName);
|
||||
if (tmpActionSel && aClass)
|
||||
{
|
||||
NSString* _tmpActionName=[NSString stringWithFormat:@"%@Action",
|
||||
[_requestHandlerPathArray objectAtIndex:0]];
|
||||
SEL _tmpActionSel=NSSelectorFromString(_tmpActionName);
|
||||
Class _class = NSClassFromString(@"DirectAction");
|
||||
NSDebugMLLog(@"requests",@"_tmpActionName=%@",_tmpActionName);
|
||||
if (_tmpActionSel && _class)
|
||||
if ([aClass instancesRespondToSelector:tmpActionSel])
|
||||
{
|
||||
if ([_class instancesRespondToSelector:_tmpActionSel])
|
||||
{
|
||||
_actionName=[_requestHandlerPathArray objectAtIndex:0];
|
||||
_className=@"DirectAction";
|
||||
};
|
||||
};
|
||||
if (!_actionName)
|
||||
{
|
||||
_className=[_requestHandlerPathArray objectAtIndex:0];
|
||||
_actionName=@"default";
|
||||
actionName=[requestHandlerPathArray objectAtIndex:0];
|
||||
className=@"DirectAction";
|
||||
};
|
||||
};
|
||||
break;
|
||||
case 2:
|
||||
_className=[_requestHandlerPathArray objectAtIndex:0];
|
||||
_actionName=[NSString stringWithFormat:@"%@",
|
||||
[_requestHandlerPathArray objectAtIndex:1]];
|
||||
break;
|
||||
default:
|
||||
ExceptionRaise0(@"GSWDirectActionRequestHandler",@"bad parameters count");
|
||||
break;
|
||||
};
|
||||
NSDebugMLLog(@"requests",@"_className=%@",_className);
|
||||
NSDebugMLLog(@"requests",@"_actionName=%@",_actionName);
|
||||
if ([_application isCachingEnabled])
|
||||
{
|
||||
//TODO
|
||||
};
|
||||
{
|
||||
GSWResourceManager* _resourceManager=nil;
|
||||
GSWDeployedBundle* _appBundle=nil;
|
||||
GSWDirectAction* _directAction=nil;
|
||||
id<GSWActionResults> _actionResult=nil;
|
||||
Class _class=nil;
|
||||
_resourceManager=[_application resourceManager];
|
||||
_appBundle=[_resourceManager _appProjectBundle];
|
||||
[_resourceManager _allFrameworkProjectBundles];//So what ?
|
||||
[_application awake];
|
||||
_class=NSClassFromString(_className);
|
||||
NSAssert1(_class,@"No direct action class named %@",_className);
|
||||
_directAction=[[_class alloc]initWithRequest:request_];
|
||||
NSAssert1(_directAction,@"Direct action of class named %@ can't be created",_className);
|
||||
_context=[_directAction _context];
|
||||
_actionResult=[_directAction performActionNamed:_actionName];
|
||||
_response=[_actionResult generateResponse];
|
||||
|
||||
//Finir ?
|
||||
};
|
||||
}
|
||||
NS_HANDLER
|
||||
{
|
||||
LOGException(@"%@ (%@)",localException,[localException reason]);
|
||||
if (!_context)
|
||||
_context=[GSWApp _context];
|
||||
_response=[_application handleException:localException
|
||||
inContext:_context];
|
||||
//TODO
|
||||
};
|
||||
NS_ENDHANDLER;
|
||||
NSDebugMLLog(@"requests",@"_response=%@",_response);
|
||||
RETAIN(_response);
|
||||
if (!_context)
|
||||
_context=[GSWApp _context];
|
||||
[_context _putAwakeComponentsToSleep];
|
||||
[_application saveSessionForContext:_context];
|
||||
NSDebugMLLog(@"requests",@"_response=%@",_response);
|
||||
AUTORELEASE(_response);
|
||||
|
||||
//Here ???
|
||||
[_application sleep];
|
||||
//TODO do not fnalize if already done (in handleException for exemple)
|
||||
[_response _finalizeInContext:_context];
|
||||
[_application _setContext:nil];
|
||||
_statisticsStore=[[GSWApplication application] statisticsStore];
|
||||
[_statisticsStore _applicationDidHandleDirectActionRequestWithActionNamed:_actionName];
|
||||
if (!actionName)
|
||||
{
|
||||
className=[requestHandlerPathArray objectAtIndex:0];
|
||||
actionName=@"default";
|
||||
};
|
||||
};
|
||||
break;
|
||||
case 2:
|
||||
className=[requestHandlerPathArray objectAtIndex:0];
|
||||
actionName=[NSString stringWithFormat:@"%@",
|
||||
[requestHandlerPathArray objectAtIndex:1]];
|
||||
break;
|
||||
default:
|
||||
ExceptionRaise0(@"GSWDirectActionRequestHandler",@"bad parameters count");
|
||||
break;
|
||||
};
|
||||
NSDebugMLLog(@"requests",@"className=%@",className);
|
||||
NSDebugMLLog(@"requests",@"actionName=%@",actionName);
|
||||
if ([application isCachingEnabled])
|
||||
{
|
||||
//TODO
|
||||
};
|
||||
{
|
||||
GSWResourceManager* resourceManager=nil;
|
||||
GSWDeployedBundle* appBundle=nil;
|
||||
GSWDirectAction* directAction=nil;
|
||||
id<GSWActionResults> actionResult=nil;
|
||||
Class aClass=nil;
|
||||
resourceManager=[application resourceManager];
|
||||
appBundle=[resourceManager _appProjectBundle];
|
||||
[resourceManager _allFrameworkProjectBundles];//So what ?
|
||||
[application awake];
|
||||
aClass=NSClassFromString(className);
|
||||
NSAssert1(aClass,@"No direct action class named %@",
|
||||
className);
|
||||
directAction=[[aClass alloc]initWithRequest:aRequest];
|
||||
NSAssert1(directAction,@"Direct action of class named %@ can't be created",
|
||||
className);
|
||||
context=[directAction _context];
|
||||
actionResult=[directAction performActionNamed:actionName];
|
||||
response=[actionResult generateResponse];
|
||||
|
||||
//Finir ?
|
||||
};
|
||||
}
|
||||
NS_HANDLER
|
||||
NS_HANDLER
|
||||
{
|
||||
LOGException(@"%@ (%@)",localException,[localException reason]);
|
||||
[_application unlockRequestHandling];
|
||||
[localException raise];//TODO
|
||||
if (!context)
|
||||
context=[GSWApp _context];
|
||||
response=[application handleException:localException
|
||||
inContext:context];
|
||||
//TODO
|
||||
};
|
||||
NS_ENDHANDLER;
|
||||
[_application unlockRequestHandling];
|
||||
};
|
||||
NS_ENDHANDLER;
|
||||
NSDebugMLLog(@"requests",@"response=%@",response);
|
||||
RETAIN(response);
|
||||
if (!context)
|
||||
context=[GSWApp _context];
|
||||
[context _putAwakeComponentsToSleep];
|
||||
[application saveSessionForContext:context];
|
||||
NSDebugMLLog(@"requests",@"response=%@",response);
|
||||
AUTORELEASE(response);
|
||||
|
||||
//Here ???
|
||||
[application sleep];
|
||||
//TODO do not fnalize if already done (in handleException for exemple)
|
||||
[response _finalizeInContext:context];
|
||||
[application _setContext:nil];
|
||||
statisticsStore=[[GSWApplication application] statisticsStore];
|
||||
[statisticsStore _applicationDidHandleDirectActionRequestWithActionNamed:actionName];
|
||||
}
|
||||
NS_HANDLER
|
||||
{
|
||||
LOGException(@"%@ (%@)",localException,[localException reason]);
|
||||
[application unlockRequestHandling];
|
||||
[localException raise];//TODO
|
||||
};
|
||||
NS_ENDHANDLER;
|
||||
[application unlockRequestHandling];
|
||||
};
|
||||
LOGObjectFnNotImplemented(); //TODOFN
|
||||
LOGObjectFnStop();
|
||||
return _response;
|
||||
return response;
|
||||
};
|
||||
|
||||
//--------------------------------------------------------------------
|
||||
-(GSWResponse*)_nilResponse
|
||||
{
|
||||
//OK
|
||||
GSWResponse* _response=nil;
|
||||
GSWResponse* response=nil;
|
||||
LOGObjectFnStart();
|
||||
_response=[[GSWResponse new]autorelease];
|
||||
[_response appendContentString:@"<HTML><HEAD><TITLE>DirectAction Error</TITLE></HEAD><BODY>The result of a direct action returned nothing.</BODY></HTML>"];
|
||||
response=[[GSWResponse new]autorelease];
|
||||
[response appendContentString:@"<HTML><HEAD><TITLE>DirectAction Error</TITLE></HEAD><BODY>The result of a direct action returned nothing.</BODY></HTML>"];
|
||||
LOGObjectFnStop();
|
||||
return _response;
|
||||
return response;
|
||||
};
|
||||
|
||||
//--------------------------------------------------------------------
|
||||
-(void)_initializeRequestSessionIDInContext:(GSWContext*)_context
|
||||
-(void)_initializeRequestSessionIDInContext:(GSWContext*)aContext
|
||||
{
|
||||
LOGObjectFnNotImplemented(); //TODOFN
|
||||
};
|
||||
|
||||
//--------------------------------------------------------------------
|
||||
-(id)submitButtonsActionPathFromRequest:(GSWRequest*)_request
|
||||
-(id)submitButtonsActionPathFromRequest:(GSWRequest*)aRequest
|
||||
{
|
||||
//OK
|
||||
NSArray* _submitActions=nil;
|
||||
NSArray* submitActions=nil;
|
||||
LOGObjectFnStart();
|
||||
_submitActions=[_request formValuesForKey:GSWKey_SubmitAction[GSWebNamingConv]];
|
||||
if (_submitActions)
|
||||
{
|
||||
//TODO
|
||||
};
|
||||
|
||||
submitActions=[aRequest formValuesForKey:GSWKey_SubmitAction[GSWebNamingConv]];
|
||||
if (submitActions)
|
||||
{
|
||||
//TODO
|
||||
};
|
||||
|
||||
LOGObjectFnNotImplemented(); //TODOFN
|
||||
LOGObjectFnStop();
|
||||
return nil;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue