Dateiverwaltung für die WebBox
ulrich
2017-08-01 5410ce4fccf2d0c91ac914f2c4ab7d93507c3960
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) {
50     Bild bild = new Bild();
51     List<FileRef> files = new ArrayList();
52     StringBuffer path = new StringBuffer(PUB_DIR_PATH); // www/
53     path.append(relPath);
54     File dir = new File(getBase().getAbsolutePath(), path.toString());
55     if(dir.exists()) {
56       File[] fileArray = dir.listFiles();
57       for(int i = 0; i < fileArray.length; i++) {
58         logger.fine(fileArray[i].toURI().toString());
59         String fname = fileArray[i].toURI().toString().replace("file:/", "");
60         if(fileArray[i].isDirectory()) {
61           fname = fname.substring(0, fname.length() - 1);
62         }
63         logger.fine(fname);
64         FileRef ref = new FileRef(fname, fileArray[i].isDirectory());
65         ref.setMimetype(bild.getMimeType(fileArray[i]));
66         files.add(ref);
67       }
68     }
69     return files;
70   }
71   
5410ce 72   /**
U 73    * Inhalte der WebBox listen. Hier wird nur ausgegeben was mit 
74    * einer relativen Pfadangabe ausgehend von www, der oeffentlichen 
75    * Ablage einer WeBox, erreichbar ist. 
76    * 
77    * Andere Inhalte werden nicht ausgegeben.
78    * 
79    * @param relPath der relative Pfad, der von www aus gelistet werden soll, ohne www
80    * @return Liste der Dateien und Ordner am Ort relPath
81    */
82   public List<FileRef> listOrdered(String relPath, String orderBy, String order) {
83     Bild bild = new Bild();
84     List<FileRef> files = new ArrayList();
85     StringBuffer path = new StringBuffer(PUB_DIR_PATH); // www/
86     path.append(relPath);
87     File dir = new File(getBase().getAbsolutePath(), path.toString());
88     if(dir.exists()) {
89       File[] fileArray = dir.listFiles();
90       if(orderBy != null && orderBy.equalsIgnoreCase("date")) {
91         Arrays.sort(fileArray, new FileDateComparator(order));
92       }
93       for(int i = 0; i < fileArray.length; i++) {
94         logger.fine(fileArray[i].toURI().toString());
95         String fname = fileArray[i].toURI().toString().replace("file:/", "");
96         if(fileArray[i].isDirectory()) {
97           fname = fname.substring(0, fname.length() - 1);
98         }
99         logger.fine(fname);
100         FileRef ref = new FileRef(fname, fileArray[i].isDirectory());
101         ref.setMimetype(bild.getMimeType(fileArray[i]));
102         files.add(ref);
103       }
104     }
105     return files;
106   }
107   
fafe1b 108 }