You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
proxysql/include/PgSQL_Authentication.h

117 lines
4.1 KiB

#ifndef __CLASS_PGSQL_AUTHENTICATION_H
#define __CLASS_PGSQL_AUTHENTICATION_H
#include "proxysql.h"
#include "cpp.h"
#define PROXYSQL_AUTH_PTHREAD_MUTEX
#ifndef PGSQL_ACCOUNT_DETAILS_T
#define PGSQL_ACCOUNT_DETAILS_T
struct _scram_keys {
uint8_t scram_ClientKey[32];
uint8_t scram_ServerKey[32];
};
typedef struct _pgsql_account_details_t {
char* username;
char* password;
char* attributes;
char* comment;
void* sha1_pass;
// TODO POSGRESQL: add client and server scram keys
//_scram_keys* scram_keys;
int default_hostgroup;
int max_connections;
int num_connections_used;
bool use_ssl;
bool transaction_persistent;
bool fast_forward;
bool __frontend; // this is used only during the dump
bool __backend; // this is used only during the dump
bool __active;
} pgsql_account_details_t;
typedef std::map<uint64_t, pgsql_account_details_t*> umap_pgauth;
#endif // PGSQL_ACCOUNT_DETAILS_T
#ifdef DEBUG
#define DEB "_DEBUG"
#else
#define DEB ""
#endif /* DEBUG */
#define PGSQL_AUTHENTICATION_VERSION "0.1.0001" DEB
class PtrArray;
#ifndef CREDS_GROUPS_T
#define CREDS_GROUPS_T
typedef struct _creds_group_t {
#ifdef PROXYSQL_AUTH_PTHREAD_MUTEX
pthread_rwlock_t lock;
#else
rwlock_t lock;
#endif
umap_pgauth bt_map;
PtrArray *cred_array;
} creds_group_t;
#endif // CREDS_GROUPS_T
class PgSQL_Authentication {
private:
/**
* @brief Holds the current value for 'runtime_pgsql_users' used by 'ProxySQL_Admin' to reply to
* 'CLUSTER_QUERY_PGSQL_USERS'.
*/
std::unique_ptr<SQLite3_result> pgsql_users_resultset { nullptr };
creds_group_t creds_backends;
creds_group_t creds_frontends;
bool _reset(enum cred_username_type usertype);
uint64_t _get_runtime_checksum(enum cred_username_type usertype);
public:
PgSQL_Authentication();
~PgSQL_Authentication();
bool add(char *username, char *password, enum cred_username_type usertype, bool use_ssl, int default_hostgroup, bool transaction_persistent, bool fast_forward, int max_connections, char* attributes, char *comment);
bool del(char *username, enum cred_username_type usertype, bool set_lock=true);
bool reset();
void print_version();
bool exists(char *username);
char * lookup(char *username, enum cred_username_type usertype, bool *use_ssl, int *default_hostgroup, bool *transaction_persistent, bool *fast_forward, int *max_connections, void **sha1_pass, char **attributes);
int dump_all_users(pgsql_account_details_t***, bool _complete=true);
int increase_frontend_user_connections(char *username, int *mc=NULL);
void decrease_frontend_user_connections(char *username);
void set_all_inactive(enum cred_username_type usertype);
void remove_inactives(enum cred_username_type usertype);
bool set_SHA1(char *username, enum cred_username_type usertype, void *sha_pass);
unsigned int memory_usage();
uint64_t get_runtime_checksum();
/**
* @brief Computes the checksum for the 'pgsql_users' table contained in the supplied resultset.
* It's UNSAFE to call this function with another resultset than the specified in @param doc.
* @param resultset Assumed to be the result of hte following query against the Admin interface:
* - '"SELECT username, password, active, use_ssl, default_hostgroup,
* transaction_persistent, fast_forward, backend, frontend, max_connections,
* attributes, comment FROM runtime_pgsql_users"'
* The order isn't relevant in the query itself because ordering is performed while processing.
* @param pgsql_users A 'unique_ptr' to be filled with the 'frontend' and 'backend' users found in the
* provided resulset.
* @return The computed hash for the provided resultset.
*/
uint64_t get_runtime_checksum(MYSQL_RES* resultset, unique_ptr<SQLite3_result>& pgsql_users);
/**
* @brief Takes ownership of the supplied resultset and stores it in 'pgsql_users_resultset' field.
* @param users Holds the current value for 'runtime_pgsql_users'.
*/
void save_pgsql_users(std::unique_ptr<SQLite3_result>&& users);
/**
* @brief Return a pointer to internally managed 'pgsql_users_resultset' field. DO NOT FREE.
* @return A pointer to the internally managed 'pgsql_users_resultset'.
*/
SQLite3_result* get_current_pgsql_users();
};
#endif /* __CLASS_PGSQL_AUTHENTICATION_H */