diff --git a/config/invenio.conf b/config/invenio.conf
index f30fd483b..911f15f3d 100644
--- a/config/invenio.conf
+++ b/config/invenio.conf
@@ -1,1487 +1,1485 @@
 ## This file is part of Invenio.
 ## Copyright (C) 2008, 2009, 2010, 2011 CERN.
 ##
 ## Invenio is free software; you can redistribute it and/or
 ## modify it under the terms of the GNU General Public License as
 ## published by the Free Software Foundation; either version 2 of the
 ## License, or (at your option) any later version.
 ##
 ## Invenio is distributed in the hope that it will be useful, but
 ## WITHOUT ANY WARRANTY; without even the implied warranty of
 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 ## General Public License for more details.
 ##
 ## You should have received a copy of the GNU General Public License
 ## along with Invenio; if not, write to the Free Software Foundation, Inc.,
 ## 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
 
 ###################################################
 ## About 'invenio.conf' and 'invenio-local.conf' ##
 ###################################################
 
 ## The 'invenio.conf' file contains the vanilla default configuration
 ## parameters of a Invenio installation, as coming out of the
 ## distribution.  The file should be self-explanatory.  Once installed
 ## in its usual location (usually /opt/invenio/etc), you could in
 ## principle go ahead and change the values according to your local
 ## needs, but this is not advised.
 ##
 ## If you would like to customize some of these parameters, you should
 ## rather create a file named 'invenio-local.conf' in the same
 ## directory where 'invenio.conf' lives and you should write there
 ## only the customizations that you want to be different from the
 ## vanilla defaults.
 ##
 ## Here is a realistic, minimalist, yet production-ready example of
 ## what you would typically put there:
 ##
 ##    $ cat /opt/invenio/etc/invenio-local.conf
 ##    [Invenio]
 ##    CFG_SITE_NAME = John Doe's Document Server
 ##    CFG_SITE_NAME_INTL_fr = Serveur des Documents de John Doe
 ##    CFG_SITE_URL = http://your.site.com
 ##    CFG_SITE_SECURE_URL = https://your.site.com
 ##    CFG_SITE_ADMIN_EMAIL = john.doe@your.site.com
 ##    CFG_SITE_SUPPORT_EMAIL = john.doe@your.site.com
 ##    CFG_WEBALERT_ALERT_ENGINE_EMAIL = john.doe@your.site.com
 ##    CFG_WEBCOMMENT_ALERT_ENGINE_EMAIL = john.doe@your.site.com
 ##    CFG_WEBCOMMENT_DEFAULT_MODERATOR = john.doe@your.site.com
 ##    CFG_DATABASE_HOST = localhost
 ##    CFG_DATABASE_NAME = invenio
 ##    CFG_DATABASE_USER = invenio
 ##    CFG_DATABASE_PASS = my123p$ss
 ##
 ## You should override at least the parameters mentioned above and the
 ## parameters mentioned in the `Part 1: Essential parameters' below in
 ## order to define some very essential runtime parameters such as the
 ## name of your document server (CFG_SITE_NAME and
 ## CFG_SITE_NAME_INTL_*), the visible URL of your document server
 ## (CFG_SITE_URL and CFG_SITE_SECURE_URL), the email address of the
 ## local Invenio administrator, comment moderator, and alert engine
 ## (CFG_SITE_SUPPORT_EMAIL, CFG_SITE_ADMIN_EMAIL, etc), and last but
 ## not least your database credentials (CFG_DATABASE_*).
 ##
 ## The Invenio system will then read both the default invenio.conf
 ## file and your customized invenio-local.conf file and it will
 ## override any default options with the ones you have specified in
 ## your local file.  This cascading of configuration parameters will
 ## ease your future upgrades.
 
 [Invenio]
 
 ###################################
 ## Part 1:  Essential parameters ##
 ###################################
 
 ## This part defines essential Invenio internal parameters that
 ## everybody should override, like the name of the server or the email
 ## address of the local Invenio administrator.
 
 ## CFG_DATABASE_* - specify which MySQL server to use, the name of the
 ## database to use, and the database access credentials.
 CFG_DATABASE_HOST = localhost
 CFG_DATABASE_PORT = 3306
 CFG_DATABASE_NAME = invenio
 CFG_DATABASE_USER = invenio
 CFG_DATABASE_PASS = my123p$ss
 
 ## CFG_SITE_URL - specify URL under which your installation will be
 ## visible.  For example, use "http://your.site.com".  Do not leave
 ## trailing slash.
 CFG_SITE_URL = http://localhost
 
 ## CFG_SITE_SECURE_URL - specify secure URL under which your
 ## installation secure pages such as login or registration will be
 ## visible.  For example, use "https://your.site.com".  Do not leave
 ## trailing slash.  If you don't plan on using HTTPS, then you may
 ## leave this empty.
 CFG_SITE_SECURE_URL = https://localhost
 
 ## CFG_SITE_NAME -- the visible name of your Invenio installation.
 CFG_SITE_NAME = Atlantis Institute of Fictive Science
 
 ## CFG_SITE_NAME_INTL -- the international versions of CFG_SITE_NAME
 ## in various languages.  (See also CFG_SITE_LANGS below.)
 CFG_SITE_NAME_INTL_en = Atlantis Institute of Fictive Science
 CFG_SITE_NAME_INTL_fr = Atlantis Institut des Sciences Fictives
 CFG_SITE_NAME_INTL_de = Atlantis Institut der fiktiven Wissenschaft
 CFG_SITE_NAME_INTL_es = Atlantis Instituto de la Ciencia Fictive
 CFG_SITE_NAME_INTL_ca = Institut Atlantis de Ciència Fictícia
 CFG_SITE_NAME_INTL_pt = Instituto Atlantis de Ciência Fictícia
 CFG_SITE_NAME_INTL_it = Atlantis Istituto di Scienza Fittizia
 CFG_SITE_NAME_INTL_ru = Институт Фиктивных Наук Атлантиды
 CFG_SITE_NAME_INTL_sk = Atlantis Inštitút Fiktívnych Vied
 CFG_SITE_NAME_INTL_cs = Atlantis Institut Fiktivních Věd
 CFG_SITE_NAME_INTL_no = Atlantis Institutt for Fiktiv Vitenskap
 CFG_SITE_NAME_INTL_sv = Atlantis Institut för Fiktiv Vetenskap
 CFG_SITE_NAME_INTL_el = Ινστιτούτο Φανταστικών Επιστημών Ατλαντίδος
 CFG_SITE_NAME_INTL_uk = Інститут вигаданих наук в Атлантісі
 CFG_SITE_NAME_INTL_ja = Fictive 科学のAtlantis の協会
 CFG_SITE_NAME_INTL_pl = Instytut Fikcyjnej Nauki Atlantis
 CFG_SITE_NAME_INTL_bg = Институт за фиктивни науки Атлантис
 CFG_SITE_NAME_INTL_hr = Institut Fiktivnih Znanosti Atlantis
 CFG_SITE_NAME_INTL_zh_CN = 阿特兰提斯虚拟科学学院
 CFG_SITE_NAME_INTL_zh_TW = 阿特蘭提斯虛擬科學學院
 CFG_SITE_NAME_INTL_hu = Kitalált Tudományok Atlantiszi Intézete
 CFG_SITE_NAME_INTL_af = Atlantis Instituut van Fiktiewe Wetenskap
 CFG_SITE_NAME_INTL_gl = Instituto Atlantis de Ciencia Fictive
 CFG_SITE_NAME_INTL_ro = Institutul Atlantis al Ştiinţelor Fictive
 CFG_SITE_NAME_INTL_rw = Atlantis Ishuri Rikuru Ry'ubuhanga
 CFG_SITE_NAME_INTL_ka = ატლანტიდის ფიქტიური მეცნიერების ინსტიტუტი
 CFG_SITE_NAME_INTL_lt = Fiktyvių Mokslų Institutas Atlantis
 CFG_SITE_NAME_INTL_ar = معهد أطلنطيس للعلوم الافتراضية
 
 ## CFG_SITE_LANG -- the default language of the interface: '
 CFG_SITE_LANG = en
 
 ## CFG_SITE_LANGS -- list of all languages the user interface should
 ## be available in, separated by commas.  The order specified below
 ## will be respected on the interface pages.  A good default would be
 ## to use the alphabetical order.  Currently supported languages
 ## include Afrikaans, Arabic, Bulgarian, Catalan, Czech, German, Georgian,
 ## Greek, English, Spanish, French, Croatian, Hungarian, Galician,
 ## Italian, Japanese, Kinyarwanda, Lithuanian, Norwegian, Polish,
 ## Portuguese, Romanian, Russian, Slovak, Swedish, Ukrainian, Chinese
 ## (China), Chinese (Taiwan), so that the eventual maximum you can
 ## currently select is
 ## "af,ar,bg,ca,cs,de,el,en,es,fr,hr,gl,ka,it,rw,lt,hu,ja,no,pl,pt,ro,ru,sk,sv,uk,zh_CN,zh_TW".
 CFG_SITE_LANGS = af,ar,bg,ca,cs,de,el,en,es,fr,hr,gl,ka,it,rw,lt,hu,ja,no,pl,pt,ro,ru,sk,sv,uk,zh_CN,zh_TW
 
 ## CFG_SITE_SUPPORT_EMAIL -- the email address of the support team for
 ## this installation:
 CFG_SITE_SUPPORT_EMAIL = info@invenio-software.org
 
 ## CFG_SITE_ADMIN_EMAIL -- the email address of the 'superuser' for
 ## this installation.  Enter your email address below and login with
 ## this address when using Invenio inistration modules.  You
 ## will then be automatically recognized as superuser of the system.
 CFG_SITE_ADMIN_EMAIL = info@invenio-software.org
 
 ## CFG_SITE_EMERGENCY_EMAIL_ADDRESSES -- list of email addresses to
 ## which an email should be sent in case of emergency (e.g. bibsched
 ## queue has been stopped because of an error).  Configuration
 ## dictionary allows for different recipients based on weekday and
 ## time-of-day. Example:
 ##
 ## CFG_SITE_EMERGENCY_EMAIL_ADDRESSES = {
 ##    'Sunday 22:00-06:00': '0041761111111@email2sms.foo.com',
 ##    '06:00-18:00': 'team-in-europe@foo.com,0041762222222@email2sms.foo.com',
 ##    '18:00-06:00': 'team-in-usa@foo.com',
 ##    '*': 'john.doe.phone@foo.com'}
 ##
 ## If you want the emergency email notifications to always go to the
 ## same address, just use the wildcard line in the above example.
 CFG_SITE_EMERGENCY_EMAIL_ADDRESSES = {}
 
 ## CFG_SITE_ADMIN_EMAIL_EXCEPTIONS -- set this to 0 if you do not want
 ## to receive any captured exception via email to CFG_SITE_ADMIN_EMAIL
 ## address.  Captured exceptions will still be available in
 ## var/log/invenio.err file.  Set this to 1 if you want to receive
 ## some of the captured exceptions (this depends on the actual place
 ## where the exception is captured).  Set this to 2 if you want to
 ## receive all captured exceptions.
 CFG_SITE_ADMIN_EMAIL_EXCEPTIONS = 1
 
 ## CFG_SITE_RECORD -- what is the URI part representing detailed
 ## record pages?  We recomment to leave the default value `record'
 ## unchanged.
 CFG_SITE_RECORD = record
 
 ## CFG_ERRORLIB_RESET_EXCEPTION_NOTIFICATION_COUNTER_AFTER -- set this to
 ## the number of seconds after which to reset the exception notification
 ## counter. A given repetitive exception is notified via email with a
 ## logarithmic strategy: the first time it is seen it is sent via email,
 ## then the second time, then the fourth, then the eighth and so forth.
 ## If the number of seconds elapsed since the last time it was notified
 ## is greater than CFG_ERRORLIB_RESET_EXCEPTION_NOTIFICATION_COUNTER_AFTER
 ## then the internal counter is reset in order not to have exception
 ## notification become more and more rare.
 CFG_ERRORLIB_RESET_EXCEPTION_NOTIFICATION_COUNTER_AFTER = 14400
 
 ## CFG_CERN_SITE -- do we want to enable CERN-specific code?
 ## Put "1" for "yes" and "0" for "no".
 CFG_CERN_SITE = 0
 
 ## CFG_INSPIRE_SITE -- do we want to enable INSPIRE-specific code?
 ## Put "1" for "yes" and "0" for "no".
 CFG_INSPIRE_SITE = 0
 
 ## CFG_ADS_SITE -- do we want to enable ADS-specific code?
 ## Put "1" for "yes" and "0" for "no".
 CFG_ADS_SITE = 0
 
 ## CFG_OPENAIRE_SITE -- do we want to enable OpenAIRE-specific code?
 ## Put "1" for "yes" and "0" for "no".
 CFG_OPENAIRE_SITE = 0
 
 ## CFG_DEVEL_SITE -- is this a development site? If it is, you might
 ## prefer that it does not do certain things. For example, you might
 ## not want WebSubmit to send certain emails or trigger certain
 ## processes on a development site.
 ## Put "1" for "yes" (this is a development site) or "0" for "no"
 ## (this isn't a development site.)
 CFG_DEVEL_SITE = 0
 
 ################################
 ## Part 2: Web page style     ##
 ################################
 
 ## The variables affecting the page style.  The most important one is
 ## the 'template skin' you would like to use and the obfuscation mode
 ## for your email addresses.  Please refer to the WebStyle Admin Guide
 ## for more explanation.  The other variables are listed here mostly
 ## for backwards compatibility purposes only.
 
 ## CFG_WEBSTYLE_TEMPLATE_SKIN -- what template skin do you want to
 ## use?
 CFG_WEBSTYLE_TEMPLATE_SKIN = default
 
 ## CFG_WEBSTYLE_EMAIL_ADDRESSES_OBFUSCATION_MODE. How do we "protect"
 ## email addresses from undesired automated email harvesters?  This
 ## setting will not affect 'support' and 'admin' emails.
 ## NOTE: there is no ultimate solution to protect against email
 ## harvesting. All have drawbacks and can more or less be
 ## circumvented. Choose you preferred mode ([t] means "transparent"
 ## for the user):
 ##    -1: hide all emails.
 ## [t] 0 : no protection, email returned as is.
 ##           foo@example.com => foo@example.com
 ##     1 : basic email munging: replaces @ by [at] and . by [dot]
 ##           foo@example.com => foo [at] example [dot] com
 ## [t] 2 : transparent name mangling: characters are replaced by
 ##         equivalent HTML entities.
 ##           foo@example.com => foo@example.com
 ## [t] 3 : javascript insertion. Requires Javascript enabled on client
 ##         side.
 ##     4 : replaces @ and . characters by gif equivalents.
 ##             foo@example.com => foo<img src="at.gif" alt=" [at] ">example<img src="dot.gif" alt=" [dot] ">com
 CFG_WEBSTYLE_EMAIL_ADDRESSES_OBFUSCATION_MODE = 2
 
 ## CFG_WEBSTYLE_INSPECT_TEMPLATES -- Do we want to debug all template
 ## functions so that they would return HTML results wrapped in
 ## comments indicating which part of HTML page was created by which
 ## template function?  Useful only for debugging Pythonic HTML
 ## template.  See WebStyle Admin Guide for more information.
 CFG_WEBSTYLE_INSPECT_TEMPLATES = 0
 
 ## (deprecated) CFG_WEBSTYLE_CDSPAGEBOXLEFTTOP -- eventual global HTML
 ## left top box:
 CFG_WEBSTYLE_CDSPAGEBOXLEFTTOP =
 
 ## (deprecated) CFG_WEBSTYLE_CDSPAGEBOXLEFTBOTTOM -- eventual global
 ## HTML left bottom box:
 CFG_WEBSTYLE_CDSPAGEBOXLEFTBOTTOM =
 
 ## (deprecated) CFG_WEBSTYLE_CDSPAGEBOXRIGHTTOP -- eventual global
 ## HTML right top box:
 CFG_WEBSTYLE_CDSPAGEBOXRIGHTTOP =
 
 ## (deprecated) CFG_WEBSTYLE_CDSPAGEBOXRIGHTBOTTOM -- eventual global
 ## HTML right bottom box:
 CFG_WEBSTYLE_CDSPAGEBOXRIGHTBOTTOM =
 
 ## CFG_WEBSTYLE_HTTP_STATUS_ALERT_LIST -- when certain HTTP status
 ## codes are raised to the WSGI handler, the corresponding exceptions
 ## and error messages can be sent to the system administrator for
 ## inspecting.  This is useful to detect and correct errors.  The
 ## variable represents a comma-separated list of HTTP statuses that
 ## should alert admin.  Wildcards are possible. If the status is
 ## followed by an "r", it means that a referer is required to exist
 ## (useful to distinguish broken known links from URL typos when 404
 ## errors are raised).
 CFG_WEBSTYLE_HTTP_STATUS_ALERT_LIST = 404r,400,5*,41*
 
 ## CFG_WEBSTYLE_HTTP_USE_COMPRESSION -- whether to enable deflate
 ## compression of your HTTP/HTTPS connections. This will affect the Apache
 ## configuration snippets created by inveniocfg --create-apache-conf and
 ## the OAI-PMH Identify response.
 CFG_WEBSTYLE_HTTP_USE_COMPRESSION = 0
 
 ##################################
 ## Part 3: WebSearch parameters ##
 ##################################
 
 ## This section contains some configuration parameters for WebSearch
 ## module.  Please note that WebSearch is mostly configured on
 ## run-time via its WebSearch Admin web interface.  The parameters
 ## below are the ones that you do not probably want to modify very
 ## often during the runtime.  (Note that you may modify them
 ## afterwards too, though.)
 
 ## CFG_WEBSEARCH_SEARCH_CACHE_SIZE -- how many queries we want to
 ## cache in memory per one Apache httpd process?  This cache is used
 ## mainly for "next/previous page" functionality, but it caches also
 ## "popular" user queries if more than one user happen to search for
 ## the same thing.  Note that large numbers may lead to great memory
 ## consumption.  We recommend a value not greater than 100.
 CFG_WEBSEARCH_SEARCH_CACHE_SIZE = 0
 
 ## CFG_WEBSEARCH_FIELDS_CONVERT -- if you migrate from an older
 ## system, you may want to map field codes of your old system (such as
 ## 'ti') to Invenio/MySQL ("title").  Use Python dictionary syntax
 ## for the translation table, e.g. {'wau':'author', 'wti':'title'}.
 ## Usually you don't want to do that, and you would use empty dict {}.
 CFG_WEBSEARCH_FIELDS_CONVERT = {}
 
 ## CFG_WEBSEARCH_LIGHTSEARCH_PATTERN_BOX_WIDTH -- width of the
 ## search pattern window in the light search interface, in
 ## characters.  CFG_WEBSEARCH_LIGHTSEARCH_PATTERN_BOX_WIDTH = 60
 CFG_WEBSEARCH_LIGHTSEARCH_PATTERN_BOX_WIDTH = 60
 
 ## CFG_WEBSEARCH_SIMPLESEARCH_PATTERN_BOX_WIDTH -- width of the search
 ## pattern window in the simple search interface, in characters.
 CFG_WEBSEARCH_SIMPLESEARCH_PATTERN_BOX_WIDTH = 40
 
 ## CFG_WEBSEARCH_ADVANCEDSEARCH_PATTERN_BOX_WIDTH -- width of the
 ## search pattern window in the advanced search interface, in
 ## characters.
 CFG_WEBSEARCH_ADVANCEDSEARCH_PATTERN_BOX_WIDTH = 30
 
 ## CFG_WEBSEARCH_NB_RECORDS_TO_SORT -- how many records do we still
 ## want to sort?  For higher numbers we print only a warning and won't
 ## perform any sorting other than default 'latest records first', as
 ## sorting would be very time consuming then.  We recommend a value of
 ## not more than a couple of thousands.
 CFG_WEBSEARCH_NB_RECORDS_TO_SORT = 1000
 
 ## CFG_WEBSEARCH_CALL_BIBFORMAT -- if a record is being displayed but
 ## it was not preformatted in the "HTML brief" format, do we want to
 ## call BibFormatting on the fly?  Put "1" for "yes" and "0" for "no".
 ## Note that "1" will display the record exactly as if it were fully
 ## preformatted, but it may be slow due to on-the-fly processing; "0"
 ## will display a default format very fast, but it may not have all
 ## the fields as in the fully preformatted HTML brief format.  Note
 ## also that this option is active only for old (PHP) formats; the new
 ## (Python) formats are called on the fly by default anyway, since
 ## they are much faster.  When usure, please set "0" here.
 CFG_WEBSEARCH_CALL_BIBFORMAT = 0
 
 ## CFG_WEBSEARCH_USE_ALEPH_SYSNOS -- do we want to make old SYSNOs
 ## visible rather than MySQL's record IDs?  You may use this if you
 ## migrate from a different e-doc system, and you store your old
 ## system numbers into 970__a.  Put "1" for "yes" and "0" for
 ## "no". Usually you don't want to do that, though.
 CFG_WEBSEARCH_USE_ALEPH_SYSNOS = 0
 
 ## CFG_WEBSEARCH_I18N_LATEST_ADDITIONS -- Put "1" if you want the
 ## "Latest Additions" in the web collection pages to show
 ## internationalized records.  Useful only if your brief BibFormat
 ## templates contains internationalized strings. Otherwise put "0" in
 ## order not to slow down the creation of latest additions by WebColl.
 CFG_WEBSEARCH_I18N_LATEST_ADDITIONS = 0
 
 ## CFG_WEBSEARCH_INSTANT_BROWSE -- the number of records to display
 ## under 'Latest Additions' in the web collection pages.
 CFG_WEBSEARCH_INSTANT_BROWSE = 10
 
 ## CFG_WEBSEARCH_INSTANT_BROWSE_RSS -- the number of records to
 ## display in the RSS feed.
 CFG_WEBSEARCH_INSTANT_BROWSE_RSS = 25
 
 ## CFG_WEBSEARCH_RSS_I18N_COLLECTIONS -- comma-separated list of
 ## collections that feature an internationalized RSS feed on their
 ## main seach interface page created by webcoll.  Other collections
 ## will have RSS feed using CFG_SITE_LANG.
 CFG_WEBSEARCH_RSS_I18N_COLLECTIONS =
 
 ## CFG_WEBSEARCH_RSS_TTL -- number of minutes that indicates how long
 ## a feed cache is valid.
 CFG_WEBSEARCH_RSS_TTL = 360
 
 ## CFG_WEBSEARCH_RSS_MAX_CACHED_REQUESTS -- maximum number of request kept
 ## in cache. If the cache is filled, following request are not cached.
 CFG_WEBSEARCH_RSS_MAX_CACHED_REQUESTS = 1000
 
 ## CFG_WEBSEARCH_AUTHOR_ET_AL_THRESHOLD -- up to how many author names
 ## to print explicitely; for more print "et al".  Note that this is
 ## used in default formatting that is seldomly used, as usually
 ## BibFormat defines all the format.  The value below is only used
 ## when BibFormat fails, for example.
 CFG_WEBSEARCH_AUTHOR_ET_AL_THRESHOLD = 3
 
 ## CFG_WEBSEARCH_NARROW_SEARCH_SHOW_GRANDSONS -- whether to show or
 ## not collection grandsons in Narrow Search boxes (sons are shown by
 ## default, grandsons are configurable here).  Use 0 for no and 1 for
 ## yes.
 CFG_WEBSEARCH_NARROW_SEARCH_SHOW_GRANDSONS = 1
 
 ## CFG_WEBSEARCH_CREATE_SIMILARLY_NAMED_AUTHORS_LINK_BOX -- shall we
 ## create help links for Ellis, Nick or Ellis, Nicholas and friends
 ## when Ellis, N was searched for?  Useful if you have one author
 ## stored in the database under several name formats, namely surname
 ## comma firstname and surname comma initial cataloging policy.  Use 0
 ## for no and 1 for yes.
 CFG_WEBSEARCH_CREATE_SIMILARLY_NAMED_AUTHORS_LINK_BOX = 1
 
 ## CFG_WEBSEARCH_USE_MATHJAX_FOR_FORMATS -- MathJax is a JavaScript
 ## library that renders (La)TeX mathematical formulas in the client
 ## browser.  This parameter must contain a comma-separated list of
 ## output formats for which to apply the MathJax rendering, for example
 ## "hb,hd".  If the list is empty, MathJax is disabled.
 CFG_WEBSEARCH_USE_MATHJAX_FOR_FORMATS =
 
 ## CFG_WEBSEARCH_EXTERNAL_COLLECTION_SEARCH_TIMEOUT -- when searching
 ## external collections (e.g. SPIRES, CiteSeer, etc), how many seconds
 ## do we wait for reply before abandonning?
 CFG_WEBSEARCH_EXTERNAL_COLLECTION_SEARCH_TIMEOUT = 5
 
 ## CFG_WEBSEARCH_EXTERNAL_COLLECTION_SEARCH_MAXRESULTS -- how many
 ## results do we fetch?
 CFG_WEBSEARCH_EXTERNAL_COLLECTION_SEARCH_MAXRESULTS = 10
 
 ## CFG_WEBSEARCH_SPLIT_BY_COLLECTION -- do we want to split the search
 ## results by collection or not?  Use 0 for not, 1 for yes.
 CFG_WEBSEARCH_SPLIT_BY_COLLECTION = 1
 
 ## CFG_WEBSEARCH_DEF_RECORDS_IN_GROUPS -- the default number of
 ## records to display per page in the search results pages.
 CFG_WEBSEARCH_DEF_RECORDS_IN_GROUPS = 10
 
 ## CFG_WEBSEARCH_MAX_RECORDS_IN_GROUPS -- in order to limit denial of
 ## service attacks the total number of records per group displayed as a
 ## result of a search query will be limited to this number. Only the superuser
 ## queries will not be affected by this limit.
 CFG_WEBSEARCH_MAX_RECORDS_IN_GROUPS = 200
 
 ## CFG_WEBSEARCH_PERMITTED_RESTRICTED_COLLECTIONS_LEVEL -- logged in users
 ## might have rights to access some restricted collections. This variable
 ## tweaks the kind of support the system will automatically provide to the
 ## user with respect to searching into these restricted collections.
 ## Set this to 0 in order to have the user to explicitly activate restricted
 ## collections in order to search into them. Set this to 1 in order to
 ## propose to the user the list of restricted collections to which he/she has
 ## rights (note: this is not yet implemented). Set this to 2 in order to
 ## silently add all the restricted collections to which the user has rights to
 ## to any query.
 ## Note: the system will discover which restricted collections a user has
 ## rights to, at login time. The time complexity of this procedure is
 ## proportional to the number of restricted collections. E.g. for a system
 ## with ~50 restricted collections, you might expect ~1s of delay in the
 ## login time, when this variable is set to a value higher than 0.
 CFG_WEBSEARCH_PERMITTED_RESTRICTED_COLLECTIONS_LEVEL = 0
 
 ## CFG_WEBSEARCH_SHOW_COMMENT_COUNT -- do we want to show the 'N comments'
 ## links on the search engine pages?  (useful only when you have allowed
 ## commenting)
 CFG_WEBSEARCH_SHOW_COMMENT_COUNT = 1
 
 ## CFG_WEBSEARCH_SHOW_REVIEW_COUNT -- do we want to show the 'N reviews'
 ## links on the search engine pages?  (useful only when you have allowed
 ## reviewing)
 CFG_WEBSEARCH_SHOW_REVIEW_COUNT = 1
 
 ## CFG_WEBSEARCH_FULLTEXT_SNIPPETS -- how many full-text snippets to
 ## display for full-text searches?
 CFG_WEBSEARCH_FULLTEXT_SNIPPETS = 4
 
 ## CFG_WEBSEARCH_FULLTEXT_SNIPPETS_WORDS -- how many context words
 ## to display around the pattern in the snippet?
 CFG_WEBSEARCH_FULLTEXT_SNIPPETS_WORDS = 4
 
 ## CFG_WEBSEARCH_WILDCARD_LIMIT -- some of the queries, wildcard
 ## queries in particular (ex: cern*, a*), but also regular expressions
 ## (ex: [a-z]+), may take a long time to respond due to the high
 ## number of hits. You can limit the number of terms matched by a
 ## wildcard by setting this variable.  A negative value or zero means
 ## that none of the queries will be limited (which may be wanted by
 ## also prone to denial-of-service kind of attacks).
 CFG_WEBSEARCH_WILDCARD_LIMIT = 50000
 
 ## CFG_WEBSEARCH_SYNONYM_KBRS -- defines which knowledge bases are to
 ## be used for which index in order to provide runtime synonym lookup
 ## of user-supplied terms, and what massaging function should be used
 ## upon search pattern before performing the KB lookup.  (Can be one
 ## of `exact', 'leading_to_comma', `leading_to_number'.)
 CFG_WEBSEARCH_SYNONYM_KBRS = {
     'journal': ['SEARCH-SYNONYM-JOURNAL', 'leading_to_number'],
     }
 
 ## CFG_SOLR_URL -- optionally, you may use Solr to serve full-text
 ## queries.  If so, please specify the URL of your Solr instance.
 ## (example: http://localhost:8080/sorl)
 CFG_SOLR_URL =
 
 ## CFG_WEBSEARCH_PREV_NEXT_HIT_LIMIT -- specify the limit when
 ## the previous/next/back hit links are to be displayed on detailed record pages.
 ## In order to speeding up list manipulations, if a search returns lots of hits,
 ## more than this limit, then do not loose time calculating next/previous/back
 ## hits at all, but display page directly without these.
 ## Note also that Invenio installations that do not like
 ## to have the next/previous hit link functionality would be able to set this
 ## variable to zero and not see anything.
 CFG_WEBSEARCH_PREV_NEXT_HIT_LIMIT = 10000
 
 #######################################
 ## Part 4: BibHarvest OAI parameters ##
 #######################################
 
 ## This part defines parameters for the Invenio OAI gateway.
 ## Useful if you are running Invenio as OAI data provider.
 
 ## CFG_OAI_ID_FIELD -- OAI identifier MARC field:
 CFG_OAI_ID_FIELD = 909COo
 
 ## CFG_OAI_SET_FIELD -- OAI set MARC field:
 CFG_OAI_SET_FIELD = 909COp
 
 ## CFG_OAI_DELETED_POLICY -- OAI deletedrecordspolicy
 ## (no/transient/persistent).
 CFG_OAI_DELETED_POLICY = no
 
 ## CFG_OAI_ID_PREFIX -- OAI identifier prefix:
 CFG_OAI_ID_PREFIX = atlantis.cern.ch
 
 ## CFG_OAI_SAMPLE_IDENTIFIER -- OAI sample identifier:
 CFG_OAI_SAMPLE_IDENTIFIER = oai:atlantis.cern.ch:CERN-TH-4036
 
 ## CFG_OAI_IDENTIFY_DESCRIPTION -- description for the OAI Identify verb:
 CFG_OAI_IDENTIFY_DESCRIPTION = <description>
    <oai-identifier xmlns="http://www.openarchives.org/OAI/2.0/oai-identifier"
                    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
                    xsi:schemaLocation="http://www.openarchives.org/OAI/2.0/oai-identifier
                                        http://www.openarchives.org/OAI/2.0/oai-identifier.xsd">
       <scheme>oai</scheme>
       <repositoryIdentifier>atlantis.cern.ch</repositoryIdentifier>
       <delimiter>:</delimiter>
       <sampleIdentifier>oai:atlantis.cern.ch:CERN-TH-4036</sampleIdentifier>
    </oai-identifier>
  </description>
  <description>
   <eprints xmlns="http://www.openarchives.org/OAI/1.1/eprints"
            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
            xsi:schemaLocation="http://www.openarchives.org/OAI/1.1/eprints
                                http://www.openarchives.org/OAI/1.1/eprints.xsd">
       <content>
        <URL>http://atlantis.cern.ch/</URL>
       </content>
       <metadataPolicy>
        <text>Free and unlimited use by anybody with obligation to refer to original record</text>
       </metadataPolicy>
       <dataPolicy>
        <text>Full content, i.e. preprints may not be harvested by robots</text>
       </dataPolicy>
       <submissionPolicy>
        <text>Submission restricted. Submitted documents are subject of approval by OAI repository admins.</text>
       </submissionPolicy>
   </eprints>
  </description>
 
 ## CFG_OAI_LOAD -- OAI number of records in a response:
 CFG_OAI_LOAD = 1000
 
 ## CFG_OAI_EXPIRE -- OAI resumptionToken expiration time:
 CFG_OAI_EXPIRE = 90000
 
 ## CFG_OAI_SLEEP -- service unavailable between two consecutive
 ## requests for CFG_OAI_SLEEP seconds:
 CFG_OAI_SLEEP = 10
 
 ##################################
 ## Part 5: WebSubmit parameters ##
 ##################################
 
 ## This section contains some configuration parameters for WebSubmit
 ## module.  Please note that WebSubmit is mostly configured on
 ## run-time via its WebSubmit Admin web interface.  The parameters
 ## below are the ones that you do not probably want to modify during
 ## the runtime.
 
 ## CFG_WEBSUBMIT_FILESYSTEM_BIBDOC_GROUP_LIMIT -- the fulltext
 ## documents are stored under "/opt/invenio/var/data/files/gX/Y"
 ## directories where X is 0,1,... and Y stands for bibdoc ID.  Thusly
 ## documents Y are grouped into directories X and this variable
 ## indicates the maximum number of documents Y stored in each
 ## directory X.  This limit is imposed solely for filesystem
 ## performance reasons in order not to have too many subdirectories in
 ## a given directory.
 CFG_WEBSUBMIT_FILESYSTEM_BIBDOC_GROUP_LIMIT = 5000
 
 ## CFG_WEBSUBMIT_ADDITIONAL_KNOWN_FILE_EXTENSIONS -- a comma-separated
 ## list of document extensions not listed in Python standard mimetype
 ## library that should be recognized by Invenio.
 CFG_WEBSUBMIT_ADDITIONAL_KNOWN_FILE_EXTENSIONS = hpg,link,lis,llb,mat,mpp,msg,docx,docm,xlsx,xlsm,xlsb,pptx,pptm,ppsx,ppsm
 
 ## CFG_BIBDOCFILE_USE_XSENDFILE -- if your web server supports
 ## XSendfile header, you may want to enable this feature in order for
 ## to Invenio tell the web server to stream files for download (after
 ## proper authorization checks) by web server's means.  This helps to
 ## liberate Invenio worker processes from being busy with sending big
 ## files to clients.  The web server will take care of that.  Note:
 ## this feature is still somewhat experimental.  Note: when enabled
 ## (set to 1), then you have to also regenerate Apache vhost conf
 ## snippets (inveniocfg --update-config-py --create-apache-conf).
 CFG_BIBDOCFILE_USE_XSENDFILE = 0
 
 ## CFG_BIBDOCFILE_MD5_CHECK_PROBABILITY -- a number between 0 and
 ## 1 that indicates probability with which MD5 checksum will be
 ## verified when streaming bibdocfile-managed files.  (0.1 will cause
 ## the check to be performed once for every 10 downloads)
 CFG_BIBDOCFILE_MD5_CHECK_PROBABILITY = 0.1
 
 ## CFG_OPENOFFICE_SERVER_HOST -- the host where an OpenOffice Server is
 ## listening to. If localhost an OpenOffice server will be started
 ## automatically if it is not already running.
 ## Note: if you set this to an empty value this will disable the usage of
 ## OpenOffice for converting documents.
 ## If you set this to something different than localhost you'll have to take
 ## care to have an OpenOffice server running on the corresponding host and
 ## to install the same OpenOffice release both on the client and on the server
 ## side.
 ## In order to launch an OpenOffice server on a remote machine, just start
 ## the usual 'soffice' executable in this way:
 ## $> soffice -headless -nologo -nodefault -norestore -nofirststartwizard \
 ## .. -accept=socket,host=HOST,port=PORT;urp;StarOffice.ComponentContext
 CFG_OPENOFFICE_SERVER_HOST = localhost
 
 ## CFG_OPENOFFICE_SERVER_PORT -- the port where an OpenOffice Server is
 ## listening to.
 CFG_OPENOFFICE_SERVER_PORT = 2002
 
 ## CFG_OPENOFFICE_USER -- the user that will be used to launch the OpenOffice
 ## client. It is recommended to set this to a user who don't own files, like
 ## e.g. 'nobody'. You should also authorize your Apache server user to be
 ## able to become this user, e.g. by adding to your /etc/sudoers the following
 ## line:
 ## "apache  ALL=(nobody) NOPASSWD: ALL"
 ## provided that apache is the username corresponding to the Apache user.
 ## On some machine this might be apache2 or www-data.
 CFG_OPENOFFICE_USER = nobody
 
 #################################
 ## Part 6: BibIndex parameters ##
 #################################
 
 ## This section contains some configuration parameters for BibIndex
 ## module.  Please note that BibIndex is mostly configured on run-time
 ## via its BibIndex Admin web interface.  The parameters below are the
 ## ones that you do not probably want to modify very often during the
 ## runtime.
 
 ## CFG_BIBINDEX_FULLTEXT_INDEX_LOCAL_FILES_ONLY -- when fulltext indexing, do
 ## you want to index locally stored files only, or also external URLs?
 ## Use "0" to say "no" and "1" to say "yes".
 CFG_BIBINDEX_FULLTEXT_INDEX_LOCAL_FILES_ONLY = 0
 
 ## CFG_BIBINDEX_REMOVE_STOPWORDS -- when indexing, do we want to remove
 ## stopwords?  Use "0" to say "no" and "1" to say "yes".
 CFG_BIBINDEX_REMOVE_STOPWORDS = 0
 
 ## CFG_BIBINDEX_CHARS_ALPHANUMERIC_SEPARATORS -- characters considered as
 ## alphanumeric separators of word-blocks inside words.  You probably
 ## don't want to change this.
 CFG_BIBINDEX_CHARS_ALPHANUMERIC_SEPARATORS = \!\"\#\$\%\&\'\(\)\*\+\,\-\.\/\:\;\<\=\>\?\@\[\\\]\^\_\`\{\|\}\~
 
 ## CFG_BIBINDEX_CHARS_PUNCTUATION -- characters considered as punctuation
 ## between word-blocks inside words.  You probably don't want to
 ## change this.
 CFG_BIBINDEX_CHARS_PUNCTUATION = \.\,\:\;\?\!\"
 
 ## CFG_BIBINDEX_REMOVE_HTML_MARKUP -- should we attempt to remove HTML markup
 ## before indexing?  Use 1 if you have HTML markup inside metadata
 ## (e.g. in abstracts), use 0 otherwise.
 CFG_BIBINDEX_REMOVE_HTML_MARKUP = 0
 
 ## CFG_BIBINDEX_REMOVE_LATEX_MARKUP -- should we attempt to remove LATEX markup
 ## before indexing?  Use 1 if you have LATEX markup inside metadata
 ## (e.g. in abstracts), use 0 otherwise.
 CFG_BIBINDEX_REMOVE_LATEX_MARKUP = 0
 
 ## CFG_BIBINDEX_MIN_WORD_LENGTH -- minimum word length allowed to be added to
 ## index.  The terms smaller then this amount will be discarded.
 ## Useful to keep the database clean, however you can safely leave
 ## this value on 0 for up to 1,000,000 documents.
 CFG_BIBINDEX_MIN_WORD_LENGTH = 0
 
 ## CFG_BIBINDEX_URLOPENER_USERNAME and CFG_BIBINDEX_URLOPENER_PASSWORD --
 ## access credentials to access restricted URLs, interesting only if
 ## you are fulltext-indexing files located on a remote server that is
 ## only available via username/password.  But it's probably better to
 ## handle this case via IP or some convention; the current scheme is
 ## mostly there for demo only.
 CFG_BIBINDEX_URLOPENER_USERNAME = mysuperuser
 CFG_BIBINDEX_URLOPENER_PASSWORD = mysuperpass
 
 ## CFG_INTBITSET_ENABLE_SANITY_CHECKS --
 ## Enable sanity checks for integers passed to the intbitset data
 ## structures. It is good to enable this during debugging
 ## and to disable this value for speed improvements.
 CFG_INTBITSET_ENABLE_SANITY_CHECKS = False
 
 ## CFG_BIBINDEX_PERFORM_OCR_ON_DOCNAMES -- regular expression that matches
 ## docnames for which OCR is desired (set this to .* in order to enable
 ## OCR in general, set this to empty in order to disable it.)
 CFG_BIBINDEX_PERFORM_OCR_ON_DOCNAMES = scan-.*
 
 ## CFG_BIBINDEX_SPLASH_PAGES -- key-value mapping where the key corresponds
 ## to a regular expression that matches the URLs of the splash pages of
 ## a given service and the value is a regular expression of the set of URLs
 ## referenced via <a> tags in the HTML content of the splash pages that are
 ## referring to documents that need to be indexed.
 ## NOTE: for backward compatibility reasons you can set this to a simple
 ## regular expression that will directly be used as the unique key of the
 ## map, with corresponding value set to ".*" (in order to match any URL)
 CFG_BIBINDEX_SPLASH_PAGES = {
     "http://documents\.cern\.ch/setlink\?.*": ".*",
     "http://ilcagenda\.linearcollider\.org/subContributionDisplay\.py\?.*|http://ilcagenda\.linearcollider\.org/contributionDisplay\.py\?.*": "http://ilcagenda\.linearcollider\.org/getFile\.py/access\?.*|http://ilcagenda\.linearcollider\.org/materialDisplay\.py\?.*",
     }
 
 ## CFG_BIBINDEX_AUTHOR_WORD_INDEX_EXCLUDE_FIRST_NAMES -- do we want
 ## the author word index to exclude first names to keep only last
 ## names?  If set to True, then for the author `Bernard, Denis', only
 ## `Bernard' will be indexed in the word index, not `Denis'.  Note
 ## that if you change this variable, you have to re-index the author
 ## index via `bibindex -w author -R'.
 CFG_BIBINDEX_AUTHOR_WORD_INDEX_EXCLUDE_FIRST_NAMES = False
 
 ## CFG_BIBINDEX_SYNONYM_KBRS -- defines which knowledge bases are to
 ## be used for which index in order to provide index-time synonym
 ## lookup, and what massaging function should be used upon search
 ## pattern before performing the KB lookup.  (Can be one of `exact',
 ## 'leading_to_comma', `leading_to_number'.)
 CFG_BIBINDEX_SYNONYM_KBRS = {
     'global': ['INDEX-SYNONYM-TITLE', 'exact'],
     'title': ['INDEX-SYNONYM-TITLE', 'exact'],
     }
 
 #######################################
 ## Part 7: Access control parameters ##
 #######################################
 
 ## This section contains some configuration parameters for the access
 ## control system.  Please note that WebAccess is mostly configured on
 ## run-time via its WebAccess Admin web interface.  The parameters
 ## below are the ones that you do not probably want to modify very
 ## often during the runtime.  (If you do want to modify them during
 ## runtime, for example te deny access temporarily because of backups,
 ## you can edit access_control_config.py directly, no need to get back
 ## here and no need to redo the make process.)
 
 ## CFG_ACCESS_CONTROL_LEVEL_SITE -- defines how open this site is.
 ## Use 0 for normal operation of the site, 1 for read-only site (all
 ## write operations temporarily closed), 2 for site fully closed,
 ## 3 for also disabling any database connection.
 ## Useful for site maintenance.
 CFG_ACCESS_CONTROL_LEVEL_SITE = 0
 
 ## CFG_ACCESS_CONTROL_LEVEL_GUESTS -- guest users access policy.  Use
 ## 0 to allow guest users, 1 not to allow them (all users must login).
 CFG_ACCESS_CONTROL_LEVEL_GUESTS = 0
 
 ## CFG_ACCESS_CONTROL_LEVEL_ACCOUNTS -- account registration and
 ## activation policy.  When 0, users can register and accounts are
 ## automatically activated.  When 1, users can register but admin must
 ## activate the accounts.  When 2, users cannot register nor update
 ## their email address, only admin can register accounts.  When 3,
 ## users cannot register nor update email address nor password, only
 ## admin can register accounts.  When 4, the same as 3 applies, nor
 ## user cannot change his login method.  When 5, then the same as 4
 ## applies, plus info about how to get an account is hidden from the
 ## login page.
 CFG_ACCESS_CONTROL_LEVEL_ACCOUNTS = 0
 
 ## CFG_ACCESS_CONTROL_LIMIT_REGISTRATION_TO_DOMAIN -- limit account
 ## registration to certain email addresses?  If wanted, give domain
 ## name below, e.g. "cern.ch".  If not wanted, leave it empty.
 CFG_ACCESS_CONTROL_LIMIT_REGISTRATION_TO_DOMAIN =
 
 ## CFG_ACCESS_CONTROL_NOTIFY_ADMIN_ABOUT_NEW_ACCOUNTS -- send a
 ## notification email to the administrator when a new account is
 ## created?  Use 0 for no, 1 for yes.
 CFG_ACCESS_CONTROL_NOTIFY_ADMIN_ABOUT_NEW_ACCOUNTS = 0
 
 ## CFG_ACCESS_CONTROL_NOTIFY_USER_ABOUT_NEW_ACCOUNT -- send a
 ## notification email to the user when a new account is created in order to
 ## to verify the validity of the provided email address?  Use
 ## 0 for no, 1 for yes.
 CFG_ACCESS_CONTROL_NOTIFY_USER_ABOUT_NEW_ACCOUNT = 1
 
 ## CFG_ACCESS_CONTROL_NOTIFY_USER_ABOUT_ACTIVATION -- send a
 ## notification email to the user when a new account is activated?
 ## Use 0 for no, 1 for yes.
 CFG_ACCESS_CONTROL_NOTIFY_USER_ABOUT_ACTIVATION = 0
 
 ## CFG_ACCESS_CONTROL_NOTIFY_USER_ABOUT_DELETION -- send a
 ## notification email to the user when a new account is deleted or
 ## account demand rejected?  Use 0 for no, 1 for yes.
 CFG_ACCESS_CONTROL_NOTIFY_USER_ABOUT_DELETION = 0
 
 ## CFG_APACHE_PASSWORD_FILE -- the file where Apache user credentials
 ## are stored.  Must be an absolute pathname.  If the value does not
 ## start by a slash, it is considered to be the filename of a file
 ## located under prefix/var/tmp directory.  This is useful for the
 ## demo site testing purposes.  For the production site, if you plan
 ## to restrict access to some collections based on the Apache user
 ## authentication mechanism, you should put here an absolute path to
 ## your Apache password file.
 CFG_APACHE_PASSWORD_FILE = demo-site-apache-user-passwords
 
 ## CFG_APACHE_GROUP_FILE -- the file where Apache user groups are
 ## defined.  See the documentation of the preceding config variable.
 CFG_APACHE_GROUP_FILE = demo-site-apache-user-groups
 
 ###################################
 ## Part 8: WebSession parameters ##
 ###################################
 
 ## This section contains some configuration parameters for tweaking
 ## session handling.
 
 ## CFG_WEBSESSION_EXPIRY_LIMIT_DEFAULT -- number of days after which a session
 ## and the corresponding cookie is considered expired.
 CFG_WEBSESSION_EXPIRY_LIMIT_DEFAULT = 2
 
 ## CFG_WEBSESSION_EXPIRY_LIMIT_REMEMBER -- number of days after which a session
 ## and the corresponding cookie is considered expired, when the user has
 ## requested to permanently stay logged in.
 CFG_WEBSESSION_EXPIRY_LIMIT_REMEMBER = 365
 
 ## CFG_WEBSESSION_RESET_PASSWORD_EXPIRE_IN_DAYS -- when user requested
 ## a password reset, for how many days is the URL valid?
 CFG_WEBSESSION_RESET_PASSWORD_EXPIRE_IN_DAYS = 3
 
 ## CFG_WEBSESSION_ADDRESS_ACTIVATION_EXPIRE_IN_DAYS -- when an account
 ## activation email was sent, for how many days is the URL valid?
 CFG_WEBSESSION_ADDRESS_ACTIVATION_EXPIRE_IN_DAYS = 3
 
 ## CFG_WEBSESSION_NOT_CONFIRMED_EMAIL_ADDRESS_EXPIRE_IN_DAYS -- when
 ## user won't confirm his email address and not complete
 ## registeration, after how many days will it expire?
 CFG_WEBSESSION_NOT_CONFIRMED_EMAIL_ADDRESS_EXPIRE_IN_DAYS = 10
 
 ## CFG_WEBSESSION_DIFFERENTIATE_BETWEEN_GUESTS -- when set to 1, the session
 ## system allocates the same uid=0 to all guests users regardless of where they
 ## come from. 0 allocate a unique uid to each guest.
 CFG_WEBSESSION_DIFFERENTIATE_BETWEEN_GUESTS = 0
 
 ################################
 ## Part 9: BibRank parameters ##
 ################################
 
 ## This section contains some configuration parameters for the ranking
 ## system.
 
 ## CFG_BIBRANK_SHOW_READING_STATS -- do we want to show reading
 ## similarity stats?  ('People who viewed this page also viewed')
 CFG_BIBRANK_SHOW_READING_STATS = 1
 
 ## CFG_BIBRANK_SHOW_DOWNLOAD_STATS -- do we want to show the download
 ## similarity stats?  ('People who downloaded this document also
 ## downloaded')
 CFG_BIBRANK_SHOW_DOWNLOAD_STATS = 1
 
 ## CFG_BIBRANK_SHOW_DOWNLOAD_GRAPHS -- do we want to show download
 ## history graph? (0=no | 1=classic/gnuplot | 2=flot)
 CFG_BIBRANK_SHOW_DOWNLOAD_GRAPHS = 1
 
 ## CFG_BIBRANK_SHOW_DOWNLOAD_GRAPHS_CLIENT_IP_DISTRIBUTION -- do we
 ## want to show a graph representing the distribution of client IPs
 ## downloading given document?
 CFG_BIBRANK_SHOW_DOWNLOAD_GRAPHS_CLIENT_IP_DISTRIBUTION = 0
 
 ## CFG_BIBRANK_SHOW_CITATION_LINKS -- do we want to show the 'Cited
 ## by' links?  (useful only when you have citations in the metadata)
 CFG_BIBRANK_SHOW_CITATION_LINKS = 1
 
 ## CFG_BIBRANK_SHOW_CITATION_STATS -- de we want to show citation
 ## stats?  ('Cited by M recors', 'Co-cited with N records')
 CFG_BIBRANK_SHOW_CITATION_STATS = 1
 
 ## CFG_BIBRANK_SHOW_CITATION_GRAPHS -- do we want to show citation
 ## history graph?  (0=no | 1=classic/gnuplot | 2=flot)
 CFG_BIBRANK_SHOW_CITATION_GRAPHS = 1
 
 ####################################
 ## Part 10: WebComment parameters ##
 ####################################
 
 ## This section contains some configuration parameters for the
 ## commenting and reviewing facilities.
 
 ## CFG_WEBCOMMENT_ALLOW_COMMENTS -- do we want to allow users write
 ## public comments on records?
 CFG_WEBCOMMENT_ALLOW_COMMENTS = 1
 
 ## CFG_WEBCOMMENT_ALLOW_REVIEWS -- do we want to allow users write
 ## public reviews of records?
 CFG_WEBCOMMENT_ALLOW_REVIEWS = 1
 
 ## CFG_WEBCOMMENT_ALLOW_SHORT_REVIEWS -- do we want to allow short
 ## reviews, that is just the attribution of stars without submitting
 ## detailed review text?
 CFG_WEBCOMMENT_ALLOW_SHORT_REVIEWS = 0
 
 ## CFG_WEBCOMMENT_NB_REPORTS_BEFORE_SEND_EMAIL_TO_ADMIN -- if users
 ## report a comment to be abusive, how many they have to be before the
 ## site admin is alerted?
 CFG_WEBCOMMENT_NB_REPORTS_BEFORE_SEND_EMAIL_TO_ADMIN = 5
 
 ## CFG_WEBCOMMENT_NB_COMMENTS_IN_DETAILED_VIEW -- how many comments do
 ## we display in the detailed record page upon welcome?
 CFG_WEBCOMMENT_NB_COMMENTS_IN_DETAILED_VIEW = 1
 
 ## CFG_WEBCOMMENT_NB_REVIEWS_IN_DETAILED_VIEW -- how many reviews do
 ## we display in the detailed record page upon welcome?
 CFG_WEBCOMMENT_NB_REVIEWS_IN_DETAILED_VIEW = 1
 
 ## CFG_WEBCOMMENT_ADMIN_NOTIFICATION_LEVEL -- do we notify the site
 ## admin after every comment?
 CFG_WEBCOMMENT_ADMIN_NOTIFICATION_LEVEL = 1
 
 ## CFG_WEBCOMMENT_TIMELIMIT_PROCESSING_COMMENTS_IN_SECONDS -- how many
 ## elapsed seconds do we consider enough when checking for possible
 ## multiple comment submissions by a user?
 CFG_WEBCOMMENT_TIMELIMIT_PROCESSING_COMMENTS_IN_SECONDS = 20
 
 ## CFG_WEBCOMMENT_TIMELIMIT_PROCESSING_REVIEWS_IN_SECONDS -- how many
 ## elapsed seconds do we consider enough when checking for possible
 ## multiple review submissions by a user?
 CFG_WEBCOMMENT_TIMELIMIT_PROCESSING_REVIEWS_IN_SECONDS = 20
 
 ## CFG_WEBCOMMENT_USE_RICH_EDITOR -- enable the WYSIWYG
 ## Javascript-based editor when user edits comments?
 CFG_WEBCOMMENT_USE_RICH_TEXT_EDITOR = False
 
 ## CFG_WEBCOMMENT_ALERT_ENGINE_EMAIL -- the email address from which the
 ## alert emails will appear to be sent:
 CFG_WEBCOMMENT_ALERT_ENGINE_EMAIL = info@invenio-software.org
 
 ## CFG_WEBCOMMENT_DEFAULT_MODERATOR -- if no rules are
 ## specified to indicate who is the comment moderator of
 ## a collection, this person will be used as default
 CFG_WEBCOMMENT_DEFAULT_MODERATOR = info@invenio-software.org
 
 ## CFG_WEBCOMMENT_USE_MATHJAX_IN_COMMENTS -- do we want to allow the use
 ## of MathJax plugin to render latex input in comments?
 CFG_WEBCOMMENT_USE_MATHJAX_IN_COMMENTS = 1
 
 ## CFG_WEBCOMMENT_AUTHOR_DELETE_COMMENT_OPTION -- allow comment author to
 ## delete its own comment?
 CFG_WEBCOMMENT_AUTHOR_DELETE_COMMENT_OPTION = 1
 
 # CFG_WEBCOMMENT_EMAIL_REPLIES_TO -- which field of the record define
 # email addresses that should be notified of newly submitted comments,
 # and for which collection. Use collection names as keys, and list of
 # tags as values
 CFG_WEBCOMMENT_EMAIL_REPLIES_TO = {
     'Articles': ['506__d', '506__m'],
     }
 
 # CFG_WEBCOMMENT_RESTRICTION_DATAFIELD -- which field of the record
 # define the restriction (must be linked to WebAccess
 # 'viewrestrcomment') to apply to newly submitted comments, and for
 # which collection. Use collection names as keys, and one tag as value
 CFG_WEBCOMMENT_RESTRICTION_DATAFIELD = {
     'Articles': '5061_a',
     'Pictures': '5061_a',
     'Theses': '5061_a',
     }
 
 # CFG_WEBCOMMENT_ROUND_DATAFIELD -- which field of the record define
 # the current round of comment for which collection. Use collection
 # name as key, and one tag as value
 CFG_WEBCOMMENT_ROUND_DATAFIELD = {
     'Articles': '562__c',
     'Pictures': '562__c',
     }
 
 # CFG_WEBCOMMENT_MAX_ATTACHMENT_SIZE -- max file size per attached
 # file, in bytes.  Choose 0 if you don't want to limit the size
 CFG_WEBCOMMENT_MAX_ATTACHMENT_SIZE = 5242880
 
 # CFG_WEBCOMMENT_MAX_ATTACHED_FILES -- maxium number of files that can
 # be attached per comment.  Choose 0 if you don't want to limit the
 # number of files.  File uploads can be restricted with action
 # "attachcommentfile".
 CFG_WEBCOMMENT_MAX_ATTACHED_FILES = 5
 
 # CFG_WEBCOMMENT_MAX_COMMENT_THREAD_DEPTH -- how many levels of
 # indentation discussions can be.  This can be used to ensure that
 # discussions will not go into deep levels of nesting if users don't
 # understand the difference between "reply to comment" and "add
 # comment". When the depth is reached, any "reply to comment" is
 # conceptually converted to a "reply to thread" (i.e. reply to this
 # parent's comment). Use -1 for no limit, 0 for unthreaded (flat)
 # discussions.
 CFG_WEBCOMMENT_MAX_COMMENT_THREAD_DEPTH = 1
 
 ##################################
 ## Part 11: BibSched parameters ##
 ##################################
 
 ## This section contains some configuration parameters for the
 ## bibliographic task scheduler.
 
 ## CFG_BIBSCHED_REFRESHTIME -- how often do we want to refresh
 ## bibsched monitor? (in seconds)
 CFG_BIBSCHED_REFRESHTIME = 5
 
 ## CFG_BIBSCHED_LOG_PAGER -- what pager to use to view bibsched task
 ## logs?
 CFG_BIBSCHED_LOG_PAGER = /bin/more
 
 ## CFG_BIBSCHED_GC_TASKS_OLDER_THAN -- after how many days to perform the
 ## gargbage collector of BibSched queue (i.e. removing/moving task to archive).
 CFG_BIBSCHED_GC_TASKS_OLDER_THAN = 30
 
 ## CFG_BIBSCHED_GC_TASKS_TO_REMOVE -- list of BibTask that can be safely
 ## removed from the BibSched queue once they are DONE.
 CFG_BIBSCHED_GC_TASKS_TO_REMOVE = bibindex,bibreformat,webcoll,bibrank,inveniogc
 
 ## CFG_BIBSCHED_GC_TASKS_TO_ARCHIVE -- list of BibTasks that should be safely
 ## archived out of the BibSched queue once they are DONE.
 CFG_BIBSCHED_GC_TASKS_TO_ARCHIVE = bibupload,oaiarchive
 
 ## CFG_BIBSCHED_MAX_NUMBER_CONCURRENT_TASKS -- maximum number of BibTasks
 ## that can run concurrently.
 ## NOTE: concurrent tasks are still considered as an experimental
 ## feature. Please keep this value set to 1 on production environments.
 CFG_BIBSCHED_MAX_NUMBER_CONCURRENT_TASKS = 1
 
 ## CFG_BIBSCHED_PROCESS_USER -- bibsched and bibtask processes must
 ## usually run under the same identity as the Apache web server
 ## process in order to share proper file read/write privileges.  If
 ## you want to force some other bibsched/bibtask user, e.g. because
 ## you are using a local `invenio' user that belongs to your
 ## `www-data' Apache user group and so shares writing rights with your
 ## Apache web server process in this way, then please set its username
 ## identity here.  Otherwise we shall check whether your
 ## bibsched/bibtask processes are run under the same identity as your
 ## Apache web server process (in which case you can leave the default
 ## empty value here).
 CFG_BIBSCHED_PROCESS_USER =
 
 ###################################
 ## Part 12: WebBasket parameters ##
 ###################################
 
 ## CFG_WEBBASKET_MAX_NUMBER_OF_DISPLAYED_BASKETS -- a safety limit for
 ## a maximum number of displayed baskets
 CFG_WEBBASKET_MAX_NUMBER_OF_DISPLAYED_BASKETS = 20
 
 ## CFG_WEBBASKET_USE_RICH_TEXT_EDITOR -- enable the WYSIWYG
 ## Javascript-based editor when user edits comments in WebBasket?
 CFG_WEBBASKET_USE_RICH_TEXT_EDITOR = False
 
 ##################################
 ## Part 13: WebAlert parameters ##
 ##################################
 
 ## This section contains some configuration parameters for the
 ## automatic email notification alert system.
 
 ## CFG_WEBALERT_ALERT_ENGINE_EMAIL -- the email address from which the
 ## alert emails will appear to be sent:
 CFG_WEBALERT_ALERT_ENGINE_EMAIL = info@invenio-software.org
 
 ## CFG_WEBALERT_MAX_NUM_OF_RECORDS_IN_ALERT_EMAIL -- how many records
 ## at most do we send in an outgoing alert email?
 CFG_WEBALERT_MAX_NUM_OF_RECORDS_IN_ALERT_EMAIL = 20
 
 ## CFG_WEBALERT_MAX_NUM_OF_CHARS_PER_LINE_IN_ALERT_EMAIL -- number of
 ## chars per line in an outgoing alert email?
 CFG_WEBALERT_MAX_NUM_OF_CHARS_PER_LINE_IN_ALERT_EMAIL = 72
 
 ## CFG_WEBALERT_SEND_EMAIL_NUMBER_OF_TRIES -- when sending alert
 ## emails fails, how many times we retry?
 CFG_WEBALERT_SEND_EMAIL_NUMBER_OF_TRIES = 3
 
 ## CFG_WEBALERT_SEND_EMAIL_SLEEPTIME_BETWEEN_TRIES -- when sending
 ## alert emails fails, what is the sleeptime between tries? (in
 ## seconds)
 CFG_WEBALERT_SEND_EMAIL_SLEEPTIME_BETWEEN_TRIES = 300
 
 ####################################
 ## Part 14: WebMessage parameters ##
 ####################################
 
 ## CFG_WEBMESSAGE_MAX_SIZE_OF_MESSAGE -- how large web messages do we
 ## allow?
 CFG_WEBMESSAGE_MAX_SIZE_OF_MESSAGE = 20000
 
 ## CFG_WEBMESSAGE_MAX_NB_OF_MESSAGES -- how many messages for a
 ## regular user do we allow in its inbox?
 CFG_WEBMESSAGE_MAX_NB_OF_MESSAGES = 30
 
 ## CFG_WEBMESSAGE_DAYS_BEFORE_DELETE_ORPHANS -- how many days before
 ## we delete orphaned messages?
 CFG_WEBMESSAGE_DAYS_BEFORE_DELETE_ORPHANS = 60
 
 ##################################
 ## Part 15: MiscUtil parameters ##
 ##################################
 
 ## CFG_MISCUTIL_SQL_USE_SQLALCHEMY -- whether to use SQLAlchemy.pool
 ## in the DB engine of Invenio.  It is okay to enable this flag
 ## even if you have not installed SQLAlchemy.  Note that Invenio will
 ## loose some perfomance if this option is enabled.
 CFG_MISCUTIL_SQL_USE_SQLALCHEMY = False
 
 ## CFG_MISCUTIL_SQL_RUN_SQL_MANY_LIMIT -- how many queries can we run
 ## inside run_sql_many() in one SQL statement?  The limit value
 ## depends on MySQL's max_allowed_packet configuration.
 CFG_MISCUTIL_SQL_RUN_SQL_MANY_LIMIT = 10000
 
 ## CFG_MISCUTIL_SMTP_HOST -- which server to use as outgoing mail server to
 ## send outgoing emails generated by the system, for example concerning
 ## submissions or email notification alerts.
 CFG_MISCUTIL_SMTP_HOST = localhost
 
 ## CFG_MISCUTIL_SMTP_PORT -- which port to use on the outgoing mail server
 ## defined in the previous step.
 CFG_MISCUTIL_SMTP_PORT = 25
 
 ## CFG_MISCUTILS_DEFAULT_PROCESS_TIMEOUT -- the default number of seconds after
 ## which a process launched trough shellutils.run_process_with_timeout will
 ## be killed. This is useful to catch runaway processes.
 CFG_MISCUTIL_DEFAULT_PROCESS_TIMEOUT = 300
 
 ## CFG_MATHJAX_HOSTING -- if you plan to use MathJax to display TeX
 ## formulas on HTML web pages, you can specify whether you wish to use
 ## 'local' hosting or 'cdn' hosting of MathJax libraries.  (If set to
 ## 'local', you have to run 'make install-mathjax-plugin' as described
 ## in the INSTALL guide.)  If set to 'local', users will use your site
 ## to download MathJax sources.  If set to 'cdn', users will use
 ## centralized MathJax CDN servers instead.  Please note that using
 ## CDN is suitable only for small institutions or for MathJax
 ## sponsors; see the MathJax website for more details.  (Also, please
 ## note that if you plan to use MathJax on your site, you have to
 ## adapt CFG_WEBSEARCH_USE_MATHJAX_FOR_FORMATS and
 ## CFG_WEBCOMMENT_USE_MATHJAX_IN_COMMENTS configuration variables
 ## elsewhere in this file.)
 CFG_MATHJAX_HOSTING = local
 
 #################################
 ## Part 16: BibEdit parameters ##
 #################################
 
 ## CFG_BIBEDIT_TIMEOUT -- when a user edits a record, this record is
 ## locked to prevent other users to edit it at the same time.
 ## How many seconds of inactivity before the locked record again will be free
 ## for other people to edit?
 CFG_BIBEDIT_TIMEOUT = 3600
 
 ## CFG_BIBEDIT_LOCKLEVEL -- when a user tries to edit a record which there
 ## is a pending bibupload task for in the queue, this shouldn't be permitted.
 ## The lock level determines how thouroughly the queue should be investigated
 ## to determine if this is the case.
 ## Level 0 - always permits editing, doesn't look at the queue
 ##           (unsafe, use only if you know what you are doing)
 ## Level 1 - permits editing if there are no queued bibedit tasks for this record
 ##           (safe with respect to bibedit, but not for other bibupload maintenance jobs)
 ## Level 2 - permits editing if there are no queued bibupload tasks of any sort
 ##           (safe, but may lock more than necessary if many cataloguers around)
 ## Level 3 - permits editing if no queued bibupload task concerns given record
 ##           (safe, most precise locking, but slow,
 ##            checks for 001/EXTERNAL_SYSNO_TAG/EXTERNAL_OAIID_TAG)
 ## The recommended level is 3 (default) or 2 (if you use maintenance jobs often).
 CFG_BIBEDIT_LOCKLEVEL = 3
 
 ## CFG_BIBEDIT_PROTECTED_FIELDS -- a comma-separated list of fields that BibEdit
 ## will not allow to be added, edited or deleted. Wildcards are not supported,
 ## but conceptually a wildcard is added at the end of every field specification.
 ## Examples:
 ## 500A   - protect all MARC fields with tag 500 and first indicator A
 ## 5      - protect all MARC fields in the 500-series.
 ## 909C_a - protect subfield a in tag 909 with first indicator C and empty
 ##          second indicator
 ## Note that 001 is protected by default, but if protection of other
 ## identifiers or automated fields is a requirement, they should be added to
 ## this list.
 CFG_BIBEDIT_PROTECTED_FIELDS =
 
 ## CFG_BIBEDITMULTI_LIMIT_INSTANT_PROCESSING -- maximum number of records
 ## that can be modified instantly using the multi-record editor. Above
 ## this limit, modifications will only be executed in limited hours.
 CFG_BIBEDITMULTI_LIMIT_INSTANT_PROCESSING = 2000
 
 ## CFG_BIBEDITMULTI_LIMIT_DELAYED_PROCESSING -- maximum number of records
 ## that can be send for modification without having a superadmin role.
 ## If the number of records is between CFG_BIBEDITMULTI_LIMIT_INSTANT_PROCESSING
 ## and this number, the modifications will take place only in limited hours.
 CFG_BIBEDITMULTI_LIMIT_DELAYED_PROCESSING = 20000
 
 ## CFG_BIBEDITMULTI_LIMIT_DELAYED_PROCESSING_TIME -- Allowed time to
 ## execute modifications on records, when the number exceeds
 ## CFG_BIBEDITMULTI_LIMIT_INSTANT_PROCESSING.
 CFG_BIBEDITMULTI_LIMIT_DELAYED_PROCESSING_TIME = 22:00-05:00
 
 ###################################
 ## Part 17: BibUpload parameters ##
 ###################################
 
 ## CFG_BIBUPLOAD_REFERENCE_TAG -- where do we store references?
 CFG_BIBUPLOAD_REFERENCE_TAG = 999
 
 ## CFG_BIBUPLOAD_EXTERNAL_SYSNO_TAG -- where do we store external
 ## system numbers?  Useful for matching when our records come from an
 ## external digital library system.
 CFG_BIBUPLOAD_EXTERNAL_SYSNO_TAG = 970__a
 
 ## CFG_BIBUPLOAD_EXTERNAL_OAIID_TAG -- where do we store OAI ID tags
 ## of harvested records?  Useful for matching when we harvest stuff
 ## via OAI that we do not want to reexport via Invenio OAI; so records
 ## may have only the source OAI ID stored in this tag (kind of like
 ## external system number too).
 CFG_BIBUPLOAD_EXTERNAL_OAIID_TAG = 035__a
 
 ## CFG_BIBUPLOAD_EXTERNAL_OAIID_PROVENANCE_TAG -- where do we store OAI SRC
 ## tags of harvested records?  Useful for matching when we harvest stuff
 ## via OAI that we do not want to reexport via Invenio OAI; so records
 ## may have only the source OAI SRC stored in this tag (kind of like
 ## external system number too). Note that the field should be the same of
 ## CFG_BIBUPLOAD_EXTERNAL_OAIID_TAG.
 CFG_BIBUPLOAD_EXTERNAL_OAIID_PROVENANCE_TAG = 035__9
 
 ## CFG_BIBUPLOAD_STRONG_TAGS -- a comma-separated list of tags that
 ## are strong enough to resist the replace mode.  Useful for tags that
 ## might be created from an external non-metadata-like source,
 ## e.g. the information about the number of copies left.
 CFG_BIBUPLOAD_STRONG_TAGS = 964
 
 ## CFG_BIBUPLOAD_CONTROLLED_PROVENANCE_TAGS -- a comma-separated list
 ## of tags that contain provenance information that should be checked
 ## in the bibupload correct mode via matching provenance codes.  (Only
 ## field instances of the same provenance information would be acted
 ## upon.)  Please specify the whole tag info up to subfield codes.
 CFG_BIBUPLOAD_CONTROLLED_PROVENANCE_TAGS = 6531_9
 
 ## CFG_BIBUPLOAD_FFT_ALLOWED_LOCAL_PATHS -- a comma-separated list of system
 ## paths from which it is allowed to take fulltextes that will be uploaded via
 ## FFT (CFG_TMPDIR is included by default).
 CFG_BIBUPLOAD_FFT_ALLOWED_LOCAL_PATHS = /tmp,/home
 
 ## CFG_BIBUPLOAD_FFT_ALLOWED_EXTERNAL_URLS -- a dictionary containing external
 ## URLs that can be accessed by Invenio and specific HTTP headers that will be
 ## used for each URL.
 ## The keys of the dictionary are regular expressions matching a set of URLs,
 ## the values are dictionaries of headers as consumed by urllib2.Request. If a
 ## regular expression matching all URLs is created at the end of the list, it
 ## means that Invenio will download all URLs. Otherwise Invenio will just
 ## download authorized URLs.
 ## CFG_BIBUPLOAD_FFT_ALLOWED_EXTERNAL_URLS = [
 ##     ('http://myurl.com/.*', {'User-Agent': 'Me'}),
 ##     ('http://yoururl.com/.*', {'User-Agent': 'You', 'Accept': 'text/plain'}),
 ##     ('http://.*', {'User-Agent': 'Invenio'}),
 ##     ]
 CFG_BIBUPLOAD_FFT_ALLOWED_EXTERNAL_URLS = [
     ('http://.*', {'User-Agent': 'Invenio'}),
     ]
 
 ## CFG_BIBUPLOAD_SERIALIZE_RECORD_STRUCTURE -- do we want to serialize
 ## internal representation of records (Pythonic record structure) into
 ## the database?  This can improve internal processing speed of some
 ## operations at the price of somewhat bigger disk space usage.
 ## If you change this value after some records have already been added
 ## to your installation, you may want to run:
 ##     $ /opt/invenio/bin/inveniocfg --reset-recstruct-cache
 ## in order to either erase the cache thus freeing database space,
 ## or to fill the cache for all records that have not been cached yet.
 CFG_BIBUPLOAD_SERIALIZE_RECORD_STRUCTURE = 1
 
 ## CFG_BATCHUPLOADER_FILENAME_MATCHING_POLICY -- a comma-separated list
 ## indicating which fields match the file names of the documents to be
 ## uploaded.
 ## The matching will be done in the same order as the list provided.
 CFG_BATCHUPLOADER_FILENAME_MATCHING_POLICY = reportnumber,recid
 
 ## CFG_BATCHUPLOADER_DAEMON_DIR -- Directory where the batchuploader daemon
 ## will look for the subfolders metadata and document by default.
 ## If path is relative, CFG_PREFIX will be joined as a prefix
 CFG_BATCHUPLOADER_DAEMON_DIR = var/batchupload
 
 ## CFG_BATCHUPLOADER_WEB_ROBOT_AGENT -- Comma-separated list to specify the
 ## agents permitted when calling batch uploader web interface
 ## cdsweb.cern.ch/batchuploader/robotupload
 ## if using a curl, eg: curl xxx -A invenio_webupload
 CFG_BATCHUPLOADER_WEB_ROBOT_AGENT = invenio_webupload
 
 ## CFG_BATCHUPLOADER_WEB_ROBOT_RIGHTS -- Access list specifying for each
 ## IP address, which collections are allowed using batch uploader robot
 ## interface.
 CFG_BATCHUPLOADER_WEB_ROBOT_RIGHTS = {
     '10.0.0.1': ['BOOK', 'REPORT'], # Example 1
     '10.0.0.2': ['POETRY', 'PREPRINT'], # Example 2
     }
 
 ####################################
 ## Part 18: BibCatalog parameters ##
 ####################################
 
 ## CFG_BIBCATALOG_SYSTEM -- set desired catalog system. For example, RT.
 CFG_BIBCATALOG_SYSTEM =
