2016-04-09 16:27:06 +03:00
|
|
|
---
|
|
|
|
title: Privileges
|
|
|
|
layout: default
|
2018-07-15 21:36:35 +03:00
|
|
|
root: ../..
|
2018-07-15 17:28:10 +03:00
|
|
|
idx: 4.1
|
|
|
|
description: Registering privs.
|
2018-07-15 21:13:16 +03:00
|
|
|
redirect_from: /en/chapters/privileges.html
|
2016-04-09 16:27:06 +03:00
|
|
|
---
|
|
|
|
|
|
|
|
## Introduction
|
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
Privileges, often called privs for short, give players the ability to perform
|
|
|
|
certain actions. Server owners can grant and revoke privileges to control
|
|
|
|
which abilities each player has.
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
* [When to use Privileges](#when-to-use-privileges)
|
|
|
|
* [Declaring Privileges](#declaring-privileges)
|
|
|
|
* [Checking for Privileges](#checking-for-privileges)
|
|
|
|
* [Getting and Setting Privileges](#getting-and-setting-privileges)
|
|
|
|
* [Adding Privileges to basic_privs](#adding-privileges-to-basic-privs)
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
## When to use Privileges
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
A privilege should give a player **the ability to do something**.
|
|
|
|
Privileges are **not for indicating class or status**.
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
The main admin of a server (the name set by the `name` setting in the
|
|
|
|
minetest.conf file) is automatically given all available privileges.
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
**Good Privileges:**
|
2016-04-09 16:27:06 +03:00
|
|
|
|
|
|
|
* interact
|
|
|
|
* shout
|
|
|
|
* noclip
|
|
|
|
* fly
|
|
|
|
* kick
|
|
|
|
* ban
|
|
|
|
* vote
|
|
|
|
* worldedit
|
|
|
|
* area_admin - admin functions of one mod is ok
|
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
**Bad Privileges:**
|
2016-04-09 16:27:06 +03:00
|
|
|
|
|
|
|
* moderator
|
|
|
|
* admin
|
|
|
|
* elf
|
|
|
|
* dwarf
|
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
## Declaring Privileges
|
|
|
|
|
|
|
|
Use `register_privilege` to declare a new privilege:
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2016-04-09 16:27:06 +03:00
|
|
|
minetest.register_privilege("vote", {
|
2017-08-26 21:01:51 +03:00
|
|
|
description = "Can vote on issues",
|
|
|
|
give_to_singleplayer = true
|
2016-04-09 16:27:06 +03:00
|
|
|
})
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
If `give_to_singleplayer` is true, you can remove it, because true is the default
|
|
|
|
when it is not specified. This simplifies the privilege registration to:
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2016-04-09 16:27:06 +03:00
|
|
|
minetest.register_privilege("vote", {
|
2017-08-26 21:01:51 +03:00
|
|
|
description = "Can vote on issues"
|
2016-04-09 16:27:06 +03:00
|
|
|
})
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
## Checking for Privileges
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
To quickly check whether a player has all the required privileges:
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2016-04-09 16:27:06 +03:00
|
|
|
local has, missing = minetest.check_player_privs(player_or_name, {
|
2017-08-26 21:01:51 +03:00
|
|
|
interact = true,
|
|
|
|
vote = true })
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
In this example, `has` is true if the player has all the privileges needed.\\
|
2016-04-09 16:27:06 +03:00
|
|
|
If `has` is false, then `missing` will contain a dictionary
|
2017-08-30 00:36:56 +03:00
|
|
|
of missing privileges.
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2016-04-09 16:27:06 +03:00
|
|
|
if minetest.check_player_privs(name, {interact=true, vote=true}) then
|
2017-08-26 21:01:51 +03:00
|
|
|
print("Player has all privs!")
|
2016-04-09 16:27:06 +03:00
|
|
|
else
|
2017-08-26 21:01:51 +03:00
|
|
|
print("Player is missing some privs!")
|
2016-04-09 16:27:06 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
local has, missing = minetest.check_player_privs(name, {
|
2017-08-26 21:01:51 +03:00
|
|
|
interact = true,
|
|
|
|
vote = true })
|
2016-04-09 16:27:06 +03:00
|
|
|
if has then
|
2017-08-26 21:01:51 +03:00
|
|
|
print("Player has all privs!")
|
2016-04-09 16:27:06 +03:00
|
|
|
else
|
2017-08-26 21:01:51 +03:00
|
|
|
print("Player is missing privs: " .. dump(missing))
|
2016-04-09 16:27:06 +03:00
|
|
|
end
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
## Getting and Setting Privileges
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
To get a table containing a player's privileges, regardless of whether
|
|
|
|
the player is logged in, use `minetest.get_player_privs`:
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2016-04-09 16:27:06 +03:00
|
|
|
local privs = minetest.get_player_privs(name)
|
|
|
|
print(dump(privs))
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
This example may give:
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2016-04-09 16:27:06 +03:00
|
|
|
{
|
2017-08-26 21:01:51 +03:00
|
|
|
fly = true,
|
|
|
|
interact = true,
|
|
|
|
shout = true
|
2016-04-09 16:27:06 +03:00
|
|
|
}
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
To set a player's privileges, use `minetest.set_player_privs`:
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2016-04-09 16:27:06 +03:00
|
|
|
minetest.set_player_privs(name, {
|
2017-08-26 21:01:51 +03:00
|
|
|
interact = true,
|
|
|
|
shout = true })
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
To grant a player privileges, use a combination of the above two functions:
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2016-04-09 16:27:06 +03:00
|
|
|
local privs = minetest.get_player_privs(name)
|
|
|
|
privs.vote = true
|
|
|
|
minetest.set_player_privs(name, privs)
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
## Adding Privileges to basic_privs
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
Players with the `basic_privs` privilege are able to grant and revoke a limited
|
2018-07-16 01:04:55 +03:00
|
|
|
set of privileges. It's common to give this privilege to moderators, so that
|
|
|
|
they can grant and revoke `interact` and `shout`, but can't grant themselves or other
|
2017-08-30 00:36:56 +03:00
|
|
|
players privileges such as `give` and `server`, which have greater potential for abuse.
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
To add a privilege to `basic_privs` and adjust which privileges your moderators can
|
|
|
|
grant and revoke from other players, you must change the `basic_privs` setting.
|
2018-07-15 17:28:10 +03:00
|
|
|
To do this, you must edit the minetest.conf file.
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2018-07-16 01:04:55 +03:00
|
|
|
By default, `basic_privs` has the following value:
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-29 03:29:04 +03:00
|
|
|
basic_privs = interact, shout
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-30 00:36:56 +03:00
|
|
|
To add `vote`, update this to:
|
2016-04-09 16:27:06 +03:00
|
|
|
|
2017-08-29 03:29:04 +03:00
|
|
|
basic_privs = interact, shout, vote
|
2017-08-30 00:36:56 +03:00
|
|
|
|
|
|
|
This will allow players with `basic_privs` to grant and revoke the `vote` privilege.
|