# Checklist - Linux Privilege Escalation

## **Best tool to look for Linux local privilege escalation vectors:** [**LinPEAS**](https://github.com/carlospolop/privilege-escalation-awesome-scripts-suite/tree/master/linPEAS)\*\*\*\*

## [System Information](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#system-information)

* [ ] Get **OS information**
* [ ] Check the [**PATH**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#path), any **writable folder**?
* [ ] Check [**env variables**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#env-info), any sensitive detail?
* [ ] Search for [**kernel exploits**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#kernel-exploits) **using scripts** (DirtyCow?)
* [ ] **Check** if the [**sudo version** is vulnerable](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#sudo-version)
* [ ] \*\*\*\*[**Dmesg** signature verification failed](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#dmesg-signature-verification-failed) error?
* [ ] More system enum ([date, system stats, cpu info, printers](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#more-system-enumeration))
* [ ] [Enumerate more defenses](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#enumerate-possible-defenses)

## [Drives](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#drives)

* [ ] **List mounted** drives
* [ ] **Any unmounted drive?**
* [ ] **Any creds in fstab?**

## \*\*\*\*[**Installed Software**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#installed-software)\*\*\*\*

* [ ] **Check for**[ **useful software**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#useful-software) **installed**
* [ ] **Check for** [**vulnerable software**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#vulnerable-software-installed) **installed**

## \*\*\*\*[Processes](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#processes)

* [ ] Is  any **unknown software running**?
* [ ] Is any software with **more privileges that it should have running**?
* [ ] Search for **exploits for running processes** (specially if running of versions)
* [ ] Can you **modify the binary** of any running process?
* [ ] **Monitor processes** and check if any interesting process is running frequently
* [ ] Can you **read** some interesting **process memory** (where passwords could be saved)?

## [Scheduled/Cron jobs?](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#scheduled-jobs)

* [ ] Is the [**PATH** ](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#cron-path)being modified by some cron and you can **write** in it?
* [ ] Any [**wildcard** ](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#cron-using-a-script-with-a-wildcard-wildcard-injection)in a cron job?
* [ ] Some [**modifiable script** ](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#cron-script-overwriting-and-symlink)is being **executed** or is inside **modifiable folder**?
* [ ] Have you detected that some **script** could be being [**executed** very **frequently**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#frequent-cron-jobs)? (every 1, 2 or 5 minutes)

## [Services](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#services)

* [ ] Any **writable .service** file?
* [ ] Any **writable binary** executed by a **service**?
* [ ] Any **writable folder in systemd PATH**?

## [Timers](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#timers)

* [ ] Any **writable timer**?

## [Sockets](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#sockets)

* [ ] Any **writable .socket** file?
* [ ] Can you **communicate with any socket**?
* [ ] **HTTP sockets** with interesting info?

## [D-Bus](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#d-bus)

* [ ] Can you **communicate with any D-Bus**?

## [Network](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#network)

* [ ] Enumerate the network to know where you are
* [ ] **Open ports you couldn't access before** getting a shell inside the machine?
* [ ] Can you **sniff traffic** using `tcpdump`?

## [Users](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#users)

* [ ] Generic users/groups **enumeration**
* [ ] Do you have a **very big UID**? Is the **machine** **vulnerable**?
* [ ] Can you [**escalate privileges thanks to a group**](https://chinnidiwakar.gitbook.io/githubimport/linux-unix/privilege-escalation/interesting-groups-linux-pe) you belong to?
* [ ] **Clipboard** data?
* [ ] Password Policy?
* [ ] Try to **use** every **known password** that you have discovered previously to login **with each** possible **user**. Try to login also without password.

## [Writable PATH](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#writable-path-abuses)

* [ ] If you have **write privileges over some folder in PATH** you may be able to escalate privileges

## [SUDO and SUID commands](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#sudo-and-suid)

* [ ] Can you execute **any comand with sudo**? Can you use it to READ, WRITE or EXECUTE anything as root? ([**GTFOBins**](https://gtfobins.github.io/))
* [ ] Is any **exploitable suid binary**? ([**GTFOBins**](https://gtfobins.github.io/))
* [ ] Are [**sudo** commands **limited** by **path**? can you **bypass** the restrictions](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#sudo-execution-bypassing-paths)?
* [ ] \*\*\*\*[**Sudo/SUID binary without path indicated**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#sudo-command-suid-binary-without-command-path)?
* [ ] \*\*\*\*[**SUID binary specifying path**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#suid-binary-with-command-path)? Bypass
* [ ] \*\*\*\*[**LD\_PRELOAD vuln**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#ld_preload)\*\*\*\*
* [ ] \*\*\*\*[**Lack of .so library in SUID binary**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#suid-binary-so-injection) *\*\**&#x66;rom a writable folder?
* [ ] \*\*\*\*[**SUDO tokens available**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#reusing-sudo-tokens)? [**Can you create a SUDO token**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#var-run-sudo-ts-less-than-username-greater-than)?
* [ ] Can you [**read or modify sudoers files**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#etc-sudoers-etc-sudoers-d)?
* [ ] Can you [**modify /etc/ld.so.conf.d/**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#etc-ld-so-conf-d)?
* [ ] [**OpenBSD DOAS**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#doas) *\*\**&#x63;ommand

## [Capabilities](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#capabilities)

* [ ] Has any binary any **unexpected capability**?

## [ACLs](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#acls)

* [ ] Has any file any **unexpected ACL**?

## [Open Shell sessions](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#open-shell-sessions)

* [ ] **screen**?
* [ ] **tmux**?

## [SSH](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#ssh)

* [ ] **Debian** [**OpenSSL Predictable PRNG - CVE-2008-0166**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#debian-openssl-predictable-prng-cve-2008-0166)\*\*\*\*
* [ ] \*\*\*\*[**SSH Interesting configuration values**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#ssh-interesting-configuration-values)\*\*\*\*

## [Interesting Files](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#interesting-files)

* [ ] **Profile files** - Read sensitive data? Write to privesc?
* [ ] **passwd/shadow files** - Read sensitive data? Write to privesc?
* [ ] **Check commonly interesting folders** for sensitive data
* [ ] **Weird Localtion/Owned files,** you may have access or alter executable files
* [ ] **Modified** in last mins
* [ ] **Sqlite DB files**
* [ ] **Hidden files**
* [ ] **Script/Binaries in PATH**
* [ ] **Web files** (passwords?)
* [ ] **Backups**?
* [ ] **Known files that contains passwords**: Use **Linpeas** and **LaZagne**
* [ ] **Generic search**

## \*\*\*\*[**Writable Files**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#writable-files)\*\*\*\*

* [ ] **Modify python library** to execute arbitrary commands?
* [ ] Can you **modify log files**? **Logtotten** exploit
* [ ] Can you **modify /etc/sysconfig/network-scripts/**? Centos/Redhat exploit
* [ ] Can you [**write in ini, int.d, systemd or rc.d files**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#init-init-d-systemd-and-rc-d)?

## \*\*\*\*[**Other tricks**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#other-tricks)\*\*\*\*

* [ ] Can you [**abuse NFS to escalate privileges**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#nfs-privilege-escalation)?
* [ ] Do you need to [**escape from a restrictive shell**](https://chinnidiwakar.gitbook.io/githubimport/privilege-escalation#escaping-from-restricted-shells)?

If you want to **know** about my **latest modifications**/**additions** or you have **any suggestion for HackTricks or PEASS**, **join the** [**💬**](https://emojipedia.org/speech-balloon/) [**PEASS & HackTricks telegram group here**](https://t.me/peass), or **follow me on Twitter** [🐦](https://emojipedia.org/bird/)[**@carlospolopm**](https://twitter.com/carlospolopm)**.**\
If you want to **share some tricks with the community** you can also submit **pull requests** to **\*\*\[**<https://github.com/carlospolop/hacktricks**](https://github.com/carlospolop/hacktricks>) **\*\*that will be reflected in this book.**\
**Don't forget to** give ⭐ on the github\*\* to motivate me to continue developing this book.

![](https://4153509160-files.gitbook.io/~/files/v0/b/gitbook-legacy-files/o/assets%2F-MaoGr_g3I50alM2whW0%2Fsync%2F4c4968b48f0ebf20a73e46cd07c9315dc629c00c.png?generation=1622227467459076\&alt=media)

​[**Buy me a coffee here**](https://www.buymeacoffee.com/carlospolop)\*\*\*\*


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://chinnidiwakar.gitbook.io/githubimport/linux-unix/linux-privilege-escalation-checklist.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
