Help:Wikifunctions/User rights
![]() |
Note: When you edit this page, you agree to release your contribution under the CC0. See Public Domain Help Pages for more info. | ![]() |
![]() | Please do not mark this page for translation yet. It is still being drafted, or it contains incomplete translation markup which should be fixed before marking for translation. |
To balance the needs of the Wikifunctions community for ease of use and stability, there are a number of different actions that are only available to some users. These are set out below. For a summary, see also user groups on Wikifunctions.
User rights
[edit]Access is subject to rate limiting, like all Wikimedia sites.
The description here describes what we are aiming for. The table below lists the current state of affairs, as well as the planned changes.
- Everyone can …
- … run functions.
- Why: We want everyone to be able to use our library of functions.
- … make normal wiki edits to talk pages, project discussions, etc.
- Why: Like other Wikimedia wikis, we want editing to be as open as possible.
- … run functions.
- Everyone with an account can …
- … add, adjust, and remove labels and aliases for any object, even pre-defined system ones and their arguments.
- Why: We want everyone to be able to participate to build and improve our library of functions, in every language.
- … create new functions, testers, and implementations, and maintain them until they are connected.
- Why: We welcome proposed new functions and their uses from anyone.
- … add, adjust, and remove labels and aliases for any object, even pre-defined system ones and their arguments.
- Only community-approved users, 'functioneers', can …
- … connect and disconnect implementations and testers from a user-written function.
- Why: Connecting or disconnecting implementations and testers from functions can have widespread effects, and could break the wiki for lots of people.
- … create new types.
- Why: Types are very powerful, and should be created following a community discussion.
- … connect and disconnect implementations and testers from a user-written function.
- Only community-approved expert users, 'function maintainers', can …
- … connect and disconnect implementations and testers from a pre-defined system function.
- Why: Connecting or disconnecting implementations and testers from system functions could break the wiki for everyone.
- … adjust the definition of a running function.
- Why: Adjusting a function will immediately break it for anyone calling it.
- … adjust the definition of a type.
- Why: Adjusting a type once it has been created will almost certainly break any function that uses it.
- … add or adjust the definition of a special system type, such as a programming language or a natural language.
- Why: Special system types will occasionally need to be extended, but could break the wiki for everyone if a mistake is made.
- … adjust implementations and testers which are 'live' and connected to a function.
- Why: Adjusting a connected implementation or tester might break the associated function for anyone calling it.
- … connect and disconnect implementations and testers from a pre-defined system function.
- Only community-approved administrator users, 'sysops', can …
- … change the type of a object.
- Why: Adjusting the nature of an object once it has been created is a very unusual step and will break any reference to it across the wiki.
- … add new values for ultra-special system types like boolean and unit.
- Why: Special system types will occasionally need to be extended, but could break the wiki for everyone if a mistake is made.
- … add and remove users from the 'functioneers' group.
- Why: We want our community to self-manage as much as possible, rather than relying on the Wikimedia-wide stewards.
- … use all the normal kinds of sysop tool familiar from other wikis – blocking users, rolling back vandalism, managing abuse filters, etc.
- Why: Like other Wikimedia wikis, the sysops of Wikifunctions are the core of the community's curation and management processes.
- … change the type of a object.
- Only community-approved super-administrator users, 'bureaucrats', can …
- … add and remove users from the 'function maintainers' group.
- Why: We want our community to self-manage as much as possible, rather than relying on the Wikimedia-wide stewards.
- … use the normal bureaucrat user rights tool familiar from other wikis – promoting users to +sysop, adding +bot rights, etc.
- Why: Like other Wikimedia wikis, the sysops of Wikifunctions are the core of the community's curation and management process.
- … add and remove users from the 'function maintainers' group.
Detailed table
[edit]While reading the following table, you must consider the following:
- The row order is important: one change might match with two different rows, which describe rights that are given to different user groups. For example, the action "add a label in Spanish for the Boolean object 'true'" both fulfills the rule "any user can edit labels", as well as "only a sysop user can edit a boolean".
- Rules are configured as to not be cumulative; they are terminal. This means that the rules are checked in a particular order, and as soon as there is a match, the process exits with the required right. Going back to our example: the rule "any user can edit labels" comes first, so when this is matched the process terminates and concludes that the action "add a label in Spanish for the Boolean object 'true'" can be performed by any logged in user.
For a more detailed understanding of what specific rights are needed for each action, how the authorization process works for edits or how to develop or edit the granular authorization rules, go to Granular Edit Authorization. A dynamic list is available at f:Special:ListGroupRights.
Action | Logged-out users | Logged-in users | Functioneers | Function maintainers | SysOps | Staff |
---|---|---|---|---|---|---|
Execution | ||||||
Run published functions | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Run unsaved code - on implementation edit page | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Object creation | ||||||
Create a boolean | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create a unit | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create predefined objects[1] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create a language | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create a programming language | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create a type | ![]() |
![]() |
![]()
|
![]()
|
![]() |
![]() |
Create an enumeration value[2] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create an implementation | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create a test | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create a function | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create a converter[3] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Create any other object[4] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Object editing | ||||||
The following rules apply to all objects, predefined and user-contributed | ||||||
Edit any labels, aliases and descriptions | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit function input labels | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit type key labels | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit error key labels | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit the object type of any object | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit a boolean | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit a unit | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit a language | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit a programming language | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit a type | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit an enumeration value | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit any other predefined object[1] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
The following rules only apply to user-contributed objects | ||||||
Edit user-contributed Function objects | ||||||
Edit inputs/output of a running function[5][6] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit tests of a running function (connect/disconnect a test) | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit tests of a not-running function (connect/disconnect a test) | ![]() |
![]()
|
![]() |
![]() |
![]() |
![]() |
Edit implementations of a running function (connect/disconnect an implementation) | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit implementations of a not-running function (connect the first implementation) | ![]() |
![]()
|
![]() |
![]() |
![]() |
![]() |
Edit a function
(fallback rule, all other function edits) |
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit user-contributed Implementation objects | ||||||
Edit an implementation connected to a user-contributed function[7] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit an implementation connected to a predefined function[7] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit an implementation[8]
(fallback rule, all other implementations, which are not connected) |
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit user-contributed Test objects | ||||||
Edit a test connected to a user-contributed function[9] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit a test connected to a predefined function[9] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit a test[10]
(fallback rule, all other tests, which are not connected) |
![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit other user-contributed objects | ||||||
Edit a connected converter[11] | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit any other converter | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Edit any other object[4] (fallback rule, all other types) | ![]() |
![]() |
![]() |
![]() |
![]() |
![]() |
Notes:
[edit]- ↑ 1.0 1.1 Predefined objects: Objects in the Zid range from Z1 to Z9999. Also referred to as built-in objects.
- ↑ An enumeration value is an instance of a Type that is marked as an enumeration.
- ↑ A converter is an object of type Z64/Deserialiser or Z46/Serialiser
- ↑ 4.0 4.1 Objects of any type excluding the types with special restrictions (function, test, implementation, unit, boolean, language, programming language or type)
- ↑ Running function: Any function that has, at least, one connected implementation.
- ↑ This operation will also automatically disconnect from this function all its connected testers and implementations.
- ↑ 7.0 7.1 Connected implementation: An implementation that is active or connected to a function.
- ↑ Any other implementation that does not fall on the specific groups detailed above: Must be a not-connected and user-contributed implementation.
- ↑ 9.0 9.1 Connected test: A test that is active or connected to a function.
- ↑ Any other test that does not fall on the specific groups detailed above: Must be a not-connected and user-contributed test.
- ↑ A connected converter is an object of type Deserialiser/Z64 or Serialiser/Z46 that is already attached to a Type.