X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=source%2Fmircoders%2Fmedia%2FMediaHandlerRealVideo.java;h=1fada7ee525d681fbe453bc20f4b752bffea91a6;hb=d7429fe1376f25d0c4420c35c69dc9edd651ab25;hp=27f80259b2c7d54a4435db8157f1293e70a40747;hpb=725d9805584b311f295769aa47fa49ae0a1598e1;p=mir.git diff --git a/source/mircoders/media/MediaHandlerRealVideo.java b/source/mircoders/media/MediaHandlerRealVideo.java index 27f80259..1fada7ee 100755 --- a/source/mircoders/media/MediaHandlerRealVideo.java +++ b/source/mircoders/media/MediaHandlerRealVideo.java @@ -1,19 +1,48 @@ /* - * put your module comment here + * Copyright (C) 2001, 2002 The Mir-coders group + * + * This file is part of Mir. + * + * Mir is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * Mir is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Mir; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + * In addition, as a special exception, The Mir-coders gives permission to link + * the code of this program with the com.oreilly.servlet library, any library + * licensed under the Apache Software License, The Sun (tm) Java Advanced + * Imaging library (JAI), The Sun JIMI library (or with modified versions of + * the above that use the same license as the above), and distribute linked + * combinations including the two. You must obey the GNU General Public + * License in all respects for all of the code used other than the above + * mentioned libraries. If you modify this file, you may extend this exception + * to your version of the file, but you are not obligated to do so. If you do + * not wish to do so, delete this exception statement from your version. */ - package mircoders.media; -import java.util.*; +import java.io.File; +import java.io.StringReader; -import freemarker.template.SimpleList; +import mir.entity.Entity; +import mir.log.LoggerWrapper; +import mir.media.MediaExc; +import mir.media.MediaFailure; +import mir.media.MirMedia; +import mir.misc.FileUtil; +import mir.misc.StringUtil; import freemarker.template.SimpleHash; - -import mir.media.*; -import mir.entity.*; -import mir.misc.*; -import mir.storage.*; +import freemarker.template.SimpleList; @@ -24,46 +53,50 @@ import mir.storage.*; * * @see mir.media.MediaHandlerGeneric * @see mir.media.MirMedia - * @author john , mh - * @version 11.10.2001 + * @author john , mh + * @version $Id: MediaHandlerRealVideo.java,v 1.18 2003/03/09 19:14:21 idfx Exp $ */ -public class MediaHandlerRealVideo extends MediaHandlerVideo implements - MirMedia +public class MediaHandlerRealVideo extends MediaHandlerVideo implements MirMedia { - public void produce (Entity ent, Entity mediaTypeEnt ) - throws MirMediaException { + protected LoggerWrapper logger; + + public MediaHandlerRealVideo() { + logger = new LoggerWrapper("Media.Video.Real"); + } + public void produce (Entity ent, Entity mediaTypeEnt) throws MediaExc, MediaFailure { // first see if the file exists super.produce(ent, mediaTypeEnt); String baseName = ent.getId(); String date = ent.getValue("date"); String datePath = StringUtil.webdbDate2path(date); - String rtspDir = MirConfig.getProp("Producer.RealMedia.Path"); - String rtspMediaHost = MirConfig.getProp("Producer.RealMedia.Host"); + String rtspDir = configuration.getString("Producer.RealMedia.Path"); + String rtspMediaHost = configuration.getString("Producer.RealMedia.Host"); String RealMediaPointer = rtspMediaHost+ent.getValue("publish_path"); String RealMediaFile = datePath+ent.getId()+".ram"; try { //write an rm (ram?. -mh) file - FileUtil.write(super.getStoragePath()+"/"+RealMediaFile, - RealMediaPointer.getBytes()); - } catch (Exception e) { - theLog.printError(e.toString()); - throw new MirMediaException(e.toString()); + FileUtil.write(super.getStoragePath()+File.separator+RealMediaFile, + new StringReader(RealMediaPointer), "US-ASCII"); + } + catch (Throwable e) { + logger.error("MediaHandlerRealVideo.produce: " + e.toString()); + + throw new MediaFailure(e); } } - public SimpleList getURL(Entity ent, Entity mediaTypeEnt) - { + public SimpleList getURL(Entity ent, Entity mediaTypeEnt) { SimpleList theList = new SimpleList(); //String stringSize = ent.getValue("size"); //int size = Integer.parseInt(stringSize, 10)/1024; theList.add(ent); - + String basePath=StringUtil.regexpReplace(ent.getValue("publish_path"), ".rm$",""); @@ -71,7 +104,7 @@ public class MediaHandlerRealVideo extends MediaHandlerVideo implements // somehow SimpleHash ramHash = new SimpleHash(); ramHash.put("publish_path", basePath+".ram"); - ramHash.put("publish_server", MirConfig.getProp("Producer.Media.Host")); + ramHash.put("publish_server", configuration.getString("Producer.Media.Host")); ramHash.put("title", "stream URL"); theList.add(ramHash); @@ -79,22 +112,19 @@ public class MediaHandlerRealVideo extends MediaHandlerVideo implements } - public String getStoragePath() - { - return MirConfig.getProp("Producer.RealMedia.Path"); + public String getStoragePath() { + return configuration.getString("Producer.RealMedia.Path"); } - public String getDescr(Entity mediaType) - { - return "RealMedia Video"; + public String getDescr(Entity mediaType) { + return "RealMedia"; } - public String getPublishHost() - { - return MirConfig.getProp("Producer.RealMedia.Host"); + public String getPublishHost() { + return StringUtil.removeSlash(configuration.getString("Producer.RealMedia.Host")); } } - - + +