From e44ed0d9811b0c53b3288c54d15e2f68b8d650ed Mon Sep 17 00:00:00 2001 From: ulrich Date: Fri, 09 Apr 2021 14:09:45 +0000 Subject: [PATCH] Entitaetslisten vereinheitlicht --- src/de/uhilger/mediaz/store/FileStorage.java | 32 +++++++++++++++++++++++++++++++- 1 files changed, 31 insertions(+), 1 deletions(-) diff --git a/src/de/uhilger/mediaz/store/FileStorage.java b/src/de/uhilger/mediaz/store/FileStorage.java index 4b0ff1a..7a86477 100644 --- a/src/de/uhilger/mediaz/store/FileStorage.java +++ b/src/de/uhilger/mediaz/store/FileStorage.java @@ -23,6 +23,7 @@ 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; @@ -32,6 +33,7 @@ import java.io.IOException; import java.util.logging.Logger; import de.uhilger.mediaz.entity.Entity; +import de.uhilger.mediaz.entity.Titel; import java.util.ArrayList; import java.util.HashMap; import java.util.List; @@ -57,6 +59,7 @@ 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"; private final String fileBase; @@ -69,10 +72,14 @@ 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<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); } /** @@ -124,6 +131,7 @@ 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()); } @@ -168,7 +176,7 @@ } return list; } - + @Override public TypeToken typeFromName(String name) { return types.get(name); @@ -199,5 +207,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