TWiki Access Control

TWiki

TWiki Access Control

Restricting read and write access to topics and webs, by Users and groups

TWiki Access Control allows you restrict access to single topics and entire webs, by individual user and by user Groups. Access control, combined with TWikiUserAuthentication, lets you easily create and manage an extremely flexible, fine-grained privilege system.

TIP Tip: TWiki:TWiki.TWikiAccessControlSupplement on TWiki.org has additional documentation on access control.

An Important Control Consideration

Open, freeform editing is the essence of WikiCulture - what makes TWiki different and often more effective than other collaboration tools. For that reason, it is strongly recommended that decisions to restrict read or write access to a web or a topic are made with great care - the more restrictions, the less Wiki in the mix. Experience shows that unrestricted write access works very well because:

  • Peer influence is enough to ensure that only relevant content is posted.
  • Peer editing - the ability for anyone to rearrange all content on a page - keeps topics focused.
  • In TWiki, content is transparently preserved under revision control:
    • Edits can be undone by the administrator (per default a member of TWikiAdminGroup; see #ManagingGroups).
    • Users are encouraged to edit and refactor (condense a long topic), since there's a safety net.
As a collaboration guideline:
  • Create broad-based Groups (for more and varied input), and...
  • Avoid creating view-only Users (if you can read it, you should be able to contribute to it).

Permissions settings of the webs on this TWiki site

Web Sitemap VIEW CHANGE RENAME
Listed DENY ALLOW DENY ALLOW DENY ALLOW
Preferences Home Main on            
Preferences Home TWiki on       TWikiAdminGroup    
Preferences Home Afp on       StGroup, AfpParticipants2010Group, StudentGroup   StGroup
Preferences Home Afp0304 on       StGroup, StudentGroup   StGroup
Preferences Home Afp0405 on       StGroup, StudentGroup   StGroup
Preferences Home Afp0506 on       StGroup, StudentGroup   StGroup
Preferences Home Afp0607 on       StGroup, StudentGroup   StGroup
Preferences Home AfpBadCopy on       StGroup, StudentGroup   StGroup
Preferences Home AfscheidDoaitseSwierstra on DoaitseSwierstra   DoaitseSwierstra AtzeDijkstra, JurriaanHage DoaitseSwierstra AtzeDijkstra, JurriaanHage
Preferences Home Alexey         StGroup   StGroup
Preferences Home Aop on       StGroup   StGroup
Preferences Home Apa on       StGroup   StGroup
Preferences Home Apa0506 on       StGroup   StGroup
Preferences Home ArieMiddelkoop on       StGroup ArieMiddelkoop   StGroup
Preferences Home Atze on       UhcGroup, StGroup   UhcGroup, StGroup
Preferences Home B3so on       StGroup   StGroup
Preferences Home Bachelor on       StGroup   StGroup
Preferences Home Bookmarks on       StGroup   StGroup
Preferences Home Buildfarm on       BuildfarmGroup   BuildfarmGroup
Preferences Home CSMaster on       StGroup JanVanLeeuwen AdFeelders   StGroup
Preferences Home Cco on       StGroup, StudentGroup   StGroup
Preferences Home Center on       StGroup   StGroup
Preferences Home DTP on       StGroup, StudentGroup    
Preferences Home Dos on       StGroup   StGroup
Preferences Home Ehc on       StGroup, EhcGroup   StGroup, EhcGroup
Preferences Home Eifl on       EiflGroup, StGroup   EiflGroup, StGroup
Preferences Home Esdx on       StudentGroup, StGroup   StudentGroup, StGroup
Preferences Home ExamCommitteeSciences on       StGroup, ExamenCommissieGroup, ExamCommitteeSciencesGroup   StGroup
Preferences Home ExamenCommissie on       StGroup, ExamenCommissieGroup   StGroup
Preferences Home FOO on       WishnuPrasetya? ZharinaShukur?   WishnuPrasetya?
Preferences Home FP on       StGroup, FpStudentassistentenGroup   StGroup
Preferences Home FPDag2012 on            
Preferences Home FPLC on       StGroup   StGroup
Preferences Home Fosa         StGroup   StGroup
Preferences Home GP on       StGroup JohanJeuring   StGroup JohanJeuring
Preferences Home? GamesAndVirtualWorlds?              
Preferences Home Gavw on            
Preferences Home GenericProgramming on       StGroup, ErikHesselink    
Preferences Home Gnp on       StGroup   StGroup
Preferences Home Gw on       StGroup StudentGroup SweYear2005Group   StGroup StudentGroup SweYear2005Group
Preferences Home HUT on       HutGroup   HutGroup
Preferences Home Hage on       StGroup   StGroup
Preferences Home HaskellResources on            
Preferences Home Helium         StGroup   StGroup
Preferences Home HerzieningBachelorInformatica on            
Preferences Home Hpc on       StGroup   StGroup
Preferences Home Hpc02         StGroup   StGroup
Preferences Home IFIP21 on       TwoDotOneGroup   StGroup
Preferences Home IFL on            
Preferences Home IFL2010 on            
Preferences Home IPA2013 on       StGroup?   StGroup?
Preferences Home IS on     TWikiGuest   TWikiGuest  
Preferences Home ISS on       StGroup   StGroup
Preferences Home Ipt on       IptGroup, StGroup   IptGroup, StGroup
Preferences Home Ist on       StGroup StudentGroup   StGroup
Preferences Home MSO on       MsoStaffGroup   MsoStaffGroup
Preferences Home MTCH on       StGroup   StGroup
Preferences Home Martin on       StGroup   StGroup
Preferences Home Master on       StGroup HansBodlaender AdFeelders   StGroup
Preferences Home Master.Intern on       StGroup HansBodlaender AdFeelders   StGroup
Preferences Home MasterProgramComputingScience on            
Preferences Home Merijn on       StGroup, MerijnDeJonge   StGroup
Preferences Home MethodEngineering              
Preferences Home Mso1011 on            
Preferences Home No on       StGroup   StGroup
Preferences Home OWMT on            
Preferences Home OacBaICA on       OacBaIcaGroup?    
Preferences Home OacBaIKU on            
Preferences Home OacMastersCs on       StGroup, OacMastersCommissieGroup   StGroup
Preferences Home Odc on       OdcGroup   OdcGroup
Preferences Home ProgrammingEnvironments on       StGroup EdwinVanRijkom IvayloGochkov LennartKats PatrickCamphuijsen RaymonVanWanrooij ReinierVis   StGroup
Preferences Home PrologJCU on       JurrienStutterheim, DoaitseSwierstra, WouterSwierstra    
Preferences Home Proxima on       StGroup ProximaGroup   StGroup
Preferences Home Proxima.klad         StGroup ProximaGroup   StGroup
Preferences Home Pt on       StGroup ProgramTransformationGroup   StGroup ProgramTransformationGroup
Preferences Home Pt03 on       StGroup ProgramTransformationGroup   StGroup ProgramTransformationGroup
Preferences Home Pt04 on       StGroup ProgramTransformationGroup   StGroup ProgramTransformationGroup
Preferences Home Pv on       StGroup   StGroup
Preferences Home Sandbox on            
Preferences Home SemanticWeb on       StGroup, SemanticWebGroup   StGroup
Preferences Home Sgc on       StGroup StudentGroup ProgramTransformationGroup   StGroup StudentGroup ProgramTransformationGroup
Preferences Home Sgc04 on       StGroup StudentGroup ProgramTransformationGroup   StGroup StudentGroup ProgramTransformationGroup
Preferences Home Spm              
Preferences Home Stc on       StGroup StudentGroup HansBodlaender   StGroup
Preferences Home StrictnessAnalysisJFC on            
Preferences Home Students on       StGroup StudentGroup   StGroup
Preferences Home Swa on       SwaGroup, SwaParticipantsGroup   SwaGroup
Preferences Home Swe on       StGroup, StudentGroup, SweGroup   StGroup, StudentGroup, SweGroup
Preferences Home Swe03 on       StGroup, StudentGroup   StGroup, StudentGroup
Preferences Home Swe04 on       StGroup, StudentGroup   StGroup, StudentGroup
Preferences Home Swe05 on       StGroup, StudentGroup, SweGroup   StGroup, StudentGroup, SweGroup
Preferences Home Swe0607 on       StGroup, StudentGroup, SweGroup   StGroup, StudentGroup, SweGroup
Preferences Home Sws on       StGroup SwsParticipants2009Group   StGroup
Preferences Home TC on       StGroup, StudentGroup   StGroup
Preferences Home TFP2014 on       StGroup   StGroup
Preferences Home TS         StGroup, StudentGroup   StGroup
Preferences Home TS0506         StGroup, StudentGroup   StGroup
Preferences Home Tbpa on       StGroup, StudentGroup   StGroup
Preferences Home Techno on       StGroup StudentGroup   StGroup StudentGroup
Preferences Home TechnologyForTeaching on            
Preferences Home? Toetsing? on            
Preferences Home TomVanDerWeide         StGroup TomVanDerWeide   StGroup TomVanDerWeide
Preferences Home Top on       StGroup   StGroup
Preferences Home Trace on       TraceGroup   TraceGroup
Preferences Home Trash on            
Preferences Home Ts on       StGroup TypeSystemsGroup   StGroup TypeSystemsGroup
Preferences Home UHC on       EhcGroup   EhcGroup
Preferences Home USCS on            
Preferences Home USCS2009 on       StGroup   StGroup
Preferences Home USCS2010 on            
Preferences Home USCS2011 on            
Preferences Home Uhc on       UhcGroup, StGroup   UhcGroup, StGroup
Preferences Home Vermaas on       StGroup   StGroup
Preferences Home Visser on       StGroup   StGroup
Preferences Home? VrouwenEnICT? on            
Preferences Home WP on       WishnuPrasetya    
Preferences Home WebFunctions on       WebFunctionsGroup, StGroup   StGroup
Preferences Home WiskundeBDeficientie on            
Preferences Home WorkingConferenceProgramTransformation         StGroup   StGroup
Preferences Home Xagp on       UhcGroup, StGroup   UhcGroup, StGroup
Preferences Home ZZZ on            

See TWikiAccessControl for details

Please Note:

  • A blank in the the above table may mean either the corresponding control is absent or commented out or that it has been set to a null value. The two conditions have dramatically different and possibly opposed semantics.
  • TWikiGuest is the guest account - used by unauthenticated users.
  • The TWiki web must not deny view to TWikiGuest; otherwise, people will not be able to register.

Note: Above table comes from SitePermissions

Authentication vs. Access Control

Authentication: Identifies who a user is based on a login procedure. See TWikiUserAuthentication.

Access control: Restrict access to content based on users and groups once a user is identified.

Users and Groups

Access control is based on the familiar concept of Users and Groups. Users are defined by their WikiNames. They can then be organized in unlimited combinations by inclusion in one or more user Groups. For convenience, Groups can also be included in other Groups.

Managing Users

A user can create an account in TWikiRegistration. The following actions are performed:

  • WikiName and encrypted password are recorded using the password manager if authentication is enabled.
  • A confirmation e-mail is sent to the user.
  • A user home page with the WikiName of the user is created in the Main web.
  • The user is added to the TWikiUsers topic.

The default visitor name is TWikiGuest. This is the non-authenticated user.

Managing Groups

The following describes the standard TWiki support for groups. Your local TWiki may have an alternate group mapping manager installed. Check with your TWiki administrator if you are in doubt.

Groups are defined by group topics located in the Main web. To create a new group, visit TWikiGroups and enter the name of the new group ending in Group into the "new group" form field. This will create a new group topic with two important settings:

  • Set GROUP = < list of Users and/or Groups >
  • Set ALLOWTOPICCHANGE = < list of Users and/or Groups >

The GROUP setting is a comma-separated list of users and/or other groups. Example:

  • Set GROUP = Main.SomeUser, Main.OtherUser, Main.SomeGroup

The ALLOWTOPICCHANGE setting defines who is allowed to change the group topic; it is a comma delimited list of users and groups. You typically want to restrict that to the members of the group itself, so it should contain the name of the topic. This prevents users not in the group from editing the topic to give themselves or others access. For example, for the KasabianGroup topic write:

  • Set ALLOWTOPICCHANGE = Main.KasabianGroup

ALERT! Note: TWiki has strict formatting rules. Make sure you have three spaces, an asterisk, and an extra space in front of any access control rule.

The Super Admin Group

A number of TWiki functions (for example, renaming webs) are only available to administrators. Administrators are simply users who belong to the SuperAdminGroup. This is a standard user group, the name of which is defined by {SuperAdminGroup} setting in configure. The default name of this group is the TWikiAdminGroup. The system administrator may have chosen a different name for this group if your local TWiki uses an alternate group mapping manager but for simplicity we will use the default name TWikiAdminGroup in the rest of this topic.

You can create new administrators simply by adding them to the TWikiAdminGroup topic. For example,

  • Set GROUP= Main.ElizabethWindsor, Main.TonyBlair
A member of the Super Admin Group has unrestricted access throughout the TWiki, so only trusted staff should be added to this group.

Restricting Access

You can define who is allowed to read or write to a web or a topic. Note that some plugins may not respect access permissions.

  • Restricting VIEW blocks viewing and searching of content.
  • Restricting CHANGE blocks creating new topics, changing topics or attaching files.
  • Restricting RENAME prevents renaming of topics within a web.

Note that there is an important distinction between CHANGE access and RENAME access. A user can CHANGE a topic, but thanks to version control their changes cannot be lost (the history of the topic before the change is recorded). However if a topic or web is renamed, that history may be lost. Typically a site will only give RENAME access to administrators and content owners.

Controlling access to a Web

You can define restrictions on who is allowed to view a TWiki web. You can restrict access to certain webs to selected Users and Groups, by:

  • authenticating all webs and restricting selected webs: Topic access in all webs is authenticated, and selected webs have restricted access.
  • authenticating and restricting selected webs only: Provide unrestricted viewing access to open webs, with authentication and restriction only on selected webs.

  • You can define these settings in the WebPreferences topic, preferable towards the end of the topic:
    • Set DENYWEBVIEW = < comma-delimited list of Users and Groups >
    • Set ALLOWWEBVIEW = < comma-delimited list of Users and Groups >
    • Set DENYWEBCHANGE = < comma-delimited list of Users and Groups >
    • Set ALLOWWEBCHANGE = < comma-delimited list of Users and Groups >
    • Set DENYWEBRENAME = < comma-delimited list of Users and Groups >
    • Set ALLOWWEBRENAME = < comma-delimited list of Users and Groups >

If your site allows hierarchical webs, then access to sub-webs is determined from the access controls of the parent web, plus the access controls in the sub-web. So, if the parent web has ALLOWWEBVIEW set, this will also apply to the subweb.

Creation and renaming of sub-webs is controlled by the WEBCHANGE setting on the parent web (or ROOTCHANGE for root webs). Renaming is additionally restricted by the setting of WEBRENAME in the web itself.

Note: For Web level access rights Setting any of these settings to an empty value has the same effect as not setting them at all. Please note that the documentation of TWiki 4.0 and earlier versions of TWiki 4.1 did not reflect the actual implementation, e.g. an empty ALLOWWEBVIEW does not prevent anyone from viewing the web, and an an empty DENYWEBVIEW does not allow all to view the web.

Controlling access to a Topic

  • You can define these settings in any topic, preferable towards the end of the topic:
    • Set DENYTOPICVIEW = < comma-delimited list of Users and Groups >
    • Set ALLOWTOPICVIEW = < comma-delimited list of Users and Groups >
    • Set DENYTOPICCHANGE = < comma-delimited list of Users and Groups >
    • Set ALLOWTOPICCHANGE = < comma-delimited list of Users and Groups >
    • Set DENYTOPICRENAME = < comma-delimited list of Users and Groups >
    • Set ALLOWTOPICRENAME = < comma-delimited list of Users and Groups >

Remember when opening up access to specific topics within a restricted web that other topics in the web - for example, the WebLeftBar - may also be accessed when viewing the topics. The message you get when you are denied access should tell you what topic you were not permitted to access.

Be careful with empty values for any of these.

  • Set ALLOWTOPICVIEW =
    This means the same as not setting it at all. (This was documented wrong in versions 4.0.X, 4.1.0 and 4.1.1)

  • Set DENYTOPICVIEW =
    Since TWiki 4.0 this means do not deny anyone the right to view this topic. If DENYTOPICVIEW is set to an empty value anyone has access even if ALLOWTOPICVIEW or ALLOWWEBVIEW is defined. This allows to have very restrictive default access rights to an entire web and still allow individual topics to have more open access.

The same rules apply to ALLOWTOPICCHANGE/DENYTOPICCHANGE and APPLYTOPICRENAME/DENYTOPICRENAME. Setting ALLOWTOPICCHANGE or ALLOWTOPICRENAME to en empty value means the same as not defining it. Setting DENYTOPICCHANGE or DENYTOPICRENAME to an empty value means that anyone can edit or rename the topic.

ALERT! The setting to an empty has caused confusion and great debate and it has been decided that the empty setting syntax will be replaced by something which is easier to understand in the 4.2 version of TWiki. A method to upgrade will be provided. Please read the release notes carefully when you upgrade.

See "How TWiki evaluates ALLOW/DENY settings" below for more on how ALLOW and DENY interacts.

Controlling access to Attachments

Attachments are referred to directly, and are not normally indirected via TWiki scripts. This means that the above instructions for access control will not apply to attachments. It is possible that someone may inadvertently publicise a URL that they expected to be access-controlled.

The easiest way to apply the same access control rules for attachments as apply to topics is to use the Apache mod_rewrite module, and configure your webserver to redirect accesses to attachments to the TWiki viewfile script. For example,

    ScriptAlias /twiki/bin/ /filesystem/path/to/twiki/bin/
    Alias /twiki/pub/       /filesystem/path/to/twiki/pub/

    RewriteEngine on
    RewriteCond %{REQUEST_URI} !^/+twiki/+pub/+TWiki/+.+
    RewriteRule ^/+twiki/+pub/+([^/]+)/+((([^/]+)/+)+)(.+) /twiki/bin/viewfile/$1/$4?filename=$5 [L,PT]

That way all the controls that apply to the topic also apply to attachments to the topic. Other types of webserver have similar support.

Note: Images embedded in topics will load much slower since each image will be delivered by the viewfile script.

Controlling who can manage top-level webs

Top level webs are a special case, because they don't have a parent web with a WebPreferences. So there has to be a special control just for the root level.

  • You can define these settings in the Main.%TWIKIPREFSTOPIC% topic, preferable towards the end of the topic:
    • Set DENYROOTCHANGE = < comma-delimited list of Users and Groups >
    • Set ALLOWROOTCHANGE = < comma-delimited list of Users and Groups >
Note that you do not require ROOTCHANGE access to rename an existing top-level web. You just need WEBCHANGE in the web itself.

How TWiki evaluates ALLOW/DENY settings

When deciding whether to grant access, TWiki evaluates the following rules in order (read from the top of the list; if the logic arrives at PERMITTED or DENIED that applies immediately and no more rules are applied). You need to read the rules bearing in mind that VIEW, CHANGE and RENAME access may be granted/denied separately.

  1. If the user is an administrator
    • access is PERMITTED.
  2. If DENYTOPIC is set to a list of wikinames
    • people in the list will be DENIED.
  3. If DENYTOPIC is set to empty ( i.e. Set DENYTOPIC = )
    • access is PERMITTED i.e no-one is denied access to this topic.
      ALERT! Attention: Use this with caution. This is deprecated and will likely change in the next release.
  4. If ALLOWTOPIC is set
    1. people in the list are PERMITTED
    2. everyone else is DENIED
  5. If DENYWEB is set to a list of wikinames
    • people in the list are DENIED access
  6. If ALLOWWEB is set to a list of wikinames
    • people in the list will be PERMITTED
    • everyone else will be DENIED
  7. If you got this far, access is PERMITTED

Access Control quick recipes

Obfuscating Webs

Another way of hiding webs is to keep them hidden by not publishing the URL and by preventing the all webs search option from accessing obfuscated webs. Do so by enabling the NOSEARCHALL variable in WebPreferences:

  • Set NOSEARCHALL = on

This setup can be useful to hide a new web until content its ready for deployment, or to hide view access restricted webs.

ALERT! Note: Obfuscating a web without view access control is very insecure, as anyone who knows the URL can access the web.

Authenticate all Webs and Restrict Selected Webs

Use the following setup to authenticate users for topic viewing in all webs and to restrict access to selected webs. Requires TWikiUserAuthentication to be enabled.

  1. Restrict view access to selected Users and Groups. Set one or both of these variables in its WebPreferences topic:
    • Set DENYWEBVIEW = < list of Users and Groups >
    • Set ALLOWWEBVIEW = < list of Users and Groups >
    • Note: DENYWEBVIEW is evaluated before ALLOWWEBVIEW. Access is denied if the authenticated person is in the DENYWEBVIEW list, or not in the ALLOWWEBVIEW list. Access is granted in case DENYWEBVIEW and ALLOWWEBVIEW is not defined.

Authenticate and Restrict Selected Webs Only

Use the following setup to provide unrestricted viewing access to open webs, with authentication only on selected webs. Requires TWikiUserAuthentication to be enabled.

  1. Restrict view access to selected Users and Groups. Set one or both of these variables in its WebPreferences topic:
    • Set DENYWEBVIEW = < list of Users and Groups >
    • Set ALLOWWEBVIEW = < list of Users and Groups >
    • Note: DENYWEBVIEW is evaluated before ALLOWWEBVIEW. Access is denied if the authenticated person is in the DENYWEBVIEW list, or not in the ALLOWWEBVIEW list. Access is granted in case DENYWEBVIEW and ALLOWWEBVIEW is not defined.

Hide Control Settings

TIP Tip: To hide access control settings from normal browser viewing, you can put them into the topic-local settings. You can access those settings via the "More" screen, as explained in TWikiVariables.

Alternatively, place them in HTML comment markers, but this exposes the access setting during ordinary editing.

<!--
   * Set DENYTOPICCHANGE = Main.SomeGroup
-->

Related Topics: AdminDocumentationCategory, TWikiUserAuthentication, TWiki:TWiki.TWikiAccessControlSupplement

-- Contributors: TWiki:Main.PeterThoeny, TWiki:Main.MikeMannix, TWiki:Main.CrawfordCurrie