Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
32dedbe6
Commit
32dedbe6
authored
Dec 02, 2006
by
andrey@example.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge ahristov@bk-internal.mysql.com:/home/bk/mysql-5.1-maint
into example.com:/work/bug24395-v2/my51
parents
8fcf1421
f74e1d26
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
63 additions
and
83 deletions
+63
-83
mysql-test/r/information_schema.result
mysql-test/r/information_schema.result
+1
-1
mysql-test/r/rpl_sp.result
mysql-test/r/rpl_sp.result
+9
-7
mysql-test/t/information_schema.test
mysql-test/t/information_schema.test
+1
-1
mysql-test/t/rpl_sp.test
mysql-test/t/rpl_sp.test
+2
-1
sql/sql_parse.cc
sql/sql_parse.cc
+50
-73
No files found.
mysql-test/r/information_schema.result
View file @
32dedbe6
...
@@ -1077,7 +1077,7 @@ CREATE PROCEDURE p1 ()
...
@@ -1077,7 +1077,7 @@ CREATE PROCEDURE p1 ()
BEGIN
BEGIN
SELECT 'foo' FROM DUAL;
SELECT 'foo' FROM DUAL;
END |
END |
ERROR 42000:
Access denied for user 'root'@'localhost' to
database 'information_schema'
ERROR 42000:
Unknown
database 'information_schema'
select ROUTINE_NAME from routines;
select ROUTINE_NAME from routines;
ROUTINE_NAME
ROUTINE_NAME
grant all on information_schema.* to 'user1'@'localhost';
grant all on information_schema.* to 'user1'@'localhost';
...
...
mysql-test/r/rpl_sp.result
View file @
32dedbe6
...
@@ -468,6 +468,7 @@ drop table t1;
...
@@ -468,6 +468,7 @@ drop table t1;
set global log_bin_trust_function_creators=0;
set global log_bin_trust_function_creators=0;
set global log_bin_trust_function_creators=0;
set global log_bin_trust_function_creators=0;
End of 5.0 tests
End of 5.0 tests
reset master;
drop database if exists mysqltest;
drop database if exists mysqltest;
drop database if exists mysqltest2;
drop database if exists mysqltest2;
create database mysqltest;
create database mysqltest;
...
@@ -476,14 +477,15 @@ use mysqltest2;
...
@@ -476,14 +477,15 @@ use mysqltest2;
create table t ( t integer );
create table t ( t integer );
create procedure mysqltest.test() begin end;
create procedure mysqltest.test() begin end;
insert into t values ( 1 );
insert into t values ( 1 );
show binlog events in 'master-bin.000001' from
8657
;
show binlog events in 'master-bin.000001' from
102
;
Log_name Pos Event_type Server_id End_log_pos Info
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 8657 Query 1 8760 drop database if exists mysqltest2
master-bin.000001 102 Query 1 203 drop database if exists mysqltest
master-bin.000001 8760 Query 1 8853 create database mysqltest
master-bin.000001 203 Query 1 306 drop database if exists mysqltest2
master-bin.000001 8853 Query 1 8948 create database mysqltest2
master-bin.000001 306 Query 1 399 create database mysqltest
master-bin.000001 8948 Query 1 9045 use `mysqltest2`; create table t ( t integer )
master-bin.000001 399 Query 1 494 create database mysqltest2
master-bin.000001 9045 Query 1 9184 use `mysqltest2`; CREATE DEFINER=`root`@`localhost` procedure mysqltest.test() begin end
master-bin.000001 494 Query 1 591 use `mysqltest2`; create table t ( t integer )
master-bin.000001 9184 Query 1 9279 use `mysqltest2`; insert into t values ( 1 )
master-bin.000001 591 Query 1 730 use `mysqltest2`; CREATE DEFINER=`root`@`localhost` procedure mysqltest.test() begin end
master-bin.000001 730 Query 1 825 use `mysqltest2`; insert into t values ( 1 )
create procedure `\\`.test() begin end;
create procedure `\\`.test() begin end;
ERROR 42000: Unknown database '\\'
ERROR 42000: Unknown database '\\'
drop database mysqltest;
drop database mysqltest;
...
...
mysql-test/t/information_schema.test
View file @
32dedbe6
...
@@ -721,7 +721,7 @@ create temporary table schemata(f1 char(10));
...
@@ -721,7 +721,7 @@ create temporary table schemata(f1 char(10));
# Bug #10708 SP's can use INFORMATION_SCHEMA as ROUTINE_SCHEMA
# Bug #10708 SP's can use INFORMATION_SCHEMA as ROUTINE_SCHEMA
#
#
delimiter
|
;
delimiter
|
;
--
error
1044
--
error
ER_BAD_DB_ERROR
CREATE
PROCEDURE
p1
()
CREATE
PROCEDURE
p1
()
BEGIN
BEGIN
SELECT
'foo'
FROM
DUAL
;
SELECT
'foo'
FROM
DUAL
;
...
...
mysql-test/t/rpl_sp.test
View file @
32dedbe6
...
@@ -532,6 +532,7 @@ set global log_bin_trust_function_creators=0;
...
@@ -532,6 +532,7 @@ set global log_bin_trust_function_creators=0;
# Bug22043: MySQL don't add "USE <DATABASE>" before "DROP PROCEDURE IF EXISTS"
# Bug22043: MySQL don't add "USE <DATABASE>" before "DROP PROCEDURE IF EXISTS"
#
#
connection
master
;
connection
master
;
reset
master
;
--
disable_warnings
--
disable_warnings
drop
database
if
exists
mysqltest
;
drop
database
if
exists
mysqltest
;
drop
database
if
exists
mysqltest2
;
drop
database
if
exists
mysqltest2
;
...
@@ -542,7 +543,7 @@ use mysqltest2;
...
@@ -542,7 +543,7 @@ use mysqltest2;
create
table
t
(
t
integer
);
create
table
t
(
t
integer
);
create
procedure
mysqltest
.
test
()
begin
end
;
create
procedure
mysqltest
.
test
()
begin
end
;
insert
into
t
values
(
1
);
insert
into
t
values
(
1
);
show
binlog
events
in
'master-bin.000001'
from
8657
;
show
binlog
events
in
'master-bin.000001'
from
102
;
--
error
ER_BAD_DB_ERROR
--
error
ER_BAD_DB_ERROR
create
procedure
`\\`
.
test
()
begin
end
;
create
procedure
`\\`
.
test
()
begin
end
;
# Clean up
# Clean up
...
...
sql/sql_parse.cc
View file @
32dedbe6
...
@@ -4426,11 +4426,10 @@ mysql_execute_command(THD *thd)
...
@@ -4426,11 +4426,10 @@ mysql_execute_command(THD *thd)
{
{
uint
namelen
;
uint
namelen
;
char
*
name
;
char
*
name
;
int
result
;
int
result
=
SP_INTERNAL_ERROR
;
DBUG_ASSERT
(
lex
->
sphead
!=
0
);
DBUG_ASSERT
(
lex
->
sphead
!=
0
);
DBUG_ASSERT
(
lex
->
sphead
->
m_db
.
str
);
/* Must be initialized in the parser */
DBUG_ASSERT
(
lex
->
sphead
->
m_db
.
str
);
/* Must be initialized in the parser */
/*
/*
Verify that the database name is allowed, optionally
Verify that the database name is allowed, optionally
lowercase it.
lowercase it.
...
@@ -4438,37 +4437,26 @@ mysql_execute_command(THD *thd)
...
@@ -4438,37 +4437,26 @@ mysql_execute_command(THD *thd)
if
(
check_db_name
(
&
lex
->
sphead
->
m_db
))
if
(
check_db_name
(
&
lex
->
sphead
->
m_db
))
{
{
my_error
(
ER_WRONG_DB_NAME
,
MYF
(
0
),
lex
->
sphead
->
m_db
.
str
);
my_error
(
ER_WRONG_DB_NAME
,
MYF
(
0
),
lex
->
sphead
->
m_db
.
str
);
delete
lex
->
sphead
;
goto
create_sp_error
;
lex
->
sphead
=
0
;
goto
error
;
}
}
/*
/*
Check that a database with this name
Check that a database directory with this name
exists.
exists. Design note: This won't work on virtual databases
like information_schema.
*/
*/
if
(
check_db_dir_existence
(
lex
->
sphead
->
m_db
.
str
))
if
(
check_db_dir_existence
(
lex
->
sphead
->
m_db
.
str
))
{
{
my_error
(
ER_BAD_DB_ERROR
,
MYF
(
0
),
lex
->
sphead
->
m_db
.
str
);
my_error
(
ER_BAD_DB_ERROR
,
MYF
(
0
),
lex
->
sphead
->
m_db
.
str
);
delete
lex
->
sphead
;
goto
create_sp_error
;
lex
->
sphead
=
0
;
goto
error
;
}
}
if
(
check_access
(
thd
,
CREATE_PROC_ACL
,
lex
->
sphead
->
m_db
.
str
,
0
,
0
,
0
,
if
(
check_access
(
thd
,
CREATE_PROC_ACL
,
lex
->
sphead
->
m_db
.
str
,
0
,
0
,
0
,
is_schema_db
(
lex
->
sphead
->
m_db
.
str
)))
is_schema_db
(
lex
->
sphead
->
m_db
.
str
)))
{
goto
create_sp_error
;
delete
lex
->
sphead
;
lex
->
sphead
=
0
;
goto
error
;
}
if
(
end_active_trans
(
thd
))
if
(
end_active_trans
(
thd
))
{
goto
create_sp_error
;
delete
lex
->
sphead
;
lex
->
sphead
=
0
;
goto
error
;
}
name
=
lex
->
sphead
->
name
(
&
namelen
);
name
=
lex
->
sphead
->
name
(
&
namelen
);
#ifdef HAVE_DLOPEN
#ifdef HAVE_DLOPEN
...
@@ -4478,10 +4466,8 @@ mysql_execute_command(THD *thd)
...
@@ -4478,10 +4466,8 @@ mysql_execute_command(THD *thd)
if
(
udf
)
if
(
udf
)
{
{
my_error
(
ER_UDF_EXISTS
,
MYF
(
0
),
name
);
my_error
(
ER_UDF_EXISTS
,
MYF
(
0
),
name
);
delete
lex
->
sphead
;
goto
create_sp_error
;
lex
->
sphead
=
0
;
goto
error
;
}
}
}
}
#endif
#endif
...
@@ -4489,7 +4475,7 @@ mysql_execute_command(THD *thd)
...
@@ -4489,7 +4475,7 @@ mysql_execute_command(THD *thd)
/*
/*
If the definer is not specified, this means that CREATE-statement missed
If the definer is not specified, this means that CREATE-statement missed
DEFINER-clause. DEFINER-clause can be missed in two cases:
DEFINER-clause. DEFINER-clause can be missed in two cases:
- The user submitted a statement w/o the clause. This is a normal
- The user submitted a statement w/o the clause. This is a normal
case, we should assign CURRENT_USER as definer.
case, we should assign CURRENT_USER as definer.
...
@@ -4498,7 +4484,7 @@ mysql_execute_command(THD *thd)
...
@@ -4498,7 +4484,7 @@ mysql_execute_command(THD *thd)
CURRENT_USER as definer here, but also we should mark this routine
CURRENT_USER as definer here, but also we should mark this routine
as NON-SUID. This is essential for the sake of backward
as NON-SUID. This is essential for the sake of backward
compatibility.
compatibility.
The problem is the slave thread is running under "special" user (@),
The problem is the slave thread is running under "special" user (@),
that actually does not exist. In the older versions we do not fail
that actually does not exist. In the older versions we do not fail
execution of a stored routine if its definer does not exist and
execution of a stored routine if its definer does not exist and
...
@@ -4523,13 +4509,9 @@ mysql_execute_command(THD *thd)
...
@@ -4523,13 +4509,9 @@ mysql_execute_command(THD *thd)
if
(
ps_arena
)
if
(
ps_arena
)
thd
->
restore_active_arena
(
ps_arena
,
&
original_arena
);
thd
->
restore_active_arena
(
ps_arena
,
&
original_arena
);
/* Error has been already reported. */
if
(
res
)
if
(
res
)
{
goto
create_sp_error
;
/* Error has been already reported. */
delete
lex
->
sphead
;
lex
->
sphead
=
0
;
goto
error
;
}
if
(
thd
->
slave_thread
)
if
(
thd
->
slave_thread
)
lex
->
sphead
->
m_chistics
->
suid
=
SP_IS_NOT_SUID
;
lex
->
sphead
->
m_chistics
->
suid
=
SP_IS_NOT_SUID
;
...
@@ -4540,7 +4522,7 @@ mysql_execute_command(THD *thd)
...
@@ -4540,7 +4522,7 @@ mysql_execute_command(THD *thd)
that the current user has SUPER privilege (in order to create a stored
that the current user has SUPER privilege (in order to create a stored
routine under another user one must have SUPER privilege).
routine under another user one must have SUPER privilege).
*/
*/
else
if
(
strcmp
(
lex
->
definer
->
user
.
str
,
thd
->
security_ctx
->
priv_user
)
||
else
if
(
strcmp
(
lex
->
definer
->
user
.
str
,
thd
->
security_ctx
->
priv_user
)
||
my_strcasecmp
(
system_charset_info
,
my_strcasecmp
(
system_charset_info
,
lex
->
definer
->
host
.
str
,
lex
->
definer
->
host
.
str
,
...
@@ -4549,9 +4531,7 @@ mysql_execute_command(THD *thd)
...
@@ -4549,9 +4531,7 @@ mysql_execute_command(THD *thd)
if
(
check_global_access
(
thd
,
SUPER_ACL
))
if
(
check_global_access
(
thd
,
SUPER_ACL
))
{
{
my_error
(
ER_SPECIFIC_ACCESS_DENIED_ERROR
,
MYF
(
0
),
"SUPER"
);
my_error
(
ER_SPECIFIC_ACCESS_DENIED_ERROR
,
MYF
(
0
),
"SUPER"
);
delete
lex
->
sphead
;
goto
create_sp_error
;
lex
->
sphead
=
0
;
goto
error
;
}
}
}
}
...
@@ -4571,54 +4551,51 @@ mysql_execute_command(THD *thd)
...
@@ -4571,54 +4551,51 @@ mysql_execute_command(THD *thd)
#endif
/* NO_EMBEDDED_ACCESS_CHECKS */
#endif
/* NO_EMBEDDED_ACCESS_CHECKS */
res
=
(
result
=
lex
->
sphead
->
create
(
thd
));
res
=
(
result
=
lex
->
sphead
->
create
(
thd
));
if
(
result
==
SP_OK
)
switch
(
result
)
{
{
case
SP_OK
:
#ifndef NO_EMBEDDED_ACCESS_CHECKS
#ifndef NO_EMBEDDED_ACCESS_CHECKS
/* only add privileges if really neccessary */
/* only add privileges if really neccessary */
if
(
sp_automatic_privileges
&&
!
opt_noacl
&&
if
(
sp_automatic_privileges
&&
!
opt_noacl
&&
check_routine_access
(
thd
,
DEFAULT_CREATE_PROC_ACLS
,
check_routine_access
(
thd
,
DEFAULT_CREATE_PROC_ACLS
,
lex
->
sphead
->
m_db
.
str
,
name
,
lex
->
sphead
->
m_db
.
str
,
name
,
lex
->
sql_command
==
SQLCOM_CREATE_PROCEDURE
,
1
))
lex
->
sql_command
==
SQLCOM_CREATE_PROCEDURE
,
1
))
{
{
if
(
sp_grant_privileges
(
thd
,
lex
->
sphead
->
m_db
.
str
,
name
,
if
(
sp_grant_privileges
(
thd
,
lex
->
sphead
->
m_db
.
str
,
name
,
lex
->
sql_command
==
SQLCOM_CREATE_PROCEDURE
))
lex
->
sql_command
==
SQLCOM_CREATE_PROCEDURE
))
push_warning
(
thd
,
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
push_warning
(
thd
,
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
ER_PROC_AUTO_GRANT_FAIL
,
ER_PROC_AUTO_GRANT_FAIL
,
ER
(
ER_PROC_AUTO_GRANT_FAIL
));
ER
(
ER_PROC_AUTO_GRANT_FAIL
));
close_thread_tables
(
thd
);
close_thread_tables
(
thd
);
}
}
#endif
#endif
lex
->
unit
.
cleanup
();
delete
lex
->
sphead
;
lex
->
sphead
=
0
;
send_ok
(
thd
);
}
else
{
switch
(
result
)
{
case
SP_WRITE_ROW_FAILED
:
my_error
(
ER_SP_ALREADY_EXISTS
,
MYF
(
0
),
SP_TYPE_STRING
(
lex
),
name
);
break
;
case
SP_NO_DB_ERROR
:
my_error
(
ER_BAD_DB_ERROR
,
MYF
(
0
),
lex
->
sphead
->
m_db
.
str
);
break
;
case
SP_BAD_IDENTIFIER
:
my_error
(
ER_TOO_LONG_IDENT
,
MYF
(
0
),
name
);
break
;
case
SP_BODY_TOO_LONG
:
my_error
(
ER_TOO_LONG_BODY
,
MYF
(
0
),
name
);
break
;
default:
my_error
(
ER_SP_STORE_FAILED
,
MYF
(
0
),
SP_TYPE_STRING
(
lex
),
name
);
break
;
}
lex
->
unit
.
cleanup
();
delete
lex
->
sphead
;
lex
->
sphead
=
0
;
goto
error
;
}
break
;
break
;
}
case
SP_WRITE_ROW_FAILED
:
my_error
(
ER_SP_ALREADY_EXISTS
,
MYF
(
0
),
SP_TYPE_STRING
(
lex
),
name
);
break
;
case
SP_BAD_IDENTIFIER
:
my_error
(
ER_TOO_LONG_IDENT
,
MYF
(
0
),
name
);
break
;
case
SP_BODY_TOO_LONG
:
my_error
(
ER_TOO_LONG_BODY
,
MYF
(
0
),
name
);
break
;
default:
my_error
(
ER_SP_STORE_FAILED
,
MYF
(
0
),
SP_TYPE_STRING
(
lex
),
name
);
break
;
}
/* end switch */
/*
Capture all errors within this CASE and
clean up the environment.
*/
create_sp_error:
lex
->
unit
.
cleanup
();
delete
lex
->
sphead
;
lex
->
sphead
=
0
;
if
(
result
!=
SP_OK
)
goto
error
;
send_ok
(
thd
);
break
;
/* break super switch */
}
/* end case group bracket */
case
SQLCOM_CALL
:
case
SQLCOM_CALL
:
{
{
sp_head
*
sp
;
sp_head
*
sp
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment