还原部分代码片段 并尝试修复 (#3)

This commit is contained in:
WindyMadman 2023-12-11 00:42:11 +08:00
parent 5fb48e8921
commit 612c2a5422
28 changed files with 179 additions and 120 deletions

View File

@ -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
View File

@ -13,4 +13,4 @@ autobackup.json
lib/LANraragi/Plugin/Scripts/ETagConverter.pm
lib/LANraragi/Plugin/Metadata/ETagCN.pm
Makefile
oshino
oshino

View File

@ -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();
}

View File

@ -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;

View File

@ -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",

View File

@ -2,7 +2,7 @@ package LANraragi::Model::Plugins;
use strict;
use warnings;
use utf8;
use feature 'fc';
use Redis;

View File

@ -2,7 +2,7 @@ package LANraragi::Model::Reader;
use strict;
use warnings;
use utf8;
use Redis;
use File::Basename;

View File

@ -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);

View File

@ -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;

View File

@ -23,7 +23,7 @@ sub plugin_info {
author => "CirnoT, Difegue",
version => "2.1",
description => " 在Koromo 风格的 Info.json 文件收集作为嵌入到档案中的元数据. ( {'Tags': [xxx] } syntax)",
icon =>
icon =>
"",
parameters => []
);

View File

@ -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);

View File

@ -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);

View File

@ -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 "";
}

View File

@ -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!";
}

View File

@ -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 );

View File

@ -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);

View File

@ -2,7 +2,7 @@ package LANraragi::Utils::Routing;
use strict;
use warnings;
use utf8;
use Mojolicious::Plugin::Status;
use Mojolicious::Plugin::Minion::Admin;

View File

@ -2,7 +2,7 @@ package LANraragi::Utils::Tags;
use strict;
use warnings;
use utf8;
use feature "switch";
no warnings 'experimental';

View File

@ -2,7 +2,7 @@ package LANraragi::Utils::TempFolder;
use strict;
use warnings;
use utf8;
use Cwd 'abs_path';
use FindBin;

View File

@ -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;
}

View File

@ -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"
}
}
}

View File

@ -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;
}

View File

@ -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

View File

@ -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

View File

@ -4,9 +4,9 @@ services:
lanraragi:
build:
dockerfile: tools/build/docker/Dockerfile-dev
context: ../../..
context: ../..
volumes:
- ../../../:/root/lanraragi
- ../../:/root/lanraragi
ports:
- "3000:3000"
environment:

View File

@ -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 {} \;

View File

@ -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);