-## CFG_BIBCATALOG_QUEUES -- UNUSED
-CFG_BIBCATALOG_QUEUES = General
 
 ## RT CONFIGURATION
 ## CFG_BIBCATALOG_SYSTEM_RT_CLI -- path to the RT CLI client
 CFG_BIBCATALOG_SYSTEM_RT_CLI = /usr/bin/rt
 
 ## CFG_BIBCATALOG_SYSTEM_RT_URL -- Base URL of the remote RT system
 CFG_BIBCATALOG_SYSTEM_RT_URL = http://localhost/rt3
 
 ## CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_USER -- Set the username for a default RT account
-## on remote system, with limited privileges, in order to only create tickets.
+## on remote system, with limited privileges, in order to only create and modify own tickets.
 CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_USER =
 
 ## CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_PWD -- Set the password for the default RT account
 ## on remote system.
 CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_PWD =
 
 ####################################
 ## Part 19: BibFormat parameters  ##
 ####################################
 
 ## CFG_BIBFORMAT_HIDDEN_TAGS -- comma-separated list of MARC tags that
 ## are not shown to users not having cataloging authorizations.
 CFG_BIBFORMAT_HIDDEN_TAGS = 595
 
 ## CFG_BIBFORMAT_ADDTHIS_ID -- if you want to use the AddThis service from
 ## <http://www.addthis.com/>, set this value to the pubid parameter as
 ## provided by the service (e.g. ra-4ff80aae118f4dad).
 ## See also the bfe_addthis.py BibFormat element.
 CFG_BIBFORMAT_ADDTHIS_ID =
 
 ####################################
 ## Part 20: BibMatch parameters  ##
 ####################################
 
 ## CFG_BIBMATCH_LOCAL_SLEEPTIME -- Determines the amount of seconds to sleep
 ## between search queries on LOCAL system.
 CFG_BIBMATCH_LOCAL_SLEEPTIME = 0.0
 
 ## CFG_BIBMATCH_REMOTE_SLEEPTIME -- Determines the amount of seconds to sleep
 ## between search queries on REMOTE systems.
 CFG_BIBMATCH_REMOTE_SLEEPTIME = 2.0
 
 ## CFG_BIBMATCH_FUZZY_WORDLIMITS -- Determines the amount of words to extract
 ## from a certain fields value during fuzzy matching mode. Add/change field
 ## and appropriate number to the dictionary to configure this.
 CFG_BIBMATCH_FUZZY_WORDLIMITS = {
                                 '100__a': 2,
                                 '245__a': 4
                                 }
 
 ## CFG_BIBMATCH_FUZZY_EMPTY_RESULT_LIMIT -- Determines the amount of empty results
 ## to accept during fuzzy matching mode.
 CFG_BIBMATCH_FUZZY_EMPTY_RESULT_LIMIT = 1
 
 ## CFG_BIBMATCH_QUERY_TEMPLATES -- Here you can set the various predefined querystrings
 ## used to standardize common matching queries. By default the following templates
 ## are given:
 ## title             - standard title search. Taken from 245__a (default)
 ## title-author      - title and author search (i.e. this is a title AND author a)
 ##                     Taken from 245__a and 100__a
 ## reportnumber      - reportnumber search (i.e. reportnumber:REP-NO-123).
 CFG_BIBMATCH_QUERY_TEMPLATES = {
                                 'title' : '[title]',
                                 'title-author' : '[title] [author]',
                                 'reportnumber' : 'reportnumber:[reportnumber]'
                                 }
 
 ######################################
 ## Part 21: BibAuthorID parameters  ##
 ######################################
 
 # CFG_BIBAUTHORID_MAX_PROCESSES is the max number of processes
 # that may be spawned by the disambiguation algorithm
 CFG_BIBAUTHORID_MAX_PROCESSES = 4
 
 # CFG_BIBAUTHORID_PERSONID_SQL_MAX_THREADS is the max number of threads
 # to parallelize sql queries during personID tables updates
 CFG_BIBAUTHORID_PERSONID_SQL_MAX_THREADS = 4
 
 # CFG_BIBAUTHORID_PERSONID_MIN_P_FROM_BCTKD_RA is the minimum confidence needed
 # when backtracking automatically disambiguated authors to persons.
 # Values in [0,1]
 CFG_BIBAUTHORID_PERSONID_MIN_P_FROM_BCTKD_RA = 0.5
 
 # CFG_BIBAUTHORID_PERSONID_MIN_P_FROM_NEW_RA is the threshold for
 # the confidence in a paper by the disambiguation algorithm to have it
 # automatically connected to a personID. Papers below the thresholds are
 # left disconnected from persons if not already connected in other ways.
 # values in [0,1]
 CFG_BIBAUTHORID_PERSONID_MIN_P_FROM_NEW_RA = 0.5
 
 # CFG_BIBAUTHORID_PERSONID_MAX_COMP_LIST_MIN_TRSH minimum threshold for
 # disambiguated authors and persons: if less compatible than this the update
 # process will create a new person to associate to the found disambiguated author.
 CFG_BIBAUTHORID_PERSONID_MAX_COMP_LIST_MIN_TRSH = 0.5
 
 # CFG_BIBAUTHORID_PERSONID_MAX_COMP_LIST_MIN_TRSH_P_N is a fallback mechanism
 # to force a merge if a certain percentage of papers is compatible no matter
 # what the confidences on the automatically disambiguated author looks like
 CFG_BIBAUTHORID_PERSONID_MAX_COMP_LIST_MIN_TRSH_P_N = 0.5
 
 # CFG_BIBAUTHORID_EXTERNAL_CLAIMED_RECORDS_KEY defines the user info
 # keys for externally claimed records in an remote-login scenario--e.g. from arXiv.org
 # e.g. "external_arxivids" for arXiv SSO
 CFG_BIBAUTHORID_EXTERNAL_CLAIMED_RECORDS_KEY =
 
 # CFG_BIBAUTHORID_ATTACH_VA_TO_MULTIPLE_RAS determines if the authorid
 # algorithm is allowed to attach a virtual author to multiple
 # real authors in the last run of the orphan processing.
 # Comma separated list of values.
 CFG_BIBAUTHORID_ATTACH_VA_TO_MULTIPLE_RAS = False
 
 # CFG_BIBAUTHORID_AID_ENABLED
 # Globally enable AuthorID Interfaces.
 #     If False: No guest, user or operator will have access to the system.
 CFG_BIBAUTHORID_ENABLED = True
 
 # CFG_BIBAUTHORID_AID_ON_AUTHORPAGES
 # Enable AuthorID information on the author pages.
 CFG_BIBAUTHORID_ON_AUTHORPAGES = True
 
 # CFG_BIBAUTHORID_AUTHOR_TICKET_ADMIN_EMAIL defines the eMail address
 # all ticket requests concerning authors will be sent to.
 CFG_BIBAUTHORID_AUTHOR_TICKET_ADMIN_EMAIL = info@invenio-software.org
 
 ######################################
 ## Part 22: BibClassify parameters  ##
 ######################################
 
 # CFG_BIBCLASSIFY_WEB_MAXKW -- maximum number of keywords to display
 # in the Keywords tab web page.
 CFG_BIBCLASSIFY_WEB_MAXKW = 100
 
 ########################################
 ## Part 23: Plotextractor parameters  ##
 ########################################
 
 ## CFG_PLOTEXTRACTOR_SOURCE_BASE_URL -- for acquiring source tarballs for plot
 ## extraction, where should we look?  If nothing is set, we'll just go
 ## to arXiv, but this can be a filesystem location, too
 CFG_PLOTEXTRACTOR_SOURCE_BASE_URL = http://arxiv.org/
 
 ## CFG_PLOTEXTRACTOR_SOURCE_TARBALL_FOLDER -- for acquiring source tarballs for plot
 ## extraction, subfolder where the tarballs sit
 CFG_PLOTEXTRACTOR_SOURCE_TARBALL_FOLDER = e-print/
 
 ## CFG_PLOTEXTRACTOR_SOURCE_PDF_FOLDER -- for acquiring source tarballs for plot
 ## extraction, subfolder where the pdf sit
 CFG_PLOTEXTRACTOR_SOURCE_PDF_FOLDER = pdf/
 
 ## CFG_PLOTEXTRACTOR_DOWNLOAD_TIMEOUT -- a float representing the number of seconds
 ## to wait between each download of pdf and/or tarball from source URL.
 CFG_PLOTEXTRACTOR_DOWNLOAD_TIMEOUT = 2.0
 
 ## CFG_PLOTEXTRACTOR_CONTEXT_LIMIT -- when extracting context of plots from
 ## TeX sources, this is the limitation of characters in each direction to extract
 ## context from. Default 750.
 CFG_PLOTEXTRACTOR_CONTEXT_EXTRACT_LIMIT = 750
 
 ## CFG_PLOTEXTRACTOR_DISALLOWED_TEX -- when extracting context of plots from TeX
 ## sources, this is the list of TeX tags that will trigger 'end of context'.
 CFG_PLOTEXTRACTOR_DISALLOWED_TEX = begin,end,section,includegraphics,caption,acknowledgements
 
 ## CFG_PLOTEXTRACTOR_CONTEXT_WORD_LIMIT -- when extracting context of plots from
 ## TeX sources, this is the limitation of words in each direction. Default 75.
 CFG_PLOTEXTRACTOR_CONTEXT_WORD_LIMIT = 75
 
 ## CFG_PLOTEXTRACTOR_CONTEXT_SENTENCE_LIMIT -- when extracting context of plots from
 ## TeX sources, this is the limitation of sentences in each direction. Default 2.
 CFG_PLOTEXTRACTOR_CONTEXT_SENTENCE_LIMIT = 2
 
 ##########################
 ##  THAT's ALL, FOLKS!  ##
 ##########################
