Persoenliche Mediazentrale
ulrich
2021-04-21 a07e7e7a3010da502deea0e5020189cb7f8477bc
src/de/uhilger/mediaz/store/FileStorage.java
@@ -1,15 +1,29 @@
/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
  Mediazentrale - Personal Media Center
  Copyright (C) 2021  Ulrich Hilger
  This program is free software: you can redistribute it and/or modify
  it under the terms of the GNU Affero General Public License as
  published by the Free Software Foundation, either version 3 of the
  License, or (at your option) any later version.
  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU Affero General Public License for more details.
  You should have received a copy of the GNU Affero General Public License
  along with this program.  If not, see <https://www.gnu.org/licenses/>.
 */
package de.uhilger.mediaz.store;
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;
@@ -18,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;
@@ -25,7 +42,7 @@
import java.util.logging.Level;
/**
 * Ablage fuer Dateien
 * Ablage fuer Dateien der Mediazentrale
 * 
 * [Basispfad]/[Typ]/[Name]
 * 
@@ -41,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;
    
    //TypeToken<List<String>> list = new TypeToken<List<String>>() {};
    // 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);
  }
  
  /**
@@ -60,65 +94,64 @@
   * 
   * 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 o
   * @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 o) throws IOException {
    Gson gson = new Gson();
    String className = o.getClass().getSimpleName();
  public File writeToFile(Entity entity, boolean overwrite) throws IOException {
    String className = entity.getClass().getSimpleName();
    logger.finer(className); 
    File dir = new File(fileBase, className);
    dir.mkdirs();
    File file = new File(dir, o.getName());
    if(file.exists()) {
      file.delete();
    File file = new File(dir, entity.getName());
    if(file.exists() && !overwrite) {
      return null;
    } else {
      FileWriter fw = new FileWriter(file);
      Gson gson = new Gson();
      fw.write(gson.toJson(entity));
      fw.flush();
      fw.close();
      return file;
    }
    FileWriter fw = new FileWriter(file);
    fw.write(gson.toJson(o));
    fw.flush();
    fw.close();
    return file;
  }
  
  public Entity readFromFile(File file) throws ClassNotFoundException, FileNotFoundException, IOException {
    String type = typeNameFromPath(file);
  public String readFromFile(File file) throws IOException {
    StringBuilder sb = new StringBuilder();
    FileReader in = new FileReader(file);
    BufferedReader r = new BufferedReader(in);
    BufferedReader r = new BufferedReader(new FileReader(file));
    String line = r.readLine();
    while(line != null) {
      sb.append(line);
      line = r.readLine();
    }
    r.close();
    in.close();
    String json = sb.toString();
    return sb.toString();
  }
  public Entity entityFromFile(File file) throws ClassNotFoundException, FileNotFoundException, IOException {
    String json = readFromFile(file);
    logger.finer("json: " + json);
    Gson gson = new Gson();
    switch(type) {
      case ST_ABLAGEORT:
        return gson.fromJson(json, Ablageort.class);
      default:
        Ablageort ablage = new Ablageort();
        ablage.setName("Test");
        return ablage;
    }
    return gson.fromJson(json, typeFromName(typeNameFromPath(file)).getType());
  }
  
  private String typeNameFromPath(File file) {
    String[] parts = file.getPath().split(App.getRs(Server.RB_SLASH));
    logger.info(parts[parts.length-2]);
    String[] parts = file.getPath().split(Server.SLASH);
    return parts[parts.length-2];
  }
  @Override
  public Object write(Entity e) {
  public Object write(Entity e, boolean overwrite) {
    try {
      return writeToFile(e);
      return writeToFile(e, overwrite);
    } catch (IOException ex) {
      logger.log(Level.SEVERE, null, ex);
      return null;
@@ -127,11 +160,8 @@
  @Override
  public Entity read(String typ, String name) {
    File base = new File(fileBase);
    File dir = new File(base, typ);
    File file = new File(dir, name);
    try {
      return readFromFile(file);
      return entityFromFile(getFile(typ, name));
    } catch (ClassNotFoundException | IOException ex) {
      logger.log(Level.SEVERE, null, ex);
      return null;
@@ -142,19 +172,69 @@
  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) {
      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);
  }
  @Override
  public String readJson(String typ, String name) {
    try {
      return readFromFile(getFile(typ, name));
    } catch (IOException ex) {
      logger.log(Level.SEVERE, null, ex);
      return null;
    }
  }
  
  private File getFile(String typ, String name) {
    File base = new File(fileBase);
    File dir = new File(base, typ);
    return new File(dir, name);
  }
  @Override
  public boolean delete(String typ, String name) {
    File file = getFile(typ, name);
    if(file.exists()) {
      return file.delete();
    } else {
      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();
  }
  
}