passenger 2.1.3 → 2.2.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of passenger might be problematic. Click here for more details.
- data/DEVELOPERS.TXT +2 -0
- data/INSTALL +3 -1
- data/LICENSE +19 -355
- data/NEWS +3 -0
- data/README +11 -4
- data/Rakefile +435 -236
- data/bin/passenger-config +20 -14
- data/bin/passenger-install-apache2-module +67 -201
- data/bin/passenger-install-nginx-module +477 -0
- data/bin/passenger-make-enterprisey +17 -12
- data/bin/passenger-memory-stats +33 -23
- data/bin/passenger-spawn-server +17 -12
- data/bin/passenger-status +18 -13
- data/bin/passenger-stress-test +17 -12
- data/doc/{Users guide.html → Users guide Apache.html } +79 -61
- data/doc/{Users guide.txt → Users guide Apache.txt } +43 -939
- data/doc/Users guide Nginx.html +2276 -0
- data/doc/Users guide Nginx.txt +776 -0
- data/doc/cxxapi/ApplicationPoolServer_8h-source.html +9 -4
- data/doc/cxxapi/ApplicationPool_8h-source.html +9 -4
- data/doc/cxxapi/Application_8h-source.html +26 -21
- data/doc/cxxapi/Bucket_8h-source.html +54 -44
- data/doc/cxxapi/CachedFileStat_8h-source.html +9 -4
- data/doc/cxxapi/Configuration_8h-source.html +357 -339
- data/doc/cxxapi/DirectoryMapper_8h-source.html +294 -280
- data/doc/cxxapi/DummySpawnManager_8h-source.html +9 -4
- data/doc/cxxapi/Exceptions_8h-source.html +9 -4
- data/doc/cxxapi/FileChecker_8h-source.html +9 -4
- data/doc/cxxapi/Hooks_8h-source.html +50 -40
- data/doc/cxxapi/Logging_8h-source.html +9 -4
- data/doc/cxxapi/MessageChannel_8h-source.html +20 -15
- data/doc/cxxapi/PoolOptions_8h-source.html +10 -5
- data/doc/cxxapi/SpawnManager_8h-source.html +9 -4
- data/doc/cxxapi/StandardApplicationPool_8h-source.html +10 -5
- data/doc/cxxapi/SystemTime_8h-source.html +9 -4
- data/doc/cxxapi/Utils_8h-source.html +242 -214
- data/doc/cxxapi/annotated.html +4 -28
- data/doc/cxxapi/classClient-members.html +4 -4
- data/doc/cxxapi/classClient.html +14 -11
- data/doc/cxxapi/classHooks-members.html +4 -5
- data/doc/cxxapi/classHooks.html +26 -24
- data/doc/cxxapi/classPassenger_1_1Application-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1Application.html +40 -37
- data/doc/cxxapi/classPassenger_1_1ApplicationPool-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1ApplicationPool.html +95 -92
- data/doc/cxxapi/classPassenger_1_1ApplicationPoolServer-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1ApplicationPoolServer.html +26 -23
- data/doc/cxxapi/classPassenger_1_1ApplicationPool__inherit__graph.map +1 -1
- data/doc/cxxapi/classPassenger_1_1ApplicationPool__inherit__graph.md5 +1 -1
- data/doc/cxxapi/classPassenger_1_1ApplicationPool__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1Application_1_1Session-members.html +17 -17
- data/doc/cxxapi/classPassenger_1_1Application_1_1Session.html +139 -136
- data/doc/cxxapi/classPassenger_1_1BufferedUpload-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1BufferedUpload.html +13 -10
- data/doc/cxxapi/classPassenger_1_1BusyException-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1BusyException.html +11 -8
- data/doc/cxxapi/classPassenger_1_1ConfigurationException-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1ConfigurationException.html +11 -8
- data/doc/cxxapi/classPassenger_1_1DirectoryMapper-members.html +4 -5
- data/doc/cxxapi/classPassenger_1_1DirectoryMapper.html +45 -43
- data/doc/cxxapi/classPassenger_1_1DummySpawnManager-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1DummySpawnManager.html +13 -10
- data/doc/cxxapi/classPassenger_1_1FileChecker-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1FileChecker.html +22 -19
- data/doc/cxxapi/classPassenger_1_1FileNotFoundException-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1FileNotFoundException.html +12 -9
- data/doc/cxxapi/classPassenger_1_1FileNotFoundException__inherit__graph.map +1 -1
- data/doc/cxxapi/classPassenger_1_1FileNotFoundException__inherit__graph.md5 +1 -1
- data/doc/cxxapi/classPassenger_1_1FileNotFoundException__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1FileSystemException-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1FileSystemException.html +14 -11
- data/doc/cxxapi/classPassenger_1_1FileSystemException__inherit__graph.map +1 -1
- data/doc/cxxapi/classPassenger_1_1FileSystemException__inherit__graph.md5 +1 -1
- data/doc/cxxapi/classPassenger_1_1FileSystemException__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1IOException-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1IOException.html +12 -9
- data/doc/cxxapi/classPassenger_1_1IOException__inherit__graph.map +1 -1
- data/doc/cxxapi/classPassenger_1_1IOException__inherit__graph.md5 +1 -1
- data/doc/cxxapi/classPassenger_1_1IOException__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1MessageChannel-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1MessageChannel.html +228 -225
- data/doc/cxxapi/classPassenger_1_1RuntimeException-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1RuntimeException.html +11 -8
- data/doc/cxxapi/classPassenger_1_1SpawnException-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1SpawnException.html +14 -11
- data/doc/cxxapi/classPassenger_1_1SpawnManager-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1SpawnManager.html +50 -47
- data/doc/cxxapi/classPassenger_1_1StandardApplicationPool-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1StandardApplicationPool.html +73 -70
- data/doc/cxxapi/classPassenger_1_1StandardApplicationPool__inherit__graph.map +1 -1
- data/doc/cxxapi/classPassenger_1_1StandardApplicationPool__inherit__graph.md5 +1 -1
- data/doc/cxxapi/classPassenger_1_1StandardApplicationPool__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1SystemException-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1SystemException.html +17 -14
- data/doc/cxxapi/classPassenger_1_1SystemException__inherit__graph.map +1 -1
- data/doc/cxxapi/classPassenger_1_1SystemException__inherit__graph.md5 +1 -1
- data/doc/cxxapi/classPassenger_1_1SystemException__inherit__graph.png +0 -0
- data/doc/cxxapi/classPassenger_1_1SystemTime-members.html +4 -4
- data/doc/cxxapi/classPassenger_1_1SystemTime.html +14 -11
- data/doc/cxxapi/classes.html +35 -0
- data/doc/cxxapi/definitions_8h-source.html +9 -4
- data/doc/cxxapi/doxygen.css +311 -303
- data/doc/cxxapi/files.html +9 -18
- data/doc/cxxapi/functions.html +5 -224
- data/doc/cxxapi/functions_func.html +5 -185
- data/doc/cxxapi/functions_type.html +4 -4
- data/doc/cxxapi/functions_vars.html +4 -4
- data/doc/cxxapi/graph_legend.dot +19 -19
- data/doc/cxxapi/graph_legend.html +5 -5
- data/doc/cxxapi/graph_legend.png +0 -0
- data/doc/cxxapi/group__Configuration.html +11 -13
- data/doc/cxxapi/group__Configuration.png +0 -0
- data/doc/cxxapi/group__Core.html +10 -12
- data/doc/cxxapi/group__Core.png +0 -0
- data/doc/cxxapi/group__Exceptions.html +5 -7
- data/doc/cxxapi/group__Hooks.html +5 -7
- data/doc/cxxapi/group__Hooks.png +0 -0
- data/doc/cxxapi/group__Support.html +5 -624
- data/doc/cxxapi/hierarchy.html +6 -6
- data/doc/cxxapi/inherit__graph__0.map +1 -1
- data/doc/cxxapi/inherit__graph__0.md5 +1 -1
- data/doc/cxxapi/inherit__graph__0.png +0 -0
- data/doc/cxxapi/inherit__graph__1.map +1 -1
- data/doc/cxxapi/inherit__graph__1.md5 +1 -1
- data/doc/cxxapi/inherit__graph__1.png +0 -0
- data/doc/cxxapi/inherit__graph__10.map +1 -1
- data/doc/cxxapi/inherit__graph__10.md5 +1 -1
- data/doc/cxxapi/inherit__graph__10.png +0 -0
- data/doc/cxxapi/inherit__graph__11.map +1 -1
- data/doc/cxxapi/inherit__graph__11.md5 +1 -1
- data/doc/cxxapi/inherit__graph__11.png +0 -0
- data/doc/cxxapi/inherit__graph__12.map +1 -1
- data/doc/cxxapi/inherit__graph__12.md5 +1 -1
- data/doc/cxxapi/inherit__graph__12.png +0 -0
- data/doc/cxxapi/inherit__graph__13.map +1 -2
- data/doc/cxxapi/inherit__graph__13.md5 +1 -1
- data/doc/cxxapi/inherit__graph__13.png +0 -0
- data/doc/cxxapi/inherit__graph__14.map +2 -1
- data/doc/cxxapi/inherit__graph__14.md5 +1 -1
- data/doc/cxxapi/inherit__graph__14.png +0 -0
- data/doc/cxxapi/inherit__graph__15.map +1 -1
- data/doc/cxxapi/inherit__graph__15.md5 +1 -1
- data/doc/cxxapi/inherit__graph__15.png +0 -0
- data/doc/cxxapi/inherit__graph__16.map +1 -1
- data/doc/cxxapi/inherit__graph__16.md5 +1 -1
- data/doc/cxxapi/inherit__graph__16.png +0 -0
- data/doc/cxxapi/inherit__graph__17.map +1 -1
- data/doc/cxxapi/inherit__graph__17.md5 +1 -1
- data/doc/cxxapi/inherit__graph__17.png +0 -0
- data/doc/cxxapi/inherit__graph__18.map +1 -1
- data/doc/cxxapi/inherit__graph__18.md5 +1 -1
- data/doc/cxxapi/inherit__graph__18.png +0 -0
- data/doc/cxxapi/inherit__graph__19.map +1 -1
- data/doc/cxxapi/inherit__graph__19.md5 +1 -1
- data/doc/cxxapi/inherit__graph__19.png +0 -0
- data/doc/cxxapi/inherit__graph__2.map +1 -1
- data/doc/cxxapi/inherit__graph__2.md5 +1 -1
- data/doc/cxxapi/inherit__graph__2.png +0 -0
- data/doc/cxxapi/inherit__graph__20.map +2 -2
- data/doc/cxxapi/inherit__graph__20.md5 +1 -1
- data/doc/cxxapi/inherit__graph__20.png +0 -0
- data/doc/cxxapi/inherit__graph__21.map +1 -1
- data/doc/cxxapi/inherit__graph__21.md5 +1 -1
- data/doc/cxxapi/inherit__graph__21.png +0 -0
- data/doc/cxxapi/inherit__graph__3.map +1 -1
- data/doc/cxxapi/inherit__graph__3.md5 +1 -1
- data/doc/cxxapi/inherit__graph__3.png +0 -0
- data/doc/cxxapi/inherit__graph__4.map +1 -1
- data/doc/cxxapi/inherit__graph__4.md5 +1 -1
- data/doc/cxxapi/inherit__graph__4.png +0 -0
- data/doc/cxxapi/inherit__graph__5.map +1 -2
- data/doc/cxxapi/inherit__graph__5.md5 +1 -1
- data/doc/cxxapi/inherit__graph__5.png +0 -0
- data/doc/cxxapi/inherit__graph__6.map +2 -1
- data/doc/cxxapi/inherit__graph__6.md5 +1 -1
- data/doc/cxxapi/inherit__graph__6.png +0 -0
- data/doc/cxxapi/inherit__graph__7.map +1 -1
- data/doc/cxxapi/inherit__graph__7.md5 +1 -1
- data/doc/cxxapi/inherit__graph__7.png +0 -0
- data/doc/cxxapi/inherit__graph__8.map +1 -1
- data/doc/cxxapi/inherit__graph__8.md5 +1 -1
- data/doc/cxxapi/inherit__graph__8.png +0 -0
- data/doc/cxxapi/inherit__graph__9.map +1 -1
- data/doc/cxxapi/inherit__graph__9.md5 +1 -1
- data/doc/cxxapi/inherit__graph__9.png +0 -0
- data/doc/cxxapi/inherits.html +41 -41
- data/doc/cxxapi/main.html +4 -4
- data/doc/cxxapi/modules.html +4 -5
- data/doc/cxxapi/structPassenger_1_1AnythingToString-members.html +4 -4
- data/doc/cxxapi/structPassenger_1_1AnythingToString.html +13 -10
- data/doc/cxxapi/structPassenger_1_1AnythingToString_3_01vector_3_01string_01_4_01_4-members.html +5 -5
- data/doc/cxxapi/structPassenger_1_1AnythingToString_3_01vector_3_01string_01_4_01_4.html +16 -13
- data/doc/cxxapi/structPassenger_1_1PoolOptions-members.html +4 -4
- data/doc/cxxapi/structPassenger_1_1PoolOptions.html +63 -60
- data/doc/cxxapi/tabs.css +5 -2
- data/doc/cxxapi/tree.html +7 -81
- data/doc/rdoc/classes/ConditionVariable.html +59 -59
- data/doc/rdoc/classes/Exception.html +11 -11
- data/doc/rdoc/classes/GC.html +4 -4
- data/doc/rdoc/classes/IO.html +14 -14
- data/doc/rdoc/classes/PhusionPassenger.html +75 -20
- data/doc/rdoc/classes/PhusionPassenger/AbstractInstaller.html +153 -0
- data/doc/rdoc/classes/PhusionPassenger/AbstractRequestHandler.html +125 -130
- data/doc/rdoc/classes/PhusionPassenger/AbstractServer.html +236 -236
- data/doc/rdoc/classes/PhusionPassenger/AbstractServerCollection.html +213 -213
- data/doc/rdoc/classes/PhusionPassenger/AdminTools.html +28 -28
- data/doc/rdoc/classes/PhusionPassenger/AdminTools/ControlProcess.html +91 -75
- data/doc/rdoc/classes/PhusionPassenger/AppInitError.html +10 -10
- data/doc/rdoc/classes/PhusionPassenger/Application.html +64 -64
- data/doc/rdoc/classes/PhusionPassenger/ConsoleTextTemplate.html +34 -34
- data/doc/rdoc/classes/PhusionPassenger/FrameworkInitError.html +13 -13
- data/doc/rdoc/classes/PhusionPassenger/HTMLTemplate.html +30 -30
- data/doc/rdoc/classes/PhusionPassenger/InitializationError.html +10 -10
- data/doc/rdoc/classes/PhusionPassenger/MessageChannel.html +136 -136
- data/doc/rdoc/classes/PhusionPassenger/NativeSupport.html +24 -24
- data/doc/rdoc/classes/PhusionPassenger/Rack/ApplicationSpawner.html +42 -42
- data/doc/rdoc/classes/PhusionPassenger/Rack/RequestHandler.html +55 -53
- data/doc/rdoc/classes/PhusionPassenger/Railz.html +1 -1
- data/doc/rdoc/classes/PhusionPassenger/Railz/ApplicationSpawner.html +25 -30
- data/doc/rdoc/classes/PhusionPassenger/Railz/CGIFixed.html +23 -23
- data/doc/rdoc/classes/PhusionPassenger/Railz/FrameworkSpawner.html +116 -117
- data/doc/rdoc/classes/PhusionPassenger/Railz/RequestHandler.html +22 -22
- data/doc/rdoc/classes/PhusionPassenger/SpawnManager.html +118 -124
- data/doc/rdoc/classes/PhusionPassenger/UnknownError.html +10 -10
- data/doc/rdoc/classes/PhusionPassenger/Utils.html +354 -354
- data/doc/rdoc/classes/PhusionPassenger/VersionNotFound.html +9 -9
- data/doc/rdoc/classes/PhusionPassenger/WSGI/ApplicationSpawner.html +37 -37
- data/doc/rdoc/classes/PlatformInfo.html +282 -261
- data/doc/rdoc/classes/RakeExtensions.html +7 -7
- data/doc/rdoc/classes/Signal.html +26 -26
- data/doc/rdoc/created.rid +1 -1
- data/doc/rdoc/files/DEVELOPERS_TXT.html +6 -1
- data/doc/rdoc/files/README.html +15 -6
- data/doc/rdoc/files/ext/phusion_passenger/native_support_c.html +1 -1
- data/doc/rdoc/files/lib/phusion_passenger/abstract_installer_rb.html +129 -0
- data/doc/rdoc/files/lib/phusion_passenger/abstract_request_handler_rb.html +20 -13
- data/doc/rdoc/files/lib/phusion_passenger/abstract_server_collection_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/abstract_server_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools/control_process_rb.html +31 -1
- data/doc/rdoc/files/lib/phusion_passenger/admin_tools_rb.html +31 -1
- data/doc/rdoc/files/lib/phusion_passenger/application_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/console_text_template_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/constants_rb.html +21 -12
- data/doc/rdoc/files/lib/phusion_passenger/dependencies_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/events_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/exceptions_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/html_template_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/message_channel_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/packaging_rb.html +122 -0
- data/doc/rdoc/files/lib/phusion_passenger/platform_info_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/rack/application_spawner_rb.html +22 -12
- data/doc/rdoc/files/lib/phusion_passenger/rack/request_handler_rb.html +21 -12
- data/doc/rdoc/files/lib/phusion_passenger/railz/application_spawner_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/railz/cgi_fixed_rb.html +1 -1
- data/doc/rdoc/files/lib/phusion_passenger/railz/framework_spawner_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/railz/request_handler_rb.html +21 -12
- data/doc/rdoc/files/lib/phusion_passenger/simple_benchmarking_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/spawn_manager_rb.html +19 -13
- data/doc/rdoc/files/lib/phusion_passenger/utils_rb.html +27 -21
- data/doc/rdoc/files/lib/phusion_passenger/wsgi/application_spawner_rb.html +21 -12
- data/doc/rdoc/files/misc/rake/extensions_rb.html +21 -12
- data/doc/rdoc/fr_class_index.html +1 -0
- data/doc/rdoc/fr_file_index.html +2 -0
- data/doc/rdoc/fr_method_index.html +116 -112
- data/doc/users_guide_snippets/analysis_and_system_maintenance_tools.txt +144 -0
- data/doc/users_guide_snippets/appendix_a_about.txt +13 -0
- data/doc/users_guide_snippets/appendix_b_terminology.txt +63 -0
- data/doc/users_guide_snippets/appendix_c_spawning_methods.txt +304 -0
- data/doc/users_guide_snippets/global_queueing_explained.txt +78 -0
- data/doc/users_guide_snippets/rackup_specifications.txt +75 -0
- data/doc/users_guide_snippets/rails_spawn_method.txt +48 -0
- data/doc/users_guide_snippets/tips.txt +173 -0
- data/ext/apache2/Bucket.cpp +17 -12
- data/ext/apache2/Bucket.h +17 -12
- data/ext/apache2/Configuration.cpp +17 -12
- data/ext/apache2/Configuration.h +27 -14
- data/ext/apache2/DirectoryMapper.h +21 -12
- data/ext/apache2/Hooks.cpp +67 -21
- data/ext/apache2/Hooks.h +17 -12
- data/ext/apache2/mod_passenger.c +17 -12
- data/ext/{apache2 → common}/Application.h +19 -14
- data/ext/{apache2 → common}/ApplicationPool.h +17 -12
- data/ext/{apache2 → common}/ApplicationPoolServer.h +18 -72
- data/ext/{apache2 → common}/ApplicationPoolServerExecutable.cpp +45 -104
- data/ext/common/ApplicationPoolStatusReporter.h +212 -0
- data/ext/{apache2 → common}/CachedFileStat.cpp +17 -12
- data/ext/{apache2 → common}/CachedFileStat.h +17 -12
- data/ext/{apache2 → common}/DummySpawnManager.h +17 -12
- data/ext/{apache2 → common}/Exceptions.h +17 -12
- data/ext/{apache2 → common}/FileChecker.h +17 -12
- data/ext/common/Logging.cpp +65 -0
- data/ext/{apache2 → common}/Logging.h +17 -12
- data/ext/{apache2 → common}/MessageChannel.h +17 -12
- data/ext/{apache2 → common}/PoolOptions.h +17 -12
- data/ext/{apache2 → common}/SpawnManager.h +17 -12
- data/ext/{apache2 → common}/StandardApplicationPool.h +17 -12
- data/ext/common/StaticString.h +147 -0
- data/ext/common/SystemTime.cpp +33 -0
- data/ext/{apache2 → common}/SystemTime.h +17 -12
- data/ext/{apache2 → common}/Utils.cpp +69 -12
- data/ext/{apache2 → common}/Utils.h +41 -12
- data/ext/nginx/Configuration.c +1091 -0
- data/ext/nginx/Configuration.h +71 -0
- data/ext/nginx/ContentHandler.c +1154 -0
- data/ext/nginx/ContentHandler.h +64 -0
- data/ext/nginx/HelperServer.cpp +857 -0
- data/ext/nginx/HttpStatusExtractor.h +161 -0
- data/ext/nginx/ScgiRequestParser.h +317 -0
- data/ext/nginx/StaticContentHandler.c +222 -0
- data/ext/nginx/StaticContentHandler.h +37 -0
- data/ext/nginx/config +41 -0
- data/ext/nginx/ngx_http_passenger_module.c +572 -0
- data/ext/nginx/ngx_http_passenger_module.h +72 -0
- data/ext/oxt/backtrace.cpp +8 -1
- data/ext/oxt/system_calls.cpp +40 -0
- data/ext/oxt/system_calls.hpp +14 -7
- data/ext/phusion_passenger/extconf.rb +17 -12
- data/ext/phusion_passenger/native_support.c +19 -12
- data/lib/phusion_passenger/abstract_installer.rb +196 -0
- data/lib/phusion_passenger/abstract_request_handler.rb +19 -24
- data/lib/phusion_passenger/abstract_server.rb +17 -12
- data/lib/phusion_passenger/abstract_server_collection.rb +17 -12
- data/lib/phusion_passenger/admin_tools.rb +23 -0
- data/lib/phusion_passenger/admin_tools/control_process.rb +39 -13
- data/lib/phusion_passenger/application.rb +17 -12
- data/lib/phusion_passenger/console_text_template.rb +17 -12
- data/lib/phusion_passenger/constants.rb +22 -11
- data/lib/phusion_passenger/dependencies.rb +47 -12
- data/lib/phusion_passenger/events.rb +17 -12
- data/lib/phusion_passenger/exceptions.rb +17 -12
- data/lib/phusion_passenger/html_template.rb +17 -12
- data/lib/phusion_passenger/message_channel.rb +17 -12
- data/lib/phusion_passenger/packaging.rb +39 -0
- data/lib/phusion_passenger/platform_info.rb +48 -22
- data/lib/phusion_passenger/rack/application_spawner.rb +22 -11
- data/lib/phusion_passenger/rack/request_handler.rb +21 -12
- data/lib/phusion_passenger/railz/application_spawner.rb +23 -23
- data/lib/phusion_passenger/railz/framework_spawner.rb +18 -14
- data/lib/phusion_passenger/railz/request_handler.rb +18 -11
- data/lib/phusion_passenger/simple_benchmarking.rb +17 -12
- data/lib/phusion_passenger/spawn_manager.rb +17 -20
- data/lib/phusion_passenger/templates/{apache_must_be_compiled_with_compatible_mpm.txt.erb → apache2/apache_must_be_compiled_with_compatible_mpm.txt.erb} +0 -0
- data/lib/phusion_passenger/templates/{apache2_config_snippets.txt.erb → apache2/config_snippets.txt.erb} +0 -0
- data/lib/phusion_passenger/templates/{deployment_example.txt.erb → apache2/deployment_example.txt.erb} +0 -0
- data/lib/phusion_passenger/templates/{no_write_permission_to_passenger_root.txt.erb → apache2/no_write_permission_to_passenger_root.txt.erb} +0 -0
- data/lib/phusion_passenger/templates/{possible_solutions_for_compilation_and_installation_problems.txt.erb → apache2/possible_solutions_for_compilation_and_installation_problems.txt.erb} +0 -0
- data/lib/phusion_passenger/templates/{run_installer_as_root.txt.erb → apache2/run_installer_as_root.txt.erb} +0 -0
- data/lib/phusion_passenger/templates/{welcome.txt.erb → apache2/welcome.txt.erb} +0 -0
- data/lib/phusion_passenger/templates/nginx/ask_for_extra_configure_flags.txt.erb +8 -0
- data/lib/phusion_passenger/templates/nginx/cannot_write_to_dir.txt.erb +11 -0
- data/lib/phusion_passenger/templates/nginx/config_snippets.txt.erb +17 -0
- data/lib/phusion_passenger/templates/nginx/config_snippets_inserted.txt.erb +20 -0
- data/lib/phusion_passenger/templates/nginx/confirm_extra_configure_flags.txt.erb +5 -0
- data/lib/phusion_passenger/templates/nginx/deployment_example.txt.erb +22 -0
- data/lib/phusion_passenger/templates/nginx/pcre_could_not_be_downloaded.txt.erb +11 -0
- data/lib/phusion_passenger/templates/nginx/pcre_could_not_be_extracted.txt.erb +11 -0
- data/lib/phusion_passenger/templates/nginx/possible_solutions_for_compilation_and_installation_problems.txt.erb +11 -0
- data/lib/phusion_passenger/templates/nginx/possible_solutions_for_download_and_extraction_problems.txt.erb +20 -0
- data/lib/phusion_passenger/templates/nginx/query_download_and_install.txt.erb +21 -0
- data/lib/phusion_passenger/templates/nginx/run_installer_as_root.txt.erb +8 -0
- data/lib/phusion_passenger/templates/nginx/welcome.txt.erb +15 -0
- data/lib/phusion_passenger/utils.rb +20 -15
- data/lib/phusion_passenger/wsgi/application_spawner.rb +18 -11
- data/lib/phusion_passenger/wsgi/request_handler.py +23 -0
- data/misc/copy_boost_headers.rb +23 -0
- data/misc/find_owner_pipe_leaks.rb +18 -11
- data/misc/rake/cplusplus.rb +18 -11
- data/misc/rake/extensions.rb +21 -14
- data/misc/render_error_pages.rb +18 -11
- data/test/ApplicationPoolServerTest.cpp +1 -3
- data/test/ApplicationPoolServer_ApplicationPoolTest.cpp +1 -1
- data/test/CxxTestMain.cpp +19 -3
- data/test/HttpStatusExtractorTest.cpp +181 -0
- data/test/ScgiRequestParserTest.cpp +337 -0
- data/test/StaticStringTest.cpp +51 -0
- data/test/UtilsTest.cpp +32 -0
- data/test/config.yml.example +5 -0
- data/test/{integration_tests.rb → integration_tests/apache2_tests.rb} +7 -299
- data/test/integration_tests/hello_world_rack_spec.rb +36 -0
- data/test/integration_tests/hello_world_wsgi_spec.rb +41 -0
- data/test/integration_tests/mycook_spec.rb +192 -0
- data/test/integration_tests/nginx_tests.rb +98 -0
- data/test/ruby/rack/application_spawner_spec.rb +40 -0
- data/test/stub/nginx/koi-utf +109 -0
- data/test/stub/nginx/koi-win +103 -0
- data/test/stub/nginx/mime.types +70 -0
- data/test/stub/nginx/nginx.conf.erb +57 -0
- data/test/stub/nginx/win-utf +126 -0
- data/test/stub/rails_apps/mycook/app/controllers/uploads_controller.rb +4 -0
- data/test/stub/rails_apps/mycook/config/routes.rb +1 -1
- data/test/stub/wsgi/passenger_wsgi.pyc +0 -0
- data/test/support/Support.h +40 -0
- data/test/support/nginx_controller.rb +98 -0
- data/test/support/test_helper.rb +79 -0
- metadata +1091 -1028
- data/benchmark/DummyRequestHandler.cpp +0 -101
- data/ext/apache2/Logging.cpp +0 -60
- data/ext/apache2/SystemTime.cpp +0 -28
@@ -1,10 +1,10 @@
|
|
1
1
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
2
2
|
<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
|
3
3
|
<title>Passenger: DirectoryMapper.h Source File</title>
|
4
|
-
<link href="doxygen.css" rel="stylesheet" type="text/css">
|
5
4
|
<link href="tabs.css" rel="stylesheet" type="text/css">
|
5
|
+
<link href="doxygen.css" rel="stylesheet" type="text/css">
|
6
6
|
</head><body>
|
7
|
-
<!-- Generated by Doxygen 1.5.
|
7
|
+
<!-- Generated by Doxygen 1.5.8 -->
|
8
8
|
<div class="navigation" id="top">
|
9
9
|
<div class="tabs">
|
10
10
|
<ul>
|
@@ -14,296 +14,310 @@
|
|
14
14
|
<li class="current"><a href="files.html"><span>Files</span></a></li>
|
15
15
|
</ul>
|
16
16
|
</div>
|
17
|
+
<div class="tabs">
|
18
|
+
<ul>
|
19
|
+
<li><a href="files.html"><span>File List</span></a></li>
|
20
|
+
</ul>
|
21
|
+
</div>
|
17
22
|
<h1>DirectoryMapper.h</h1><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span>
|
18
23
|
<a name="l00002"></a>00002 <span class="comment"> * Phusion Passenger - http://www.modrails.com/</span>
|
19
|
-
<a name="l00003"></a>00003 <span class="comment"> * Copyright (
|
24
|
+
<a name="l00003"></a>00003 <span class="comment"> * Copyright (c) 2008, 2009 Phusion</span>
|
20
25
|
<a name="l00004"></a>00004 <span class="comment"> *</span>
|
21
|
-
<a name="l00005"></a>00005 <span class="comment"> * Phusion Passenger is a trademark of Hongli Lai & Ninh Bui.</span>
|
26
|
+
<a name="l00005"></a>00005 <span class="comment"> * "Phusion Passenger" is a trademark of Hongli Lai & Ninh Bui.</span>
|
22
27
|
<a name="l00006"></a>00006 <span class="comment"> *</span>
|
23
|
-
<a name="l00007"></a>00007 <span class="comment"> *
|
24
|
-
<a name="l00008"></a>00008 <span class="comment"> *
|
25
|
-
<a name="l00009"></a>00009 <span class="comment"> * the
|
26
|
-
<a name="l00010"></a>00010 <span class="comment">
|
27
|
-
<a name="l00011"></a>00011 <span class="comment"> *
|
28
|
-
<a name="l00012"></a>00012 <span class="comment"> *
|
29
|
-
<a name="l00013"></a>00013 <span class="comment">
|
30
|
-
<a name="l00014"></a>00014 <span class="comment"> *
|
31
|
-
<a name="l00015"></a>00015 <span class="comment">
|
32
|
-
<a name="l00016"></a>00016 <span class="comment">
|
33
|
-
<a name="l00017"></a>00017 <span class="comment"> *
|
34
|
-
<a name="l00018"></a>00018 <span class="comment"> *
|
35
|
-
<a name="l00019"></a>00019 <span class="comment">
|
36
|
-
<a name="l00020"></a>00020 <span class="
|
37
|
-
<a name="l00021"></a>00021 <span class="
|
38
|
-
<a name="l00022"></a>00022 <span class="
|
39
|
-
<a name="l00023"></a>00023 <span class="
|
40
|
-
<a name="l00024"></a>00024 <span class="
|
41
|
-
<a name="l00025"></a>00025 <span class="preprocessor">#
|
42
|
-
<a name="l00026"></a>00026
|
43
|
-
<a name="l00027"></a>00027 <span class="preprocessor"
|
44
|
-
<a name="l00028"></a>00028
|
45
|
-
<a name="l00029"></a>00029 <span class="preprocessor">#include
|
46
|
-
<a name="l00030"></a>00030 <span class="preprocessor">#include
|
47
|
-
<a name="l00031"></a>00031
|
48
|
-
<a name="l00032"></a>00032
|
49
|
-
<a name="l00033"></a>00033
|
50
|
-
<a name="l00034"></a>00034 <span class="
|
51
|
-
<a name="l00035"></a>00035 <span class="preprocessor">#include
|
52
|
-
<a name="l00036"></a>00036 <span class="preprocessor">#include
|
28
|
+
<a name="l00007"></a>00007 <span class="comment"> * Permission is hereby granted, free of charge, to any person obtaining a copy</span>
|
29
|
+
<a name="l00008"></a>00008 <span class="comment"> * of this software and associated documentation files (the "Software"), to deal</span>
|
30
|
+
<a name="l00009"></a>00009 <span class="comment"> * in the Software without restriction, including without limitation the rights</span>
|
31
|
+
<a name="l00010"></a>00010 <span class="comment"> * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell</span>
|
32
|
+
<a name="l00011"></a>00011 <span class="comment"> * copies of the Software, and to permit persons to whom the Software is</span>
|
33
|
+
<a name="l00012"></a>00012 <span class="comment"> * furnished to do so, subject to the following conditions:</span>
|
34
|
+
<a name="l00013"></a>00013 <span class="comment"> *</span>
|
35
|
+
<a name="l00014"></a>00014 <span class="comment"> * The above copyright notice and this permission notice shall be included in</span>
|
36
|
+
<a name="l00015"></a>00015 <span class="comment"> * all copies or substantial portions of the Software.</span>
|
37
|
+
<a name="l00016"></a>00016 <span class="comment"> *</span>
|
38
|
+
<a name="l00017"></a>00017 <span class="comment"> * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR</span>
|
39
|
+
<a name="l00018"></a>00018 <span class="comment"> * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,</span>
|
40
|
+
<a name="l00019"></a>00019 <span class="comment"> * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE</span>
|
41
|
+
<a name="l00020"></a>00020 <span class="comment"> * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER</span>
|
42
|
+
<a name="l00021"></a>00021 <span class="comment"> * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,</span>
|
43
|
+
<a name="l00022"></a>00022 <span class="comment"> * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN</span>
|
44
|
+
<a name="l00023"></a>00023 <span class="comment"> * THE SOFTWARE.</span>
|
45
|
+
<a name="l00024"></a>00024 <span class="comment"> */</span>
|
46
|
+
<a name="l00025"></a>00025 <span class="preprocessor">#ifndef _PASSENGER_DIRECTORY_MAPPER_H_</span>
|
47
|
+
<a name="l00026"></a>00026 <span class="preprocessor"></span><span class="preprocessor">#define _PASSENGER_DIRECTORY_MAPPER_H_</span>
|
48
|
+
<a name="l00027"></a>00027 <span class="preprocessor"></span>
|
49
|
+
<a name="l00028"></a>00028 <span class="preprocessor">#include <string></span>
|
50
|
+
<a name="l00029"></a>00029 <span class="preprocessor">#include <set></span>
|
51
|
+
<a name="l00030"></a>00030 <span class="preprocessor">#include <cstring></span>
|
52
|
+
<a name="l00031"></a>00031
|
53
|
+
<a name="l00032"></a>00032 <span class="preprocessor">#include <oxt/backtrace.hpp></span>
|
54
|
+
<a name="l00033"></a>00033
|
55
|
+
<a name="l00034"></a>00034 <span class="preprocessor">#include "CachedFileStat.h"</span>
|
56
|
+
<a name="l00035"></a>00035 <span class="preprocessor">#include "Configuration.h"</span>
|
57
|
+
<a name="l00036"></a>00036 <span class="preprocessor">#include "Utils.h"</span>
|
53
58
|
<a name="l00037"></a>00037
|
54
|
-
<a name="l00038"></a>00038 <span class="
|
55
|
-
<a name="l00039"></a>00039
|
56
|
-
<a name="l00040"></a>00040 <span class="
|
57
|
-
<a name="l00041"></a>00041 <span class="
|
58
|
-
<a name="l00042"></a>00042
|
59
|
-
<a name="l00043"></a>00043 <span class="
|
60
|
-
<a name="l00044"></a>00044
|
61
|
-
<a name="l00045"></a>00045 <span class="
|
62
|
-
<a name="l00046"></a>00046 <span class="
|
63
|
-
<a name="l00047"></a>00047 <span class="comment"
|
64
|
-
<a name="l00048"></a>00048 <span class="comment"
|
65
|
-
<a name="l00049"></a>00049 <span class="comment"> *
|
66
|
-
<a name="l00050"></a>00050 <span class="comment"> *
|
67
|
-
<a name="l00051"></a>00051 <span class="comment">
|
68
|
-
<a name="l00052"></a
|
69
|
-
<a name="l00053"></a>00053 <span class="
|
70
|
-
<a name="l00054"></a>00054
|
71
|
-
<a name="l00055"></a>00055
|
72
|
-
<a name="l00056"></a>00056
|
73
|
-
<a name="l00057"></a>00057
|
74
|
-
<a name="l00058"></a>00058
|
75
|
-
<a name="l00059"></a>00059
|
76
|
-
<a name="l00060"></a>00060
|
77
|
-
<a name="l00061"></a>00061
|
78
|
-
<a name="l00062"></a>00062
|
79
|
-
<a name="l00063"></a>00063
|
80
|
-
<a name="l00064"></a>00064
|
81
|
-
<a name="l00065"></a>00065
|
82
|
-
<a name="l00066"></a>00066
|
83
|
-
<a name="l00067"></a>00067
|
84
|
-
<a name="l00068"></a>00068
|
85
|
-
<a name="l00069"></a>00069
|
86
|
-
<a name="l00070"></a>00070 <span class="
|
87
|
-
<a name="l00071"></a>00071
|
88
|
-
<a name="l00072"></a>00072
|
89
|
-
<a name="l00073"></a>00073
|
59
|
+
<a name="l00038"></a>00038 <span class="comment">// The Apache/APR headers *must* come after the Boost headers, otherwise</span>
|
60
|
+
<a name="l00039"></a>00039 <span class="comment">// compilation will fail on OpenBSD.</span>
|
61
|
+
<a name="l00040"></a>00040 <span class="preprocessor">#include <httpd.h></span>
|
62
|
+
<a name="l00041"></a>00041 <span class="preprocessor">#include <http_core.h></span>
|
63
|
+
<a name="l00042"></a>00042
|
64
|
+
<a name="l00043"></a>00043 <span class="keyword">namespace </span>Passenger {
|
65
|
+
<a name="l00044"></a>00044
|
66
|
+
<a name="l00045"></a>00045 <span class="keyword">using namespace </span>std;
|
67
|
+
<a name="l00046"></a>00046 <span class="keyword">using namespace </span>oxt;
|
68
|
+
<a name="l00047"></a>00047 <span class="comment"></span>
|
69
|
+
<a name="l00048"></a>00048 <span class="comment">/**</span>
|
70
|
+
<a name="l00049"></a>00049 <span class="comment"> * Utility class for determining URI-to-application directory mappings.</span>
|
71
|
+
<a name="l00050"></a>00050 <span class="comment"> * Given a URI, it will determine whether that URI belongs to a Phusion</span>
|
72
|
+
<a name="l00051"></a>00051 <span class="comment"> * Passenger-handled application, what the base URI of that application is,</span>
|
73
|
+
<a name="l00052"></a>00052 <span class="comment"> * and what the associated 'public' directory is.</span>
|
74
|
+
<a name="l00053"></a>00053 <span class="comment"> *</span>
|
75
|
+
<a name="l00054"></a>00054 <span class="comment"> * @note This class is not thread-safe, but is reentrant.</span>
|
76
|
+
<a name="l00055"></a>00055 <span class="comment"> * @ingroup Core</span>
|
77
|
+
<a name="l00056"></a>00056 <span class="comment"> */</span>
|
78
|
+
<a name="l00057"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html">00057</a> <span class="keyword">class </span><a class="code" href="classPassenger_1_1DirectoryMapper.html" title="Utility class for determining URI-to-application directory mappings.">DirectoryMapper</a> {
|
79
|
+
<a name="l00058"></a>00058 <span class="keyword">public</span>:
|
80
|
+
<a name="l00059"></a>00059 <span class="keyword">enum</span> ApplicationType {
|
81
|
+
<a name="l00060"></a>00060 NONE,
|
82
|
+
<a name="l00061"></a>00061 RAILS,
|
83
|
+
<a name="l00062"></a>00062 RACK,
|
84
|
+
<a name="l00063"></a>00063 WSGI
|
85
|
+
<a name="l00064"></a>00064 };
|
86
|
+
<a name="l00065"></a>00065
|
87
|
+
<a name="l00066"></a>00066 <span class="keyword">private</span>:
|
88
|
+
<a name="l00067"></a>00067 DirConfig *config;
|
89
|
+
<a name="l00068"></a>00068 request_rec *r;
|
90
|
+
<a name="l00069"></a>00069 CachedMultiFileStat *mstat;
|
91
|
+
<a name="l00070"></a>00070 <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> throttleRate;
|
92
|
+
<a name="l00071"></a>00071 <span class="keywordtype">bool</span> baseURIKnown;
|
93
|
+
<a name="l00072"></a>00072 <span class="keyword">const</span> <span class="keywordtype">char</span> *baseURI;
|
94
|
+
<a name="l00073"></a>00073 ApplicationType appType;
|
90
95
|
<a name="l00074"></a>00074
|
91
|
-
<a name="l00075"></a>00075 <span class="keyword">inline</span> <span class="keywordtype">bool</span>
|
92
|
-
<a name="l00076"></a>00076 <span class="keywordflow">return</span> config->
|
93
|
-
<a name="l00077"></a>00077 config->
|
96
|
+
<a name="l00075"></a>00075 <span class="keyword">inline</span> <span class="keywordtype">bool</span> shouldAutoDetectRails() {
|
97
|
+
<a name="l00076"></a>00076 <span class="keywordflow">return</span> config->autoDetectRails == DirConfig::ENABLED ||
|
98
|
+
<a name="l00077"></a>00077 config->autoDetectRails == DirConfig::UNSET;
|
94
99
|
<a name="l00078"></a>00078 }
|
95
100
|
<a name="l00079"></a>00079
|
96
|
-
<a name="l00080"></a>00080 <span class="keyword">inline</span> <span class="keywordtype">bool</span>
|
97
|
-
<a name="l00081"></a>00081 <span class="keywordflow">return</span> config->
|
98
|
-
<a name="l00082"></a>00082 config->
|
101
|
+
<a name="l00080"></a>00080 <span class="keyword">inline</span> <span class="keywordtype">bool</span> shouldAutoDetectRack() {
|
102
|
+
<a name="l00081"></a>00081 <span class="keywordflow">return</span> config->autoDetectRack == DirConfig::ENABLED ||
|
103
|
+
<a name="l00082"></a>00082 config->autoDetectRack == DirConfig::UNSET;
|
99
104
|
<a name="l00083"></a>00083 }
|
100
105
|
<a name="l00084"></a>00084
|
101
|
-
<a name="l00085"></a>00085
|
102
|
-
<a name="l00086"></a>00086
|
103
|
-
<a name="l00087"></a>00087
|
104
|
-
<a name="l00088"></a>00088
|
105
|
-
<a name="l00089"></a>00089
|
106
|
-
<a name="l00090"></a>00090 <span class="
|
107
|
-
<a name="l00091"></a>00091 <span class="comment">
|
108
|
-
<a name="l00092"></a>00092 <span class="comment"> *
|
109
|
-
<a name="l00093"></a>00093 <span class="comment">
|
110
|
-
<a name="l00094"></a
|
111
|
-
<a name="l00095"></a>00095
|
112
|
-
<a name="l00096"></a>00096
|
113
|
-
<a name="l00097"></a>00097
|
114
|
-
<a name="l00098"></a>00098
|
115
|
-
<a name="l00099"></a>00099
|
116
|
-
<a name="l00100"></a>00100
|
117
|
-
<a name="l00101"></a>00101
|
118
|
-
<a name="l00102"></a>00102
|
119
|
-
<a name="l00103"></a>00103
|
120
|
-
<a name="l00104"></a>00104
|
121
|
-
<a name="l00105"></a>00105
|
122
|
-
<a name="l00106"></a>00106 <span class="
|
123
|
-
<a name="l00107"></a>00107
|
124
|
-
<a name="l00108"></a>00108
|
125
|
-
<a name="l00109"></a>00109
|
126
|
-
<a name="l00110"></a>00110 <span class="comment">
|
127
|
-
<a name="l00111"></a>00111 <span class="comment"> *
|
128
|
-
<a name="l00112"></a>00112 <span class="comment"> *
|
129
|
-
<a name="l00113"></a>00113 <span class="comment">
|
130
|
-
<a name="l00114"></a>00114 <span class="comment">
|
131
|
-
<a name="l00115"></a>00115 <span class="comment">
|
132
|
-
<a name="l00116"></a>00116 <span class="comment"> *
|
133
|
-
<a name="l00117"></a>00117 <span class="comment"> *
|
134
|
-
<a name="l00118"></a>00118 <span class="comment">
|
135
|
-
<a name="l00119"></a>00119 <span class="comment"> *
|
136
|
-
<a name="l00120"></a>00120 <span class="comment">
|
137
|
-
<a name="l00121"></a>00121 <span class="comment">
|
138
|
-
<a name="l00122"></a
|
139
|
-
<a name="l00123"></a>00123
|
140
|
-
<a name="l00124"></a>00124
|
141
|
-
<a name="l00125"></a>00125
|
142
|
-
<a name="l00126"></a>00126
|
143
|
-
<a name="l00127"></a>00127
|
144
|
-
<a name="l00128"></a>00128
|
145
|
-
<a name="l00129"></a>00129 <span class="
|
146
|
-
<a name="l00130"></a>00130
|
147
|
-
<a name="l00131"></a>00131
|
148
|
-
<a name="l00132"></a>00132
|
149
|
-
<a name="l00133"></a>00133
|
150
|
-
<a name="l00134"></a>00134
|
151
|
-
<a name="l00135"></a>00135
|
106
|
+
<a name="l00085"></a>00085 <span class="keyword">inline</span> <span class="keywordtype">bool</span> shouldAutoDetectWSGI() {
|
107
|
+
<a name="l00086"></a>00086 <span class="keywordflow">return</span> config->autoDetectWSGI == DirConfig::ENABLED ||
|
108
|
+
<a name="l00087"></a>00087 config->autoDetectWSGI == DirConfig::UNSET;
|
109
|
+
<a name="l00088"></a>00088 }
|
110
|
+
<a name="l00089"></a>00089
|
111
|
+
<a name="l00090"></a>00090 <span class="keyword">public</span>:<span class="comment"></span>
|
112
|
+
<a name="l00091"></a>00091 <span class="comment"> /**</span>
|
113
|
+
<a name="l00092"></a>00092 <span class="comment"> * Create a new DirectoryMapper object.</span>
|
114
|
+
<a name="l00093"></a>00093 <span class="comment"> *</span>
|
115
|
+
<a name="l00094"></a>00094 <span class="comment"> * @param mstat A CachedMultiFileStat object used for statting files.</span>
|
116
|
+
<a name="l00095"></a>00095 <span class="comment"> * @param throttleRate A throttling rate for mstat.</span>
|
117
|
+
<a name="l00096"></a>00096 <span class="comment"> * @warning Do not use this object after the destruction of <tt>r</tt>,</span>
|
118
|
+
<a name="l00097"></a>00097 <span class="comment"> * <tt>config</tt> or <tt>mstat</tt>.</span>
|
119
|
+
<a name="l00098"></a>00098 <span class="comment"> */</span>
|
120
|
+
<a name="l00099"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#e2725c3280a5e5d63dbc099fe3c3d82a">00099</a> <a class="code" href="classPassenger_1_1DirectoryMapper.html#e2725c3280a5e5d63dbc099fe3c3d82a" title="Create a new DirectoryMapper object.">DirectoryMapper</a>(request_rec *r, DirConfig *config,
|
121
|
+
<a name="l00100"></a>00100 CachedMultiFileStat *mstat, <span class="keywordtype">unsigned</span> <span class="keywordtype">int</span> throttleRate) {
|
122
|
+
<a name="l00101"></a>00101 this->r = r;
|
123
|
+
<a name="l00102"></a>00102 this->config = config;
|
124
|
+
<a name="l00103"></a>00103 this->mstat = mstat;
|
125
|
+
<a name="l00104"></a>00104 this->throttleRate = throttleRate;
|
126
|
+
<a name="l00105"></a>00105 appType = NONE;
|
127
|
+
<a name="l00106"></a>00106 baseURIKnown = <span class="keyword">false</span>;
|
128
|
+
<a name="l00107"></a>00107 baseURI = NULL;
|
129
|
+
<a name="l00108"></a>00108 }
|
130
|
+
<a name="l00109"></a>00109 <span class="comment"></span>
|
131
|
+
<a name="l00110"></a>00110 <span class="comment"> /**</span>
|
132
|
+
<a name="l00111"></a>00111 <span class="comment"> * Determine whether the given HTTP request falls under one of the specified</span>
|
133
|
+
<a name="l00112"></a>00112 <span class="comment"> * RailsBaseURIs or RackBaseURIs. If yes, then the first matching base URI will</span>
|
134
|
+
<a name="l00113"></a>00113 <span class="comment"> * be returned.</span>
|
135
|
+
<a name="l00114"></a>00114 <span class="comment"> *</span>
|
136
|
+
<a name="l00115"></a>00115 <span class="comment"> * If Rails/Rack autodetection was enabled in the configuration, and the document</span>
|
137
|
+
<a name="l00116"></a>00116 <span class="comment"> * root seems to be a valid Rails/Rack 'public' folder, then this method will</span>
|
138
|
+
<a name="l00117"></a>00117 <span class="comment"> * return "/".</span>
|
139
|
+
<a name="l00118"></a>00118 <span class="comment"> *</span>
|
140
|
+
<a name="l00119"></a>00119 <span class="comment"> * Otherwise, NULL will be returned.</span>
|
141
|
+
<a name="l00120"></a>00120 <span class="comment"> *</span>
|
142
|
+
<a name="l00121"></a>00121 <span class="comment"> * @throws FileSystemException This method might also examine the filesystem in</span>
|
143
|
+
<a name="l00122"></a>00122 <span class="comment"> * order to detect the application's type. During that process, a</span>
|
144
|
+
<a name="l00123"></a>00123 <span class="comment"> * FileSystemException might be thrown.</span>
|
145
|
+
<a name="l00124"></a>00124 <span class="comment"> * @warning The return value may only be used as long as <tt>config</tt></span>
|
146
|
+
<a name="l00125"></a>00125 <span class="comment"> * hasn't been destroyed.</span>
|
147
|
+
<a name="l00126"></a>00126 <span class="comment"> */</span>
|
148
|
+
<a name="l00127"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821">00127</a> <span class="keyword">const</span> <span class="keywordtype">char</span> *<a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821" title="Determine whether the given HTTP request falls under one of the specified RailsBaseURIs...">getBaseURI</a>() {
|
149
|
+
<a name="l00128"></a>00128 TRACE_POINT();
|
150
|
+
<a name="l00129"></a>00129 <span class="keywordflow">if</span> (baseURIKnown) {
|
151
|
+
<a name="l00130"></a>00130 <span class="keywordflow">return</span> baseURI;
|
152
|
+
<a name="l00131"></a>00131 }
|
153
|
+
<a name="l00132"></a>00132
|
154
|
+
<a name="l00133"></a>00133 set<string>::const_iterator it;
|
155
|
+
<a name="l00134"></a>00134 <span class="keyword">const</span> <span class="keywordtype">char</span> *uri = r->uri;
|
156
|
+
<a name="l00135"></a>00135 <span class="keywordtype">size_t</span> uri_len = strlen(uri);
|
152
157
|
<a name="l00136"></a>00136
|
153
|
-
<a name="l00137"></a>00137
|
154
|
-
<a name="l00138"></a>00138
|
155
|
-
<a name="l00139"></a>00139 <span class="
|
156
|
-
<a name="l00140"></a>00140
|
157
|
-
<a name="l00141"></a>00141
|
158
|
-
<a name="l00142"></a>00142
|
159
|
-
<a name="l00143"></a>00143
|
160
|
-
<a name="l00144"></a>00144 )
|
161
|
-
<a name="l00145"></a>00145
|
162
|
-
<a name="l00146"></a>00146
|
163
|
-
<a name="l00147"></a>00147
|
164
|
-
<a name="l00148"></a>00148
|
165
|
-
<a name="l00149"></a>00149
|
166
|
-
<a name="l00150"></a>00150
|
167
|
-
<a name="l00151"></a>00151
|
168
|
-
<a name="l00152"></a>00152
|
169
|
-
<a name="l00153"></a>00153
|
170
|
-
<a name="l00154"></a>00154
|
171
|
-
<a name="l00155"></a>00155
|
172
|
-
<a name="l00156"></a>00156
|
173
|
-
<a name="l00157"></a>00157
|
174
|
-
<a name="l00158"></a>00158
|
175
|
-
<a name="l00159"></a>00159 )
|
176
|
-
<a name="l00160"></a>00160
|
177
|
-
<a name="l00161"></a>00161
|
178
|
-
<a name="l00162"></a>00162
|
179
|
-
<a name="l00163"></a>00163
|
180
|
-
<a name="l00164"></a>00164
|
181
|
-
<a name="l00165"></a>00165
|
182
|
-
<a name="l00166"></a>00166
|
183
|
-
<a name="l00167"></a>00167
|
184
|
-
<a name="l00168"></a>00168
|
185
|
-
<a name="l00169"></a>00169
|
186
|
-
<a name="l00170"></a>00170
|
187
|
-
<a name="l00171"></a>00171
|
188
|
-
<a name="l00172"></a>00172
|
189
|
-
<a name="l00173"></a>00173
|
190
|
-
<a name="l00174"></a>00174
|
191
|
-
<a name="l00175"></a>00175
|
192
|
-
<a name="l00176"></a>00176
|
193
|
-
<a name="l00177"></a>00177
|
194
|
-
<a name="l00178"></a>00178
|
195
|
-
<a name="l00179"></a>00179
|
196
|
-
<a name="l00180"></a>00180
|
197
|
-
<a name="l00181"></a>00181
|
198
|
-
<a name="l00182"></a>00182
|
199
|
-
<a name="l00183"></a>00183
|
200
|
-
<a name="l00184"></a>00184
|
201
|
-
<a name="l00185"></a>00185
|
202
|
-
<a name="l00186"></a>00186
|
203
|
-
<a name="l00187"></a>00187
|
204
|
-
<a name="l00188"></a>00188
|
205
|
-
<a name="l00189"></a>00189
|
206
|
-
<a name="l00190"></a>00190
|
207
|
-
<a name="l00191"></a>00191
|
208
|
-
<a name="l00192"></a>00192
|
209
|
-
<a name="l00193"></a>00193
|
210
|
-
<a name="l00194"></a>00194
|
211
|
-
<a name="l00195"></a>00195
|
212
|
-
<a name="l00196"></a>00196
|
213
|
-
<a name="l00197"></a>00197
|
214
|
-
<a name="l00198"></a>00198
|
215
|
-
<a name="l00199"></a>00199 <span class="
|
216
|
-
<a name="l00200"></a>00200
|
217
|
-
<a name="l00201"></a>00201
|
218
|
-
<a name="l00202"></a>00202
|
219
|
-
<a name="l00203"></a>00203 <span class="comment">
|
220
|
-
<a name="l00204"></a>00204 <span class="comment">
|
221
|
-
<a name="l00205"></a>00205 <span class="comment"> *
|
222
|
-
<a name="l00206"></a>00206 <span class="comment">
|
223
|
-
<a name="l00207"></a
|
224
|
-
<a name="l00208"></a>00208
|
225
|
-
<a name="l00209"></a>00209
|
226
|
-
<a name="l00210"></a>00210
|
227
|
-
<a name="l00211"></a>00211
|
228
|
-
<a name="l00212"></a>00212
|
229
|
-
<a name="l00213"></a>00213
|
230
|
-
<a name="l00214"></a>00214
|
231
|
-
<a name="l00215"></a>00215
|
232
|
-
<a name="l00216"></a>00216 <span class="
|
233
|
-
<a name="l00217"></a>00217
|
234
|
-
<a name="l00218"></a>00218
|
235
|
-
<a name="l00219"></a>00219
|
236
|
-
<a name="l00220"></a>00220
|
237
|
-
<a name="l00221"></a>00221
|
238
|
-
<a name="l00222"></a>00222
|
239
|
-
<a name="l00223"></a>00223
|
240
|
-
<a name="l00224"></a>00224 <span class="keywordflow">if</span> (
|
241
|
-
<a name="l00225"></a>00225 path.
|
242
|
-
<a name="l00226"></a>00226 }
|
243
|
-
<a name="l00227"></a>00227
|
244
|
-
<a name="l00228"></a>00228
|
245
|
-
<a name="l00229"></a>00229 <span class="keywordflow">
|
246
|
-
<a name="l00230"></a>00230
|
247
|
-
<a name="l00231"></a>00231
|
248
|
-
<a name="l00232"></a>00232
|
249
|
-
<a name="l00233"></a>00233
|
250
|
-
<a name="l00234"></a>00234
|
251
|
-
<a name="l00235"></a>00235
|
252
|
-
<a name="l00236"></a>00236
|
253
|
-
<a name="l00237"></a>00237 <span class="
|
254
|
-
<a name="l00238"></a
|
255
|
-
<a name="l00239"></a>00239
|
256
|
-
<a name="l00240"></a>00240
|
257
|
-
<a name="l00241"></a>00241
|
258
|
-
<a name="l00242"></a>00242
|
259
|
-
<a name="l00243"></a>00243
|
260
|
-
<a name="l00244"></a>00244
|
261
|
-
<a name="l00245"></a>00245 <span class="comment">
|
262
|
-
<a name="l00246"></a>00246 <span class="comment">
|
263
|
-
<a name="l00247"></a>00247 <
|
264
|
-
<a name="l00248"></a>00248
|
265
|
-
<a name="l00249"></a>00249
|
266
|
-
<a name="l00250"></a>00250
|
267
|
-
<a name="l00251"></a
|
268
|
-
<a name="l00252"></a>00252
|
269
|
-
<a name="l00253"></a>00253
|
270
|
-
<a name="l00254"></a>00254
|
271
|
-
<a name="l00255"></a>00255
|
272
|
-
<a name="l00256"></a>00256
|
273
|
-
<a name="l00257"></a>00257
|
274
|
-
<a name="l00258"></a>00258
|
275
|
-
<a name="l00259"></a>00259
|
276
|
-
<a name="l00260"></a>00260
|
277
|
-
<a name="l00261"></a>00261
|
278
|
-
<a name="l00262"></a>00262
|
279
|
-
<a name="l00263"></a>00263
|
280
|
-
<a name="l00264"></a>00264
|
281
|
-
<a name="l00265"></a>00265
|
282
|
-
<a name="l00266"></a>00266
|
283
|
-
<a name="l00267"></a>00267
|
284
|
-
<a name="l00268"></a>00268
|
285
|
-
<a name="l00269"></a>00269
|
286
|
-
<a name="l00270"></a>00270
|
287
|
-
<a name="l00271"></a>00271
|
288
|
-
<a name="l00272"></a
|
289
|
-
<a name="l00273"></a>00273
|
290
|
-
<a name="l00274"></a>00274
|
291
|
-
<a name="l00275"></a>00275
|
292
|
-
<a name="l00276"></a>00276
|
293
|
-
<a name="l00277"></a>00277
|
294
|
-
<a name="l00278"></a>00278
|
295
|
-
<a name="l00279"></a>00279
|
296
|
-
<a name="l00280"></a>00280
|
297
|
-
<a name="l00281"></a>00281
|
298
|
-
<a name="l00282"></a>00282
|
299
|
-
<a name="l00283"></a>00283
|
300
|
-
<a name="l00284"></a>00284
|
301
|
-
<a name="l00285"></a>00285
|
302
|
-
<a name="l00286"></a>00286
|
303
|
-
<a name="l00287"></a>00287
|
158
|
+
<a name="l00137"></a>00137 <span class="keywordflow">if</span> (uri_len == 0 || uri[0] != <span class="charliteral">'/'</span>) {
|
159
|
+
<a name="l00138"></a>00138 baseURIKnown = <span class="keyword">true</span>;
|
160
|
+
<a name="l00139"></a>00139 <span class="keywordflow">return</span> NULL;
|
161
|
+
<a name="l00140"></a>00140 }
|
162
|
+
<a name="l00141"></a>00141
|
163
|
+
<a name="l00142"></a>00142 UPDATE_TRACE_POINT();
|
164
|
+
<a name="l00143"></a>00143 <span class="keywordflow">for</span> (it = config->railsBaseURIs.begin(); it != config->railsBaseURIs.end(); it++) {
|
165
|
+
<a name="l00144"></a>00144 <span class="keyword">const</span> <span class="keywordtype">string</span> &base(*it);
|
166
|
+
<a name="l00145"></a>00145 <span class="keywordflow">if</span> ( base == <span class="stringliteral">"/"</span>
|
167
|
+
<a name="l00146"></a>00146 || ( uri_len == base.size() && memcmp(uri, base.c_str(), uri_len) == 0 )
|
168
|
+
<a name="l00147"></a>00147 || ( uri_len > base.size() && memcmp(uri, base.c_str(), base.size()) == 0
|
169
|
+
<a name="l00148"></a>00148 && uri[base.size()] == <span class="charliteral">'/'</span> )
|
170
|
+
<a name="l00149"></a>00149 ) {
|
171
|
+
<a name="l00150"></a>00150 baseURIKnown = <span class="keyword">true</span>;
|
172
|
+
<a name="l00151"></a>00151 baseURI = base.c_str();
|
173
|
+
<a name="l00152"></a>00152 appType = RAILS;
|
174
|
+
<a name="l00153"></a>00153 <span class="keywordflow">return</span> baseURI;
|
175
|
+
<a name="l00154"></a>00154 }
|
176
|
+
<a name="l00155"></a>00155 }
|
177
|
+
<a name="l00156"></a>00156
|
178
|
+
<a name="l00157"></a>00157 UPDATE_TRACE_POINT();
|
179
|
+
<a name="l00158"></a>00158 <span class="keywordflow">for</span> (it = config->rackBaseURIs.begin(); it != config->rackBaseURIs.end(); it++) {
|
180
|
+
<a name="l00159"></a>00159 <span class="keyword">const</span> <span class="keywordtype">string</span> &base(*it);
|
181
|
+
<a name="l00160"></a>00160 <span class="keywordflow">if</span> ( base == <span class="stringliteral">"/"</span>
|
182
|
+
<a name="l00161"></a>00161 || ( uri_len == base.size() && memcmp(uri, base.c_str(), uri_len) == 0 )
|
183
|
+
<a name="l00162"></a>00162 || ( uri_len > base.size() && memcmp(uri, base.c_str(), base.size()) == 0
|
184
|
+
<a name="l00163"></a>00163 && uri[base.size()] == <span class="charliteral">'/'</span> )
|
185
|
+
<a name="l00164"></a>00164 ) {
|
186
|
+
<a name="l00165"></a>00165 baseURIKnown = <span class="keyword">true</span>;
|
187
|
+
<a name="l00166"></a>00166 baseURI = base.c_str();
|
188
|
+
<a name="l00167"></a>00167 appType = RACK;
|
189
|
+
<a name="l00168"></a>00168 <span class="keywordflow">return</span> baseURI;
|
190
|
+
<a name="l00169"></a>00169 }
|
191
|
+
<a name="l00170"></a>00170 }
|
192
|
+
<a name="l00171"></a>00171
|
193
|
+
<a name="l00172"></a>00172 UPDATE_TRACE_POINT();
|
194
|
+
<a name="l00173"></a>00173 <span class="keywordflow">if</span> (shouldAutoDetectRails()
|
195
|
+
<a name="l00174"></a>00174 && verifyRailsDir(config->getAppRoot(ap_document_root(r)), mstat, throttleRate)) {
|
196
|
+
<a name="l00175"></a>00175 baseURIKnown = <span class="keyword">true</span>;
|
197
|
+
<a name="l00176"></a>00176 baseURI = <span class="stringliteral">"/"</span>;
|
198
|
+
<a name="l00177"></a>00177 appType = RAILS;
|
199
|
+
<a name="l00178"></a>00178 <span class="keywordflow">return</span> baseURI;
|
200
|
+
<a name="l00179"></a>00179 }
|
201
|
+
<a name="l00180"></a>00180
|
202
|
+
<a name="l00181"></a>00181 UPDATE_TRACE_POINT();
|
203
|
+
<a name="l00182"></a>00182 <span class="keywordflow">if</span> (shouldAutoDetectRack()
|
204
|
+
<a name="l00183"></a>00183 && verifyRackDir(config->getAppRoot(ap_document_root(r)), mstat, throttleRate)) {
|
205
|
+
<a name="l00184"></a>00184 baseURIKnown = <span class="keyword">true</span>;
|
206
|
+
<a name="l00185"></a>00185 baseURI = <span class="stringliteral">"/"</span>;
|
207
|
+
<a name="l00186"></a>00186 appType = RACK;
|
208
|
+
<a name="l00187"></a>00187 <span class="keywordflow">return</span> baseURI;
|
209
|
+
<a name="l00188"></a>00188 }
|
210
|
+
<a name="l00189"></a>00189
|
211
|
+
<a name="l00190"></a>00190 UPDATE_TRACE_POINT();
|
212
|
+
<a name="l00191"></a>00191 <span class="keywordflow">if</span> (shouldAutoDetectWSGI()
|
213
|
+
<a name="l00192"></a>00192 && verifyWSGIDir(config->getAppRoot(ap_document_root(r)), mstat, throttleRate)) {
|
214
|
+
<a name="l00193"></a>00193 baseURIKnown = <span class="keyword">true</span>;
|
215
|
+
<a name="l00194"></a>00194 baseURI = <span class="stringliteral">"/"</span>;
|
216
|
+
<a name="l00195"></a>00195 appType = WSGI;
|
217
|
+
<a name="l00196"></a>00196 <span class="keywordflow">return</span> baseURI;
|
218
|
+
<a name="l00197"></a>00197 }
|
219
|
+
<a name="l00198"></a>00198
|
220
|
+
<a name="l00199"></a>00199 baseURIKnown = <span class="keyword">true</span>;
|
221
|
+
<a name="l00200"></a>00200 <span class="keywordflow">return</span> NULL;
|
222
|
+
<a name="l00201"></a>00201 }
|
223
|
+
<a name="l00202"></a>00202 <span class="comment"></span>
|
224
|
+
<a name="l00203"></a>00203 <span class="comment"> /**</span>
|
225
|
+
<a name="l00204"></a>00204 <span class="comment"> * Returns the filename of the 'public' directory of the Rails/Rack application</span>
|
226
|
+
<a name="l00205"></a>00205 <span class="comment"> * that's associated with the HTTP request.</span>
|
227
|
+
<a name="l00206"></a>00206 <span class="comment"> *</span>
|
228
|
+
<a name="l00207"></a>00207 <span class="comment"> * Returns an empty string if the document root of the HTTP request</span>
|
229
|
+
<a name="l00208"></a>00208 <span class="comment"> * cannot be determined, or if it isn't a valid folder.</span>
|
230
|
+
<a name="l00209"></a>00209 <span class="comment"> *</span>
|
231
|
+
<a name="l00210"></a>00210 <span class="comment"> * @throws FileSystemException An error occured while examening the filesystem.</span>
|
232
|
+
<a name="l00211"></a>00211 <span class="comment"> */</span>
|
233
|
+
<a name="l00212"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#ef969f27622fb215990a870076648aa1">00212</a> <span class="keywordtype">string</span> <a class="code" href="classPassenger_1_1DirectoryMapper.html#ef969f27622fb215990a870076648aa1" title="Returns the filename of the &#39;public&#39; directory of the Rails/Rack application...">getPublicDirectory</a>() {
|
234
|
+
<a name="l00213"></a>00213 <span class="keywordflow">if</span> (!baseURIKnown) {
|
235
|
+
<a name="l00214"></a>00214 <a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821" title="Determine whether the given HTTP request falls under one of the specified RailsBaseURIs...">getBaseURI</a>();
|
236
|
+
<a name="l00215"></a>00215 }
|
237
|
+
<a name="l00216"></a>00216 <span class="keywordflow">if</span> (baseURI == NULL) {
|
238
|
+
<a name="l00217"></a>00217 <span class="keywordflow">return</span> <span class="stringliteral">""</span>;
|
239
|
+
<a name="l00218"></a>00218 }
|
240
|
+
<a name="l00219"></a>00219
|
241
|
+
<a name="l00220"></a>00220 <span class="keyword">const</span> <span class="keywordtype">char</span> *docRoot = ap_document_root(r);
|
242
|
+
<a name="l00221"></a>00221 <span class="keywordtype">size_t</span> len = strlen(docRoot);
|
243
|
+
<a name="l00222"></a>00222 <span class="keywordflow">if</span> (len > 0) {
|
244
|
+
<a name="l00223"></a>00223 <span class="keywordtype">string</span> path;
|
245
|
+
<a name="l00224"></a>00224 <span class="keywordflow">if</span> (docRoot[len - 1] == <span class="charliteral">'/'</span>) {
|
246
|
+
<a name="l00225"></a>00225 path.assign(docRoot, len - 1);
|
247
|
+
<a name="l00226"></a>00226 } <span class="keywordflow">else</span> {
|
248
|
+
<a name="l00227"></a>00227 path.assign(docRoot, len);
|
249
|
+
<a name="l00228"></a>00228 }
|
250
|
+
<a name="l00229"></a>00229 <span class="keywordflow">if</span> (strcmp(baseURI, <span class="stringliteral">"/"</span>) != 0) {
|
251
|
+
<a name="l00230"></a>00230 <span class="comment">/* Application is deployed in a sub-URI.</span>
|
252
|
+
<a name="l00231"></a>00231 <span class="comment"> * This is probably a symlink, so let's resolve it.</span>
|
253
|
+
<a name="l00232"></a>00232 <span class="comment"> */</span>
|
254
|
+
<a name="l00233"></a>00233 path.append(baseURI);
|
255
|
+
<a name="l00234"></a>00234 path = resolveSymlink(path);
|
256
|
+
<a name="l00235"></a>00235 }
|
257
|
+
<a name="l00236"></a>00236 <span class="keywordflow">return</span> path;
|
258
|
+
<a name="l00237"></a>00237 } <span class="keywordflow">else</span> {
|
259
|
+
<a name="l00238"></a>00238 <span class="keywordflow">return</span> <span class="stringliteral">""</span>;
|
260
|
+
<a name="l00239"></a>00239 }
|
261
|
+
<a name="l00240"></a>00240 }
|
262
|
+
<a name="l00241"></a>00241 <span class="comment"></span>
|
263
|
+
<a name="l00242"></a>00242 <span class="comment"> /**</span>
|
264
|
+
<a name="l00243"></a>00243 <span class="comment"> * Returns the application type that's associated with the HTTP request.</span>
|
265
|
+
<a name="l00244"></a>00244 <span class="comment"> *</span>
|
266
|
+
<a name="l00245"></a>00245 <span class="comment"> * @throws FileSystemException An error occured while examening the filesystem.</span>
|
267
|
+
<a name="l00246"></a>00246 <span class="comment"> */</span>
|
268
|
+
<a name="l00247"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#ba438d86ca263972a47540956bf11ec1">00247</a> ApplicationType <a class="code" href="classPassenger_1_1DirectoryMapper.html#ba438d86ca263972a47540956bf11ec1" title="Returns the application type that&#39;s associated with the HTTP request.">getApplicationType</a>() {
|
269
|
+
<a name="l00248"></a>00248 <span class="keywordflow">if</span> (!baseURIKnown) {
|
270
|
+
<a name="l00249"></a>00249 <a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821" title="Determine whether the given HTTP request falls under one of the specified RailsBaseURIs...">getBaseURI</a>();
|
271
|
+
<a name="l00250"></a>00250 }
|
272
|
+
<a name="l00251"></a>00251 <span class="keywordflow">return</span> appType;
|
273
|
+
<a name="l00252"></a>00252 }
|
274
|
+
<a name="l00253"></a>00253 <span class="comment"></span>
|
275
|
+
<a name="l00254"></a>00254 <span class="comment"> /**</span>
|
276
|
+
<a name="l00255"></a>00255 <span class="comment"> * Returns the application type (as a string) that's associated</span>
|
277
|
+
<a name="l00256"></a>00256 <span class="comment"> * with the HTTP request.</span>
|
278
|
+
<a name="l00257"></a>00257 <span class="comment"> *</span>
|
279
|
+
<a name="l00258"></a>00258 <span class="comment"> * @throws FileSystemException An error occured while examening the filesystem.</span>
|
280
|
+
<a name="l00259"></a>00259 <span class="comment"> */</span>
|
281
|
+
<a name="l00260"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#c46f0e74ffd05b7fe9924dd99a057cf7">00260</a> <span class="keyword">const</span> <span class="keywordtype">char</span> *<a class="code" href="classPassenger_1_1DirectoryMapper.html#c46f0e74ffd05b7fe9924dd99a057cf7" title="Returns the application type (as a string) that&#39;s associated with the HTTP request...">getApplicationTypeString</a>() {
|
282
|
+
<a name="l00261"></a>00261 <span class="keywordflow">if</span> (!baseURIKnown) {
|
283
|
+
<a name="l00262"></a>00262 <a class="code" href="classPassenger_1_1DirectoryMapper.html#2da887c077fc2460dea204783470e821" title="Determine whether the given HTTP request falls under one of the specified RailsBaseURIs...">getBaseURI</a>();
|
284
|
+
<a name="l00263"></a>00263 }
|
285
|
+
<a name="l00264"></a>00264 <span class="keywordflow">switch</span> (appType) {
|
286
|
+
<a name="l00265"></a>00265 <span class="keywordflow">case</span> RAILS:
|
287
|
+
<a name="l00266"></a>00266 <span class="keywordflow">return</span> <span class="stringliteral">"rails"</span>;
|
288
|
+
<a name="l00267"></a>00267 <span class="keywordflow">case</span> RACK:
|
289
|
+
<a name="l00268"></a>00268 <span class="keywordflow">return</span> <span class="stringliteral">"rack"</span>;
|
290
|
+
<a name="l00269"></a>00269 <span class="keywordflow">case</span> WSGI:
|
291
|
+
<a name="l00270"></a>00270 <span class="keywordflow">return</span> <span class="stringliteral">"wsgi"</span>;
|
292
|
+
<a name="l00271"></a>00271 <span class="keywordflow">default</span>:
|
293
|
+
<a name="l00272"></a>00272 <span class="keywordflow">return</span> NULL;
|
294
|
+
<a name="l00273"></a>00273 };
|
295
|
+
<a name="l00274"></a>00274 }
|
296
|
+
<a name="l00275"></a>00275 <span class="comment"></span>
|
297
|
+
<a name="l00276"></a>00276 <span class="comment"> /**</span>
|
298
|
+
<a name="l00277"></a>00277 <span class="comment"> * Returns the environment under which the application should be spawned.</span>
|
299
|
+
<a name="l00278"></a>00278 <span class="comment"> *</span>
|
300
|
+
<a name="l00279"></a>00279 <span class="comment"> * @throws FileSystemException An error occured while examening the filesystem.</span>
|
301
|
+
<a name="l00280"></a>00280 <span class="comment"> */</span>
|
302
|
+
<a name="l00281"></a><a class="code" href="classPassenger_1_1DirectoryMapper.html#f5091e3cef3878e160e5d3b2181d82fb">00281</a> <span class="keyword">const</span> <span class="keywordtype">char</span> *<a class="code" href="classPassenger_1_1DirectoryMapper.html#f5091e3cef3878e160e5d3b2181d82fb" title="Returns the environment under which the application should be spawned.">getEnvironment</a>() {
|
303
|
+
<a name="l00282"></a>00282 <span class="keywordflow">switch</span> (<a class="code" href="classPassenger_1_1DirectoryMapper.html#ba438d86ca263972a47540956bf11ec1" title="Returns the application type that&#39;s associated with the HTTP request.">getApplicationType</a>()) {
|
304
|
+
<a name="l00283"></a>00283 <span class="keywordflow">case</span> RAILS:
|
305
|
+
<a name="l00284"></a>00284 <span class="keywordflow">return</span> config->getRailsEnv();
|
306
|
+
<a name="l00285"></a>00285 <span class="keywordflow">case</span> RACK:
|
307
|
+
<a name="l00286"></a>00286 <span class="keywordflow">return</span> config->getRackEnv();
|
308
|
+
<a name="l00287"></a>00287 <span class="keywordflow">default</span>:
|
309
|
+
<a name="l00288"></a>00288 <span class="keywordflow">return</span> <span class="stringliteral">"production"</span>;
|
310
|
+
<a name="l00289"></a>00289 }
|
311
|
+
<a name="l00290"></a>00290 }
|
312
|
+
<a name="l00291"></a>00291 };
|
313
|
+
<a name="l00292"></a>00292
|
314
|
+
<a name="l00293"></a>00293 } <span class="comment">// namespace Passenger</span>
|
315
|
+
<a name="l00294"></a>00294
|
316
|
+
<a name="l00295"></a>00295 <span class="preprocessor">#endif </span><span class="comment">/* _PASSENGER_DIRECTORY_MAPPER_H_ */</span>
|
317
|
+
<a name="l00296"></a>00296
|
304
318
|
</pre></div></div>
|
305
|
-
<hr size="1"><address style="text-align: right;"><small>Generated on
|
319
|
+
<hr size="1"><address style="text-align: right;"><small>Generated on Thu Apr 16 19:48:18 2009 for Passenger by
|
306
320
|
<a href="http://www.doxygen.org/index.html">
|
307
|
-
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.
|
321
|
+
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.8 </small></address>
|
308
322
|
</body>
|
309
323
|
</html>
|