diff --git a/modules/bibcatalog/lib/bibcatalog_system.py b/modules/bibcatalog/lib/bibcatalog_system.py
index 68bd876fe..7c1443b47 100644
--- a/modules/bibcatalog/lib/bibcatalog_system.py
+++ b/modules/bibcatalog/lib/bibcatalog_system.py
@@ -1,158 +1,174 @@
 # -*- coding: utf-8 -*-
 ##
 ## This file is part of Invenio.
 ## Copyright (C) 2009, 2010, 2011 CERN.
 ##
 ## Invenio is free software; you can redistribute it and/or
 ## modify it under the terms of the GNU General Public License as
 ## published by the Free Software Foundation; either version 2 of the
 ## License, or (at your option) any later version.
 ##
 ## Invenio is distributed in the hope that it will be useful, but
 ## WITHOUT ANY WARRANTY; without even the implied warranty of
 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 ## General Public License for more details.
 ##
 ## You should have received a copy of the GNU General Public License
 ## along with Invenio; if not, write to the Free Software Foundation, Inc.,
 ## 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
 
 """
 Provide a "ticket" interface with a request tracker.
 Please see the help/hacking/bibcatalog-api page for details.
 This is a base class that cannot be instantiated.
 """
 
 from invenio.webuser import get_user_preferences
 
 class BibCatalogSystem:
     """ A template class for ticket support."""
 
     TICKET_ATTRIBUTES = ['ticketid', 'priority', 'recordid', 'subject', 'text', 'creator', 'owner', 'date', 'status', 'queue', 'url_display', 'url_modify', 'url_close']
 
     def check_system(self, uid=None):
         """Check connectivity. Return a string describing the error or an empty str
            @param uid: invenio user id. optional
            @type uid: number
            @return: empty string on success. Otherwise a string describing error.
            @rtype: string
         """
