CWE Rule 273
Description
Rule Description
The product attempts to drop privileges but does not check or incorrectly checks to see if the drop succeeded.
Polyspace Implementation
The rule checker checks for Privilege drop not verified.
Examples
Privilege drop not verified
This issue occurs when you relinquish privileges using functions such as
setuid
but do not verify that the
privileges were actually dropped before exiting your
function.
If privilege relinquishment fails, an attacker can regain elevated privileges and have more access to your program than intended. This security hole can cause unexpected behavior in your code if left open.
Before the end of scope, verify that the privileges that you dropped were actually dropped.
#define _BSD_SOURCE #include <sys/types.h> #include <unistd.h> #include <grp.h> #include <stdlib.h> #define fatal_error() abort() extern int need_more_privileges; void missingprivilegedropcheck() { /* Code intended to run with elevated privileges */ /* Temporarily drop elevated privileges */ if (seteuid(getuid()) != 0) { /* Handle error */ fatal_error(); } /* Code intended to run with lower privileges */ if (need_more_privileges) { /* Restore elevated privileges */ if (seteuid(0) != 0) { /* Handle error */ fatal_error(); } /* Code intended to run with elevated privileges */ } /* ... */ /* Permanently drop elevated privileges */ if (setuid(getuid()) != 0) { /* Handle error */ fatal_error(); } /* Code intended to run with lower privileges */ } //Noncompliant
In this example, privileges are elevated and dropped to run code with the intended privilege level. When privileges are dropped, the privilege level before exiting the function body is not verified. A malicious attacker can regain their elevated privileges.
One possible correction is to use setuid
to
verify that the privileges were dropped.
#define _BSD_SOURCE #include <sys/types.h> #include <unistd.h> #include <grp.h> #include <stdlib.h> #define fatal_error() abort() extern int need_more_privileges; void missingprivilegedropcheck() { /* Store the privileged ID for later verification */ uid_t privid = geteuid(); /* Code intended to run with elevated privileges */ /* Temporarily drop elevated privileges */ if (seteuid(getuid()) != 0) { /* Handle error */ fatal_error(); } /* Code intended to run with lower privileges */ if (need_more_privileges) { /* Restore elevated Privileges */ if (seteuid(privid) != 0) { /* Handle error */ fatal_error(); } /* Code intended to run with elevated privileges */ } /* ... */ /* Restore privileges if needed */ if (geteuid() != privid) { if (seteuid(privid) != 0) { /* Handle error */ fatal_error(); } } /* Permanently drop privileges */ if (setuid(getuid()) != 0) { /* Handle error */ fatal_error(); } if (setuid(0) != -1) { /* Privileges can be restored, handle error */ fatal_error(); } /* Code intended to run with lower privileges; */ }
Check Information
Category: Privilege Issues |
Version History
Introduced in R2024a
See Also
External Websites
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
Asia Pacific
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)