/* AV-Direktor - Control OMXPlayer on Raspberry Pi via HTTP 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 . */ package de.uhilger.calypso.handler; import com.sun.net.httpserver.HttpExchange; import de.uhilger.calypso.App; 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; /** * 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) * * ?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) { super(cmd); } @Override protected StringBuilder buildParams(HttpExchange t) { StringBuilder params = super.buildParams(t); params.append(App.getPlayer().buildParams(t, map)); return params; } /* protected StringBuilder buildParams(HttpExchange t) { StringBuilder params = super.buildParams(t); params.append("-o "); params.append(getParam(map, "o")); params.append(" --threshold "); params.append(getParam(map, "th")); params.append(" --timeout "); params.append(getParam(map, "ti")); String log = getParam(map, "log"); if (log != null && log.equalsIgnoreCase("true")) { params.append(" --genlog"); } return params; } */ @Override protected String process(HttpExchange t, String params) { if (cmd.equalsIgnoreCase(BasePlayer.F_PLAY)) { try { //FileUtils.deleteDirectory(new File(System.getProperty("omx.wd"), "omx-logs")); FileSystem fs = FileSystems.getDefault(); Path path = fs.getPath(System.getProperty("omx.wd"), "omx-logs"); if(path.toFile().exists()) { deleteDirectory(path); } //Files.delete(path); } catch (IOException ex) { logger.log(Level.SEVERE, null, ex); } } Player player = App.getPlayer(); String antwort = player.abspielen( player.getParam(map, "titel"), params, player.getParam(map, "r"), "1"); logger.log(Level.FINE, antwort); return antwort; } protected void deleteDirectory(Path start) throws IOException { Files.walkFileTree(start, new SimpleFileVisitor() { @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; } } }); } }