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