Skip to main content
Join the official 2019 Python Developers SurveyStart the survey!

Plone PAS plugin for adding roles (or groups) to anonymous or logged-in visitors looking for HTTP Headers.

Project description

Add roles or groups to anonymous or logged-in visitors based on HTTP headers


The AutoRoleFromHostHeader PAS plugin allows to assign roles to users looking at HTTP headers.

There is an extraction and authentication plugin included, to enable additional roles for anonymous users. They are required since PAS does not support roles (or properties or groups) for anonymous users. You can disable these interfaces if only logged-in users should get additional roles.

AutoRoleFromHostHeader furthermore provides a groups plugin interface, allowing you to assign groups instead of roles.


The plugin is configured by editing the Header name; regexp; roles/groups property on the plugin’s properties screen (through ZMI). Each line represents a mapping from an header value (using a regexp match) to one or more roles. The format is as follows:

http_header_name; regular expression; role[, role ...] ; TALES

The (optional) TALES allows arbitrary expressions to be added to role mappings, for example to check other HTTP headers:


Assign groups, not roles

This plugin can be used to assign groups instead of roles if used as a group plugin instead of a role plugin:

http_header_name; regular expression; group[, group ...] ; TALES

Groups plugin is not activated by default.


If you have AutoRoleFromHostHeader configured for anonymous users and come from a network matching one of its rules, you will not be able to log in with an account from a higher-up user folder. This is because AutoRole authenticates the Anonymous User which stops the lookup process.


Tested with all Plone versions from 4.0 to 4.3.


Developed with the support of:

All of them supports the PloneGov initiative.


  • This product was developed by RedTurtle Technology team.

    RedTurtle Technology Site
  • AutoRoleFromHostHeader is not an original idea but is taken from the work made by Jarn company for the AutoRole plugin.

  • Special thanks to Mauro Amico (mamico) for giving us the main direction.

  • Matthew Wilkes (MatthewWilkes) contributed adding the conditional expression.


1.0.0 (2015-06-05)

Dropped Plone 3 compatibility

  • Add TALES field to assignments, allowing users to provide arbitrary conditions [matthewwilkes]

0.4.1 (2014-07-10)

  • Restored MANIFEST file that was destroyed [keul]
  • Run import step profile only when needed [keul]

0.4.0 (Unreleased)

  • Do not fail if the configured header was not found [keul]
  • Dropped support for ancient Plone versions (Python 2.3) [keul]
  • Pyflakes cleanup [keul]
  • Now works also on Plone 4.3 [keul]

0.3.0 (2011-10-17)

  • Fixed compatibliy with webserverauth [yurj]
  • Updates tests on Plone 4.1 [keul]

0.2.0 (2010-10-04)

  • Fixed project URL on [keul]
  • Added plugin icon [keul]
  • Fixed broken tests [keul]
  • Added z3c.autoinclude support [keul]

0.1.0a (2010-03-24)

  • Initial release

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for Products.AutoRoleFromHostHeader, version 1.0.0
Filename, size File type Python version Upload date Hashes
Filename, size Products.AutoRoleFromHostHeader-1.0.0.tar.gz (16.1 kB) File type Source Python version None Upload date Hashes View hashes

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN SignalFx SignalFx Supporter DigiCert DigiCert EV certificate StatusPage StatusPage Status page