Examples of ConverterProcessResult


Examples of org.apache.openmeetings.documents.beans.ConverterProcessResult

  private static final Logger log = Red5LoggerFactory.
      getLogger(CreateLibraryPresentation.class, OpenmeetingsVariables.webAppRootKey);
 
  public static ConverterProcessResult generateXMLDocument(File targetDirectory, String originalDocument,
      String pdfDocument, String swfDocument){
    ConverterProcessResult returnMap = new ConverterProcessResult();
    returnMap.setProcess("generateXMLDocument");   
    try {
     
          Document document = DocumentHelper.createDocument();
          Element root = document.addElement( "presentation" );

          File file = new File(targetDirectory, originalDocument);
          root.addElement( "originalDocument" )
        .addAttribute("lastmod", (new Long(file.lastModified())).toString())
        .addAttribute("size", (new Long(file.length())).toString())         
              .addText( originalDocument );
         
          if (pdfDocument!=null){
            File pdfDocumentFile = new File(targetDirectory, pdfDocument);
            root.addElement( "pdfDocument" )
          .addAttribute("lastmod", (new Long(pdfDocumentFile.lastModified())).toString())
          .addAttribute("size", (new Long(pdfDocumentFile.length())).toString())                
                .addText( pdfDocument );
          }
         
          if (swfDocument!=null){
            File swfDocumentFile = new File(targetDirectory, originalDocument);
            root.addElement( "swfDocument" )
          .addAttribute("lastmod", (new Long(swfDocumentFile.lastModified())).toString())
          .addAttribute("size", (new Long(swfDocumentFile.length())).toString())               
                .addText( swfDocument );   
          }
         
          Element thumbs = root.addElement( "thumbs" );
         
      //Secoond get all Files of this Folder
      FilenameFilter ff = new FilenameFilter() {
           public boolean accept(File b, String name) {
              File f = new File(b, name);
                return f.isFile();
           }
      }
     
      String[] allfiles = targetDirectory.list(ff);     
      if(allfiles!=null){
        Arrays.sort(allfiles);
        for(int i=0; i<allfiles.length; i++){
          File thumbfile = new File(targetDirectory, allfiles[i]);
          if (allfiles[i].startsWith("_thumb_")){
            thumbs.addElement( "thumb" )
              .addAttribute("lastmod", (new Long(thumbfile.lastModified())).toString())
              .addAttribute("size", (new Long(thumbfile.length())).toString())
                    .addText( allfiles[i] );
          }
        }
      }
         
          // lets write to a file
          XMLWriter writer = new XMLWriter(
              new FileOutputStream(new File(targetDirectory, OmFileHelper.libraryFileName))
          );
          writer.write( document );
          writer.close();
     
          returnMap.setExitValue("0");
         
      return returnMap;
    } catch (Exception err) {
      log.error("[generateXMLDocument]", err);
      returnMap.setError(err.getMessage());
      returnMap.setExitValue("-1");
      return returnMap;
    }
  }
View Full Code Here

Examples of org.apache.openmeetings.documents.beans.ConverterProcessResult

      System.arraycopy(argv, 0, cmd, 2, argv.length);
      Map<String, String> env = new HashMap<String, String>();
      return executeScript(process, cmd, env);
    } catch (Exception t) {
      log.error("executeScriptWindows", t);
      return new ConverterProcessResult(process, t.getMessage(), t);
    }
  }
View Full Code Here

Examples of org.apache.openmeetings.documents.beans.ConverterProcessResult

    return executeScript(process, argv, env);
  }
 
  public static ConverterProcessResult executeScript(String process,
      String[] argv, Map<? extends String, ? extends String> env) {
    ConverterProcessResult returnMap = new ConverterProcessResult();
    returnMap.setProcess(process);
    log.debug("process: " + process);
    log.debug("args: " + Arrays.toString(argv));
 
    try {
      returnMap.setCommand(Arrays.toString(argv));
      returnMap.setOut("");
 
      // By using the process Builder we have access to modify the
      // environment variables
      // that is handy to set variables to run it inside eclipse
      ProcessBuilder pb = new ProcessBuilder(argv);
      pb.environment().putAll(env);
 
      Process proc = pb.start();
 
      // 20-minute timeout for command execution
      // FFMPEG conversion of Recordings may take a real long time until
      // its finished
      long timeout = 60000 * 20;
 
      StreamWatcher errorWatcher = new StreamWatcher(proc, true);
      Worker worker = new Worker(proc);
      StreamWatcher inputWatcher = new StreamWatcher(proc, false);
      errorWatcher.start();
      inputWatcher.start();
      worker.start();
     
      try {
        worker.join(timeout);
        if (worker.exitCode != null) {
          returnMap.setExitValue(""+worker.exitCode);
          log.debug("exitVal: " + worker.exitCode);
          returnMap.setError(errorWatcher.output.toString());
        } else {
          returnMap.setException("timeOut");
          returnMap.setError(errorWatcher.output.toString());
          returnMap.setExitValue("-1");
 
          throw new TimeoutException();
        }
      } catch (InterruptedException ex) {
        worker.interrupt();
        errorWatcher.interrupt();
        inputWatcher.interrupt();
        Thread.currentThread().interrupt();
 
        returnMap.setError(ex.getMessage());
        returnMap.setExitValue("-1");
 
        throw ex;
      } finally {
        proc.destroy();
      }
     
    } catch (TimeoutException e) {
      // Timeout exception is processed above
      log.error("executeScript",e);
      returnMap.setError(e.getMessage());
      returnMap.setException(e.toString());
      returnMap.setExitValue("-1");
    } catch (Throwable t) {
      // Any other exception is shown in debug window
      log.error("executeScript",t);
      returnMap.setError(t.getMessage());
      returnMap.setException(t.toString());
      returnMap.setExitValue("-1");
    }
   
    return returnMap;
  }