-        return "this class cannot be instantiated"
+        raise NotImplementedError("This class cannot be instantiated")
 
     def ticket_search(self, uid, recordid=-1, subject="", text="", creator="", owner="", \
-                      date_from="", date_until="", status="", priority=""):
+                      date_from="", date_until="", status="", priority="", queue=""):
         """Search for tickets based on various criteria. Return an array of ticket numbers
            @param uid: invenio user id.
            @type uid: number
            @param recordid: search criteria - ticket contains this record id.
            @type recordid: number
            @param subject: search criteria - ticket has this subject (substr).
            @type subject: string
            @param text: search criteria - ticket has this text in body (substr).
            @type text: string
            @param creator: search criteria - ticket creator's id.
            @type creator: number
            @param owner: search criteria - ticket owner's id.
            @type owner: number
            @param date_from: search criteria - ticket created starting from this date. Example: '2009-01-24'
            @type date_until: date in yyyy-mm-dd format
            @param date_until: search criteria - ticket created until from this date. Example: '2009-01-24'
            @type date_from: date in yyyy-mm-dd format
            @param status: search criteria - ticket has this status. Example: 'resolved'.
            @type status: string
            @param priority: search criteria - ticket priority number.
-           @type priority: number.
+           @type priority: number
+           @param queue: search criteria - specific queue to search within
+           @type queue: string
         """
