use of org.opencastproject.caption.api.CaptionConverter in project opencast by opencast.
the class CaptionServiceImpl method getLanguageList.
/**
* {@inheritDoc}
*/
@Override
public String[] getLanguageList(MediaPackageElement input, String format) throws UnsupportedCaptionFormatException, CaptionConverterException {
if (format == null) {
throw new UnsupportedCaptionFormatException("<null>");
}
CaptionConverter converter = getCaptionConverter(format);
if (converter == null) {
throw new UnsupportedCaptionFormatException(format);
}
File captions;
try {
captions = workspace.get(input.getURI());
} catch (NotFoundException e) {
throw new CaptionConverterException("Requested media package element " + input + " could not be found.");
} catch (IOException e) {
throw new CaptionConverterException("Requested media package element " + input + "could not be accessed.");
}
FileInputStream stream = null;
String[] languageList;
try {
stream = new FileInputStream(captions);
languageList = converter.getLanguageList(stream);
} catch (FileNotFoundException e) {
throw new CaptionConverterException("Requested file " + captions + "could not be found.");
} finally {
IoSupport.closeQuietly(stream);
}
return languageList == null ? new String[0] : languageList;
}
use of org.opencastproject.caption.api.CaptionConverter in project opencast by opencast.
the class CaptionServiceImpl method convert.
/**
* Converts the captions and returns them in a new catalog.
*
* @return the converted catalog
*/
protected MediaPackageElement convert(Job job, MediaPackageElement input, String inputFormat, String outputFormat, String language) throws UnsupportedCaptionFormatException, CaptionConverterException, MediaPackageException {
try {
// check parameters
if (input == null)
throw new IllegalArgumentException("Input element can't be null");
if (StringUtils.isBlank(inputFormat))
throw new IllegalArgumentException("Input format is null");
if (StringUtils.isBlank(outputFormat))
throw new IllegalArgumentException("Output format is null");
// get input file
File captionsFile;
try {
captionsFile = workspace.get(input.getURI());
} catch (NotFoundException e) {
throw new CaptionConverterException("Requested media package element " + input + " could not be found.");
} catch (IOException e) {
throw new CaptionConverterException("Requested media package element " + input + "could not be accessed.");
}
logger.debug("Atempting to convert from {} to {}...", inputFormat, outputFormat);
List<Caption> collection = null;
try {
collection = importCaptions(captionsFile, inputFormat, language);
logger.debug("Parsing to collection succeeded.");
} catch (UnsupportedCaptionFormatException e) {
throw new UnsupportedCaptionFormatException(inputFormat);
} catch (CaptionConverterException e) {
throw e;
}
URI exported;
try {
exported = exportCaptions(collection, job.getId() + "." + FilenameUtils.getExtension(captionsFile.getAbsolutePath()), outputFormat, language);
logger.debug("Exporting captions succeeding.");
} catch (UnsupportedCaptionFormatException e) {
throw new UnsupportedCaptionFormatException(outputFormat);
} catch (IOException e) {
throw new CaptionConverterException("Could not export caption collection.", e);
}
// create catalog and set properties
CaptionConverter converter = getCaptionConverter(outputFormat);
MediaPackageElementBuilder elementBuilder = MediaPackageElementBuilderFactory.newInstance().newElementBuilder();
MediaPackageElement mpe = elementBuilder.elementFromURI(exported, converter.getElementType(), new MediaPackageElementFlavor("captions", outputFormat + (language == null ? "" : "+" + language)));
if (mpe.getMimeType() == null) {
String[] mimetype = FileTypeMap.getDefaultFileTypeMap().getContentType(exported.getPath()).split("/");
mpe.setMimeType(mimeType(mimetype[0], mimetype[1]));
}
if (language != null)
mpe.addTag("lang:" + language);
return mpe;
} catch (Exception e) {
logger.warn("Error converting captions in " + input, e);
if (e instanceof CaptionConverterException) {
throw (CaptionConverterException) e;
} else if (e instanceof UnsupportedCaptionFormatException) {
throw (UnsupportedCaptionFormatException) e;
} else {
throw new CaptionConverterException(e);
}
}
}
use of org.opencastproject.caption.api.CaptionConverter in project opencast by opencast.
the class CaptionServiceImpl method exportCaptions.
/**
* Exports captions {@link List} to specified format. Extension is added to exported file name. Throws
* {@link UnsupportedCaptionFormatException} if format is not supported.
*
* @param captions
* {@link {@link List} to be exported
* @param outputName
* name under which exported captions will be stored
* @param outputFormat
* format of exported collection
* @param language
* (optional) captions' language
* @throws UnsupportedCaptionFormatException
* if there is no registered engine for given format
* @return location of converted captions
* @throws IOException
* if exception occurs while writing to output stream
*/
private URI exportCaptions(List<Caption> captions, String outputName, String outputFormat, String language) throws UnsupportedCaptionFormatException, IOException {
CaptionConverter converter = getCaptionConverter(outputFormat);
if (converter == null) {
logger.error("No available caption format found for {}.", outputFormat);
throw new UnsupportedCaptionFormatException(outputFormat);
}
// TODO instead of first writing it all in memory, write it directly to disk
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
try {
converter.exportCaption(outputStream, captions, language);
} catch (IOException e) {
// since we're writing to memory, this should not happen
}
ByteArrayInputStream in = new ByteArrayInputStream(outputStream.toByteArray());
return workspace.putInCollection(COLLECTION, outputName + "." + converter.getExtension(), in);
}
use of org.opencastproject.caption.api.CaptionConverter in project opencast by opencast.
the class CaptionServiceImpl method getCaptionConverter.
/**
* Returns specific {@link CaptionConverter}. Registry is searched based on formatName, so in order for
* {@link CaptionConverter} to be found, it has to have <code>caption.format</code> property set with
* {@link CaptionConverter} format. If none is found, null is returned, if more than one is found then the first
* reference is returned.
*
* @param formatName
* name of the caption format
* @return {@link CaptionConverter} or null if none is found
*/
protected CaptionConverter getCaptionConverter(String formatName) {
ServiceReference[] ref = null;
try {
ref = componentContext.getBundleContext().getServiceReferences(CaptionConverter.class.getName(), "(caption.format=" + formatName + ")");
} catch (InvalidSyntaxException e) {
throw new RuntimeException(e);
}
if (ref == null) {
logger.warn("No caption format available for {}.", formatName);
return null;
}
if (ref.length > 1)
logger.warn("Multiple references for caption format {}! Returning first service reference.", formatName);
CaptionConverter converter = (CaptionConverter) componentContext.getBundleContext().getService(ref[0]);
return converter;
}
use of org.opencastproject.caption.api.CaptionConverter in project opencast by opencast.
the class CaptionServiceImpl method getAvailableCaptionConverters.
/**
* Returns all registered CaptionFormats.
*/
protected HashMap<String, CaptionConverter> getAvailableCaptionConverters() {
HashMap<String, CaptionConverter> captionConverters = new HashMap<String, CaptionConverter>();
ServiceReference[] refs = null;
try {
refs = componentContext.getBundleContext().getServiceReferences(CaptionConverter.class.getName(), null);
} catch (InvalidSyntaxException e) {
// should not happen since it is called with null argument
}
if (refs != null) {
for (ServiceReference ref : refs) {
CaptionConverter converter = (CaptionConverter) componentContext.getBundleContext().getService(ref);
String format = (String) ref.getProperty("caption.format");
if (captionConverters.containsKey(format)) {
logger.warn("Caption converter with format {} has already been registered. Ignoring second definition.", format);
} else {
captionConverters.put((String) ref.getProperty("caption.format"), converter);
}
}
}
return captionConverters;
}
Aggregations