8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-23 14:03:07 +01:00

Fixed output of show grants (#25)

This commit is contained in:
Roman Simakov 2016-05-13 16:03:19 +03:00 committed by Alexander Peshkov
parent 13ad68de93
commit 352591aaf0

View File

@ -1806,7 +1806,7 @@ void SHOW_grant_roles2 (const SCHAR* terminator,
* Functional description * Functional description
* Show grants for each role name * Show grants for each role name
* This function is also called by extract for privileges. * This function is also called by extract for privileges.
* All membership privilege may have the with_admin option set. * All membership privilege may have the with_admin or/and default options set.
* *
**************************************/ **************************************/
TEXT SQL_identifier2[BUFFER_LENGTH128]; TEXT SQL_identifier2[BUFFER_LENGTH128];
@ -1818,7 +1818,8 @@ void SHOW_grant_roles2 (const SCHAR* terminator,
FOR PRV IN RDB$USER_PRIVILEGES WITH FOR PRV IN RDB$USER_PRIVILEGES WITH
PRV.RDB$OBJECT_TYPE EQ obj_sql_role AND PRV.RDB$OBJECT_TYPE EQ obj_sql_role AND
PRV.RDB$USER_TYPE EQ obj_user AND (PRV.RDB$USER_TYPE EQ obj_user OR
PRV.RDB$USER_TYPE EQ obj_sql_role) AND
PRV.RDB$PRIVILEGE EQ 'M' PRV.RDB$PRIVILEGE EQ 'M'
SORTED BY PRV.RDB$RELATION_NAME, PRV.RDB$USER SORTED BY PRV.RDB$RELATION_NAME, PRV.RDB$USER
@ -1833,8 +1834,11 @@ void SHOW_grant_roles2 (const SCHAR* terminator,
const char* user_string = fb_utils::exact_name(PRV.RDB$USER); const char* user_string = fb_utils::exact_name(PRV.RDB$USER);
const char* with_option = ""; const char* with_option = "";
const char* default_option = "";
if (PRV.RDB$GRANT_OPTION) if (PRV.RDB$GRANT_OPTION)
with_option = " WITH ADMIN OPTION"; with_option = " WITH ADMIN OPTION";
if (!PRV.RDB$FIELD_NAME.NULL && PRV.RDB$FIELD_NAME[0] == 'D')
default_option = " DEFAULT";
const char* role = fb_utils::exact_name(PRV.RDB$RELATION_NAME); const char* role = fb_utils::exact_name(PRV.RDB$RELATION_NAME);
const char* grantor = fb_utils::exact_name(PRV.RDB$GRANTOR); const char* grantor = fb_utils::exact_name(PRV.RDB$GRANTOR);
@ -1845,7 +1849,7 @@ void SHOW_grant_roles2 (const SCHAR* terminator,
IUTILS_copy_SQL_id(PRV.RDB$USER, SQL_identifier2, DBL_QUOTE); IUTILS_copy_SQL_id(PRV.RDB$USER, SQL_identifier2, DBL_QUOTE);
user_string = SQL_identifier2; user_string = SQL_identifier2;
} }
isqlGlob.printf("GRANT %s TO %s%s%s%s%s", role, isqlGlob.printf("GRANT%s %s TO %s%s%s%s%s", default_option, role,
user_string, with_option, granted_by(buf_grantor, grantor, false), terminator, NEWLINE); user_string, with_option, granted_by(buf_grantor, grantor, false), terminator, NEWLINE);
END_FOR END_FOR