-        pass
+        raise NotImplementedError("This class cannot be instantiated")
 
     def ticket_submit(self, uid=None, subject="", recordid=-1, text="", queue="", priority="", owner="",requestor=""):
         """submit a ticket. Return ticket number on success, otherwise None
            @param uid: invenio user id. optional
            @type uid: number
            @param subject: set this as the ticket's subject.
            @type subject: string
            @param recordid: ticket concerns this record.
            @type recordid: number
            @param text: ticket body.
            @type text: string
            @param queue: the queue for this ticket (if supported).
            @type queue: string
            @param priority: ticket priority.
            @type priority: number
            @param owner: set ticket owner to this uid.
            @type owner: number
            @param requestor: set ticket requestor to this email.
            @type requestor: string
            @return: new ticket id or None
         """
-        pass
+        raise NotImplementedError("This class cannot be instantiated")
 
     def ticket_assign(self, uid, ticketid, to_user):
         """assign a ticket to a user. Return 1 on success
            @param uid: invenio user id
            @type uid: number
            @param ticketid: ticket id
            @type ticketid: number
            @param to_user: assign ticket to this user
            @type to_user: number
            @return: 1 on success, 0 otherwise
            @rtype: number
         """
-        pass
+        raise NotImplementedError("This class cannot be instantiated")
 
     def ticket_set_attribute(self, uid, ticketid, attribute, new_value):
         """set an attribute of a ticket. Return 1 on success
            @param uid: invenio user id
            @type uid: number
            @param ticketid: ticket id
            @type ticketid: number
            @param attribute: This is a member of TICKET_ATTRIBUTES.
            @type attribute: string
            @param new_value: new value for this attribute.
            @type new_value: string
            @return: 1 on success, 0 otherwise
            @rtype: number
         """
