From 275b2136b8c8eee4efaa7e9d325d9e283a8687ed Mon Sep 17 00:00:00 2001
From: ulrich
Date: Wed, 21 Apr 2021 16:55:18 +0000
Subject: [PATCH] Fehler in Breadcrumb-Links berichtigt
---
src/de/uhilger/mediaz/store/FileStorage.java | 72 +++++++++++++++++++++++++++++------
1 files changed, 59 insertions(+), 13 deletions(-)
diff --git a/src/de/uhilger/mediaz/store/FileStorage.java b/src/de/uhilger/mediaz/store/FileStorage.java
index 524e4d2..f855d4e 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,9 @@
import java.io.IOException;
import java.util.logging.Logger;
import de.uhilger.mediaz.entity.Entity;
+import de.uhilger.mediaz.entity.Geraet;
+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 +58,35 @@
/** 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";
+ public static final String ST_GERAET = "Geraet";
- 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<Geraet> ttGeraet = new TypeToken<Geraet>() {};
+ 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);
+ types.put(Geraet.class.getSimpleName(), ttGeraet);
}
/**
@@ -72,13 +94,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 +112,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 +138,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];
}
@@ -159,7 +183,7 @@
}
return list;
}
-
+
@Override
public TypeToken typeFromName(String name) {
return types.get(name);
@@ -190,5 +214,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