Revision as of 14:32, 14 July 2020 edit66.90.149.252 (talk) s/torvalds/dmr/g s/thompson/ken/g s/wozniak/bwk/g← Previous edit | Revision as of 14:32, 14 July 2020 edit undoDrmies (talk | contribs)Autopatrolled, Checkusers, Oversighters, Administrators407,409 edits Reverted 1 edit by 66.90.149.252 (talk): Why (TW)Tag: UndoNext edit → | ||
Line 41: | Line 41: | ||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
$ stat -c "%a %A" ~/test/ | $ stat -c "%a %A" ~/test/ | ||
1770 drwxrwx--T | 1770 drwxrwx--T | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Line 48: | Line 48: | ||
'''4701''' on an executable file owned by 'root' and the group 'root' | '''4701''' on an executable file owned by 'root' and the group 'root' | ||
A user named ' |
A user named 'thompson' attempts to execute the file. The executable permission for all users is set (the '1') so 'thompson' can execute the file. The file owner is 'root' and the SUID permission is set (the '4') - so the file is executed as 'root'. | ||
The reason an executable would be run as 'root' is so that it can modify specific files that the user would not normally be allowed to, without giving the user full root access. | The reason an executable would be run as 'root' is so that it can modify specific files that the user would not normally be allowed to, without giving the user full root access. | ||
A default use of this can be seen with the <code>/usr/bin/passwd</code> binary file. <code>/usr/bin/passwd</code> needs to modify <code>/etc/passwd</code> and <code>/etc/shadow</code> which store account information and password hashes for all users, and these can only be modified by the user 'root'.<syntaxhighlight lang="console"> | A default use of this can be seen with the <code>/usr/bin/passwd</code> binary file. <code>/usr/bin/passwd</code> needs to modify <code>/etc/passwd</code> and <code>/etc/shadow</code> which store account information and password hashes for all users, and these can only be modified by the user 'root'.<syntaxhighlight lang="console"> | ||
$ stat -c "%a %U:%G %n" /usr/bin/passwd | $ stat -c "%a %U:%G %n" /usr/bin/passwd | ||
4701 root:root /usr/bin/passwd | 4701 root:root /usr/bin/passwd | ||
$ passwd | $ passwd | ||
passwd: Changing password for |
passwd: Changing password for thompson | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Line 65: | Line 65: | ||
'''2770''' on a directory named 'music' owned by the user 'root' and the group 'engineers' | '''2770''' on a directory named 'music' owned by the user 'root' and the group 'engineers' | ||
A user named ' |
A user named 'torvalds' who belongs primarily to the group 'torvalds' but secondarily to the group 'engineers' makes a directory named 'electronic' under the directory named 'music'. The group ownership of the new directory named 'electronic' inherits 'engineers.' This is the same when making a new ''file'' named 'imagine.txt' | ||
Without SGID the group ownership of the new directory/file would have been ' |
Without SGID the group ownership of the new directory/file would have been 'torvalds' as that is the primary group of user 'torvalds'. | ||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
$ groups |
$ groups torvalds | ||
torvalds : torvalds engineers | |||
$ stat -c "%a %U:%G %n" ./music/ | $ stat -c "%a %U:%G %n" ./music/ | ||
2770 root:engineers ./music/ | 2770 root:engineers ./music/ | ||
$ mkdir ~/music/electronic | $ mkdir ~/music/electronic | ||
$ stat -c "%U:%G %n" ./music/electronic/ | $ stat -c "%U:%G %n" ./music/electronic/ | ||
torvalds:engineers ./music/electronic/ | |||
$ echo 'NEW FILE' > ~/music/imagine.txt | $ echo 'NEW FILE' > ~/music/imagine.txt | ||
$ stat -c "%U:%G %n" ./music/imagine.txt | $ stat -c "%U:%G %n" ./music/imagine.txt | ||
torvalds:engineers ./music/imagine.txt | |||
$ touch ~/test | $ touch ~/test | ||
$ stat -c "%U:%G %n" ~/test | $ stat -c "%U:%G %n" ~/test | ||
torvalds:torvalds ~/test | |||
</syntaxhighlight> | </syntaxhighlight> | ||
===Sticky bit=== | ===Sticky bit=== | ||
{{seealso|Sticky bit}} | {{seealso|Sticky bit}} | ||
'''1770''' on a directory named 'videogames' owned by the user ' |
'''1770''' on a directory named 'videogames' owned by the user 'torvalds' and the group 'engineers'. | ||
A user named ' |
A user named 'torvalds' creates a file named 'tekken' under the directory named 'videogames'. A user named 'wozniak', who is also part of the group 'engineers', attempts to delete the file named 'tekken' but he cannot, since he is not the owner. | ||
Without sticky bit ' |
Without sticky bit 'wozniak' could have deleted the file, because the directory named 'videogames' allows read and write by 'engineers'. A default use of this can be seen at the <code>/tmp</code> folder. | ||
<syntaxhighlight lang="console"> | <syntaxhighlight lang="console"> | ||
$ groups |
$ groups torvalds | ||
torvalds : torvalds engineers | |||
$ stat -c "%a %U:%G %n" ./videogames/ | $ stat -c "%a %U:%G %n" ./videogames/ | ||
1770 |
1770 torvalds:engineers ./videogames/ | ||
$ echo 'NEW FILE' > videogames/tekken | $ echo 'NEW FILE' > videogames/tekken | ||
$ su - |
$ su - wozniak | ||
Password: | Password: | ||
$ groups |
$ groups wozniak | ||
wozniak : wozniak engineers | |||
$ cd /home/shared/videogames | $ cd /home/shared/videogames | ||
$ rm tekken | $ rm tekken | ||
rm: cannot remove ‘tekken’: Operation not permitted | rm: cannot remove ‘tekken’: Operation not permitted | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Line 122: | Line 122: | ||
'''3171''' on a directory named 'blog' owned by the group 'engineers' and the user 'root' | '''3171''' on a directory named 'blog' owned by the group 'engineers' and the user 'root' | ||
A user named ' |
A user named 'torvalds' who belongs to the group 'engineers' creates a file or directory named 'thoughts' inside the directory 'blog'. A user named 'wozniak' who also belongs to the group 'engineers' cannot delete, rename, or move the file or directory named 'thoughts', because he is not the owner and the sticky bit is set. However, if 'thoughts' is a file, then 'wozniak' can edit it. | ||
'''Sticky bit has the final decision.''' If sticky bit and SGID had not been set, the user ' |
'''Sticky bit has the final decision.''' If sticky bit and SGID had not been set, the user 'wozniak' could rename, move, or delete the file named 'thoughts' because the directory named 'blog' allows read and write by group, and wozniak belongs to the group, and the default 0002 umask allows new files to be edited by group. Sticky bit and SGID could be combined with something such as a read-only umask or an append only attribute.<syntaxhighlight lang="console"> | ||
$ stat -c "%a %U:%G %n" ./blog/ | $ stat -c "%a %U:%G %n" ./blog/ | ||
3171 root:engineers ./blog/ | 3171 root:engineers ./blog/ | ||
$ echo 'NEW FILE' > ./blog/thoughts | $ echo 'NEW FILE' > ./blog/thoughts | ||
$ su - |
$ su - wozniak | ||
Password: | Password: | ||
$ cd /home/shared/blog | $ cd /home/shared/blog | ||
$ groups |
$ groups wozniak | ||
wozniak : wozniak engineers | |||
$ stat -c "%a %U:%G %n" ./thoughts | $ stat -c "%a %U:%G %n" ./thoughts | ||
664 |
664 torvalds:engineers ./thoughts | ||
$ rm thoughts | $ rm thoughts | ||
rm: cannot remove ‘thoughts’: Operation not permitted | rm: cannot remove ‘thoughts’: Operation not permitted | ||
$ mv thoughts /home/ |
$ mv thoughts /home/wozniak/ | ||
mv: cannot move ‘thoughts’ to ‘/home/ |
mv: cannot move ‘thoughts’ to ‘/home/wozniak/thoughts’: Operation not permitted | ||
$ mv thoughts pondering | $ mv thoughts pondering | ||
mv: cannot move ‘thoughts’ to ‘pondering’: Operation not permitted | mv: cannot move ‘thoughts’ to ‘pondering’: Operation not permitted | ||
$ echo 'REWRITE!' > thoughts | $ echo 'REWRITE!' > thoughts | ||
$ cat thoughts | $ cat thoughts | ||
REWRITE! | REWRITE! | ||
</syntaxhighlight> | </syntaxhighlight> |
Revision as of 14:32, 14 July 2020
"SGID" redirects here. For the company which briefly used this stock ticker symbol, see Silicon Graphics.setuid and setgid (short for "set user ID" and "set group ID") are Unix access rights flags that allow users to run an executable with the permissions of the executable's owner or group respectively and to change behaviour in directories. They are often used to allow users on a computer system to run programs with temporarily elevated privileges in order to perform a specific task. While the assumed user id or group id privileges provided are not always elevated, at a minimum they are specific.
setuid
and setgid
are needed for tasks that require different privileges than what the user is normally granted, such as the ability to alter system files or databases to change their login password. Some of the tasks that require additional privileges may not immediately be obvious, though, such as the ping
command, which must send and listen for control packets on a network interface.
Effects
The setuid
and setgid
flags have different effects, depending on whether they are applied to a file, to a directory or binary executable or non binary executable file. The setuid
and setgid
flags only have effect on binary executable files. Setting these bits on scripts like bash, perl or python does not have any effect.
When set on an executable file
When the setuid
or setgid
attributes are set on an executable file, then any users able to execute the file will automatically execute the file with the privileges of the file's owner (commonly root) and/or the file's group, depending upon the flags set. This allows the system designer to permit trusted programs to be run which a user would otherwise not be allowed to execute. These may not always be obvious. For example, the ping command may need access to networking privileges that a normal user cannot access; therefore it may be given the setuid flag to ensure that a user who needs to ping another system can do so, even if their own account does not have the required privilege for sending packets.
For security purposes, the invoking user is usually prohibited by the system from altering the new process in any way, such as by using ptrace
, LD_LIBRARY_PATH
or sending signals to it, to exploit the raised privilege, although signals from the terminal will still be accepted.
The setuid
and setgid
bits are normally set with the command chmod
by setting the high-order octal digit to 4 for setuid
or 2 for setgid
. "chmod 6711 file
" will set both the setuid
and setgid
bits (4+2=6), making the file read/write/executable for the owner (7), and executable by the group (first 1) and others (second 1). When a user other than the owner executes the file, the process will run with user and group permissions set upon it by its owner. For example, if the file is owned by user root
and group wheel
, it will run as root:wheel
no matter who executes the file.
Most implementations of the chmod
command also support finer-grained, symbolic arguments to set these bits. The numeric way of setting these stick permissions as used above "chmod 6711 file
" doesn't allow one to withdraw these same permissions as one would expect as "chmod 0711 file
". The preferably finer-grained mode is shown in the demonstration below as the "chmod ug+s
"
Security impact
While the setuid
feature is very useful in many cases, its improper use can pose a security risk if the setuid
attribute is assigned to executable programs that are not carefully designed. Due to potential security issues, many operating systems ignore the setuid
attribute when applied to executable shell scripts.
The presence of setuid
executables explains why the chroot
system call is not available to non-root users on Unix. See limitations of chroot
for more details.
When set on a directory
Setting the setgid
permission on a directory ("chmod g+s
") causes new files and subdirectories created within it to inherit its group ID, rather than the primary group ID of the user who created the file (the owner ID is never affected, only the group ID).
- Newly created subdirectories inherit the
setgid
bit. Thus, this enables a shared workspace for a group without the inconvenience of requiring group members to explicitly change their current group before creating new files or directories. - only affects the group ID of new files and subdirectories created after the
setgid
bit is set, and is not applied to existing entities. - does not affect group ID of the files that are created elsewhere and moved to the directory in question. The file will continue to carry the group ID that was effected when and where it was created.
Setting the setgid
bit on existing subdirectories must be done manually, with a command such as find /path/to/directory -type d -exec chmod g+s '{}' \;
The setuid
permission set on a directory is ignored on most UNIX and Linux systems. However FreeBSD can be configured to interpret setuid
in a manner similar to setgid
, in which case it forces all files and sub-directories created in a directory to be owned by that directory's owner - a simple form of inheritance. This is generally not needed on most systems derived from BSD, since by default directories are treated as if their setgid
bit is always set, regardless of the actual value. As is stated in open(2)
, "When a new file is created it is given the group of the directory which contains it."
Examples
Checking permissions
Permissions of a file can be checked in octal form and/or alphabetic form with the command line tool stat
$ stat -c "%a %A" ~/test/ 1770 drwxrwx--T
SUID
4701 on an executable file owned by 'root' and the group 'root'
A user named 'thompson' attempts to execute the file. The executable permission for all users is set (the '1') so 'thompson' can execute the file. The file owner is 'root' and the SUID permission is set (the '4') - so the file is executed as 'root'.
The reason an executable would be run as 'root' is so that it can modify specific files that the user would not normally be allowed to, without giving the user full root access.
A default use of this can be seen with the /usr/bin/passwd
binary file. /usr/bin/passwd
needs to modify /etc/passwd
and /etc/shadow
which store account information and password hashes for all users, and these can only be modified by the user 'root'.
$ stat -c "%a %U:%G %n" /usr/bin/passwd 4701 root:root /usr/bin/passwd $ passwd passwd: Changing password for thompson
The owner of the process is not the user running the executable file but the owner of the executable file
SGID
2770 on a directory named 'music' owned by the user 'root' and the group 'engineers'
A user named 'torvalds' who belongs primarily to the group 'torvalds' but secondarily to the group 'engineers' makes a directory named 'electronic' under the directory named 'music'. The group ownership of the new directory named 'electronic' inherits 'engineers.' This is the same when making a new file named 'imagine.txt'
Without SGID the group ownership of the new directory/file would have been 'torvalds' as that is the primary group of user 'torvalds'.
$ groups torvalds torvalds : torvalds engineers $ stat -c "%a %U:%G %n" ./music/ 2770 root:engineers ./music/ $ mkdir ~/music/electronic $ stat -c "%U:%G %n" ./music/electronic/ torvalds:engineers ./music/electronic/ $ echo 'NEW FILE' > ~/music/imagine.txt $ stat -c "%U:%G %n" ./music/imagine.txt torvalds:engineers ./music/imagine.txt $ touch ~/test $ stat -c "%U:%G %n" ~/test torvalds:torvalds ~/test
Sticky bit
See also: Sticky bit1770 on a directory named 'videogames' owned by the user 'torvalds' and the group 'engineers'.
A user named 'torvalds' creates a file named 'tekken' under the directory named 'videogames'. A user named 'wozniak', who is also part of the group 'engineers', attempts to delete the file named 'tekken' but he cannot, since he is not the owner.
Without sticky bit 'wozniak' could have deleted the file, because the directory named 'videogames' allows read and write by 'engineers'. A default use of this can be seen at the /tmp
folder.
$ groups torvalds torvalds : torvalds engineers $ stat -c "%a %U:%G %n" ./videogames/ 1770 torvalds:engineers ./videogames/ $ echo 'NEW FILE' > videogames/tekken $ su - wozniak Password: $ groups wozniak wozniak : wozniak engineers $ cd /home/shared/videogames $ rm tekken rm: cannot remove ‘tekken’: Operation not permitted
Sticky bit with SGID
3171 on a directory named 'blog' owned by the group 'engineers' and the user 'root'
A user named 'torvalds' who belongs to the group 'engineers' creates a file or directory named 'thoughts' inside the directory 'blog'. A user named 'wozniak' who also belongs to the group 'engineers' cannot delete, rename, or move the file or directory named 'thoughts', because he is not the owner and the sticky bit is set. However, if 'thoughts' is a file, then 'wozniak' can edit it.
Sticky bit has the final decision. If sticky bit and SGID had not been set, the user 'wozniak' could rename, move, or delete the file named 'thoughts' because the directory named 'blog' allows read and write by group, and wozniak belongs to the group, and the default 0002 umask allows new files to be edited by group. Sticky bit and SGID could be combined with something such as a read-only umask or an append only attribute.
$ stat -c "%a %U:%G %n" ./blog/ 3171 root:engineers ./blog/ $ echo 'NEW FILE' > ./blog/thoughts $ su - wozniak Password: $ cd /home/shared/blog $ groups wozniak wozniak : wozniak engineers $ stat -c "%a %U:%G %n" ./thoughts 664 torvalds:engineers ./thoughts $ rm thoughts rm: cannot remove ‘thoughts’: Operation not permitted $ mv thoughts /home/wozniak/ mv: cannot move ‘thoughts’ to ‘/home/wozniak/thoughts’: Operation not permitted $ mv thoughts pondering mv: cannot move ‘thoughts’ to ‘pondering’: Operation not permitted $ echo 'REWRITE!' > thoughts $ cat thoughts REWRITE!
Security
Developers should design and implement programs that use this bit on executables carefully in order to avoid security vulnerabilities including buffer overruns and path injection. Successful buffer-overrun attacks on vulnerable applications allow the attacker to execute arbitrary code under the rights of the process exploited. In the event that a vulnerable process uses the setuid
bit to run as root
, the code will execute with root privileges, in effect giving the attacker root access to the system on which the vulnerable process is running.
Of particular importance in the case of a setuid
process is the environment of the process. If the environment is not properly sanitized by a privileged process, its behavior can be changed by the unprivileged process that started it. For example, GNU libc was at one point vulnerable to an exploit using setuid
and an environment variable that allowed executing code from untrusted shared libraries.
History
The setuid
bit was invented by Dennis Ritchie and included in su
. His employer, then Bell Telephone Laboratories, applied for a patent in 1972; the patent was granted in 1979 as patent number US 4135240 "Protection of data file contents". The patent was later placed in the public domain.
See also
- Sticky bit
- User identifier
- umask
- Group identifier
- Process identifier
chmod
sudo
- Confused deputy problem
- PolicyKit
- Unix security
- File system permissions
- Privilege revocation (computing)
- Privilege separation
- Environment variable
References
- von Hagen, William (2010-05-13). Ubuntu Linux Bible. pp. 3–59. ISBN 9780470881804.
- ^ Frisch, Æleen (2009-02-09). Essential system administration. O'Reilly. p. 351. ISBN 9780596550493.
- Billimoria, Kaiwan N. (2018). Hands-On System Programming with Linux: Explore Linux system programming interfaces, theory, and practice. Packt Publishing Ltd. p. 250. ISBN 978-1-78899-674-7.
- "Unix - Frequently Asked Questions".
- "chmod -- change file modes". freebsd.org.
- "open, openat -- open or create a file for reading, writing or executing". freebsd.org.
- Neil Brown (November 23, 2010). "Ghosts of Unix past, part 4: High-maintenance designs". LWN.net. Retrieved 30 March 2014.
- Jake Edge (October 27, 2010). "Two glibc vulnerabilities". LWN.net. Retrieved 30 March 2014.
- ^ McIlroy, M. Douglas (1987). A Research Unix reader: annotated excerpts from the Programmer's Manual, 1971–1986 (PDF) (Technical report). CSTR. Bell Labs. 139.
- "Summary of key software patents".
External links
- Chen, Hao; Wagner, David; and Dean, Drew; Setuid Demystified (pdf)
- Tsafrir, Dan; Da Silva, Dilma; and Wagner, David; The Murky Issue of Changing Process Identity: Revising Setuid Demystified (pdf)
- Pollock, Wayne; Unix File and Directory Permissions and Modes