Skip to content
/ PolyUDF Public

PostgreSQL Pwn library for Windows with multiversion support. One DLL to rule them all!

Notifications You must be signed in to change notification settings

rop-la/PolyUDF

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PolyUDF

PolyUDF is a User Defined Functions (UDF) library for PostgreSQL version 9.4+ (version 1 calling convention) that supports targeting PostgreSQL for Windows on x86 and x64 architectures. This project is the result of several hours of ideas exchange between RoP Team members and the constant necessity to recompile the UDF modules for different versions of PostgreSQL and lack of support for x64 builds on Windows. Some crazy ideas arose and were left on the drawing table for years. As none of these ideas were applied nor developed by others we decided to put our hands to work and here is the first release. We hope this library will be as useful for pentesters and red teams as for students in their learning path about Windows and PostgreSQL's internals.

We use some Windows specific tricks for supporting multiple versions of PostgreSQL, targeting builds by EnterpriseDB and 2ndQuadrant as are the most popular and used builds for Windows, but we have in the TODO list the support for Linux. Checkout the complete post at our blog PolyUDF: Universal PostgreSQL UDF module for Windows

The main features of PolyUDF are:

  • Multiversion (9.4+ - version 1 calling convention) and architecture (x86/x64) support (Pretty obvious)
  • Clean DLL and functions loading and registering (Register one function that register all!)
  • Clean DLL and functions unloading and unregistering (Register one function that unregister all functions and unloads the DLL. No more service restart to delete DLL from disk and leave no trace.)

The current TODO List:

  • Support for Linux
  • Implement all functions required by SQLMap
  • Integrate into SQLMap
  • Validate and add support to 8.x - 9.3 versions (Version 0 calling convention)

Build environment

PolyUDF was build using the following software environment:

  • Windows 7 Professional (64 bits)
  • Visual Studio 2015 Update 3
  • PostgreSQL 10 (32/64 bits)
  • Windows SDK v7.1A and 10

It will work with other configurations but we have not tested it yet.

About

PostgreSQL Pwn library for Windows with multiversion support. One DLL to rule them all!

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages