ContentItemNameFix tool
git-svn-id: https://svn.libreccm.org/ccm/trunk@3142 8810af33-2d31-482b-a856-94f89814c4dfmaster
parent
224066e645
commit
54744af3d4
|
|
@ -148,7 +148,7 @@ class TaskAddUser extends SimpleContainer {
|
||||||
|
|
||||||
if (users == null) {
|
if (users == null) {
|
||||||
throw new FormProcessException
|
throw new FormProcessException
|
||||||
((GlobalizationUtil.globalize("cms.ui.workflow.no_users_were_selected"));
|
((GlobalizationUtil.globalize("cms.ui.workflow.no_users_were_selected")));
|
||||||
} else {
|
} else {
|
||||||
// Add each checked user to the task.
|
// Add each checked user to the task.
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -22,6 +22,8 @@ import com.arsdigita.cms.ContentBundle;
|
||||||
import com.arsdigita.cms.ContentItem;
|
import com.arsdigita.cms.ContentItem;
|
||||||
import com.arsdigita.cms.ItemCollection;
|
import com.arsdigita.cms.ItemCollection;
|
||||||
import com.arsdigita.cms.Folder;
|
import com.arsdigita.cms.Folder;
|
||||||
|
import com.arsdigita.cms.TextAsset;
|
||||||
|
import com.arsdigita.cms.contenttypes.GenericArticle;
|
||||||
import com.arsdigita.kernel.Kernel;
|
import com.arsdigita.kernel.Kernel;
|
||||||
import com.arsdigita.kernel.KernelExcursion;
|
import com.arsdigita.kernel.KernelExcursion;
|
||||||
import com.arsdigita.persistence.DataCollection;
|
import com.arsdigita.persistence.DataCollection;
|
||||||
|
|
@ -34,6 +36,9 @@ import com.arsdigita.util.cmd.Program;
|
||||||
import org.apache.commons.cli.CommandLine;
|
import org.apache.commons.cli.CommandLine;
|
||||||
import org.apache.commons.cli.OptionBuilder;
|
import org.apache.commons.cli.OptionBuilder;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author Jens Pelzetter
|
* @author Jens Pelzetter
|
||||||
|
|
@ -77,6 +82,8 @@ public class ContentItemNameFix extends Program {
|
||||||
protected void excurse() {
|
protected void excurse() {
|
||||||
setEffectiveParty(Kernel.getSystemParty());
|
setEffectiveParty(Kernel.getSystemParty());
|
||||||
|
|
||||||
|
final Set<LinkToCheck> linksToCheck = new HashSet<LinkToCheck>();
|
||||||
|
|
||||||
final Session session = SessionManager.getSession();
|
final Session session = SessionManager.getSession();
|
||||||
final TransactionContext transactionContext = session.getTransactionContext();
|
final TransactionContext transactionContext = session.getTransactionContext();
|
||||||
|
|
||||||
|
|
@ -84,53 +91,87 @@ public class ContentItemNameFix extends Program {
|
||||||
|
|
||||||
final DataCollection draftFolders = session.retrieve(Folder.BASE_DATA_OBJECT_TYPE);
|
final DataCollection draftFolders = session.retrieve(Folder.BASE_DATA_OBJECT_TYPE);
|
||||||
draftFolders.addEqualsFilter(ContentItem.VERSION, "draft");
|
draftFolders.addEqualsFilter(ContentItem.VERSION, "draft");
|
||||||
|
|
||||||
while (draftFolders.next()) {
|
while (draftFolders.next()) {
|
||||||
checkFolder(draftFolders.getDataObject());
|
checkFolder(draftFolders.getDataObject(), linksToCheck);
|
||||||
}
|
}
|
||||||
|
|
||||||
final DataCollection draftBundles = session.retrieve(
|
final DataCollection draftBundles = session.retrieve(
|
||||||
ContentBundle.BASE_DATA_OBJECT_TYPE);
|
ContentBundle.BASE_DATA_OBJECT_TYPE);
|
||||||
draftBundles.addEqualsFilter(ContentItem.VERSION, "draft");
|
draftBundles.addEqualsFilter(ContentItem.VERSION, "draft");
|
||||||
|
|
||||||
while (draftBundles.next()) {
|
while (draftBundles.next()) {
|
||||||
checkBundle(draftBundles.getDataObject());
|
checkBundle(draftBundles.getDataObject(), linksToCheck);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
transactionContext.commitTxn();
|
transactionContext.commitTxn();
|
||||||
|
|
||||||
|
System.out.println("-------------------------------------------------------------");
|
||||||
|
|
||||||
|
System.out.println("Checking for potentially brocken links...");
|
||||||
|
System.out.println("GenericArticle (ccm-cms-types-article, ccm-cms-types-news, ...");
|
||||||
|
System.out.println("");
|
||||||
|
|
||||||
|
final DataCollection articles = session.retrieve(
|
||||||
|
GenericArticle.BASE_DATA_OBJECT_TYPE);
|
||||||
|
articles.addEqualsFilter(ContentItem.VERSION, "draft");
|
||||||
|
while (articles.next()) {
|
||||||
|
checkArticle(articles.getDataObject(), linksToCheck);
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.println("");
|
||||||
|
System.out.println("MultiPartArticles...");
|
||||||
|
System.out.println("");
|
||||||
|
|
||||||
|
final DataCollection mpArticles = session.retrieve(
|
||||||
|
"com.arsdigita.cms.contenttypes.MultiPartArticle");
|
||||||
|
mpArticles.addEqualsFilter(ContentItem.VERSION, "draft");
|
||||||
|
while (mpArticles.next()) {
|
||||||
|
checkMpArticle(mpArticles.getDataObject(), linksToCheck);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}.run();
|
}.run();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkFolder(final DataObject folderObj) {
|
private void checkFolder(final DataObject folderObj, final Set<LinkToCheck> linksToCheck) {
|
||||||
|
|
||||||
final Folder draftFolder = new Folder(folderObj);
|
final Folder draftFolder = new Folder(folderObj);
|
||||||
final Folder liveFolder = (Folder) draftFolder.getLiveVersion();
|
final Folder liveFolder = (Folder) draftFolder.getLiveVersion();
|
||||||
|
|
||||||
if (liveFolder != null && !draftFolder.getName().equals(liveFolder.getName())) {
|
if (liveFolder != null && !draftFolder.getName().equals(liveFolder.getName())) {
|
||||||
System.out.printf("Problems with folder %s:/%s (id: %s):\n",
|
System.out.printf("Problems with folder %s:/%s (id: %s):\n",
|
||||||
draftFolder.getContentSection().getName(),
|
draftFolder.getContentSection().getName(),
|
||||||
draftFolder.getPath(),
|
draftFolder.getPath(),
|
||||||
draftFolder.getID().toString());
|
draftFolder.getID().toString());
|
||||||
System.out.printf("\t Live Folder has wrong name: Is '%s' but should be '%s'.",
|
System.out.printf("\t Live Folder has wrong name: Is '%s' but should be '%s'.",
|
||||||
liveFolder.getName(),
|
liveFolder.getName(),
|
||||||
draftFolder.getName());
|
draftFolder.getName());
|
||||||
|
|
||||||
|
linksToCheck.add(new LinkToCheck(liveFolder.getName(),
|
||||||
|
draftFolder.getName(),
|
||||||
|
String.format("%s:/%s",
|
||||||
|
liveFolder.getContentSection().getName(),
|
||||||
|
liveFolder.getPath()),
|
||||||
|
String.format("%s:/%s",
|
||||||
|
draftFolder.getContentSection().getName(),
|
||||||
|
draftFolder.getPath())));
|
||||||
|
|
||||||
if (pretend) {
|
if (pretend) {
|
||||||
System.out.print("\n\n");
|
System.out.print("\n\n");
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
liveFolder.setName(draftFolder.getName());
|
liveFolder.setName(draftFolder.getName());
|
||||||
System.out.print(" Corrected.\n\n");
|
System.out.print(" Corrected.\n\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkBundle(final DataObject bundleObj) {
|
private void checkBundle(final DataObject bundleObj, final Set<LinkToCheck> linksToCheck) {
|
||||||
|
|
||||||
final ContentBundle draftBundle = new ContentBundle(bundleObj);
|
final ContentBundle draftBundle = new ContentBundle(bundleObj);
|
||||||
final ContentItem primaryDraftItem = draftBundle.getPrimaryInstance();
|
final ContentItem primaryDraftItem = draftBundle.getPrimaryInstance();
|
||||||
|
|
@ -153,6 +194,14 @@ public class ContentItemNameFix extends Program {
|
||||||
"\t Draft ContentBundle has wrong name: Is '%s' but should be '%s'.",
|
"\t Draft ContentBundle has wrong name: Is '%s' but should be '%s'.",
|
||||||
itemName,
|
itemName,
|
||||||
draftBundle.getName());
|
draftBundle.getName());
|
||||||
|
|
||||||
|
linksToCheck.add(new LinkToCheck(draftBundle.getName(),
|
||||||
|
itemName,
|
||||||
|
String.format("%s:/%s",
|
||||||
|
draftBundle.getContentSection().getName(),
|
||||||
|
draftBundle.getPath()),
|
||||||
|
itemPath));
|
||||||
|
|
||||||
if (pretend) {
|
if (pretend) {
|
||||||
System.out.print("\n");
|
System.out.print("\n");
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -161,7 +210,7 @@ public class ContentItemNameFix extends Program {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
checkInstances(draftBundle, itemName, itemId, itemPath, headerStatus);
|
checkInstances(draftBundle, itemName, itemId, itemPath, headerStatus, linksToCheck);
|
||||||
|
|
||||||
final ContentBundle liveBundle = (ContentBundle) draftBundle.getLiveVersion();
|
final ContentBundle liveBundle = (ContentBundle) draftBundle.getLiveVersion();
|
||||||
if (liveBundle != null) {
|
if (liveBundle != null) {
|
||||||
|
|
@ -173,6 +222,14 @@ public class ContentItemNameFix extends Program {
|
||||||
itemName,
|
itemName,
|
||||||
liveBundle.getName());
|
liveBundle.getName());
|
||||||
|
|
||||||
|
linksToCheck.add(new LinkToCheck(liveBundle.getName(),
|
||||||
|
itemName,
|
||||||
|
String.format("%s:/%s",
|
||||||
|
liveBundle.getContentSection()
|
||||||
|
.getName(),
|
||||||
|
liveBundle.getPath()),
|
||||||
|
itemPath));
|
||||||
|
|
||||||
if (pretend) {
|
if (pretend) {
|
||||||
System.out.print("\n");
|
System.out.print("\n");
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -181,9 +238,9 @@ public class ContentItemNameFix extends Program {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
checkInstances(liveBundle, itemName, itemId, itemPath, headerStatus);
|
checkInstances(liveBundle, itemName, itemId, itemPath, headerStatus, linksToCheck);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (headerStatus.isHeaderPrinted()) {
|
if (headerStatus.isHeaderPrinted()) {
|
||||||
System.out.print("\n");
|
System.out.print("\n");
|
||||||
}
|
}
|
||||||
|
|
@ -194,7 +251,8 @@ public class ContentItemNameFix extends Program {
|
||||||
final String itemName,
|
final String itemName,
|
||||||
final String itemId,
|
final String itemId,
|
||||||
final String itemPath,
|
final String itemPath,
|
||||||
final HeaderStatus headerStatus) {
|
final HeaderStatus headerStatus,
|
||||||
|
final Set<LinkToCheck> linksToCheck) {
|
||||||
final ItemCollection instances = draftBundle.getInstances();
|
final ItemCollection instances = draftBundle.getInstances();
|
||||||
ContentItem current;
|
ContentItem current;
|
||||||
while (instances.next()) {
|
while (instances.next()) {
|
||||||
|
|
@ -209,6 +267,14 @@ public class ContentItemNameFix extends Program {
|
||||||
current.getLanguage(),
|
current.getLanguage(),
|
||||||
itemName,
|
itemName,
|
||||||
current.getName());
|
current.getName());
|
||||||
|
|
||||||
|
linksToCheck.add(new LinkToCheck(current.getName(),
|
||||||
|
itemName,
|
||||||
|
String.format("%s:/%s",
|
||||||
|
current.getContentSection().getName(),
|
||||||
|
current.getPath()),
|
||||||
|
itemPath));
|
||||||
|
|
||||||
if (pretend) {
|
if (pretend) {
|
||||||
System.out.print("\n");
|
System.out.print("\n");
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -247,4 +313,174 @@ public class ContentItemNameFix extends Program {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class LinkToCheck {
|
||||||
|
|
||||||
|
private String wrongName;
|
||||||
|
private String correctName;
|
||||||
|
private String wrongPath;
|
||||||
|
private String correctPath;
|
||||||
|
|
||||||
|
public LinkToCheck() {
|
||||||
|
//Nothing
|
||||||
|
}
|
||||||
|
|
||||||
|
public LinkToCheck(final String wrongName,
|
||||||
|
final String correctName,
|
||||||
|
final String wrongPath,
|
||||||
|
final String correctPath) {
|
||||||
|
this.wrongName = wrongName;
|
||||||
|
this.correctName = correctName;
|
||||||
|
this.wrongPath = wrongPath;
|
||||||
|
this.correctPath = correctPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getWrongName() {
|
||||||
|
return wrongName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setWrongName(final String wrongName) {
|
||||||
|
this.wrongName = wrongName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getCorrectName() {
|
||||||
|
return correctName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCorrectName(final String correctName) {
|
||||||
|
this.correctName = correctName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getWrongPath() {
|
||||||
|
return wrongPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setWrongPath(final String wrongPath) {
|
||||||
|
this.wrongPath = wrongPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getCorrectPath() {
|
||||||
|
return correctPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCorrectPath(final String correctPath) {
|
||||||
|
this.correctPath = correctPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
int hash = 7;
|
||||||
|
if (wrongName == null) {
|
||||||
|
hash = 47 * hash;
|
||||||
|
} else {
|
||||||
|
hash = 47 * hash + wrongName.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (correctName == null) {
|
||||||
|
hash = 47 * hash;
|
||||||
|
} else {
|
||||||
|
hash = 47 * hash + correctName.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
return hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(final Object obj) {
|
||||||
|
if (obj == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (getClass() != obj.getClass()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
final LinkToCheck other = (LinkToCheck) obj;
|
||||||
|
if (wrongName == null && other.getWrongName() != null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (wrongName != null && other.getWrongName() == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (correctName == null && other.getCorrectName() != null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (correctName != null && other.getCorrectName() == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ((correctName.equals(other.getCorrectName()))
|
||||||
|
&& (wrongName.equals(other.getWrongName())));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkArticle(final DataObject articleObj,
|
||||||
|
final Set<LinkToCheck> linksToCheck) {
|
||||||
|
final GenericArticle article = new GenericArticle(articleObj);
|
||||||
|
|
||||||
|
final TextAsset textAsset = article.getTextAsset();
|
||||||
|
|
||||||
|
if (textAsset == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final String text = textAsset.getText();
|
||||||
|
|
||||||
|
if (text == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (LinkToCheck linkToCheck : linksToCheck) {
|
||||||
|
if (text.contains(linkToCheck.getWrongName())) {
|
||||||
|
System.out.printf("Found a potenially brocken link in article item %s:/%s:\n",
|
||||||
|
article.getContentSection().getName(),
|
||||||
|
article.getPath());
|
||||||
|
System.out.printf("\tLook for a link containing to path '%s' and replace it with "
|
||||||
|
+ "the stable link to the target item.\n\n",
|
||||||
|
linkToCheck.getWrongPath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkMpArticle(final DataObject mpArticleObj,
|
||||||
|
final Set<LinkToCheck> linksToCheck) {
|
||||||
|
final ContentItem mpItem = new ContentItem(mpArticleObj);
|
||||||
|
final DataCollection sections = (DataCollection) mpArticleObj.get("sections");
|
||||||
|
|
||||||
|
while (sections.next()) {
|
||||||
|
checkMpSection(mpItem, sections.getDataObject(), linksToCheck);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkMpSection(final ContentItem mpItem,
|
||||||
|
final DataObject sectionObj,
|
||||||
|
final Set<LinkToCheck> linksToCheck) {
|
||||||
|
final DataObject textAssetObj = (DataObject) sectionObj.get("text");
|
||||||
|
|
||||||
|
if (textAssetObj == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
final String text = (String) textAssetObj.get(TextAsset.CONTENT);
|
||||||
|
|
||||||
|
if (text == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (LinkToCheck linkToCheck : linksToCheck) {
|
||||||
|
if (text.contains(linkToCheck.getWrongName())) {
|
||||||
|
System.out.printf("Found a potenially brocken link in section '%s' of "
|
||||||
|
+ "MultiPartArticle %s:/%s.\n",
|
||||||
|
(String) sectionObj.get("title"),
|
||||||
|
mpItem.getContentSection().getName(),
|
||||||
|
mpItem.getPath());
|
||||||
|
System.out.printf("\tLook for a link containing to path '%s' and replace it with "
|
||||||
|
+ "the stable link to the target item.\n\n",
|
||||||
|
linkToCheck.getWrongPath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue