mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-11-04 00:02:37 +01:00 
			
		
		
		
	Merge pull request #1551 from shapeblue/rbac-mysql-fix
dynamic-roles: packaging improvementsOn some MySQL server envs, this may cause a SQL statement error, though I was unable to reproduce it. Since it's not needed, an order by 'sort_order' is enough, we can safely remove it. /cc @swill @anshulgangwar @DaanHoogland and others * pr/1551: migrate-dynamicroles: use mysql.connector due to #1054 packaging: don't bundle systemvm.zip in rpms packaging: backup commands.properties as it does not exist in new rpms dynamic-roles: remove unnecessary order by ID Signed-off-by: Will Stevens <williamstevens@gmail.com>
This commit is contained in:
		
						commit
						34111df02f
					
				@ -156,7 +156,6 @@ public class RolePermissionsDaoImpl extends GenericDaoBase<RolePermissionVO, Lon
 | 
			
		||||
            sc.setParameters("roleId", roleId);
 | 
			
		||||
        }
 | 
			
		||||
        final Filter searchBySorted = new Filter(RolePermissionVO.class, "sortOrder", true, null, null);
 | 
			
		||||
        searchBySorted.addOrderBy(RolePermissionVO.class, "id", true);
 | 
			
		||||
        final List<RolePermissionVO> rolePermissionList = listBy(sc, searchBySorted);
 | 
			
		||||
        if (rolePermissionList == null) {
 | 
			
		||||
            return Collections.emptyList();
 | 
			
		||||
 | 
			
		||||
@ -234,7 +234,6 @@ mkdir -p ${RPM_BUILD_ROOT}%{python_sitearch}/
 | 
			
		||||
mkdir -p ${RPM_BUILD_ROOT}%/usr/bin
 | 
			
		||||
cp -r scripts/* ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/scripts
 | 
			
		||||
install -D systemvm/dist/systemvm.iso ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/vms/systemvm.iso
 | 
			
		||||
install -D systemvm/dist/systemvm.zip ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/vms/systemvm.zip
 | 
			
		||||
install python/lib/cloud_utils.py ${RPM_BUILD_ROOT}%{python_sitearch}/cloud_utils.py
 | 
			
		||||
cp -r python/lib/cloudutils ${RPM_BUILD_ROOT}%{python_sitearch}/
 | 
			
		||||
python -m py_compile ${RPM_BUILD_ROOT}%{python_sitearch}/cloud_utils.py
 | 
			
		||||
@ -396,6 +395,13 @@ if [ -d "%{_sysconfdir}/cloud" ] ; then
 | 
			
		||||
    mv %{_sysconfdir}/cloud %{_sysconfdir}/cloud.rpmsave
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# in case of upgrade to 4.9+ copy commands.properties if not exists in /etc/cloudstack/management/
 | 
			
		||||
if [ "$1" == "2" ] ; then
 | 
			
		||||
    if [ -f "%{_datadir}/%{name}-management/webapps/client/WEB-INF/classes/commands.properties" ] && [ ! -f "%{_sysconfdir}/%{name}/management/commands.properties" ] ; then
 | 
			
		||||
        cp -p %{_datadir}/%{name}-management/webapps/client/WEB-INF/classes/commands.properties %{_sysconfdir}/%{name}/management/commands.properties
 | 
			
		||||
    fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
%post management
 | 
			
		||||
if [ "$1" == "1" ] ; then
 | 
			
		||||
    /sbin/chkconfig --add cloudstack-management > /dev/null 2>&1 || true
 | 
			
		||||
@ -605,7 +611,6 @@ fi
 | 
			
		||||
%attr(0755,root,root) %{_datadir}/%{name}-common/scripts
 | 
			
		||||
%attr(0755,root,root) /usr/bin/cloudstack-sccs
 | 
			
		||||
%attr(0644, root, root) %{_datadir}/%{name}-common/vms/systemvm.iso
 | 
			
		||||
%attr(0644, root, root) %{_datadir}/%{name}-common/vms/systemvm.zip
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloud_utils.py
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloud_utils.pyc
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloudutils/*
 | 
			
		||||
 | 
			
		||||
@ -202,7 +202,6 @@ mkdir -p ${RPM_BUILD_ROOT}%{python_sitearch}/
 | 
			
		||||
mkdir -p ${RPM_BUILD_ROOT}%/usr/bin
 | 
			
		||||
cp -r scripts/* ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/scripts
 | 
			
		||||
install -D systemvm/dist/systemvm.iso ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/vms/systemvm.iso
 | 
			
		||||
install -D systemvm/dist/systemvm.zip ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/vms/systemvm.zip
 | 
			
		||||
install python/lib/cloud_utils.py ${RPM_BUILD_ROOT}%{python_sitearch}/cloud_utils.py
 | 
			
		||||
cp -r python/lib/cloudutils ${RPM_BUILD_ROOT}%{python_sitearch}/
 | 
			
		||||
python -m py_compile ${RPM_BUILD_ROOT}%{python_sitearch}/cloud_utils.py
 | 
			
		||||
@ -352,6 +351,13 @@ id cloud > /dev/null 2>&1 || /usr/sbin/useradd -M -c "CloudStack unprivileged us
 | 
			
		||||
 | 
			
		||||
rm -rf %{_localstatedir}/cache/cloudstack
 | 
			
		||||
 | 
			
		||||
# in case of upgrade to 4.9+ copy commands.properties if not exists in /etc/cloudstack/management/
 | 
			
		||||
if [ "$1" == "2" ] ; then
 | 
			
		||||
    if [ -f "%{_datadir}/%{name}-management/webapps/client/WEB-INF/classes/commands.properties" ] && [ ! -f "%{_sysconfdir}/%{name}/management/commands.properties" ] ; then
 | 
			
		||||
        cp -p %{_datadir}/%{name}-management/webapps/client/WEB-INF/classes/commands.properties %{_sysconfdir}/%{name}/management/commands.properties
 | 
			
		||||
    fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
%post management
 | 
			
		||||
if [ "$1" == "1" ] ; then
 | 
			
		||||
    /usr/bin/systemctl on cloudstack-management > /dev/null 2>&1 || true
 | 
			
		||||
@ -501,7 +507,6 @@ fi
 | 
			
		||||
%attr(0755,root,root) %{_datadir}/%{name}-common/scripts
 | 
			
		||||
%attr(0755,root,root) /usr/bin/cloudstack-sccs
 | 
			
		||||
%attr(0644, root, root) %{_datadir}/%{name}-common/vms/systemvm.iso
 | 
			
		||||
%attr(0644, root, root) %{_datadir}/%{name}-common/vms/systemvm.zip
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloud_utils.py
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloud_utils.pyc
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloudutils/*
 | 
			
		||||
 | 
			
		||||
@ -234,7 +234,6 @@ mkdir -p ${RPM_BUILD_ROOT}%{python_sitearch}/
 | 
			
		||||
mkdir -p ${RPM_BUILD_ROOT}%/usr/bin
 | 
			
		||||
cp -r scripts/* ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/scripts
 | 
			
		||||
install -D systemvm/dist/systemvm.iso ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/vms/systemvm.iso
 | 
			
		||||
install -D systemvm/dist/systemvm.zip ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/vms/systemvm.zip
 | 
			
		||||
install python/lib/cloud_utils.py ${RPM_BUILD_ROOT}%{python_sitearch}/cloud_utils.py
 | 
			
		||||
cp -r python/lib/cloudutils ${RPM_BUILD_ROOT}%{python_sitearch}/
 | 
			
		||||
python -m py_compile ${RPM_BUILD_ROOT}%{python_sitearch}/cloud_utils.py
 | 
			
		||||
@ -395,6 +394,13 @@ if [ -d "%{_sysconfdir}/cloud" ] ; then
 | 
			
		||||
    mv %{_sysconfdir}/cloud %{_sysconfdir}/cloud.rpmsave
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# in case of upgrade to 4.9+ copy commands.properties if not exists in /etc/cloudstack/management/
 | 
			
		||||
if [ "$1" == "2" ] ; then
 | 
			
		||||
    if [ -f "%{_datadir}/%{name}-management/webapps/client/WEB-INF/classes/commands.properties" ] && [ ! -f "%{_sysconfdir}/%{name}/management/commands.properties" ] ; then
 | 
			
		||||
        cp -p %{_datadir}/%{name}-management/webapps/client/WEB-INF/classes/commands.properties %{_sysconfdir}/%{name}/management/commands.properties
 | 
			
		||||
    fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
%post management
 | 
			
		||||
if [ "$1" == "1" ] ; then
 | 
			
		||||
    /sbin/chkconfig --add cloudstack-management > /dev/null 2>&1 || true
 | 
			
		||||
@ -603,7 +609,6 @@ fi
 | 
			
		||||
%attr(0755,root,root) %{_datadir}/%{name}-common/scripts
 | 
			
		||||
%attr(0755,root,root) /usr/bin/cloudstack-sccs
 | 
			
		||||
%attr(0644, root, root) %{_datadir}/%{name}-common/vms/systemvm.iso
 | 
			
		||||
%attr(0644, root, root) %{_datadir}/%{name}-common/vms/systemvm.zip
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloud_utils.py
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloud_utils.pyc
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloudutils/*
 | 
			
		||||
 | 
			
		||||
@ -234,7 +234,6 @@ mkdir -p ${RPM_BUILD_ROOT}%{python_sitearch}/
 | 
			
		||||
mkdir -p ${RPM_BUILD_ROOT}%/usr/bin
 | 
			
		||||
cp -r scripts/* ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/scripts
 | 
			
		||||
install -D systemvm/dist/systemvm.iso ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/vms/systemvm.iso
 | 
			
		||||
install -D systemvm/dist/systemvm.zip ${RPM_BUILD_ROOT}%{_datadir}/%{name}-common/vms/systemvm.zip
 | 
			
		||||
install python/lib/cloud_utils.py ${RPM_BUILD_ROOT}%{python_sitearch}/cloud_utils.py
 | 
			
		||||
cp -r python/lib/cloudutils ${RPM_BUILD_ROOT}%{python_sitearch}/
 | 
			
		||||
python -m py_compile ${RPM_BUILD_ROOT}%{python_sitearch}/cloud_utils.py
 | 
			
		||||
@ -395,6 +394,13 @@ if [ -d "%{_sysconfdir}/cloud" ] ; then
 | 
			
		||||
    mv %{_sysconfdir}/cloud %{_sysconfdir}/cloud.rpmsave
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# in case of upgrade to 4.9+ copy commands.properties if not exists in /etc/cloudstack/management/
 | 
			
		||||
if [ "$1" == "2" ] ; then
 | 
			
		||||
    if [ -f "%{_datadir}/%{name}-management/webapps/client/WEB-INF/classes/commands.properties" ] && [ ! -f "%{_sysconfdir}/%{name}/management/commands.properties" ] ; then
 | 
			
		||||
        cp -p %{_datadir}/%{name}-management/webapps/client/WEB-INF/classes/commands.properties %{_sysconfdir}/%{name}/management/commands.properties
 | 
			
		||||
    fi
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
%post management
 | 
			
		||||
if [ "$1" == "1" ] ; then
 | 
			
		||||
    /sbin/chkconfig --add cloudstack-management > /dev/null 2>&1 || true
 | 
			
		||||
@ -603,7 +609,6 @@ fi
 | 
			
		||||
%attr(0755,root,root) %{_datadir}/%{name}-common/scripts
 | 
			
		||||
%attr(0755,root,root) /usr/bin/cloudstack-sccs
 | 
			
		||||
%attr(0644, root, root) %{_datadir}/%{name}-common/vms/systemvm.iso
 | 
			
		||||
%attr(0644, root, root) %{_datadir}/%{name}-common/vms/systemvm.zip
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloud_utils.py
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloud_utils.pyc
 | 
			
		||||
%attr(0644,root,root) %{python_sitearch}/cloudutils/*
 | 
			
		||||
 | 
			
		||||
@ -25,9 +25,9 @@ from contextlib import closing
 | 
			
		||||
from optparse import OptionParser
 | 
			
		||||
 | 
			
		||||
try:
 | 
			
		||||
    import MySQLdb
 | 
			
		||||
    import mysql.connector
 | 
			
		||||
except ImportError:
 | 
			
		||||
    print("MySQLdb cannot be imported, please install python-mysqldb(apt) or mysql-python(yum)")
 | 
			
		||||
    print("mysql.connector cannot be imported, please install mysql-connector-python")
 | 
			
		||||
    sys.exit(1)
 | 
			
		||||
 | 
			
		||||
dryrun = False
 | 
			
		||||
@ -82,7 +82,7 @@ def main():
 | 
			
		||||
    if options.dryrun:
 | 
			
		||||
        dryrun = True
 | 
			
		||||
 | 
			
		||||
    conn = MySQLdb.connect(
 | 
			
		||||
    conn = mysql.connector.connect(
 | 
			
		||||
            host=options.host,
 | 
			
		||||
            user=options.user,
 | 
			
		||||
            passwd=options.password,
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user