-        pass
+        raise NotImplementedError("This class cannot be instantiated")
 
     def ticket_get_attribute(self, uid, ticketid, attribute):
         """return an attribute
            @param uid: invenio user id
            @type uid: number
            @param ticketid: ticket id
            @type ticketid: number
            @param attribute: attribute name.
            @type attribute: string
            @return: the value of the attribute, or None if the ticket or attribute does not exist
            @rtype: string
         """
-        pass
+        raise NotImplementedError("This class cannot be instantiated")
 
     def ticket_get_info(self, uid, ticketid, attributes = None):
         """Return the attributes of a ticket as a dictionary whose fields are TICKET_ATTRIBUTES.
            @param uid: user id
            @type uid: number
            @param ticketid: ticket id
            @type ticketid: number
            @param attributes: a list of attributes, each in TICKET_ATTRIBUTES.
            @type attributes: list
            @return: dictionary whose fields are TICKET_ATTRIBUTES
            @rtype: dictionary
         """
-        pass
+        raise NotImplementedError("This class cannot be instantiated")
+
+    def ticket_comment(self, uid, ticketid, comment):
+        """Submit a comment to specified ticket. Accepts multi-line text.
+           @param uid: user id
+           @type uid: number
+           @param ticketid: ticket id
+           @type ticketid: number
+           @param comment: the comment to send.
+           @type comment: string
+           @return: 1 on success, otherwise 0
+           @rtype: int
+        """
+        raise NotImplementedError("This class cannot be instantiated")
+
 
 def get_bibcat_from_prefs(uid):
     """gets username and pw from user prefs as a tuple.
        if not successfull, returns None
        @param uid: user id
        @type uid: number
        @return: ('bibcatalog_username', 'bibcatalog_password')
        @rtype: tuple
     """
     user_pref = get_user_preferences(uid)
     if not user_pref.has_key('bibcatalog_username'):
         return (None, None)
     if not user_pref.has_key('bibcatalog_password'):
         return (None, None)
     return (user_pref['bibcatalog_username'], user_pref['bibcatalog_password'])
 
