From d027b57c66dcdb183683c34101518df1572c1bf8 Mon Sep 17 00:00:00 2001 From: ulrich Date: Mon, 12 Apr 2021 16:53:30 +0000 Subject: [PATCH] Livestreams erste Fassung fertig --- src/de/uhilger/mediaz/store/FileStorage.java | 80 +++++++++++++++++++++++++++++++--------- 1 files changed, 62 insertions(+), 18 deletions(-) diff --git a/src/de/uhilger/mediaz/store/FileStorage.java b/src/de/uhilger/mediaz/store/FileStorage.java index bf06140..ce6b60f 100644 --- a/src/de/uhilger/mediaz/store/FileStorage.java +++ b/src/de/uhilger/mediaz/store/FileStorage.java @@ -19,9 +19,11 @@ import com.google.gson.Gson; import com.google.gson.reflect.TypeToken; -import de.uhilger.mediaz.App; import de.uhilger.mediaz.Server; import de.uhilger.mediaz.entity.Ablageort; +import de.uhilger.mediaz.entity.Abspieler; +import de.uhilger.mediaz.entity.Abspielliste; +import de.uhilger.mediaz.entity.Einstellung; import java.io.BufferedReader; import java.io.File; import java.io.FileNotFoundException; @@ -30,6 +32,8 @@ import java.io.IOException; import java.util.logging.Logger; import de.uhilger.mediaz.entity.Entity; +import de.uhilger.mediaz.entity.Livestream; +import de.uhilger.mediaz.entity.Titel; import java.util.ArrayList; import java.util.HashMap; import java.util.List; @@ -53,18 +57,32 @@ /** StorageType Ablageort */ public static final String ST_ABLAGEORT = "Ablageort"; + public static final String ST_EINSTELLUNG = "Einstellung"; + public static final String ST_ABSPIELER = "Abspieler"; + public static final String ST_ABSPIELLISTE = "Abspielliste"; + public static final String ST_LIVESTREAM = "Livestream"; - private String fileBase; + private final String fileBase; - private Map<String, TypeToken> types; + private final Map<String, TypeToken> types; public FileStorage(String base) { this.fileBase = base; // Beispiel: TypeToken<List<String>> list = new TypeToken<List<String>>() {}; TypeToken<Ablageort> ttAblageort = new TypeToken<Ablageort>() {}; + TypeToken<Einstellung> ttEinstellung = new TypeToken<Einstellung>() {}; + TypeToken<Abspieler> ttAbspieler = new TypeToken<Abspieler>() {}; + TypeToken<Abspielliste> ttAbspielliste = new TypeToken<Abspielliste>() {}; + TypeToken<Livestream> ttLivestream = new TypeToken<Livestream>() {}; + TypeToken<Titel> ttTitel = new TypeToken<Titel>() {}; types = new HashMap(); types.put(Ablageort.class.getSimpleName(), ttAblageort); + types.put(Einstellung.class.getSimpleName(), ttEinstellung); + types.put(Abspieler.class.getSimpleName(), ttAbspieler); + types.put(Abspielliste.class.getSimpleName(), ttAbspielliste); + types.put(Titel.class.getSimpleName(), ttTitel); + types.put(Livestream.class.getSimpleName(), ttLivestream); } /** @@ -72,13 +90,17 @@ * * Es wird in den Ordner geschrieben, der von conf angegeben ist * - * Wenn es z.B. ein Ablage-Objekt ist, wird das Objekt in die Datei - * [conf]/Ablage/[name der Ablage].json geschrieben - * - * Der Name der Ablage muss eindeutig sein + * Wenn es z.B.ein Ablage-Objekt ist, wird das Objekt in die Datei + [conf]/Ablage/[name der Ablage].json geschrieben + + Der Name der Ablage muss eindeutig sein * * - * @param entity + * @param entity das Objekt, das geschrieben werden soll + * @param overwrite true, wenn Aenderung, false fuer neue Elemente + * @return die Datei oder null, wenn die Datei existiert und ein + * neues Element (overwrite=false) uebergeben wurde + * @throws java.io.IOException */ public File writeToFile(Entity entity, boolean overwrite) throws IOException { String className = entity.getClass().getSimpleName(); @@ -86,9 +108,6 @@ File dir = new File(fileBase, className); dir.mkdirs(); File file = new File(dir, entity.getName()); - //if(file.exists()) { - // file.delete(); - //} if(file.exists() && !overwrite) { return null; } else { @@ -115,12 +134,13 @@ public Entity entityFromFile(File file) throws ClassNotFoundException, FileNotFoundException, IOException { String json = readFromFile(file); + logger.finer("json: " + json); Gson gson = new Gson(); return gson.fromJson(json, typeFromName(typeNameFromPath(file)).getType()); } private String typeNameFromPath(File file) { - String[] parts = file.getPath().split(App.getRs(Server.RB_SLASH)); + String[] parts = file.getPath().split(Server.SLASH); return parts[parts.length-2]; } @@ -148,16 +168,18 @@ public List<String> list(String typ) { File base = new File(fileBase); File dir = new File(base, typ); - File[] files = dir.listFiles(); List<String> list = new ArrayList(); - for(File file : files) { - //NamedItem n = new NamedItem(); - //n.setLabel(file.getName()); - list.add(file.getName()); + File[] files = dir.listFiles(); + if(files != null) { + for(File file : files) { + //NamedItem n = new NamedItem(); + //n.setLabel(file.getName()); + list.add(file.getName()); + } } return list; } - + @Override public TypeToken typeFromName(String name) { return types.get(name); @@ -188,5 +210,27 @@ return false; } } + + @Override + public List<Entity> listObjects(String typ) { + File base = new File(fileBase); + File dir = new File(base, typ); + List<Entity> list = new ArrayList(); + File[] files = dir.listFiles(); + if(files != null) { + for(File file : files) { + try { + list.add(entityFromFile(file)); + } catch (ClassNotFoundException | IOException ex) { + logger.log(Level.SEVERE, null, ex); + } + } + } + return list; + } + + public boolean exists(String typ, String name) { + return getFile(typ, name).exists(); + } } -- Gitblit v1.9.3