odyssey/modules/audit_module.c

70 lines
1.2 KiB
C
Raw Normal View History

2020-06-09 09:19:11 +00:00
/*
* Odyssey module.
*
* Scalable PostgreSQL connection pooler.
*/
#include "audit_module.h"
od_module_t od_module = {
.module_init_cb = audit_init_cb,
.auth_complete_cb = audit_auth_complete_cb,
.auth_attempt_cb = audit_auth_attempt_cb,
.disconnect_cb = audit_disconnect_cb,
.unload_cb = audit_auth_unload,
.config_init_cb = audit_config_init,
2020-06-09 09:19:11 +00:00
};
int
audit_auth_attempt_cb(od_client_t *c)
{
return OD_MODULE_CB_OK_RETCODE;
}
int
audit_auth_complete_cb(od_client_t *c, bool auth_ok)
2020-06-09 09:19:11 +00:00
{
FILE *fptr;
fptr = fopen("/tmp/audit_usr.log", "a");
if (fptr == NULL) {
printf("Error!");
return OD_MODULE_CB_FAIL_RETCODE;
2020-06-09 09:19:11 +00:00
}
if (auth_ok) {
fprintf(fptr,
"usr successfully logged in: usrname = %s",
c->startup.user.value);
} else {
fprintf(
fptr, "usr failed to log in: usrname = %s", c->startup.user.value);
}
fclose(fptr);
return OD_MODULE_CB_OK_RETCODE;
2020-06-09 09:19:11 +00:00
}
int
audit_disconnect_cb(od_client_t *c, od_status_t s)
{
return OD_MODULE_CB_OK_RETCODE;
}
int
audit_init_cb()
{
return OD_MODULE_CB_OK_RETCODE;
2020-06-09 09:19:11 +00:00
}
int
audit_auth_unload(void)
2020-06-09 09:19:11 +00:00
{
return OD_MODULE_CB_OK_RETCODE;
2020-06-09 09:19:11 +00:00
}
int
audit_config_init(char *usr, od_config_reader_t *cr, od_token_t *token)
2020-06-09 09:19:11 +00:00
{
return OD_MODULE_CB_OK_RETCODE;
2020-06-09 09:19:11 +00:00
}