Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/timescale/pgspot
Spot vulnerabilities in postgres SQL scripts
https://github.com/timescale/pgspot
Last synced: 11 days ago
JSON representation
Spot vulnerabilities in postgres SQL scripts
- Host: GitHub
- URL: https://github.com/timescale/pgspot
- Owner: timescale
- License: postgresql
- Created: 2022-02-10T18:17:46.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2025-01-03T03:04:42.000Z (16 days ago)
- Last Synced: 2025-01-05T07:52:21.770Z (14 days ago)
- Language: Python
- Homepage:
- Size: 199 KB
- Stars: 82
- Watchers: 9
- Forks: 8
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Codeowners: CODEOWNERS
- Security: SECURITY.md
Awesome Lists containing this project
- trackawesomelist - pgspot (⭐45) - Spot vulnerabilities in PostgreSQL extension scripts. (Recently Updated / [Sep 16, 2024](/content/2024/09/16/README.md))
- awesome-repositories - timescale/pgspot - Spot vulnerabilities in postgres SQL scripts (Python)
README
## pgspot
Spot vulnerabilities in PostgreSQL extension scripts.
pgspot checks extension scripts for following PostgreSQL security best
practices. In addition to checking extension scripts it can also be
used to check security definer functions or any other PostgreSQL SQL code.pgspot checks for the following vulnerabilities:
- search_path-based attacks
- unsafe object creationConsult the [reference] for detailed documentation of the vulnerabilities which
pgspot detects, and their potential mitigations.[reference]: https://github.com/timescale/pgspot/blob/main/REFERENCE.md
## Useful links
- [PostgreSQL security recommendations for extensions](https://www.postgresql.org/docs/current/extend-extensions.html#EXTEND-EXTENSIONS-SECURITY)
- [PostgreSQL security recommendations for SECURITY DEFINER functions](https://www.postgresql.org/docs/current/sql-createfunction.html#SQL-CREATEFUNCTION-SECURITY)## Installation
pip install pgspot
## Requirements
- python >= 3.10
- [pglast](https://github.com/lelit/pglast)
- [libpg_query](https://github.com/pganalyze/libpg_query) (through pglast)To install the runtime requirements, use `pip install -r requirements.txt`.
### Usage
```
> pgspot -h
usage: pgspot [-h] [-a] [--proc-without-search-path PROC] [--summary-only] [--plpgsql | --no-plpgsql] [--explain EXPLAIN] [--ignore IGNORE] [--sql-accepting SQL_FN] [FILE ...]Spot vulnerabilities in PostgreSQL SQL scripts
positional arguments:
FILE file to check for vulnerabilitiesoptions:
-h, --help show this help message and exit
-a, --append append files before checking
--proc-without-search-path PROC
whitelist functions without explicit search_path
--summary-only only print number of errors, warnings and unknowns
--plpgsql, --no-plpgsql
Analyze PLpgSQL code (default: True)
--explain EXPLAIN Describe an error/warning code
--ignore IGNORE Ignore error or warning code
--ignore-lang LANG Ignore unknown procedural language
--sql-accepting SQL_FN
Specify one or more sql-accepting functions
``````
> pgspot --ignore PS017 <<<"CREATE TABLE IF NOT EXISTS foo();"
PS012: Unsafe table creation: fooErrors: 1 Warnings: 0 Unknown: 0
```#### SQL-accepting functions
It is a common pattern that SQL-accepting functions exist, which take a
string-like argument which will be executed as SQL. This can "hide" some SQL
from pgspot, as the string-like argument masks the SQL. With the
`--sql-accepting` argument, pgspot can be told about such functions.Assuming a function named `execute_sql` which takes a SQL string as its first
argument, and executes it. With `pgspot --sql-accepting=execute_sql` we can
tell pgspot `execute_sql` may accept SQL. pgspot will attempt to unpack and
evaluate all arguments to that function as SQL.