# ---------------------------------------------------------------------------------- # This is the global Evergreen virtual host config. Anything you want published # through all virtual hosts (port 80, port 443, etc.) should live in here. # ---------------------------------------------------------------------------------- # ---------------------------------------------------------------------------------- # Point / to the opac - if you have a custom skin or locale, point at it here # ---------------------------------------------------------------------------------- RedirectMatch 301 ^/$ /opac/en-US/skin/default/xml/index.xml # ---------------------------------------------------------------------------------- # Point / to the IP address redirector # ---------------------------------------------------------------------------------- # # SetHandler perl-script # PerlHandler OpenILS::WWW::Redirect # Options +ExecCGI # PerlSendHeader On # #PerlSetVar OILSRedirectSkin "default" # # OILSRedirectDepth defaults to the depth of the branch that the OPAC was directed to # #PerlSetVar OILSRedirectDepth "0" # #PerlSetVar OILSRedirectLocale "en-US" # # Use the template-toolkit opac # #PerlSetVar OILSRedirectTpac "true" # allow from all # # ---------------------------------------------------------------------------------- # Assign a default locale to the accessible OPAC # ---------------------------------------------------------------------------------- RedirectMatch 301 ^/opac/extras/slimpac/start.html$ /opac/en-US/extras/slimpac/start.html RedirectMatch 301 ^/opac/extras/slimpac/advanced.html$ /opac/en-US/extras/slimpac/advanced.html # ---------------------------------------------------------------------------------- # Configure the gateway # ---------------------------------------------------------------------------------- OSRFGatewayConfig /openils/conf/opensrf_core.xml # Translator memcache server. Default is localhost # OSRFTranslatorCacheServer 127.0.0.1:11211 # ---------------------------------------------------------------------------------- # Added content plugin # ---------------------------------------------------------------------------------- SetHandler perl-script PerlHandler OpenILS::WWW::AddedContent Options +ExecCGI PerlSendHeader On allow from all # Autosuggest for searches SetHandler perl-script PerlHandler OpenILS::WWW::AutoSuggest PerlSendHeader On Allow from All # Flattener service SetHandler perl-script PerlHandler OpenILS::WWW::FlatFielder PerlSendHeader On Allow from All # ---------------------------------------------------------------------------------- # Replace broken cover images with a transparent GIF by default # ---------------------------------------------------------------------------------- RewriteEngine ON RewriteRule ^/opac/extras/ac/jacket/(small|medium|large)/$ \ /opac/images/blank.png [P,L] # ---------------------------------------------------------------------------------- # Add the row ID (RID) and date so we can make unAPI happy # ---------------------------------------------------------------------------------- RewriteCond %{QUERY_STRING} (^r|&r)=(\d+) RewriteRule . - [E=OILS_OPAC_RID:%2,E=OILS_TIME_YEAR:%{TIME_YEAR}] # ---------------------------------------------------------------------------------- # Pull the locale from the URL # ---------------------------------------------------------------------------------- RewriteCond %{REQUEST_URI} ^/opac/(.*?)/ RewriteRule . - [E=locale:%1] # ---------------------------------------------------------------------------------- # For sanity reasons, default indexes to Off # ---------------------------------------------------------------------------------- Options -Indexes # ---------------------------------------------------------------------------------- # Configure the OPAC # ---------------------------------------------------------------------------------- AddType application/xhtml+xml .xml # - configure mod_xmlent XMLEntStripPI "yes" XMLEntEscapeScript "no" XMLEntStripComments "yes" XMLEntContentType "text/html; charset=utf-8" # forces quirks mode which we want for now XMLEntStripDoctype "yes" # - set up the include handlers Options +Includes AddOutputFilter INCLUDES .xsl AddOutputFilter INCLUDES;XMLENT .xml SetEnvIf Request_URI ".*" OILS_OPAC_BASE=/opac/ # This gives you the option to configure a different host to serve OPAC images from # Specify the hostname (without protocol) and path to the images. Protocol will # be determined at runtime #SetEnvIf Request_URI ".*" OILS_OPAC_IMAGES_HOST=static.example.org/opac/ # In addition to loading images from a static host, you can also load CSS and/or # Javascript from a static host or hosts. Protocol will be determined at runtime # and/or by configuration options immediately following. #SetEnvIf Request_URI ".*" OILS_OPAC_CSS_HOST=static.example.org/opac/ #SetEnvIf Request_URI ".*" OILS_OPAC_JS_HOST=static.example.org/opac/ # If you are not able to serve static content via https and # wish to force http:// (and are comfortable with mixed-content # warnings in client browsers), set this: #SetEnvIf Request_URI ".*" OILS_OPAC_STATIC_PROTOCOL=http # If you would prefer to fall back to your non-static servers for # https pages, avoiding mixed-content warnings in client browsers # and are willing to accept some increased server load, set this: #SetEnvIf Request_URI ".*" OILS_OPAC_BYPASS_STATIC_FOR_HTTPS=yes # Specify a ChiliFresh account to integrate their services with the OPAC #SetEnv OILS_CHILIFRESH_ACCOUNT #SetEnv OILS_CHILIFRESH_PROFILE #SetEnv OILS_CHILIFRESH_URL http://chilifresh.com/on-site/js/evergreen.js #SetEnv OILS_CHILIFRESH_HTTPS_URL https://secure.chilifresh.com/on-site/js/evergreen.js # Specify the initial script URL for Novelist (containing account credentials, etc.) #SetEnv OILS_NOVELIST_URL # # Uncomment to force SSL any time a patron is logged in. This protects # authentication tokens. Left commented out for backwards compat for now. #SetEnv OILS_OPAC_FORCE_LOGIN_SSL 1 # If set, the skin uses the combined JS file at $SKINDIR/js/combined.js #SetEnv OILS_OPAC_COMBINED_JS 1 # ---------------------------------------------------------------------------------- # Some mod_deflate fun # ---------------------------------------------------------------------------------- SetOutputFilter DEFLATE BrowserMatch ^Mozilla/4 gzip-only-text/html BrowserMatch ^Mozilla/4\.0[678] no-gzip BrowserMatch \bMSI[E] !no-gzip !gzip-only-text/html SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary Header append Vary User-Agent env=!dont-vary # ---------------------------------------------------------------------------------- # Some mod_deflate fun # ---------------------------------------------------------------------------------- SetOutputFilter DEFLATE BrowserMatch ^Mozilla/4 gzip-only-text/html BrowserMatch ^Mozilla/4\.0[678] no-gzip BrowserMatch \bMSI[E] !no-gzip !gzip-only-text/html SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary Header append Vary User-Agent env=!dont-vary # ---------------------------------------------------------------------------------- # Force SSL on the OPAC's "My Account" page # ---------------------------------------------------------------------------------- SSLRequireSSL # Force to en-US for now to satisfy bbags.xml SetEnv locale en-US Options +Includes AddOutputFilter INCLUDES .xml AddType application/xhtml+xml .xml RewriteCond %{QUERY_STRING} locale=([^&]*) RewriteRule ^/opac/[a-z]{2}-[A-Z]{2}/extras/slimpac/(.*)$ /opac/%1/extras/slimpac/$1? [redirect] AddOutputFilter INCLUDES;XMLENT .html # ---------------------------------------------------------------------------------- # Run server-side XUL and XHTML through xmlent to load the correct XML entities # ---------------------------------------------------------------------------------- RewriteCond %{HTTP:Accept-Language} ([a-z]{2}-[A-Z]{2}) RewriteRule ^/xul/ - [E=locale:%1] RewriteRule ^/reports/ - [E=locale:%1] # Default to en-US if we haven't matched a locale of the form xx-YY RewriteCond %{HTTP:Accept-Language} !([a-z]{2}-[A-Z]{2}) RewriteRule ^/xul/ - [E=locale:en-US] RewriteRule ^/reports/ - [E=locale:en-US] # Default to en-US if we are just given en RewriteCond %{ENV:locale} ^$ [OR] RewriteCond %{ENV:locale} ^en$ RewriteRule . - [E=locale:en-US] Options +Includes XMLEntEscapeScript "no" XMLEntStripComments "yes" XMLEntStripPI "yes" XMLEntStripDoctype "yes" XMLEntContentType "text/html; charset=utf-8" AddOutputFilter INCLUDES;XMLENT .xhtml AddOutputFilter INCLUDES;XMLENT .html SetEnv no-gzip allow from all Options +Includes XMLEntContentType "application/vnd.mozilla.xul+xml" AddOutputFilter INCLUDES;XMLENT .xul SetEnv no-gzip allow from all # ---------------------------------------------------------------------------------- # Self-serve password interface # ---------------------------------------------------------------------------------- SetHandler perl-script PerlHandler OpenILS::WWW::PasswordReset::password_reset Options +ExecCGI PerlSendHeader On allow from all # Force clients to use HTTPS RewriteCond %{HTTPS} !=on [NC] RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [R,L] # ---------------------------------------------------------------------------------- # Supercat feeds # ---------------------------------------------------------------------------------- SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::oisbn Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::supercat Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::unapi Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::bookbag_feed Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::opensearch_feed Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::sru_search Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::sru_auth_search Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::changes_feed Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::string_browse Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::SuperCat::string_startwith Options +ExecCGI PerlSendHeader On allow from all # ---------------------------------------------------------------------------------- # Module for displaying OpenSRF API documentation # ---------------------------------------------------------------------------------- AddOutputFilter INCLUDES .xsl # ---------------------------------------------------------------------------------- # Module for processing staff-client offline scripts lives here # ---------------------------------------------------------------------------------- AddHandler cgi-script .pl AllowOverride None Options +ExecCGI allow from all # ---------------------------------------------------------------------------------- # XXX Note, it's important to explicitly set the JSON encoding style # (OSRFGatewayLegacyJSON), since the default encoding style will likely change # with OpenSRF 1.0 # ---------------------------------------------------------------------------------- # OpenSRF JSON legacy gateway # ---------------------------------------------------------------------------------- SetHandler osrf_json_gateway_module OSRFGatewayLegacyJSON "true" allow from all # ---------------------------------------------------------------------------------- # New-style OpenSRF JSON gateway # ---------------------------------------------------------------------------------- SetHandler osrf_json_gateway_module OSRFGatewayLegacyJSON "false" allow from all # ---------------------------------------------------------------------------------- # OpenSRF-over-HTTP translator # (http://open-ils.org/dokuwiki/doku.php?id=opensrf_over_http) # ---------------------------------------------------------------------------------- SetHandler osrf_http_translator_module allow from all # ---------------------------------------------------------------------------------- # The exporter lives here # ---------------------------------------------------------------------------------- SetHandler perl-script AuthType Basic AuthName "Exporter Login" PerlOptions +GlobalRequest PerlSetVar OILSProxyPermissions "STAFF_LOGIN" PerlAuthenHandler OpenILS::WWW::Proxy::Authen require valid-user PerlHandler OpenILS::WWW::Exporter Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script AuthType Basic AuthName "Batch Update Login" PerlOptions +GlobalRequest PerlSetVar OILSProxyPermissions "STAFF_LOGIN" PerlAuthenHandler OpenILS::WWW::Proxy::Authen require valid-user PerlHandler OpenILS::WWW::TemplateBatchBibUpdate PerlSendHeader On Options +ExecCGI allow from all AuthType Basic AuthName "Circ Extras Login" PerlOptions +GlobalRequest PerlSetVar OILSProxyPermissions "STAFF_LOGIN" PerlAuthenHandler OpenILS::WWW::Proxy::Authen require valid-user Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script AuthType Basic AuthName "Collections Login" PerlOptions +GlobalRequest PerlSetVar OILSProxyPermissions "money.collections_tracker.create" PerlAuthenHandler OpenILS::WWW::Proxy::Authen require valid-user Options +ExecCGI PerlSendHeader On allow from all # ---------------------------------------------------------------------------------- # Reporting output lives here # ---------------------------------------------------------------------------------- AuthType Basic AuthName "Report Login" PerlOptions +GlobalRequest PerlSetVar OILSProxyPermissions "VIEW_REPORT_OUTPUT" PerlAuthenHandler OpenILS::WWW::Proxy::Authen require valid-user Options +ExecCGI PerlSendHeader On allow from all # ---------------------------------------------------------------------------------- # Selfcheck interface # ---------------------------------------------------------------------------------- AuthType Basic AuthName "Self-check Login" PerlOptions +GlobalRequest PerlSetVar OILSProxyPermissions "STAFF_LOGIN" PerlAuthenHandler OpenILS::WWW::Proxy::Authen require valid-user Options +ExecCGI PerlSendHeader On allow from all # ---------------------------------------------------------------------------------- # Reports GUI # ---------------------------------------------------------------------------------- Options +Includes AddOutputFilter INCLUDES;XMLENT .xhtml IDLChunkStripPI "yes" IDLChunkEscapeScript "no" IDLChunkStripComments "yes" IDLChunkStripDoctype "yes" IDLChunkContentType "application/xml; charset=utf-8" AddOutputFilter INCLUDES;IDLCHUNK .xml # ---------------------------------------------------------------------------------- # EDI Message viewer # ---------------------------------------------------------------------------------- SetHandler perl-script PerlHandler OpenILS::WWW::EDI Options +ExecCGI PerlSendHeader On allow from all # ---------------------------------------------------------------------------------- # XML-RPC gateway # ---------------------------------------------------------------------------------- SetHandler perl-script PerlHandler OpenILS::WWW::XMLRPCGateway Options +ExecCGI PerlSendHeader On allow from all # ---------------------------------------------------------------------------------- # Conify - next-generation Evergreen administration interface # ---------------------------------------------------------------------------------- RewriteRule ^/conify/([a-z]{2}-[A-Z]{2})/global/(.*)$ /conify/global/$2 [E=locale:$1,L] Options +Includes XMLEntStripPI "yes" XMLEntEscapeScript "no" XMLEntStripComments "no" XMLEntContentType "text/html; charset=utf-8" AddOutputFilter INCLUDES;XMLENT .html AuthType Basic AuthName "Dojo Admin Login" PerlOptions +GlobalRequest PerlSetVar OILSProxyPermissions "STAFF_LOGIN" PerlAuthenHandler OpenILS::WWW::Proxy::Authen require valid-user Options +ExecCGI PerlSendHeader On allow from all SetHandler perl-script PerlHandler OpenILS::WWW::Vandelay::spool_marc Options +ExecCGI allow from all # OpenURL 0.1 searching based on OpenSearch RewriteMap openurl prg:/openils/bin/openurl_map.pl RewriteCond %{QUERY_STRING} (^.*$) RewriteRule ^/openurl$ ${openurl:%1} [NE,PT] # General Evergreen web template processor SetHandler perl-script PerlHandler OpenILS::WWW::EGWeb Options +ExecCGI PerlSendHeader On allow from all PerlSetVar OILSWebBasePath "/eg" PerlSetVar OILSWebWebDir "/openils/var/web" PerlSetVar OILSWebDefaultTemplateExtension "tt2" # Enable Template-Toolkit error debugging messages (apache error log) PerlSetVar OILSWebDebugTemplate "true" # ------------------------------------------------------- # Media Prefix. In the 3rd example, the protocol (http) is enforced #PerlSetVar OILSWebMediaPrefix "/media" #PerlSetVar OILSWebMediaPrefix "static.example.com/media" #PerlSetVar OILSWebMediaPrefix "http://static.example.com/media" # Locale messages files #PerlAddVar OILSWebLocale "en" #PerlAddVar OILSWebLocale "/openils/var/data/locale/messages.en.po" #PerlAddVar OILSWebLocale "en_ca" #PerlAddVar OILSWebLocale "/openils/var/data/locale/messages.en_ca.po" #PerlAddVar OILSWebLocale "fr_ca" #PerlAddVar OILSWebLocale "/openils/var/data/locale/messages.fr_ca.po" # Templates will be loaded from the following paths in reverse order. PerlAddVar OILSWebTemplatePath "/openils/var/templates" #PerlAddVar OILSWebTemplatePath "/openils/var/templates_localskin" #------------------------------------------------- # Added Content Configuration #------------------------------------------------- # Content Cafe #SetEnv OILS_CONTENT_CAFE_USER MYUSER #SetEnv OILS_CONTENT_CAFE_PASS MYPASS # LibraryThing #SetEnv OILS_LIBRARYTHING_URL http://ltfl.librarything.com/forlibraries/widget.js?id=MYID #SetEnv OILS_LIBRARYTHING_HTTPS_URL https://ltfl.librarything.com/forlibraries/widget.js?id=MYID # ChiliFresh #SetEnv OILS_CHILIFRESH_ACCOUNT #SetEnv OILS_CHILIFRESH_URL http://chilifresh.com/on-site/js/evergreen.js #SetEnv OILS_CHILIFRESH_HTTPS_URL https://secure.chilifresh.com/on-site/js/evergreen.js #------------------------------------------------- SetOutputFilter DEFLATE BrowserMatch ^Mozilla/4 gzip-only-text/html BrowserMatch ^Mozilla/4\.0[678] no-gzip BrowserMatch \bMSI[E] !no-gzip !gzip-only-text/html SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary Header append Cache-Control "public" Header append Vary User-Agent env=!dont-vary # should pick up the default expire time from eg.conf... SetOutputFilter DEFLATE BrowserMatch ^Mozilla/4 gzip-only-text/html BrowserMatch ^Mozilla/4\.0[678] no-gzip BrowserMatch \bMSI[E] !no-gzip !gzip-only-text/html SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary Header append Cache-Control "public" Header append Vary User-Agent env=!dont-vary PerlSetVar OILSWebContextLoader "OpenILS::WWW::EGCatLoader" # Expire the HTML quickly since we're loading dynamic data for each page ExpiresActive On ExpiresByType text/html "access plus 5 seconds" PerlSetVar OILSWebContextLoader "OpenILS::WWW::EGKPacLoader" PerlSetVar KPacConfigFile "/openils/conf/kpac.xml.example" ExpiresActive On ExpiresByType text/html "access plus 5 seconds" # Note: the template processor will decline handling anything it does not # have an explicit configuration for, which means it will fall back to # Apache to serve the file. However, in the interest of speed, go ahead # and tell Apache to avoid asking OpenILS::WWW::EGWeb for static content. # Add more exemptions as needed. SetHandler None # ---------------------------------------------------------------------------------- # Some mod_deflate logging setup # ---------------------------------------------------------------------------------- DeflateFilterNote Input instream DeflateFilterNote Output outstream DeflateFilterNote Ratio ratio LogFormat '"%r" %{outstream}n/%{instream}n (%{ratio}n%%)' deflate CustomLog /var/log/apache2/deflate_log deflate # There are problems with XMLENT and mod_deflate - so lets disable it # This is where we don't have a pre-existing LocationMatch directive earlier SetEnv no-gzip SetEnv no-gzip SetEnv no-gzip SetEnv no-gzip SetHandler perl-script PerlHandler OpenILS::WWW::IDL2js Options +ExecCGI PerlSendHeader On allow from all Header append Cache-Control "public" SetOutputFilter DEFLATE BrowserMatch ^Mozilla/4 gzip-only-text/html BrowserMatch ^Mozilla/4\.0[678] no-gzip BrowserMatch \bMSI[E] !no-gzip !gzip-only-text/html SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary Header append Vary User-Agent env=!dont-vary # Uncomment the following to force SSL for everything. Note that this defeats caching # and you will suffer a performance hit. #RewriteCond %{HTTPS} off #RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [NE,R,L]