ref #9607 replacing class local factory methods and heplers in CdmImageInfo by servic...
[cdmlib.git] / cdmlib-remote / src / main / java / eu / etaxonomy / cdm / remote / controller / MediaController.java
index 3f40326f50a6efca37af97d7b9b084cb05789009..add8c8d53f0e3e588d476f97c16e649ae9ecf434 100644 (file)
@@ -1,4 +1,3 @@
-// $Id$\r
 /**\r
 * Copyright (C) 2007 EDIT\r
 * European Distributed Institute of Taxonomy\r
@@ -7,13 +6,9 @@
 * The contents of this file are subject to the Mozilla Public License Version 1.1\r
 * See LICENSE.TXT at the top of this package for the full license terms.\r
 */\r
-\r
 package eu.etaxonomy.cdm.remote.controller;\r
 \r
-import io.swagger.annotations.Api;\r
-\r
 import java.io.IOException;\r
-import java.net.URI;\r
 import java.util.Arrays;\r
 import java.util.List;\r
 import java.util.Map;\r
@@ -24,36 +19,41 @@ import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;\r
 \r
 import org.apache.http.HttpException;\r
+import org.apache.log4j.Logger;\r
 //import org.mortbay.log.Log;\r
 import org.springframework.beans.factory.annotation.Autowired;\r
 import org.springframework.stereotype.Controller;\r
 import org.springframework.web.bind.annotation.PathVariable;\r
 import org.springframework.web.bind.annotation.RequestMapping;\r
 import org.springframework.web.bind.annotation.RequestMethod;\r
-import org.springframework.web.servlet.ModelAndView;\r
+import org.springframework.web.bind.annotation.RequestParam;\r
 \r
 import eu.etaxonomy.cdm.api.service.IMediaService;\r
-import eu.etaxonomy.cdm.common.media.ImageInfo;\r
+import eu.etaxonomy.cdm.api.service.media.MediaInfoFactory;\r
+import eu.etaxonomy.cdm.common.URI;\r
+import eu.etaxonomy.cdm.common.media.CdmImageInfo;\r
 import eu.etaxonomy.cdm.model.media.Media;\r
 import eu.etaxonomy.cdm.model.media.MediaRepresentation;\r
 import eu.etaxonomy.cdm.remote.exception.NoRecordsMatchException;\r
+import io.swagger.annotations.Api;\r
 \r
 /**\r
  * TODO write controller documentation\r
  *\r
  * @author a.kohlbecker\r
- * @date 24.03.2009\r
+ * @since 24.03.2009\r
  */\r
-\r
 @Controller\r
 @Api("media")\r
 @RequestMapping(value = {"/media/{uuid}"})\r
-public class MediaController extends BaseController<Media, IMediaService>\r
-{\r
+public class MediaController extends AbstractIdentifiableController<Media, IMediaService>{\r
+\r
+    private static final Logger logger = Logger.getLogger(MediaController.class);\r
+\r
+\r
+    @Autowired\r
+    private MediaInfoFactory mediaInfoFactory;\r
 \r
-    /* (non-Javadoc)\r
-     * @see eu.etaxonomy.cdm.remote.controller.GenericController#setService(eu.etaxonomy.cdm.api.service.IService)\r
-     */\r
     @Autowired\r
     @Override\r
     public void setService(IMediaService service) {\r
@@ -65,36 +65,45 @@ public class MediaController extends BaseController<Media, IMediaService>
             "representations.parts"\r
     });\r
 \r
+\r
     @RequestMapping(value = {"metadata"}, method = RequestMethod.GET)\r
-    public ModelAndView doGetMediaMetaData(@PathVariable("uuid") UUID uuid,\r
-            HttpServletRequest request, HttpServletResponse response) throws IOException {\r
-        Map<String, String> result;\r
+    public Map<String, String> doGetMediaMetaData(\r
+            @PathVariable("uuid") UUID uuid,\r
+            @RequestParam(value = "applyFilterPreset", defaultValue = "true") Boolean applyFilterPreset,\r
+            HttpServletRequest request,\r
+            HttpServletResponse response) throws IOException {\r
 \r
-        ModelAndView mv = new ModelAndView();\r
+        Map<String, String> result;\r
         try{\r
             Media media = getCdmBaseInstance(uuid, response, MEDIA_INIT_STRATEGY);\r
 \r
             Set<MediaRepresentation> representations = media.getRepresentations();\r
-            //get first representation and retrieve the according metadata\r
-\r
-            Object[] repArray = representations.toArray();\r
-            Object mediaRep = repArray[0];\r
+            if(media.getRepresentations().isEmpty()) {\r
+                return null;\r
+            }\r
+            MediaRepresentation mediaRepresentation = representations.iterator().next();\r
             URI uri = null;\r
             try {\r
-                if (mediaRep instanceof MediaRepresentation){\r
-                    MediaRepresentation medRep = (MediaRepresentation) mediaRep;\r
-                    uri = medRep.getParts().get(0).getUri();\r
-                    ImageInfo imageInfo = ImageInfo.NewInstanceWithMetaData(uri, 3000);\r
-                    result = imageInfo.getMetaData();\r
-                    if(result != null) {\r
-                        mv.addObject(result);\r
-                    }\r
+                if(applyFilterPreset) {\r
+                        result = service.readResourceMetadataFiltered(mediaRepresentation);\r
+\r
+                } else {\r
+                    uri = mediaRepresentation.getParts().get(0).getUri();\r
+                    CdmImageInfo cdmImageInfo = mediaInfoFactory.cdmImageInfoWithMetaData(uri);\r
+                    result = cdmImageInfo.getMetaData();\r
                 }\r
-            } catch (HttpException e) {\r
+            } catch (IOException | HttpException e) {\r
                 logger.info(e.getMessage());\r
-                HttpStatusMessage.create("Reading media file from " + uri.toString() + " failed due to (" + e.getMessage() + ")", 400).send(response);\r
+                if(uri != null) {\r
+                    // may happen when applyFilterPreset == false\r
+                    HttpStatusMessage.create("Reading media file from " + uri.toString() + " failed due to (" + e.getMessage() + ")", 400).send(response);\r
+                } else {\r
+                    // may happen when applyFilterPreset == true\r
+                    HttpStatusMessage.create("Reading media file failed due to (" + e.getMessage() + ")", 400).send(response);\r
+                }\r
                 return null;\r
             }\r
+\r
         } catch (NoRecordsMatchException e){\r
            /* IGNORE */\r
            /* java.lang.IllegalStateException: STREAM is thrown by the servlet container\r
@@ -104,7 +113,7 @@ public class MediaController extends BaseController<Media, IMediaService>
             return null;\r
 \r
         }\r
-        return mv;\r
+        return result;\r
 \r
     }\r
 \r