From 5e0727a1e0e25a67caa19bdf75b1aa69a9b843fe Mon Sep 17 00:00:00 2001 From: li-guohao Date: Mon, 14 Aug 2023 14:54:01 +0800 Subject: [PATCH] optimize: link ass file if exists for solve #1 . --- gradle.properties | 2 +- .../run/ikaros/jellyfin/MediaDirInit.java | 71 +++++++++---------- src/main/resources/plugin.yaml | 2 +- 3 files changed, 34 insertions(+), 41 deletions(-) diff --git a/gradle.properties b/gradle.properties index e1a03fc..644068a 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,3 +1,3 @@ group=run.ikaros.jellyfin description=A jellyfin plugin for ikaros. -version=0.6.0 \ No newline at end of file +version=0.6.1 \ No newline at end of file diff --git a/src/main/java/run/ikaros/jellyfin/MediaDirInit.java b/src/main/java/run/ikaros/jellyfin/MediaDirInit.java index 2facf45..58e1412 100644 --- a/src/main/java/run/ikaros/jellyfin/MediaDirInit.java +++ b/src/main/java/run/ikaros/jellyfin/MediaDirInit.java @@ -23,6 +23,7 @@ import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; import java.util.List; +import java.util.Objects; import java.util.Optional; import lombok.extern.slf4j.Slf4j; @@ -178,7 +179,7 @@ private void linkEpisodeFileAndGenerateNfo(Optional bgmTvIdOp, String fileName = file.getName(); String epFileAbsolutePath = file.getFsPath(); - if(epFileAbsolutePath == null) { + if (epFileAbsolutePath == null) { log.warn("skip link episode file, episode file path is null for file: {}", file); return; } @@ -203,7 +204,7 @@ private void linkEpisodeFileAndGenerateNfo(Optional bgmTvIdOp, targetEpisodeFile.getAbsolutePath(), epFileAbsolutePath, e); } // generate nfo file - Integer sequence = episode.getSequence(); + Integer sequence = episode.getSequence(); if (!episodeNfoFile.exists()) { XmlUtils.generateJellyfinEpisodeNfoXml(episodeNfoFile.getAbsolutePath(), episode.getDescription(), @@ -216,52 +217,44 @@ private void linkEpisodeFileAndGenerateNfo(Optional bgmTvIdOp, } // link ass file if exists - String originalFileNameWithNoPostfix = - fileName.substring(0, fileName.indexOf(".")); - log.debug("originalFileNameWithNoPostfix: {}", originalFileNameWithNoPostfix); - fileOperate.findAllByNameLikeAndType(originalFileNameWithNoPostfix, - FileType.DOCUMENT) - .filter( - entity -> { - String fileEntityName = entity.getName(); - String postfix = fileEntityName.substring(fileEntityName.indexOf(".") + 1); - boolean result = postfix.endsWith("ass"); - log.debug("fileEntityName: [{}], postfix: [{}], end with ass: [{}].", - fileEntityName, postfix, result); - return result; - }) - .subscribe(entity -> { - String fsPath = entity.getFsPath(); - log.debug("ass file file system path: {}", fsPath); - if (StringUtils.hasText(fsPath)) { - File assFile = new File(fsPath); - log.debug("ass file exists: {}", assFile.exists()); - if (assFile.exists()) { - File targetAssFile = new File(subjectDirAbsolutePath - + File.separatorChar + entity.getName()); - try { - log.debug("targetAssFile exists: {}.", targetAssFile.exists()); - if (!targetAssFile.exists()) { - Files.createLink(targetAssFile.toPath(), assFile.toPath()); - log.debug("create jellyfin episode subtitle hard link success, " - + "link={}, existing={}", - targetAssFile.getAbsolutePath(), fsPath); - } - } catch (IOException e) { - log.debug("create jellyfin episode subtitle hard link fail, " + if (Objects.nonNull(episode.getResources()) && !episode.getResources().isEmpty() + && Objects.nonNull(episode.getResources().get(0)) + && Objects.nonNull(episode.getResources().get(0).getSubtitles()) + && !episode.getResources().get(0).getSubtitles().isEmpty()) { + List subtitles = episode.getResources().get(0).getSubtitles(); + for (Subtitle subtitle : subtitles) { + String subtitleName = subtitle.getName(); + String url = subtitle.getUrl(); + String assFilePath = url.startsWith("http") ? "" : ikarosProperties.getWorkDir() + url; + File assFile = new File(assFilePath); + log.debug("ass file exists: {}", assFile.exists()); + if (assFile.exists()) { + File targetAssFile = new File(subjectDirAbsolutePath + + File.separatorChar + subtitleName); + try { + log.debug("targetAssFile exists: {}.", targetAssFile.exists()); + if (!targetAssFile.exists()) { + Files.createLink(targetAssFile.toPath(), assFile.toPath()); + log.debug("create jellyfin episode subtitle hard link success, " + "link={}, existing={}", - targetAssFile.getAbsolutePath(), fsPath, e); + targetAssFile.getAbsolutePath(), subtitleName); } + } catch (IOException e) { + log.debug("create jellyfin episode subtitle hard link fail, " + + "link={}, existing={}", + targetAssFile.getAbsolutePath(), subtitleName, e); } } - }); + } + } + } else { // 剧集文件不存在,可能是已经推送到了远端 // 如果此时媒体目录的剧集文件和nfo文件存在,则删除 - if(targetEpisodeFile.exists()) { + if (targetEpisodeFile.exists()) { targetEpisodeFile.delete(); } - if(episodeNfoFile.exists()) { + if (episodeNfoFile.exists()) { episodeNfoFile.delete(); } } diff --git a/src/main/resources/plugin.yaml b/src/main/resources/plugin.yaml index cf775a8..c1288ea 100644 --- a/src/main/resources/plugin.yaml +++ b/src/main/resources/plugin.yaml @@ -4,7 +4,7 @@ name: PluginJellyfin # plugin entry class that extends BasePlugin clazz: run.ikaros.jellyfin.JellyfinPlugin # plugin 'version' is a valid semantic version string (see semver.org). -version: 0.6.0 +version: 0.6.1 requires: ">=0.6.0" author: name: Ikaros OSS Team