View Full Code Here

Examples of org.apache.openmeetings.util.process.ConverterProcessResult

    File destinationFile = OmFileHelper.getNewFile(OmFileHelper.getUploadRoomDir(roomName), fileName, ".jpg");

    log.debug("##### convertImage destinationFile: " + destinationFile);

    ConverterProcessResult processJPG = convertSingleJpg(fileFullPath.getCanonicalPath(), destinationFile);
    ConverterProcessResult processThumb = generateThumbs.generateThumb(thumbImagePrefix, destinationFile, 50);

    returnMap.addItem("processJPG", processJPG);
    returnMap.addItem("processThumb", processThumb);

    // Delete old one
View Full Code Here

Examples of org.apache.openmeetings.util.process.ConverterProcessResult

              , "-i", path
              , "-an" // only input files with video will be treated as video sources
              , "-v", "error"
              , "-f", "null"
              , "file.null"};
          ConverterProcessResult r = ProcessHelper.executeScript("checkFlvPod_" + pod , args);
          returnLog.add(r);
          if ("".equals(r.getError())) {
            pods[pod - 1] = path;
          }
          found = true;
        }
      }
      if (!found) {
        ConverterProcessResult r = new ConverterProcessResult();
        r.setProcess("CheckFlvFilesExists");
        r.setError("No valid pods found");
        returnLog.add(r);
        return;
      }
      boolean shortest = false;
      List<String> args = new ArrayList<String>();
View Full Code Here

Examples of org.apache.openmeetings.util.process.ConverterProcessResult

    File destinationFile = OmFileHelper.getNewFile(OmFileHelper.getUploadRoomDir(roomName), fileName, ".jpg");

    log.debug("##### convertImage destinationFile: " + destinationFile);

    ConverterProcessResult processJPG = convertSingleJpg(fileFullPath.getCanonicalPath(), destinationFile);
    ConverterProcessResult processThumb = generateThumbs.generateThumb(thumbImagePrefix, destinationFile, 50);

    returnMap.addItem("processJPG", processJPG);
    returnMap.addItem("processThumb", processThumb);

    // Delete old one
View Full Code Here

Examples of org.apache.openmeetings.util.process.ConverterProcessResult

              , "-i", path
              , "-an" // only input files with video will be treated as video sources
              , "-v", "error"
              , "-f", "null"
              , "file.null"};
          ConverterProcessResult r = ProcessHelper.executeScript("checkFlvPod_" + pod , args);
          returnLog.add(r);
          if ("".equals(r.getError())) {
            pods[pod - 1] = path;
          }
          found = true;
        }
      }
      if (!found) {
        ConverterProcessResult r = new ConverterProcessResult();
        r.setProcess("CheckFlvFilesExists");
        r.setError("No valid pods found");
        returnLog.add(r);
        return;
      }
      boolean shortest = false;
      List<String> args = new ArrayList<String>();
View Full Code Here

Examples of org.apache.openmeetings.util.process.ConverterProcessResult

      // Add empty pieces at the beginning and end of the wav
      // FIXME: Is this really needed anymore?!

    } catch (Exception err) {
      log.error("[startConversion]", err);
      returnLog.add(new ConverterProcessResult("startConversion", err.getMessage(), err));
    }

    return returnLog;
  }
View Full Code Here

