501a865e58ee53c2e25eb183ecbfbd0e2277a37f
[mir.git] / source / mircoders / media / AbstractMediaHandler.java
1 /*
2  * Copyright (C) 2001, 2002 The Mir-coders group
3  *
4  * This file is part of Mir.
5  *
6  * Mir is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * Mir is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Mir; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  * In addition, as a special exception, The Mir-coders gives permission to link
21  * the code of this program with  any library licensed under the Apache Software License,
22  * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library
23  * (or with modified versions of the above that use the same license as the above),
24  * and distribute linked combinations including the two.  You must obey the
25  * GNU General Public License in all respects for all of the code used other than
26  * the above mentioned libraries.  If you modify this file, you may extend this
27  * exception to your version of the file, but you are not obligated to do so.
28  * If you do not wish to do so, delete this exception statement from your version.
29  */
30 package mircoders.media;
31
32 import mir.entity.Entity;
33 import mir.media.MediaExc;
34 import mir.media.MediaFailure;
35 import mir.media.MediaHandler;
36 import mir.misc.StringUtil;
37
38 import java.io.*;
39
40 public abstract class AbstractMediaHandler implements MediaHandler {
41   protected InputStream getStorageInputStream(Entity aMedia, Entity aMediaType) throws MediaExc, MediaFailure {
42     try {
43       return new FileInputStream(getMediaStorageFile(aMedia, aMediaType));
44     }
45     catch (Throwable e) {
46       throw new MediaFailure(e);
47     }
48   }
49
50   protected OutputStream getStorageOutputStream(Entity aMedia, Entity aMediaType) throws MediaExc, MediaFailure {
51     try {
52       return new FileOutputStream(getMediaStoragePath(aMedia, aMediaType));
53     }
54     catch (Throwable e) {
55       throw new MediaFailure(e);
56     }
57   }
58
59   protected String getRelativeMediaStoragePath(Entity aMedia, Entity aMediaType) {
60     String publishPath = aMedia.getFieldValue("publish_path");
61
62     if (publishPath==null || publishPath.length()==0) {
63       String extension = aMediaType.getFieldValue("name");
64       String mediaFileName = aMedia.getId() + "." + extension;
65       String date = aMedia.getFieldValue("date");
66       String datePath = StringUtil.webdbDate2path(date);
67
68       return datePath + "/" + mediaFileName;
69     }
70
71                 return publishPath;
72   }
73
74   protected String getMediaStoragePath(Entity aMedia, Entity aMediaType) throws MediaExc, MediaFailure {
75     return getBaseStoragePath() + "/" + getRelativeMediaStoragePath(aMedia, aMediaType);
76   }
77
78   protected final File getMediaStorageFile(Entity aMedia, Entity aMediaType) throws MediaExc, MediaFailure {
79     return new File(getMediaStoragePath(aMedia, aMediaType));
80   }
81
82 }