On Sun, 5 Feb 2012, Joao Morais wrote:

Hello fpc-devel list.

I need to implement some customizations to the request and response
classes of the fastcgi implementation -- maybe others as well -- but
afaics I cannot override such classes without copy/paste the whole
FCGI.ProcessRecord method.

A draft of the implementation I'd like to see in the fcl-web is
described below. Is it possible to implement? Perhaps 2.6 branch?

It is possible to implement this, and I even have started the process.

However, I don't see the use of adding the abstract calls ?
Implementing this in src/base/custweb.pp gives the impression that you can use any TRequest/TResponse descendent, which definitely is not the case.

Each descendent needs to be sure that it gets the correct TRequest descendent.

I think it is sufficient to make sure that every webhandler has 2 virtual calls that create the correct descendents. You can then override these 2 virtual calls.

for instance in src/base/custfcgi.pp I would add

    function CreateRequest: TFCGIRequest; virtual;
    function CreateResponse(ARequest: TFCGIRequest): TFCGIResponse; virtual;

And similar functions in the other webhandler components.

I started on this procedure already.

For instance in custcgi, it is already implemented like that:

   Function CreateResponse(AOutput : TStream) : TCGIResponse; virtual;
   Function CreateRequest : TCGIRequest; virtual;

I just need to complete the work.

If you want, you can of course provide a patch that completes the work.

Michael.


Joao Morais



1. New virtual methods used to create requests and responses:

--- src/base/custweb.pp (revision 20261)
+++ src/base/custweb.pp (workcopy)
@@ -108,6 +108,8 @@
    Procedure SetBaseURL(AModule : TCustomHTTPModule; Const
AModuleName : String; ARequest : TRequest); virtual;
    function GetApplicationURL(ARequest : TRequest): String; virtual;
    procedure ShowRequestException(R: TResponse; E: Exception); virtual;
+    function CreateRequest: TRequest; virtual; abstract;
+    function CreateResponse(ARequest: TRequest): TResponse; virtual; abstract;
    Procedure InitRequest(ARequest : TRequest); virtual;
    Procedure InitResponse(AResponse : TResponse); virtual;
    Function GetEmail : String; virtual;

2. Patch every fcl-web implementation in order to use the virtual
method instead of a hardcoded class:

--- src/base/custfcgi.pp        (revision 20261)
+++ src/base/custfcgi.pp        (workcopy)
@@ -119,6 +119,8 @@
    function Read_FCGIRecord : PFCGI_Header;
    function DataAvailable : Boolean;
  protected
+    function CreateRequest: TRequest; override;
+    function CreateResponse(ARequest: TRequest): TResponse; override;
    Function DoFastCGIRead(AHandle : THandle; Var ABuf; ACount :
Integer) : Integer; virtual;
    Function DoFastCGIWrite(AHandle : THandle; Const ABuf; ACount :
Integer) : Integer; virtual;
    function  ProcessRecord(AFCGI_Record: PFCGI_Header; out ARequest:
TRequest;  out AResponse: TResponse): boolean; virtual;
@@ -793,6 +795,16 @@
end;
{$endif}

+function TFCgiHandler.CreateRequest: TRequest;
+begin
+  Result := TFCGIRequest.Create;
+end;
+
+function TFCgiHandler.CreateResponse(ARequest: TRequest): TResponse;
+begin
+  Result := TFCGIResponse.Create(ARequest);
+end;
+
function TFCgiHandler.DoFastCGIRead(AHandle: THandle; var ABuf;
ACount: Integer): Integer;
begin
{$ifdef windowspipe}
@@ -831,7 +843,7 @@
      end;
    assert(not assigned(FRequestsArray[ARequestID].Request));
    assert(not assigned(FRequestsArray[ARequestID].Response));
-    ATempRequest:=TFCGIRequest.Create;
+    ATempRequest:=CreateRequest as TFCGIRequest;
    InitRequest(ATempRequest);
    ATempRequest.RequestID:=ARequestID;
    ATempRequest.Handle:=FHandle;
@@ -848,7 +860,7 @@
  else if FRequestsArray[ARequestID].Request.ProcessFCGIRecord(AFCGI_Record)
then
    begin
    ARequest:=FRequestsArray[ARequestID].Request;
-    FRequestsArray[ARequestID].Response := TFCGIResponse.Create(ARequest);
+    FRequestsArray[ARequestID].Response := CreateResponse(ARequest)
as TFCGIResponse;
    InitResponse(FRequestsArray[ARequestID].Response);
    FRequestsArray[ARequestID].Response.ProtocolOptions:=Self.ProtocolOptions;
    FRequestsArray[ARequestID].Response.FOnWrite:=@DoFastCGIWrite;
_______________________________________________
fpc-devel maillist  -  fpc-devel@lists.freepascal.org
http://lists.freepascal.org/mailman/listinfo/fpc-devel

_______________________________________________
fpc-devel maillist  -  fpc-devel@lists.freepascal.org
http://lists.freepascal.org/mailman/listinfo/fpc-devel

Reply via email to