Dateiverwaltung für die WebBox
ulrich
2017-08-04 17414d294543dddddad631bb427d2349326edfaf
commit | author | age
fafe1b 1 /*
U 2     Dateiverwaltung - File management in your browser
3     Copyright (C) 2017 Ulrich Hilger, http://uhilger.de
4
5     This program is free software: you can redistribute it and/or modify
6     it under the terms of the GNU Affero General Public License as
7     published by the Free Software Foundation, either version 3 of the
8     License, or (at your option) any later version.
9
10     This program is distributed in the hope that it will be useful,
11     but WITHOUT ANY WARRANTY; without even the implied warranty of
12     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13     GNU Affero General Public License for more details.
14
15     You should have received a copy of the GNU Affero General Public License
16     along with this program.  If not, see <http://www.gnu.org/licenses/>.
17 */
18
19 package de.uhilger.filecms.pub;
20
21 import de.uhilger.filecms.api.Api;
22 import de.uhilger.filecms.data.Bild;
23 import de.uhilger.filecms.data.FileRef;
24 import java.io.File;
25 import java.util.ArrayList;
5410ce 26 import java.util.Arrays;
U 27 import java.util.Comparator;
fafe1b 28 import java.util.List;
U 29 import java.util.logging.Logger;
30
31 /**
32  * Methoden zur Arbeit mit Inhalten in der oeffentlichen 
33  * Ablage einer WebBox
34  */
35 public class Catalog extends Api {
36
37   private static final Logger logger = Logger.getLogger(Catalog.class.getName());
38   
39   /**
40    * Inhalte der WebBox listen. Hier wird nur ausgegeben was mit 
41    * einer relativen Pfadangabe ausgehend von www, der oeffentlichen 
42    * Ablage einer WeBox, erreichbar ist. 
43    * 
44    * Andere Inhalte werden nicht ausgegeben.
45    * 
46    * @param relPath der relative Pfad, der von www aus gelistet werden soll, ohne www
47    * @return Liste der Dateien und Ordner am Ort relPath
48    */
49   public List<FileRef> list(String relPath) {
301e44 50     return listInt(relPath, null, null);
fafe1b 51   }
U 52   
5410ce 53   /**
U 54    * Inhalte der WebBox listen. Hier wird nur ausgegeben was mit 
55    * einer relativen Pfadangabe ausgehend von www, der oeffentlichen 
56    * Ablage einer WeBox, erreichbar ist. 
57    * 
58    * Andere Inhalte werden nicht ausgegeben.
59    * 
60    * @param relPath der relative Pfad, der von www aus gelistet werden soll, ohne www
61    * @return Liste der Dateien und Ordner am Ort relPath
62    */
63   public List<FileRef> listOrdered(String relPath, String orderBy, String order) {
301e44 64     return listInt(relPath, orderBy, order);
U 65   }
66   
67   private List<FileRef> listInt(String relPath, String orderBy, String order) {
68      Bild bild = new Bild();
5410ce 69     List<FileRef> files = new ArrayList();
U 70     StringBuffer path = new StringBuffer(PUB_DIR_PATH); // www/
71     path.append(relPath);
72     File dir = new File(getBase().getAbsolutePath(), path.toString());
73     if(dir.exists()) {
74       File[] fileArray = dir.listFiles();
75       if(orderBy != null && orderBy.equalsIgnoreCase("date")) {
76         Arrays.sort(fileArray, new FileDateComparator(order));
77       }
78       for(int i = 0; i < fileArray.length; i++) {
79         logger.fine(fileArray[i].toURI().toString());
80         String fname = fileArray[i].toURI().toString().replace("file:/", "");
81         if(fileArray[i].isDirectory()) {
82           fname = fname.substring(0, fname.length() - 1);
83         }
84         logger.fine(fname);
85         FileRef ref = new FileRef(fname, fileArray[i].isDirectory());
86         ref.setMimetype(bild.getMimeType(fileArray[i]));
87         files.add(ref);
88       }
89     }
90     return files;
301e44 91  }
5410ce 92   
fafe1b 93 }