2023-04-28 08:09:26 +02:00
/* Copyright (c) 2010, 2023, Oracle and/or its affiliates.
2012-08-01 16:27:34 +02:00
This program is free software ; you can redistribute it and / or modify
2020-01-19 12:52:07 +01:00
it under the terms of the GNU General Public License , version 2.0 ,
as published by the Free Software Foundation .
This program is also distributed with certain software ( including
but not limited to OpenSSL ) that is licensed under separate terms ,
as designated in a particular file or component or in included license
documentation . The authors of MySQL hereby grant you an additional
permission to link the program and your derivative works with the
separately licensed software that they have included with MySQL .
2012-08-01 16:27:34 +02:00
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
2020-01-19 12:52:07 +01:00
GNU General Public License , version 2.0 , for more details .
2012-08-01 16:27:34 +02:00
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software Foundation ,
2019-05-11 18:25:02 +02:00
51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1335 USA */
2012-08-01 16:27:34 +02:00
/**
@ file storage / perfschema / table_setup_actors . cc
Table SETUP_ACTORS ( implementation ) .
*/
# include "my_global.h"
2019-12-10 15:35:00 +01:00
# include "my_thread.h"
2012-08-01 16:27:34 +02:00
# include "pfs_instr_class.h"
# include "pfs_column_types.h"
# include "pfs_column_values.h"
# include "pfs_setup_actor.h"
# include "table_setup_actors.h"
# include "pfs_global.h"
2019-12-10 15:35:00 +01:00
# include "pfs_buffer_container.h"
# include "field.h"
2012-08-01 16:27:34 +02:00
THR_LOCK table_setup_actors : : m_table_lock ;
2022-07-29 14:48:01 +02:00
PFS_engine_table_share_state
table_setup_actors : : m_share_state = {
false /* m_checked */
} ;
2012-08-01 16:27:34 +02:00
PFS_engine_table_share
table_setup_actors : : m_share =
{
{ C_STRING_WITH_LEN ( " setup_actors " ) } ,
& pfs_editable_acl ,
table_setup_actors : : create ,
table_setup_actors : : write_row ,
table_setup_actors : : delete_all_rows ,
table_setup_actors : : get_row_count ,
sizeof ( PFS_simple_index ) ,
& m_table_lock ,
2014-08-19 13:18:18 +02:00
{ C_STRING_WITH_LEN ( " CREATE TABLE setup_actors( "
2021-09-10 16:16:18 +02:00
" HOST CHAR( " HOSTNAME_LENGTH_STR " ) collate utf8_bin default '%' not null comment 'Host name, either a literal, or the % wildcard representing any host.', "
" USER CHAR( " USERNAME_CHAR_LENGTH_STR " ) collate utf8_bin default '%' not null comment 'User name, either a literal or the % wildcard representing any name.', "
" ROLE CHAR( " USERNAME_CHAR_LENGTH_STR " ) collate utf8_bin default '%' not null comment 'Unused', "
2021-09-10 09:50:58 +02:00
" ENABLED ENUM('YES', 'NO') not null default 'YES' comment 'Whether to enable instrumentation for foreground threads matched by the row.', "
" HISTORY ENUM('YES', 'NO') not null default 'YES' comment 'Whether to log historical events for foreground threads matched by the row.') " ) } ,
2022-07-29 14:48:01 +02:00
false , /* m_perpetual */
false , /* m_optional */
& m_share_state
2012-08-01 16:27:34 +02:00
} ;
PFS_engine_table * table_setup_actors : : create ( )
{
return new table_setup_actors ( ) ;
}
2019-07-04 20:31:35 +02:00
int table_setup_actors : : write_row ( TABLE * table , const unsigned char * buf ,
2012-08-01 16:27:34 +02:00
Field * * fields )
{
Field * f ;
2019-06-28 07:05:12 +02:00
String user_data ( " % " , 1 , & my_charset_utf8mb3_bin ) ;
String host_data ( " % " , 1 , & my_charset_utf8mb3_bin ) ;
String role_data ( " % " , 1 , & my_charset_utf8mb3_bin ) ;
2012-08-01 16:27:34 +02:00
String * user = & user_data ;
String * host = & host_data ;
String * role = & role_data ;
2019-12-10 15:35:00 +01:00
enum_yes_no enabled_value = ENUM_YES ;
enum_yes_no history_value = ENUM_YES ;
bool enabled ;
bool history ;
2012-08-01 16:27:34 +02:00
for ( ; ( f = * fields ) ; fields + + )
{
if ( bitmap_is_set ( table - > write_set , f - > field_index ) )
{
switch ( f - > field_index )
{
case 0 : /* HOST */
host = get_field_char_utf8 ( f , & host_data ) ;
break ;
case 1 : /* USER */
user = get_field_char_utf8 ( f , & user_data ) ;
break ;
case 2 : /* ROLE */
role = get_field_char_utf8 ( f , & role_data ) ;
break ;
2019-12-10 15:35:00 +01:00
case 3 : /* ENABLED */
enabled_value = ( enum_yes_no ) get_field_enum ( f ) ;
break ;
case 4 : /* HISTORY */
history_value = ( enum_yes_no ) get_field_enum ( f ) ;
break ;
2012-08-01 16:27:34 +02:00
default :
2021-05-03 11:21:56 +02:00
assert ( false ) ;
2012-08-01 16:27:34 +02:00
}
}
}
2019-12-10 15:35:00 +01:00
/* Reject illegal enum values in ENABLED */
if ( ( enabled_value ! = ENUM_YES ) & & ( enabled_value ! = ENUM_NO ) )
return HA_ERR_NO_REFERENCED_ROW ;
/* Reject illegal enum values in HISTORY */
if ( ( history_value ! = ENUM_YES ) & & ( history_value ! = ENUM_NO ) )
return HA_ERR_NO_REFERENCED_ROW ;
/* Reject if any of user/host/role is not provided */
2013-03-25 23:03:13 +01:00
if ( user - > length ( ) = = 0 | | host - > length ( ) = = 0 | | role - > length ( ) = = 0 )
return HA_ERR_WRONG_COMMAND ;
2019-12-10 15:35:00 +01:00
enabled = ( enabled_value = = ENUM_YES ) ? true : false ;
history = ( history_value = = ENUM_YES ) ? true : false ;
return insert_setup_actor ( user , host , role , enabled , history ) ;
2012-08-01 16:27:34 +02:00
}
int table_setup_actors : : delete_all_rows ( void )
{
return reset_setup_actor ( ) ;
}
ha_rows table_setup_actors : : get_row_count ( void )
{
2019-12-10 15:35:00 +01:00
return global_setup_actor_container . get_row_count ( ) ;
2012-08-01 16:27:34 +02:00
}
table_setup_actors : : table_setup_actors ( )
: PFS_engine_table ( & m_share , & m_pos ) ,
m_row_exists ( false ) , m_pos ( 0 ) , m_next_pos ( 0 )
{ }
void table_setup_actors : : reset_position ( void )
{
m_pos . m_index = 0 ;
m_next_pos . m_index = 0 ;
}
int table_setup_actors : : rnd_next ( )
{
PFS_setup_actor * pfs ;
2019-12-10 15:35:00 +01:00
m_pos . set_at ( & m_next_pos ) ;
PFS_setup_actor_iterator it = global_setup_actor_container . iterate ( m_pos . m_index ) ;
pfs = it . scan_next ( & m_pos . m_index ) ;
if ( pfs ! = NULL )
2012-08-01 16:27:34 +02:00
{
2019-12-10 15:35:00 +01:00
make_row ( pfs ) ;
m_next_pos . set_after ( & m_pos ) ;
return 0 ;
2012-08-01 16:27:34 +02:00
}
return HA_ERR_END_OF_FILE ;
}
int table_setup_actors : : rnd_pos ( const void * pos )
{
PFS_setup_actor * pfs ;
set_position ( pos ) ;
2019-12-10 15:35:00 +01:00
pfs = global_setup_actor_container . get ( m_pos . m_index ) ;
if ( pfs ! = NULL )
2012-08-01 16:27:34 +02:00
{
make_row ( pfs ) ;
return 0 ;
}
return HA_ERR_RECORD_DELETED ;
}
void table_setup_actors : : make_row ( PFS_setup_actor * pfs )
{
2019-12-10 15:35:00 +01:00
pfs_optimistic_state lock ;
2012-08-01 16:27:34 +02:00
m_row_exists = false ;
pfs - > m_lock . begin_optimistic_lock ( & lock ) ;
m_row . m_hostname_length = pfs - > m_hostname_length ;
if ( unlikely ( ( m_row . m_hostname_length = = 0 ) | |
( m_row . m_hostname_length > sizeof ( m_row . m_hostname ) ) ) )
return ;
memcpy ( m_row . m_hostname , pfs - > m_hostname , m_row . m_hostname_length ) ;
m_row . m_username_length = pfs - > m_username_length ;
if ( unlikely ( ( m_row . m_username_length = = 0 ) | |
( m_row . m_username_length > sizeof ( m_row . m_username ) ) ) )
return ;
memcpy ( m_row . m_username , pfs - > m_username , m_row . m_username_length ) ;
m_row . m_rolename_length = pfs - > m_rolename_length ;
if ( unlikely ( ( m_row . m_rolename_length = = 0 ) | |
( m_row . m_rolename_length > sizeof ( m_row . m_rolename ) ) ) )
return ;
memcpy ( m_row . m_rolename , pfs - > m_rolename , m_row . m_rolename_length ) ;
2019-12-10 15:35:00 +01:00
m_row . m_enabled_ptr = & pfs - > m_enabled ;
m_row . m_history_ptr = & pfs - > m_history ;
2012-08-01 16:27:34 +02:00
if ( pfs - > m_lock . end_optimistic_lock ( & lock ) )
m_row_exists = true ;
}
int table_setup_actors : : read_row_values ( TABLE * table ,
unsigned char * buf ,
Field * * fields ,
bool read_all )
{
Field * f ;
if ( unlikely ( ! m_row_exists ) )
return HA_ERR_RECORD_DELETED ;
/* Set the null bits */
2021-05-03 11:21:56 +02:00
assert ( table - > s - > null_bytes = = 1 ) ;
2012-08-01 16:27:34 +02:00
for ( ; ( f = * fields ) ; fields + + )
{
if ( read_all | | bitmap_is_set ( table - > read_set , f - > field_index ) )
{
switch ( f - > field_index )
{
case 0 : /* HOST */
set_field_char_utf8 ( f , m_row . m_hostname , m_row . m_hostname_length ) ;
break ;
case 1 : /* USER */
set_field_char_utf8 ( f , m_row . m_username , m_row . m_username_length ) ;
break ;
case 2 : /* ROLE */
set_field_char_utf8 ( f , m_row . m_rolename , m_row . m_rolename_length ) ;
break ;
2019-12-10 15:35:00 +01:00
case 3 : /* ENABLED */
set_field_enum ( f , ( * m_row . m_enabled_ptr ) ? ENUM_YES : ENUM_NO ) ;
break ;
case 4 : /* HISTORY */
set_field_enum ( f , ( * m_row . m_history_ptr ) ? ENUM_YES : ENUM_NO ) ;
break ;
2012-08-01 16:27:34 +02:00
default :
2021-05-03 11:21:56 +02:00
assert ( false ) ;
2012-08-01 16:27:34 +02:00
}
}
}
return 0 ;
}
int table_setup_actors : : update_row_values ( TABLE * table ,
const unsigned char * old_buf ,
2017-04-16 21:40:39 +02:00
const unsigned char * new_buf ,
2012-08-01 16:27:34 +02:00
Field * * fields )
{
2019-12-10 15:35:00 +01:00
int result ;
2012-08-01 16:27:34 +02:00
Field * f ;
2019-12-10 15:35:00 +01:00
enum_yes_no value ;
2012-08-01 16:27:34 +02:00
for ( ; ( f = * fields ) ; fields + + )
{
if ( bitmap_is_set ( table - > write_set , f - > field_index ) )
{
switch ( f - > field_index )
{
case 0 : /* HOST */
case 1 : /* USER */
case 2 : /* ROLE */
return HA_ERR_WRONG_COMMAND ;
2019-12-10 15:35:00 +01:00
case 3 : /* ENABLED */
value = ( enum_yes_no ) get_field_enum ( f ) ;
/* Reject illegal enum values in ENABLED */
if ( ( value ! = ENUM_YES ) & & ( value ! = ENUM_NO ) )
return HA_ERR_NO_REFERENCED_ROW ;
* m_row . m_enabled_ptr = ( value = = ENUM_YES ) ? true : false ;
break ;
case 4 : /* HISTORY */
value = ( enum_yes_no ) get_field_enum ( f ) ;
/* Reject illegal enum values in HISTORY */
if ( ( value ! = ENUM_YES ) & & ( value ! = ENUM_NO ) )
return HA_ERR_NO_REFERENCED_ROW ;
* m_row . m_history_ptr = ( value = = ENUM_YES ) ? true : false ;
2012-08-01 16:27:34 +02:00
break ;
default :
2021-05-03 11:21:56 +02:00
assert ( false ) ;
2012-08-01 16:27:34 +02:00
}
}
}
2019-12-10 15:35:00 +01:00
result = update_setup_actors_derived_flags ( ) ;
return result ;
2012-08-01 16:27:34 +02:00
}
int table_setup_actors : : delete_row_values ( TABLE * table ,
const unsigned char * buf ,
Field * * fields )
{
2021-05-03 11:21:56 +02:00
assert ( m_row_exists ) ;
2012-08-01 16:27:34 +02:00
2019-06-28 07:05:12 +02:00
CHARSET_INFO * cs = & my_charset_utf8mb3_bin ;
2013-03-25 23:03:13 +01:00
String user ( m_row . m_username , m_row . m_username_length , cs ) ;
String role ( m_row . m_rolename , m_row . m_rolename_length , cs ) ;
String host ( m_row . m_hostname , m_row . m_hostname_length , cs ) ;
2012-08-01 16:27:34 +02:00
2013-03-25 23:03:13 +01:00
return delete_setup_actor ( & user , & host , & role ) ;
2012-08-01 16:27:34 +02:00
}