From 6ff352870ec1dfea573fb3e6de370f8020fe0d04 Mon Sep 17 00:00:00 2001 From: ulrich Date: Sun, 04 Apr 2021 08:38:03 +0000 Subject: [PATCH] Umgestellt auf nio.FileSystem --- src/de/uhilger/avdirektor/handler/PlayHandler.java | 74 +++++++++++++++++------- src/de/uhilger/avdirektor/handler/PlayOnHandler.java | 78 ++++++++++++++++---------- src/de/uhilger/avdirektor/handler/OMXPlayer.java | 4 + src/de/uhilger/avdirektor/App.java | 1 4 files changed, 103 insertions(+), 54 deletions(-) diff --git a/src/de/uhilger/avdirektor/App.java b/src/de/uhilger/avdirektor/App.java index 4831380..33906d2 100644 --- a/src/de/uhilger/avdirektor/App.java +++ b/src/de/uhilger/avdirektor/App.java @@ -51,6 +51,7 @@ public static final String IP_PLAYER = "player"; public static final String VLC_PLAYER = "vlc"; public static final String OMX_PLAYER = "omx"; + public static final String OMX_WD = "omx.wd"; private static HashMap initParams; diff --git a/src/de/uhilger/avdirektor/handler/OMXPlayer.java b/src/de/uhilger/avdirektor/handler/OMXPlayer.java index d360e13..0fa96c2 100644 --- a/src/de/uhilger/avdirektor/handler/OMXPlayer.java +++ b/src/de/uhilger/avdirektor/handler/OMXPlayer.java @@ -49,6 +49,8 @@ private static final Logger logger = Logger.getLogger(OMXPlayer.class.getName()); + public static final String NAME = "omxplayer"; + public static final String BLANK = " "; public static final String CMD_DEC_SPEED = "1"; public static final String CMD_DEC_VOL = "-"; @@ -87,7 +89,7 @@ tilgen(); } List<String> kommando = new ArrayList(); - kommando.add("omxplayer"); + kommando.add(NAME); kommando.addAll(Arrays.asList(parameter.split(BLANK))); if(urlStr.startsWith("http")) { kommando.add(urlStr.replace(" ", "%20")); diff --git a/src/de/uhilger/avdirektor/handler/PlayHandler.java b/src/de/uhilger/avdirektor/handler/PlayHandler.java index ce37932..8f34c6d 100644 --- a/src/de/uhilger/avdirektor/handler/PlayHandler.java +++ b/src/de/uhilger/avdirektor/handler/PlayHandler.java @@ -14,40 +14,41 @@ 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.avdirektor.handler; import com.sun.net.httpserver.HttpExchange; import de.uhilger.avdirektor.App; -import java.io.File; import java.io.IOException; +import java.nio.file.FileSystem; +import java.nio.file.FileSystems; +import java.nio.file.FileVisitResult; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.SimpleFileVisitor; +import java.nio.file.attribute.BasicFileAttributes; import java.util.logging.Level; import java.util.logging.Logger; -import org.apache.commons.io.FileUtils; /** * Play - * + * * rpi4-az:9090/avd/play?titel=/Filme/S/sound_city.m4v&th=60&ti=60&o=local - * - * OMXPlayer.abspielenMitParameternUndRueckmeldung( - * String urlStr, String parameter, String meldeUrlStr, String token) * - * Parameter des Aufrufs play als query (th threshold, ti timeout) + * OMXPlayer.abspielenMitParameternUndRueckmeldung( String urlStr, String + * parameter, String meldeUrlStr, String token) * - * ?titel=/Filme/S/sound_city.m4v - * &ti=60 - * &th=60 - * &o=local|hdmi|both - * &r=http://uhilger.de/mc/api/usw + * Parameter des Aufrufs play als query (th threshold, ti timeout) * - * r muss ganz wegbleiben, wenn keine Rueckmeldung gewuescht ist - * + * ?titel=/Filme/S/sound_city.m4v &ti=60 &th=60 &o=local|hdmi|both + * &r=http://uhilger.de/mc/api/usw + * + * r muss ganz wegbleiben, wenn keine Rueckmeldung gewuescht ist + * * @author ulrich */ public class PlayHandler extends CmdHandler { - + private static final Logger logger = Logger.getLogger(PlayHandler.class.getName()); public PlayHandler(String cmd) { @@ -63,25 +64,52 @@ params.append(" --timeout "); params.append(getParam(map, "ti")); String log = getParam(map, "log"); - if(log != null && log.equalsIgnoreCase("true")) { + if (log != null && log.equalsIgnoreCase("true")) { params.append(" --genlog"); } return params; } - + @Override protected String process(HttpExchange t, String params) { - if(cmd.equalsIgnoreCase(OMXPlayer.F_PLAY)) { + if (cmd.equalsIgnoreCase(OMXPlayer.F_PLAY)) { try { - FileUtils.deleteDirectory(new File(System.getProperty("omx.wd"), "omx-logs")); + //FileUtils.deleteDirectory(new File(System.getProperty("omx.wd"), "omx-logs")); + FileSystem fs = FileSystems.getDefault(); + Path path = fs.getPath(System.getProperty("omx.wd"), "omx-logs"); + deleteDirectory(path); + //Files.delete(path); } catch (IOException ex) { logger.log(Level.SEVERE, null, ex); } } - String antwort = App.getPlayer().abspielen( - getParam(map, "titel"), params, getParam(map, "r"), "1"); + String antwort = App.getPlayer().abspielen( + getParam(map, "titel"), params, getParam(map, "r"), "1"); logger.log(Level.FINE, antwort); return antwort; } + protected void deleteDirectory(Path start) throws IOException { + Files.walkFileTree(start, new SimpleFileVisitor<Path>() { + @Override + public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) + throws IOException { + Files.delete(file); + return FileVisitResult.CONTINUE; + } + + @Override + public FileVisitResult postVisitDirectory(Path dir, IOException e) + throws IOException { + if (e == null) { + Files.delete(dir); + return FileVisitResult.CONTINUE; + } else { + // directory iteration failed + throw e; + } + } + }); + } + } diff --git a/src/de/uhilger/avdirektor/handler/PlayOnHandler.java b/src/de/uhilger/avdirektor/handler/PlayOnHandler.java index ea6dd8b..5fcf37e 100644 --- a/src/de/uhilger/avdirektor/handler/PlayOnHandler.java +++ b/src/de/uhilger/avdirektor/handler/PlayOnHandler.java @@ -1,69 +1,87 @@ package de.uhilger.avdirektor.handler; import com.sun.net.httpserver.HttpExchange; -import com.sun.net.httpserver.HttpHandler; import de.uhilger.avdirektor.App; import de.uhilger.avdirektor.OMXLogLeser; import java.io.File; import java.io.FileNotFoundException; import java.io.IOException; +import java.nio.file.FileSystem; +import java.nio.file.FileSystems; +import java.nio.file.Files; +import java.nio.file.Path; +import static java.nio.file.StandardCopyOption.REPLACE_EXISTING; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.logging.Level; import java.util.logging.Logger; -import org.apache.commons.io.FileUtils; /** - * z.B. + * z.B. * http://rpi4-az:9090/avd/playon?th=1&ti=240&o=local&log=true&titel=http://amd-srv:9090/srv/Filme/C/casino_royale.m4v + * * @author ulrich */ public class PlayOnHandler extends PlayHandler { + + private static final Logger logger = Logger.getLogger(PlayOnHandler.class.getName()); - private static final Logger logger = Logger.getLogger(PlayOnHandler.class.getName()); - - SimpleDateFormat sdf = new SimpleDateFormat("yyyy-mm-dd-hh-MM-ss"); + public static final String LOG_DIR = "omx-logs"; + public static final String LOG_EXT = "log"; + public static final String DASH = "-"; + public static final String DOT = "."; + + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd-HH-mm-ss"); public PlayOnHandler(String cmd) { super(cmd); } - + /* 1. buildParams 2. process - */ - + */ @Override protected StringBuilder buildParams(HttpExchange t) { - String wd = System.getProperty("omx.wd"); - File targetDir = new File(wd, "omx-logs"); - try { - File logFile = new File(wd, "omxplayer.log"); - Date date = new Date(logFile.lastModified()); - File srcFile = new File(wd, "omxplayer-" + sdf.format(date) + ".log"); - logFile.renameTo(srcFile); - targetDir.mkdirs(); - FileUtils.moveFileToDirectory(srcFile, targetDir, false); - } catch (IOException ex) { - Logger.getLogger(PlayOnHandler.class.getName()).log(Level.SEVERE, null, ex); - } + File logDir = logSichern(); StringBuilder params = super.buildParams(t); params.append(" --pos "); try { - // hier das Ergebnis der Log-Auswertung angeben - params.append(logsLesen(targetDir)); - } catch (IOException ex) { - Logger.getLogger(PlayOnHandler.class.getName()).log(Level.SEVERE, null, ex); - } catch (ParseException ex) { - Logger.getLogger(PlayOnHandler.class.getName()).log(Level.SEVERE, null, ex); + params.append(dauerBestimmen(logDir)); + } catch (IOException | ParseException ex) { + logger.log(Level.SEVERE, null, ex); } return params; - } + } + + private File logSichern() { + String wd = System.getProperty(App.OMX_WD); + File zielOrdner = new File(wd, LOG_DIR); + try { + // omxplayer.log umbenennen + FileSystem fs = FileSystems.getDefault(); + Path logDatei = fs.getPath(wd, OMXPlayer.NAME + DOT + LOG_EXT); + Date now = new Date(); + String neuerName = OMXPlayer.NAME + DASH + sdf.format(now) + DOT + LOG_EXT; + Files.move(logDatei, logDatei.resolveSibling(neuerName)); - private String logsLesen(File logDir) throws IOException, FileNotFoundException, ParseException { + // Unterverzeichnis ggf. erzeugen + zielOrdner.mkdirs(); + + // omxplayer-datum.log verschieben + Path quellDatei = fs.getPath(wd, neuerName); + Path zielPfad = fs.getPath(wd, LOG_DIR); + Files.move(quellDatei, zielPfad.resolve(quellDatei.getFileName()), REPLACE_EXISTING); + } catch (IOException ex) { + logger.log(Level.SEVERE, null, ex); + } + return zielOrdner; + } + + private String dauerBestimmen(File logDir) throws IOException, FileNotFoundException, ParseException { OMXLogLeser leser = new OMXLogLeser(); return leser.logDirLesen(logDir); } - + } -- Gitblit v1.9.3