1
19
20 package com.liferay.portal.verify;
21
22 import com.liferay.portal.GroupFriendlyURLException;
23 import com.liferay.portal.kernel.log.Log;
24 import com.liferay.portal.kernel.log.LogFactoryUtil;
25 import com.liferay.portal.kernel.util.StringPool;
26 import com.liferay.portal.model.Group;
27 import com.liferay.portal.model.User;
28 import com.liferay.portal.service.GroupLocalServiceUtil;
29 import com.liferay.portal.service.UserLocalServiceUtil;
30
31 import java.util.List;
32
33
39 public class VerifyGroup extends VerifyProcess {
40
41 public void verify() throws VerifyException {
42 _log.info("Verifying");
43
44 try {
45 verifyGroup();
46 }
47 catch (Exception e) {
48 throw new VerifyException(e);
49 }
50 }
51
52 protected void verifyGroup() throws Exception {
53 List<Group> groups = GroupLocalServiceUtil.getNullFriendlyURLGroups();
54
55 for (Group group : groups) {
56 String friendlyURL = StringPool.SLASH + group.getGroupId();
57
58 User user = null;
59
60 if (group.isUser()) {
61 user = UserLocalServiceUtil.getUserById(group.getClassPK());
62
63 friendlyURL = StringPool.SLASH + user.getScreenName();
64 }
65 else if (group.getClassPK() > 0) {
66 friendlyURL = StringPool.SLASH + group.getClassPK();
67 }
68
69 try {
70 GroupLocalServiceUtil.updateFriendlyURL(
71 group.getGroupId(), friendlyURL);
72 }
73 catch (GroupFriendlyURLException gfurle) {
74 if (user != null) {
75 long userId = user.getUserId();
76 String screenName = user.getScreenName();
77
78 _log.info(
79 "Updating user screen name " + screenName + " to " +
80 userId + " because it is generating an invalid " +
81 "friendly URL");
82
83 UserLocalServiceUtil.updateScreenName(
84 userId, String.valueOf(userId));
85 }
86 else {
87 _log.error("Invalid Friendly URL " + friendlyURL);
88
89 throw gfurle;
90 }
91 }
92 }
93 }
94
95 private static Log _log = LogFactoryUtil.getLog(VerifyGroup.class);
96
97 }