Installing PHP on the Red Hat family—Fedora, RHEL, CentOS 7—is a must for cyber security and it’s not rocket science. With a few easy steps, you too can bring your PHP based web applications to the next level.
The setup of the LEMP stack (NGINX, MariaDB or MySQL, and PHP) has many caveats which can impact both performance and security. Here is how to do it right.
Are you concerned about the security of data transmissions in which your web server participates day in and day out? Passwords, user names, credit card numbers, and other sensitive private communications on the Internet can easily be compromised unless you actively take precautionary measures and preempt the most common exploits by means of modern cryptography. Your users trust that you will protect them. The only question is: how do you measure success?
Mode bits in Linux/Unix have been puzzling newbies to no end:
-rwxrwxrwx. 1 owner group 420 Dec 21 12:46 .bash_history
The first mode bit designates the type of the item; the following nine mode bits indicate access permissions on the item with respect to the owner, the group and all other users.
Special file designator
The first character field is a special file designator. It can indicate that an item is:
- a directory (d);
- a symlink or symbolic link (l);
- a Unix socket (s);
- a block device (b);
- a named pipe (p) such as initctl;
- a character device (c);
- a “door” (D); rarely used, but nonetheless supported.
For lack of a letter, a leading ‘–‘ in place of a special file designator indicates that the item in question is a regular file.
Permissions (file mode) bits
Each consecutive three characters within the nine permissions bits represent privileges that may be assigned to the owner of an item (the first three characters after the special file designator), the group (the next three characters), and/or everyone else (the next three characters). Unix/Linux supports the following permissions:
- read (r);
- write (w);
- execute a file or list a directory or perform a search within a directory (x);
- in the owner’s or group’s permissions: set-user-ID mode on a file that is not executable (S);
- in the owner’s or group’s permissions: set-user-ID mode on an executable file (s).
For example the following notation:
-rw-r----- someuser somegroup filename
translates as follows:
- the item is a file (-),
- the user ‘someuser’ has read and write permissions (rw-) on it,
- the group somegroup has only read permissions (r–) on it, and
- everyone else can neither read nor write nor execute the file (—).
Setting read, write, and execute permissions for the owner, group, and everyone else
Unix permissions can be expressed numerically as powers of two:
- r equals 4 (2^2; the lack of this privilege is represented by a 0),
- w equals 2 (2^1; the lack of this privilege is represented by a 0),
- x equals 1 (2^0; the lack of this privilege is represented by a 0).
This designation ensures that there is no room for overlaps. Undefined permissions aren’t possible, either. It’s as clear cut as it gets.
To arrive at a numerical value for permissions that affect an entity class such as the owner, the group or everyone else (meaning all users that neither belong to the group nor own the object), all you have to do is sum up the permissions that represent privileges of this entity class (the owner’s, the group’s, and everyone else’s permissions, one single digit for each class).
If an entity class such as the owner, the group or ‘everyone else’ has read (4), write (2), and execute (1) permissions, these equal 7 (4+2+1=7).
Likewise, if an entity class such as the owner, the group or ‘everyone else’ can read (4) and execute (1) a file but not write (0) to it, the permissions equal 5 (4+0+1=5).
If an entity class such as the owner, the group or ‘everyone else’ has read (4) permissions only, these permissions are represented by the digit 4 (4+0+0=4).
This is how you can change privileges on a file in a way that only grants its owner read, write, and execute permissions:
chmod 700 filename ls -l filename -rwx------ owner group filename
When a new file is created, it usually inherits the group id of its creator. However, there are exceptions from the rule.
If you want new files to inherit the group id of their parent folder, enable the SGID (Set Group ID on execution) bit on that folder.
In addition to the above, the permissions to delete or rename a file or directory can be limited to its owner and the root user by means of setting a sticky bit (mode 1000) in one of two scenarios:
- sticky bit on an object without execute or search permissions (T);
- sticky bit on an object that is either an executable file or a searchable directory (t).
In each case, the sticky bit appears in place of the last one of the three mode bits that denote permissions for “everyone else”.
Alternate access method designator
Following the file mode bits is a single character that specifies an alternate access method such as an access control list. When the character following the file mode bits is a space, there is no alternate access method. When it is a printing character, then there is such a method.
GNU ‘ls’ command uses a dot (‘.‘) to indicate a file with an SELinux security context and no other alternate access method. A file with any other combination of alternate access methods is marked with a ‘+‘ character.
In order to read out the alternate access methods, you can use the command:
for example like this:
-rw-------. 1 centos centos 586 Oct 21 15:03 authorized_keys getfacl . # file: . # owner: centos # group: centos user::rwx group::--- other::---
Tip: use this SELinux label for a temp directory
chcon -t tmp_t temp
One way to find out the details of your PHP configuration is by saving
<?php phpinfo(); ?>
in a text file with the extension .php in a web server directory. You can name this file whatever you want; its customary name is info.php. When you visit the corresponding URI in your web browser, it will show you all the relevant details of your configuration. This method, however, leaves you vulnerable: it discloses details to the public that should be nobody’s business but the administrator’s. It is certainly not a good policy to leave the file on the server and too much hassle to create it every time it’s needed. Luckily, there is a better way.