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