logger.warn("You must specify the new content......");
throw new ConstraintException("Content.mustHaveSameLanguage", "3309");
}
MediumContentVersionImpl selfNewVersion = null;
ContentVersionVO contentVersionVO = ContentVersionController.getContentVersionController().getLatestActiveContentVersionVO(contentId, languageId, db);
if(contentVersionVO == null)
{
logger.warn("There must be a version....");
throw new ConstraintException("Content.mustHaveSameLanguage", "3309");
}
MediumContentVersionImpl contentVersion = ContentVersionController.getContentVersionController().checkStateAndChangeIfNeeded(contentVersionVO.getId(), principal, db);
if(contentVersion.getId() > contentVersionVO.getId())
{
selfNewVersion = contentVersion;
}
MediumDigitalAssetImpl asset = DigitalAssetController.getController().getMediumDigitalAssetWithId(digitalAssetId, db);
Map<Integer,Integer> replaceMap = new HashMap<Integer,Integer>();
List<Integer> selfContentVersionIDList = new ArrayList<Integer>();
Iterator<MediumContentVersionImpl> versionIterator = asset.getContentVersions().iterator();
while(versionIterator.hasNext())
{
MediumContentVersionImpl version = versionIterator.next();
for(SmallestContentVersionVO cvVO : versions)
{
if(version.getContentVersionId().equals(cvVO.getId()))
{
logger.info("Removing from:" + cvVO.getId());
selfContentVersionIDList.add(version.getContentVersionId());
versionIterator.remove();
replaceMap.put(version.getContentId(), contentId);
break;
}
}
}
contentVersion.getDigitalAssets().add(asset);
asset.getContentVersions().add(contentVersion);
if(fixReferences)
{
for(Integer oldContentId : replaceMap.keySet())
{
Integer newContentId = replaceMap.get(oldContentId);
logger.info("We should replace all instances of " + oldContentId + "(" + asset.getAssetKey() + ") --> " + newContentId + "(" + asset.getAssetKey() + ")");
List<ReferenceBean> referenceBeans = RegistryController.getController().getReferencingObjectsForContentAsset(oldContentId, asset.getAssetKey(), 100, true, true, false);
logger.info("referenceBeans:" + referenceBeans.size());
for(Integer cvID : selfContentVersionIDList)
{
ContentVersionVO cvVO = ContentVersionController.getContentVersionController().getContentVersionVOWithId(cvID, db);
ReferenceBean bean = new ReferenceBean();
ReferenceVersionBean versionBean = new ReferenceVersionBean();
versionBean.setReferencingObject(cvVO);
//bean.setReferencingCompletingObject(versionBean);
bean.getVersions().add(versionBean);
referenceBeans.add(bean);
}
logger.info("referenceBeans:" + referenceBeans.size());
for(ReferenceBean referenceBean : referenceBeans)
{
logger.info("ReferenceBean:" + referenceBean.getName() + ":" + referenceBean.getReferencingCompletingObject());
for(ReferenceVersionBean referenceVersionBean : referenceBean.getVersions())
{
Object o = referenceVersionBean.getReferencingObject();
logger.info("o:" + o.getClass().getName());
try
{
if(o instanceof ContentVersionVO)
{
ContentVersionVO cv = (ContentVersionVO)o;
logger.info("Replacing in:" + cv.getId());
String newVersionValue = cv.getVersionValue(); //.replaceAll("\"" + oldContentId + "\"", "\"" + newContentId + "\"");
Pattern p = Pattern.compile("<binding.*?>");
Matcher m = p.matcher(newVersionValue);
while (m.find())
{
logger.info("Found a " + m.group() + ".");
String binding = m.group();
if(binding.contains("\"" + oldContentId + "\"") && binding.contains("\"" + asset.getAssetKey() + "\""))
{
binding = binding.replaceFirst("\"" + oldContentId + "\"", "\"" + newContentId + "\"");
logger.info("Replacing:" + m.group() + ":" + binding);
newVersionValue = StringUtils.replace(newVersionValue, m.group(), binding);
//newVersionValue = newVersionValue.replaceAll(m.group(), binding);
logger.info("newVersionValue: " + newVersionValue);
}
}
Pattern pInlineAssets = Pattern.compile("getInlineAssetUrl\\(.*?\\)");
Matcher mInlineAssets = pInlineAssets.matcher(newVersionValue);
while (mInlineAssets.find())
{
logger.info("Found a " + mInlineAssets.group() + ".");
String assetCall = mInlineAssets.group();
if(assetCall.contains(oldContentId + ",") && (assetCall.contains("\"" + asset.getAssetKey() + "\"") || URLDecoder.decode(assetCall, "utf-8").contains("\"" + asset.getAssetKey() + "\"")))
{
logger.info("Replacing:" + mInlineAssets.group() + ":" + assetCall);
assetCall = assetCall.replaceFirst("" + oldContentId + ",", "" + newContentId + ",");
newVersionValue = StringUtils.replace(newVersionValue, mInlineAssets.group(), assetCall);
//newVersionValue = newVersionValue.replaceAll(mInlineAssets.group(), assetCall);
logger.info("newVersionValue: " + newVersionValue);
}
}
//newVersionValue = newVersionValue.replaceAll("getInlineAssetUrl\\(" + oldContentId + ",", "getInlineAssetUrl(" + newContentId + ",");
ContentVersion cvReal = ContentVersionController.getContentVersionController().getMediumContentVersionWithId(cv.getId(), db);
logger.info("cvReal:" + cvReal.getId());
if(selfNewVersion != null && selfNewVersion.getContentId().intValue() == cvReal.getValueObject().getContentId().intValue() && selfNewVersion.getLanguageId().intValue() == cvReal.getValueObject().getLanguageId().intValue() && selfNewVersion.getId().intValue() > cvReal.getId().intValue())
{
logger.info("Was itself - lets use the new version instead...");
cvReal = selfNewVersion;
}
cvReal.setVersionValue(newVersionValue);
cvReal.setVersionComment("Asset moved...");
cvReal.setVersionModifier(principal.getName());
cvReal.setModifiedDateTime(new Date());
RegistryController.getController().updateContentVersion(cvReal.getValueObject(), null, db);
}
else if(o instanceof SiteNodeVersionVO)
{
SiteNodeVersionVO snvo = (SiteNodeVersionVO)o;
logger.info("Replacing in sn:" + snvo.getId());
SiteNodeVO siteNodeVO = SiteNodeController.getController().getSiteNodeVOWithId(snvo.getSiteNodeId(), db);
LanguageVO masterLanguageVO = LanguageController.getController().getMasterLanguage(siteNodeVO.getRepositoryId(), db);
ContentVersionVO cv = ContentVersionController.getContentVersionController().getLatestActiveContentVersionVO(siteNodeVO.getMetaInfoContentId(), masterLanguageVO.getId(), db);
logger.info("Replacing in:" + cv.getVersionValue());
String newVersionValue = cv.getVersionValue(); //.replaceAll("\"" + oldContentId + "\"", "\"" + newContentId + "\"");
Pattern p = Pattern.compile("<binding.*?>");
Matcher m = p.matcher(newVersionValue);
while (m.find())
{
logger.info("Found a " + m.group() + ".");
String binding = m.group();
if(binding.contains("\"" + oldContentId + "\"") && binding.contains("\"" + asset.getAssetKey() + "\""))
{
binding = binding.replaceFirst("\"" + oldContentId + "\"", "\"" + newContentId + "\"");
logger.info("Replacing:" + m.group() + ":" + binding);
newVersionValue = StringUtils.replace(newVersionValue, m.group(), binding);
logger.info("newVersionValue: " + newVersionValue);
}
}
ContentVersion cvReal = ContentVersionController.getContentVersionController().getMediumContentVersionWithId(cv.getId(), db);
cvReal.setVersionValue(newVersionValue);
cvReal.setVersionComment("Asset moved...");
cvReal.setVersionModifier(principal.getName());
cvReal.setModifiedDateTime(new Date());