001
014
015 package com.liferay.portal.upgrade.v6_0_12_to_6_1_0;
016
017 import com.liferay.portal.kernel.dao.jdbc.DataAccess;
018 import com.liferay.portal.kernel.exception.PortalException;
019 import com.liferay.portal.kernel.exception.SystemException;
020 import com.liferay.portal.kernel.log.Log;
021 import com.liferay.portal.kernel.log.LogFactoryUtil;
022 import com.liferay.portal.kernel.upgrade.UpgradeProcess;
023 import com.liferay.portal.kernel.util.GetterUtil;
024 import com.liferay.portal.model.GroupedModel;
025 import com.liferay.portal.model.PermissionedModel;
026 import com.liferay.portal.model.ResourceBlock;
027 import com.liferay.portal.model.ResourceBlockPermissionsContainer;
028 import com.liferay.portal.model.ResourceConstants;
029 import com.liferay.portal.model.ResourcePermission;
030 import com.liferay.portal.service.ResourceBlockLocalServiceUtil;
031 import com.liferay.portal.service.ResourcePermissionLocalServiceUtil;
032 import com.liferay.portal.util.PropsValues;
033 import com.liferay.portlet.bookmarks.model.BookmarksEntry;
034 import com.liferay.portlet.bookmarks.model.BookmarksFolder;
035
036 import java.sql.Connection;
037 import java.sql.PreparedStatement;
038 import java.sql.ResultSet;
039
040 import java.util.List;
041
042
046 public class UpgradePermission extends UpgradeProcess {
047
048 protected ResourceBlock convertResourcePermissions(
049 long companyId, String name, long primKey)
050 throws PortalException, SystemException {
051
052 PermissionedModel permissionedModel =
053 ResourceBlockLocalServiceUtil.getPermissionedModel(name, primKey);
054
055 long groupId = 0;
056
057 if (permissionedModel instanceof GroupedModel) {
058 GroupedModel groupedModel = (GroupedModel)permissionedModel;
059
060 groupId = groupedModel.getGroupId();
061 }
062
063 ResourceBlockPermissionsContainer resourceBlockPermissionsContainer =
064 getResourceBlockPermissionsContainer(
065 companyId, groupId, name, primKey);
066
067 String permissionsHash =
068 ResourceBlockLocalServiceUtil.getPermissionsHash(
069 resourceBlockPermissionsContainer);
070
071 ResourceBlock resourceBlock =
072 ResourceBlockLocalServiceUtil.updateResourceBlockId(
073 companyId, groupId, name, permissionedModel, permissionsHash,
074 resourceBlockPermissionsContainer);
075
076 return resourceBlock;
077 }
078
079 protected void convertResourcePermissions(
080 String name, String tableName, String pkColumnName)
081 throws Exception {
082
083 Connection con = null;
084 PreparedStatement ps = null;
085 ResultSet rs = null;
086
087 try {
088 con = DataAccess.getConnection();
089
090 ps = con.prepareStatement(
091 "select " + pkColumnName + ", companyId from " + tableName);
092
093 rs = ps.executeQuery();
094
095 while (rs.next()) {
096 long primKey = rs.getLong(pkColumnName);
097 long companyId = rs.getLong("companyId");
098
099 ResourceBlock resourceBlock = convertResourcePermissions(
100 companyId, name, primKey);
101
102 if (_log.isInfoEnabled() &&
103 (resourceBlock.getResourceBlockId() % 100 == 0)) {
104
105 _log.info("Processed 100 resource blocks for " + name);
106 }
107 }
108 }
109 finally {
110 DataAccess.cleanUp(con, ps, rs);
111 }
112
113 List<ResourcePermission> resourcePermissions =
114 ResourcePermissionLocalServiceUtil.getScopeResourcePermissions(
115 _scopes);
116
117 for (ResourcePermission resourcePermission : resourcePermissions) {
118 int scope = resourcePermission.getScope();
119
120 if ((scope == ResourceConstants.SCOPE_COMPANY) ||
121 (scope == ResourceConstants.SCOPE_GROUP_TEMPLATE)) {
122
123 ResourceBlockLocalServiceUtil.setCompanyScopePermissions(
124 resourcePermission.getCompanyId(), name,
125 resourcePermission.getRoleId(),
126 resourcePermission.getActionIds());
127 }
128 else if (scope == ResourceConstants.SCOPE_GROUP) {
129 ResourceBlockLocalServiceUtil.setGroupScopePermissions(
130 resourcePermission.getCompanyId(),
131 GetterUtil.getLong(resourcePermission.getPrimaryKey()),
132 name, resourcePermission.getRoleId(),
133 resourcePermission.getActionIds());
134 }
135 }
136 }
137
138 @Override
139 protected void doUpgrade() throws Exception {
140 if (PropsValues.PERMISSIONS_USER_CHECK_ALGORITHM == 6) {
141 convertResourcePermissions(
142 BookmarksEntry.class.getName(), "BookmarksEntry", "entryId");
143 convertResourcePermissions(
144 BookmarksFolder.class.getName(), "BookmarksFolder", "folderId");
145 }
146 }
147
148 protected ResourceBlockPermissionsContainer
149 getResourceBlockPermissionsContainer(
150 long companyId, long groupId, String name, long primKey)
151 throws SystemException {
152
153 ResourceBlockPermissionsContainer resourceBlockPermissionContainer =
154 new ResourceBlockPermissionsContainer();
155
156 List<ResourcePermission> resourcePermissions =
157 ResourcePermissionLocalServiceUtil.getResourceResourcePermissions(
158 companyId, groupId, name, String.valueOf(primKey));
159
160 for (ResourcePermission resourcePermission : resourcePermissions) {
161 resourceBlockPermissionContainer.addPermission(
162 resourcePermission.getRoleId(),
163 resourcePermission.getActionIds());
164 }
165
166 return resourceBlockPermissionContainer;
167 }
168
169 private static Log _log = LogFactoryUtil.getLog(UpgradePermission.class);
170
171 private static final int[] _scopes = {
172 ResourceConstants.SCOPE_COMPANY,
173 ResourceConstants.SCOPE_GROUP,
174 ResourceConstants.SCOPE_GROUP_TEMPLATE
175 };
176
177 }