From 5c621434b008d1671accfc4b9c9c9016a256fd9f Mon Sep 17 00:00:00 2001
From: ulrich
Date: Wed, 21 Apr 2021 09:42:16 +0000
Subject: [PATCH] Ein/Aus-Schalter verbessert
---
src/de/uhilger/mediaz/store/FileStorage.java | 47 ++++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 44 insertions(+), 3 deletions(-)
diff --git a/src/de/uhilger/mediaz/store/FileStorage.java b/src/de/uhilger/mediaz/store/FileStorage.java
index e8ce068..f855d4e 100644
--- a/src/de/uhilger/mediaz/store/FileStorage.java
+++ b/src/de/uhilger/mediaz/store/FileStorage.java
@@ -19,9 +19,10 @@
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;
@@ -31,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;
@@ -55,6 +59,10 @@
/** 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 final String fileBase;
@@ -66,9 +74,19 @@
// 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);
}
/**
@@ -120,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];
}
@@ -164,7 +183,7 @@
}
return list;
}
-
+
@Override
public TypeToken typeFromName(String name) {
return types.get(name);
@@ -195,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