The PostgreSQL Audit Extension (pgAudit) provides detailed session and/or object audit logging via the standard PostgreSQL logging.
The project is open source (https://github.com/pgaudit/pgaudit) with branches for each version of PostgreSQL:
PostgreSQL 13: https://github.com/pgaudit/pgaudit/tree/REL_13_STABLE
PostgreSQL 12: https://github.com/pgaudit/pgaudit/tree/REL_12_STABLE
There are many tutorials that discuss using Mingw or Cygwin to compile PostgreSQL and associated modules/plugins. These might work, but they seem to skip the part about linking.
Alright, let's begin. First, create a new project.
data:image/s3,"s3://crabby-images/146aa/146aa5ac96e3b4454874651b9d15cebef8bbe95d" alt=""
Next, make sure you are creating a dynamic link library.
data:image/s3,"s3://crabby-images/9bad5/9bad5da15581b62702b62313ed1a39ef3e8185e3" alt=""
Now, name the project and create it.
data:image/s3,"s3://crabby-images/27a9f/27a9fcbc08b886d431d76edab08ad22ab2fd2c42" alt=""
Remove all the auto-generated pre-compiled headers. Really, there are no need for headers here as PGAudit is just a single .c file.
data:image/s3,"s3://crabby-images/48318/48318e0693fa33cd5fa744b206422b6dcf57a546" alt=""
Now paste in the correct pgaudit file.
Here they are if you're too lazy to get them for github.
pgaudit12.c
pgaudit13.c
data:image/s3,"s3://crabby-images/b6b75/b6b75d0c5e813afdc8956eb204d3ec5ccd80cd8c" alt=""
Time to configure the project. Right click, and select properties. Now remove settings for pre-compiled headers.
data:image/s3,"s3://crabby-images/757ca/757ca1a2405ec7d5f10d1935cc9970c9a770b08a" alt=""
Now link the PostgreSQL libs.
data:image/s3,"s3://crabby-images/097ca/097ca26b09419a17f20398f56ff49b378273dec9" alt=""
Then specify all the includes (make sure you specify the correct PostgreSQL version):
C:\Program Files\PostgreSQL\13\include;
C:\Program Files\PostgreSQL\13\include\server;
C:\Program Files\PostgreSQL\13\include\server\port\win32;
C:\Program Files\PostgreSQL\13\include\server\port\win32_msvc
data:image/s3,"s3://crabby-images/e8506/e8506a8ff99a3b0be082324836015e4ad4c838cf" alt=""
Add _CRT_SECURE_NO_WARNINGS
data:image/s3,"s3://crabby-images/ffd97/ffd97e991919512df96d805c0557f2da098a3980" alt=""
Finally, compile the project.
data:image/s3,"s3://crabby-images/62916/62916a3e3a7a34a819e83e7e0e3a36db2a56eefa" alt=""
Hopefully, you've made the DLL!
What next?
You can compile other PostgreSQL plugins this way.
But, if all you wanted was PGAudit for windows installations, here are the DLLs:
pgAudit12_win_x64.dll
pgAudit13_win_x64.dll