mysql5/mysql-5.7.27/sql/auth/auth_common.h

792 lines
30 KiB
C++

#ifndef AUTH_COMMON_INCLUDED
#define AUTH_COMMON_INCLUDED
/* Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; version 2 of the License.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software Foundation,
51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA */
#include "my_global.h" /* NO_EMBEDDED_ACCESS_CHECKS */
#include "auth_acls.h" /* ACL information */
#include "sql_string.h" /* String */
#include "table.h" /* TABLE_LIST */
#include "field.h"
#include <set>
/* Forward Declarations */
class LEX_COLUMN;
class THD;
struct GRANT_INFO;
struct LEX;
typedef struct user_conn USER_CONN;
/* Classes */
enum ACL_internal_access_result
{
/**
Access granted for all the requested privileges,
do not use the grant tables.
This flag is used only for the INFORMATION_SCHEMA privileges,
for compatibility reasons.
*/
ACL_INTERNAL_ACCESS_GRANTED,
/** Access denied, do not use the grant tables. */
ACL_INTERNAL_ACCESS_DENIED,
/** No decision yet, use the grant tables. */
ACL_INTERNAL_ACCESS_CHECK_GRANT
};
/**
Per internal table ACL access rules.
This class is an interface.
Per table(s) specific access rule should be implemented in a subclass.
@sa ACL_internal_schema_access
*/
class ACL_internal_table_access
{
public:
ACL_internal_table_access()
{}
virtual ~ACL_internal_table_access()
{}
/**
Check access to an internal table.
When a privilege is granted, this method add the requested privilege
to save_priv.
@param want_access the privileges requested
@param [in, out] save_priv the privileges granted
@return
@retval ACL_INTERNAL_ACCESS_GRANTED All the requested privileges
are granted, and saved in save_priv.
@retval ACL_INTERNAL_ACCESS_DENIED At least one of the requested
privileges was denied.
@retval ACL_INTERNAL_ACCESS_CHECK_GRANT No requested privilege
was denied, and grant should be checked for at least one
privilege. Requested privileges that are granted, if any, are saved
in save_priv.
*/
virtual ACL_internal_access_result check(ulong want_access,
ulong *save_priv) const= 0;
};
/**
Per internal schema ACL access rules.
This class is an interface.
Each per schema specific access rule should be implemented
in a different subclass, and registered.
Per schema access rules can control:
- every schema privileges on schema.*
- every table privileges on schema.table
@sa ACL_internal_schema_registry
*/
class ACL_internal_schema_access
{
public:
ACL_internal_schema_access()
{}
virtual ~ACL_internal_schema_access()
{}
/**
Check access to an internal schema.
@param want_access the privileges requested
@param [in, out] save_priv the privileges granted
@return
@retval ACL_INTERNAL_ACCESS_GRANTED All the requested privileges
are granted, and saved in save_priv.
@retval ACL_INTERNAL_ACCESS_DENIED At least one of the requested
privileges was denied.
@retval ACL_INTERNAL_ACCESS_CHECK_GRANT No requested privilege
was denied, and grant should be checked for at least one
privilege. Requested privileges that are granted, if any, are saved
in save_priv.
*/
virtual ACL_internal_access_result check(ulong want_access,
ulong *save_priv) const= 0;
/**
Search for per table ACL access rules by table name.
@param name the table name
@return per table access rules, or NULL
*/
virtual const ACL_internal_table_access *lookup(const char *name) const= 0;
};
/**
A registry for per internal schema ACL.
An 'internal schema' is a database schema maintained by the
server implementation, such as 'performance_schema' and 'INFORMATION_SCHEMA'.
*/
class ACL_internal_schema_registry
{
public:
static void register_schema(const LEX_STRING &name,
const ACL_internal_schema_access *access);
static const ACL_internal_schema_access *lookup(const char *name);
};
/**
Extension of ACL_internal_schema_access for Information Schema
*/
class IS_internal_schema_access : public ACL_internal_schema_access
{
public:
IS_internal_schema_access()
{}
~IS_internal_schema_access()
{}
ACL_internal_access_result check(ulong want_access,
ulong *save_priv) const;
const ACL_internal_table_access *lookup(const char *name) const;
};
/* Data Structures */
extern const char *command_array[];
extern uint command_lengths[];
enum mysql_db_table_field
{
MYSQL_DB_FIELD_HOST = 0,
MYSQL_DB_FIELD_DB,
MYSQL_DB_FIELD_USER,
MYSQL_DB_FIELD_SELECT_PRIV,
MYSQL_DB_FIELD_INSERT_PRIV,
MYSQL_DB_FIELD_UPDATE_PRIV,
MYSQL_DB_FIELD_DELETE_PRIV,
MYSQL_DB_FIELD_CREATE_PRIV,
MYSQL_DB_FIELD_DROP_PRIV,
MYSQL_DB_FIELD_GRANT_PRIV,
MYSQL_DB_FIELD_REFERENCES_PRIV,
MYSQL_DB_FIELD_INDEX_PRIV,
MYSQL_DB_FIELD_ALTER_PRIV,
MYSQL_DB_FIELD_CREATE_TMP_TABLE_PRIV,
MYSQL_DB_FIELD_LOCK_TABLES_PRIV,
MYSQL_DB_FIELD_CREATE_VIEW_PRIV,
MYSQL_DB_FIELD_SHOW_VIEW_PRIV,
MYSQL_DB_FIELD_CREATE_ROUTINE_PRIV,
MYSQL_DB_FIELD_ALTER_ROUTINE_PRIV,
MYSQL_DB_FIELD_EXECUTE_PRIV,
MYSQL_DB_FIELD_EVENT_PRIV,
MYSQL_DB_FIELD_TRIGGER_PRIV,
MYSQL_DB_FIELD_COUNT
};
enum mysql_user_table_field
{
MYSQL_USER_FIELD_HOST= 0,
MYSQL_USER_FIELD_USER,
MYSQL_USER_FIELD_SELECT_PRIV,
MYSQL_USER_FIELD_INSERT_PRIV,
MYSQL_USER_FIELD_UPDATE_PRIV,
MYSQL_USER_FIELD_DELETE_PRIV,
MYSQL_USER_FIELD_CREATE_PRIV,
MYSQL_USER_FIELD_DROP_PRIV,
MYSQL_USER_FIELD_RELOAD_PRIV,
MYSQL_USER_FIELD_SHUTDOWN_PRIV,
MYSQL_USER_FIELD_PROCESS_PRIV,
MYSQL_USER_FIELD_FILE_PRIV,
MYSQL_USER_FIELD_GRANT_PRIV,
MYSQL_USER_FIELD_REFERENCES_PRIV,
MYSQL_USER_FIELD_INDEX_PRIV,
MYSQL_USER_FIELD_ALTER_PRIV,
MYSQL_USER_FIELD_SHOW_DB_PRIV,
MYSQL_USER_FIELD_SUPER_PRIV,
MYSQL_USER_FIELD_CREATE_TMP_TABLE_PRIV,
MYSQL_USER_FIELD_LOCK_TABLES_PRIV,
MYSQL_USER_FIELD_EXECUTE_PRIV,
MYSQL_USER_FIELD_REPL_SLAVE_PRIV,
MYSQL_USER_FIELD_REPL_CLIENT_PRIV,
MYSQL_USER_FIELD_CREATE_VIEW_PRIV,
MYSQL_USER_FIELD_SHOW_VIEW_PRIV,
MYSQL_USER_FIELD_CREATE_ROUTINE_PRIV,
MYSQL_USER_FIELD_ALTER_ROUTINE_PRIV,
MYSQL_USER_FIELD_CREATE_USER_PRIV,
MYSQL_USER_FIELD_EVENT_PRIV,
MYSQL_USER_FIELD_TRIGGER_PRIV,
MYSQL_USER_FIELD_CREATE_TABLESPACE_PRIV,
MYSQL_USER_FIELD_SSL_TYPE,
MYSQL_USER_FIELD_SSL_CIPHER,
MYSQL_USER_FIELD_X509_ISSUER,
MYSQL_USER_FIELD_X509_SUBJECT,
MYSQL_USER_FIELD_MAX_QUESTIONS,
MYSQL_USER_FIELD_MAX_UPDATES,
MYSQL_USER_FIELD_MAX_CONNECTIONS,
MYSQL_USER_FIELD_MAX_USER_CONNECTIONS,
MYSQL_USER_FIELD_PLUGIN,
MYSQL_USER_FIELD_AUTHENTICATION_STRING,
MYSQL_USER_FIELD_PASSWORD_EXPIRED,
MYSQL_USER_FIELD_PASSWORD_LAST_CHANGED,
MYSQL_USER_FIELD_PASSWORD_LIFETIME,
MYSQL_USER_FIELD_ACCOUNT_LOCKED,
MYSQL_USER_FIELD_COUNT
};
enum mysql_proxies_priv_table_feild
{
MYSQL_PROXIES_PRIV_FIELD_HOST = 0,
MYSQL_PROXIES_PRIV_FIELD_USER,
MYSQL_PROXIES_PRIV_FIELD_PROXIED_HOST,
MYSQL_PROXIES_PRIV_FIELD_PROXIED_USER,
MYSQL_PROXIES_PRIV_FIELD_WITH_GRANT,
MYSQL_PROXIES_PRIV_FIELD_GRANTOR,
MYSQL_PROXIES_PRIV_FIELD_TIMESTAMP,
MYSQL_PROXIES_PRIV_FIELD_COUNT
};
enum mysql_procs_priv_table_field
{
MYSQL_PROCS_PRIV_FIELD_HOST = 0,
MYSQL_PROCS_PRIV_FIELD_DB,
MYSQL_PROCS_PRIV_FIELD_USER,
MYSQL_PROCS_PRIV_FIELD_ROUTINE_NAME,
MYSQL_PROCS_PRIV_FIELD_ROUTINE_TYPE,
MYSQL_PROCS_PRIV_FIELD_GRANTOR,
MYSQL_PROCS_PRIV_FIELD_PROC_PRIV,
MYSQL_PROCS_PRIV_FIELD_TIMESTAMP,
MYSQL_PROCS_PRIV_FIELD_COUNT
};
enum mysql_columns_priv_table_field
{
MYSQL_COLUMNS_PRIV_FIELD_HOST = 0,
MYSQL_COLUMNS_PRIV_FIELD_DB,
MYSQL_COLUMNS_PRIV_FIELD_USER,
MYSQL_COLUMNS_PRIV_FIELD_TABLE_NAME,
MYSQL_COLUMNS_PRIV_FIELD_COLUMN_NAME,
MYSQL_COLUMNS_PRIV_FIELD_TIMESTAMP,
MYSQL_COLUMNS_PRIV_FIELD_COLUMN_PRIV,
MYSQL_COLUMNS_PRIV_FIELD_COUNT
};
enum mysql_tables_priv_table_field
{
MYSQL_TABLES_PRIV_FIELD_HOST = 0,
MYSQL_TABLES_PRIV_FIELD_DB,
MYSQL_TABLES_PRIV_FIELD_USER,
MYSQL_TABLES_PRIV_FIELD_TABLE_NAME,
MYSQL_TABLES_PRIV_FIELD_GRANTOR,
MYSQL_TABLES_PRIV_FIELD_TIMESTAMP,
MYSQL_TABLES_PRIV_FIELD_TABLE_PRIV,
MYSQL_TABLES_PRIV_FIELD_COLUMN_PRIV,
MYSQL_TABLES_PRIV_FIELD_COUNT
};
/* When we run mysql_upgrade we must make sure that the server can be run
using previous mysql.user table schema during acl_load.
Acl_load_user_table_schema is a common interface for the current and the
previous mysql.user table schema.
*/
class Acl_load_user_table_schema
{
public:
virtual uint host_idx()= 0;
virtual uint user_idx()= 0;
virtual uint password_idx()= 0;
virtual uint select_priv_idx()= 0;
virtual uint insert_priv_idx()= 0;
virtual uint update_priv_idx()= 0;
virtual uint delete_priv_idx()= 0;
virtual uint create_priv_idx()= 0;
virtual uint drop_priv_idx()= 0;
virtual uint reload_priv_idx()= 0;
virtual uint shutdown_priv_idx()= 0;
virtual uint process_priv_idx()= 0;
virtual uint file_priv_idx()= 0;
virtual uint grant_priv_idx()= 0;
virtual uint references_priv_idx()= 0;
virtual uint index_priv_idx()= 0;
virtual uint alter_priv_idx()= 0;
virtual uint show_db_priv_idx()= 0;
virtual uint super_priv_idx()= 0;
virtual uint create_tmp_table_priv_idx()= 0;
virtual uint lock_tables_priv_idx()= 0;
virtual uint execute_priv_idx()= 0;
virtual uint repl_slave_priv_idx()= 0;
virtual uint repl_client_priv_idx()= 0;
virtual uint create_view_priv_idx()= 0;
virtual uint show_view_priv_idx()= 0;
virtual uint create_routine_priv_idx()= 0;
virtual uint alter_routine_priv_idx()= 0;
virtual uint create_user_priv_idx()= 0;
virtual uint event_priv_idx()= 0;
virtual uint trigger_priv_idx()= 0;
virtual uint create_tablespace_priv_idx()= 0;
virtual uint ssl_type_idx()= 0;
virtual uint ssl_cipher_idx()= 0;
virtual uint x509_issuer_idx()= 0;
virtual uint x509_subject_idx()= 0;
virtual uint max_questions_idx()= 0;
virtual uint max_updates_idx()= 0;
virtual uint max_connections_idx()= 0;
virtual uint max_user_connections_idx()= 0;
virtual uint plugin_idx()= 0;
virtual uint authentication_string_idx()= 0;
virtual uint password_expired_idx()= 0;
virtual uint password_last_changed_idx()= 0;
virtual uint password_lifetime_idx()= 0;
virtual uint account_locked_idx()= 0;
virtual ~Acl_load_user_table_schema() {}
};
/*
This class describes indices for the current mysql.user table schema.
*/
class Acl_load_user_table_current_schema : public Acl_load_user_table_schema
{
public:
uint host_idx() { return MYSQL_USER_FIELD_HOST; }
uint user_idx() { return MYSQL_USER_FIELD_USER; }
//not available
uint password_idx() { DBUG_ASSERT(0); return MYSQL_USER_FIELD_COUNT; }
uint select_priv_idx() { return MYSQL_USER_FIELD_SELECT_PRIV; }
uint insert_priv_idx() { return MYSQL_USER_FIELD_INSERT_PRIV; }
uint update_priv_idx() { return MYSQL_USER_FIELD_UPDATE_PRIV; }
uint delete_priv_idx() { return MYSQL_USER_FIELD_DELETE_PRIV; }
uint create_priv_idx() { return MYSQL_USER_FIELD_CREATE_PRIV; }
uint drop_priv_idx() { return MYSQL_USER_FIELD_DROP_PRIV; }
uint reload_priv_idx() { return MYSQL_USER_FIELD_RELOAD_PRIV; }
uint shutdown_priv_idx() { return MYSQL_USER_FIELD_SHUTDOWN_PRIV; }
uint process_priv_idx() { return MYSQL_USER_FIELD_PROCESS_PRIV; }
uint file_priv_idx() { return MYSQL_USER_FIELD_FILE_PRIV; }
uint grant_priv_idx() { return MYSQL_USER_FIELD_GRANT_PRIV; }
uint references_priv_idx() { return MYSQL_USER_FIELD_REFERENCES_PRIV; }
uint index_priv_idx() { return MYSQL_USER_FIELD_INDEX_PRIV; }
uint alter_priv_idx() { return MYSQL_USER_FIELD_ALTER_PRIV; }
uint show_db_priv_idx() { return MYSQL_USER_FIELD_SHOW_DB_PRIV; }
uint super_priv_idx() { return MYSQL_USER_FIELD_SUPER_PRIV; }
uint create_tmp_table_priv_idx()
{
return MYSQL_USER_FIELD_CREATE_TMP_TABLE_PRIV;
}
uint lock_tables_priv_idx() { return MYSQL_USER_FIELD_LOCK_TABLES_PRIV; }
uint execute_priv_idx() { return MYSQL_USER_FIELD_EXECUTE_PRIV; }
uint repl_slave_priv_idx() { return MYSQL_USER_FIELD_REPL_SLAVE_PRIV; }
uint repl_client_priv_idx() { return MYSQL_USER_FIELD_REPL_CLIENT_PRIV; }
uint create_view_priv_idx() { return MYSQL_USER_FIELD_CREATE_VIEW_PRIV; }
uint show_view_priv_idx() { return MYSQL_USER_FIELD_SHOW_VIEW_PRIV; }
uint create_routine_priv_idx()
{
return MYSQL_USER_FIELD_CREATE_ROUTINE_PRIV;
}
uint alter_routine_priv_idx() { return MYSQL_USER_FIELD_ALTER_ROUTINE_PRIV; }
uint create_user_priv_idx() { return MYSQL_USER_FIELD_CREATE_USER_PRIV; }
uint event_priv_idx() { return MYSQL_USER_FIELD_EVENT_PRIV; }
uint trigger_priv_idx() { return MYSQL_USER_FIELD_TRIGGER_PRIV; }
uint create_tablespace_priv_idx()
{
return MYSQL_USER_FIELD_CREATE_TABLESPACE_PRIV;
}
uint ssl_type_idx() { return MYSQL_USER_FIELD_SSL_TYPE; }
uint ssl_cipher_idx() { return MYSQL_USER_FIELD_SSL_CIPHER; }
uint x509_issuer_idx() { return MYSQL_USER_FIELD_X509_ISSUER; }
uint x509_subject_idx() { return MYSQL_USER_FIELD_X509_SUBJECT; }
uint max_questions_idx() { return MYSQL_USER_FIELD_MAX_QUESTIONS; }
uint max_updates_idx() { return MYSQL_USER_FIELD_MAX_UPDATES; }
uint max_connections_idx() { return MYSQL_USER_FIELD_MAX_CONNECTIONS; }
uint max_user_connections_idx()
{
return MYSQL_USER_FIELD_MAX_USER_CONNECTIONS;
}
uint plugin_idx() { return MYSQL_USER_FIELD_PLUGIN; }
uint authentication_string_idx()
{
return MYSQL_USER_FIELD_AUTHENTICATION_STRING;
}
uint password_expired_idx() { return MYSQL_USER_FIELD_PASSWORD_EXPIRED; }
uint password_last_changed_idx()
{
return MYSQL_USER_FIELD_PASSWORD_LAST_CHANGED;
}
uint password_lifetime_idx() { return MYSQL_USER_FIELD_PASSWORD_LIFETIME; }
uint account_locked_idx() { return MYSQL_USER_FIELD_ACCOUNT_LOCKED; }
};
/*
This class describes indices for the old mysql.user table schema.
*/
class Acl_load_user_table_old_schema : public Acl_load_user_table_schema
{
public:
enum mysql_user_table_field_56
{
MYSQL_USER_FIELD_HOST_56= 0,
MYSQL_USER_FIELD_USER_56,
MYSQL_USER_FIELD_PASSWORD_56,
MYSQL_USER_FIELD_SELECT_PRIV_56,
MYSQL_USER_FIELD_INSERT_PRIV_56,
MYSQL_USER_FIELD_UPDATE_PRIV_56,
MYSQL_USER_FIELD_DELETE_PRIV_56,
MYSQL_USER_FIELD_CREATE_PRIV_56,
MYSQL_USER_FIELD_DROP_PRIV_56,
MYSQL_USER_FIELD_RELOAD_PRIV_56,
MYSQL_USER_FIELD_SHUTDOWN_PRIV_56,
MYSQL_USER_FIELD_PROCESS_PRIV_56,
MYSQL_USER_FIELD_FILE_PRIV_56,
MYSQL_USER_FIELD_GRANT_PRIV_56,
MYSQL_USER_FIELD_REFERENCES_PRIV_56,
MYSQL_USER_FIELD_INDEX_PRIV_56,
MYSQL_USER_FIELD_ALTER_PRIV_56,
MYSQL_USER_FIELD_SHOW_DB_PRIV_56,
MYSQL_USER_FIELD_SUPER_PRIV_56,
MYSQL_USER_FIELD_CREATE_TMP_TABLE_PRIV_56,
MYSQL_USER_FIELD_LOCK_TABLES_PRIV_56,
MYSQL_USER_FIELD_EXECUTE_PRIV_56,
MYSQL_USER_FIELD_REPL_SLAVE_PRIV_56,
MYSQL_USER_FIELD_REPL_CLIENT_PRIV_56,
MYSQL_USER_FIELD_CREATE_VIEW_PRIV_56,
MYSQL_USER_FIELD_SHOW_VIEW_PRIV_56,
MYSQL_USER_FIELD_CREATE_ROUTINE_PRIV_56,
MYSQL_USER_FIELD_ALTER_ROUTINE_PRIV_56,
MYSQL_USER_FIELD_CREATE_USER_PRIV_56,
MYSQL_USER_FIELD_EVENT_PRIV_56,
MYSQL_USER_FIELD_TRIGGER_PRIV_56,
MYSQL_USER_FIELD_CREATE_TABLESPACE_PRIV_56,
MYSQL_USER_FIELD_SSL_TYPE_56,
MYSQL_USER_FIELD_SSL_CIPHER_56,
MYSQL_USER_FIELD_X509_ISSUER_56,
MYSQL_USER_FIELD_X509_SUBJECT_56,
MYSQL_USER_FIELD_MAX_QUESTIONS_56,
MYSQL_USER_FIELD_MAX_UPDATES_56,
MYSQL_USER_FIELD_MAX_CONNECTIONS_56,
MYSQL_USER_FIELD_MAX_USER_CONNECTIONS_56,
MYSQL_USER_FIELD_PLUGIN_56,
MYSQL_USER_FIELD_AUTHENTICATION_STRING_56,
MYSQL_USER_FIELD_PASSWORD_EXPIRED_56,
MYSQL_USER_FIELD_COUNT_56
};
uint host_idx() { return MYSQL_USER_FIELD_HOST_56; }
uint user_idx() { return MYSQL_USER_FIELD_USER_56; }
uint password_idx() { return MYSQL_USER_FIELD_PASSWORD_56; }
uint select_priv_idx() { return MYSQL_USER_FIELD_SELECT_PRIV_56; }
uint insert_priv_idx() { return MYSQL_USER_FIELD_INSERT_PRIV_56; }
uint update_priv_idx() { return MYSQL_USER_FIELD_UPDATE_PRIV_56; }
uint delete_priv_idx() { return MYSQL_USER_FIELD_DELETE_PRIV_56; }
uint create_priv_idx() { return MYSQL_USER_FIELD_CREATE_PRIV_56; }
uint drop_priv_idx() { return MYSQL_USER_FIELD_DROP_PRIV_56; }
uint reload_priv_idx() { return MYSQL_USER_FIELD_RELOAD_PRIV_56; }
uint shutdown_priv_idx() { return MYSQL_USER_FIELD_SHUTDOWN_PRIV_56; }
uint process_priv_idx() { return MYSQL_USER_FIELD_PROCESS_PRIV_56; }
uint file_priv_idx() { return MYSQL_USER_FIELD_FILE_PRIV_56; }
uint grant_priv_idx() { return MYSQL_USER_FIELD_GRANT_PRIV_56; }
uint references_priv_idx() { return MYSQL_USER_FIELD_REFERENCES_PRIV_56; }
uint index_priv_idx() { return MYSQL_USER_FIELD_INDEX_PRIV_56; }
uint alter_priv_idx() { return MYSQL_USER_FIELD_ALTER_PRIV_56; }
uint show_db_priv_idx() { return MYSQL_USER_FIELD_SHOW_DB_PRIV_56; }
uint super_priv_idx() { return MYSQL_USER_FIELD_SUPER_PRIV_56; }
uint create_tmp_table_priv_idx()
{
return MYSQL_USER_FIELD_CREATE_TMP_TABLE_PRIV_56;
}
uint lock_tables_priv_idx() { return MYSQL_USER_FIELD_LOCK_TABLES_PRIV_56; }
uint execute_priv_idx() { return MYSQL_USER_FIELD_EXECUTE_PRIV_56; }
uint repl_slave_priv_idx() { return MYSQL_USER_FIELD_REPL_SLAVE_PRIV_56; }
uint repl_client_priv_idx() { return MYSQL_USER_FIELD_REPL_CLIENT_PRIV_56; }
uint create_view_priv_idx() { return MYSQL_USER_FIELD_CREATE_VIEW_PRIV_56; }
uint show_view_priv_idx() { return MYSQL_USER_FIELD_SHOW_VIEW_PRIV_56; }
uint create_routine_priv_idx()
{
return MYSQL_USER_FIELD_CREATE_ROUTINE_PRIV_56;
}
uint alter_routine_priv_idx()
{
return MYSQL_USER_FIELD_ALTER_ROUTINE_PRIV_56;
}
uint create_user_priv_idx() { return MYSQL_USER_FIELD_CREATE_USER_PRIV_56; }
uint event_priv_idx() { return MYSQL_USER_FIELD_EVENT_PRIV_56; }
uint trigger_priv_idx() { return MYSQL_USER_FIELD_TRIGGER_PRIV_56; }
uint create_tablespace_priv_idx()
{
return MYSQL_USER_FIELD_CREATE_TABLESPACE_PRIV_56;
}
uint ssl_type_idx() { return MYSQL_USER_FIELD_SSL_TYPE_56; }
uint ssl_cipher_idx() { return MYSQL_USER_FIELD_SSL_CIPHER_56; }
uint x509_issuer_idx() { return MYSQL_USER_FIELD_X509_ISSUER_56; }
uint x509_subject_idx() { return MYSQL_USER_FIELD_X509_SUBJECT_56; }
uint max_questions_idx() { return MYSQL_USER_FIELD_MAX_QUESTIONS_56; }
uint max_updates_idx() { return MYSQL_USER_FIELD_MAX_UPDATES_56; }
uint max_connections_idx() { return MYSQL_USER_FIELD_MAX_CONNECTIONS_56; }
uint max_user_connections_idx()
{
return MYSQL_USER_FIELD_MAX_USER_CONNECTIONS_56;
}
uint plugin_idx() { return MYSQL_USER_FIELD_PLUGIN_56; }
uint authentication_string_idx()
{
return MYSQL_USER_FIELD_AUTHENTICATION_STRING_56;
}
uint password_expired_idx() { return MYSQL_USER_FIELD_PASSWORD_EXPIRED_56; }
//those fields are not available in 5.6 db schema
uint password_last_changed_idx() { return MYSQL_USER_FIELD_COUNT_56; }
uint password_lifetime_idx() { return MYSQL_USER_FIELD_COUNT_56; }
uint account_locked_idx() { return MYSQL_USER_FIELD_COUNT_56; }
};
class Acl_load_user_table_schema_factory
{
public:
virtual Acl_load_user_table_schema* get_user_table_schema(TABLE *table)
{
return is_old_user_table_schema(table) ?
(Acl_load_user_table_schema*) new Acl_load_user_table_old_schema():
(Acl_load_user_table_schema*) new Acl_load_user_table_current_schema();
}
virtual bool is_old_user_table_schema(TABLE* table)
{
Field *password_field=
table->field[Acl_load_user_table_old_schema::MYSQL_USER_FIELD_PASSWORD_56];
return strncmp(password_field->field_name, "Password", 8) == 0;
}
virtual bool user_table_schema_check(TABLE* table)
{
return table->s->fields >
Acl_load_user_table_old_schema::MYSQL_USER_FIELD_PASSWORD_56;
}
virtual ~Acl_load_user_table_schema_factory() {}
};
extern const TABLE_FIELD_DEF mysql_db_table_def;
extern bool mysql_user_table_is_in_short_password_format;
extern my_bool disconnect_on_expired_password;
extern const char *any_db; // Special symbol for check_access
/** controls the extra checks on plugin availability for mysql.user records */
#ifndef NO_EMBEDDED_ACCESS_CHECKS
extern my_bool validate_user_plugins;
#endif /* NO_EMBEDDED_ACCESS_CHECKS */
/* Function Declarations */
/* sql_authentication */
int set_default_auth_plugin(char *plugin_name, size_t plugin_name_length);
void acl_log_connect(const char *user, const char *host, const char *auth_as,
const char *db, THD *thd,
enum enum_server_command command);
int acl_authenticate(THD *thd, enum_server_command command);
bool acl_check_host(const char *host, const char *ip);
/*
User Attributes are the once which are defined during CREATE/ALTER/GRANT
statement. These attributes are divided into following catagories.
*/
#define NONE_ATTR 0L
#define DEFAULT_AUTH_ATTR (1L << 0) /* update defaults auth */
#define PLUGIN_ATTR (1L << 1) /* update plugin */
/* authentication_string */
#define SSL_ATTR (1L << 2) /* ex: SUBJECT,CIPHER.. */
#define RESOURCE_ATTR (1L << 3) /* ex: MAX_QUERIES_PER_HOUR.. */
#define PASSWORD_EXPIRE_ATTR (1L << 4) /* update password expire col */
#define ACCESS_RIGHTS_ATTR (1L << 5) /* update privileges */
#define ACCOUNT_LOCK_ATTR (1L << 6) /* update account lock status */
/* rewrite CREATE/ALTER/GRANT user */
void mysql_rewrite_create_alter_user(THD *thd, String *rlb,
std::set<LEX_USER *> *extra_users= NULL,
bool hide_password_hash= false);
void mysql_rewrite_grant(THD *thd, String *rlb);
/* sql_user */
void append_user(THD *thd, String *str, LEX_USER *user,
bool comma, bool ident);
void append_user_new(THD *thd, String *str, LEX_USER *user, bool comma= true,
bool hide_password_hash= false);
int check_change_password(THD *thd, const char *host, const char *user,
const char *password, size_t password_len);
bool change_password(THD *thd, const char *host, const char *user,
char *password);
bool mysql_create_user(THD *thd, List <LEX_USER> &list, bool if_not_exists);
bool mysql_alter_user(THD *thd, List <LEX_USER> &list, bool if_exists);
bool mysql_drop_user(THD *thd, List <LEX_USER> &list, bool if_exists);
bool mysql_rename_user(THD *thd, List <LEX_USER> &list);
bool set_and_validate_user_attributes(THD *thd,
LEX_USER *Str,
ulong &what_to_set,
bool is_privileged_user,
const char * cmd);
/* sql_auth_cache */
int wild_case_compare(CHARSET_INFO *cs, const char *str,const char *wildstr);
bool hostname_requires_resolving(const char *hostname);
my_bool acl_init(bool dont_read_acl_tables);
void acl_free(bool end=0);
my_bool acl_reload(THD *thd);
bool grant_init(bool skip_grant_tables);
void grant_free(void);
my_bool grant_reload(THD *thd);
ulong acl_get(const char *host, const char *ip,
const char *user, const char *db, my_bool db_is_pattern);
bool is_acl_user(const char *host, const char *user);
bool acl_getroot(Security_context *sctx, char *user,
char *host, char *ip, const char *db);
/* sql_authorization */
bool mysql_grant(THD *thd, const char *db, List <LEX_USER> &user_list,
ulong rights, bool revoke, bool is_proxy);
bool mysql_routine_grant(THD *thd, TABLE_LIST *table, bool is_proc,
List <LEX_USER> &user_list, ulong rights,
bool revoke, bool write_to_binlog);
int mysql_table_grant(THD *thd, TABLE_LIST *table, List <LEX_USER> &user_list,
List <LEX_COLUMN> &column_list, ulong rights,
bool revoke);
bool check_grant(THD *thd, ulong want_access, TABLE_LIST *tables,
bool any_combination_will_do, uint number, bool no_errors);
bool check_grant_column (THD *thd, GRANT_INFO *grant,
const char *db_name, const char *table_name,
const char *name, size_t length,
Security_context *sctx, ulong want_privilege);
bool check_column_grant_in_table_ref(THD *thd, TABLE_LIST * table_ref,
const char *name, size_t length,
ulong want_privilege);
bool check_grant_all_columns(THD *thd, ulong want_access,
Field_iterator_table_ref *fields);
bool check_grant_routine(THD *thd, ulong want_access,
TABLE_LIST *procs, bool is_proc, bool no_error);
bool check_routine_level_acl(THD *thd, const char *db, const char *name,
bool is_proc);
bool check_grant_db(THD *thd,const char *db);
bool acl_check_proxy_grant_access(THD *thd, const char *host, const char *user,
bool with_grant);
void get_privilege_desc(char *to, uint max_length, ulong access);
void get_mqh(const char *user, const char *host, USER_CONN *uc);
ulong get_table_grant(THD *thd, TABLE_LIST *table);
ulong get_column_grant(THD *thd, GRANT_INFO *grant,
const char *db_name, const char *table_name,
const char *field_name);
bool mysql_show_grants(THD *thd, LEX_USER *user);
bool mysql_show_create_user(THD *thd, LEX_USER *user, bool are_both_users_same);
bool mysql_revoke_all(THD *thd, List <LEX_USER> &list);
bool sp_revoke_privileges(THD *thd, const char *sp_db, const char *sp_name,
bool is_proc);
bool sp_grant_privileges(THD *thd, const char *sp_db, const char *sp_name,
bool is_proc);
void fill_effective_table_privileges(THD *thd, GRANT_INFO *grant,
const char *db, const char *table);
int fill_schema_user_privileges(THD *thd, TABLE_LIST *tables, Item *cond);
int fill_schema_schema_privileges(THD *thd, TABLE_LIST *tables, Item *cond);
int fill_schema_table_privileges(THD *thd, TABLE_LIST *tables, Item *cond);
int fill_schema_column_privileges(THD *thd, TABLE_LIST *tables, Item *cond);
const ACL_internal_schema_access *
get_cached_schema_access(GRANT_INTERNAL_INFO *grant_internal_info,
const char *schema_name);
bool select_precheck(THD *thd, LEX *lex, TABLE_LIST *tables,
TABLE_LIST *first_table);
bool multi_delete_precheck(THD *thd, TABLE_LIST *tables);
bool delete_precheck(THD *thd, TABLE_LIST *tables);
bool lock_tables_precheck(THD *thd, TABLE_LIST *tables);
bool create_table_precheck(THD *thd, TABLE_LIST *tables,
TABLE_LIST *create_table);
bool check_fk_parent_table_access(THD *thd,
const char *child_table_db,
HA_CREATE_INFO *create_info,
Alter_info *alter_info);
bool check_readonly(THD *thd, bool err_if_readonly);
void err_readonly(THD *thd);
bool is_secure_transport(int vio_type);
#ifndef NO_EMBEDDED_ACCESS_CHECKS
bool check_one_table_access(THD *thd, ulong privilege, TABLE_LIST *tables);
bool check_single_table_access(THD *thd, ulong privilege,
TABLE_LIST *tables, bool no_errors);
bool check_routine_access(THD *thd, ulong want_access, const char *db,
char *name, bool is_proc, bool no_errors);
bool check_some_access(THD *thd, ulong want_access, TABLE_LIST *table);
bool check_some_routine_access(THD *thd, const char *db, const char *name, bool is_proc);
bool check_access(THD *thd, ulong want_access, const char *db, ulong *save_priv,
GRANT_INTERNAL_INFO *grant_internal_info,
bool dont_check_global_grants, bool no_errors);
bool check_table_access(THD *thd, ulong requirements,TABLE_LIST *tables,
bool any_combination_of_privileges_will_do,
uint number,
bool no_errors);
#else
inline bool check_one_table_access(THD *thd, ulong privilege, TABLE_LIST *tables)
{ return false; }
inline bool check_single_table_access(THD *thd, ulong privilege,
TABLE_LIST *tables, bool no_errors)
{ return false; }
inline bool check_routine_access(THD *thd,ulong want_access,const char *db,
char *name, bool is_proc, bool no_errors)
{ return false; }
inline bool check_some_access(THD *thd, ulong want_access, TABLE_LIST *table)
{
table->grant.privilege= want_access;
return false;
}
inline bool check_some_routine_access(THD *thd, const char *db,
const char *name, bool is_proc)
{ return false; }
inline bool check_access(THD *, ulong, const char *, ulong *save_priv,
GRANT_INTERNAL_INFO *, bool, bool)
{
if (save_priv)
*save_priv= GLOBAL_ACLS;
return false;
}
inline bool
check_table_access(THD *thd, ulong requirements,TABLE_LIST *tables,
bool any_combination_of_privileges_will_do,
uint number,
bool no_errors)
{ return false; }
#endif /*NO_EMBEDDED_ACCESS_CHECKS*/
/* These was under the INNODB_COMPATIBILITY_HOOKS */
bool check_global_access(THD *thd, ulong want_access);
#ifdef NO_EMBEDDED_ACCESS_CHECKS
#define check_grant(A,B,C,D,E,F) 0
#define check_grant_db(A,B) 0
#endif
/* sql_user_table */
void close_acl_tables(THD *thd);
#ifndef EMBEDDED_LIBRARY
typedef enum ssl_artifacts_status
{
SSL_ARTIFACTS_NOT_FOUND= 0,
SSL_ARTIFACTS_VIA_OPTIONS,
SSL_ARTIFACT_TRACES_FOUND,
SSL_ARTIFACTS_AUTO_DETECTED
} ssl_artifacts_status;
#endif /* EMBEDDED_LIBRARY */
#if defined(HAVE_OPENSSL) && !defined(HAVE_YASSL)
extern my_bool opt_auto_generate_certs;
bool do_auto_cert_generation(ssl_artifacts_status auto_detection_status);
#endif /* HAVE_OPENSSL && !HAVE_YASSL */
#endif /* AUTH_COMMON_INCLUDED */