X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=source%2Fmircoders%2Fproducer%2FMediaGeneratingProducerNode.java;h=27295aba003df2b962370e824fce47e9857ec0e4;hb=5482f08f712cabcf7ed43f42d7ff8d83ae7c95ff;hp=501e893361503aff247db0c987ee253fd4ee1a2c;hpb=d1fe8297d584e69a5d2bed84cc979d8bdd13cb31;p=mir.git diff --git a/source/mircoders/producer/MediaGeneratingProducerNode.java b/source/mircoders/producer/MediaGeneratingProducerNode.java index 501e8933..27295aba 100755 --- a/source/mircoders/producer/MediaGeneratingProducerNode.java +++ b/source/mircoders/producer/MediaGeneratingProducerNode.java @@ -30,20 +30,23 @@ package mircoders.producer; -import java.util.Map; - +import mir.changetracker.ChangeTracker; +import mir.changetracker.ChangeType; import mir.entity.Entity; import mir.entity.adapter.EntityAdapter; import mir.log.LoggerWrapper; -import mircoders.media.MediaHelper; import mir.media.MediaHandler; +import mir.producer.AbstractProducerNode; import mir.producer.ProducerExc; -import mir.producer.ProducerNode; import mir.util.ParameterExpander; import mircoders.entity.EntityUploadedMedia; +import mircoders.global.MirGlobal; +import mircoders.media.MediaHelper; import mircoders.storage.DatabaseUploadedMedia; -public class MediaGeneratingProducerNode implements ProducerNode { +import java.util.Map; + +public class MediaGeneratingProducerNode extends AbstractProducerNode { private String mediaEntityKey; public MediaGeneratingProducerNode(String aMediaEntityKey) { @@ -61,12 +64,15 @@ public class MediaGeneratingProducerNode implements ProducerNode { data = ParameterExpander.findValueForKey( aValueMap, mediaEntityKey ); if (!(data instanceof EntityAdapter)) { - throw new ProducerExc("MediaGeneratingProducerNode: value of '"+mediaEntityKey+"' is not an EntityAdapter, but an " + data.getClass().getName()); + throw new ProducerExc("MediaGeneratingProducerNode: value of '" + + mediaEntityKey + "' is not an EntityAdapter, but an " + data.getClass().getName()); } entity = ((EntityAdapter) data).getEntity(); - if (! (entity instanceof EntityUploadedMedia)) { - throw new ProducerExc("MediaGeneratingProducerNode: value of '"+mediaEntityKey+"' is not an uploaded media EntityAdapter, but a " + entity.getClass().getName() + " adapter"); + if (!(entity instanceof EntityUploadedMedia)) { + throw new ProducerExc("MediaGeneratingProducerNode: value of '" + + mediaEntityKey + "' is not an uploaded media EntityAdapter, but a " + + entity.getClass().getName() + " adapter"); } uploadedMediaEntity = (EntityUploadedMedia) entity; @@ -80,7 +86,18 @@ public class MediaGeneratingProducerNode implements ProducerNode { entity.setFieldValue("is_produced", "1"); entity.update(); - aLogger.info("media with id "+uploadedMediaEntity.getFieldValue("id") + ", mediaType " + mediaType.getFieldValue("name") + " successfully produced"); + // Inform the Change Reporter of the change + StringBuffer imagepath = new StringBuffer(currentMediaHandler.getBaseStoragePath()); + imagepath.append(entity.getFieldValue("publish_path").substring(1)); + ChangeTracker tracker = MirGlobal.getChangeEngine().getTracker(); + tracker.addChange(imagepath.toString(), ChangeType.MODIFICATION); + + // Log the icon change also + String iconpath = entity.getFieldValue("icon_path"); + tracker.addChange(iconpath, ChangeType.MODIFICATION); + + aLogger.info("media with id " + uploadedMediaEntity.getFieldValue("id") + + ", mediaType " + mediaType.getFieldValue("name") + " successfully produced"); } catch (Throwable t) { String message = "Error while generating media";