PEXAdmin allow you to edit your PermissionsEX data from a fancy web-interface.
- Don't get bored anymore with pex permissions editing commands!
- Global overview of all permissions + preview chat prefix / suffix set
- Edit player and groups options (default, build, ...)
- Easily list all registered groups / players set in PEX
- Add / Copy / Remove groups
- Add / Copy / Remove players
- Protected access (letting you can configure write/readonly access)
https://oxygen-framework.net/demos/pexadmin
Login: demo
Password: demo
NOTE: You only have a readonly access in live demo.
-
PHP >= 5.3
-
PDO Drivers (MySQL)
-
Apache mod_rewrite
-
Oxygen Framework version >= 0.1.7 (Included) (latest version available at https://git.dbn.re/David/oxygen-framework)
-
PEX backend must be set to sql
PEXAdmin comes in 2 flavors:
- If you have access to apache server's configuration, you must setup your virtualhost to let the
/
location being mapped into thepublic
folder (e.g. if all settings are ok, you won't be able to accessApplication
folder or any of it's contents from your browser). Here is a Virtualhost directive to use for example:
<VirtualHost *:80>
DocumentRoot /path/where/you/put/pexadmin/public
ServerName pexadmin.example.com
</VirtualHost>
- If you cannot modify the server configuration and only access to the folder served as root or want to install PEXadmin in a subfolder, you can download the 'subfolder' version of PEXAdmin or create it by running the scripts under the
subfolder-flavor
folder.
As the PEXAdmin config files are all in JSON format, watch out the syntax errors!
You can use tools like JSONLint to check the syntax before editing the actual file.
You have to set your database access to let PEXAdmin handle the permissions.
Open the file Application/Config/db.json
, change the host/dbname and credentials according to your database' ones.
{
"default": {
"dsn": "mysql:host=localhost;dbname=minecraft;charset=utf8",
"user": "test",
"password": "password"
}
}
In this sample file, the database is hosted at localhost
and named minecraft
, use the same as your PEX's config.yml.
If you set tables aliases in PermissionsEX config.yml, you have to tell the new names to PEXAdmin by editing Application/Config/pex.json
.
In the table_aliases
section you'll find a similar syntax to the config.yml to let you tell the aliases (at left (key) you have the original table name and at right (value) you can change the name according to your PermissionEX aliases configuration).
Do not edit the rest of the files unless you know what you are doing!
To allow which users can connect to PEXAdmin, you have to edit the Application/Config/users.json
.
{
"demo":
{
"password": "89e495e7941cf9e40e6980d14a16bf023ccd4c91",
"role": "read"
},
"admin":
{
"password": "d033e22ae348aeb5660fc2140aec35850c4da997",
"role": "write"
},
"admin2":
{
"password": "$2y$10$iqiefC9ER6Ifw/jnOEs8ser1ETQCZ0KDCs/ylVFPnGK.OA749WDqa",
"role": "write",
"hashType": "bcrypt"
}
}
Each object is a user, the key is the user's login and data is user's password and role.
In the sample config shown above, there are 3 users (demo , admin and admin2) and their passwords are respectively 'demo', 'admin' (hashed with SHA1 algorithm). and 'admin2' (hashed with bcrypt algorithm)
The usernames keys must be in lowercase !
Roles:
read
can see all permission / players / groups but cannot edit them- it can be used for people that need to know permissions nodes
write
can edit all permission / players / groups
hashType option specify which hash algorithm was used to hash the password Here's the accepted values:
- 'sha1' (default if not provided): using the sha1 algorithm
- 'bcrypt': more robust
- 'clear': don't use any hash algorithm, meaning password is stored as-is (This value should not be used in production and was kept for debugging / testing purposes only!)
To get the SHA1 hash from your password, you can use one of the the online sha1 script, or simply run echo sha1('YOUR PASSWORD');
in PHP.
To get the bcrypt hash from your password, you can also use one of the the online hash scripts, or simply run echo password_hash("YOUR PASSWORD", PASSWORD_DEFAULT);
in PHP.