diff --git a/modules/bibcatalog/lib/bibcatalog_system_rt.py b/modules/bibcatalog/lib/bibcatalog_system_rt.py
index 571cf2545..4a4a3dfc4 100644
--- a/modules/bibcatalog/lib/bibcatalog_system_rt.py
+++ b/modules/bibcatalog/lib/bibcatalog_system_rt.py
@@ -1,397 +1,408 @@
 # -*- coding: utf-8 -*-
 ##
 ## This file is part of Invenio.
 ## Copyright (C) 2009, 2010, 2011 CERN.
 ##
 ## Invenio is free software; you can redistribute it and/or
 ## modify it under the terms of the GNU General Public License as
 ## published by the Free Software Foundation; either version 2 of the
 ## License, or (at your option) any later version.
 ##
 ## Invenio is distributed in the hope that it will be useful, but
 ## WITHOUT ANY WARRANTY; without even the implied warranty of
 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 ## General Public License for more details.
 ##
 ## You should have received a copy of the GNU General Public License
 ## along with Invenio; if not, write to the Free Software Foundation, Inc.,
 ## 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
 
 """
 Provide a "ticket" interface with a request tracker.
 This is a subclass of BibCatalogSystem
 """
 
 import os
 import invenio.webuser
 from invenio.shellutils import run_shell_command, escape_shell_arg
 from invenio.bibcatalog_system import BibCatalogSystem, get_bibcat_from_prefs
 
 from invenio.config import CFG_BIBCATALOG_SYSTEM, \
                            CFG_BIBCATALOG_SYSTEM_RT_CLI, \
                            CFG_BIBCATALOG_SYSTEM_RT_URL, \
-                           CFG_BIBCATALOG_QUEUES, \
                            CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_USER, \
                            CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_PWD
 
 class BibCatalogSystemRT(BibCatalogSystem):
 
     BIBCATALOG_RT_SERVER = "" #construct this by http://user:password@RT_URL
 
     def check_system(self, uid=None):
         """return an error string if there are problems"""
         if uid:
-            user_pref = invenio.webuser.get_user_preferences(uid)
-            if not user_pref.has_key('bibcatalog_username'):
-                return "user " + str(uid) + " has no bibcatalog_username"
-            rtuid = user_pref['bibcatalog_username']
-            if not user_pref.has_key('bibcatalog_password'):
-                return "user " + str(uid) + " has no bibcatalog_password"
-            rtpw = user_pref['bibcatalog_password']
+            rtuid, rtpw = get_bibcat_from_prefs(uid)
         else:
             # Assume default RT user
             rtuid = CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_USER
             rtpw = CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_PWD
 
         if not rtuid and not rtpw:
             return "No valid RT user login specified"
+
         if not CFG_BIBCATALOG_SYSTEM == 'RT':
             return "CFG_BIBCATALOG_SYSTEM is not RT though this is an RT module"
         if not CFG_BIBCATALOG_SYSTEM_RT_CLI:
             return "CFG_BIBCATALOG_SYSTEM_RT_CLI not defined or empty"
         if not os.path.exists(CFG_BIBCATALOG_SYSTEM_RT_CLI):
             return "CFG_BIBCATALOG_SYSTEM_RT_CLI " + CFG_BIBCATALOG_SYSTEM_RT_CLI + " file does not exists"
 
         # Check that you can execute the binary.. this is a safe call unless someone can fake CFG_BIBCATALOG_SYSTEM_RT_CLI (unlikely)
         dummy, myout, myerr = run_shell_command(CFG_BIBCATALOG_SYSTEM_RT_CLI + " help")
         helpfound = False
         if myerr.count("help") > 0:
             helpfound = True
         if not helpfound:
             return "Execution of CFG_BIBCATALOG_SYSTEM_RT_CLI " + CFG_BIBCATALOG_SYSTEM_RT_CLI + " help did not produce output 'help'"
 
         if not CFG_BIBCATALOG_SYSTEM_RT_URL:
             return "CFG_BIBCATALOG_SYSTEM_RT_URL not defined or empty"
         # Construct URL, split RT_URL at //
         if not CFG_BIBCATALOG_SYSTEM_RT_URL.startswith('http://') and \
            not CFG_BIBCATALOG_SYSTEM_RT_URL.startswith('https://'):
             return "CFG_BIBCATALOG__SYSTEM_RT_URL does not start with 'http://' or 'https://'"
         httppart, siteandpath = CFG_BIBCATALOG_SYSTEM_RT_URL.split("//")
         # Assemble by http://user:password@RT_URL
         BIBCATALOG_RT_SERVER = httppart + "//" + rtuid + ":" + rtpw + "@" + siteandpath
 
         #set as env var
         os.environ["RTUSER"] = rtuid
         os.environ["RTSERVER"] = BIBCATALOG_RT_SERVER
 
         #try to talk to RT server
         #this is a safe call since rtpw is the only variable in it, and it is escaped
         rtpw = escape_shell_arg(rtpw)
         dummy, myout, myerr = run_shell_command("echo "+rtpw+" | " + CFG_BIBCATALOG_SYSTEM_RT_CLI + " ls \"Subject like 'F00'\"")
         if len(myerr) > 0:
             return "could not connect to " + BIBCATALOG_RT_SERVER + " " + myerr
         #finally, check that there is some sane output like tickets or 'No matching result'
         saneoutput = (myout.count('matching') > 0) or (myout.count('1') > 0)
         if not saneoutput:
             return CFG_BIBCATALOG_SYSTEM_RT_CLI + " returned " + myout + " instead of 'matching' or '1'"
-        if not CFG_BIBCATALOG_QUEUES:
-            return "CFG_BIBCATALOG_QUEUES not defined or empty"
-        if uid:
-            (username, dummy) = get_bibcat_from_prefs(uid)
-            if (username is None):
-                return "Cannot find user preference bibcatalog_username for uid "+str(uid)
         return ""
 
     def ticket_search(self, uid, recordid=-1, subject="", text="", creator="", owner="", \
-                      date_from="", date_until="", status="", priority=""):
+                      date_from="", date_until="", status="", priority="", queue=""):
         """returns a list of ticket ID's related to this record or by
            matching the subject, creator or owner of the ticket."""
 
         search_atoms = [] #the search expression will be made by and'ing these
         if (recordid > -1):
             #search by recid
             search_atoms.append("CF.{RecordID} = " + escape_shell_arg(str(recordid)))
         if (len(subject) > 0):
             #search by subject
             search_atoms.append("Subject like " + escape_shell_arg(str(subject)))
         if (len(text) > 0):
             search_atoms.append("Content like " + escape_shell_arg(str(text)))
         if (len(str(creator)) > 0):
             #search for this person's bibcatalog_username in preferences
             creatorprefs = invenio.webuser.get_user_preferences(creator)
             creator = "Nobody can Have This Kind of Name"
             if creatorprefs.has_key("bibcatalog_username"):
                 creator = creatorprefs["bibcatalog_username"]
             search_atoms.append("Creator = " + escape_shell_arg(str(creator)))
         if (len(str(owner)) > 0):
             ownerprefs = invenio.webuser.get_user_preferences(owner)
             owner = "Nobody can Have This Kind of Name"
             if ownerprefs.has_key("bibcatalog_username"):
                 owner = ownerprefs["bibcatalog_username"]
             search_atoms.append("Owner = " + escape_shell_arg(str(owner)))
         if (len(date_from) > 0):
             search_atoms.append("Created >= " + escape_shell_arg(str(date_from)))
         if (len(date_until) > 0):
             search_atoms.append("Created <= " + escape_shell_arg(str(date_until)))
         if (len(str(status)) > 0) and (type(status) == type("this is a string")):
             search_atoms.append("Status = " + escape_shell_arg(str(status)))
         if (len(str(priority)) > 0):
             #try to convert to int
             intpri = -1
             try:
                 intpri = int(priority)
             except:
                 pass
             if (intpri > -1):
                 search_atoms.append("Priority = " + str(intpri))
+        if queue:
+            search_atoms.append("Queue = " + escape_shell_arg(queue))
         searchexp = " and ".join(search_atoms)
         tickets = []
-        if not CFG_BIBCATALOG_SYSTEM_RT_URL:
-            return tickets
 