Examples of org.apache.openmeetings.util.process.ConverterProcessResult

          "-ar", "22050", "-acodec", "libmp3lame", "-ab", "32k",
          "-vcodec", "flv",
          outputFullFlv.getCanonicalPath() };
      // "-s", flvWidth + "x" + flvHeight,

      ConverterProcessResult returnMapConvertFLV = ProcessHelper.executeScript("uploadFLV ID :: "
          + fileExplorerItem.getFileExplorerItemId(), argv_fullFLV);
     
      //Parse the width height from the FFMPEG output
      FlvDimension flvDimension = getFlvDimension(returnMapConvertFLV.getError());
      int flvWidth = flvDimension.width;
      int flvHeight = flvDimension.height;
     
     
      fileExplorerItem.setFlvWidth(flvWidth);
      fileExplorerItem.setFlvHeight(flvHeight);

      returnLog.add(returnMapConvertFLV);

      String hashFileFullNameJPEG = "UPLOADFLV_" + fileExplorerItem.getFileExplorerItemId() + ".jpg";
      File outPutJpeg = new File(getStreamsHibernateDir(), name + ".jpg");

      fileExplorerItem.setPreviewImage(hashFileFullNameJPEG);

      String[] argv_previewFLV = new String[] { getPathToFFMPEG(), "-i",
          outputFullFlv.getCanonicalPath(), "-vcodec", "mjpeg", "-vframes", "1", "-an",
          "-f", "rawvideo", "-s", flvWidth + "x" + flvHeight,
          outPutJpeg.getCanonicalPath() };

      returnLog.add(ProcessHelper.executeScript("previewUpload ID :: "
              + fileExplorerItem.getFileExplorerItemId(),
              argv_previewFLV));

      fileExplorerItemDaoImpl.updateFileOrFolder(fileExplorerItem);

      for (ConverterProcessResult returnMap : returnLog) {
        flvRecordingLogDaoImpl.addFLVRecordingLog("generateFFMPEG", null, returnMap);
      }
    } catch (Exception err) {
      log.error("[convertToFLV]", err);
      returnLog.add(new ConverterProcessResult("convertToFLV", err.getMessage(), err));
    }

    return returnLog;
  }
View Full Code Here

Examples of org.apache.openmeetings.util.process.ConverterProcessResult

        log.debug("isAsIs: " + isAsIs);

        // add outputfolders for profiles
        // if it is a presenation it will be copied to another place
        if (!(canBeConverted || isPdf || isImage || isVideo || isAsIs)) {
          returnError.addItem("wrongType", new ConverterProcessResult("The file type cannot be converted"));
            return returnError;
        }

        File completeName = new File(
          isAsIs ? OmFileHelper.getUploadFilesDir() : OmFileHelper.getUploadTempFilesDir()
          , newFileSystemName + newFileExtDot);
        log.debug("writing file to: " + completeName);
        FileHelper.copy(is, completeName);
        is.close();

        Long ownerId = null;
        if (parentFolderId == -2) {
            parentFolderId = 0L;
            ownerId = userId;
        }
        if (isOwner) {
            ownerId = userId;
        }

        String fileHashName = newFileSystemName + newFileExtDot;
        Boolean isPresentation = false;
        if (canBeConverted || isPdf) {
            // In case of a presentation the hash is a folder-name
            fileHashName = newFileSystemName;
            isPresentation = true;
        }
        if (isImage) {
            fileHashName = newFileSystemName + ".jpg";
        }
        if (isVideo) {
            fileHashName = newFileSystemName + ".flv";
        }

        FileExplorerItem fileExplorerItem = fileExplorerItemDao.getFileExplorerItemsById(parentFolderId);

        if (fileExplorerItem != null) {
            if (fileExplorerItem.getIsFolder() == null
                    || !fileExplorerItem.getIsFolder()) {
                parentFolderId = 0L;
            }
        }

        Long fileExplorerItemId = fileExplorerItemDao.add(
                fileSystemName, fileHashName, // The Hashname of the file
                parentFolderId, ownerId, room_id, userId, false, // isFolder
                isImage, isPresentation, "", false, isChart,
                externalFileId, externalType);
        log.debug("fileExplorerItemId: " + fileExplorerItemId);
       
       
       
        log.debug("canBeConverted: " + canBeConverted);
        if (canBeConverted) {
            // convert to pdf, thumbs, swf and xml-description
            returnError = generatePDF.convertPDF(newFileSystemName, "files", true, completeName);
        } else if (isPdf) {
            // convert to thumbs, swf and xml-description
            returnError = generatePDF.convertPDF(newFileSystemName, "files", false, completeName);
        } else if (isChart) {
            log.debug("uploaded chart file");
        } else if (isImage && !isAsIs) {
            // convert it to JPG
            log.debug("##### convert it to JPG: ");
            returnError = generateImage.convertImage(newFileSystemName, newFileExtDot, "files",
                    newFileSystemName, false);
        } else if (isAsIs) {
          ConverterProcessResult processThumb = generateThumbs.generateThumb(thumbImagePrefix, completeName, 50);
            returnError.addItem("processThumb", processThumb);
        } else if (isVideo) {
          List<ConverterProcessResult> returnList = flvExplorerConverter.startConversion(fileExplorerItemId, completeName.getCanonicalPath());
         
          int i=0;
View Full Code Here
TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.