还原部分代码片段 并尝试修复 (#3)
This commit is contained in:
parent
5fb48e8921
commit
612c2a5422
@ -9,7 +9,7 @@ ENV LC_ALL=en_US.UTF-8 LANG=en_US.UTF-8 LANGUAGE=en_US.UTF-8
|
||||
|
||||
# Install needed packages and setup non-root user. Use a separate RUN statement to add your own dependencies.
|
||||
ARG USERNAME=root
|
||||
ARG USER_UID=1000
|
||||
ARG USER_UID=0
|
||||
ARG USER_GID=$USER_UID
|
||||
RUN export DEBIAN_FRONTEND=noninteractive \
|
||||
&& apt-get -y update && apt-get -y install wget \
|
||||
@ -27,7 +27,8 @@ RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
|
||||
# Dropping copies of the files in the .devcontainer folder should also work, but I cba to duplicate my build files for this and symlinks aint working I hate computers
|
||||
RUN wget -P /tools https://raw.githubusercontent.com/WindyCloudCute/LANraragi_Chinese/dev/tools/cpanfile \
|
||||
&& wget -P /tools https://raw.githubusercontent.com/WindyCloudCute/LANraragi_Chinese/dev/tools/install.pl \
|
||||
&& wget https://raw.githubusercontent.com/WindyCloudCute/LANraragi_Chinese/dev/package.json
|
||||
&& wget https://raw.githubusercontent.com/WindyCloudCute/LANraragi_Chinese/dev/package.json \
|
||||
&& wget https://raw.githubusercontent.com/WindyCloudCute/LANraragi_Chinese/dev/package-lock.json
|
||||
|
||||
RUN npm run lanraragi-installer install-full
|
||||
|
||||
|
2
.gitignore
vendored
2
.gitignore
vendored
@ -13,4 +13,4 @@ autobackup.json
|
||||
lib/LANraragi/Plugin/Scripts/ETagConverter.pm
|
||||
lib/LANraragi/Plugin/Metadata/ETagCN.pm
|
||||
Makefile
|
||||
oshino
|
||||
oshino
|
||||
|
@ -43,7 +43,7 @@ sub socket {
|
||||
|
||||
my $logger = get_logger( "Batch Tagging", "lanraragi" );
|
||||
|
||||
$logger->info('客户端连接到 Batch Tagging 服务');
|
||||
$logger->info('Client connected to Batch Tagging service');
|
||||
|
||||
# Increase inactivity timeout for connection a bit to account for clientside timeouts
|
||||
$self->inactivity_timeout(80);
|
||||
@ -81,7 +81,7 @@ sub socket {
|
||||
my @args = @{ $command->{"args"} };
|
||||
|
||||
if ( !@args ) {
|
||||
$logger->debug("没有覆盖插件全局参数.");
|
||||
$logger->debug("No user overrides given.");
|
||||
|
||||
# Try getting the saved defaults
|
||||
@args = get_plugin_parameters($pluginname);
|
||||
@ -127,7 +127,7 @@ sub socket {
|
||||
|
||||
if ( $operation eq "tagrules" ) {
|
||||
|
||||
$logger->debug("将标签规则应用于$id...");
|
||||
$logger->debug("Applying tag rules to $id...");
|
||||
my $tags = $redis->hget( $id, "tags" );
|
||||
$tags = redis_decode($tags);
|
||||
|
||||
@ -137,7 +137,7 @@ sub socket {
|
||||
|
||||
# Merge array with commas
|
||||
my $newtags = join( ', ', @tagarray );
|
||||
$logger->debug("新标签: $newtags");
|
||||
$logger->debug("New tags: $newtags");
|
||||
set_tags( $id, $newtags );
|
||||
|
||||
$client->send(
|
||||
@ -155,7 +155,7 @@ sub socket {
|
||||
}
|
||||
|
||||
if ( $operation eq "delete" ) {
|
||||
$logger->debug("正在删除 $id...");
|
||||
$logger->debug("Deleting $id...");
|
||||
|
||||
my $delStatus = LANraragi::Model::Archive::delete_archive($id);
|
||||
|
||||
@ -187,7 +187,7 @@ sub socket {
|
||||
|
||||
# If the client doesn't respond, halt processing
|
||||
finish => sub {
|
||||
$logger->info('客户端断开连接,停止剩余操作');
|
||||
$logger->info('Client disconnected, halting remaining operations');
|
||||
$cancelled = 1;
|
||||
$redis->quit();
|
||||
}
|
||||
|
@ -271,4 +271,50 @@ sub update_metadata {
|
||||
return "";
|
||||
}
|
||||
|
||||
# Deletes the archive with the given id from redis, and the matching archive file/thumbnail.
|
||||
sub delete_archive ($id) {
|
||||
|
||||
my $redis = LANraragi::Model::Config->get_redis;
|
||||
my $filename = $redis->hget( $id, "file" );
|
||||
my $oldtags = $redis->hget( $id, "tags" );
|
||||
$oldtags = redis_decode($oldtags);
|
||||
|
||||
my $oldtitle = lc( redis_decode( $redis->hget( $id, "title" ) ) );
|
||||
$oldtitle = trim($oldtitle);
|
||||
$oldtitle = trim_CRLF($oldtitle);
|
||||
$oldtitle = redis_encode($oldtitle);
|
||||
|
||||
$redis->del($id);
|
||||
$redis->quit();
|
||||
|
||||
# Remove matching data from the search indexes
|
||||
my $redis_search = LANraragi::Model::Config->get_redis_search;
|
||||
$redis_search->zrem( "LRR_TITLES", "$oldtitle\0$id" );
|
||||
$redis_search->srem( "LRR_NEW", $id );
|
||||
$redis_search->srem( "LRR_UNTAGGED", $id );
|
||||
$redis_search->quit();
|
||||
|
||||
LANraragi::Utils::Database::update_indexes( $id, $oldtags, "" );
|
||||
|
||||
if ( -e $filename ) {
|
||||
my $status = unlink $filename;
|
||||
|
||||
my $thumbdir = LANraragi::Model::Config->get_thumbdir;
|
||||
my $subfolder = substr( $id, 0, 2 );
|
||||
|
||||
my $jpg_thumbname = "$thumbdir/$subfolder/$id.jpg";
|
||||
unlink $jpg_thumbname;
|
||||
|
||||
my $jxl_thumbname = "$thumbdir/$subfolder/$id.jxl";
|
||||
unlink $jxl_thumbname;
|
||||
|
||||
# Delete the thumbpages folder
|
||||
remove_tree("$thumbdir/$subfolder/$id/");
|
||||
|
||||
return $status ? $filename : "0";
|
||||
}
|
||||
|
||||
return "0";
|
||||
}
|
||||
|
||||
1;
|
||||
|
@ -60,7 +60,7 @@ sub generate_opds_catalog {
|
||||
version => $mojo->LRR_VERSION,
|
||||
api_key_query => $api_key ? "?key=" . $api_key : "",
|
||||
api_key_and => $api_key ? "&key=" . $api_key : ""
|
||||
);
|
||||
);
|
||||
}else{
|
||||
return $mojo->render_to_string(
|
||||
template => "opds",
|
||||
|
@ -2,7 +2,7 @@ package LANraragi::Model::Plugins;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
use feature 'fc';
|
||||
|
||||
use Redis;
|
||||
|
@ -2,7 +2,7 @@ package LANraragi::Model::Reader;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
|
||||
use Redis;
|
||||
use File::Basename;
|
||||
|
@ -2,8 +2,8 @@ package LANraragi::Model::Search;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
|
||||
use List::Util qw(min);
|
||||
use Redis;
|
||||
use Storable qw/ nfreeze thaw /;
|
||||
@ -27,7 +27,7 @@ sub do_search {
|
||||
my $logger = get_logger( "Search Engine", "lanraragi" );
|
||||
|
||||
unless ( $redis->exists("LAST_JOB_TIME") ) {
|
||||
$logger->error("搜索引擎尚未初始化。 请稍等几秒钟。");
|
||||
$logger->error("Search engine is not initialized yet. Please wait a few seconds.");
|
||||
return ( -1, -1, () );
|
||||
}
|
||||
|
||||
@ -41,7 +41,7 @@ sub do_search {
|
||||
my ( $cachehit, @filtered ) = check_cache( $cachekey, $cachekey_inv );
|
||||
|
||||
unless ($cachehit) {
|
||||
$logger->debug("没有可用的缓存,进行完整的DB解析。");
|
||||
$logger->debug("No cache available, doing a full DB parse.");
|
||||
@filtered = search_uncached( $category_id, $filter, $sortkey, $sortorder, $newonly, $untaggedonly );
|
||||
|
||||
# Cache this query in the search database
|
||||
@ -70,10 +70,10 @@ sub check_cache {
|
||||
|
||||
my @filtered = ();
|
||||
my $cachehit = 0;
|
||||
$logger->debug("搜索请求: $cachekey");
|
||||
$logger->debug("Search request: $cachekey");
|
||||
|
||||
if ( $redis->exists("LRR_SEARCHCACHE") && $redis->hexists( "LRR_SEARCHCACHE", $cachekey ) ) {
|
||||
$logger->debug("将缓存用于此查询。");
|
||||
$logger->debug("Using cache for this query.");
|
||||
$cachehit = 1;
|
||||
|
||||
# Thaw cache and use that as the filtered list
|
||||
@ -81,7 +81,7 @@ sub check_cache {
|
||||
@filtered = @{ thaw $frozendata };
|
||||
|
||||
} elsif ( $redis->exists("LRR_SEARCHCACHE") && $redis->hexists( "LRR_SEARCHCACHE", $cachekey_inv ) ) {
|
||||
$logger->debug("与对面的排序订单存在缓存密钥.");
|
||||
$logger->debug("A cache key exists with the opposite sortorder.");
|
||||
$cachehit = 1;
|
||||
|
||||
# Thaw cache, invert the list to match the sortorder and use that as the filtered list
|
||||
@ -147,7 +147,7 @@ sub search_uncached {
|
||||
my $isneg = $token->{isneg};
|
||||
my $isexact = $token->{isexact};
|
||||
|
||||
$logger->debug("正在搜索 $tag, isneg=$isneg, isexact=$isexact");
|
||||
$logger->debug("Searching for $tag, isneg=$isneg, isexact=$isexact");
|
||||
|
||||
# Encode tag as we'll use it in redis operations
|
||||
$tag = redis_encode($tag);
|
||||
@ -162,7 +162,7 @@ sub search_uncached {
|
||||
my $operator = $2;
|
||||
my $pagecount = $3;
|
||||
|
||||
$logger->debug("搜索具有页面的ID $operator $pagecount $col");
|
||||
$logger->debug("Searching for IDs with $operator $pagecount $col");
|
||||
|
||||
# If no operator is specified, we assume it's an exact match
|
||||
$operator = "=" if !$operator;
|
||||
@ -194,7 +194,7 @@ sub search_uncached {
|
||||
|
||||
# Get the list of IDs for this tag
|
||||
@ids = $redis->smembers("INDEX_$tag");
|
||||
$logger->debug( "找到了 $tag 的索引,包含 " . scalar @ids . "个 ID" );
|
||||
$logger->debug( "Found tag index for $tag, containing " . scalar @ids . " IDs" );
|
||||
} else {
|
||||
|
||||
# Get index keys that match this tag.
|
||||
@ -206,7 +206,7 @@ sub search_uncached {
|
||||
# Get the list of IDs for each key
|
||||
foreach my $key (@keys) {
|
||||
my @keyids = $redis->smembers($key);
|
||||
$logger->trace( "找到了 $tag 的索引 $key,包含了 " . scalar @ids . " 个 ID" );
|
||||
$logger->trace( "Found index $key for $tag, containing " . scalar @ids . " IDs" );
|
||||
push @ids, @keyids;
|
||||
}
|
||||
}
|
||||
@ -218,7 +218,7 @@ sub search_uncached {
|
||||
|
||||
# First iteration
|
||||
if ( $scan == -1 ) { $scan = 0; }
|
||||
$logger->trace("正在扫描 $namesearch, cursor=$scan");
|
||||
$logger->trace("Scanning for $namesearch, cursor=$scan");
|
||||
|
||||
my @result = $redis->zscan( "LRR_TITLES", $scan, "MATCH", $namesearch, "COUNT", 100 );
|
||||
$scan = $result[0];
|
||||
@ -226,7 +226,7 @@ sub search_uncached {
|
||||
foreach my $title ( @{ $result[1] } ) {
|
||||
|
||||
if ( $title eq "0" ) { next; } # Skip scores
|
||||
$logger->trace("找到标题匹配项: $title");
|
||||
$logger->trace("Found title match: $title");
|
||||
|
||||
# Strip everything before \x00 to get the ID out of the key
|
||||
my $id = substr( $title, index( $title, "\x00" ) + 1 );
|
||||
@ -237,11 +237,11 @@ sub search_uncached {
|
||||
if ( scalar @ids == 0 && !$isneg ) {
|
||||
|
||||
# No more results, we can end search here
|
||||
$logger->trace("该标记没有结果,正在停止搜索。");
|
||||
$logger->trace("No results for this token, halting search.");
|
||||
@filtered = ();
|
||||
last;
|
||||
} else {
|
||||
$logger->trace( "找到此标记的 " . scalar @ids . " 个结果." );
|
||||
$logger->trace( "Found " . scalar @ids . " results for this token." );
|
||||
|
||||
# Intersect the new list with the previous ones
|
||||
@filtered = intersect_arrays( \@ids, \@filtered, $isneg );
|
||||
@ -250,7 +250,7 @@ sub search_uncached {
|
||||
}
|
||||
|
||||
if ( $#filtered > 0 ) {
|
||||
$logger->debug( "筛选后找到了 " . $#filtered . " 个结果" );
|
||||
$logger->debug( "Found " . $#filtered . " results after filtering." );
|
||||
|
||||
if ( !$sortkey ) {
|
||||
$sortkey = "title";
|
||||
@ -268,7 +268,7 @@ sub search_uncached {
|
||||
# Remove the titles from the keys, which are stored as "title\x00id"
|
||||
@ordered = map { substr( $_, index( $_, "\x00" ) + 1 ) } @ordered;
|
||||
|
||||
$logger->trace( "有序列表中的示例元素: " . $ordered[0] );
|
||||
$logger->trace( "Example element from ordered list: " . $ordered[0] );
|
||||
|
||||
# Just intersect the ordered list with the filtered one to get the final result
|
||||
@filtered = intersect_arrays( \@filtered, \@ordered, 0 );
|
||||
@ -382,7 +382,7 @@ sub compute_search_filter {
|
||||
}
|
||||
|
||||
# Escape already present regex characters
|
||||
$logger->debug("预转义标签: $tag");
|
||||
$logger->debug("Pre-escaped tag: $tag");
|
||||
|
||||
$tag = trim($tag);
|
||||
|
||||
|
@ -2,7 +2,7 @@ package LANraragi::Model::Stats;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
|
||||
use Redis;
|
||||
use File::Find;
|
||||
@ -21,7 +21,7 @@ sub get_archive_count {
|
||||
sub get_page_stat {
|
||||
|
||||
my $redis = LANraragi::Model::Config->get_redis_config;
|
||||
my $stat = $redis->get("LRR_TOTALPAGESTAT") || 0;
|
||||
my $stat = $redis->get("LRR_TOTALPAGESTAT") || 0;
|
||||
$redis->quit();
|
||||
|
||||
return $stat;
|
||||
|
@ -23,7 +23,7 @@ sub plugin_info {
|
||||
author => "CirnoT, Difegue",
|
||||
version => "2.1",
|
||||
description => " 在Koromo 风格的 Info.json 文件收集作为嵌入到档案中的元数据. ( {'Tags': [xxx] } syntax)",
|
||||
icon =>
|
||||
icon =>
|
||||
"",
|
||||
parameters => []
|
||||
);
|
||||
|
@ -2,7 +2,7 @@ package LANraragi::Plugin::Metadata::Ksk;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
use LANraragi::Model::Plugins;
|
||||
use LANraragi::Utils::Logging qw(get_plugin_logger);
|
||||
use LANraragi::Utils::Archive qw(is_file_in_archive extract_file_from_archive);
|
||||
|
@ -344,7 +344,7 @@ sub set_title ( $id, $newtitle ) {
|
||||
# Set $append to 1 if you want to append the tags instead of replacing them.
|
||||
sub set_tags ( $id, $newtags, $append = 0 ) {
|
||||
|
||||
my $redis = LANraragi::Model::Config->get_redis;
|
||||
my $redis = LANraragi::Model::Config->get_redis;
|
||||
my $oldtags = $redis->hget( $id, "tags" );
|
||||
$oldtags = redis_decode($oldtags);
|
||||
|
||||
|
@ -93,7 +93,7 @@ sub start_minion {
|
||||
my $logger = get_logger( "Minion", "minion" );
|
||||
|
||||
my $numcpus = Sys::CpuAffinity::getNumCpus();
|
||||
$logger->info("在子进程中使用 $numcpus 并行作业启动新的 Minion 工作进程。");
|
||||
$logger->info("Starting new Minion worker in subprocess with $numcpus parallel jobs.");
|
||||
|
||||
my $worker = $mojo->app->minion->worker;
|
||||
$worker->status->{jobs} = $numcpus;
|
||||
@ -103,9 +103,9 @@ sub start_minion {
|
||||
my $proc = Proc::Simple->new();
|
||||
$proc->start(
|
||||
sub {
|
||||
$logger->info("Minion 工作线程 $$ 开始运行");
|
||||
$logger->info("Minion worker $$ started");
|
||||
$worker->run;
|
||||
$logger->info("Minion 工作线程 $$ 停止运行");
|
||||
$logger->info("Minion worker $$ stopped");
|
||||
return 1;
|
||||
}
|
||||
);
|
||||
@ -123,7 +123,7 @@ sub _spawn {
|
||||
my ( $job, $pid ) = @_;
|
||||
my ( $id, $task ) = ( $job->id, $job->task );
|
||||
my $logger = get_logger( "Minion Worker", "minion" );
|
||||
$job->app->log->debug(qq{进程 $pid 正在执行作业 "$id" 和任务 "$task"});
|
||||
$job->app->log->debug(qq{Process $pid is performing job "$id" with task "$task"});
|
||||
}
|
||||
|
||||
# Start Shinobu and return its Proc::Background object.
|
||||
@ -134,7 +134,7 @@ sub start_shinobu {
|
||||
$proc->start( $^X, "./lib/Shinobu.pm" );
|
||||
$proc->kill_on_destroy(0);
|
||||
|
||||
$mojo->LRR_LOGGER->debug( "Shinobu 工作进程新的 PID 为 " . $proc->pid );
|
||||
$mojo->LRR_LOGGER->debug( "Shinobu Worker new PID is " . $proc->pid );
|
||||
|
||||
# Freeze the process object in the PID file
|
||||
store \$proc, get_temp() . "/shinobu.pid";
|
||||
@ -159,7 +159,7 @@ sub shasum {
|
||||
};
|
||||
|
||||
if ($@) {
|
||||
$logger->error( "创建哈希时出错" . $_[0] . " -- " . $@ );
|
||||
$logger->error( "Error building hash for " . $_[0] . " -- " . $@ );
|
||||
|
||||
return "";
|
||||
}
|
||||
|
@ -3,7 +3,7 @@ package LANraragi::Utils::Logging;
|
||||
use strict;
|
||||
use warnings;
|
||||
use utf8;
|
||||
use open ':std', ':encoding(UTF-8)';
|
||||
|
||||
use feature 'say';
|
||||
use POSIX;
|
||||
use FindBin;
|
||||
@ -123,7 +123,7 @@ sub get_lines_from_file {
|
||||
return decode_utf8($res);
|
||||
}
|
||||
|
||||
return "找不到可以显示的日志!\n或者程序没有产生日志。";
|
||||
return "No logs to be found here!";
|
||||
|
||||
}
|
||||
|
||||
|
@ -2,7 +2,7 @@ package LANraragi::Utils::Minion;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
use utf8;
|
||||
|
||||
use Encode;
|
||||
use Mojo::UserAgent;
|
||||
use Parallel::Loops;
|
||||
@ -56,14 +56,14 @@ sub add_tasks {
|
||||
my @keys = $redis->keys('????????????????????????????????????????');
|
||||
$redis->quit();
|
||||
|
||||
$logger->info("开始缩略图重新生成作业 (强制模式 = $force)");
|
||||
$logger->info("Starting thumbnail regen job (force = $force)");
|
||||
my @errors = ();
|
||||
|
||||
my $numCpus = Sys::CpuAffinity::getNumCpus();
|
||||
my $pl = Parallel::Loops->new($numCpus);
|
||||
$pl->share( \@errors );
|
||||
|
||||
$logger->debug("可用于处理的核心数量: $numCpus");
|
||||
$logger->debug("Number of available cores for processing: $numCpus");
|
||||
my @sections = split_workload_by_cpu( $numCpus, @keys );
|
||||
|
||||
# Regen thumbnails for errythang if $force = 1, only missing thumbs otherwise
|
||||
@ -80,12 +80,12 @@ sub add_tasks {
|
||||
|
||||
unless ( $force == 0 && -e $thumbname ) {
|
||||
eval {
|
||||
$logger->debug("正在重新生成:$id...");
|
||||
$logger->debug("Regenerating for $id...");
|
||||
extract_thumbnail( $thumbdir, $id, 0, 1 );
|
||||
};
|
||||
|
||||
if ($@) {
|
||||
$logger->warn("生成缩略图时出错: $@");
|
||||
$logger->warn("Error while generating thumbnail: $@");
|
||||
push @errors, $@;
|
||||
}
|
||||
}
|
||||
@ -130,7 +130,7 @@ sub add_tasks {
|
||||
or die "Bullshit! File path could not be converted back to a byte sequence!"
|
||||
; # This error happening would not make any sense at all so it deserves the EYE reference
|
||||
|
||||
$logger->info("正在处理上传的文件 $file...");
|
||||
$logger->info("Processing uploaded file $file...");
|
||||
|
||||
# Since we already have a file, this goes straight to handle_incoming_file.
|
||||
my ( $status, $id, $title, $message ) = LANraragi::Model::Upload::handle_incoming_file( $file, $catid, "" );
|
||||
@ -153,7 +153,7 @@ sub add_tasks {
|
||||
|
||||
my $ua = Mojo::UserAgent->new;
|
||||
my $logger = get_logger( "Minion", "minion" );
|
||||
$logger->info("正在下载 $url...");
|
||||
$logger->info("Downloading url $url...");
|
||||
|
||||
# Keep a clean copy of the url for display and tagging
|
||||
my $og_url = $url;
|
||||
@ -166,7 +166,7 @@ sub add_tasks {
|
||||
{ success => 0,
|
||||
url => $og_url,
|
||||
id => $recorded_id,
|
||||
message => "链接已被下载!"
|
||||
message => "URL already downloaded!"
|
||||
}
|
||||
);
|
||||
return;
|
||||
@ -177,7 +177,7 @@ sub add_tasks {
|
||||
|
||||
if ($downloader) {
|
||||
|
||||
$logger->info( "发现下载器 " . $downloader->{namespace} );
|
||||
$logger->info( "Found downloader " . $downloader->{namespace} );
|
||||
|
||||
# Use the downloader to transform the URL
|
||||
my $plugname = $downloader->{namespace};
|
||||
@ -197,15 +197,15 @@ sub add_tasks {
|
||||
|
||||
$ua = $plugin_result->{user_agent};
|
||||
$url = $plugin_result->{download_url};
|
||||
$logger->info("插件将 URL 转换为 $url");
|
||||
$logger->info("URL transformed by plugin to $url");
|
||||
} else {
|
||||
$logger->debug("找不到下载器,尝试直接下载 URL.");
|
||||
$logger->debug("No downloader found, trying direct URL.");
|
||||
}
|
||||
|
||||
# Download the URL
|
||||
eval {
|
||||
my $tempfile = LANraragi::Model::Upload::download_url( $url, $ua );
|
||||
$logger->info("URL将会被保存为 $tempfile ");
|
||||
$logger->info("URL downloaded to $tempfile");
|
||||
|
||||
# Add the url as a source: tag
|
||||
my $tag = "source:$og_url";
|
||||
@ -243,7 +243,7 @@ sub add_tasks {
|
||||
my ( $namespace, $id, $scriptarg ) = @args;
|
||||
|
||||
my $logger = get_logger( "Minion", "minion" );
|
||||
$logger->info("运行插件 $namespace...");
|
||||
$logger->info("Running plugin $namespace...");
|
||||
|
||||
my ( $pluginfo, $plugin_result ) = use_plugin( $namespace, $id, $scriptarg );
|
||||
|
||||
|
@ -2,7 +2,7 @@ package LANraragi::Utils::Plugins;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
|
||||
use Mojo::JSON qw(decode_json);
|
||||
use LANraragi::Utils::Database qw(redis_decode);
|
||||
|
@ -2,7 +2,7 @@ package LANraragi::Utils::Routing;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
|
||||
use Mojolicious::Plugin::Status;
|
||||
use Mojolicious::Plugin::Minion::Admin;
|
||||
|
@ -2,7 +2,7 @@ package LANraragi::Utils::Tags;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
use feature "switch";
|
||||
no warnings 'experimental';
|
||||
|
||||
|
@ -2,7 +2,7 @@ package LANraragi::Utils::TempFolder;
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
|
||||
use Cwd 'abs_path';
|
||||
use FindBin;
|
||||
|
@ -47,7 +47,7 @@ my $inotifysub = sub {
|
||||
my $e = shift;
|
||||
my $name = $e->path;
|
||||
my $type = $e->type;
|
||||
$logger->debug("收到 $name 上的 inotify 事件 $type");
|
||||
$logger->debug("Received inotify event $type on $name");
|
||||
|
||||
if ( $type eq "create" || $type eq "modify" ) {
|
||||
new_file_callback($name);
|
||||
@ -63,11 +63,11 @@ sub initialize_from_new_process {
|
||||
|
||||
my $userdir = LANraragi::Model::Config->get_userdir;
|
||||
|
||||
$logger->info("Shinobu文件监视器启动.");
|
||||
$logger->info("内容文件夹为: $userdir.");
|
||||
$logger->info("Shinobu File Watcher started.");
|
||||
$logger->info("Content folder is $userdir.");
|
||||
|
||||
update_filemap();
|
||||
$logger->info("初始扫描完成! 将观监视器添加到内容文件夹以监视进一步的文件变动。");
|
||||
$logger->info("Initial scan complete! Adding watcher to content folder to monitor for further file edits.");
|
||||
|
||||
# Add watcher to content directory
|
||||
my $contentwatcher = File::ChangeNotify->instantiate_watcher(
|
||||
@ -75,17 +75,17 @@ sub initialize_from_new_process {
|
||||
filter => qr/\.(?:zip|rar|7z|tar|tar\.gz|lzma|xz|cbz|cbr|cb7|cbt|pdf|epub)$/i,
|
||||
follow_symlinks => 1,
|
||||
exclude => [ 'thumb', '.' ], #excluded subdirs
|
||||
depth => 5, #扫描档案目录时扫描的最大目录深度
|
||||
depth => 10, #扫描档案目录时扫描的最大目录深度
|
||||
);
|
||||
|
||||
my $class = ref($contentwatcher);
|
||||
$logger->debug("文件监视器类名为: $class");
|
||||
$logger->debug("Watcher class is $class");
|
||||
|
||||
# Add watcher to tempfolder
|
||||
my $tempwatcher = File::ChangeNotify->instantiate_watcher( directories => [ get_temp() ] );
|
||||
|
||||
# manual event loop
|
||||
$logger->info("全部初始化已经完成,文件监视器正在全力监测文件变动。");
|
||||
$logger->info("All done! Now dutifully watching your files. ");
|
||||
|
||||
while (1) {
|
||||
|
||||
@ -107,22 +107,22 @@ sub initialize_from_new_process {
|
||||
# This computes IDs for all new archives and henceforth can get rather expensive!
|
||||
sub update_filemap {
|
||||
|
||||
$logger->info("正在扫描内容文件夹以查找更改...");
|
||||
$logger->info("Scanning content folder for changes...");
|
||||
my $redis = LANraragi::Model::Config->get_redis_config;
|
||||
|
||||
# Clear hash
|
||||
my $dirname = LANraragi::Model::Config->get_userdir;
|
||||
my @files;
|
||||
|
||||
# 在内容目录和子目录中获取所有文件。
|
||||
# Get all files in content directory and subdirectories.
|
||||
find(
|
||||
{ wanted => sub {
|
||||
return if -d $_; #目录当场被排除在外
|
||||
return if -d $_; #Directories are excluded on the spot
|
||||
return unless is_archive($_);
|
||||
push @files, $_; #将文件推入数组
|
||||
push @files, $_; #Push files to array
|
||||
},
|
||||
no_chdir => 5,
|
||||
follow_fast => 1 #扫描档案目录时扫描的最大目录深度
|
||||
no_chdir => 1,
|
||||
follow_fast => 1
|
||||
},
|
||||
$dirname
|
||||
);
|
||||
@ -136,13 +136,13 @@ sub update_filemap {
|
||||
my @newfiles = grep { !$filemaphash{$_} } @files;
|
||||
my @deletedfiles = grep { !$fshash{$_} } @filemapfiles;
|
||||
|
||||
$logger->info( "找到 " . scalar @newfiles . " 个新文件." );
|
||||
$logger->info( scalar @deletedfiles . " 个文件在数据库里找到文件,但在文件系统上找不到文件。" );
|
||||
$logger->info( "Found " . scalar @newfiles . " new files." );
|
||||
$logger->info( scalar @deletedfiles . " files were found on the filemap but not on the filesystem." );
|
||||
|
||||
# Delete old files from filemap
|
||||
foreach my $deletedfile (@deletedfiles) {
|
||||
$logger->debug("正在从数据库中删除 $deletedfile");
|
||||
$redis->hdel( "LRR_FILEMAP", $deletedfile ) || $logger->warn("无法从数据库中删除以前的文件数据。");
|
||||
$logger->debug("Removing $deletedfile from filemap.");
|
||||
$redis->hdel( "LRR_FILEMAP", $deletedfile ) || $logger->warn("Couldn't delete previous filemap data.");
|
||||
}
|
||||
|
||||
$redis->quit();
|
||||
@ -151,7 +151,7 @@ sub update_filemap {
|
||||
my $numCpus = Sys::CpuAffinity::getNumCpus();
|
||||
my $pl = Parallel::Loops->new($numCpus);
|
||||
|
||||
$logger->debug("可用于处理的核心数量: $numCpus");
|
||||
$logger->debug("Number of available cores for processing: $numCpus");
|
||||
my @sections = split_workload_by_cpu( $numCpus, @newfiles );
|
||||
|
||||
# Eval the parallelized file crawl to avoid taking down the entire process in case one of the forked processes dies
|
||||
@ -166,7 +166,7 @@ sub update_filemap {
|
||||
eval { add_to_filemap( $redis, $file ); };
|
||||
|
||||
if ($@) {
|
||||
$logger->error("扫描 $file 文件时出现错误: $@");
|
||||
$logger->error("Error scanning $file: $@");
|
||||
}
|
||||
}
|
||||
$redis->quit();
|
||||
@ -175,7 +175,7 @@ sub update_filemap {
|
||||
};
|
||||
|
||||
if ($@) {
|
||||
$logger->error("扫描内容文件夹时出错: $@");
|
||||
$logger->error("Error while scanning content folder: $@");
|
||||
}
|
||||
}
|
||||
|
||||
@ -184,14 +184,14 @@ sub add_to_filemap ( $redis_cfg, $file ) {
|
||||
my $redis_arc = LANraragi::Model::Config->get_redis;
|
||||
if ( is_archive($file) ) {
|
||||
|
||||
$logger->debug("将 $file 添加到 Shinobu 数据库。");
|
||||
$logger->debug("Adding $file to Shinobu filemap.");
|
||||
|
||||
#Freshly created files might not be complete yet.
|
||||
#We have to wait before doing any form of calculation.
|
||||
while (1) {
|
||||
last unless -e $file; # Sanity check to avoid sticking in this loop if the file disappears
|
||||
last if open( my $handle, '<', $file );
|
||||
$logger->debug("等待文件允许被打开");
|
||||
$logger->debug("Waiting for file to be openable");
|
||||
sleep(1);
|
||||
}
|
||||
|
||||
@ -199,7 +199,7 @@ sub add_to_filemap ( $redis_cfg, $file ) {
|
||||
my $cnt = 0;
|
||||
while (1) {
|
||||
last if ( ( ( -s $file ) >= 512000 ) || $cnt >= 5 );
|
||||
$logger->debug("等待文件完全写入磁盘");
|
||||
$logger->debug("Waiting for file to be fully written");
|
||||
sleep(1);
|
||||
$cnt++;
|
||||
}
|
||||
@ -209,23 +209,23 @@ sub add_to_filemap ( $redis_cfg, $file ) {
|
||||
eval { $id = compute_id($file); };
|
||||
|
||||
if ($@) {
|
||||
$logger->error("无法打开 $file 进行ID计算: $@");
|
||||
$logger->error("放弃将文件添加到数据库.");
|
||||
$logger->error("Couldn't open $file for ID computation: $@");
|
||||
$logger->error("Giving up on adding it to the filemap.");
|
||||
return;
|
||||
}
|
||||
|
||||
$logger->debug("计算出的ID为: $id.");
|
||||
$logger->debug("Computed ID is $id.");
|
||||
|
||||
# If the id already exists on the server, throw a warning about duplicates
|
||||
if ( $redis_cfg->hexists( "LRR_FILEMAP", $file ) ) {
|
||||
|
||||
my $filemap_id = $redis_cfg->hget( "LRR_FILEMAP", $file );
|
||||
|
||||
$logger->debug("$file 文件已经存在于数据库中!");
|
||||
$logger->debug("$file was logged but is already in the filemap!");
|
||||
|
||||
if ( $filemap_id ne $id ) {
|
||||
$logger->debug("$file 文件的ID与数据库中现有的ID不同! ($filemap_id)");
|
||||
$logger->info("$file 文件已被修改,已将其在数据库中的ID从 $filemap_id 修改为 $id.");
|
||||
$logger->debug("$file has a different ID than the one in the filemap! ($filemap_id)");
|
||||
$logger->info("$file has been modified, updating its ID from $filemap_id to $id.");
|
||||
|
||||
change_archive_id( $filemap_id, $id );
|
||||
|
||||
@ -233,7 +233,7 @@ sub add_to_filemap ( $redis_cfg, $file ) {
|
||||
$redis_cfg->hset( "LRR_FILEMAP", $file, $id );
|
||||
} else {
|
||||
$logger->debug(
|
||||
"$file 文件的ID与数据库内的ID一致. 可能是重复的 inotify 事件触发? 为了防止出现其他意外情况现在开始清理缓存");
|
||||
"$file has the same ID as the one in the filemap. Duplicate inotify events? Cleaning cache just to make sure");
|
||||
invalidate_cache();
|
||||
}
|
||||
|
||||
@ -251,12 +251,12 @@ sub add_to_filemap ( $redis_cfg, $file ) {
|
||||
#Update the real file path and title if they differ from the saved one
|
||||
#This is meant to always track the current filename for the OS.
|
||||
unless ( $file eq $filecheck ) {
|
||||
$logger->debug("在数据库和文件系统之间检测到文件名差异!");
|
||||
$logger->debug("文件系统: $file");
|
||||
$logger->debug("数据库内: $filecheck");
|
||||
$logger->debug("File name discrepancy detected between DB and filesystem!");
|
||||
$logger->debug("Filesystem: $file");
|
||||
$logger->debug("Database: $filecheck");
|
||||
my ( $name, $path, $suffix ) = fileparse( $file, qr/\.[^.]*/ );
|
||||
$redis_arc->hset( $id, " 所属文件: ", $file );
|
||||
$redis_arc->hset( $id, " 所属名字: ", redis_encode($name) );
|
||||
$redis_arc->hset( $id, "file", $file );
|
||||
$redis_arc->hset( $id, "name", redis_encode($name) );
|
||||
$redis_arc->wait_all_responses;
|
||||
invalidate_cache();
|
||||
}
|
||||
@ -268,7 +268,7 @@ sub add_to_filemap ( $redis_cfg, $file ) {
|
||||
|
||||
# Set pagecount in case it's not already there
|
||||
unless ( $redis_arc->hget( $id, "pagecount" ) ) {
|
||||
$logger->debug("未计算 $id 的页数,立即执行!");
|
||||
$logger->debug("Pagecount not calculated for $id, doing it now!");
|
||||
LANraragi::Utils::Database::add_pagecount( $redis_arc, $id );
|
||||
}
|
||||
|
||||
@ -279,7 +279,7 @@ sub add_to_filemap ( $redis_cfg, $file ) {
|
||||
invalidate_cache();
|
||||
}
|
||||
} else {
|
||||
$logger->debug("$file 未被识别为存档,正在跳过。");
|
||||
$logger->debug("$file not recognized as archive, skipping.");
|
||||
}
|
||||
$redis_arc->quit;
|
||||
}
|
||||
@ -288,7 +288,7 @@ sub add_to_filemap ( $redis_cfg, $file ) {
|
||||
# "handles the addition of new subdirectories by adding them to the watch list"
|
||||
sub new_file_callback ($name) {
|
||||
|
||||
$logger->debug("检测到新文件: $name");
|
||||
$logger->debug("New file detected: $name");
|
||||
unless ( -d $name ) {
|
||||
|
||||
my $redis = LANraragi::Model::Config->get_redis_config;
|
||||
@ -296,7 +296,7 @@ sub new_file_callback ($name) {
|
||||
$redis->quit();
|
||||
|
||||
if ($@) {
|
||||
$logger->error("处理新文件时出错: $@");
|
||||
$logger->error("Error while handling new file: $@");
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -305,7 +305,7 @@ sub new_file_callback ($name) {
|
||||
# Deleted subdirectories trigger deleted events for every file deleted.
|
||||
sub deleted_file_callback ($name) {
|
||||
|
||||
$logger->info("$name 已从内容文件夹中删除!");
|
||||
$logger->info("$name was deleted from the content folder!");
|
||||
unless ( -d $name ) {
|
||||
|
||||
my $redis = LANraragi::Model::Config->get_redis_config;
|
||||
@ -322,7 +322,7 @@ sub deleted_file_callback ($name) {
|
||||
sub add_new_file ( $id, $file ) {
|
||||
|
||||
my $redis = LANraragi::Model::Config->get_redis;
|
||||
$logger->info("添加 ID 为 $id 的新文件 $file");
|
||||
$logger->info("Adding new file $file with ID $id");
|
||||
|
||||
eval {
|
||||
LANraragi::Utils::Database::add_archive_to_redis( $id, $file, $redis );
|
||||
@ -334,7 +334,7 @@ sub add_new_file ( $id, $file ) {
|
||||
};
|
||||
|
||||
if ($@) {
|
||||
$logger->error("添加文件时出错: $@");
|
||||
$logger->error("Error while adding file: $@");
|
||||
}
|
||||
$redis->quit;
|
||||
}
|
||||
|
14
package.json
14
package.json
@ -1,8 +1,8 @@
|
||||
{
|
||||
"name": "lanraragi",
|
||||
"version": "0.9.10",
|
||||
"version_name": "行尸走肉",
|
||||
"description": "我一世英名恐怕要毁在日本文化的影响下了!",
|
||||
"version_name": "Dead Man Walking",
|
||||
"description": "I'm under Japanese influence and my honor's at stake!",
|
||||
"scripts": {
|
||||
"test": "prove -r -l -v tests/",
|
||||
"lanraragi-installer": "perl ./tools/install.pl",
|
||||
@ -11,21 +11,21 @@
|
||||
"dev-server": "perl ./script/launcher.pl -m -v ./script/lanraragi",
|
||||
"dev-server-verbose": "export LRR_DEVSERVER=1 && perl ./script/launcher.pl -m -v ./script/lanraragi",
|
||||
"kill-workers": "(kill -15 `cat ./public/temp/shinobu.pid-s6` || true) && (kill -15 `cat ./public/temp/minion.pid-s6` || true) && (pkill -9 -f ./script/lanraragi || true)",
|
||||
"docker-build": "docker build -t windycloud/lanraragi_cn:dev -f ./tools/build/docker/Dockerfile .",
|
||||
"docker-build": "docker build -t difegue/lanraragi -f ./tools/build/docker/Dockerfile .",
|
||||
"critic": "perlcritic ./lib/* ./script/* ./tools/install.pl",
|
||||
"backup-db": "perl ./script/backup",
|
||||
"get-version": "perl ./script/get_version"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "git+https://github.com/WindyCloudCute/LANraragi_Chinese.git"
|
||||
"url": "git+https://github.com/Difegue/LANraragi.git"
|
||||
},
|
||||
"author": "dfug",
|
||||
"license": "MIT",
|
||||
"bugs": {
|
||||
"url": "https://github.com/WindyCloudCute/LANraragi_Chinese/issues"
|
||||
"url": "https://github.com/Difegue/LANraragi/issues"
|
||||
},
|
||||
"homepage": "https://github.com/WindyCloudCute/LANraragi_Chinesei#readme",
|
||||
"homepage": "https://github.com/Difegue/LANraragi#readme",
|
||||
"dependencies": {
|
||||
"@fortawesome/fontawesome-free": "^6.2.1",
|
||||
"@jcubic/tagger": "^0.4.2",
|
||||
@ -52,4 +52,4 @@
|
||||
"eslint-config-airbnb-base": "^15.0.0",
|
||||
"eslint-plugin-import": "^2.26.0"
|
||||
}
|
||||
}
|
||||
}
|
@ -201,6 +201,18 @@ table.itg th {
|
||||
color: #34495E !important;
|
||||
}
|
||||
|
||||
.caption-tags>*>*>span {
|
||||
color: #34495E !important;
|
||||
}
|
||||
|
||||
#archive-categories .gt a {
|
||||
color: #E1E7E9;
|
||||
}
|
||||
|
||||
#archive-categories .gt a:hover {
|
||||
color: #ed2553;
|
||||
}
|
||||
|
||||
.tippy-arrow {
|
||||
color: #E1E7E9;
|
||||
}
|
||||
|
@ -3,12 +3,12 @@
|
||||
use strict;
|
||||
use warnings;
|
||||
use Cwd 'abs_path';
|
||||
|
||||
use Mojo::Base -strict;
|
||||
use Mojo::Server::Morbo;
|
||||
use Mojo::Server::Prefork;
|
||||
use Mojo::Util qw(extract_usage getopt);
|
||||
use File::Path qw(make_path);
|
||||
use utf8;
|
||||
|
||||
getopt
|
||||
'm|morbo' => \my $morbo,
|
||||
@ -55,7 +55,7 @@ if ($morbo) {
|
||||
$backend->daemon->listen(@listen);
|
||||
$backend->run($app);
|
||||
} else {
|
||||
print "服务器PID存放在 " . $hypno_pid . "\n";
|
||||
print "Server PID will be at " . $hypno_pid . "\n";
|
||||
|
||||
$backend = Mojo::Server::Prefork->new( keep_alive_timeout => 30 );
|
||||
$backend->pid_file($hypno_pid);
|
||||
|
Binary file not shown.
Before Width: | Height: | Size: 1.3 MiB After Width: | Height: | Size: 1.0 MiB |
@ -7,7 +7,7 @@ EXPOSE 3000
|
||||
# Enable UTF-8 (might not do anything extra on alpine tho)
|
||||
ENV LC_ALL=en_US.UTF-8 LANG=en_US.UTF-8 LANGUAGE=en_US.UTF-8 \
|
||||
# rootless user id
|
||||
LRR_UID=1000 LRR_GID=1000 \
|
||||
LRR_UID=0 LRR_GID=0 \
|
||||
# Environment variables overridable by the user on container deployment
|
||||
LRR_NETWORK=http://*:3000 \
|
||||
# extra variables
|
||||
@ -31,7 +31,7 @@ WORKDIR /tmp/lrr
|
||||
#This allows for Docker cache to preserve cpan dependencies
|
||||
COPY --chown=root:root /tools/cpanfile /tools/install.pl /tools/build/docker/install-everything.sh tools/
|
||||
COPY --chown=root:root /package.json package.json
|
||||
COPY --chown=root:root /package-lock.json package-lock.json
|
||||
COPY --chown=root:root /package-lock.json package-lock.json
|
||||
|
||||
# Run the install script as root, in dev mode to prevent wget etc from being uninstalled
|
||||
RUN sh ./tools/install-everything.sh -d
|
||||
|
@ -4,9 +4,9 @@ services:
|
||||
lanraragi:
|
||||
build:
|
||||
dockerfile: tools/build/docker/Dockerfile-dev
|
||||
context: ../../..
|
||||
context: ../..
|
||||
volumes:
|
||||
- ../../../:/root/lanraragi
|
||||
- ../../:/root/lanraragi
|
||||
ports:
|
||||
- "3000:3000"
|
||||
environment:
|
||||
|
@ -24,10 +24,10 @@ chmod -R u+rwx /root/lanraragi/database
|
||||
|
||||
if [ "$FIX_PERMS" -eq 1 ]; then
|
||||
echo "Fixing permissions, hold on!"
|
||||
#Ensure thumbnail folder is writable
|
||||
chown -R root /root/lanraragi/content/thumb
|
||||
find /root/lanraragi/content/thumb -type f -exec chmod u+rw {} \;
|
||||
find /root/lanraragi/content/thumb -type d -exec chmod u+rwx {} \;
|
||||
#Ensure thumbnail folder is writable
|
||||
chown -R root /root/lanraragi/content/thumb
|
||||
find /root/lanraragi/content/thumb -type f -exec chmod u+rw {} \;
|
||||
find /root/lanraragi/content/thumb -type d -exec chmod u+rwx {} \;
|
||||
|
||||
# Ensure the rest of the content folder is at least readable
|
||||
find /root/lanraragi/content -name thumb -prune -o -type f -exec chmod u+r {} \;
|
||||
|
@ -2,11 +2,11 @@
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use utf8;
|
||||
use open ':std', ':encoding(UTF-8)';
|
||||
use Cwd;
|
||||
use Config;
|
||||
use utf8;
|
||||
|
||||
use File::Copy;
|
||||
use feature qw(say);
|
||||
use File::Path qw(make_path);
|
||||
|
Loading…
Reference in New Issue
Block a user