-        httppart, siteandpath = CFG_BIBCATALOG_SYSTEM_RT_URL.split("//")
-        (username, passwd) = get_bibcat_from_prefs(uid)
-        BIBCATALOG_RT_SERVER = httppart + "//" + username + ":" + passwd + "@" + siteandpath
-        #set as env var
-        os.environ["RTUSER"] = username
-        os.environ["RTSERVER"] = BIBCATALOG_RT_SERVER
-        #search..
         if len(searchexp) == 0:
             #just make an expression that is true for all tickets
             searchexp = "Created > '1900-01-01'"
-        passwd = escape_shell_arg(passwd)
-        #make a call. This is safe since passwd and all variables in searchexp have been escaped.
-        dummy, myout, dummyerr = run_shell_command("echo "+passwd+" | " + CFG_BIBCATALOG_SYSTEM_RT_CLI + " ls -l \"" + searchexp + "\"")
+
+        command = CFG_BIBCATALOG_SYSTEM_RT_CLI + " ls -l \"" + searchexp + "\""
+        command_out = self._run_rt_command(command, uid)
+        if command_out == None:
+            return tickets
+
         statuses = []
-        for line in myout.split("\n"):
+        for line in command_out.split("\n"):
             #if there are matching lines they will look like NUM:subj.. so pick num
             if (line.count('id: ticket/') > 0):
                 dummy, tnum = line.split('/') #get the ticket id
                 try:
                     inum = int(tnum)
                     tickets.append(tnum)
                 except:
                     pass
             if (line.count('Status: ') > 0):
                 dummy, tstatus = line.split('Status: ')
                 statuses.append(tstatus)
         if (type(status) == type([])):
             #take only those tickets whose status matches with one of the status list
             alltickets = tickets
             tickets = []
             for i in range(len(alltickets)):
                 tstatus = statuses[i]
                 tnum = alltickets[i]
                 if (status.count(tstatus) > 0): #match
                     tickets.append(tnum)
         return tickets
 
     def ticket_submit(self, uid=None, subject="", recordid=-1, text="", queue="",
         priority="", owner="", requestor=""):
         """creates a ticket. return ticket num on success, otherwise None"""
-        if not CFG_BIBCATALOG_SYSTEM_RT_URL:
-            return None
-        if uid:
-            username, passwd = get_bibcat_from_prefs(uid)
-        else:
-            username = CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_USER
-            passwd = CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_PWD
-        httppart, siteandpath = CFG_BIBCATALOG_SYSTEM_RT_URL.split("//")
-        BIBCATALOG_RT_SERVER = httppart + "//" + username + ":" + passwd + "@" + siteandpath
-        #set as env var
-        os.environ["RTUSER"] = username
-        os.environ["RTSERVER"] = BIBCATALOG_RT_SERVER
         queueset = ""
         textset = ""
         priorityset = ""
         ownerset = ""
         subjectset = ""
         requestorset = ""
         if subject:
             subjectset = " subject=" + escape_shell_arg(subject)
         recidset = " CF-RecordID=" + escape_shell_arg(str(recordid))
-        if text:
-            textset = " text=" + escape_shell_arg(text)
         if priority:
             priorityset = " priority=" + escape_shell_arg(str(priority))
         if queue:
             queueset = " queue=" + escape_shell_arg(queue)
         if requestor:
             requestorset = " requestor=" + escape_shell_arg(requestor)
         if owner:
             #get the owner name from prefs
             ownerprefs = invenio.webuser.get_user_preferences(owner)
             if ownerprefs.has_key("bibcatalog_username"):
                 owner = ownerprefs["bibcatalog_username"]
                 ownerset = " owner=" + escape_shell_arg(owner)
-        #make a command.. note that all set 'set' parts have been escaped
-
+        if text:
+            if '\n' in text:
+                # contains newlines (\n) return with error
+                return "Newlines are not allowed in text parameter. Use ticket_comment() instead."
+            else:
+                textset = " text=" + escape_shell_arg(text)
+        # make a command.. note that all set 'set' parts have been escaped
         command = CFG_BIBCATALOG_SYSTEM_RT_CLI + " create -t ticket set " + subjectset + recidset + \
                   queueset + textset + priorityset + ownerset + requestorset
-
-        passwd = escape_shell_arg(passwd)
-        #make a call.. passwd and command have been escaped (see above)
-        dummy, myout, dummyerr = run_shell_command("echo "+passwd+" | " + command)
+        command_out = self._run_rt_command(command, uid)
+        if command_out == None:
+            return None
         inum = -1
-        for line in myout.split("\n"):
+        for line in command_out.split("\n"):
             if line.count(' ') > 0:
                 stuff = line.split(' ')
                 try:
                     inum = int(stuff[2])
                 except:
                     pass
         if inum > 0:
             return inum
         return None
 
+    def ticket_comment(self, uid, ticketid, comment):
+        """comment on a given ticket. Returns 1 on success, 0 on failure"""
+        command = '%s comment -m %s %s' % (CFG_BIBCATALOG_SYSTEM_RT_CLI, \
+                                           escape_shell_arg(comment), str(ticketid))
+        command_out = self._run_rt_command(command, uid)
+        if command_out == None:
+            return None
+        return 1
+
     def ticket_assign(self, uid, ticketid, to_user):
         """assign a ticket to an RT user. Returns 1 on success, 0 on failure"""
         return self.ticket_set_attribute(uid, ticketid, 'owner', to_user)
 
     def ticket_set_attribute(self, uid, ticketid, attribute, new_value):
         """change the ticket's attribute. Returns 1 on success, 0 on failure"""
         #check that the attribute is accepted..
         if attribute not in BibCatalogSystem.TICKET_ATTRIBUTES:
             return 0
         #we cannot change read-only values.. including text that is an attachment. pity
         if attribute in ['creator', 'date', 'ticketid', 'url_close', 'url_display', 'recordid', 'text']:
             return 0
         #check attribute
         setme = ""
         if (attribute == 'priority'):
             try:
                 dummy = int(new_value)
             except:
                 return 0
             setme = "set Priority=" + str(new_value)
         if (attribute == 'subject'):
             subject = escape_shell_arg(new_value)
             setme = "set Subject='" + subject +"'"
 
         if (attribute == 'owner'):
             #convert from invenio to RT
             ownerprefs = invenio.webuser.get_user_preferences(new_value)
             if not ownerprefs.has_key("bibcatalog_username"):
                 return 0
             else:
                 owner = escape_shell_arg(ownerprefs["bibcatalog_username"])
             setme = " set owner='" + owner +"'"
 
         if (attribute == 'status'):
             setme = " set status='" + escape_shell_arg(new_value) +"'"
 
         if (attribute == 'queue'):
             setme = " set queue='" + escape_shell_arg(new_value) +"'"
 
-        if not CFG_BIBCATALOG_SYSTEM_RT_URL:
-            return 0
         #make sure ticketid is numeric
         try:
             dummy = int(ticketid)
         except:
             return 0
-        (username, passwd) = get_bibcat_from_prefs(uid)
-        httppart, siteandpath = CFG_BIBCATALOG_SYSTEM_RT_URL.split("//")
-        BIBCATALOG_RT_SERVER = httppart + "//" + username + ":" + passwd + "@" + siteandpath
-        #set as env var
-        os.environ["RTUSER"] = username
-        os.environ["RTSERVER"] = BIBCATALOG_RT_SERVER
-        passwd = escape_shell_arg(passwd)
-        #make a call. safe since passwd and all variables in 'setme' have been escaped
-        dummy, myout, dummyerr = run_shell_command("echo "+passwd+" | " + CFG_BIBCATALOG_SYSTEM_RT_CLI + " edit ticket/" + str(ticketid) + setme)
-        respOK = False
-        mylines = myout.split("\n")
+
+        command = CFG_BIBCATALOG_SYSTEM_RT_CLI + " edit ticket/" + str(ticketid) + setme
+        command_out = self._run_rt_command(command, uid)
+        if command_out == None:
+            return 0
+        mylines = command_out.split("\n")
         for line in mylines:
             if line.count('updated') > 0:
-                respOK = True
-        if respOK:
-            return 1
-            #print str(mylines)
+                return 1
         return 0
 
     def ticket_get_attribute(self, uid, ticketid, attribute):
         """return an attribute of a ticket"""
         ticinfo = self.ticket_get_info(uid, ticketid, [attribute])
         if ticinfo.has_key(attribute):
             return ticinfo[attribute]
         return None
 
     def ticket_get_info(self, uid, ticketid, attributes = None):
         """return ticket info as a dictionary of pre-defined attribute names.
            Or just those listed in attrlist.
            Returns None on failure"""
-        if not CFG_BIBCATALOG_SYSTEM_RT_URL:
-            return 0
         #make sure ticketid is numeric
         try:
             dummy = int(ticketid)
         except:
             return 0
         if attributes is None:
             attributes = []
-        (username, passwd) = get_bibcat_from_prefs(uid)
-        httppart, siteandpath = CFG_BIBCATALOG_SYSTEM_RT_URL.split("//")
-        BIBCATALOG_RT_SERVER = httppart + "//" + username + ":" + passwd + "@" + siteandpath
-        #set as env var
-        os.environ["RTUSER"] = username
-        os.environ["RTSERVER"] = BIBCATALOG_RT_SERVER
-        passwd = escape_shell_arg(passwd)
-        #make a call. This is safe.. passwd escaped, ticketid numeric
-        dummy, myout, dummyerr = run_shell_command("echo "+passwd+" | " + CFG_BIBCATALOG_SYSTEM_RT_CLI + " show ticket/" + str(ticketid))
+
+        command = CFG_BIBCATALOG_SYSTEM_RT_CLI + " show ticket/" + str(ticketid)
+        command_out = self._run_rt_command(command, uid)
+        print command_out
+        if command_out == None:
+            return 0
+
         tdict = {}
-        for line in myout.split("\n"):
+        for line in command_out.split("\n"):
             if line.count(": ") > 0:
                 tattr, tvaluen = line.split(": ")
                 tvalue = tvaluen.rstrip()
                 tdict[tattr] = tvalue
+
         #query again to get attachments -> Contents
-        dummy, myout, dummyerr = run_shell_command("echo "+passwd+" | " + CFG_BIBCATALOG_SYSTEM_RT_CLI + " show ticket/" + str(ticketid) + "/attachments/")
+        command = CFG_BIBCATALOG_SYSTEM_RT_CLI + " show ticket/" + str(ticketid) + "/attachments/"
+        command_out = self._run_rt_command(command, uid)
+        if command_out == None:
+            return 0
+
         attachments = []
-        for line in myout.split("\n"):
+        for line in command_out.split("\n"):
             if line.count(": ") > 1: #there is a line Attachments: 40: xxx
                 aline = line.split(": ")
                 attachments.append(aline[1])
+
         #query again for each attachment
         for att in attachments:
-            #passwd still escaped..
-            dummy, myout, dummyerr = run_shell_command("echo "+passwd+" | " + CFG_BIBCATALOG_SYSTEM_RT_CLI + " show ticket/" + str(ticketid) + "/attachments/" + att)
+            command = CFG_BIBCATALOG_SYSTEM_RT_CLI + " show ticket/" + str(ticketid) + "/attachments/" + att
+            command_out = self._run_rt_command(command, uid)
+            if command_out == None:
+                return 0
             #get the contents line
-            for line in myout.split("\n"):
+            for line in command_out.split("\n"):
                 if line.count("Content: ") > 0:
                     cstuff = line.split("Content: ")
                     tdict['Text'] = cstuff[1].rstrip()
+
         if (len(tdict) > 0):
             #iterate over TICKET_ATTRIBUTES to make a canonical ticket
             candict = {}
             for f in BibCatalogSystem.TICKET_ATTRIBUTES:
                 tcased = f.title()
                 if tdict.has_key(tcased):
                     candict[f] = tdict[tcased]
             if tdict.has_key('CF.{RecordID}'):
                 candict['recordid'] = tdict['CF.{RecordID}']
             if tdict.has_key('id'):
                 candict['ticketid'] = tdict['id']
             #make specific URL attributes:
             url_display = CFG_BIBCATALOG_SYSTEM_RT_URL + "/Ticket/Display.html?id="+str(ticketid)
             candict['url_display'] = url_display
             url_close = CFG_BIBCATALOG_SYSTEM_RT_URL + "/Ticket/Update.html?Action=Comment&DefaultStatus=resolved&id="+str(ticketid)
             candict['url_close'] = url_close
             url_modify = CFG_BIBCATALOG_SYSTEM_RT_URL + "/Ticket/ModifyAll.html?id="+str(ticketid)
             candict['url_modify'] = url_modify
             #change the ticket owner into invenio UID
             if tdict.has_key('owner'):
                 rt_owner = tdict["owner"]
                 uid = invenio.webuser.get_uid_based_on_pref("bibcatalog_username", rt_owner)
                 candict['owner'] = uid
             if len(attributes) == 0: #return all fields
                 return candict
             else: #return only the fields that were requested
                 tdict = {}
                 for myatt in attributes:
                     if candict.has_key(myatt):
                         tdict[myatt] = candict[myatt]
                 return tdict
         else:
             return None
 
+    def _run_rt_command(self, command, uid=None):
+        """
+        This function will run a RT CLI command as given user. If no user is specified
+        the default RT user will be used, if configured.
+
+        Should any of the configuration parameters be missing this function will return
+        None. Otherwise it will return the standard output from the CLI command.
+
+        @param command: RT CLI command to execute
+        @type command: string
+
+        @param uid: the Invenio user id to submit on behalf of. Optional.
+        @type uid: int
+
+        @return: standard output from the command given. None, if any errors.
+        @rtype: string
+        """
+        if not CFG_BIBCATALOG_SYSTEM_RT_URL:
+            return None
+        if uid:
+            username, passwd = get_bibcat_from_prefs(uid)
+        else:
+            username = CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_USER
+            passwd = CFG_BIBCATALOG_SYSTEM_RT_DEFAULT_PWD
+        httppart, siteandpath = CFG_BIBCATALOG_SYSTEM_RT_URL.split("//")
+        BIBCATALOG_RT_SERVER = httppart + "//" + username + ":" + passwd + "@" + siteandpath
+        #set as env var
+        os.environ["RTUSER"] = username
+        os.environ["RTSERVER"] = BIBCATALOG_RT_SERVER
+        passwd = escape_shell_arg(passwd)
+        dummy, myout, dummyerr = run_shell_command("echo "+passwd+" | " + command)
+        return myout
+