Fork of WebGUI 7.10, maintained by Oqapi
https://git.oqapi.nl/oqapi/webgui
New API method: WebGUI::Response::sendFile; it, as appropriate, calls setRedirect or setStreamedFile, depending on enableStreamingUploads config var. setStreamedFile now kicks off the XSendfile process. File.pm now uses this instead of trying to set both a redirect and a stream. IO::File::WithPath blows up if a file doesn't exist so this raises an exception now. The http now no longer insist that '0' is not a valid filename to stream. site.psgi, depending on enableStreamingUploads, enables either the Static or XSendfile middleware. |
||
|---|---|---|
| docs | ||
| eg | ||
| etc | ||
| lib | ||
| sbin | ||
| share | ||
| t | ||
| www | ||
| .gitignore | ||
| .perltidyrc | ||
| .proverc | ||
| app.psgi | ||
| asset_status.ods | ||
| benchmark.pl | ||
| README | ||
| TODO | ||
| WebGUI-Session-Plack.pm | ||
This is the PSGI branch of WebGUI8 To try this out: 0) Start from WebGUI 7.10.4 or the example .conf and create.sql that comes with WebGUI 8 1) Run testEnvironment.pl to install Plack 2) Get a new wgd from http://haarg.org/wgd 3) $ wgd reset --upgrade 4) $ cd /data/WebGUI (or whereever you unpacked it) 5) $ rsync -r -a (or cp -a) /data/WebGUI/www/extras /data/domains/www.example.com/public/ 6) $ export PERL5LIB='/data/WebGUI/lib:/data/WebGUI/t/lib' To start it: 7) $ plackup app.psgi See docs/install.txt for more detailed installation instructions. Currently, the best performance is achieved via: plackup -E none -s Starman --workers 10 --disable-keepalive You can benchmark your server via: ab -t 3 -c 10 -k http://dev.localhost.localdomain:5000/ | grep Req I'm currently getting 370 requests/second, whereas I'm getting 430/second on the non-PSGI WebGUI8 branch. = ARCHITECTURE = * The root level app.psgi file loads all the config files found and loads the site specific psgi file for each, linking them to the proper host names. * The site psgi file uses the WEBGUI_CONFIG environment variable to find the config. * It instantiates the $wg WebGUI object (one per app). * $wg creates and stores the WebGUI::Config (one per app) * $wg creates the $app PSGI app code ref (one per app) * WebGUI::Middleware::Session is wrapped around $app at the outer-most layer so that it can open and close the $session WebGUI::Session. Any other wG middleware that needs $session should go in between it and $app ($session created one per request) * $session creates the $request WebGUI::Session::Request and $response WebGUI::Session::Response objects (one per request)