2019-01-08 12:48:27 +01:00
|
|
|
unit WebModuleU;
|
|
|
|
|
|
|
|
interface
|
|
|
|
|
|
|
|
uses
|
|
|
|
System.SysUtils,
|
|
|
|
System.Classes,
|
|
|
|
Web.HTTPApp,
|
|
|
|
MVCFramework;
|
|
|
|
|
|
|
|
type
|
|
|
|
TMyWebModule = class(TWebModule)
|
|
|
|
procedure WebModuleCreate(Sender: TObject);
|
|
|
|
procedure WebModuleDestroy(Sender: TObject);
|
|
|
|
private
|
|
|
|
FMVC: TMVCEngine;
|
|
|
|
public
|
|
|
|
{ Public declarations }
|
|
|
|
end;
|
|
|
|
|
|
|
|
var
|
|
|
|
WebModuleClass: TComponentClass = TMyWebModule;
|
|
|
|
|
|
|
|
implementation
|
|
|
|
|
|
|
|
{$R *.dfm}
|
|
|
|
|
2019-01-18 19:35:37 +01:00
|
|
|
|
2019-01-08 12:48:27 +01:00
|
|
|
uses
|
|
|
|
MainControllerU,
|
|
|
|
System.IOUtils,
|
|
|
|
MVCFramework.Commons,
|
|
|
|
LoggerPro.FileAppender,
|
|
|
|
LoggerPro,
|
|
|
|
MVCFramework.Middleware.Analytics;
|
|
|
|
|
|
|
|
var
|
|
|
|
GLogWriter: ILogWriter = nil;
|
|
|
|
GLock: TObject = nil;
|
|
|
|
|
|
|
|
function GetLoggerForAnalytics: ILogWriter;
|
2019-01-18 19:35:37 +01:00
|
|
|
var
|
|
|
|
lLog: ILogAppender;
|
2019-01-08 12:48:27 +01:00
|
|
|
begin
|
|
|
|
if GLogWriter = nil then
|
|
|
|
begin
|
|
|
|
TMonitor.Enter(GLock);
|
|
|
|
try
|
|
|
|
if GLogWriter = nil then // double check locking (https://en.wikipedia.org/wiki/Double-checked_locking)
|
|
|
|
begin
|
2019-01-18 19:35:37 +01:00
|
|
|
lLog := TLoggerProFileAppender.Create(5, 2000, AppPath + 'analytics', [], '%s.%2.2d.%s.csv');
|
|
|
|
TLoggerProFileAppender(lLog).OnLogRow := procedure(const LogItem: TLogItem; out LogRow: string)
|
|
|
|
begin
|
|
|
|
LogRow := Format('%s;%s;%s;%s', [datetimetostr(LogItem.TimeStamp),
|
|
|
|
LogItem.LogTypeAsString, LogItem.LogMessage, LogItem.LogTag]);
|
|
|
|
end;
|
|
|
|
GLogWriter := BuildLogWriter([lLog]);
|
2019-01-08 12:48:27 +01:00
|
|
|
end;
|
|
|
|
finally
|
|
|
|
TMonitor.Exit(GLock);
|
|
|
|
end;
|
|
|
|
end;
|
|
|
|
Result := GLogWriter;
|
|
|
|
end;
|
|
|
|
|
|
|
|
procedure TMyWebModule.WebModuleCreate(Sender: TObject);
|
|
|
|
begin
|
|
|
|
FMVC := TMVCEngine.Create(Self,
|
|
|
|
procedure(Config: TMVCConfig)
|
|
|
|
begin
|
|
|
|
// enable static files
|
|
|
|
Config[TMVCConfigKey.DocumentRoot] := TPath.Combine(ExtractFilePath(GetModuleName(HInstance)), 'www');
|
|
|
|
// session timeout (0 means session cookie)
|
|
|
|
Config[TMVCConfigKey.SessionTimeout] := '0';
|
|
|
|
// default content-type
|
|
|
|
Config[TMVCConfigKey.DefaultContentType] := TMVCConstants.DEFAULT_CONTENT_TYPE;
|
|
|
|
// default content charset
|
|
|
|
Config[TMVCConfigKey.DefaultContentCharset] := TMVCConstants.DEFAULT_CONTENT_CHARSET;
|
|
|
|
// unhandled actions are permitted?
|
|
|
|
Config[TMVCConfigKey.AllowUnhandledAction] := 'false';
|
|
|
|
// default view file extension
|
|
|
|
Config[TMVCConfigKey.DefaultViewFileExtension] := 'html';
|
|
|
|
// view path
|
|
|
|
Config[TMVCConfigKey.ViewPath] := 'templates';
|
|
|
|
// Enable Server Signature in response
|
|
|
|
Config[TMVCConfigKey.ExposeServerSignature] := 'false';
|
|
|
|
// Define a default URL for requests that don't map to a route or a file (useful for client side web app)
|
|
|
|
Config[TMVCConfigKey.FallbackResource] := 'index.html';
|
|
|
|
end);
|
|
|
|
FMVC.AddController(TMainController).AddMiddleware(TMVCAnalyticsMiddleware.Create(GetLoggerForAnalytics));
|
|
|
|
end;
|
|
|
|
|
|
|
|
procedure TMyWebModule.WebModuleDestroy(Sender: TObject);
|
|
|
|
begin
|
|
|
|
FMVC.Free;
|
|
|
|
end;
|
|
|
|
|
|
|
|
initialization
|
|
|
|
|
|
|
|
GLock := TObject.Create;
|
|
|
|
|
|
|
|
finalization
|
|
|
|
|
|
|
|
GLock.Free;
|
|
|
|
|
|
|
|
end.
|